PageRenderTime 27ms CodeModel.GetById 14ms RepoModel.GetById 1ms app.codeStats 0ms

/vendor/magento/module-sales/Model/ResourceModel/Report/Order/Createdat.php

https://gitlab.com/yousafsyed/easternglamor
PHP | 255 lines | 205 code | 16 blank | 34 comment | 5 complexity | f4930bc9c717d6d04b5ff2d6a8018898 MD5 | raw file
  1. <?php
  2. /**
  3. * Copyright © 2016 Magento. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Sales\Model\ResourceModel\Report\Order;
  7. /**
  8. * Order entity resource model with aggregation by created at
  9. *
  10. * @author Magento Core Team <core@magentocommerce.com>
  11. */
  12. class Createdat extends \Magento\Sales\Model\ResourceModel\Report\AbstractReport
  13. {
  14. /**
  15. * Model initialization
  16. *
  17. * @return void
  18. */
  19. protected function _construct()
  20. {
  21. $this->_init('sales_order_aggregated_created', 'id');
  22. }
  23. /**
  24. * Aggregate Orders data by order created at
  25. *
  26. * @param string|int|\DateTime|array|null $from
  27. * @param string|int|\DateTime|array|null $to
  28. * @return $this
  29. */
  30. public function aggregate($from = null, $to = null)
  31. {
  32. return $this->_aggregateByField('created_at', $from, $to);
  33. }
  34. /**
  35. * Aggregate Orders data by custom field
  36. *
  37. * @param string $aggregationField
  38. * @param string|int|\DateTime|array|null $from
  39. * @param string|int|\DateTime|array|null $to
  40. * @return $this
  41. * @throws \Exception
  42. * @SuppressWarnings(PHPMD.ExcessiveMethodLength)
  43. * @SuppressWarnings(PHPMD.UnusedLocalVariable)
  44. */
  45. protected function _aggregateByField($aggregationField, $from, $to)
  46. {
  47. $connection = $this->getConnection();
  48. $connection->beginTransaction();
  49. try {
  50. if ($from !== null || $to !== null) {
  51. $subSelect = $this->_getTableDateRangeSelect(
  52. $this->getTable('sales_order'),
  53. $aggregationField,
  54. $aggregationField,
  55. $from,
  56. $to
  57. );
  58. } else {
  59. $subSelect = null;
  60. }
  61. $this->_clearTableByDateRange($this->getMainTable(), $from, $to, $subSelect);
  62. $periodExpr = $connection->getDatePartSql(
  63. $this->getStoreTZOffsetQuery(
  64. ['o' => $this->getTable('sales_order')],
  65. 'o.' . $aggregationField,
  66. $from,
  67. $to
  68. )
  69. );
  70. // Columns list
  71. $columns = [
  72. 'period' => $periodExpr,
  73. 'store_id' => 'o.store_id',
  74. 'order_status' => 'o.status',
  75. 'orders_count' => new \Zend_Db_Expr('COUNT(o.entity_id)'),
  76. 'total_qty_ordered' => new \Zend_Db_Expr('SUM(oi.total_qty_ordered)'),
  77. 'total_qty_invoiced' => new \Zend_Db_Expr('SUM(oi.total_qty_invoiced)'),
  78. 'total_income_amount' => new \Zend_Db_Expr(
  79. sprintf(
  80. 'SUM((%s - %s) * %s)',
  81. $connection->getIfNullSql('o.base_grand_total', 0),
  82. $connection->getIfNullSql('o.base_total_canceled', 0),
  83. $connection->getIfNullSql('o.base_to_global_rate', 0)
  84. )
  85. ),
  86. 'total_revenue_amount' => new \Zend_Db_Expr(
  87. sprintf(
  88. 'SUM((%s - %s - %s - (%s - %s - %s)) * %s)',
  89. $connection->getIfNullSql('o.base_total_invoiced', 0),
  90. $connection->getIfNullSql('o.base_tax_invoiced', 0),
  91. $connection->getIfNullSql('o.base_shipping_invoiced', 0),
  92. $connection->getIfNullSql('o.base_total_refunded', 0),
  93. $connection->getIfNullSql('o.base_tax_refunded', 0),
  94. $connection->getIfNullSql('o.base_shipping_refunded', 0),
  95. $connection->getIfNullSql('o.base_to_global_rate', 0)
  96. )
  97. ),
  98. 'total_profit_amount' => new \Zend_Db_Expr(
  99. sprintf(
  100. 'SUM((%s - %s - %s - %s - %s) * %s)',
  101. $connection->getIfNullSql('o.base_total_paid', 0),
  102. $connection->getIfNullSql('o.base_total_refunded', 0),
  103. $connection->getIfNullSql('o.base_tax_invoiced', 0),
  104. $connection->getIfNullSql('o.base_shipping_invoiced', 0),
  105. $connection->getIfNullSql('o.base_total_invoiced_cost', 0),
  106. $connection->getIfNullSql('o.base_to_global_rate', 0)
  107. )
  108. ),
  109. 'total_invoiced_amount' => new \Zend_Db_Expr(
  110. sprintf(
  111. 'SUM(%s * %s)',
  112. $connection->getIfNullSql('o.base_total_invoiced', 0),
  113. $connection->getIfNullSql('o.base_to_global_rate', 0)
  114. )
  115. ),
  116. 'total_canceled_amount' => new \Zend_Db_Expr(
  117. sprintf(
  118. 'SUM(%s * %s)',
  119. $connection->getIfNullSql('o.base_total_canceled', 0),
  120. $connection->getIfNullSql('o.base_to_global_rate', 0)
  121. )
  122. ),
  123. 'total_paid_amount' => new \Zend_Db_Expr(
  124. sprintf(
  125. 'SUM(%s * %s)',
  126. $connection->getIfNullSql('o.base_total_paid', 0),
  127. $connection->getIfNullSql('o.base_to_global_rate', 0)
  128. )
  129. ),
  130. 'total_refunded_amount' => new \Zend_Db_Expr(
  131. sprintf(
  132. 'SUM(%s * %s)',
  133. $connection->getIfNullSql('o.base_total_refunded', 0),
  134. $connection->getIfNullSql('o.base_to_global_rate', 0)
  135. )
  136. ),
  137. 'total_tax_amount' => new \Zend_Db_Expr(
  138. sprintf(
  139. 'SUM((%s - %s) * %s)',
  140. $connection->getIfNullSql('o.base_tax_amount', 0),
  141. $connection->getIfNullSql('o.base_tax_canceled', 0),
  142. $connection->getIfNullSql('o.base_to_global_rate', 0)
  143. )
  144. ),
  145. 'total_tax_amount_actual' => new \Zend_Db_Expr(
  146. sprintf(
  147. 'SUM((%s -%s) * %s)',
  148. $connection->getIfNullSql('o.base_tax_invoiced', 0),
  149. $connection->getIfNullSql('o.base_tax_refunded', 0),
  150. $connection->getIfNullSql('o.base_to_global_rate', 0)
  151. )
  152. ),
  153. 'total_shipping_amount' => new \Zend_Db_Expr(
  154. sprintf(
  155. 'SUM((%s - %s) * %s)',
  156. $connection->getIfNullSql('o.base_shipping_amount', 0),
  157. $connection->getIfNullSql('o.base_shipping_canceled', 0),
  158. $connection->getIfNullSql('o.base_to_global_rate', 0)
  159. )
  160. ),
  161. 'total_shipping_amount_actual' => new \Zend_Db_Expr(
  162. sprintf(
  163. 'SUM((%s - %s) * %s)',
  164. $connection->getIfNullSql('o.base_shipping_invoiced', 0),
  165. $connection->getIfNullSql('o.base_shipping_refunded', 0),
  166. $connection->getIfNullSql('o.base_to_global_rate', 0)
  167. )
  168. ),
  169. 'total_discount_amount' => new \Zend_Db_Expr(
  170. sprintf(
  171. 'SUM((ABS(%s) - %s) * %s)',
  172. $connection->getIfNullSql('o.base_discount_amount', 0),
  173. $connection->getIfNullSql('o.base_discount_canceled', 0),
  174. $connection->getIfNullSql('o.base_to_global_rate', 0)
  175. )
  176. ),
  177. 'total_discount_amount_actual' => new \Zend_Db_Expr(
  178. sprintf(
  179. 'SUM((%s - %s) * %s)',
  180. $connection->getIfNullSql('o.base_discount_invoiced', 0),
  181. $connection->getIfNullSql('o.base_discount_refunded', 0),
  182. $connection->getIfNullSql('o.base_to_global_rate', 0)
  183. )
  184. ),
  185. ];
  186. $select = $connection->select();
  187. $selectOrderItem = $connection->select();
  188. $qtyCanceledExpr = $connection->getIfNullSql('qty_canceled', 0);
  189. $cols = [
  190. 'order_id' => 'order_id',
  191. 'total_qty_ordered' => new \Zend_Db_Expr("SUM(qty_ordered - {$qtyCanceledExpr})"),
  192. 'total_qty_invoiced' => new \Zend_Db_Expr('SUM(qty_invoiced)'),
  193. ];
  194. $selectOrderItem->from(
  195. $this->getTable('sales_order_item'),
  196. $cols
  197. )->where(
  198. 'parent_item_id IS NULL'
  199. )->group(
  200. 'order_id'
  201. );
  202. $select->from(
  203. ['o' => $this->getTable('sales_order')],
  204. $columns
  205. )->join(
  206. ['oi' => $selectOrderItem],
  207. 'oi.order_id = o.entity_id',
  208. []
  209. )->where(
  210. 'o.state NOT IN (?)',
  211. [\Magento\Sales\Model\Order::STATE_PENDING_PAYMENT, \Magento\Sales\Model\Order::STATE_NEW]
  212. );
  213. if ($subSelect !== null) {
  214. $select->having($this->_makeConditionFromDateRangeSelect($subSelect, 'period'));
  215. }
  216. $select->group([$periodExpr, 'o.store_id', 'o.status']);
  217. $connection->query($select->insertFromSelect($this->getMainTable(), array_keys($columns)));
  218. // setup all columns to select SUM() except period, store_id and order_status
  219. foreach ($columns as $k => $v) {
  220. $columns[$k] = new \Zend_Db_Expr('SUM(' . $k . ')');
  221. }
  222. $columns['period'] = 'period';
  223. $columns['store_id'] = new \Zend_Db_Expr(\Magento\Store\Model\Store::DEFAULT_STORE_ID);
  224. $columns['order_status'] = 'order_status';
  225. $select->reset();
  226. $select->from($this->getMainTable(), $columns)->where('store_id <> 0');
  227. if ($subSelect !== null) {
  228. $select->where($this->_makeConditionFromDateRangeSelect($subSelect, 'period'));
  229. }
  230. $select->group(['period', 'order_status']);
  231. $connection->query($select->insertFromSelect($this->getMainTable(), array_keys($columns)));
  232. $connection->commit();
  233. } catch (\Exception $e) {
  234. $connection->rollBack();
  235. throw $e;
  236. }
  237. return $this;
  238. }
  239. }