This extension enhances or adds functionality to existing Yii Framework 2 Widgets to make available other bundled features available in Bootstrap 3.0, new HTML 5 features and affiliated Bootstrap extras.
NOTE: This extension has been revamped with release v3.4.1 on 05-Dec-2015. With release v3.4.0, each widget within this extension bundle has been logically regrouped and split into separate sub repositories. This change has been done to allow developers flexibility to install separately or specific widgets only (via composer) if needed. However, for new users installing this bundle should be the easiest way to give you access to all these important widget sub repositories in one shot. This change would not affect backward compatibility for any users already using the previous extension versions.
The yii2-widgets bundle automatically includes extensions or widgets from these sub repositories for accessing via \kartik\widgets\
namespace.
This extension has now matured to contain the most needed basic widgets for Yii 2 input and navigation controls. In order to support this extension better, any
additional input and navigation widgets will be created separately. Listed below are the additional widgets that are related to similar functionality like the
yii2-widgets
, but have been created as separate extensions (these widgets depend on kartik-v/yii2-widgets
).
The preferred way to install this extension is through composer. Remember to refer to the composer.json for this extension's requirements and dependencies.
Note: Check the composer.json for this extension's requirements and dependencies. Read this web tip /wiki on setting the
minimum-stability
settings for your application's composer.json.
Either run
$ php composer.phar require kartik-v/yii2-widgets "*"
or add
"kartik-v/yii2-widgets": "*"
to the require
section of your composer.json
file.
Refer the CHANGE LOG for details on changes to various releases.
The widgets currently available in yii2-widgets are grouped by the type of usage.
Extends Yii ActiveForm widget. Facilitates all three form layouts available in Bootstrap i.e. vertical, horizontal, and inline. Allows options for offsetting labels and inputs for horizontal form layout. Works closely with the extended ActiveField widget.
Extends Yii ActiveField widget. Allows Bootstrap styled input group addons to be prepended or appended to textInputs. Automatically adjusts checkboxes and radio input offsets for horizontal forms. Allows, flexibility to control the labels and placeholders based on form layout style (e.g. hide labels and show them as placeholder for inline forms). The extended ActiveField functionalities available are:
The DepDrop widget is a Yii 2 wrapper for the dependent-dropdown jQuery plugin by Krajee. This plugin allows multi level dependent dropdown with nested dependencies. The plugin thus enables to convert normal select inputs to a dependent input field, whose options are derived based on value selected in another input/or a group of inputs. It works both with normal select options and select with optgroups as well.
The Select2 widget is a Yii 2 wrapper for the Select2 jQuery plugin. This input widget is a jQuery based replacement for select boxes. It supports searching, remote data sets, and infinite scrolling of results. The widget is specially styled for Bootstrap 3. The widget allows graceful degradation to a normal HTML select or text input, if the browser does not support JQuery.
The Typeahead widget is a Yii 2 wrapper for for the Twitter Typeahead.js
plugin with certain custom enhancements. This input widget is a jQuery based replacement for text inputs providing search and
typeahead functionality. It is inspired by twitter.com's autocomplete search functionality and based on Twitter's typeahead.js
which is described as as a fast and fully-featured autocomplete library. The widget is specially styled for Bootstrap 3.
The widget allows graceful degradation to a normal HTML text input, if the browser does not support JQuery. You can setup model
validation rules for a model attribute that uses Typeahead widget for input like any other field. The widget comes in two
variants:
TypeaheadBasic
: This widget is a basic implementation of the typeahead.js plugin without any suggestion engine.
It uses a javascript substring matcher and Regular Expression matching to query and display suggestions.
VIEW DEMO
Typeahead
: This widget is an advanced implementation of the typeahead.js plugin with the BloodHound suggestion
engine and the Handlebars template compiler.
VIEW DEMO
The DatePicker widget is a Yii 2 wrapper for the Bootstrap DatePicker plugin. The plugin is a fork of Stefan Petre's DatePicker (of eyecon.ro), with improvements by @eternicode. The widget is specially styled for Yii framework 2.0 and Bootstrap 3 and allows graceful degradation to a normal HTML text input, if the browser does not support JQuery. The widget supports these markups:
The TimePicker widget allows you to easily select a time for a text input using your mouse or keyboards arrow keys. The widget is a wrapper enhancement of the TimePicker plugin by rendom forked from jdewit's TimePicker. This widget as used here has been specially enhanced for Yii framework 2.0 and Bootstrap 3.
The DateTimePicker widget is a Yii 2 wrapper for the Bootstrap DateTimePicker plugin. The plugin is a fork of the DateTimePicker plugin by @eternicode and adds the time functionality. The widget is similar to the DatePicker widget in most aspects, except that it adds the time functionality and does not support ranges. The widget is specially styled for Yii framework 2.0 and Bootstrap 3 and allows graceful degradation to a normal HTML text input, if the browser does not support JQuery. The widget supports these markups:
The TouchSpin widget is a Yii 2 wrapper for for the bootstrap-touchspin plugin by István Ujj-Mészáros, with certain additional enhancements. This input widget is a mobile and touch friendly input spinner component for Bootstrap 3. You can use the widget buttons to rapidly increase and decrease numeric and/or decimal values in your input field. The widget can be setup to include model validation rules for the related model attribute.
The FileInput widget is a customized file input widget based on Krajee's Bootstrap FileInput JQuery Plugin. The widget enhances the default HTML file input with various features including the following:
The widget runs on all modern browsers supporting HTML5 File Inputs and File Processing API. For browser versions IE9 and below, this widget will gracefully degrade to normal HTML file input. The widget is vastly inspired by this blog article and Jasny's File Input plugin.
The ColorInput widget is an advanced ColorPicker input styled for Bootstrap. It uses a combination of the HTML5 color input and/or the JQuery Spectrum Plugin for rendering the color picker. You can use the Native HTML5 color input by setting the useNative
option to true
. Else, the Spectrum plugin polyfills for unsupported browser versions.
HTML5 color input
for unsupported browser versions.The RangeInput widget is a customized range slider control widget based on HTML5 range input. The widget enhances the default HTML range input with various features including the following:
The SwitchInput widget turns checkboxes and radio buttons into toggle switches. The plugin is a wrapper for the Bootstrap Switch Plugin and is specially styled for Bootstrap 3.
The StarRating widget is a wrapper for the Bootstrap Star Rating Plugin JQuery Plugin designed by Krajee. This plugin is a simple yet powerful JQuery star rating plugin for Bootstrap. Developed with a focus on utlizing pure CSS-3 styling to render the control.
The Spinner widget is a wrapper for the spin.js. It enables you to add an animated CSS3 loading spinner which allows VML fallback for IE. Since, its not image based, it allows you to configure the spinner style, size, color, and other CSS attributes. The major advantage of using the CSS3 based spinner, is that the animation can be made visible to user for non-ajax based scenarios. For example on events like window.load or window.unload (thereby enabling you to show a page loading progress without using ajax).
Extends Yii Menu widget. This widget offers a scrollspy and affixed enhanced navigation (upto 2-levels) to highlight sections and secondary sections in each page. The affix widget can be used to generate both the:
The parameters to pass are:
type
The affix content type. Must be either menu
or body
. Defaults to menu
items
: The affix content items as an array. Check the affix combined usage for a detailed example.Note: If you have the
header
section fixed to the top, you must add a CSS classkv-header
to the header container. Similarly, for a fixed footer you must add the classkv-footer
to your footer container. This will ensure a correct positioning of the affix widget on the page.
This widget is a collapsible side navigation menu built to seamlessly work with Bootstrap framework. It is built over Bootstrap stacked nav component. This widget class extends the Yii Menu widget. Upto 3 levels of submenus are by default supported by the CSS styles to balance performance and useability. You can choose to extend it to more or less levels by customizing the CSS.
Extends the \yii\bootstrap\Alert widget with more easy styling and auto fade out options.
A widget that turns standard Bootstrap alerts into "Growl-like" notifications. This widget is a wrapper for the Bootstrap Growl plugin by remabledesigns.
Alert block widget that groups multiple \kartik\widget\Alert
or kartik\widget\Growl
widgets in one single block and renders them stacked vertically on the current page.
You can choose the TYPE_ALERT
style or the TYPE_GROWL
style for your notifications. You can also set the widget to automatically read and display session flash
messages (which is the default setting). Alternatively, you can setup and configure your own block of custom alerts.
You can see a demonstration here on usage of these widgets with documentation and examples.
// add this in your view
use kartik\widgets\ActiveForm;
$form = ActiveForm::begin();
// Vertical Form
$form = ActiveForm::begin([
'id' => 'form-signup',
'type' => ActiveForm::TYPE_VERTICAL
]);
// Inline Form
$form = ActiveForm::begin([
'id' => 'form-login',
'type' => ActiveForm::TYPE_INLINE,
'fieldConfig' => ['autoPlaceholder'=>true]
]);
// Horizontal Form Configuration
$form = ActiveForm::begin([
'id' => 'form-signup',
'type' => ActiveForm::TYPE_HORIZONTAL,
'formConfig' => ['labelSpan' => 3, 'deviceSize' => ActiveForm::SIZE_SMALL]
]);
// Prepend an addon text
echo $form->field($model, 'email', ['addon' => ['prepend' => ['content'=>'@']]]);
// Append an addon text
echo $form->field($model, 'amount_paid', [
'addon' => ['append' => ['content'=>'.00']]
]);
// Formatted addons (like icons)
echo $form->field($model, 'phone', [
'addon' => [
'prepend' => [
'content' => '<i class="glyphicon glyphicon-phone"></i>'
]
]
]);
// Formatted addons (inputs)
echo $form->field($model, 'phone', [
'addon' => [
'prepend' => [
'content' => '<input type="radio">'
]
]
]);
// Formatted addons (buttons)
echo $form->field($model, 'phone', [
'addon' => [
'prepend' => [
'content' => Html::button('Go', ['class'=>'btn btn-primary'])
]
'asButton' => true
]
]);
// Normal parent select
echo $form->field($model, 'cat')->dropDownList($catList, ['id'=>'cat-id']);
// Dependent Dropdown
echo $form->field($model, 'subcat')->widget(DepDrop::classname(), [
'options' => ['id'=>'subcat-id'],
'pluginOptions'=>[
'depends'=>['cat-id'],
'placeholder' => 'Select...',
'url' => Url::to(['/site/subcat'])
]
]);
// Normal select with ActiveForm & model
echo $form->field($model, 'state_1')->widget(Select2::classname(), [
'data' => array_merge(["" => ""], $data),
'language' => 'de',
'options' => ['placeholder' => 'Select a state ...'],
'pluginOptions' => [
'allowClear' => true
],
]);
// Multiple select without model
echo Select2::widget([
'name' => 'state_2',
'value' => '',
'data' => $data,
'options' => ['multiple' => true, 'placeholder' => 'Select states ...']
]);
use kartik\widgets\TypeaheadBasic;
// TypeaheadBasic usage with ActiveForm and model
echo $form->field($model, 'state_3')->widget(Typeahead::classname(), [
'data' => $data,
'pluginOptions' => ['highlight' => true],
'options' => ['placeholder' => 'Filter as you type ...'],
]);
// Typeahead usage with ActiveForm and model
echo $form->field($model, 'state_4')->widget(Typeahead::classname(), [
'dataset' => [
[
'local' => $data,
'limit' => 10
]
],
'pluginOptions' => ['highlight' => true],
'options' => ['placeholder' => 'Filter as you type ...'],
]);
use kartik\widgets\DatePicker;
// usage without model
echo '<label>Check Issue Date</label>';
echo DatePicker::widget([
'name' => 'check_issue_date',
'value' => date('d-M-Y', strtotime('+2 days')),
'options' => ['placeholder' => 'Select issue date ...'],
'pluginOptions' => [
'format' => 'dd-M-yyyy',
'todayHighlight' => true
]
]);
use kartik\widgets\TimePicker;
// usage without model
echo '<label>Start Time</label>';
echo TimePicker::widget([
'name' => 'start_time',
'value' => '11:24 AM',
'pluginOptions' => [
'showSeconds' => true
]
]);
use kartik\widgets\DateTimePicker;
// usage without model
echo '<label>Start Date/Time</label>';
echo DateTimePicker::widget([
'name' => 'datetime_10',
'options' => ['placeholder' => 'Select operating time ...'],
'convertFormat' => true,
'pluginOptions' => [
'format' => 'd-M-Y g:i A',
'startDate' => '01-Mar-2014 12:00 AM',
'todayHighlight' => true
]
]);
use kartik\widgets\TouchSpin;
echo TouchSpin::widget([
'name' => 'volume',
'options' => ['placeholder' => 'Adjust...'],
'pluginOptions' => ['step' => 1]
]);
use kartik\widgets\FileInput;
// Usage with ActiveForm and model
echo $form->field($model, 'avatar')->widget(FileInput::classname(), [
'options' => ['accept' => 'image/*'],
]);
// With model & without ActiveForm
echo '<label class="control-label">Add Attachments</label>';
echo FileInput::widget([
'model' => $model,
'attribute' => 'attachment_1',
'options' => ['multiple' => true]
]);
use kartik\widgets\ColorInput;
// Usage with ActiveForm and model
echo $form->field($model, 'color')->widget(ColorInput::classname(), [
'options' => ['placeholder' => 'Select color ...'],
]);
// With model & without ActiveForm
echo '<label class="control-label">Select Color</label>';
echo ColorInput::widget([
'model' => $model,
'attribute' => 'saturation',
]);
use kartik\widgets\RangeInput;
// Usage with ActiveForm and model
echo $form->field($model, 'rating')->widget(RangeInput::classname(), [
'options' => ['placeholder' => 'Select color ...'],
'html5Options' => ['min'=>0, 'max'=>1, 'step'=>1],
'addon' => ['append'=>['content'=>'star']]
]);
// With model & without ActiveForm
echo '<label class="control-label">Adjust Contrast</label>';
echo RangeInput::widget([
'model' => $model,
'attribute' => 'contrast',
'addon' => ['append'=>['content'=>'%']]
]);
use kartik\widgets\SwitchInput;
// Usage with ActiveForm and model
echo $form->field($model, 'status')->widget(SwitchInput::classname(), [
'type' => SwitchInput::CHECKBOX
]);
// With model & without ActiveForm
echo SwitchInput::widget([
'name' => 'status_1',
'type' => SwitchInput::RADIO
]);
use kartik\widgets\StarRating;
// Usage with ActiveForm and model
echo $form->field($model, 'rating')->widget(StarRating::classname(), [
'pluginOptions' => ['size'=>'lg']
]);
// With model & without ActiveForm
echo StarRating::widget([
'name' => 'rating_1',
'pluginOptions' => ['disabled'=>true, 'showClear'=>false]
]);
use kartik\widgets\Spinner;
<div class="well">
<?= Spinner::widget([
'preset' => Spinner::LARGE,
'color' => 'blue',
'align' => 'left'
])?>
</div>
$content = 'Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat.';
$items = [[
'url' => '#sec-1',
'label' => 'Section 1',
'icon' => 'play-circle',
'content' => $content,
'items' => [
['url' => '#sec-1-1', 'label' => 'Section 1.1', 'content' => $content],
['url' => '#sec-1-2', 'label' => 'Section 1.2', 'content' => $content],
['url' => '#sec-1-3', 'label' => 'Section 1.3', 'content' => $content],
['url' => '#sec-1-4', 'label' => 'Section 1.4', 'content' => $content],
['url' => '#sec-1-5', 'label' => 'Section 1.5', 'content' => $content],
],
]];
// Displays sidebar menu
echo Affix::widget([
'items' => $items,
'type' => 'menu'
]);
// Displays body sections
echo Affix::widget([
'items' => $items,
'type' => 'body'
]);
use kartik\widgets\SideNav;
echo SideNav::widget([
'type' => SideNav::TYPE_DEFAULT,
'heading' => 'Options',
'items' => [
[
'url' => '#',
'label' => 'Home',
'icon' => 'home'
],
[
'label' => 'Help',
'icon' => 'question-sign',
'items' => [
['label' => 'About', 'icon'=>'info-sign', 'url'=>'#'],
['label' => 'Contact', 'icon'=>'phone', 'url'=>'#'],
],
],
],
]);
use kartik\widgets\Alert;
echo Alert::widget([
'type' => Alert::TYPE_INFO,
'title' => 'Note',
'titleOptions' => ['icon' => 'info-sign'],
'body' => 'This is an informative alert'
]);
use kartik\widgets\Growl;
echo Growl::widget([
'type' => Growl::TYPE_SUCCESS,
'icon' => 'glyphicon glyphicon-ok-sign',
'title' => 'Note',
'showSeparator' => true,
'body' => 'This is a successful growling alert.'
]);
use kartik\widgets\AlertBlock;
echo AlertBlock::widget([
'type' => AlertBlock::TYPE_ALERT,
'useSessionFlash' => true
]);
This project exists thanks to all the people who contribute. [Contribute].
Become a financial contributor and help us sustain our community. [Contribute]
Support this project with your organization. Your logo will show up here with a link to your website. [Contribute]
yii2-widgets is released under the BSD-3-Clause License. See the bundled LICENSE.md
for details.
Date: 09-Oct-2018
src
directory.Date: 09-Nov-2014
Date: 05-Nov-2014
Date: 25-Oct-2014
Date: 10-Oct-2014
Date: 08-Oct-2014
Date: 14-Aug-2014
label
displayed after SwitchInput.ColorInput
widget to read colors correctly based on plugin preferredFormat
.ColorInput
widget to allow controlling display of default palette of colors.Date: 31-Jul-2014
Date: 18-Jul-2014
iconPrefix
property in SideNav to easily configure with more icon frameworks (other than glyphicon).allowClear
is true
. language
configuration property for DatePicker, DateTimePicker, and TimePicker.autoWidgetSettings
for DateControl module .Date: 01-Jul-2014
language
property to InputWidget
along with initLanguage
method for automatic language setting in pluginOptions
.
The language
property will be auto defaulted to Yii::$app->language
if not set.select2
plugin.select2
plugin.Typeahead widget upgraded to use ## Version 0.10 of the typeahead.js
plugin.
The widget has been released as 2 variants:
TypeaheadBasic
: This widget is a basic implementation of the typeahead.js plugin without any suggestion engine.
It uses a javascript substring matcher and Regular Expression matching to query and display suggestions.
VIEW DEMO
Typeahead
: This widget is an advanced implementation of the typeahead.js plugin with the BloodHound suggestion
engine and the Handlebars template compiler.
VIEW DEMO
Alert
widget extending the default \yii\bootstrap\Alert widget with more styling and auto fade out options.Growl
widget wrapping the Bootstrap Growl JQuery plugin.AlertBlock
widget allowing a block of alerts to be displayed and faded out. Uses and processes session flash messages if needed.The fileinput routines and rendering have been enhanced and offers ability to configure most options, call events, and methods.
Initial release
Comments