3 namespace app\controllers;
6 use app\models\Locations;
7 use app\models\LocationsSearch;
8 use yii\web\Controller;
9 use yii\web\NotFoundHttpException;
10 use yii\filters\VerbFilter;
13 * LocationsController implements the CRUD actions for Locations model.
15 class LocationsController extends Controller
20 public function behaviors()
24 'class' => VerbFilter::className(),
26 'delete' => [ 'POST' ],
33 * Добавление места разположения
35 * @param array $options
36 * string 'name' - наименование места расположения
37 * string|NULL 'region' - наименование региона/подразделения
38 * integer|NULL 'region_id' - идентификатор региона/подразделения
39 * @return integer|boolean - идентификатор записи места расположения или FALSE
41 public static function addIfNeed($options)
43 if (is_array($options) && isset($options[ 'name' ]) && (isset($options[ 'region' ]) || isset($options[ 'region_id' ])))
45 if (isset($options[ 'region' ]))
47 $region_id = RegionsController::addIfNeed([ 'name' => $options[ 'region' ]]);
51 $region_id = $options[ 'region_id' ];
53 if ($region_id !== FALSE) {
54 // Ищем расположение, совпадающее по наименованию и региону/подразделению
55 $location = Locations::find()
56 ->where([ 'like', 'name', $options[ 'name' ]])
57 ->andWhere([ 'region_id' => $region_id ])
59 if (count($location) > 0)
61 return $location[0]->id; // Если нашли, возвращаем идентификатор записи
63 // Не нашли, пробуем добавить место расположения
64 $location = new Locations();
65 $location->name = $options[ 'name' ];
66 $location->region_id = $region_id;
67 if($location->validate() && $location->save())
69 return $location->id; // Если удалось сохранить, вернём идентификатор места расположения
73 return FALSE; // Записать не удалось, вернём FALSE
77 * Список всех мест/размещений.
80 public function actionIndex()
82 $searchModel = new LocationsSearch();
83 $dataProvider = $searchModel->search(Yii::$app->request->queryParams);
85 return $this->render('index', [
86 'searchModel' => $searchModel,
87 'dataProvider' => $dataProvider,
92 * Показ одного места размещения (не используется).
95 * @throws NotFoundHttpException если отсутствует место/размещение
97 public function actionView($id)
99 return $this->render('view', [
100 'model' => $this->findModel($id),
105 * Создание нового места/размещения.
106 * В случае успешного создания, происходит переход к списку всех мест/размещений.
109 public function actionCreate()
111 $model = new Locations();
113 if ($model->load(Yii::$app->request->post()) && $model->save())
115 return $this->redirect([ 'index', 'id' => $model->id ]);
118 return $this->render('create', [
124 * Изменение существующего места/размещения.
125 * В случаае успешного изменения, происходит переход к списку всех мест/размещений.
128 * @throws NotFoundHttpException если отсутствует место/размещение
130 public function actionUpdate($id)
132 $model = $this->findModel($id);
134 if ($model->load(Yii::$app->request->post()) && $model->save())
136 return $this->redirect([ 'index', 'id' => $model->id ]);
139 return $this->render('update', [
145 * Удаение существующего места/размещения.
146 * В случае успешного удаления, происходит переход к списку всех мест/размещений.
149 * @throws NotFoundHttpException Усли отсутствует место/размещение
151 public function actionDelete($id)
153 $this->findModel($id)->delete();
155 return $this->redirect([ 'index' ]);
159 * Finds the Locations model based on its primary key value.
160 * If the model is not found, a 404 HTTP exception will be thrown.
162 * @return Locations the loaded model
163 * @throws NotFoundHttpException if the model cannot be found
165 protected function findModel($id)
167 if (($model = Locations::findOne($id)) !== null)
172 throw new NotFoundHttpException(Yii::t('locations', 'The requested page does not exist.'));