thelia / keyword-module
Associate contents, folders, categories and products to one or more keywords
Installs: 1 971
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 7
Forks: 7
Open Issues: 3
Type:thelia-module
pkg:composer/thelia/keyword-module
Requires
- thelia/installer: ~1.0
README
This module is used to associate category, product, content or folders to one or more keywords. This allows you for example to display items based on a particular keyword or structure your page with a tag system.
How to install
This module must be into your modules/ directory (thelia/local/modules/).
You can download the .zip file of this module or create a git submodule into your project like this :
cd /path-to-thelia
git submodule add https://github.com/thelia-modules/Keyword.git local/modules/Keyword
Next, go to your Thelia admin panel for module activation.
How to use
You can manage your keywords on the configuration view of the module with the "configure" button on the modules list.
To associate one or more keywords to a content or a folder, go to tab "Modules" of content or folder editing view.
This module allow you to use 6 new loops : keyword_category, keyword_product, keyword_content, keyword_folder, keyword_group and keyword.
Since v3.1.0 you can use classic loops (category, product, content, folder) with the argument "keyword" to filter the results (and keyword_match_mode : exact or partial).
Ex :
{loop name="categories" type="category" keyword="my_keyword" keyword_match_mode="exact"}
    ...
{/loop}
Here is an example of using each :
Use the keyword_category loop (list of categories related to the "my_keyword" keyword)
{loop name="categories" type="keyword_category" keyword="my_keyword" association_order="manual_reverse"}
    ...
{/loop}
Use the keyword_product loop (list of products related to the "my_keyword" keyword)
{loop name="products" type="keyword_product" keyword="my_keyword" association_order="manual_reverse"}
    ...
{/loop}
Use the keyword_content loop (list of contents related to the "my_keyword" keyword)
{loop name="contents" type="keyword_content" keyword="my_keyword" folder="1" association_order="manual_reverse"}
    ...
{/loop}
Use the keyword_folder loop (list of folders related to the "my_keyword" keyword)
{loop name="folders" type="keyword_folder" keyword="my_keyword"}
    ...
{/loop}
Use the keyword_category loop (list of categories related to the "my_keyword" keyword)
{loop name="categories" type="keyword_category" keyword="my_keyword"}
    ...
{/loop}
Use the keyword_product loop (list of products related to the "my_keyword" keyword)
{loop name="products" type="keyword_product" keyword="my_keyword"}
    ...
{/loop}
Use the keyword loop (list all keywords that are visible)
{loop name="keyword_list" type="keyword" visible="*" order="manual" backend_context="1" lang=$lang_id}
    ...
{/loop}
Use the keyword group loop (list all keyword groups that are visible)
{loop name="keyword_group_list" type="keyword_group" visible="*" order="manual" backend_context="1" lang=$lang_id}
    ...
{/loop}
You can also check the association between a keyword and a category, a product, a folder or a content by using Smarty extension available in the latest version of this plugin :
Check if thelia object is associated with keyword "my_keyword"
{category_has_keyword category_id=$ID keyword_code="my_keyword"} {* return true/false if relation exist or not *}
{product_has_keyword product_id=$ID keyword_code="my_keyword"}
{folder_has_keyword folder_id=$ID keyword_code="my_keyword"}
{content_has_keyword content_id=$ID keyword_code="my_keyword"}