In this part i want to take a basic look on the plugin itself and its main structure. Or with other words the files your plugin MUST have in order to be a valud plugin. In the next part (Part 3) we will see some additional files which you can add to your app, but they are not mandatory for a valid plugin.
All the plugins are stored in the ./apps/ folder (take a look on this page for more detailed information). Sample apps folder structure:
./apps/
plugin_name_1/
plugin_name_2/
...
plugin_name_X/
plugin.php
/apps/my_plugin/plugin.php
- All events reactions( onPostLoad(), etc ), MUST be placed in a class with the SAME NAME as you plugins folder. So lets say you have ./apps/plugin_name/plugin.php. The class in the plugin.php file should be plugin_name (class plugin_name{}).
- Class methods names are the same as the events you want to attach your plugin. So if you want to attach some actions on onPostLoad() event you should have onPostLoad() method in your class in the plugin.php file.
- It is NOT mandotory to extend your plugin class with the plugin class but it is recommended. Your plugin will work without this, but the plugin class contains some useful ready to be used methods and variables which you do not have to write again.
In Sharetronix there are a number of events which are triggered on some specific cases. Take a look on this event list. For example there is event onPageLoad() which is triggered when the page is loaded so you will have a chance to set some changes on the loaded page before it is loaded. Take a look on Part 1 to see how to change the header.
- <?php
- class myplugin extends plugin
- {
- public function onPageLoad()
- {
- global $C;
- $this->setDelimiter( ' - ' );
- $this->setVar( 'page_title', 'hopa tropa' );
- if( $this->getCurrentController() == 'dashboard' ){
- $this->setVar( 'main_content', '2' );
- }
- }
- }
- ?>
Clarification: before a plugin is triggered on a specific event, before that the controller of the page where we are located on this moment is loaded first. This means the controller prepare some data for the view and after that the plugins are triggered and they can change that data(delete/add).
class plugin{}
This class contains the following properties:
$db2 - link to your database connection.
$network - network class, where a lot of cache functions are stored.
$page - class to read page parameters
$cache - if you want to use the cache
$user - the current user data
And the following methods
setVar( $name, $value, $action = 'add', $priority = 0 )
This is a main method, it is used to store data in the template. Take a look on the template view in Part 1. With this method you can store data in the template placeholder({%placeholder_name%}) you want. Example:
$this->setVar('placeholder_name', 'value'); //where the value is HTML value you want to store in the template.
The $action parameter by detault is "add", so you will add cont in the template placeholder you want. So, if the controller set the placeholder_name to be "<b>Some Text</b>", and after that you and your plugin set placeholder_name to be "<i>another text</i>", the result in placeholder_name in the end in the template will be "<b>Some Text</b><i>another text</i>". This is because setVar() action by default is "add" - add information, if you set the action to be "replace" the plugin will replace the controller value. Ex.
$this->setVar('placeholder_name ', '<i>another text</i>', 'replace');
in this case in the placeholder_name in the template will only have "<i>another text</i>", no matter waht the controller(or other plugin has set).
setDelimiter( $value )
This method is very useful when you add some data in the template placeholder where the controller already has stored something else, like the previous example. Example:
controller sets "<b>Some Text</b>" in the template placeholder_name.
$this->setVar('placeholder_name ', '<i>another text</i>'); //you add '<i>another text</i>' in the template
The result in placeholder_name
<b>Some Text</b><i>another text</i>
but you can use the setDelimiter() method to separate the texts.
$this->setDelimiter(' && ');
$this->setVar('placeholder_name ', '<i>another text</i>'); //you add '<i>another text</i>' in the template
The result in placeholder_name
<b>Some Text</b> && <i>another text</i>
getCurrentController()
Returns the name of the current controller where we are located, eg. dahboard, members, group.
This is very useful if you want your plugin to be active onPageLoad() event and only in the user profile eg. controller name user.
getCurrentTab()
This is similar to the upper method but it return the current active tab in the controller we are located eg. all, posts, etc. So your app to be active only in a specific tab.
isMobileRegime()
Returns TRUE or FALSE. If you are in the mobile interface it will returns TRUE, else FALSE. This is very useful when you want to put different content(HTML) in the mobile site.
manifest.json file
This is the second mandatory file your plugin should have. Contains the following information:
{
"plugin_name": "The name of your plugin, must be same as your plugin folder name and class in plugin.php file",
"descr": "Basic description for your plugin.",
"version": "1.0",
"author": "Your name ",
"email": "email@email.com"
}
In the end a valid plugin should contain these two files:
./apps/app_name/plugin.php
./apps/app_name/manifest.json
that's all.
P.S. When your plugin is ready it should be zipped and named like the folder in ./apps/ you want to create. The zip file should contain that folder. eg.
your_plugin_name.zip/
your_plugin_name/
plugin.php
manifest.json
Няма коментари:
Публикуване на коментар