From aef3b7931e6bf1f1bd328d6315e09ee4c6dc327e Mon Sep 17 00:00:00 2001 From: yarik Date: Wed, 9 Nov 2016 19:55:48 +0200 Subject: [PATCH] For Leha commit --- widget/Seo.php | 448 ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- widgets/Seo.php | 448 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 448 insertions(+), 448 deletions(-) delete mode 100644 widget/Seo.php create mode 100644 widgets/Seo.php diff --git a/widget/Seo.php b/widget/Seo.php deleted file mode 100644 index 88da831..0000000 --- a/widget/Seo.php +++ /dev/null @@ -1,448 +0,0 @@ -url = \Yii::$app->request->url; - $this->project_name = \Yii::$app->name; - if(empty(self::$optionsList)){ - self::$optionsList = ArrayHelper::getColumn(TaxGroup::find()->where(['is_filter' => 'TRUE'])->all(),'alias'); - } - - parent::init(); - - } - - - public function run() - { - - $seoData = $this->getViewData(); - foreach ($seoData as $key => $value) { - $this->$key = $value; - } - - - switch ($this->row) { - case self::SEO_TEXT: - - - $filter = \Yii::$app->request->get('filters', []); - $sort = \Yii::$app->request->get('sort', []); - $paginate = \Yii::$app->request->get('page', []); - - if(empty($filter) && empty($sort) && empty($paginate) ){ - - return $this->selectSeoData(self::SEO_TEXT); - - } else { - - $widgetData = static::findSeoByUrl($this->url); - - $result = ''; - - if ($widgetData instanceof \artweb\artbox\seo\models\Seo) { - - $result = $widgetData->{self::SEO_TEXT}; - - } else { - - $widgetData = $this->findSeoByDynamic(); - - if ($widgetData instanceof SeoDynamic) { - - $result = $widgetData->{self::SEO_TEXT}; - - } - - } - - return $this->replaceData($result); - } - - - break; - case self::H1: - - $filter = \Yii::$app->request->get('filters', []); - - $default = $this->selectSeoData(self::H1); - - if ($default != $this->{self::H1}) { - - return $default; - - - } else if(!empty($filter) && !$this->checkFilter($filter)){ - - $array = $this->arrayBuilder($filter); - return $this->getNameString($array); - } - else { - - return $default; - } - break; - case self::TITLE: - - $filter = \Yii::$app->request->get('filters', []); - - - $title = $this->selectSeoData(self::TITLE); - - - if(!empty($filter) && $title == $this->title || !empty($filter) && empty($title)) { - - $array = $this->arrayBuilder($filter); - - $title_string = $this->getTitleString($array); - - if($title_string){ - return $title_string; - } - - } - - if (!empty($title)) { - - return $title; - } else { - return $this->project_name; - } - - break; - case self::DESCRIPTION: - $description = $this->selectSeoData(self::DESCRIPTION); - - if (!empty($description)) { - - $this->getView()->registerMetaTag([ - 'name' => 'description', - 'content' => $description - ]); - - } else { - - $filter = \Yii::$app->request->get('filters', []); - - if(!empty($filter)){ - $array = $this->arrayBuilder($filter); - $this->getView()->registerMetaTag([ - 'name' => 'description', - 'content' => $this->getDescriptionString($array) - ]); - } - - } - - break; - case self::META: - - $meta = $this->selectSeoData(self::META); - - $filter = \Yii::$app->request->get('filters', []); - $sort = \Yii::$app->request->get('sort', []); - $paginate = \Yii::$app->request->get('page', []); - - - - if (!empty($meta) && empty($sort) && empty($paginate) && !isset($filter['prices']) ) { - - $this->getView()->registerMetaTag([ - 'name' => 'robots', - 'content' => $meta - ]); - - } else if(!empty($filter['special'])){ - - $this->getView()->registerMetaTag([ - 'name' => 'robots', - 'content' => 'noindex,follow' - ]); - - } else if ( - isset($filter['brands']) && count($filter['brands']) > 1 - || isset($filter) && $this->checkFilter($filter) - - ) { - - $this->getView()->registerMetaTag([ - 'name' => 'robots', - 'content' => 'noindex,nofollow' - ]); - - } else if ( - isset($filter['brands']) && count($filter['brands']) > 1 && isset($filter) && count($filter, COUNT_RECURSIVE) >= 4 - || isset($filter) && count($filter, COUNT_RECURSIVE) > 4 - || !empty($sort) || !empty($paginate) || isset($filter['prices']) - ) { - - $this->getView()->registerMetaTag([ - 'name' => 'robots', - 'content' => 'noindex,nofollow' - ]); - } else { - - $this->getView()->registerMetaTag([ - 'name' => 'robots', - 'content' => 'index,follow' - ]); - } - - - - - break; - } - - - } - - protected function replaceData($str) - { - - if (!empty($this->fields)) { - foreach ($this->fields as $field_name => $field_value) { - $str = str_replace('{' . $field_name . '}', $field_value, $str); - } - } - $str = str_replace('{project_name}', $this->project_name, $str); - return $str; - } - - protected static function findSeoByUrl($url) - { - if(empty(self::$check_url_bool)){ - self::$check_url = \artweb\artbox\seo\models\Seo::findOne(['url' => $url]); - self::$check_url_bool = true; - } - return self::$check_url; - } - - protected function findSeoByDynamic() - { - - if(!empty($this->key)){ - - $query = SeoDynamic::find()->joinWith('seoCategory')->where(['controller' => \Yii::$app->controller->id, 'action' => \Yii::$app->controller->action->id, 'key' => $this->key]); - } else { - - - $query = SeoDynamic::find()->joinWith('seoCategory')->where(['controller' => \Yii::$app->controller->id, 'action' => \Yii::$app->controller->action->id]); - } - - return $query->one(); - } - - - protected function findSeoByDynamicForFilters(){ - return SeoDynamic::find()->joinWith('seoCategory')->where(['param' =>'filters'])->one(); - } - - - protected function getViewData() - { - $params = $this->getView()->params; - if (isset($params['seo'])) { - return $params['seo']; - } else { - return []; - } - } - - protected function selectSeoData($param) - { - - $result = ''; - - $widgetData = static::findSeoByUrl($this->url); - - if ($widgetData instanceof \artweb\artbox\seo\models\Seo) { - - $result = $widgetData->$param; - - } else if (!empty($this->$param)) { - - $result = $this->$param; - - } else { - - $widgetData = $this->findSeoByDynamic(); - - if ($widgetData instanceof SeoDynamic) { - - $result = $widgetData->$param; - - } - - } - - return $this->replaceData($result); - - } - - public function getTitleString($array){ - // "{Название раздела: Название блока фильтра | Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3} - купить в Киеве, Украине - интернет магазин Лінія Світла"; - $row = ''; - foreach($array as $name => $field){ - - if($name == 'category' ){ - $row = $field.' | '.$row; - } else { - $row .= $field['name'] .' '.$field['value'].' | ' ; - } - - - - } - $row = substr($row, 0,-2 ); - $row .= " - купить в Киеве, Украине - интернет магазин Лінія Світла"; - return $row; -// $template = SeoDynamic::find()->select('title')->where(['param' =>'filters'])->one(); -// if($template instanceof SeoDynamic){ -// foreach ($array as $field_name => $field_value) { -// $template->title = str_replace('{' . $field_name . '}', mb_strtolower($field_value), $template->title); -// } -// $template = preg_replace('/\{.[^\}]*\}\s/','',$template->title); -// return $template; -// } -// -// return false; - - } - - - public function getDescriptionString($array){ - // "Лучшие цены на {Название раздела | Название блока фильтра: Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3}. Лінія Світла"; - $row = 'Лучшие цены на '; - foreach($array as $name => $field){ - - if($name == 'category' ){ - $row = $field.' | '.$row; - } else { - $row .= $field['name'] .' '.$field['value'].' | ' ; - } - - - - } - $row = substr($row, 0,-2 ); - $row .= ". Лінія Світла"; - return $row; - - } - - - public function getNameString($array){ - // "Лучшие цены на {Название раздела | Название блока фильтра: Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3}. Лінія Світла"; - $row = ''; - foreach($array as $name => $field){ - - if($name == 'category' ){ - $row = $field.' | '.$row; - } else { - $row .= $field['name'] .' '.$field['value'].' | ' ; - } - - - - } - $row = substr($row, 0,-2 ); - return $row; - - } - - public function arrayBuilder($filter) - { - - $array = [ - 'category' => $this->category_name - ]; - - - if (isset($filter['brands']) && count($filter['brands']) == 1) { - $model = Brand::find()->where(['alias' => $filter['brands'][0]])->one(); - if (!$model instanceof Brand) { - - \Yii::$app->response->redirect(['/site/error'], 404); - } else { - $array['brand']['name'] = 'Бренд'; - $array['brand']['value'] = $model->name; - } - - } - - - $optionsList = ArrayHelper::map(TaxGroup::find()->where(['is_filter' => 'TRUE'])->all(), 'alias', 'name'); - - - foreach ($optionsList as $optionList => $name) { - - - if (isset($filter[$optionList]) && count($filter[$optionList]) == 1) { - - $model = TaxOption::find()->where(['alias' => $filter[$optionList]])->one(); - if (!$model instanceof TaxOption) { - - \Yii::$app->response->redirect(['site/error'], 404); - } else { - $array[$optionList]['value'] = $model->value; - $array[$optionList]['name'] = $name; - } - - - } - - - } - - return $array; - - } - - protected function checkFilter($filter){ - foreach(self::$optionsList as $optionList){ - - if(isset($filter[$optionList]) && count($filter[$optionList]) > 1){ - return true; - } - - } - return false; - } - - -} \ No newline at end of file diff --git a/widgets/Seo.php b/widgets/Seo.php new file mode 100644 index 0000000..9869ea7 --- /dev/null +++ b/widgets/Seo.php @@ -0,0 +1,448 @@ +url = \Yii::$app->request->url; + $this->project_name = \Yii::$app->name; + if(empty(self::$optionsList)){ + self::$optionsList = ArrayHelper::getColumn(TaxGroup::find()->where(['is_filter' => 'TRUE'])->all(),'alias'); + } + + parent::init(); + + } + + + public function run() + { + + $seoData = $this->getViewData(); + foreach ($seoData as $key => $value) { + $this->$key = $value; + } + + + switch ($this->row) { + case self::SEO_TEXT: + + + $filter = \Yii::$app->request->get('filters', []); + $sort = \Yii::$app->request->get('sort', []); + $paginate = \Yii::$app->request->get('page', []); + + if(empty($filter) && empty($sort) && empty($paginate) ){ + + return $this->selectSeoData(self::SEO_TEXT); + + } else { + + $widgetData = static::findSeoByUrl($this->url); + + $result = ''; + + if ($widgetData instanceof \artweb\artbox\seo\models\Seo) { + + $result = $widgetData->{self::SEO_TEXT}; + + } else { + + $widgetData = $this->findSeoByDynamic(); + + if ($widgetData instanceof SeoDynamic) { + + $result = $widgetData->{self::SEO_TEXT}; + + } + + } + + return $this->replaceData($result); + } + + + break; + case self::H1: + + $filter = \Yii::$app->request->get('filters', []); + + $default = $this->selectSeoData(self::H1); + + if ($default != $this->{self::H1}) { + + return $default; + + + } else if(!empty($filter) && !$this->checkFilter($filter)){ + + $array = $this->arrayBuilder($filter); + return $this->getNameString($array); + } + else { + + return $default; + } + break; + case self::TITLE: + + $filter = \Yii::$app->request->get('filters', []); + + + $title = $this->selectSeoData(self::TITLE); + + + if(!empty($filter) && $title == $this->title || !empty($filter) && empty($title)) { + + $array = $this->arrayBuilder($filter); + + $title_string = $this->getTitleString($array); + + if($title_string){ + return $title_string; + } + + } + + if (!empty($title)) { + + return $title; + } else { + return $this->project_name; + } + + break; + case self::DESCRIPTION: + $description = $this->selectSeoData(self::DESCRIPTION); + + if (!empty($description)) { + + $this->getView()->registerMetaTag([ + 'name' => 'description', + 'content' => $description + ]); + + } else { + + $filter = \Yii::$app->request->get('filters', []); + + if(!empty($filter)){ + $array = $this->arrayBuilder($filter); + $this->getView()->registerMetaTag([ + 'name' => 'description', + 'content' => $this->getDescriptionString($array) + ]); + } + + } + + break; + case self::META: + + $meta = $this->selectSeoData(self::META); + + $filter = \Yii::$app->request->get('filters', []); + $sort = \Yii::$app->request->get('sort', []); + $paginate = \Yii::$app->request->get('page', []); + + + + if (!empty($meta) && empty($sort) && empty($paginate) && !isset($filter['prices']) ) { + + $this->getView()->registerMetaTag([ + 'name' => 'robots', + 'content' => $meta + ]); + + } else if(!empty($filter['special'])){ + + $this->getView()->registerMetaTag([ + 'name' => 'robots', + 'content' => 'noindex,follow' + ]); + + } else if ( + isset($filter['brands']) && count($filter['brands']) > 1 + || isset($filter) && $this->checkFilter($filter) + + ) { + + $this->getView()->registerMetaTag([ + 'name' => 'robots', + 'content' => 'noindex,nofollow' + ]); + + } else if ( + isset($filter['brands']) && count($filter['brands']) > 1 && isset($filter) && count($filter, COUNT_RECURSIVE) >= 4 + || isset($filter) && count($filter, COUNT_RECURSIVE) > 4 + || !empty($sort) || !empty($paginate) || isset($filter['prices']) + ) { + + $this->getView()->registerMetaTag([ + 'name' => 'robots', + 'content' => 'noindex,nofollow' + ]); + } else { + + $this->getView()->registerMetaTag([ + 'name' => 'robots', + 'content' => 'index,follow' + ]); + } + + + + + break; + } + + + } + + protected function replaceData($str) + { + + if (!empty($this->fields)) { + foreach ($this->fields as $field_name => $field_value) { + $str = str_replace('{' . $field_name . '}', $field_value, $str); + } + } + $str = str_replace('{project_name}', $this->project_name, $str); + return $str; + } + + protected static function findSeoByUrl($url) + { + if(empty(self::$check_url_bool)){ + self::$check_url = \artweb\artbox\seo\models\Seo::findOne(['url' => $url]); + self::$check_url_bool = true; + } + return self::$check_url; + } + + protected function findSeoByDynamic() + { + + if(!empty($this->key)){ + + $query = SeoDynamic::find()->joinWith('seoCategory')->where(['controller' => \Yii::$app->controller->id, 'action' => \Yii::$app->controller->action->id, 'key' => $this->key]); + } else { + + + $query = SeoDynamic::find()->joinWith('seoCategory')->where(['controller' => \Yii::$app->controller->id, 'action' => \Yii::$app->controller->action->id]); + } + + return $query->one(); + } + + + protected function findSeoByDynamicForFilters(){ + return SeoDynamic::find()->joinWith('seoCategory')->where(['param' =>'filters'])->one(); + } + + + protected function getViewData() + { + $params = $this->getView()->params; + if (isset($params['seo'])) { + return $params['seo']; + } else { + return []; + } + } + + protected function selectSeoData($param) + { + + $result = ''; + + $widgetData = static::findSeoByUrl($this->url); + + if ($widgetData instanceof \artweb\artbox\seo\models\Seo) { + + $result = $widgetData->$param; + + } else if (!empty($this->$param)) { + + $result = $this->$param; + + } else { + + $widgetData = $this->findSeoByDynamic(); + + if ($widgetData instanceof SeoDynamic) { + + $result = $widgetData->$param; + + } + + } + + return $this->replaceData($result); + + } + + public function getTitleString($array){ + // "{Название раздела: Название блока фильтра | Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3} - купить в Киеве, Украине - интернет магазин Лінія Світла"; + $row = ''; + foreach($array as $name => $field){ + + if($name == 'category' ){ + $row = $field.' | '.$row; + } else { + $row .= $field['name'] .' '.$field['value'].' | ' ; + } + + + + } + $row = substr($row, 0,-2 ); + $row .= " - купить в Киеве, Украине - интернет магазин Лінія Світла"; + return $row; +// $template = SeoDynamic::find()->select('title')->where(['param' =>'filters'])->one(); +// if($template instanceof SeoDynamic){ +// foreach ($array as $field_name => $field_value) { +// $template->title = str_replace('{' . $field_name . '}', mb_strtolower($field_value), $template->title); +// } +// $template = preg_replace('/\{.[^\}]*\}\s/','',$template->title); +// return $template; +// } +// +// return false; + + } + + + public function getDescriptionString($array){ + // "Лучшие цены на {Название раздела | Название блока фильтра: Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3}. Лінія Світла"; + $row = 'Лучшие цены на '; + foreach($array as $name => $field){ + + if($name == 'category' ){ + $row = $field.' | '.$row; + } else { + $row .= $field['name'] .' '.$field['value'].' | ' ; + } + + + + } + $row = substr($row, 0,-2 ); + $row .= ". Лінія Світла"; + return $row; + + } + + + public function getNameString($array){ + // "Лучшие цены на {Название раздела | Название блока фильтра: Фильтр 1 | Название блока фильтра: Фильтр 2 | Название блока фильтра: Фильтр 3}. Лінія Світла"; + $row = ''; + foreach($array as $name => $field){ + + if($name == 'category' ){ + $row = $field.' | '.$row; + } else { + $row .= $field['name'] .' '.$field['value'].' | ' ; + } + + + + } + $row = substr($row, 0,-2 ); + return $row; + + } + + public function arrayBuilder($filter) + { + + $array = [ + 'category' => $this->category_name + ]; + + + if (isset($filter['brands']) && count($filter['brands']) == 1) { + $model = Brand::find()->where(['alias' => $filter['brands'][0]])->one(); + if (!$model instanceof Brand) { + + \Yii::$app->response->redirect(['/site/error'], 404); + } else { + $array['brand']['name'] = 'Бренд'; + $array['brand']['value'] = $model->name; + } + + } + + + $optionsList = ArrayHelper::map(TaxGroup::find()->where(['is_filter' => 'TRUE'])->all(), 'alias', 'name'); + + + foreach ($optionsList as $optionList => $name) { + + + if (isset($filter[$optionList]) && count($filter[$optionList]) == 1) { + + $model = TaxOption::find()->where(['alias' => $filter[$optionList]])->one(); + if (!$model instanceof TaxOption) { + + \Yii::$app->response->redirect(['site/error'], 404); + } else { + $array[$optionList]['value'] = $model->value; + $array[$optionList]['name'] = $name; + } + + + } + + + } + + return $array; + + } + + protected function checkFilter($filter){ + foreach(self::$optionsList as $optionList){ + + if(isset($filter[$optionList]) && count($filter[$optionList]) > 1){ + return true; + } + + } + return false; + } + + +} \ No newline at end of file -- libgit2 0.21.4