|
|
|
|
|
|
|
|
{ |
|
|
{ |
|
|
$optionsSearch = self::defaultOptionsSearch() ; |
|
|
$optionsSearch = self::defaultOptionsSearch() ; |
|
|
|
|
|
|
|
|
$query = User::find(); |
|
|
|
|
|
|
|
|
$query = User::find() |
|
|
|
|
|
->select( |
|
|
|
|
|
'`user`.id, ' |
|
|
|
|
|
.'`user`.username,' |
|
|
|
|
|
.'`user`.email, ' |
|
|
|
|
|
.'`user`.status, ' |
|
|
|
|
|
.'`user`.created_at, ' |
|
|
|
|
|
.'`user`.updated_at, ' |
|
|
|
|
|
.'`user`.lastname, ' |
|
|
|
|
|
.'`user`.name, ' |
|
|
|
|
|
.'`user`.phone, ' |
|
|
|
|
|
.'`user`.address, ' |
|
|
|
|
|
.'`user`.no_mail, ' |
|
|
|
|
|
.'`user`.mail_distribution_monday, ' |
|
|
|
|
|
.'`user`.mail_distribution_tuesday, ' |
|
|
|
|
|
.'`user`.mail_distribution_wednesday, ' |
|
|
|
|
|
.'`user`.mail_distribution_thursday, ' |
|
|
|
|
|
.'`user`.mail_distribution_friday, ' |
|
|
|
|
|
.'`user`.mail_distribution_saturday, ' |
|
|
|
|
|
.'`user`.mail_distribution_sunday, ' |
|
|
|
|
|
.'`user`.id_producer, ' |
|
|
|
|
|
.'`user`.date_last_connection, ' |
|
|
|
|
|
. '(SELECT COUNT(*) FROM `order` WHERE `user`.id = `order`.id_user) AS count_orders'); |
|
|
|
|
|
|
|
|
$dataProvider = new ActiveDataProvider([ |
|
|
$dataProvider = new ActiveDataProvider([ |
|
|
'query' => $query, |
|
|
'query' => $query, |
|
|
|
|
|
|
|
|
return $dataProvider; |
|
|
return $dataProvider; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
$active = (isset($this->inactive) && $this->inactive) ? 0 : 1 ; |
|
|
|
|
|
$query->innerJoin('user_producer','user.id = user_producer.id_user AND user_producer.active = '.$active.' AND user_producer.id_producer = :id_producer', [':id_producer' => Producer::getId()]) ; |
|
|
|
|
|
|
|
|
$query->innerJoin('user_producer','user.id = user_producer.id_user AND user_producer.id_producer = :id_producer', [':id_producer' => Producer::getId()]) ; |
|
|
|
|
|
|
|
|
if(isset($this->id_point_sale) && $this->id_point_sale) { |
|
|
if(isset($this->id_point_sale) && $this->id_point_sale) { |
|
|
$pointSale = PointSale::findOne(['id' => $this->id_point_sale]) ; |
|
|
$pointSale = PointSale::findOne(['id' => $this->id_point_sale]) ; |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if(isset($this->inactive) && $this->inactive) { |
|
|
if(isset($this->inactive) && $this->inactive) { |
|
|
$query->innerJoin( |
|
|
|
|
|
'order', |
|
|
|
|
|
'user.id = order.id_user' |
|
|
|
|
|
) |
|
|
|
|
|
->groupBy('user.id'); |
|
|
|
|
|
|
|
|
$query->having([ |
|
|
|
|
|
'count_orders' => 0 |
|
|
|
|
|
]) ; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
$query->andFilterWhere([ |
|
|
$query->andFilterWhere([ |
|
|
|
|
|
|
|
|
['like', 'user.name', $this->username] |
|
|
['like', 'user.name', $this->username] |
|
|
]); |
|
|
]); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return $dataProvider; |
|
|
return $dataProvider; |
|
|
} |
|
|
} |
|
|
|
|
|
|