2017 © Pedro Peláez
 

yii2-extension yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

image

2amigos/yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

  • Friday, May 15, 2015
  • by tonydspaniard
  • Repository
  • 21 Watchers
  • 24 Stars
  • 39,123 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 7 Forks
  • 3 Open issues
  • 5 Versions
  • 9 % Grown

The README.md

Bootstrap TypeAhead Widget for Yii2

Latest Version Software License Build Status Coverage Status Quality Score Total Downloads, (*1)

Renders a Twitter Typeahead.js Bootstrap plugin widget., (*2)

Installation

The preferred way to install this extension is through composer., (*3)

Either run, (*4)

$ composer require 2amigos/yii2-type-ahead-widget:~2.0

or add, (*5)

"2amigos/yii2-type-ahead-widget": "~2.0"

to the require section of your composer.json file., (*6)

Usage

Using a model and a remote configuration:, (*7)

use dosamigos\typeahead\Bloodhound;
use dosamigos\typeahead\TypeAhead;
use yii\helpers\Url;

 'countriesEngine',
        'clientOptions' => [
            'datumTokenizer' => new \yii\web\JsExpression("Bloodhound.tokenizers.obj.whitespace('name')"),
            'queryTokenizer' => new \yii\web\JsExpression("Bloodhound.tokenizers.whitespace"),
            'remote' => [
                'url' => Url::to(['country/autocomplete', 'query'=>'QRY']),
                'wildcard' => 'QRY'
            ]
        ]
    ]);
?>
= $form->field($model, 'country')->widget(
    TypeAhead::className(),
    [
        'options' => ['class' => 'form-control'],
        'engines' => [ $engine ],
        'clientOptions' => [
            'highlight' => true,
            'minLength' => 3
        ],
        'clientEvents' => [
            'typeahead:selected' => 'function (e, o) { console.log("event \'selected\' occured on " + o.value + "."); }'
        ],
        'dataSets' => [
            [
                'name' => 'countries',
                'displayKey' => 'value',
                'source' => $engine->getAdapterScript()
            ]
        ]
    ]
);?>

Note the use of the custom wildcard. It is required as if we use typeahead.js default's wildcard (%QUERY), Yii2 will automatically URL encode it thus making the wrong configuration for token replacement., (*8)

The results need to be JSON encoded as specified on the plugin documentation. The following is an example of a custom Action class that you could plug to any Controller:, (*9)

namespace frontend\controllers\actions;

use yii\base\Action;
use yii\helpers\Json;
use yii\base\InvalidConfigException;

class AutocompleteAction extends Action
{
    public $tableName;

    public $field;

    public $clientIdGetParamName = 'query';

    public $searchPrefix = '';

    public $searchSuffix = '%';

    public function init()
    {
        if($this->tableName === null) {
            throw new  InvalidConfigException(get_class($this) . '::$tableName must be defined.');
        }
        if($this->field === null) {
            throw new  InvalidConfigException(get_class($this) . '::$field must be defined.');
        }
        parent::init();
    }

    public function run()
    {
        $value = $this->searchPrefix . $_GET[$this->clientIdGetParamName] . $this->searchSuffix;
        $rows = \Yii::$app->db
            ->createCommand("SELECT {$this->field} AS value FROM {$this->tableName} WHERE {$this->field} LIKE :field ORDER BY {$this->field}")
            ->bindValues([':field' => $value])
            ->queryAll();

        echo Json::encode($rows);
    }
}

And how to configure it on your Controller class:, (*10)

public function actions()
{
    return [
        'autocomplete' => [
            'class' => 'frontend\controllers\actions\AutocompleteAction',
            'tableName' => Country::tableName(),
            'field' => 'name'
        ]
    ];
}

Theming

Twitter Typeahead.js Bootstrap plugin does not style the dropdown nor the hint or the input-field. It does it this way in order for you to customize it so it suits your application., (*11)

We have included a stylesheet with hints to match form-control bootstrap classes and other tweaks so you can easily identify the classes and style it., (*12)

Testing

$ ./vendor/bin/phpunit

Contributing

Please see CONTRIBUTING for details., (*13)

Credits

License

The BSD License (BSD). Please see License File for more information., (*14)


web development has never been so fun
www.2amigos.us

The Versions

15/05 2015

dev-master

9999999-dev https://github.com/2amigos/yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 2amigos yii yii 2 widget typeahead

15/05 2015

1.1

1.1.0.0 https://github.com/2amigos/yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 2amigos yii yii 2 widget typeahead

31/03 2015

1.0.0

1.0.0.0 https://github.com/2amigos/yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 2amigos yii yii 2 widget typeahead

31/03 2015

dev-develop

dev-develop https://github.com/2amigos/yii2-type-ahead-widget

The bootstrap typeahead widget for the Yii framework

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

by Alexander Kochetov

yii2 2amigos yii yii 2 widget typeahead

13/03 2014

0.1.0

0.1.0.0

TypeAhead Bootstrap widget for Yii2.

  Sources   Download

BSD-3-Clause

The Requires

 

extension yii widget typeahead