Author: Simon Roberts simon@snails.email
This module provides a centralized toolkit including input, display, stats and substantial more comprehensive applications, so that each module does not need to develop its own tag handling scripts.
Check http://en.wikipedia.org/wiki/Tags for more info about "tag"
The following goes in the .htaccess if your running apache2 in the XOOPS_ROOT_PATH
RewriteEngine On
RewriteRule ^tags/index.html ./modules/tag/index.php [L,NC,QSA]
RewriteRule ^tags/index-(.*?).html ./modules/tag/index.php?dirname=$1 [L,NC,QSA]
RewriteRule ^tags/feed.rss ./modules/tag/backend.php [L,NC,QSA]
RewriteRule ^tags/feed-(.*?).rss ./modules/tag/backend.php?dirname=$1 
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&termid=$7 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)/([0-9]+)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&catid=$7&termid=$8 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)-(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&termid=$7&dirname=$8 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)/([0-9]+)-(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&catid=$4&termid=$7&dirname=$8 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&term=$7 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)/(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&catid=$7&term=$8 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/(.*?)-(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&term=$7&dirname=$8 [L,NC,QSA]
RewriteRule ^tags/(view|list|feed)/(tag|cat)/([0-9]+)/(count|time|term)/(ASC|DESC)/(cloud|list)/([0-9]+)/(.*?)-(.*?)(.html|.rss) ./modules/tag/$1.$2.php?start=$3&sort=$4&order=$5&mode=$6&catid=$7&term=$8&dirname=$9 [L,NC,QSA]
To enable tag for a module ("mymodule"), following steps are need:
- add tag input box to your item edit form (required)
- add tag storage to your item submission page (required)
- define functions to build info of tagged items (required)
- add tag display API to your item display page and include tag template in your item template (optional)
- add module tag view page and tag list page (optional)
- add module tag blocks (optional)
This is how you would set up an inclusion of the tag module in an itemised edit form in your module, this is not explicit example and could have variegates for the module you are writing or editing.
// File: edit.item.php
$itemid = $item_obj->isNew() ? 0 : $item_obj->getVar("itemid");
include_once XOOPS_ROOT_PATH . "/modules/tag/include/formtag.php";
$form_item->addElement(new XoopsFormTag("item_tag", 60, 255, $itemid, $catid = 0));
This is how you would set up an inclusion of the tag module in an itemised submition form in your module, this is not explicit example and could have variegates for the module you are writing or editing.
// File: submit.item.php
$handler = xoops_getmodulehandler('tag', 'tag');
$handler->updateByItem($_POST["item_tag"], $itemid, $xoopsModule->getVar("dirname"), $catid = 0);
This is the plugin for the tag module to enable the taging in both the tag module and the module you are writing/editing! Editing File Example: /modules/tag/plugin/mymodule.php
function mymodule_tag_iteminfo(&$items)
{
    $items_id = array();
    foreach (array_keys($items) as $cat_id) {
        // Some handling here to build the link upon catid
            // If catid is not used, just skip it
        foreach (array_keys($items[$cat_id]) as $item_id) {
            // In article, the item_id is "art_id"
            $items_id[] = intval($item_id);
        }
    }
    $item_handler =& xoops_getmodulehandler('item', 'mymodule');
    $items_obj = $item_handler->getObjects(new Criteria("id", "(" . implode(", ", $items_id) . ")", "IN"), true);
    $myts =& MyTextSanitizer::getInstance();
    foreach (array_keys($items) as $cat_id) {
        foreach (array_keys($items[$cat_id]) as $item_id) {
            $item_obj =& $items_obj[$item_id];
            if (is_object($item_obj))
                $items[$cat_id][$item_id] = array(
                    "title"     => $item_obj->getVar("subject"),
                    "uid"       => $item_obj->getVar("uid"),
                    "link"      => "index.php?id={$item_id}",
                    "url"       => XOOPS_URL . "/modules/mymodule/index.php?id={$item_id}",
                    "time"      => formatTimestamp($item_obj->getVar("date"), "s"),
                    "tags"      => tag_parse_tag($item_obj->getVar("tags", "n")),
                    "category"  => tag_parse_category($cat_id),
                    "content"   => $myts->displayTarea($item_obj->getVar("page_description"),true,true,true,true,true,true)
                    );
        }
    }
    unset($items_obj);    
    return $items;
}
function mymodule_tag_synchronization($mid) 
{
    // Optional
}
function mymodule_tag_category($catid) 
{
    return array('catid'=>0, 'parentid' =>0, 'term' =>'Category Title');
}
function mymodule_tag_supported() 
{
    return false;
}
Get's if tag's module (parent) version supported and module version (child) supported (new function in plugin since 2.30)
function mymodule_tag_version() 
{
    return array('parent' => 3.02, 'child' => 1.69);
}
These files are not explicit as filenames they could be different this is how to display the tag in the item of the module you are editing/writing.
include_once XOOPS_ROOT_PATH."/modules/tag/include/tagbar.php";
$xoopsTpl->assign('tagbar', tagBar($itemid, $catid = 0));
<{include file="db:bar.html"}>
This is the files that belong in /modules/mymodule/xxxx.xxx.php for redirecting or displaying within your module the tag lists and views as well as categories
 include "header.php";
 include XOOPS_ROOT_PATH . "/modules/tag/list.tag.php";
 include "header.php";
 include XOOPS_ROOT_PATH . "/modules/tag/view.tag.php";
 include "header.php";
 include XOOPS_ROOT_PATH . "/modules/tag/list.cat.php";
 include "header.php";
 include XOOPS_ROOT_PATH . "/modules/tag/view.cat.php";
This is where you create the blocks you will have to edit and create files for this within your module
 /*
  * $options:  
  *                    $options[0] - number of tags to display
  *                    $options[1] - time duration, in days, 0 for all the time
  *                    $options[2] - max font size (px or %)
  *                    $options[3] - min font size (px or %)
  */
 $modversion["blocks"][]    = array(
     "file"            => "mymodule_block_tag.php",
     "name"            => "Module Tag Cloud",
     "description"    => "Show tag cloud",
     "show_func"        => "mymodule_block_cloud_show",
     "edit_func"        => "mymodule_block_cloud_edit",
     "options"        => "100|0|150|80",
     "template"        => "mymodule_block_cloud.html",
     );
 /*
  * $options:
  *                    $options[0] - number of tags to display
  *                    $options[1] - time duration, in days, 0 for all the time
  *                    $options[2] - sort: a - alphabet; c - count; t - time
  */
 $modversion["blocks"][]    = array(
     "file"            => "mymodule_block_tag.php",
     "name"            => "Module Top Tags",
     "description"    => "Show top tags",
     "show_func"        => "mymodule_block_top_show",
     "edit_func"        => "mymodule_block_top_edit",
     "options"        => "50|30|c",
     "template"        => "mymodule_block_top.html",
     );
 /*
  * $options:
  */
 $modversion["blocks"][]    = array(
     "file"            => "mymodule_block_cumulus.php",
     "name"            => "Module Top Tags",
     "description"    => "Show top tags",
     "show_func"        => "mymodule_block_cumulus_show",
     "edit_func"        => "mymodule_block_cumulus_edit",
     "options"        => "",
     "template"        => "mymodule_block_cumulus.html",
     );
This file belongs in /modules/mymodule/blocks and is adjustable in function names and filename in the xoops_version.php as seen in the example above.
 function mymodule_block_cloud_show($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_cloud_show($options, basename(dirname(__DIR__)));
 }
 function mymodule_block_cloud_edit($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_cloud_edit($options);
 }
 function mymodule_block_top_show($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_top_show($options, basename(dirname(__DIR__));
 }
 function mymodule_block_top_edit($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_top_edit($options);
 }
This file belongs in /modules/mymodule/blocks and is adjustable in function names and filename in the xoops_version.php as seen in the example above.
 function mymodule_block_cumulus_show($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_cumulus_show($options, basename(dirname(__DIR__)));
 }
 function mymodule_block_cumulus_edit($options) 
 {
     include_once XOOPS_ROOT_PATH . "/modules/tag/blocks/block.php";
     return block_cumulus_edit($options);
 }
This file belongs in /modules/mymodule/templates/blocks and is adjustable in function names and filename in the xoops_version.php as seen in the example above.
 <{include file="db:block_cloud.html"}>
This file belongs in /modules/mymodule/templates/blocks and is adjustable in function names and filename in the xoops_version.php as seen in the example above.
 <{include file="db:block_top.html"}>
This file belongs in /modules/mymodule/templates/blocks and is adjustable in function names and filename in the xoops_version.php as seen in the example above.
 <{include file="db:block_cumulus.html"}>