ManufacturersSearch.php 2.59 KB
<?php

namespace common\models;

use Yii;
use yii\base\Model;
use yii\data\ActiveDataProvider;
use common\models\Manufacturers;

/**
 * ManufacturersSearch represents the model behind the search form about `common\models\Manufacturers`.
 */
class ManufacturersSearch extends Manufacturers
{
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
            [['MFA_ID', 'MFA_PC_MFC', 'MFA_CV_MFC', 'MFA_AXL_MFC', 'MFA_ENG_MFC', 'MFA_ENG_TYP', 'MFA_MF_NR', 'MY_SORT', 'MY_ACTIVE', 'MY_DEFAULT'], 'integer'],
            [['MFA_MFC_CODE', 'MFA_BRAND', 'MY_IMG', 'name', 'content', 'title', 'kwords', 'descr', 'h1', 'original_url'], 'safe'],
        ];
    }

    /**
     * @inheritdoc
     */
    public function scenarios()
    {
        // bypass scenarios() implementation in the parent class
        return Model::scenarios();
    }

    /**
     * Creates data provider instance with search query applied
     *
     * @param array $params
     *
     * @return ActiveDataProvider
     */
    public function search($params)
    {
        $query = Manufacturers::find();

        $dataProvider = new ActiveDataProvider([
            'query' => $query,
        ]);

        $this->load($params);

        if (!$this->validate()) {
            // uncomment the following line if you do not want to return any records when validation fails
            // $query->where('0=1');
            return $dataProvider;
        }

        $query->andFilterWhere([
            'MFA_ID' => $this->MFA_ID,
            'MFA_PC_MFC' => $this->MFA_PC_MFC,
            'MFA_CV_MFC' => $this->MFA_CV_MFC,
            'MFA_AXL_MFC' => $this->MFA_AXL_MFC,
            'MFA_ENG_MFC' => $this->MFA_ENG_MFC,
            'MFA_ENG_TYP' => $this->MFA_ENG_TYP,
            'MFA_MF_NR' => $this->MFA_MF_NR,
            'MY_SORT' => $this->MY_SORT,
            'MY_ACTIVE' => $this->MY_ACTIVE,
            'MY_DEFAULT' => $this->MY_DEFAULT,
        ]);

        $query->andFilterWhere(['like', 'MFA_MFC_CODE', $this->MFA_MFC_CODE])
            ->andFilterWhere(['like', 'MFA_BRAND', $this->MFA_BRAND])
            ->andFilterWhere(['like', 'MY_IMG', $this->MY_IMG])
            ->andFilterWhere(['like', 'name', $this->name])
            ->andFilterWhere(['like', 'content', $this->content])
            ->andFilterWhere(['like', 'title', $this->title])
            ->andFilterWhere(['like', 'kwords', $this->kwords])
            ->andFilterWhere(['like', 'descr', $this->descr])
            ->andFilterWhere(['like', 'h1', $this->h1])
            ->andFilterWhere(['like', 'original_url', $this->original_url]);

        return $dataProvider;
    }
}