MenuItem.php 2.68 KB
<?php

namespace backend\modules\menu\models\search;

use Yii;
use yii\data\ActiveDataProvider;
use yii\base\Model;
//
use thread\app\model\interfaces\search\BaseBackendSearchModel;
//
use backend\modules\menu\Menu as ParentModule;
use backend\modules\menu\models\{
    MenuItem as ParentModel, MenuItemLang as ParentLang
};

/**
 * Class MenuItem
 *
 * @package backend\modules\menu\models\search
 * @author FilamentV <vortex.filament@gmail.com>
 * @copyright (c), Thread
 */
class MenuItem extends ParentModel implements BaseBackendSearchModel
{
    public $title;

    /**
     * @return array
     */
    public function rules()
    {
        return [
            [['alias', 'title'], 'string', 'max' => 255],
            [['published'], 'in', 'range' => array_keys(self::statusKeyRange())],
        ];
    }

    /**
     *
     * @return array
     */
    public function scenarios()
    {
        return Model::scenarios();
    }

    /**
     * @param $query
     * @param $params
     * @return ActiveDataProvider
     */
    public function baseSearch($query, $params)
    {
        /** @var ParentModule $module */
        $module = Yii::$app->getModule('menu');
        $dataProvider = new ActiveDataProvider(
            [
                'query' => $query,
                'pagination' => [
                    'pageSize' => 999//$module->itemOnPage
                ],
                'sort' => [
                    'defaultOrder' => [
                        'position' => SORT_ASC
                    ]
                ]
            ]
        );

        $query->andWhere(['group_id' => Yii::$app->getRequest()->get('group_id') ?? '']);
        //
        if (!($this->load($params) && $this->validate())) {
            return $dataProvider;
        }
        $query->andFilterWhere(['like', 'alias', $this->alias])
            ->andFilterWhere(['=', 'published', $this->published]);
        //
        $query->andFilterWhere(['like', ParentLang::tableName() . '.title', $this->title]);

        return $dataProvider;
    }

    /**
     * Description
     * @param array $params
     * @return ActiveDataProvider
     */
    public function search($params)
    {
        $parent_id = Yii::$app->request->get('parent_id', 0);
        $query = ParentModel::find()->joinWith(['lang'])->parent_id($parent_id)->undeleted();
        return $this->baseSearch($query, $params);
    }

    /**
     * Description
     * @param $params
     * @return ActiveDataProvider
     */
    public function trash($params)
    {
        $parent_id = Yii::$app->request->get('parent_id', 0);
        $query = ParentModel::find()->joinWith(['lang'])->parent_id($parent_id)->deleted();
        return $this->baseSearch($query, $params);
    }
}