-
-
Notifications
You must be signed in to change notification settings - Fork 29
How to create an module can be downloaded from github
This tuto help you how to create a module to be downloaded from github communiy or official add on.
In the future, it will be integrated (maybe) inside the application to allow the community to push their module on GitHub ClicShopping community.
In this tuto, we create a new module called: module_header_tags_favicon
Note,: In different apps, you can also create a header tag module: For example like products app to include an header tag facebook. If you module header tag is used in all the website, it's better to follow this example.
Very important: All the modules start must begin by : module_
module_apps_best_selling, module_header_tags_touch_icon, modules_header_bootstrap_caroussel
The structure of the directory
module_header_tags_favicon ===> note : the directory must have the same name of your module
readme.md LICENCSE -- includes ----modules ----header_tags -- ModulesInfosJson -- sources ---- images ------ icons ---- languages ------ english -------- modules ----------header_tags ------ french -------- modules ----------header_tags
Step 1 Insides this directory : header_tags create a file called ht_favicon.php
-- includes
----modules
----header_tags
----- ht_favicon.php
insert this code
<?php /** * * @copyright 2008 - https://www.clicshopping.org * @Brand : ClicShopping(Tm) at Inpi all right Reserved * @Licence GPL 2 & MIT * @licence MIT - Portion of osCommerce 2.4 * @Info : https://www.clicshopping.org/forum/trademark/ * */ use ClicShopping\OM\Registry; use ClicShopping\OM\HTTP; use ClicShopping\OM\CLICSHOPPING; class ht_favicon { public $code; public $group; public $title; public $description; public $sort_order; public $enabled = false; public function __construct() { $this->code = get_class($this); $this->group = basename(__DIR__); $this->title = CLICSHOPPING::getDef('module_header_tags_favicon_title'); $this->description = CLICSHOPPING::getDef('module_header_tags_favicon_description'); if ( defined('MODULE_HEADER_TAGS_FAVICON_STATUS') ) { $this->sort_order = MODULE_HEADER_TAGS_FAVICON_SORT_ORDER; $this->enabled = (MODULE_HEADER_TAGS_FAVICON_STATUS == 'True'); } } public function execute() { $CLICSHOPPING_Template = Registry::get('Template'); $extansion_favicon = MODULE_HEADER_TAGS_FAVICON_EXTENSION_FAVICON; $CLICSHOPPING_Template->addBlock('<link rel="icon" type="image/' . $extansion_favicon . '" href="' . HTTP::getShopUrlDomain() . 'sources/images/icons/favicon.' . $extansion_favicon . '">', $this->group); } public function isEnabled() { return $this->enabled; } public function check() { return defined('MODULE_HEADER_TAGS_FAVICON_STATUS'); } public function install() { $CLICSHOPPING_Db = Registry::get('Db'); $CLICSHOPPING_Db->save('configuration', [ 'configuration_title' => 'Do you want install this module ?', 'configuration_key' => 'MODULE_HEADER_TAGS_FAVICON_STATUS', 'configuration_value' => 'True', 'configuration_description' => 'Do you want activate this module ?', 'configuration_group_id' => '6', 'sort_order' => '1', 'set_function' => 'osc_cfg_set_boolean_value(array(\'True\', \'False\'))', 'date_added' => 'now()' ] ); $CLICSHOPPING_Db->save('configuration', [ 'configuration_title' => 'Choose favicon extansion ?', 'configuration_key' => 'MODULE_HEADER_TAGS_FAVICON_EXTENSION_FAVICON', 'configuration_value' => 'png', 'configuration_description' => 'Extansion allowed : png, gif ou ico : <br /><br /><strong>Note :</strong><br /><br />- The favicon must be in the sources/image/icons directory', 'configuration_group_id' => '6', 'sort_order' => '1', 'set_function' => 'osc_cfg_set_boolean_value(array(\'png\', \'gif\', \'ico\'))', 'date_added' => 'now()' ] ); $CLICSHOPPING_Db->save('configuration', [ 'configuration_title' => 'Display sort order', 'configuration_key' => 'MODULE_HEADER_TAGS_FAVICON_SORT_ORDER', 'configuration_value' => '75', 'configuration_description' => 'Display sort order (lower is displayed in first)', 'configuration_group_id' => '6', 'sort_order' => '55', 'set_function' => '', 'date_added' => 'now()' ] ); return $CLICSHOPPING_Db->save('configuration', ['configuration_value' => '1'], ['configuration_key' => 'WEBSITE_MODULE_INSTALLED'] ); } public function remove() { return Registry::get('Db')->exec('delete from :table_configuration where configuration_key in ("' . implode('", "', $this->keys()) . '")'); } public function keys() { return array('MODULE_HEADER_TAGS_FAVICON_STATUS', 'MODULE_HEADER_TAGS_FAVICON_EXTENSION_FAVICON', 'MODULE_HEADER_TAGS_FAVICON_SORT_ORDER'); } }
Step 2 : In ModuleInfosJson directory, create module_header_tags_favicon.json
ModuleInfosJson
-- module_header_tags_favicon.json
Note : module_header_tags_favicon.json has the same namo of you root directory
the json must have these elements
{
"title": "module_header_tags_favicon",
"type": "meta tag",
"vendor": "ClicShopping",
"is_free": "yes",
"is_free": "no",
"website_link_to_sell" : "",
"version": 1.0,
"req_core_version": 3.0,
"license": "GPL 2",
"tag": "header tag, script, meta tag, favicon",
"install": "includes/modules/",
"module_directory": "header_tags",
"apps_name": "",
"type_module": "fixe",
"dependance": "",
"description": "This module allow you to insert a favicon inside your site",
"image": "",
"authors": [
{
"name": "ClicShopping Team",
"company": "",
"email": "",
"website": "",
"Community": "http://www.clicshopping.org"
}
]
}
Note on the most important json elements :
- title must have the same name of your directory
- type : apps or modules_directory (ex : modules_footer)
- is_free : Yes or No (if no include your link in website_link_to_sell)
- is_core : Yes or No
- type module : fixe or template
- dependance : if you must have another module to use this module. For example a hook
- module_directory: Module directory
- apps_name : Apps Directory name
Step 3 : Image
In icons directory
-- sources
---- images
------ icons
In icons directory insert : favico.gif, favicon.ico, favicon.png
Step 4 Languages
---- languages
------ english
-------- modules
----------header_tags
------ french
-------- modules
----------header_tags
In each header_tags directory insert this file : ht_favicon.txt and include inside
for english :
module_header_tags_favicon_title = Do you want use Favicon balise
module_header_tags_favicon_description = Add favicon balise in the store
for french :
module_header_tags_favicon_title = Souhaitez utiliser la balise Favicon pour afficher une petite image à cotè de l'URL ?
module_header_tags_favicon_description = Ajouter une petite image en 64x64 à coté de l'URL
Copyright ClicSHopping