Merge pull request #204 from nexx/master

[Tags Plugin] Enable sorting & beautify with ucfirst()
This commit is contained in:
Diego Najar 2016-01-22 16:22:27 -03:00
commit 2288075874
2 changed files with 42 additions and 8 deletions

View File

@ -3,5 +3,9 @@
{ {
"name": "Tags list", "name": "Tags list",
"description": "Shows all tags." "description": "Shows all tags."
} },
"tag-sort-order": "Sort the tag list by",
"tag-sort-alphabetical": "Alphabetical order",
"tag-sort-count": "Number of times each tag has been used",
"tag-sort-date": "Date each tag was first used"
} }

View File

@ -5,7 +5,8 @@ class pluginTags extends Plugin {
public function init() public function init()
{ {
$this->dbFields = array( $this->dbFields = array(
'label'=>'Tags' 'label'=>'Tags',
'sort'=>'date'
); );
} }
@ -18,6 +19,19 @@ class pluginTags extends Plugin {
$html .= '<input name="label" id="jslabel" type="text" value="'.$this->getDbField('label').'">'; $html .= '<input name="label" id="jslabel" type="text" value="'.$this->getDbField('label').'">';
$html .= '</div>'; $html .= '</div>';
$html .= '<div>';
$html .= $Language->get('tag-sort-order').': <select name="sort">';
foreach(array('alpha'=>'tag-sort-alphabetical', 'count'=>'tag-sort-count', 'date'=>'tag-sort-date') as $key=>$value) {
if ($key == $this->getDbField('sort')) {
$html .= '<option value="'.$key.'" selected>'.$Language->get($value).'</option>';
} else {
$html .= '<option value="'.$key.'">'.$Language->get($value).'</option>';
}
}
$html .= '</select>';
$html .= '</div>';
return $html; return $html;
} }
@ -37,12 +51,28 @@ class pluginTags extends Plugin {
foreach($db as $tagKey=>$fields) foreach($db as $tagKey=>$fields)
{ {
$count = $dbTags->countPostsByTag($tagKey); $tagArray[] = array('tagKey'=>$tagKey, 'count'=>$dbTags->countPostsByTag($tagKey), 'name'=>ucfirst($fields['name']));
// Print the parent
$html .= '<li><a href="'.HTML_PATH_ROOT.$filter.'/'.$tagKey.'">'.$fields['name'].' ('.$count.')</a></li>';
} }
// Sort the array based on options
if ($this->getDbField('sort') == "count")
{
usort($tagArray, function($a, $b) {
return $b['count'] - $a['count'];
});
}
elseif ($this->getDbField('sort') == "alpha")
{
usort($tagArray, function($a, $b) {
return strcmp($a['tagKey'], $b['tagKey']);
});
}
foreach($tagArray as $tagKey=>$fields)
{
// Print the parent
$html .= '<li><a href="'.HTML_PATH_ROOT.$filter.'/'.$fields['tagKey'].'">'.$fields['name'].' ('.$fields['count'].')</a></li>';
}
$html .= '</ul>'; $html .= '</ul>';
$html .= '</div>'; $html .= '</div>';
$html .= '</div>'; $html .= '</div>';