| @@ 304-327 (lines=24) @@ | ||
| 301 | * |
|
| 302 | * @return int |
|
| 303 | */ |
|
| 304 | public function getCustomersCountWhatMakeCarts(AclHelper $aclHelper, \DateTime $from = null, \DateTime $to = null) |
|
| 305 | { |
|
| 306 | $qb = $this->createQueryBuilder('c'); |
|
| 307 | ||
| 308 | try { |
|
| 309 | $qb |
|
| 310 | ->select('COUNT(DISTINCT c.customer) + SUM(CASE WHEN c.isGuest = true THEN 1 ELSE 0 END)'); |
|
| 311 | if ($from) { |
|
| 312 | $qb |
|
| 313 | ->andWhere('c.createdAt > :from') |
|
| 314 | ->setParameter('from', $from); |
|
| 315 | } |
|
| 316 | if ($to) { |
|
| 317 | $qb |
|
| 318 | ->andWhere('c.createdAt < :to') |
|
| 319 | ->setParameter('to', $to); |
|
| 320 | } |
|
| 321 | $this->applyActiveChannelLimitation($qb); |
|
| 322 | ||
| 323 | return (int)$aclHelper->apply($qb)->getSingleScalarResult(); |
|
| 324 | } catch (NoResultException $ex) { |
|
| 325 | return 0; |
|
| 326 | } |
|
| 327 | } |
|
| 328 | ||
| 329 | /** |
|
| 330 | * @param string $alias |
|
| @@ 273-295 (lines=23) @@ | ||
| 270 | * |
|
| 271 | * @return int |
|
| 272 | */ |
|
| 273 | public function getUniqueBuyersCount(AclHelper $aclHelper, \DateTime $from = null, \DateTime $to = null) |
|
| 274 | { |
|
| 275 | $qb = $this->createQueryBuilder('o'); |
|
| 276 | ||
| 277 | try { |
|
| 278 | $qb->select('COUNT(DISTINCT o.customer) + SUM(CASE WHEN o.isGuest = true THEN 1 ELSE 0 END)'); |
|
| 279 | if ($from) { |
|
| 280 | $qb |
|
| 281 | ->andWhere('o.createdAt > :from') |
|
| 282 | ->setParameter('from', $from); |
|
| 283 | } |
|
| 284 | if ($to) { |
|
| 285 | $qb |
|
| 286 | ->andWhere('o.createdAt > :to') |
|
| 287 | ->setParameter('to', $to); |
|
| 288 | } |
|
| 289 | $this->applyActiveChannelLimitation($qb); |
|
| 290 | ||
| 291 | return (int) $aclHelper->apply($qb)->getSingleScalarResult(); |
|
| 292 | } catch (NoResultException $ex) { |
|
| 293 | return 0; |
|
| 294 | } |
|
| 295 | } |
|
| 296 | ||
| 297 | /** |
|
| 298 | * @param $alias |
|
| @@ 491-508 (lines=18) @@ | ||
| 488 | * |
|
| 489 | * @return double |
|
| 490 | */ |
|
| 491 | public function getWeightedPipelineAmount(AclHelper $aclHelper, \DateTime $start = null, \DateTime $end = null) |
|
| 492 | { |
|
| 493 | $qb = $this->createQueryBuilder('o'); |
|
| 494 | ||
| 495 | $qb->select('SUM(o.budgetAmount * o.probability)'); |
|
| 496 | if ($start) { |
|
| 497 | $qb |
|
| 498 | ->andWhere('o.createdAt > :start') |
|
| 499 | ->setParameter('start', $start); |
|
| 500 | } |
|
| 501 | if ($end) { |
|
| 502 | $qb |
|
| 503 | ->andWhere('o.createdAt < :end') |
|
| 504 | ->setParameter('end', $end); |
|
| 505 | } |
|
| 506 | ||
| 507 | return $aclHelper->apply($qb)->getSingleScalarResult(); |
|
| 508 | } |
|
| 509 | ||
| 510 | /** |
|
| 511 | * @param AclHelper $aclHelper |
|