Sha256: 0431226e8c5ee5ab6efa30287eb2b5020fc217cb61f12112dc67ebfddc6156cd

Contents?: true

Size: 1.98 KB

Versions: 34

Compression:

Stored size: 1.98 KB

Contents

# Revenue: Transactions Grouped By Name

module Admin
  class ReportTransactionsGroupedByQbNameDatatable < Effective::Datatable
    filters do
      filter_date_range :current_month
    end

    datatable do
      length 250

      col :qb_item_name
      col :subtotal, as: :price
      col :tax, as: :price
      col :total, as: :price

      payment_providers.each do |provider|
        col("p - #{provider}", as: :price, visible: false)
      end

      col :orders_count

      col :orders, visible: false
      col :users, visible: false

      col :start_date, as: :date, search: false, sort: false, visible: false do
        date_range.begin&.strftime('%F')
      end

      col :end_date, as: :date, search: false, sort: false, visible: false do
        date_range.end&.strftime('%F')
      end

      aggregate :total
    end

    collection do
      start_date = date_range.begin&.strftime('%F')
      end_date = date_range.end&.strftime('%F')

      orders = Effective::Order.purchased.where(purchased_at: date_range).where('total != 0')
      order_items = Effective::OrderItem.includes(:qb_order_item).where(order_id: orders).includes(:purchasable, order: :user)

      items = order_items.group_by(&:qb_item_name).map do |name, items|
        row = [
          name,
          items.sum { |item| item.subtotal }.to_i,
          items.sum { |item| item.tax }.to_i,
          items.sum { |item| item.total }.to_i,
        ]

        row += payment_providers.map do |payment_provider|
          items.sum { |item| (item.order.payment_provider == payment_provider) ? item.total : 0 }.to_i
        end

        row += [
          items.map(&:order_id).uniq.length,
          items.map { |item| item.order },
          items.map { |item| item.order.user },
          start_date,
          end_date
        ]

        row
      end
    end

    def payment_providers
      @payment_providers ||= Effective::Order.purchased.group(:payment_provider).pluck(:payment_provider) - ['free', 'pretend', '', nil]
    end

  end
end

Version data entries

34 entries across 34 versions & 1 rubygems

Version Path
effective_orders-6.19.1 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.19.0 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.18.4 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.18.3 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.18.2 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.18.1 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.18.0 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.17.2 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.17.1 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.17.0 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.16.4 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.16.3 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.16.2 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.16.1 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.16.0 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.15.0 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.14.6 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.14.5 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.14.4 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb
effective_orders-6.14.3 app/datatables/admin/report_transactions_grouped_by_qb_name_datatable.rb