You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							71 lines
						
					
					
						
							1.8 KiB
						
					
					
				
			
		
		
	
	
							71 lines
						
					
					
						
							1.8 KiB
						
					
					
				<?php | 
						|
 | 
						|
namespace backend\forms; | 
						|
 | 
						|
use yii\base\Model; | 
						|
use yii\data\ActiveDataProvider; | 
						|
use core\entities\user\User; | 
						|
use yii\helpers\ArrayHelper; | 
						|
 | 
						|
class UserSearch extends Model | 
						|
{ | 
						|
    public $id; | 
						|
    public $date_from; | 
						|
    public $date_to; | 
						|
    public $username; | 
						|
    public $email; | 
						|
    public $status; | 
						|
    public $role; | 
						|
 | 
						|
    public function rules() | 
						|
    { | 
						|
        return [ | 
						|
            [['id', 'status'], 'integer'], | 
						|
            [['username', 'email', 'role'], 'safe'], | 
						|
            [['date_from', 'date_to'], 'date', 'format' => 'php:Y-m-d'], | 
						|
        ]; | 
						|
    } | 
						|
 | 
						|
    /** | 
						|
     * @param array $params | 
						|
     * @return ActiveDataProvider | 
						|
     */ | 
						|
    public function search(array $params): ActiveDataProvider | 
						|
    { | 
						|
        $query = User::find()->alias('u'); | 
						|
 | 
						|
        $dataProvider = new ActiveDataProvider([ | 
						|
            'query' => $query, | 
						|
        ]); | 
						|
 | 
						|
        $this->load($params); | 
						|
 | 
						|
        if (!$this->validate()) { | 
						|
            $query->where('0=1'); | 
						|
            return $dataProvider; | 
						|
        } | 
						|
 | 
						|
        $query->andFilterWhere([ | 
						|
            'u.id' => $this->id, | 
						|
            'u.status' => $this->status, | 
						|
        ]); | 
						|
 | 
						|
        if (!empty($this->role)) { | 
						|
            $query->innerJoin('{{%auth_assignments}} a', 'a.user_id = u.id'); | 
						|
            $query->andWhere(['a.item_name' => $this->role]); | 
						|
        } | 
						|
 | 
						|
        $query | 
						|
            ->andFilterWhere(['like', 'u.username', $this->username]) | 
						|
            ->andFilterWhere(['like', 'u.email', $this->email]) | 
						|
            ->andFilterWhere(['>=', 'u.created_at', $this->date_from ? strtotime($this->date_from . ' 00:00:00') : null]) | 
						|
            ->andFilterWhere(['<=', 'u.created_at', $this->date_to ? strtotime($this->date_to . ' 23:59:59') : null]); | 
						|
 | 
						|
        return $dataProvider; | 
						|
    } | 
						|
 | 
						|
    public function rolesList(): array | 
						|
    { | 
						|
        return ArrayHelper::map(\Yii::$app->authManager->getRoles(), 'name', 'description'); | 
						|
    } | 
						|
}
 | 
						|
 |