Commit e3ec491ce7d09d1ed4f28a0f7335ab11cac9ef21
1 parent
b15a9aec
+ Catalog в backend по структуре semena.in.ua
Showing
10 changed files
with
579 additions
and
0 deletions
Show diff stats
1 | +<?php | |
2 | + | |
3 | +namespace backend\controllers; | |
4 | + | |
5 | +use Yii; | |
6 | +use common\models\Catalog; | |
7 | +use backend\models\SearchCatalog; | |
8 | +use yii\web\Controller; | |
9 | +use yii\web\NotFoundHttpException; | |
10 | +use yii\filters\VerbFilter; | |
11 | +use common\models\CatalogLang; | |
12 | + | |
13 | +/** | |
14 | + * CatalogController implements the CRUD actions for Catalog model. | |
15 | + */ | |
16 | +class CatalogController extends Controller | |
17 | +{ | |
18 | + public function behaviors() | |
19 | + { | |
20 | + return [ | |
21 | + 'verbs' => [ | |
22 | + 'class' => VerbFilter::className(), | |
23 | + 'actions' => [ | |
24 | + 'delete' => ['post'], | |
25 | + ], | |
26 | + ], | |
27 | + ]; | |
28 | + } | |
29 | + | |
30 | + /** | |
31 | + * Lists all Catalog models. | |
32 | + * @return mixed | |
33 | + */ | |
34 | + public function actionIndex() | |
35 | + { | |
36 | + $searchModel = new SearchCatalog(); | |
37 | + $dataProvider = $searchModel->search(Yii::$app->request->queryParams); | |
38 | + | |
39 | + return $this->render('index', [ | |
40 | + 'searchModel' => $searchModel, | |
41 | + 'dataProvider' => $dataProvider, | |
42 | + ]); | |
43 | + } | |
44 | + | |
45 | + /** | |
46 | + * Displays a single Catalog model. | |
47 | + * @param integer $id | |
48 | + * @return mixed | |
49 | + */ | |
50 | + public function actionView($id) | |
51 | + { | |
52 | + return $this->render('view', [ | |
53 | + 'model' => $this->findModel($id), | |
54 | + ]); | |
55 | + } | |
56 | + | |
57 | + /** | |
58 | + * Creates a new Catalog model. | |
59 | + * If creation is successful, the browser will be redirected to the 'view' page. | |
60 | + * @return mixed | |
61 | + */ | |
62 | + public function actionCreate() | |
63 | + { | |
64 | + $model = new Catalog(); | |
65 | + | |
66 | + if ($model->load(Yii::$app->request->post()) && $model->save()) | |
67 | + { | |
68 | + return $this->redirect(['view', 'id' => $model->id]); | |
69 | + } | |
70 | + else | |
71 | + { | |
72 | + return $this->render('create', [ | |
73 | + 'model' => $model, | |
74 | + ]); | |
75 | + } | |
76 | + } | |
77 | + | |
78 | + /** | |
79 | + * Updates an existing Catalog model. | |
80 | + * If update is successful, the browser will be redirected to the 'view' page. | |
81 | + * @param integer $id | |
82 | + * @return mixed | |
83 | + */ | |
84 | + public function actionUpdate($id) | |
85 | + { | |
86 | + $model = $this->findModel($id); | |
87 | + $model_lang = CatalogLang::find() | |
88 | + ->where(['catalog' => $id, 'lang_id' => 1]) | |
89 | + ->one(); | |
90 | +//die(); | |
91 | + if ($model->load(Yii::$app->request->post())) | |
92 | + { | |
93 | + | |
94 | + //var_dump($model->title);die(); | |
95 | + echo $model_lang->title = $model->title; | |
96 | + | |
97 | + //var_dump($model->save());die(); | |
98 | + $model->save(); | |
99 | + $model_lang->save(); | |
100 | + | |
101 | + return $this->redirect(['view', 'id' => $model->id]); | |
102 | + } | |
103 | + else | |
104 | + { | |
105 | + return $this->render('update', [ | |
106 | + 'model' => $model, | |
107 | + ]); | |
108 | + } | |
109 | + } | |
110 | + | |
111 | + /** | |
112 | + * Deletes an existing Catalog model. | |
113 | + * If deletion is successful, the browser will be redirected to the 'index' page. | |
114 | + * @param integer $id | |
115 | + * @return mixed | |
116 | + */ | |
117 | + public function actionDelete($id) | |
118 | + { | |
119 | + $this->findModel($id)->delete(); | |
120 | + | |
121 | + return $this->redirect(['index']); | |
122 | + } | |
123 | + | |
124 | + /** | |
125 | + * Finds the Catalog model based on its primary key value. | |
126 | + * If the model is not found, a 404 HTTP exception will be thrown. | |
127 | + * @param integer $id | |
128 | + * @return Catalog the loaded model | |
129 | + * @throws NotFoundHttpException if the model cannot be found | |
130 | + */ | |
131 | + protected function findModel($id) | |
132 | + { | |
133 | + if (($model = Catalog::findOne($id)) !== null) | |
134 | + { | |
135 | + return $model; | |
136 | + } | |
137 | + else | |
138 | + { | |
139 | + throw new NotFoundHttpException('The requested page does not exist.'); | |
140 | + } | |
141 | + } | |
142 | +} | ... | ... |
1 | +<?php | |
2 | + | |
3 | +namespace backend\models; | |
4 | + | |
5 | +use Yii; | |
6 | +use yii\base\Model; | |
7 | +use yii\data\ActiveDataProvider; | |
8 | +use common\models\Catalog; | |
9 | + | |
10 | +/** | |
11 | + * SearchCatalog represents the model behind the search form about `common\models\Catalog`. | |
12 | + */ | |
13 | +class SearchCatalog extends Catalog | |
14 | +{ | |
15 | + public $title; | |
16 | + | |
17 | + /** | |
18 | + * @inheritdoc | |
19 | + */ | |
20 | + public function rules() | |
21 | + { | |
22 | + return [ | |
23 | + [['id', 'parent_id', 'type', 'subtype', 'status', 'sort'], 'integer'], | |
24 | + [['cover', 'options'], 'safe'], | |
25 | + // + поиск по title | |
26 | + [['title'], 'safe'] | |
27 | + ]; | |
28 | + } | |
29 | + | |
30 | + /** | |
31 | + * @inheritdoc | |
32 | + */ | |
33 | + public function scenarios() | |
34 | + { | |
35 | + // bypass scenarios() implementation in the parent class | |
36 | + return Model::scenarios(); | |
37 | + } | |
38 | + | |
39 | + /** | |
40 | + * Creates data provider instance with search query applied | |
41 | + * | |
42 | + * @param array $params | |
43 | + * | |
44 | + * @return ActiveDataProvider | |
45 | + */ | |
46 | + public function search($params) | |
47 | + { | |
48 | + $query = Catalog::find(); | |
49 | + | |
50 | + $dataProvider = new ActiveDataProvider([ | |
51 | + 'query' => $query, | |
52 | + ]); | |
53 | + | |
54 | + // + поиск по title | |
55 | + $dataProvider->setSort([ | |
56 | + 'attributes' => [ | |
57 | + 'id', | |
58 | + 'title' => [ | |
59 | + 'asc' => ['title' => SORT_ASC], | |
60 | + 'desc' => ['title' => SORT_DESC], | |
61 | + 'label' => 'title', | |
62 | + 'default' => SORT_ASC | |
63 | + ] | |
64 | + ] | |
65 | + ]); | |
66 | + | |
67 | + $this->load($params); | |
68 | + | |
69 | + if (!$this->validate()) | |
70 | + { | |
71 | + // uncomment the following line if you do not want to return any records when validation fails | |
72 | + // $query->where('0=1'); | |
73 | + | |
74 | + // + поиск по title | |
75 | + $query->joinWith(['catalog_i18n']); | |
76 | + | |
77 | + return $dataProvider; | |
78 | + } | |
79 | + | |
80 | + $query->andFilterWhere([ | |
81 | + 'id' => $this->id, | |
82 | + 'parent_id' => $this->parent_id, | |
83 | + 'type' => $this->type, | |
84 | + 'subtype' => $this->subtype, | |
85 | + 'status' => $this->status, | |
86 | + 'sort' => $this->sort, | |
87 | + ]); | |
88 | + | |
89 | + $query->andFilterWhere(['like', 'cover', $this->cover]) | |
90 | + ->andFilterWhere(['like', 'options', $this->options]); | |
91 | + | |
92 | + // + поиск по title | |
93 | + $query->joinWith(['relationTable' => function ($q) | |
94 | + { | |
95 | + //$q->where("catalog_i18n.title LIKE '%". $this->title . "%'"); | |
96 | + $q->where(['like', 'catalog_i18n.title', $this->title]); | |
97 | + }]); | |
98 | + | |
99 | + return $dataProvider; | |
100 | + } | |
101 | +} | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | +use yii\widgets\ActiveForm; | |
5 | + | |
6 | +/* @var $this yii\web\View */ | |
7 | +/* @var $model common\models\Catalog */ | |
8 | +/* @var $form yii\widgets\ActiveForm */ | |
9 | +?> | |
10 | + | |
11 | +<div class="catalog-form"> | |
12 | + | |
13 | + <?php $form = ActiveForm::begin(); ?> | |
14 | + | |
15 | + <?= $form->field($model, 'title')->textInput() ?> | |
16 | + | |
17 | + <?= $form->field($model, 'parent_id')->textInput() ?> | |
18 | + | |
19 | + <?= $form->field($model, 'type')->textInput() ?> | |
20 | + | |
21 | + <?= $form->field($model, 'subtype')->textInput() ?> | |
22 | + | |
23 | + <?= $form->field($model, 'cover')->textInput(['maxlength' => true]) ?> | |
24 | + | |
25 | + <?= $form->field($model, 'options')->textInput() ?> | |
26 | + | |
27 | + <?= $form->field($model, 'status')->textInput() ?> | |
28 | + | |
29 | + <?= $form->field($model, 'sort')->textInput() ?> | |
30 | + | |
31 | + <div class="form-group"> | |
32 | + <?= Html::submitButton($model->isNewRecord ? Yii::t('app', 'Create') : Yii::t('app', 'Update'), ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?> | |
33 | + </div> | |
34 | + | |
35 | + <?php ActiveForm::end(); ?> | |
36 | + | |
37 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | +use yii\widgets\ActiveForm; | |
5 | + | |
6 | +/* @var $this yii\web\View */ | |
7 | +/* @var $model backend\models\SearchCatalog */ | |
8 | +/* @var $form yii\widgets\ActiveForm */ | |
9 | +?> | |
10 | + | |
11 | +<div class="catalog-search"> | |
12 | + | |
13 | + <?php $form = ActiveForm::begin([ | |
14 | + 'action' => ['index'], | |
15 | + 'method' => 'get', | |
16 | + ]); ?> | |
17 | + | |
18 | + <?= $form->field($model, 'id') ?> | |
19 | + | |
20 | + <?= $form->field($model, 'parent_id') ?> | |
21 | + | |
22 | + <?= $form->field($model, 'type') ?> | |
23 | + | |
24 | + <?= $form->field($model, 'subtype') ?> | |
25 | + | |
26 | + <?= $form->field($model, 'cover') ?> | |
27 | + | |
28 | + <?php // echo $form->field($model, 'options') ?> | |
29 | + | |
30 | + <?php // echo $form->field($model, 'status') ?> | |
31 | + | |
32 | + <?php // echo $form->field($model, 'sort') ?> | |
33 | + | |
34 | + <div class="form-group"> | |
35 | + <?= Html::submitButton(Yii::t('app', 'Search'), ['class' => 'btn btn-primary']) ?> | |
36 | + <?= Html::resetButton(Yii::t('app', 'Reset'), ['class' => 'btn btn-default']) ?> | |
37 | + </div> | |
38 | + | |
39 | + <?php ActiveForm::end(); ?> | |
40 | + | |
41 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | + | |
5 | + | |
6 | +/* @var $this yii\web\View */ | |
7 | +/* @var $model common\models\Catalog */ | |
8 | + | |
9 | +$this->title = Yii::t('app', 'Create Catalog'); | |
10 | +$this->params['breadcrumbs'][] = ['label' => Yii::t('app', 'Catalogs'), 'url' => ['index']]; | |
11 | +$this->params['breadcrumbs'][] = $this->title; | |
12 | +?> | |
13 | +<div class="catalog-create"> | |
14 | + | |
15 | + <h1><?= Html::encode($this->title) ?></h1> | |
16 | + | |
17 | + <?= $this->render('_form', [ | |
18 | + 'model' => $model, | |
19 | + ]) ?> | |
20 | + | |
21 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | +use yii\grid\GridView; | |
5 | + | |
6 | +/* @var $this yii\web\View */ | |
7 | +/* @var $searchModel backend\models\SearchCatalog */ | |
8 | +/* @var $dataProvider yii\data\ActiveDataProvider */ | |
9 | + | |
10 | +$this->title = Yii::t('app', 'Catalogs'); | |
11 | +$this->params['breadcrumbs'][] = $this->title; | |
12 | +?> | |
13 | +<div class="catalog-index"> | |
14 | + | |
15 | + <h1><?= Html::encode($this->title) ?></h1> | |
16 | + <?php // echo $this->render('_search', ['model' => $searchModel]); ?> | |
17 | + | |
18 | + <p> | |
19 | + <?= Html::a(Yii::t('app', 'Create Catalog'), ['create'], ['class' => 'btn btn-success']) ?> | |
20 | + </p> | |
21 | + | |
22 | + <?= GridView::widget([ | |
23 | + 'dataProvider' => $dataProvider, | |
24 | + 'filterModel' => $searchModel, | |
25 | + 'columns' => [ | |
26 | + ['class' => 'yii\grid\SerialColumn'], | |
27 | + | |
28 | + 'id', | |
29 | + 'parent_id', | |
30 | + 'title', | |
31 | + 'type', | |
32 | + 'subtype', | |
33 | + // 'options', | |
34 | + // 'status', | |
35 | + // 'sort', | |
36 | + | |
37 | + ['class' => 'yii\grid\ActionColumn'], | |
38 | + ], | |
39 | + ]); ?> | |
40 | + | |
41 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | + | |
5 | +/* @var $this yii\web\View */ | |
6 | +/* @var $model common\models\Catalog */ | |
7 | + | |
8 | +$this->title = Yii::t('app', 'Update {modelClass}: ', [ | |
9 | + 'modelClass' => 'Catalog', | |
10 | +]) . ' ' . $model->id; | |
11 | +$this->params['breadcrumbs'][] = ['label' => Yii::t('app', 'Catalogs'), 'url' => ['index']]; | |
12 | +$this->params['breadcrumbs'][] = ['label' => $model->id, 'url' => ['view', 'id' => $model->id]]; | |
13 | +$this->params['breadcrumbs'][] = Yii::t('app', 'Update'); | |
14 | +?> | |
15 | +<div class="catalog-update"> | |
16 | + | |
17 | + <h1><?= Html::encode($this->title) ?></h1> | |
18 | + | |
19 | + <?= $this->render('_form', [ | |
20 | + 'model' => $model, | |
21 | + ]) ?> | |
22 | + | |
23 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +use yii\helpers\Html; | |
4 | +use yii\widgets\DetailView; | |
5 | + | |
6 | +/* @var $this yii\web\View */ | |
7 | +/* @var $model common\models\Catalog */ | |
8 | + | |
9 | +$this->title = $model->id; | |
10 | +$this->params['breadcrumbs'][] = ['label' => Yii::t('app', 'Catalogs'), 'url' => ['index']]; | |
11 | +$this->params['breadcrumbs'][] = $this->title; | |
12 | +?> | |
13 | +<div class="catalog-view"> | |
14 | + | |
15 | + <h1><?= Html::encode($this->title) ?></h1> | |
16 | + | |
17 | + <p> | |
18 | + <?= Html::a(Yii::t('app', 'Update'), ['update', 'id' => $model->id], ['class' => 'btn btn-primary']) ?> | |
19 | + <?= Html::a(Yii::t('app', 'Delete'), ['delete', 'id' => $model->id], [ | |
20 | + 'class' => 'btn btn-danger', | |
21 | + 'data' => [ | |
22 | + 'confirm' => Yii::t('app', 'Are you sure you want to delete this item?'), | |
23 | + 'method' => 'post', | |
24 | + ], | |
25 | + ]) ?> | |
26 | + </p> | |
27 | + | |
28 | + <?= DetailView::widget([ | |
29 | + 'model' => $model, | |
30 | + 'attributes' => [ | |
31 | + 'id', | |
32 | + 'parent_id', | |
33 | + 'type', | |
34 | + 'subtype', | |
35 | + 'cover', | |
36 | + 'options', | |
37 | + 'status', | |
38 | + 'sort', | |
39 | + ], | |
40 | + ]) ?> | |
41 | + | |
42 | +</div> | ... | ... |
1 | +<?php | |
2 | + | |
3 | +namespace common\models; | |
4 | + | |
5 | +use Yii; | |
6 | + | |
7 | +/** | |
8 | + * This is the model class for table "catalog". | |
9 | + * | |
10 | + * @property integer $id | |
11 | + * @property integer $parent_id | |
12 | + * @property integer $type | |
13 | + * @property integer $subtype | |
14 | + * @property string $cover | |
15 | + * @property string $options | |
16 | + * @property integer $status | |
17 | + * @property integer $sort | |
18 | + */ | |
19 | +class Catalog extends \yii\db\ActiveRecord | |
20 | +{ | |
21 | + /** | |
22 | + * @inheritdoc | |
23 | + */ | |
24 | + public static function tableName() | |
25 | + { | |
26 | + return 'catalog'; | |
27 | + } | |
28 | + | |
29 | + /** | |
30 | + * @inheritdoc | |
31 | + */ | |
32 | + public function rules() | |
33 | + { | |
34 | + return [ | |
35 | + [['parent_id', 'type', 'subtype', 'status', 'sort'], 'integer'], | |
36 | + [['options'], 'string'], | |
37 | + [['cover'], 'string', 'max' => 32], | |
38 | + ]; | |
39 | + } | |
40 | + | |
41 | + /** | |
42 | + * @inheritdoc | |
43 | + */ | |
44 | + public function attributeLabels() | |
45 | + { | |
46 | + return [ | |
47 | + 'id' => Yii::t('app', 'ID'), | |
48 | + 'parent_id' => Yii::t('app', 'Parent ID'), | |
49 | + 'type' => Yii::t('app', 'Type'), | |
50 | + 'subtype' => Yii::t('app', 'Subtype'), | |
51 | + 'cover' => Yii::t('app', 'Cover'), | |
52 | + 'options' => Yii::t('app', 'Options'), | |
53 | + 'status' => Yii::t('app', 'Status'), | |
54 | + 'sort' => Yii::t('app', 'Sort'), | |
55 | + ]; | |
56 | + } | |
57 | + | |
58 | + /** | |
59 | + * @return \yii\db\ActiveQuery | |
60 | + */ | |
61 | + public function getRelationTable() | |
62 | + { | |
63 | + return $this->hasOne(CatalogLang::className(), ['catalog' => 'id']); | |
64 | + } | |
65 | + | |
66 | + public function getTitle() | |
67 | + { | |
68 | + return $this->relationTable->title; | |
69 | + } | |
70 | + | |
71 | +} | ... | ... |
1 | +<?php | |
2 | + | |
3 | +namespace common\models; | |
4 | + | |
5 | +use Yii; | |
6 | + | |
7 | +/** | |
8 | + * This is the model class for table "catalog_i18n". | |
9 | + * | |
10 | + * @property integer $catalog | |
11 | + * @property integer $lang_id | |
12 | + * @property string $title | |
13 | + * @property string $alias | |
14 | + * @property string $meta_title | |
15 | + * @property string $meta_keywords | |
16 | + * @property string $meta_description | |
17 | + * @property string $full_alias | |
18 | + */ | |
19 | +class CatalogLang extends \yii\db\ActiveRecord | |
20 | +{ | |
21 | + /** | |
22 | + * @inheritdoc | |
23 | + */ | |
24 | + public static function tableName() | |
25 | + { | |
26 | + return 'catalog_i18n'; | |
27 | + } | |
28 | + | |
29 | + /** | |
30 | + * @inheritdoc | |
31 | + */ | |
32 | + public function rules() | |
33 | + { | |
34 | + return [ | |
35 | + [['catalog', 'lang_id', 'title', 'alias'], 'required'], | |
36 | + [['catalog', 'lang_id'], 'integer'], | |
37 | + [['title'], 'string', 'max' => 1024], | |
38 | + [['alias'], 'string', 'max' => 128], | |
39 | + [['meta_title', 'meta_keywords', 'meta_description', 'full_alias'], 'string', 'max' => 255], | |
40 | + [['alias', 'lang_id'], 'unique', 'targetAttribute' => ['alias', 'lang_id'], 'message' => 'The combination of Lang ID and Alias has already been taken.'] | |
41 | + ]; | |
42 | + } | |
43 | + | |
44 | + /** | |
45 | + * @inheritdoc | |
46 | + */ | |
47 | + public function attributeLabels() | |
48 | + { | |
49 | + return [ | |
50 | + 'catalog' => Yii::t('app', 'Catalog'), | |
51 | + 'lang_id' => Yii::t('app', 'Lang ID'), | |
52 | + 'title' => Yii::t('app', 'Title'), | |
53 | + 'alias' => Yii::t('app', 'Alias'), | |
54 | + 'meta_title' => Yii::t('app', 'Meta Title'), | |
55 | + 'meta_keywords' => Yii::t('app', 'Meta Keywords'), | |
56 | + 'meta_description' => Yii::t('app', 'Meta Description'), | |
57 | + 'full_alias' => Yii::t('app', 'Full Alias'), | |
58 | + ]; | |
59 | + } | |
60 | +} | ... | ... |