Skip to content

[yima, zend framework 2, zf2 module] Widgets are standalone application or part of a module that can embed into web pages (written inside codes or by ajax call) as html code block.

License

Notifications You must be signed in to change notification settings

YiMAproject/yimaWidgetator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

75 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Widgetator Layout Module

this module is part of Yima Application Framework

See it in action

What is widget

Widget is a class that implement minimal interface WidgetInterface

interface WidgetInterface
{
    /**
     * Render widget as string output
     *
     * @return string
     */
    public function render();
}

Widget plugin manager

Widgets stored in widget plugin manager (serviceLocator for widgets). stored with serviceManager key yimaWidgetator.WidgetManager and build as factory service.

Define widget(s) from merged config

return array(
    /**
     * Register Widgets in WidgetManager
     *
     * each widget must instance of WidgetInterface
     */
    'yima_widgetator' => [
        // This is configurable service manager config
        'services' => [
            'invokables' => [
                # 'widgetName' => 'Widget\Class',
            ],
            'initializers' => [
                // DB: Using Global db Adapter on each services Implemented AdapterAwareInterface
                function ($instance, $sl) {
                    if ($instance instanceof \Zend\Db\Adapter\AdapterAwareInterface) {
                        $sm = $sl->getServiceLocator();
                        $instance->setDbAdapter(
                            $sm->get('Zend\Db\Adapter\Adapter')
                        );
                    }
                }
            ],
        ],
        'widgets' => [
            /** @see RegionBoxContainer */
            'region_box' => [
                # // $priority default is start with 0
                # $priority => 'WidgetName',
                # $priority => [
                #    'widget' => 'WidgetName'
                #    'params' => [
                #       'with_construct_param' => 'param_value'
                #     ]
                # ],
            ],
        ],
    ],

How to Get Widgets From ?

In Controller with controller helper:

$this->layout()->side_bar = $this->widget('widgetName')->render();

In View Script:

<div class="container">
    <p><?php echo $this->widget('widgetName')->render();?></p>
</div>

Load Widgets With Ajax Call

ajax widget loading need some js resources you can find in www folder of module, you can put file anywhere you want and edit config\module.config.php.

return array(
    /**
     * Libraries that used in Ajax Loading of widgets.
     * @see \yimaJquery\View\Helper\WidgetAjaxy
     */
    'static_uri_helper' => array(
        'Yima.Widgetator.JS.Jquery.Ajaxq' => '$basepath/js/yima-widgetator/jquery.ajaxq.min.js',
        'Yima.Widgetator.JS.Jquery.Json'  => '$basepath/js/yima-widgetator/jquery.json.min.js',
    ),

for more info around static_uri_helper see yimaStaticUriHelper

In View Script:

<div class="container">
    <p id="container_id">
        <?php
        echo $this->widgetAjaxy('widgetName',   // widget name
            array('option' => 'value'),         // options
            'container_id',                     // id of dom element
            'function callback(response)'       // callback after loading widget
            );
        ?>
    </p>
</div>

I`m working to improve ajax loading of widgets.

And Finally

We have some Abstract class for widgets called: AbstractWidget and AbstractMvcWidget. (take a look)

Todo

Example Widgets and AbstractClasses will be added.

Installation

Requirement

Composer installation:

require rayamedia/yima-widgetator in your composer.json

Or clone to modules folder

Enable module in application config

Support

To report bugs or request features, please visit the Issue Tracker.

Please feel free to contribute with new issues, requests and code fixes or new features.

About

[yima, zend framework 2, zf2 module] Widgets are standalone application or part of a module that can embed into web pages (written inside codes or by ajax call) as html code block.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages