Commit d15518de77130b35cf47e2f8c45093229a0df3c6
Merge remote-tracking branch 'origin/clinica_alias'
Showing
7 changed files
with
132 additions
and
94 deletions
Show diff stats
clinica deleted
| 1 | -Subproject commit 8b1b0efde228ff71e43eba90086e0c15392645cc |
common/models/Question.php
common/models/Service.php
common/models/ServiceLang.php
frontend/controllers/SiteController.php
| 1 | 1 | <?php |
| 2 | 2 | namespace frontend\controllers; |
| 3 | 3 | |
| 4 | + use artbox\core\models\Alias; | |
| 4 | 5 | use artbox\core\models\Feedback; |
| 6 | + use artbox\core\models\Language; | |
| 5 | 7 | use common\models\Comment; |
| 6 | 8 | use common\models\Package; |
| 7 | 9 | use common\models\Question; |
| ... | ... | @@ -13,10 +15,13 @@ |
| 13 | 15 | use yii\db\ActiveQuery; |
| 14 | 16 | use yii\db\Expression; |
| 15 | 17 | use yii\filters\VerbFilter; |
| 18 | + use yii\helpers\ArrayHelper; | |
| 19 | + use yii\helpers\Json; | |
| 16 | 20 | use yii\swiftmailer\Mailer; |
| 17 | 21 | use yii\web\BadRequestHttpException; |
| 18 | 22 | use yii\web\Controller; |
| 19 | 23 | use yii\web\Response; |
| 24 | + use yii\helpers\VarDumper as d; | |
| 20 | 25 | |
| 21 | 26 | /** |
| 22 | 27 | * Site controller |
| ... | ... | @@ -224,6 +229,7 @@ |
| 224 | 229 | } |
| 225 | 230 | |
| 226 | 231 | public function actionQuestions($service_id = null){ |
| 232 | + Language::getCurrent(); | |
| 227 | 233 | |
| 228 | 234 | if (\Yii::$app->request->isAjax){ |
| 229 | 235 | Yii::$app->response->format = Response::FORMAT_JSON; |
| ... | ... | @@ -248,11 +254,16 @@ |
| 248 | 254 | ], |
| 249 | 255 | ]); |
| 250 | 256 | $services = Service::find()->where(['status' => true])->andWhere(['parent_id' => null])->all(); |
| 251 | - | |
| 257 | + $route = []; | |
| 258 | + foreach ($services as $service){ | |
| 259 | + $route[] = Json::encode(['site/questions', 'service_id' => $service->id]); | |
| 260 | + } | |
| 261 | + $alias = Alias::find()->where(['route' => $route])->andWhere(['language_id' => Language::getCurrent()->id])->indexBy('route')->asArray()->all(); | |
| 252 | 262 | return $this->render('questions', [ |
| 253 | 263 | 'dataProvider' => $dataProvider, |
| 254 | 264 | 'services' => $services, |
| 255 | - 'service_id' => $service_id | |
| 265 | + 'service_id' => $service_id, | |
| 266 | + 'alias' => $alias | |
| 256 | 267 | ]); |
| 257 | 268 | } |
| 258 | 269 | ... | ... |
frontend/views/site/questions.php
| 1 | 1 | <?php |
| 2 | 2 | /** |
| 3 | 3 | * @var \yii\data\ActiveDataProvider $dataProvider |
| 4 | - * @var \common\models\Service[] $services | |
| 5 | - * @var \yii\web\View $this | |
| 6 | - * @var int $service_id | |
| 4 | + * @var \common\models\Service[] $services | |
| 5 | + * @var \yii\web\View $this | |
| 6 | + * @var int $service_id | |
| 7 | + * @var array $alias; | |
| 7 | 8 | */ |
| 8 | 9 | |
| 9 | 10 | use artbox\core\helpers\Url; |
| 10 | 11 | use common\models\Question; |
| 11 | 12 | use yii\helpers\ArrayHelper; |
| 12 | 13 | use yii\helpers\Html; |
| 14 | + use yii\helpers\Json; | |
| 13 | 15 | use yii\widgets\ActiveForm; |
| 14 | 16 | use yii\widgets\ListView; |
| 17 | + use yii\helpers\VarDumper as d; | |
| 18 | + use artbox\core\models\Alias; | |
| 15 | 19 | |
| 16 | - $this->params[ 'breadcrumbs'][] = \Yii::t('app', 'Quest/Answer'); | |
| 20 | + $this->params[ 'breadcrumbs' ][] = \Yii::t('app', 'Quest/Answer'); | |
| 17 | 21 | |
| 18 | - $model = new Question(['service_id' => $service_id]); | |
| 22 | + $model = new Question([ 'service_id' => $service_id ]); | |
| 19 | 23 | $model->scenario = Question::SCENARIO_QUESTION; |
| 20 | 24 | |
| 21 | - $data = ['' =>\Yii::t('app','General issues')] + ArrayHelper::map($services, 'id', 'title'); | |
| 22 | - ?> | |
| 25 | + $data = [ '' => \Yii::t('app', 'General issues') ] + ArrayHelper::map($services, 'id', 'title'); | |
| 26 | +?> | |
| 23 | 27 | |
| 24 | 28 | |
| 25 | 29 | <section class="section-service-page section-answer-page"> |
| 26 | - <div class="container"> | |
| 27 | - <div class="row"> | |
| 28 | - <div class="col-xs-12 col-sm-12"> | |
| 29 | - <h1 class="title-pages"><?=\Yii::t('app','Quest/Answer')?></h1> | |
| 30 | - </div> | |
| 30 | + <div class="container"> | |
| 31 | + <div class="row"> | |
| 32 | + <div class="col-xs-12 col-sm-12"> | |
| 33 | + <h1 class="title-pages"><?= \Yii::t('app', 'Quest/Answer') ?></h1> | |
| 34 | + </div> | |
| 35 | + </div> | |
| 36 | + <div class="row"> | |
| 37 | + <div class="col-xs-12 col-sm-12"> | |
| 38 | + <div class="style add-answer-forms"> | |
| 39 | + <span class="btn_"><?= \Yii::t('app', 'Asc question'); ?></span> | |
| 31 | 40 | </div> |
| 32 | - <div class="row"> | |
| 33 | - <div class="col-xs-12 col-sm-12"> | |
| 34 | - <div class="style add-answer-forms"> | |
| 35 | - <span class="btn_"><?=\Yii::t('app','Asc question');?></span> | |
| 36 | - </div> | |
| 37 | - <div class="style hidden-answer-comment-form hidden"> | |
| 38 | - <div class="hidden-answer-comment-form-title"><?=\Yii::t('app','Asc question');?></div> | |
| 39 | - <?php $form = ActiveForm::begin(['id' => 'total_question_form'])?> | |
| 40 | - <div class="col-xs-12 col-sm-6"> | |
| 41 | - <div class="input-wr"> | |
| 42 | - <?=$form->field($model, 'service_id')->dropDownList($data) | |
| 43 | - ->label(\Yii::t('app','Choosing department'))?> | |
| 44 | - </div> | |
| 45 | - | |
| 46 | - <div class="input-wr required"> | |
| 47 | - <?=$form->field($model, 'name') | |
| 48 | - ->label(\Yii::t('app','FIO'))?> | |
| 49 | - </div> | |
| 50 | - <div class="input-wr required"> | |
| 51 | - <?=$form->field($model, 'email') | |
| 52 | - ->label(\Yii::t('app','Email'))?> | |
| 53 | - </div> | |
| 54 | - </div> | |
| 55 | - <div class="col-xs-12 col-sm-6"> | |
| 56 | - <div class="input-wr"> | |
| 57 | - <?=$form->field($model, 'question')->textarea(['cols' => 30, 'rows' => 10]) | |
| 58 | - ->label(\Yii::t('app','Yours question'))?> | |
| 59 | -<!-- <label class="control-label" for="feedback-name">Ваш вопрос</label>--> | |
| 60 | -<!-- <textarea name="" id="" cols="30" rows="10"></textarea>--> | |
| 61 | - </div> | |
| 62 | - </div> | |
| 63 | - <div class="col-xs-12 col-sm-12"> | |
| 64 | - <div class="button-wr submit-close-wr-c-a"> | |
| 65 | - <?=Html::submitButton(\Yii::t('app','Send question'))?> | |
| 66 | -<!-- <button type="submit">Отправить вопрос</button>--> | |
| 67 | - <div class="submit-close-c-a submit-close-c-a-page"> | |
| 68 | - <span><?=\Yii::t('app','Minimize a window');?></span></div> | |
| 69 | - </div> | |
| 70 | - </div> | |
| 71 | - <?php $form::end();?> | |
| 72 | - </div> | |
| 41 | + <div class="style hidden-answer-comment-form hidden"> | |
| 42 | + <div class="hidden-answer-comment-form-title"><?= \Yii::t('app', 'Asc question'); ?></div> | |
| 43 | + <?php $form = ActiveForm::begin([ 'id' => 'total_question_form' ]) ?> | |
| 44 | + <div class="col-xs-12 col-sm-6"> | |
| 45 | + <div class="input-wr"> | |
| 46 | + <?= $form->field($model, 'service_id') | |
| 47 | + ->dropDownList($data) | |
| 48 | + ->label(\Yii::t('app', 'Choosing department')) ?> | |
| 73 | 49 | </div> |
| 74 | - <div class="col-xs-12 col-sm-12"> | |
| 75 | - <ul class="answers-category-list"> | |
| 76 | - <li <?=($service_id == null ? 'class="active"' : '')?>> | |
| 77 | - <a href="<?=Url::current(['service_id' => null])?>"> | |
| 78 | - <span><?=\Yii::t('app','General issues');?></span></a></li> | |
| 79 | - <?php foreach ($services as $service){?> | |
| 80 | - <li <?=($service_id == $service->id ? 'class="active"' : '')?>> | |
| 81 | - <a href="<?=Url::current(['service_id' => $service->id])?>"><span><?=$service->title?></span></a></li> | |
| 82 | - <?php } ?> | |
| 83 | - </ul> | |
| 50 | + | |
| 51 | + <div class="input-wr required"> | |
| 52 | + <?= $form->field($model, 'name') | |
| 53 | + ->label(\Yii::t('app', 'FIO')) ?> | |
| 84 | 54 | </div> |
| 85 | - <div class="col-xs-12 col-sm-12"> | |
| 86 | - <div class="service-comments-wr style"> | |
| 87 | - <?php echo ListView::widget( | |
| 88 | - [ | |
| 89 | - 'itemOptions' => [ | |
| 90 | - ], | |
| 91 | - 'layout' => '{items}', | |
| 92 | - 'dataProvider' => $dataProvider, | |
| 93 | - 'itemView' => '_question' | |
| 94 | - ] | |
| 95 | - );?> | |
| 96 | - | |
| 97 | - | |
| 98 | - <div class="style navi-c-a"> | |
| 99 | - <?php echo \frontend\widgets\FrontendPager::widget( | |
| 100 | - [ | |
| 101 | - 'pagination' => $dataProvider->pagination, | |
| 102 | - 'prevPageLabel' => 'previous', | |
| 103 | - 'nextPageLabel' => 'next', | |
| 104 | - 'maxButtonCount' => 3, | |
| 105 | - 'lastPageLabel' => 'last_number', | |
| 106 | - ] | |
| 107 | - );?> | |
| 108 | - </div> | |
| 109 | - | |
| 110 | - | |
| 111 | - </div> | |
| 55 | + <div class="input-wr required"> | |
| 56 | + <?= $form->field($model, 'email') | |
| 57 | + ->label(\Yii::t('app', 'Email')) ?> | |
| 58 | + </div> | |
| 59 | + </div> | |
| 60 | + <div class="col-xs-12 col-sm-6"> | |
| 61 | + <div class="input-wr"> | |
| 62 | + <?= $form->field($model, 'question') | |
| 63 | + ->textarea( | |
| 64 | + [ | |
| 65 | + 'cols' => 30, | |
| 66 | + 'rows' => 10, | |
| 67 | + ] | |
| 68 | + ) | |
| 69 | + ->label(\Yii::t('app', 'Yours question')) ?> | |
| 70 | + <!-- <label class="control-label" for="feedback-name">Ваш вопрос</label>--> | |
| 71 | + <!-- <textarea name="" id="" cols="30" rows="10"></textarea>--> | |
| 112 | 72 | </div> |
| 73 | + </div> | |
| 74 | + <div class="col-xs-12 col-sm-12"> | |
| 75 | + <div class="button-wr submit-close-wr-c-a"> | |
| 76 | + <?= Html::submitButton(\Yii::t('app', 'Send question')) ?> | |
| 77 | + <!-- <button type="submit">Отправить вопрос</button>--> | |
| 78 | + <div class="submit-close-c-a submit-close-c-a-page"> | |
| 79 | + <span><?= \Yii::t('app', 'Minimize a window'); ?></span></div> | |
| 80 | + </div> | |
| 81 | + </div> | |
| 82 | + <?php $form::end(); ?> | |
| 83 | + </div> | |
| 84 | + </div> | |
| 85 | + <div class="col-xs-12 col-sm-12"> | |
| 86 | + <ul class="answers-category-list"> | |
| 87 | + <li <?= ( $service_id == null ? 'class="active"' : '' ) ?>> | |
| 88 | + <a href="<?= Url::current([ 'service_id' => null ]) ?>"> | |
| 89 | + <span><?= \Yii::t('app', 'General issues'); ?></span></a></li> | |
| 90 | + <?php foreach ($services as $service) { | |
| 91 | + $route = Json::encode(['site/questions', 'service_id' => $service->id]); | |
| 92 | + ?> | |
| 93 | + <li <?= ( $service_id == $service->id ? 'class="active"' : '' ) ?>> | |
| 94 | + <a href="<?= ( array_key_exists($route, $alias) ) ? Url::to( | |
| 95 | + [ 'alias' => $alias[$route] ] | |
| 96 | + ) : Url::current([ 'service_id' => $service->id ]) ?>"><span><?= $service->title ?></span></a></li> | |
| 97 | + <?php } ?> | |
| 98 | + | |
| 99 | + | |
| 100 | + </ul> | |
| 101 | + </div> | |
| 102 | + <div class="col-xs-12 col-sm-12"> | |
| 103 | + <div class="service-comments-wr style"> | |
| 104 | + <?php echo ListView::widget( | |
| 105 | + [ | |
| 106 | + 'itemOptions' => [], | |
| 107 | + 'layout' => '{items}', | |
| 108 | + 'dataProvider' => $dataProvider, | |
| 109 | + 'itemView' => '_question', | |
| 110 | + ] | |
| 111 | + ); ?> | |
| 112 | + | |
| 113 | + | |
| 114 | + <div class="style navi-c-a"> | |
| 115 | + <?php echo \frontend\widgets\FrontendPager::widget( | |
| 116 | + [ | |
| 117 | + 'pagination' => $dataProvider->pagination, | |
| 118 | + 'prevPageLabel' => 'previous', | |
| 119 | + 'nextPageLabel' => 'next', | |
| 120 | + 'maxButtonCount' => 3, | |
| 121 | + 'lastPageLabel' => 'last_number', | |
| 122 | + ] | |
| 123 | + ); ?> | |
| 124 | + </div> | |
| 125 | + | |
| 126 | + | |
| 113 | 127 | </div> |
| 128 | + </div> | |
| 114 | 129 | </div> |
| 130 | + </div> | |
| 115 | 131 | </section> | ... | ... |