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.
72 lines
1.9 KiB
72 lines
1.9 KiB
<?php |
|
|
|
namespace backend\forms; |
|
|
|
use Yii; |
|
use yii\base\Model; |
|
use yii\data\ActiveDataProvider; |
|
use core\entities\user\User; |
|
use yii\helpers\ArrayHelper; |
|
|
|
class UserSearch extends Model |
|
{ |
|
public ?int $id = null; |
|
public ?string $date_from = null; |
|
public ?string $date_to = null; |
|
public ?string $username = null; |
|
public ?string $email = null; |
|
public ?int $status = null; |
|
public ?string $role = null; |
|
|
|
public function rules(): array |
|
{ |
|
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'); |
|
} |
|
}
|
|
|