dev-master
9999999-dev https://github.com/keygenqt/yii2-autocomplete-ajaxA simple way to search model id of the attributes model.
BSD-3-Clause
The Requires
- yiisoft/yii2 *
- php >=5.4.0
plugin extension yii2 jquery ajax widget autocomplete
A simple way to search model id of the attributes model.
This is the AutocompleteAjax widget and a Yii 2 enhanced wrapper for the Autocomplete | jQuery UI. A simple way to search model id of the attributes model., (*1)
The preferred way to install this extension is through composer., (*2)
Either add, (*3)
"require": { "keygenqt/yii2-autocomplete-ajax": "*" }
of your composer.json
file., (*4)
The latest version of the module is v0.5.0 BETA
., (*5)
View:, (*6)
use keygenqt\autocompleteAjax\AutocompleteAjax; // Normal select with ActiveForm & model = $form->field($model, 'user_id')->widget(AutocompleteAjax::classname(), [ 'multiple' => false, 'url' => ['ajax/search-user'], 'options' => ['placeholder' => 'Find by user email or user id.'] ]) ?>
Controller:, (*7)
class AjaxController extends Controller { public function actionSearchUser($term) { if (Yii::$app->request->isAjax) { $results = []; if (is_numeric($term)) { /** @var Tag $model */ $model = Tag::findOne(['id' => $term]); if ($model) { $results[] = [ 'id' => $model['id'], 'label' => $model['email'] . ' (model id: ' . $model['id'] . ')', ]; } } else { $q = addslashes($term); foreach(Tag::find()->where("(`email` like '%{$q}%')")->all() as $model) { $results[] = [ 'id' => $model['id'], 'label' => $model['email'] . ' (model id: ' . $model['id'] . ')', ]; } } echo Json::encode($results); } } }
<?= $form->field($model, 'address')->widget(\keygenqt\autocompleteAjax\AutocompleteAjax::classname(), [ 'startQuery' => false, 'url' => ['ajax/search-place'], 'options' => ['placeholder' => 'Find place.'], 'afterSelect' => 'function(event, ui) { var value = JSON.parse(ui.item.data); updateMarker(value.lat, value.lng); }' ]) ?>
/** * enable "Google Places API Web Service" in https://console.developers.google.com **/ public function actionSearchPlace($term, $apiKey = '') { $result = []; $results = []; if (Yii::$app->request->isAjax) { /** CURL QUERY **/ $curl = curl_init('https://maps.googleapis.com/maps/api/place/textsearch/json?key=' . urlencode($apiKey) . '&language=en&query=' . urlencode($term)); curl_setopt ($curl, CURLOPT_RETURNTRANSFER, 1); $response = curl_exec($curl); $status = curl_getinfo($curl, CURLINFO_HTTP_CODE); if ($status !== 200) { throw new NotFoundHttpException('Error: ' . curl_error($curl) . ' Code: ' . $status); } else { if (json_decode($response, true) && json_last_error() == JSON_ERROR_NONE) { $result = json_decode($response, true); } } curl_close($curl); /** CURL QUERY **/ if (!empty($result['results'])) { foreach($result['results'] as $model) { $results[] = [ 'id' => $model['formatted_address'], 'label' => $model['formatted_address'] . ' (model location: ' . json_encode($model['geometry']['location']) . ')', 'data' => json_encode($model['geometry']['location']), ]; } } echo Json::encode($results); } }
yii2-autocomplete-ajax is released under the BSD 3-Clause License. See the bundled LICENSE.md
for details., (*8)
A simple way to search model id of the attributes model.
BSD-3-Clause
plugin extension yii2 jquery ajax widget autocomplete