| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Reports\Block\Adminhtml\Sales\Coupons;
- /**
- * Adminhtml coupons report grid block
- *
- * @author Magento Core Team <core@magentocommerce.com>
- * @SuppressWarnings(PHPMD.DepthOfInheritance)
- */
- class Grid extends \Magento\Reports\Block\Adminhtml\Grid\AbstractGrid
- {
- /**
- * GROUP BY criteria
- *
- * @var string
- */
- protected $_columnGroupBy = 'period';
- /**
- * {@inheritdoc}
- * @codeCoverageIgnore
- */
- protected function _construct()
- {
- parent::_construct();
- $this->setCountTotals(true);
- $this->setCountSubTotals(true);
- }
- /**
- * {@inheritdoc}
- */
- public function getResourceCollectionName()
- {
- if ($this->getFilterData()->getData('report_type') == 'updated_at_order') {
- return \Magento\SalesRule\Model\ResourceModel\Report\Updatedat\Collection::class;
- } else {
- return \Magento\SalesRule\Model\ResourceModel\Report\Collection::class;
- }
- }
- /**
- * {@inheritdoc}
- * @SuppressWarnings(PHPMD.ExcessiveMethodLength)
- */
- protected function _prepareColumns()
- {
- $this->addColumn(
- 'period',
- [
- 'header' => __('Interval'),
- 'index' => 'period',
- 'sortable' => false,
- 'period_type' => $this->getPeriodType(),
- 'renderer' => \Magento\Reports\Block\Adminhtml\Sales\Grid\Column\Renderer\Date::class,
- 'totals_label' => __('Total'),
- 'subtotals_label' => __('Subtotal'),
- 'html_decorators' => ['nobr'],
- 'header_css_class' => 'col-period',
- 'column_css_class' => 'col-period'
- ]
- );
- $this->addColumn(
- 'coupon_code',
- [
- 'header' => __('Coupon Code'),
- 'sortable' => false,
- 'index' => 'coupon_code',
- 'header_css_class' => 'col-code',
- 'column_css_class' => 'col-code'
- ]
- );
- $this->addColumn(
- 'rule_name',
- [
- 'header' => __('Price Rule'),
- 'sortable' => false,
- 'index' => 'rule_name',
- 'header_css_class' => 'col-rule',
- 'column_css_class' => 'col-rule'
- ]
- );
- $this->addColumn(
- 'coupon_uses',
- [
- 'header' => __('Uses'),
- 'sortable' => false,
- 'index' => 'coupon_uses',
- 'total' => 'sum',
- 'type' => 'number',
- 'header_css_class' => 'col-users',
- 'column_css_class' => 'col-users'
- ]
- );
- if ($this->getFilterData()->getStoreIds()) {
- $this->setStoreIds(explode(',', $this->getFilterData()->getStoreIds()));
- }
- $currencyCode = $this->getCurrentCurrencyCode();
- $rate = $this->getRate($currencyCode);
- $this->addColumn(
- 'subtotal_amount',
- [
- 'header' => __('Sales Subtotal'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'subtotal_amount',
- 'rate' => $rate,
- 'header_css_class' => 'col-sales',
- 'column_css_class' => 'col-sales'
- ]
- );
- $this->addColumn(
- 'discount_amount',
- [
- 'header' => __('Sales Discount'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'discount_amount',
- 'rate' => $rate,
- 'header_css_class' => 'col-sales-discount',
- 'column_css_class' => 'col-sales-discount'
- ]
- );
- $this->addColumn(
- 'total_amount',
- [
- 'header' => __('Sales Total'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'total_amount',
- 'rate' => $rate,
- 'header_css_class' => 'col-total-amount',
- 'column_css_class' => 'col-total-amount'
- ]
- );
- $this->addColumn(
- 'subtotal_amount_actual',
- [
- 'header' => __('Subtotal'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'subtotal_amount_actual',
- 'rate' => $rate,
- 'header_css_class' => 'col-subtotal',
- 'column_css_class' => 'col-subtotal'
- ]
- );
- $this->addColumn(
- 'discount_amount_actual',
- [
- 'header' => __('Discount'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'discount_amount_actual',
- 'rate' => $rate,
- 'header_css_class' => 'col-discount',
- 'column_css_class' => 'col-discount'
- ]
- );
- $this->addColumn(
- 'total_amount_actual',
- [
- 'header' => __('Total'),
- 'sortable' => false,
- 'type' => 'currency',
- 'currency_code' => $currencyCode,
- 'total' => 'sum',
- 'index' => 'total_amount_actual',
- 'rate' => $rate,
- 'header_css_class' => 'col-total',
- 'column_css_class' => 'col-total'
- ]
- );
- $this->addExportType('*/*/exportCouponsCsv', __('CSV'));
- $this->addExportType('*/*/exportCouponsExcel', __('Excel XML'));
- return parent::_prepareColumns();
- }
- /**
- * Add price rule filter
- *
- * @param \Magento\Reports\Model\ResourceModel\Report\Collection\AbstractCollection $collection
- * @param \Magento\Framework\DataObject $filterData
- * @return \Magento\Reports\Block\Adminhtml\Grid\AbstractGrid
- */
- protected function _addCustomFilter($collection, $filterData)
- {
- if ($filterData->getPriceRuleType()) {
- $rulesList = $filterData->getData('rules_list');
- if (isset($rulesList[0])) {
- $rulesIds = explode(',', $rulesList[0]);
- $collection->addRuleFilter($rulesIds);
- }
- }
- return parent::_addCustomFilter($filterData, $collection);
- }
- }
|