mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-15 22:13:13 +00:00
implementation back-end for refactoring of orders
refactoring layout order-box and order-item
This commit is contained in:
@@ -31,58 +31,118 @@ class OrderRepository extends EntityRepository
|
||||
/**
|
||||
* Returns an array of all the orders, starting at $offsetStart, limited to $perPage
|
||||
*
|
||||
* @param array $baseIds
|
||||
* @param array $baseIds
|
||||
* @param integer $offsetStart
|
||||
* @param integer $perPage
|
||||
* @param string $sort
|
||||
*
|
||||
* @param string $sort
|
||||
* @param ArrayCollection $filters
|
||||
* @return Order[]
|
||||
*/
|
||||
public function listOrders($baseIds, $offsetStart = 0, $perPage = 20, $sort = "created_on")
|
||||
public function listOrders($baseIds, $offsetStart = 0, $perPage = 20, $sort = "created_on", $filters = [])
|
||||
{
|
||||
$qb = $this
|
||||
->createQueryBuilder('o');
|
||||
|
||||
if (!empty($baseIds)) {
|
||||
$qb
|
||||
->innerJoin('o.elements', 'e')
|
||||
->where($qb->expr()->in('e.baseId', $baseIds))
|
||||
->groupBy('o.id');
|
||||
}
|
||||
$this->performQuery($qb, $baseIds, $filters);
|
||||
$qb->groupBy('o.id');
|
||||
|
||||
if ($sort === 'user') {
|
||||
$qb->orderBy('o.user', 'ASC');
|
||||
} elseif ($sort === 'usage') {
|
||||
$qb->orderBy('o.orderUsage', 'ASC');
|
||||
} else {
|
||||
$qb->orderBy('o.createdOn', 'DESC');
|
||||
}
|
||||
if ($sort === 'user') {
|
||||
$qb->orderBy('o.user', 'ASC');
|
||||
}
|
||||
elseif ($sort === 'usage') {
|
||||
$qb->orderBy('o.orderUsage', 'ASC');
|
||||
}
|
||||
else {
|
||||
$qb->orderBy('o.createdOn', 'DESC');
|
||||
}
|
||||
|
||||
$qb
|
||||
->setFirstResult((int) $offsetStart)
|
||||
->setMaxResults(max(10, (int) $perPage));
|
||||
$qb
|
||||
->setFirstResult((int)$offsetStart)
|
||||
->setMaxResults(max(10, (int)$perPage));
|
||||
|
||||
return $qb->getQuery()->getResult();
|
||||
return $qb->getQuery()->getResult();
|
||||
}
|
||||
|
||||
public function performQuery($qb, $baseIds, $filters)
|
||||
{
|
||||
if (!empty($baseIds)) {
|
||||
$qb
|
||||
->innerJoin('o.elements', 'e')
|
||||
->where($qb->expr()->in('e.baseId', $baseIds));
|
||||
if ($filters['todo'] == Order::STATUS_TODO) {
|
||||
$qb
|
||||
->andWhere('o.todo != 0');
|
||||
}
|
||||
elseif ($filters['todo'] == Order::STATUS_PROCESSED) {
|
||||
$qb
|
||||
->andWhere('o.todo = 0');
|
||||
}
|
||||
|
||||
$createdOn = '';
|
||||
switch ($filters['created_on']) {
|
||||
case Order::STATUS_CURRENT_WEEK: //this week
|
||||
$time = strtotime(date("Y-m-d 00:00:00"));
|
||||
//check if today is monday
|
||||
if (date('D', $time) == 'Mon') {
|
||||
$weekStartDate = date('Y-m-d', strtotime("Monday", $time));
|
||||
}
|
||||
else {
|
||||
$weekStartDate = date('Y-m-d', strtotime("last Monday", $time));
|
||||
}
|
||||
$createdOn = $weekStartDate;
|
||||
$qb->andWhere("o.createdOn >= '" . $createdOn . "'");
|
||||
break;
|
||||
|
||||
case Order::STATUS_PAST_WEEK: //last week
|
||||
$time = strtotime('last week');
|
||||
$lastWeekStartDate = date('Y-m-d', strtotime("Monday", $time));
|
||||
$createdOn = $lastWeekStartDate;
|
||||
$qb->andWhere("o.createdOn >= '" . $createdOn . "'");
|
||||
break;
|
||||
|
||||
case Order::STATUS_PAST_MONTH: //last month
|
||||
$lastMonthStartDate = date("Y-m-d", strtotime("first day of previous month"));
|
||||
$createdOn = $lastMonthStartDate;
|
||||
$qb->andWhere("o.createdOn >= '" . $createdOn . "'");
|
||||
break;
|
||||
|
||||
case Order::STATUS_BEFORE: //before specific date
|
||||
if (isset($filters['limit']['date'])) {
|
||||
$createdOn = date('Y-m-d', strtotime($filters['limit']['date']));
|
||||
$qb->andWhere("o.createdOn < '" . $createdOn . "'");
|
||||
}
|
||||
break;
|
||||
|
||||
case Order::STATUS_AFTER: //before specific date
|
||||
if (isset($filters['limit']['date'])) {
|
||||
$createdOn = date('Y-m-d', strtotime($filters['limit']['date']));
|
||||
$qb->andWhere("o.createdOn > '" . $createdOn . "'");
|
||||
}
|
||||
break;
|
||||
|
||||
case Order::STATUS_NO_FILTER:
|
||||
//no filtering by date
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns the total number of orders from an array of base_id
|
||||
* Returns the total number of orders from an array of base_id and filters
|
||||
*
|
||||
* @param array $baseIds
|
||||
*
|
||||
* @param array $filters
|
||||
* @return int
|
||||
*/
|
||||
public function countTotalOrders(array $baseIds = [])
|
||||
public function countTotalOrders(array $baseIds = [], $filters = [])
|
||||
{
|
||||
$builder = $this->createQueryBuilder('o');
|
||||
$builder->select($builder->expr()->countDistinct('o.id'));
|
||||
|
||||
if (!empty($baseIds)) {
|
||||
$builder
|
||||
->innerJoin('o.elements', 'e')
|
||||
->where($builder->expr()->in('e.baseId', $baseIds));
|
||||
}
|
||||
$this->performQuery($builder, $baseIds, $filters);
|
||||
|
||||
return $builder->getQuery()->getSingleScalarResult();
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user