[Yii Framework] How to develop an extension with image, css and js
Here is an example of how to develop a widget (yes, widget is also an extension in Yii) in Yii.
Let say you want to display something with widget in the page, of course you can place your widget
in protected/components when there are one or two classes inside. But when there is a lot of them,
it is hard for you to manage them. Therefore we will place them in protected/extensions. Here we
will build the testWidget, the path will be protected/extensions/testWidget.
Structure:
| | | |~assets/
| | | | |~css/
| | | | | `-testWidget.css
| | | | |~images/
| | | | | `-loading.gif
| | | | `~js/
| | | | `-testWidget.js
| | | |~views/
| | | | `-testWidget.php
| | | `-testWidget.php
1. Develop a widget class file: testWidget.php
class testWidget extends CWidget
{
private $loadingImageUrl;
public function init()
{
$assetsDir = dirname(__FILE__).'/assets';
$cs = Yii::app()->getClientScript();
$cs->registerCoreScript("jquery");
// Publishing and registering JavaScript file
$cs->registerScriptFile(
Yii::app()->assetManager->publish(
$assetsDir.'/js/testWidget.js'
),
CClientScript::POS_END
);
// Publishing and registering CSS file
$cs->registerCssFile(
Yii::app()->assetManager->publish(
$assetsDir.'/css/testWidget.css'
)
);
// Publishing image
$this->loadingImageUrl = Yii::app()->assetManager->publish(
$assetsDir.'/images/loading.gif'
);
}
public function run()
{
$this->render(
'testWidget',
array(
'loadingImageUrl' => $this->loadingImageUrl,
)
);
}
}
2. Develop the view file:
3. You can develop you testWidget.css and testWidget.js file.
4. Use the new widget.
Yes, that is a very simple widget extension, just a tutorial to show how to build one.
Have fun with Yii!