Commit aee73024e7bc8ae82b15390c309258d4247ad7c8
1 parent
e950ba39
Artbox great prepairings
Showing
19 changed files
with
144 additions
and
1044 deletions
Show diff stats
backend/config/main.php
1 | 1 | <?php |
2 | 2 | use artbox\core\components\SeoUrlManager; |
3 | + use artbox\core\components\Sitemap; | |
3 | 4 | use artbox\core\models\Page; |
4 | - use common\components\Sitemap; | |
5 | 5 | |
6 | 6 | $params = array_merge( |
7 | 7 | require( __DIR__ . '/../../common/config/params.php' ), |
... | ... | @@ -18,9 +18,9 @@ |
18 | 18 | 'controllerNamespace' => 'backend\controllers', |
19 | 19 | 'bootstrap' => [ 'log' ], |
20 | 20 | 'controllerMap' => [ |
21 | - 'profile' => 'artbox\core\controllers\ProfileController', | |
22 | - 'page' => 'artbox\core\controllers\PageController', | |
23 | - 'alias' => 'artbox\core\controllers\AliasController', | |
21 | + 'profile' => 'artbox\core\controllers\ProfileController', | |
22 | + 'page' => 'artbox\core\controllers\PageController', | |
23 | + 'alias' => 'artbox\core\controllers\AliasController', | |
24 | 24 | 'seo' => 'artbox\core\controllers\SeoController', |
25 | 25 | 'feedback' => 'artbox\core\controllers\FeedbackController', |
26 | 26 | 'weblog-article' => 'artbox\weblog\controllers\ArticleController', |
... | ... | @@ -35,16 +35,17 @@ |
35 | 35 | 'variant-option-complementary' => 'artbox\catalog\controllers\VariantOptionComplController', |
36 | 36 | 'variant-option-exclusion' => 'artbox\catalog\controllers\VariantOptionExclController', |
37 | 37 | 'product-option-complementary' => 'artbox\catalog\controllers\ProductOptionComplController', |
38 | - 'product-option-exclusion' => 'artbox\catalog\controllers\ProductOptionExclController', | |
39 | - 'import' => 'artbox\catalog\controllers\ImportController', | |
40 | - 'blog-article' => 'artbox\weblog\controllers\ArticleController', | |
41 | - 'blog-category' => 'artbox\weblog\controllers\CategoryController', | |
42 | - 'blog-tag' => 'artbox\weblog\controllers\TagController', | |
43 | - 'order' => 'artbox\order\controllers\OrderController', | |
44 | - 'order-product' => 'artbox\order\controllers\OrderProductController', | |
45 | - 'label' => 'artbox\order\controllers\LabelController', | |
46 | - 'delivery' => 'artbox\order\controllers\DeliveryController', | |
47 | - 'payment' => 'artbox\order\controllers\PaymentController', | |
38 | + 'product-option-exclusion' => 'artbox\catalog\controllers\ProductOptionExclController', | |
39 | + 'import' => 'artbox\catalog\controllers\ImportController', | |
40 | + 'blog-article' => 'artbox\weblog\controllers\ArticleController', | |
41 | + 'blog-category' => 'artbox\weblog\controllers\CategoryController', | |
42 | + 'blog-tag' => 'artbox\weblog\controllers\TagController', | |
43 | + 'order' => 'artbox\order\controllers\OrderController', | |
44 | + 'order-product' => 'artbox\order\controllers\OrderProductController', | |
45 | + 'label' => 'artbox\order\controllers\LabelController', | |
46 | + 'delivery' => 'artbox\order\controllers\DeliveryController', | |
47 | + 'payment' => 'artbox\order\controllers\PaymentController', | |
48 | + 'sitemap' => 'artbox\core\controllers\SitemapController', | |
48 | 49 | ], |
49 | 50 | 'components' => [ |
50 | 51 | 'assetManager' => [ | ... | ... |
backend/controllers/SitemapController.php deleted
1 | -<?php | |
2 | - namespace backend\controllers; | |
3 | - | |
4 | - use common\components\Sitemap; | |
5 | - use common\models\SitemapDynamic; | |
6 | - use common\models\SitemapStatic; | |
7 | - use yii\bootstrap\ActiveForm; | |
8 | - use yii\bootstrap\Html; | |
9 | - use yii\filters\AccessControl; | |
10 | - use yii\helpers\Json; | |
11 | - use yii\web\Controller; | |
12 | - | |
13 | - /** | |
14 | - * Class SitemapController | |
15 | - */ | |
16 | - class SitemapController extends Controller | |
17 | - { | |
18 | - /** | |
19 | - * @inheritdoc | |
20 | - */ | |
21 | - public function behaviors() | |
22 | - { | |
23 | - return [ | |
24 | - 'access' => [ | |
25 | - 'class' => AccessControl::className(), | |
26 | - 'rules' => [ | |
27 | - [ | |
28 | - 'actions' => [ | |
29 | - 'login', | |
30 | - 'error', | |
31 | - ], | |
32 | - 'allow' => true, | |
33 | - ], | |
34 | - [ | |
35 | - 'allow' => true, | |
36 | - 'roles' => [ '@' ], | |
37 | - ], | |
38 | - ], | |
39 | - ], | |
40 | - ]; | |
41 | - } | |
42 | - | |
43 | - /** | |
44 | - * Action to configure sitemap of the website | |
45 | - * | |
46 | - * @return string | |
47 | - */ | |
48 | - public function actionIndex() | |
49 | - { | |
50 | - return $this->render('index'); | |
51 | - } | |
52 | - | |
53 | - /** | |
54 | - * Action to configure sitemap of the website | |
55 | - * | |
56 | - * @return string | |
57 | - */ | |
58 | - public function actionUpdate() | |
59 | - { | |
60 | - /** | |
61 | - * @var Sitemap $sitemap | |
62 | - */ | |
63 | - $request = \Yii::$app->request; | |
64 | - // ***** Generate SitemapDynamic models for every entity in Sitemap component | |
65 | - $sitemap = \Yii::$app->get('sitemap'); | |
66 | - $entities = $sitemap->entities; | |
67 | - /** | |
68 | - * @var SitemapDynamic[] $entity_models | |
69 | - */ | |
70 | - $entity_models = []; | |
71 | - foreach ($entities as $entity) { | |
72 | - $entity_model = new SitemapDynamic(); | |
73 | - $entity_model->entity = $entity[ 'class' ]; | |
74 | - $entity_model->status = SitemapDynamic::STATUS_DISABLED; | |
75 | - $entity_models[] = $entity_model; | |
76 | - } | |
77 | - // ***** <<< End | |
78 | - if ($request->isPost) { | |
79 | - $success = false; | |
80 | - // ***** Create SitemapStatic models from POST and delete existing | |
81 | - $models = []; | |
82 | - $index = 1; | |
83 | - foreach ($request->post('SitemapStatic') as $item) { | |
84 | - $model = new SitemapStatic(); | |
85 | - if ($model->load($item, '') && $model->validate()) { | |
86 | - $model->id = $index++; | |
87 | - $models[] = $model; | |
88 | - } | |
89 | - } | |
90 | - if (!empty( $models )) { | |
91 | - $old = SitemapStatic::find() | |
92 | - ->all(); | |
93 | - foreach ($old as $item) { | |
94 | - $item->delete(); | |
95 | - } | |
96 | - foreach ($models as $model) { | |
97 | - $model->save(false); | |
98 | - $success = true; | |
99 | - } | |
100 | - } | |
101 | - // ***** <<< End | |
102 | - // ***** Create SitemapDynamic models from POST and delete existing | |
103 | - | |
104 | - /** | |
105 | - * @var SitemapDynamic[] $old_entity_models | |
106 | - */ | |
107 | - $old_entity_models = SitemapDynamic::find() | |
108 | - ->all(); | |
109 | - foreach ($old_entity_models as $old_entity_model) { | |
110 | - $old_entity_model->delete(); | |
111 | - } | |
112 | - $index = 1; | |
113 | - $entity_models = []; | |
114 | - foreach ($request->post('SitemapDynamic') as $item) { | |
115 | - $entity = new SitemapDynamic(); | |
116 | - if ($entity->load($item, '') && $entity->validate()) { | |
117 | - $entity->id = $index++; | |
118 | - $entity->save(false); | |
119 | - $entity_models[] = $entity; | |
120 | - $success = true; | |
121 | - } | |
122 | - } | |
123 | - if ($success) { | |
124 | - if ($request->post('action', '') == 'generate') { | |
125 | - if ($sitemap->generateXML()) { | |
126 | - \Yii::$app->session->setFlash( | |
127 | - 'success', | |
128 | - \Yii::t( | |
129 | - 'core', | |
130 | - 'Карта сайта сгенерированна в ' . \Yii::getAlias( | |
131 | - $sitemap->path . '.' | |
132 | - ) | |
133 | - ) | |
134 | - ); | |
135 | - } | |
136 | - } | |
137 | - return $this->redirect([ 'index' ]); | |
138 | - } | |
139 | - // ***** <<< End | |
140 | - } else { | |
141 | - // ***** Find existing SitemapStatic models | |
142 | - $models = SitemapStatic::find() | |
143 | - ->all(); | |
144 | - if (empty( $models )) { | |
145 | - $models = [ new SitemapStatic() ]; | |
146 | - } | |
147 | - // ***** <<< End | |
148 | - // ***** Fill SitemapDynamic models from Sitemap component with existing models | |
149 | - /** | |
150 | - * @var SitemapDynamic[] $old_entity_models | |
151 | - */ | |
152 | - $old_entity_models = SitemapDynamic::find() | |
153 | - ->indexBy('entity') | |
154 | - ->all(); | |
155 | - foreach ($entity_models as $index => $entity_model) { | |
156 | - if (isset( $old_entity_models[ $entity_model->entity ] )) { | |
157 | - $entity_model->status = $old_entity_models[ $entity_model->entity ]->status; | |
158 | - $entity_model->priority = $old_entity_models[ $entity_model->entity ]->priority; | |
159 | - $entity_model->frequency = $old_entity_models[ $entity_model->entity ]->frequency; | |
160 | - } | |
161 | - } | |
162 | - // ***** <<< End | |
163 | - } | |
164 | - return $this->render( | |
165 | - 'update', | |
166 | - [ | |
167 | - 'models' => $models, | |
168 | - 'entity_models' => $entity_models, | |
169 | - ] | |
170 | - ); | |
171 | - } | |
172 | - | |
173 | - /** | |
174 | - * Create activeField for static sitemap | |
175 | - * | |
176 | - * @return string | |
177 | - */ | |
178 | - public function actionCreateStatic() | |
179 | - { | |
180 | - $content = ''; | |
181 | - $request = \Yii::$app->request; | |
182 | - $formId = $request->get('formId'); | |
183 | - $count = $request->get('count'); | |
184 | - if (empty( $formId ) || empty( $count )) { | |
185 | - return $this->renderContent($content); | |
186 | - } | |
187 | - $model = new SitemapStatic(); | |
188 | - $form = new ActiveForm(); | |
189 | - $content .= $form->field( | |
190 | - $model, | |
191 | - "[$count]url", | |
192 | - [ | |
193 | - 'options' => [ | |
194 | - 'class' => 'form-group col-xs-5 col-sm-6', | |
195 | - ], | |
196 | - ] | |
197 | - ) | |
198 | - ->textInput() | |
199 | - ->render(); | |
200 | - $content .= $form->field( | |
201 | - $model, | |
202 | - "[$count]frequency", | |
203 | - [ | |
204 | - 'options' => [ | |
205 | - 'class' => 'form-group col-xs-3 col-sm-3', | |
206 | - ], | |
207 | - ] | |
208 | - ) | |
209 | - ->dropDownList( | |
210 | - [ | |
211 | - 'always' => 'always', | |
212 | - 'hourly' => 'hourly', | |
213 | - 'daily' => 'daily', | |
214 | - 'weekly' => 'weekly', | |
215 | - 'monthly' => 'monthly', | |
216 | - 'yearly' => 'yearly', | |
217 | - 'never' => 'never', | |
218 | - ] | |
219 | - ) | |
220 | - ->render(); | |
221 | - $content .= $form->field( | |
222 | - $model, | |
223 | - "[$count]priority", | |
224 | - [ | |
225 | - 'options' => [ | |
226 | - 'class' => 'form-group col-xs-3 col-sm-2', | |
227 | - ], | |
228 | - ] | |
229 | - ) | |
230 | - ->textInput() | |
231 | - ->render(); | |
232 | - $content .= Html::icon( | |
233 | - 'minus', | |
234 | - [ | |
235 | - 'class' => 'col-xs-1 field-group-remove', | |
236 | - 'onclick' => 'sitemap_remove(this)', | |
237 | - ] | |
238 | - ); | |
239 | - foreach ($form->attributes as $index => $attribute) { | |
240 | - $content .= Html::script("$('#w0').yiiActiveForm('add', " . Json::htmlEncode($attribute) . ");"); | |
241 | - } | |
242 | - $content = Html::tag( | |
243 | - 'div', | |
244 | - $content, | |
245 | - [ | |
246 | - 'class' => 'row field-group', | |
247 | - ] | |
248 | - ); | |
249 | - $this->layout = false; | |
250 | - return $this->renderContent($content); | |
251 | - } | |
252 | - | |
253 | - /** | |
254 | - * Generate sitemap XML to Sitemap::$path | |
255 | - * | |
256 | - * @return bool | |
257 | - */ | |
258 | - public function actionGenerate() | |
259 | - { | |
260 | - $response = \Yii::$app->response; | |
261 | - $response->format = $response::FORMAT_JSON; | |
262 | - /** | |
263 | - * @var Sitemap $sitemap | |
264 | - */ | |
265 | - $sitemap = \Yii::$app->get('sitemap'); | |
266 | - return $sitemap->generateXML(); | |
267 | - } | |
268 | - } | |
269 | - | |
270 | 0 | \ No newline at end of file |
common/components/Sitemap.php deleted
1 | -<?php | |
2 | - namespace common\components; | |
3 | - | |
4 | - use common\models\SitemapDynamic; | |
5 | - use common\models\SitemapStatic; | |
6 | - use yii\base\Object; | |
7 | - use yii\db\ActiveRecord; | |
8 | - use yii\helpers\Html; | |
9 | - use yii\web\UrlManager; | |
10 | - | |
11 | - class Sitemap extends Object | |
12 | - { | |
13 | - public $entities = []; | |
14 | - public $path = '@frontend/web/sitemap.xml'; | |
15 | - public $url = 'sitemap.xml'; | |
16 | - | |
17 | - /** | |
18 | - * Get absolute url to sitemap.xml | |
19 | - * | |
20 | - * @return string | |
21 | - */ | |
22 | - public function getUrl(): string | |
23 | - { | |
24 | - /** | |
25 | - * @var UrlManager $urlManager | |
26 | - */ | |
27 | - $urlManager = \Yii::$app->get('urlManagerFrontend'); | |
28 | - return $urlManager->createAbsoluteUrl('/' . $this->url); | |
29 | - } | |
30 | - | |
31 | - /** | |
32 | - * Check whether sitemap.xml exist | |
33 | - * | |
34 | - * @return bool | |
35 | - */ | |
36 | - public function checkFileExist(): bool | |
37 | - { | |
38 | - return file_exists(\Yii::getAlias($this->path)); | |
39 | - } | |
40 | - /** | |
41 | - * Generate sitemap XML in $path | |
42 | - * | |
43 | - * @return bool | |
44 | - */ | |
45 | - public function generateXML(): bool | |
46 | - { | |
47 | - return $this->saveXML($this->generateOneShot()); | |
48 | - } | |
49 | - | |
50 | - /** | |
51 | - * Save generated xml to $path file | |
52 | - * | |
53 | - * @param string $xml | |
54 | - * | |
55 | - * @return bool | |
56 | - */ | |
57 | - protected function saveXML(string $xml): bool | |
58 | - { | |
59 | - $realpath = \Yii::getAlias($this->path); | |
60 | - if (file_put_contents($realpath, $xml)) { | |
61 | - return true; | |
62 | - } else { | |
63 | - return false; | |
64 | - } | |
65 | - } | |
66 | - | |
67 | - /** | |
68 | - * Generate xml from configs | |
69 | - * | |
70 | - * @return string | |
71 | - */ | |
72 | - public function generateOneShot(): string | |
73 | - { | |
74 | - /** | |
75 | - * @var UrlManager $urlManager | |
76 | - */ | |
77 | - $urlManager = \Yii::$app->get('urlManagerFrontend'); | |
78 | - $content = '<?xml version="1.0" encoding="UTF-8"?>'; | |
79 | - $content .= '<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">'; | |
80 | - /** | |
81 | - * @var SitemapStatic[] $static | |
82 | - */ | |
83 | - // ***** Begin generating static pages | |
84 | - $static = SitemapStatic::find() | |
85 | - ->all(); | |
86 | - foreach ($static as $item) { | |
87 | - $content .= Html::tag( | |
88 | - 'url', | |
89 | - Html::tag('loc', $item->url) . Html::tag('lastmod', date('Y-m-d')) . Html::tag( | |
90 | - 'changefreq', | |
91 | - $item->frequency | |
92 | - ) . Html::tag('priority', $item->priority) | |
93 | - ); | |
94 | - } | |
95 | - // ***** <<< End | |
96 | - /** | |
97 | - * @var SitemapDynamic $dynamic | |
98 | - */ | |
99 | - $dynamic = SitemapDynamic::find() | |
100 | - ->indexBy('entity') | |
101 | - ->where([ 'status' => 1 ]) | |
102 | - ->all(); | |
103 | - $entities = $this->entities; | |
104 | - foreach ($entities as $entity) { | |
105 | - /** | |
106 | - * @var string $class | |
107 | - */ | |
108 | - $class = $entity[ 'class' ]; | |
109 | - /** | |
110 | - * @var ActiveRecord $classInstance | |
111 | - */ | |
112 | - $classInstance = new $class(); | |
113 | - if (is_subclass_of($classInstance, ActiveRecord::className())) { | |
114 | - if (!empty( $dynamic[ $class ] )) { | |
115 | - /** | |
116 | - * @var SitemapDynamic $model | |
117 | - */ | |
118 | - $model = $dynamic[ $class ]; | |
119 | - $query = $classInstance::find(); | |
120 | - if (isset( $entity[ 'conditions' ] )) { | |
121 | - foreach ($entity[ 'conditions' ] as $condition) { | |
122 | - $query->where($condition); | |
123 | - } | |
124 | - } | |
125 | - $result = $query->all(); | |
126 | - foreach ($result as $record) { | |
127 | - $content .= Html::tag( | |
128 | - 'url', | |
129 | - Html::tag( | |
130 | - 'loc', | |
131 | - $urlManager->createAbsoluteUrl( | |
132 | - [ | |
133 | - $entity[ 'url' ], | |
134 | - 'id' => $record->getAttribute('id'), | |
135 | - ] | |
136 | - ) | |
137 | - ) . Html::tag('lastmod', date('Y-m-d')) . Html::tag( | |
138 | - 'changefreq', | |
139 | - $model->frequency | |
140 | - ) . Html::tag('priority', $model->priority) | |
141 | - ); | |
142 | - } | |
143 | - } | |
144 | - } | |
145 | - } | |
146 | - $content .= '</urlset>'; | |
147 | - return $content; | |
148 | - } | |
149 | - } | |
150 | 0 | \ No newline at end of file |
common/models/LoginForm.php deleted
1 | -<?php | |
2 | - namespace common\models; | |
3 | - | |
4 | - use artbox\order\models\Customer; | |
5 | - use Yii; | |
6 | - use yii\base\Model; | |
7 | - | |
8 | - /** | |
9 | - * Login form | |
10 | - */ | |
11 | - class LoginForm extends Model | |
12 | - { | |
13 | - public $username; | |
14 | - public $password; | |
15 | - public $rememberMe = true; | |
16 | - public $returnUrl; | |
17 | - | |
18 | - private $_user; | |
19 | - | |
20 | - /** | |
21 | - * @inheritdoc | |
22 | - */ | |
23 | - public function rules() | |
24 | - { | |
25 | - return [ | |
26 | - // username and password are both required | |
27 | - [ | |
28 | - [ | |
29 | - 'username', | |
30 | - 'password', | |
31 | - ], | |
32 | - 'required', | |
33 | - ], | |
34 | - [ | |
35 | - [ | |
36 | - 'returnUrl', | |
37 | - ], | |
38 | - 'string', | |
39 | - ], | |
40 | - // rememberMe must be a boolean value | |
41 | - [ | |
42 | - 'rememberMe', | |
43 | - 'boolean', | |
44 | - ], | |
45 | - // password is validated by validatePassword() | |
46 | - [ | |
47 | - 'password', | |
48 | - 'validatePassword', | |
49 | - ], | |
50 | - ]; | |
51 | - } | |
52 | - | |
53 | - /** | |
54 | - * Validates the password. | |
55 | - * This method serves as the inline validation for password. | |
56 | - * | |
57 | - * @param string $attribute the attribute currently being validated | |
58 | - * @param array $params the additional name-value pairs given in the rule | |
59 | - */ | |
60 | - public function validatePassword($attribute, $params) | |
61 | - { | |
62 | - if (!$this->hasErrors()) { | |
63 | - $user = $this->getUser(); | |
64 | - if (!$user || !$user->validatePassword($this->password)) { | |
65 | - $this->addError($attribute, 'Incorrect username or password.'); | |
66 | - } | |
67 | - } | |
68 | - } | |
69 | - | |
70 | - /** | |
71 | - * Logs in a user using the provided username and password. | |
72 | - * | |
73 | - * @return bool whether the user is logged in successfully | |
74 | - */ | |
75 | - public function login() | |
76 | - { | |
77 | - if ($this->validate()) { | |
78 | - return Yii::$app->user->login($this->getUser(), $this->rememberMe ? 3600 * 24 * 30 : 0); | |
79 | - } else { | |
80 | - return false; | |
81 | - } | |
82 | - } | |
83 | - | |
84 | - /** | |
85 | - * Finds user by [[username]] | |
86 | - * | |
87 | - * @return Customer|null | |
88 | - */ | |
89 | - protected function getUser() | |
90 | - { | |
91 | - if ($this->_user === null) { | |
92 | - $this->_user = Customer::findByUsername($this->username); | |
93 | - } | |
94 | - | |
95 | - return $this->_user; | |
96 | - } | |
97 | - | |
98 | - public function attributeLabels() | |
99 | - { | |
100 | - return [ | |
101 | - 'username' => Yii::t('app', 'Логин'), | |
102 | - 'password' => Yii::t('app', 'Пароль'), | |
103 | - 'rememberMe' => Yii::t('app', 'Запомнить'), | |
104 | - ]; | |
105 | - } | |
106 | - } |
common/models/PasswordResetRequestForm.php deleted
1 | -<?php | |
2 | - | |
3 | - namespace common\models; | |
4 | - | |
5 | - use artbox\order\models\Customer; | |
6 | - use Yii; | |
7 | - use yii\base\Model; | |
8 | - | |
9 | - /** | |
10 | - * Password reset request form | |
11 | - */ | |
12 | - class PasswordResetRequestForm extends Model | |
13 | - { | |
14 | - public $email; | |
15 | - /** | |
16 | - * @inheritdoc | |
17 | - */ | |
18 | - public function rules() | |
19 | - { | |
20 | - return [ | |
21 | - [ | |
22 | - 'email', | |
23 | - 'trim', | |
24 | - ], | |
25 | - [ | |
26 | - 'email', | |
27 | - 'required', | |
28 | - ], | |
29 | - [ | |
30 | - 'email', | |
31 | - 'email', | |
32 | - ], | |
33 | - [ | |
34 | - 'email', | |
35 | - 'exist', | |
36 | - 'targetClass' => '\artbox\order\models\Customer', | |
37 | - 'filter' => [ 'status' => Customer::STATUS_ACTIVE ], | |
38 | - 'message' => 'There is no user with this email address.', | |
39 | - ], | |
40 | - ]; | |
41 | - } | |
42 | - /** | |
43 | - * Sends an email with a link, for resetting the password. | |
44 | - * | |
45 | - * @return bool whether the email was send | |
46 | - */ | |
47 | - public function sendEmail() | |
48 | - { | |
49 | - /* @var $user Customer */ | |
50 | - $user = Customer::findOne( | |
51 | - [ | |
52 | - 'status' => Customer::STATUS_ACTIVE, | |
53 | - 'email' => $this->email, | |
54 | - ] | |
55 | - ); | |
56 | - if (!$user) { | |
57 | - return false; | |
58 | - } | |
59 | - | |
60 | - if (!Customer::isPasswordResetTokenValid($user->password_reset_token)) { | |
61 | - $user->generatePasswordResetToken(); | |
62 | - if (!$user->save()) { | |
63 | - return false; | |
64 | - } | |
65 | - } | |
66 | - return Yii::$app->mailer->compose( | |
67 | - [ | |
68 | - 'html' => 'passwordResetToken-html', | |
69 | - 'text' => 'passwordResetToken-text', | |
70 | - ], | |
71 | - [ 'user' => $user ] | |
72 | - ) | |
73 | - ->setFrom([ Yii::$app->params[ 'supportEmail' ] => Yii::$app->name . ' robot' ]) | |
74 | - ->setTo($this->email) | |
75 | - ->setSubject('Password reset for ' . Yii::$app->name) | |
76 | - ->send(); | |
77 | - } | |
78 | - } | |
79 | 0 | \ No newline at end of file |
common/models/ResetPasswordForm.php deleted
1 | -<?php | |
2 | - | |
3 | - namespace common\models; | |
4 | - | |
5 | - use artbox\order\models\Customer; | |
6 | - use yii\base\Model; | |
7 | - use yii\base\InvalidParamException; | |
8 | - | |
9 | - /** | |
10 | - * Password reset form | |
11 | - */ | |
12 | - class ResetPasswordForm extends Model | |
13 | - { | |
14 | - public $password; | |
15 | - | |
16 | - /** | |
17 | - * @var \artbox\order\models\Customer | |
18 | - */ | |
19 | - private $_user; | |
20 | - | |
21 | - /** | |
22 | - * Creates a form model given a token. | |
23 | - * | |
24 | - * @param string $token | |
25 | - * @param array $config name-value pairs that will be used to initialize the object properties | |
26 | - * | |
27 | - * @throws \yii\base\InvalidParamException if token is empty or not valid | |
28 | - */ | |
29 | - public function __construct($token, $config = []) | |
30 | - { | |
31 | - if (empty($token) || !is_string($token)) { | |
32 | - throw new InvalidParamException('Password reset token cannot be blank.'); | |
33 | - } | |
34 | - $this->_user = Customer::findByPasswordResetToken($token); | |
35 | - if (!$this->_user) { | |
36 | - throw new InvalidParamException('Wrong password reset token.'); | |
37 | - } | |
38 | - parent::__construct($config); | |
39 | - } | |
40 | - | |
41 | - /** | |
42 | - * @inheritdoc | |
43 | - */ | |
44 | - public function rules() | |
45 | - { | |
46 | - return [ | |
47 | - [ | |
48 | - 'password', | |
49 | - 'required', | |
50 | - ], | |
51 | - [ | |
52 | - 'password', | |
53 | - 'string', | |
54 | - 'min' => 6, | |
55 | - ], | |
56 | - ]; | |
57 | - } | |
58 | - | |
59 | - /** | |
60 | - * Resets password. | |
61 | - * | |
62 | - * @return bool if password was reset. | |
63 | - */ | |
64 | - public function resetPassword() | |
65 | - { | |
66 | - $user = $this->_user; | |
67 | - $user->setPassword($this->password); | |
68 | - $user->removePasswordResetToken(); | |
69 | - | |
70 | - return $user->save(false); | |
71 | - } | |
72 | - } | |
73 | 0 | \ No newline at end of file |
common/models/SignupForm.php deleted
1 | -<?php | |
2 | - | |
3 | - namespace common\models; | |
4 | - | |
5 | - use artbox\order\models\Customer; | |
6 | - use yii\base\Model; | |
7 | - | |
8 | - /** | |
9 | - * Signup form | |
10 | - */ | |
11 | - class SignupForm extends Model | |
12 | - { | |
13 | - public $username; | |
14 | - public $email; | |
15 | - public $password; | |
16 | - | |
17 | - /** | |
18 | - * @inheritdoc | |
19 | - */ | |
20 | - public function rules() | |
21 | - { | |
22 | - return [ | |
23 | - [ | |
24 | - 'username', | |
25 | - 'trim', | |
26 | - ], | |
27 | - [ | |
28 | - 'username', | |
29 | - 'required', | |
30 | - ], | |
31 | - [ | |
32 | - 'username', | |
33 | - 'unique', | |
34 | - 'targetClass' => '\artbox\order\models\Customer', | |
35 | - 'message' => 'This username has already been taken.', | |
36 | - ], | |
37 | - [ | |
38 | - 'username', | |
39 | - 'string', | |
40 | - 'min' => 2, | |
41 | - 'max' => 255, | |
42 | - ], | |
43 | - | |
44 | - [ | |
45 | - 'email', | |
46 | - 'trim', | |
47 | - ], | |
48 | - [ | |
49 | - 'email', | |
50 | - 'required', | |
51 | - ], | |
52 | - [ | |
53 | - 'email', | |
54 | - 'email', | |
55 | - ], | |
56 | - [ | |
57 | - 'email', | |
58 | - 'string', | |
59 | - 'max' => 255, | |
60 | - ], | |
61 | - [ | |
62 | - 'email', | |
63 | - 'unique', | |
64 | - 'targetClass' => '\artbox\order\models\Customer', | |
65 | - 'message' => 'This email address has already been taken.', | |
66 | - ], | |
67 | - | |
68 | - [ | |
69 | - 'password', | |
70 | - 'required', | |
71 | - ], | |
72 | - [ | |
73 | - 'password', | |
74 | - 'string', | |
75 | - 'min' => 6, | |
76 | - ], | |
77 | - ]; | |
78 | - } | |
79 | - | |
80 | - /** | |
81 | - * Signs user up. | |
82 | - * | |
83 | - * @return \artbox\order\models\Customer|null the saved model or null if saving fails | |
84 | - */ | |
85 | - public function signup() | |
86 | - { | |
87 | - if (!$this->validate()) { | |
88 | - return null; | |
89 | - } | |
90 | - | |
91 | - $user = new Customer(); | |
92 | - $user->username = $this->username; | |
93 | - $user->email = $this->email; | |
94 | - $user->setPassword($this->password); | |
95 | - $user->generateAuthKey(); | |
96 | - | |
97 | - return $user->save() ? $user : null; | |
98 | - } | |
99 | - } | |
100 | 0 | \ No newline at end of file |
common/models/SitemapDynamic.php deleted
1 | -<?php | |
2 | - namespace common\models; | |
3 | - | |
4 | - use Yii; | |
5 | - use yii\helpers\ArrayHelper; | |
6 | - use yii2tech\filedb\ActiveRecord; | |
7 | - | |
8 | - /** | |
9 | - * Class SitemapDynamic | |
10 | - * | |
11 | - * @property int $id | |
12 | - * @property string $entity | |
13 | - * @property bool $status | |
14 | - * @property float $priority | |
15 | - * @property string $frequency | |
16 | - */ | |
17 | - class SitemapDynamic extends ActiveRecord | |
18 | - { | |
19 | - | |
20 | - const STATUS_ENABLED = 1; | |
21 | - const STATUS_DISABLED = 0; | |
22 | - | |
23 | - /** | |
24 | - * @inheritdoc | |
25 | - */ | |
26 | - public static function getDb() | |
27 | - { | |
28 | - return \Yii::$app->get('sitemapdb'); | |
29 | - } | |
30 | - | |
31 | - /** | |
32 | - * @inheritdoc | |
33 | - */ | |
34 | - public function attributes() | |
35 | - { | |
36 | - return [ | |
37 | - 'id', | |
38 | - 'entity', | |
39 | - 'status', | |
40 | - 'priority', | |
41 | - 'frequency', | |
42 | - ]; | |
43 | - } | |
44 | - | |
45 | - /** | |
46 | - * @inheritdoc | |
47 | - */ | |
48 | - public static function primaryKey() | |
49 | - { | |
50 | - return [ 'id' ]; | |
51 | - } | |
52 | - | |
53 | - /** | |
54 | - * @inheritdoc | |
55 | - */ | |
56 | - public function rules() | |
57 | - { | |
58 | - return [ | |
59 | - [ | |
60 | - [ | |
61 | - 'entity', | |
62 | - 'status', | |
63 | - 'priority', | |
64 | - 'frequency', | |
65 | - ], | |
66 | - 'required', | |
67 | - ], | |
68 | - [ | |
69 | - [ | |
70 | - 'status', | |
71 | - ], | |
72 | - 'boolean', | |
73 | - ], | |
74 | - [ | |
75 | - [ | |
76 | - 'entity', | |
77 | - 'frequency', | |
78 | - ], | |
79 | - 'string', | |
80 | - ], | |
81 | - [ | |
82 | - [ | |
83 | - 'priority', | |
84 | - ], | |
85 | - 'double', | |
86 | - 'min' => 0, | |
87 | - 'max' => 1, | |
88 | - ], | |
89 | - ]; | |
90 | - } | |
91 | - | |
92 | - /** | |
93 | - * @inheritdoc | |
94 | - */ | |
95 | - public function attributeLabels() | |
96 | - { | |
97 | - return [ | |
98 | - 'id' => Yii::t('core', 'ID'), | |
99 | - 'entity' => Yii::t('core', 'Model'), | |
100 | - 'status' => Yii::t('core', 'Status'), | |
101 | - 'priority' => Yii::t('core', 'Priority'), | |
102 | - 'frequency' => Yii::t('core', 'Frequency'), | |
103 | - ]; | |
104 | - } | |
105 | - | |
106 | - /** | |
107 | - * Find maximum ID value from SitemapStatic models | |
108 | - */ | |
109 | - public static function max(): int | |
110 | - { | |
111 | - $models = self::find() | |
112 | - ->all(); | |
113 | - $array = ArrayHelper::getColumn($models, self::primaryKey()[ 0 ], false); | |
114 | - if (empty( $array )) { | |
115 | - return 0; | |
116 | - } else { | |
117 | - return max($array); | |
118 | - } | |
119 | - } | |
120 | - } | |
121 | 0 | \ No newline at end of file |
common/models/SitemapStatic.php deleted
1 | -<?php | |
2 | - namespace common\models; | |
3 | - | |
4 | - use Yii; | |
5 | - use yii\helpers\ArrayHelper; | |
6 | - use yii2tech\filedb\ActiveRecord; | |
7 | - | |
8 | - /** | |
9 | - * Class SitemapStatic | |
10 | - * | |
11 | - * @property int $id | |
12 | - * @property string $url | |
13 | - * @property float $priority | |
14 | - * @property string $frequency | |
15 | - */ | |
16 | - class SitemapStatic extends ActiveRecord | |
17 | - { | |
18 | - /** | |
19 | - * @inheritdoc | |
20 | - */ | |
21 | - public static function getDb() | |
22 | - { | |
23 | - return \Yii::$app->get('sitemapdb'); | |
24 | - } | |
25 | - | |
26 | - /** | |
27 | - * @inheritdoc | |
28 | - */ | |
29 | - public function attributes() | |
30 | - { | |
31 | - return [ | |
32 | - 'id', | |
33 | - 'url', | |
34 | - 'priority', | |
35 | - 'frequency', | |
36 | - ]; | |
37 | - } | |
38 | - | |
39 | - /** | |
40 | - * @inheritdoc | |
41 | - */ | |
42 | - public static function primaryKey() | |
43 | - { | |
44 | - return [ 'id' ]; | |
45 | - } | |
46 | - | |
47 | - /** | |
48 | - * @inheritdoc | |
49 | - */ | |
50 | - public function rules() | |
51 | - { | |
52 | - return [ | |
53 | - [ | |
54 | - [ | |
55 | - 'url', | |
56 | - 'priority', | |
57 | - ], | |
58 | - 'required', | |
59 | - ], | |
60 | - [ | |
61 | - [ | |
62 | - 'priority', | |
63 | - ], | |
64 | - 'double', | |
65 | - 'min' => 0, | |
66 | - 'max' => 1, | |
67 | - ], | |
68 | - [ | |
69 | - [ | |
70 | - 'url', | |
71 | - 'frequency', | |
72 | - ], | |
73 | - 'string', | |
74 | - ], | |
75 | - ]; | |
76 | - } | |
77 | - | |
78 | - /** | |
79 | - * @inheritdoc | |
80 | - */ | |
81 | - public function attributeLabels() | |
82 | - { | |
83 | - return [ | |
84 | - 'id' => Yii::t('core', 'ID'), | |
85 | - 'url' => Yii::t('core', 'Url'), | |
86 | - 'priority' => Yii::t('core', 'Priority'), | |
87 | - 'frequency' => Yii::t('core', 'Frequency'), | |
88 | - ]; | |
89 | - } | |
90 | - | |
91 | - /** | |
92 | - * Find maximum ID value from SitemapStatic models | |
93 | - */ | |
94 | - public static function max(): int | |
95 | - { | |
96 | - $models = self::find() | |
97 | - ->all(); | |
98 | - $array = ArrayHelper::getColumn($models, self::primaryKey()[ 0 ], false); | |
99 | - if (empty( $array )) { | |
100 | - return 0; | |
101 | - } else { | |
102 | - return max($array); | |
103 | - } | |
104 | - } | |
105 | - } | |
106 | 0 | \ No newline at end of file |
console/controllers/CheckController.php
frontend/assets/AppAsset.php
frontend/controllers/AccountController.php
... | ... | @@ -8,8 +8,8 @@ |
8 | 8 | use artbox\order\models\Wishlist; |
9 | 9 | use yii\data\ActiveDataProvider; |
10 | 10 | use yii\db\ActiveQuery; |
11 | + use yii\filters\AccessControl; | |
11 | 12 | use yii\web\Controller; |
12 | - use yii\web\ForbiddenHttpException; | |
13 | 13 | use yii\web\NotFoundHttpException; |
14 | 14 | use yii\web\Response; |
15 | 15 | |
... | ... | @@ -20,9 +20,35 @@ |
20 | 20 | */ |
21 | 21 | class AccountController extends Controller |
22 | 22 | { |
23 | + /** | |
24 | + * @inheritdoc | |
25 | + */ | |
26 | + public function behaviors() | |
27 | + { | |
28 | + return [ | |
29 | + 'access' => [ | |
30 | + 'class' => AccessControl::className(), | |
31 | + 'rules' => [ | |
32 | + [ | |
33 | + 'allow' => true, | |
34 | + 'roles' => [ '@' ], | |
35 | + ], | |
36 | + ], | |
37 | + ], | |
38 | + ]; | |
39 | + } | |
40 | + | |
41 | + /** | |
42 | + * Account main page with orders | |
43 | + * | |
44 | + * @return string | |
45 | + */ | |
23 | 46 | public function actionIndex() |
24 | 47 | { |
25 | - $user = Customer::findOne(\Yii::$app->user->identity->getId()); | |
48 | + /** | |
49 | + * @var Customer $user | |
50 | + */ | |
51 | + $user = \Yii::$app->user->identity; | |
26 | 52 | |
27 | 53 | $orders = $user->getOrders() |
28 | 54 | ->with( |
... | ... | @@ -46,12 +72,24 @@ |
46 | 72 | ); |
47 | 73 | } |
48 | 74 | |
75 | + /** | |
76 | + * Account detail order page | |
77 | + * | |
78 | + * @param $id | |
79 | + * | |
80 | + * @return string | |
81 | + * @throws \yii\web\NotFoundHttpException | |
82 | + */ | |
49 | 83 | public function actionOrder($id) |
50 | 84 | { |
51 | 85 | /** |
86 | + * @var Customer $user | |
87 | + */ | |
88 | + $user = \Yii::$app->user->identity; | |
89 | + /** | |
52 | 90 | * @var Order $order |
53 | 91 | */ |
54 | - $order = Order::find() | |
92 | + $order = $user->getOrders() | |
55 | 93 | ->with('orderProducts.variant.product.lang') |
56 | 94 | ->where( |
57 | 95 | [ |
... | ... | @@ -62,8 +100,6 @@ |
62 | 100 | |
63 | 101 | if (empty($order)) { |
64 | 102 | throw new NotFoundHttpException(\Yii::t('app', 'Order not found')); |
65 | - } elseif ($order->user_id !== \Yii::$app->user->identity->getId()) { | |
66 | - throw new ForbiddenHttpException(); | |
67 | 103 | } |
68 | 104 | |
69 | 105 | return $this->render( |
... | ... | @@ -74,6 +110,11 @@ |
74 | 110 | ); |
75 | 111 | } |
76 | 112 | |
113 | + /** | |
114 | + * Acount info page | |
115 | + * | |
116 | + * @return string | |
117 | + */ | |
77 | 118 | public function actionAccount() |
78 | 119 | { |
79 | 120 | $user = \Yii::$app->user->identity; |
... | ... | @@ -86,6 +127,11 @@ |
86 | 127 | ); |
87 | 128 | } |
88 | 129 | |
130 | + /** | |
131 | + * Account wishlist page | |
132 | + * | |
133 | + * @return string | |
134 | + */ | |
89 | 135 | public function actionWishlist() |
90 | 136 | { |
91 | 137 | /** |
... | ... | @@ -114,7 +160,7 @@ |
114 | 160 | ], |
115 | 161 | ] |
116 | 162 | ); |
117 | - | |
163 | + | |
118 | 164 | return $this->render( |
119 | 165 | 'wishlist', |
120 | 166 | [ |
... | ... | @@ -122,7 +168,12 @@ |
122 | 168 | ] |
123 | 169 | ); |
124 | 170 | } |
125 | - | |
171 | + | |
172 | + /** | |
173 | + * Account change password action | |
174 | + * | |
175 | + * @return string|\yii\web\Response | |
176 | + */ | |
126 | 177 | public function actionChangePassword() |
127 | 178 | { |
128 | 179 | /** |
... | ... | @@ -165,6 +216,11 @@ |
165 | 216 | |
166 | 217 | } |
167 | 218 | |
219 | + /** | |
220 | + * Account change data action | |
221 | + * | |
222 | + * @return string|\yii\web\Response | |
223 | + */ | |
168 | 224 | public function actionChangeData() |
169 | 225 | { |
170 | 226 | /** |
... | ... | @@ -188,6 +244,11 @@ |
188 | 244 | ); |
189 | 245 | } |
190 | 246 | |
247 | + /** | |
248 | + * Account delete from wishlist action | |
249 | + * | |
250 | + * @return array | |
251 | + */ | |
191 | 252 | public function actionWishlistDelete() |
192 | 253 | { |
193 | 254 | \Yii::$app->response->format = Response::FORMAT_JSON; |
... | ... | @@ -201,21 +262,22 @@ |
201 | 262 | ->andWhere( |
202 | 263 | [ |
203 | 264 | 'variant_id' => \Yii::$app->request->post('variant'), |
204 | - | |
265 | + | |
205 | 266 | ] |
206 | 267 | ) |
207 | 268 | ->one(); |
208 | 269 | if (!empty($model) && $model->delete()) { |
209 | 270 | return [ |
210 | 271 | 'success' => true, |
211 | - 'message' => 'Товар удален из избранного', | |
272 | + 'message' => \Yii::t('app', 'Товар удален из избранного'), | |
212 | 273 | ]; |
213 | 274 | } |
214 | - | |
275 | + | |
215 | 276 | return [ |
216 | 277 | 'success' => false, |
217 | - 'message' => 'Ошибка', | |
278 | + 'message' => \Yii::t('app', 'Ошибка'), | |
218 | 279 | ]; |
219 | 280 | } |
281 | + return []; | |
220 | 282 | } |
221 | 283 | } |
222 | 284 | \ No newline at end of file | ... | ... |
frontend/controllers/PageController.php
... | ... | @@ -43,7 +43,13 @@ |
43 | 43 | ] |
44 | 44 | ); |
45 | 45 | } |
46 | - | |
46 | + | |
47 | + /** | |
48 | + * @param $id | |
49 | + * | |
50 | + * @return \artbox\core\models\Page | |
51 | + * @throws \yii\web\NotFoundHttpException | |
52 | + */ | |
47 | 53 | protected function findModel($id) |
48 | 54 | { |
49 | 55 | /** |
... | ... | @@ -60,11 +66,11 @@ |
60 | 66 | |
61 | 67 | if (!empty( $model )) { |
62 | 68 | if ($model->lang->alias_id !== Yii::$app->seo->aliasId) { |
63 | - throw new NotFoundHttpException('Wrong language'); | |
69 | + throw new NotFoundHttpException(\Yii::t('app', 'Wrong language')); | |
64 | 70 | } |
65 | 71 | return $model; |
66 | 72 | } else { |
67 | - throw new NotFoundHttpException('Model not found'); | |
73 | + throw new NotFoundHttpException(\Yii::t('app', 'Model not found')); | |
68 | 74 | } |
69 | 75 | } |
70 | 76 | } |
71 | 77 | \ No newline at end of file | ... | ... |
frontend/controllers/ProductController.php
... | ... | @@ -83,14 +83,19 @@ |
83 | 83 | ->one(); |
84 | 84 | if (!empty($model)) { |
85 | 85 | if ($model->lang->alias_id !== $seo->aliasId) { |
86 | - throw new NotFoundHttpException('Wrong language'); | |
86 | + throw new NotFoundHttpException(\Yii::t('app', 'Wrong language')); | |
87 | 87 | } |
88 | 88 | return $model; |
89 | 89 | } else { |
90 | - throw new NotFoundHttpException('Model not found'); | |
90 | + throw new NotFoundHttpException(\Yii::t('app', 'Model not found')); | |
91 | 91 | } |
92 | 92 | } |
93 | 93 | |
94 | + /** | |
95 | + * Remove product from wishlist | |
96 | + * | |
97 | + * @return array | |
98 | + */ | |
94 | 99 | public function actionWishlistRm() |
95 | 100 | { |
96 | 101 | \Yii::$app->response->format = Response::FORMAT_JSON; |
... | ... | @@ -113,7 +118,7 @@ |
113 | 118 | 'button' => Html::button( |
114 | 119 | Html::tag('i', '', [ 'class' => 'fa fa-heart-o' ]), |
115 | 120 | [ |
116 | - 'title' => 'Добавить в избранное', | |
121 | + 'title' => \Yii::t('app', 'Добавить в избранное'), | |
117 | 122 | 'data' => [ |
118 | 123 | 'toggle' => 'tooltip', |
119 | 124 | 'placement' => 'top', |
... | ... | @@ -125,7 +130,7 @@ |
125 | 130 | 'class' => 'wishlist-add btn btn-success pull-right', |
126 | 131 | ] |
127 | 132 | ), |
128 | - 'message' => 'Товар убран из избранного', | |
133 | + 'message' => \Yii::t('app', 'Товар убран из избранного'), | |
129 | 134 | ]; |
130 | 135 | } |
131 | 136 | |
... | ... | @@ -133,7 +138,7 @@ |
133 | 138 | 'button' => Html::button( |
134 | 139 | Html::tag('i', '', [ 'class' => 'fa fa-heart' ]), |
135 | 140 | [ |
136 | - 'title' => 'Убрать из избранного', | |
141 | + 'title' => \Yii::t('app', 'Убрать из избранного'), | |
137 | 142 | 'data' => [ |
138 | 143 | 'toggle' => 'tooltip', |
139 | 144 | 'placement' => 'top', |
... | ... | @@ -145,11 +150,17 @@ |
145 | 150 | 'class' => 'wishlist-rm btn btn-success pull-right', |
146 | 151 | ] |
147 | 152 | ), |
148 | - 'message' => 'Товар не найден', | |
153 | + 'message' => \Yii::t('app', 'Товар не найден'), | |
149 | 154 | ]; |
150 | 155 | } |
156 | + return []; | |
151 | 157 | } |
152 | 158 | |
159 | + /** | |
160 | + * Add product to wishlist | |
161 | + * | |
162 | + * @return array | |
163 | + */ | |
153 | 164 | public function actionWishlistAdd() |
154 | 165 | { |
155 | 166 | \Yii::$app->response->format = Response::FORMAT_JSON; |
... | ... | @@ -164,7 +175,7 @@ |
164 | 175 | 'button' => Html::button( |
165 | 176 | Html::tag('i', '', [ 'class' => 'fa fa-heart' ]), |
166 | 177 | [ |
167 | - 'title' => 'Убрать из избранного', | |
178 | + 'title' => \Yii::t('app', 'Убрать из избранного'), | |
168 | 179 | 'data' => [ |
169 | 180 | 'toggle' => 'tooltip', |
170 | 181 | 'placement' => 'top', |
... | ... | @@ -184,7 +195,7 @@ |
184 | 195 | 'button' => Html::button( |
185 | 196 | Html::tag('i', '', [ 'class' => 'fa fa-heart-o' ]), |
186 | 197 | [ |
187 | - 'title' => 'Добавить в избранное', | |
198 | + 'title' => \Yii::t('app', 'Добавить в избранное'), | |
188 | 199 | 'data' => [ |
189 | 200 | 'toggle' => 'tooltip', |
190 | 201 | 'placement' => 'top', |
... | ... | @@ -196,8 +207,9 @@ |
196 | 207 | 'class' => 'wishlist-add btn btn-success pull-right', |
197 | 208 | ] |
198 | 209 | ), |
199 | - 'message' => 'Товар добавить не вышло', | |
210 | + 'message' => \Yii::t('app', 'Товар добавить не вышло'), | |
200 | 211 | ]; |
201 | 212 | } |
213 | + return []; | |
202 | 214 | } |
203 | 215 | } |
204 | 216 | \ No newline at end of file | ... | ... |
frontend/controllers/SiteController.php
... | ... | @@ -7,12 +7,12 @@ |
7 | 7 | use artbox\catalog\models\Product; |
8 | 8 | use artbox\core\models\DummyAlias; |
9 | 9 | use artbox\core\models\Feedback; |
10 | + use artbox\order\models\LoginForm; | |
11 | + use artbox\order\models\PasswordResetRequestForm; | |
12 | + use artbox\order\models\ResetPasswordForm; | |
13 | + use artbox\order\models\SignupForm; | |
10 | 14 | use artbox\weblog\models\Article; |
11 | - use common\models\LoginForm; | |
12 | - use common\models\PasswordResetRequestForm; | |
13 | - use common\models\ResetPasswordForm; | |
14 | 15 | use common\models\Settings; |
15 | - use common\models\SignupForm; | |
16 | 16 | use Yii; |
17 | 17 | use yii\base\InvalidParamException; |
18 | 18 | use yii\bootstrap\Html; | ... | ... |
frontend/views/layouts/main.php
... | ... | @@ -11,7 +11,7 @@ |
11 | 11 | use artbox\core\models\Image; |
12 | 12 | use artbox\core\models\Page; |
13 | 13 | use artbox\core\models\User; |
14 | - use common\models\LoginForm; | |
14 | + use artbox\order\models\LoginForm; | |
15 | 15 | use common\models\Newsletter; |
16 | 16 | use common\models\SearchForm; |
17 | 17 | use common\models\Settings; | ... | ... |
frontend/web/sitemap.xml
1 | -<?xml version="1.0" encoding="UTF-8"?><urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"></urlset> | |
2 | 1 | \ No newline at end of file |
2 | +<?xml version="1.0" encoding="UTF-8"?> | |
3 | +<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"> | |
4 | + <url> | |
5 | + <loc>artbox.dev</loc> | |
6 | + <lastmod>2017-05-29</lastmod> | |
7 | + <changefreq>always</changefreq> | |
8 | + <priority>1</priority> | |
9 | + </url> | |
10 | + <url> | |
11 | + <loc>http://www.artbox.dev/ru/o-nas</loc> | |
12 | + <lastmod>2017-05-29</lastmod> | |
13 | + <changefreq>always</changefreq> | |
14 | + <priority>1</priority> | |
15 | + </url> | |
16 | + <url> | |
17 | + <loc>http://www.artbox.dev/ru/dostavka-i-oplata</loc> | |
18 | + <lastmod>2017-05-29</lastmod> | |
19 | + <changefreq>always</changefreq> | |
20 | + <priority>1</priority> | |
21 | + </url> | |
22 | +</urlset> | |
3 | 23 | \ No newline at end of file | ... | ... |