mirror of
https://github.com/silverstripe/silverstripe-blog
synced 2024-06-27 15:09:41 +02:00
127 lines
3.1 KiB
PHP
127 lines
3.1 KiB
PHP
<?php
|
|
|
|
namespace SilverStripe\Blog\Widgets;
|
|
|
|
use SilverStripe\Blog\Model\Blog;
|
|
use SilverStripe\Core\Convert;
|
|
use SilverStripe\Forms\DropdownField;
|
|
use SilverStripe\ORM\ArrayList;
|
|
use SilverStripe\ORM\DataObject;
|
|
use SilverStripe\ORM\DB;
|
|
use SilverStripe\Widgets\Model\Widget;
|
|
use SilverStripe\Control\Controller;
|
|
|
|
if (!class_exists(Widget::class)) {
|
|
return;
|
|
}
|
|
|
|
/**
|
|
* @method Blog Blog()
|
|
*/
|
|
class BlogTagsCloudWidget extends Widget
|
|
{
|
|
/**
|
|
* @var string
|
|
*/
|
|
private static $title = 'Tags Cloud';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
private static $cmsTitle = 'Blog Tags Cloud';
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
private static $description = 'Displays a tag cloud for this blog.';
|
|
|
|
/**
|
|
* @var array
|
|
*/
|
|
private static $db = [];
|
|
|
|
/**
|
|
* @var array
|
|
*/
|
|
private static $has_one = [
|
|
'Blog' => Blog::class,
|
|
];
|
|
|
|
/**
|
|
* @var string
|
|
*/
|
|
private static $table_name = 'BlogTagsCloudWidget';
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getCMSFields()
|
|
{
|
|
$this->beforeUpdateCMSFields(function ($fields) {
|
|
/*
|
|
* @var FieldList $fields
|
|
*/
|
|
$fields->push(
|
|
DropdownField::create(
|
|
'BlogID',
|
|
_t(__CLASS__ . '.Blog', 'Blog'),
|
|
Blog::get()->map()
|
|
)
|
|
);
|
|
});
|
|
|
|
return parent::getCMSFields();
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
public function getTags()
|
|
{
|
|
if ($blog = $this->Blog()) {
|
|
$escapedID = Convert::raw2sql($blog->ID);
|
|
$sql = 'SELECT DISTINCT "BlogTag"."URLSegment","BlogTag"."Title",Count("BlogTagID") AS "TagCount"
|
|
from "BlogPost_Tags"
|
|
INNER JOIN "BlogPost"
|
|
ON "BlogPost"."ID" = "BlogPost_Tags"."BlogPostID"
|
|
INNER JOIN "BlogTag"
|
|
ON "BlogTag"."ID" = "BlogPost_Tags"."BlogTagID"
|
|
WHERE "BlogID" = ' . $escapedID
|
|
. ' GROUP By "BlogTag"."URLSegment","BlogTag"."Title"
|
|
ORDER BY "Title"';
|
|
|
|
$records = DB::query($sql);
|
|
$bloglink = $blog->Link();
|
|
$maxTagCount = 0;
|
|
|
|
// create DataObjects that can be used to render the tag cloud
|
|
$tags = ArrayList::create();
|
|
foreach ($records as $record) {
|
|
$tag = DataObject::create();
|
|
$tag->TagName = $record['Title'];
|
|
$link = Controller::join_links($bloglink, 'tag', $record['URLSegment']);
|
|
$tag->Link = $link;
|
|
if ($record['TagCount'] > $maxTagCount) {
|
|
$maxTagCount = $record['TagCount'];
|
|
}
|
|
$tag->TagCount = $record['TagCount'];
|
|
$tags->push($tag);
|
|
}
|
|
|
|
// normalize the tag counts from 1 to 10
|
|
if ($maxTagCount) {
|
|
$tagfactor = 10 / $maxTagCount;
|
|
foreach ($tags->getIterator() as $tag) {
|
|
$normalized = round($tagfactor * ($tag->TagCount));
|
|
$tag->NormalizedTag = $normalized;
|
|
}
|
|
}
|
|
|
|
|
|
return $tags;
|
|
}
|
|
|
|
return [];
|
|
}
|
|
}
|