123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class Report::TicketMoved < Report::Base
- =begin
- result = Report::TicketMoved.aggs(
- range_start: Time.zone.parse('2015-01-01T00:00:00Z'),
- range_end: Time.zone.parse('2015-12-31T23:59:59Z'),
- interval: 'month', # quarter, month, week, day, hour, minute, second
- selector: selector, # ticket selector to get only a collection of tickets
- params: { type: 'in' }, # in|out
- timezone: 'Europe/Berlin',
- )
- returns
- [4,5,1,5,0,51,5,56,7,4]
- =end
- def self.aggs(params_origin)
- params = params_origin.deep_dup
- selector = params[:selector]['ticket.group_id']
- if !selector
- return [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
- end
- result = []
- case params[:interval]
- when 'month'
- stop_interval = 12
- when 'week'
- stop_interval = 7
- when 'day'
- stop_interval = 31
- when 'hour'
- stop_interval = 24
- when 'minute'
- stop_interval = 60
- end
- (1..stop_interval).each do |_counter|
- case params[:interval]
- when 'month'
- params[:range_end] = params[:range_start].next_month
- when 'week', 'day'
- params[:range_end] = params[:range_start].next_day
- when 'hour'
- params[:range_end] = params[:range_start] + 1.hour
- when 'minute'
- params[:range_end] = params[:range_start] + 1.minute
- end
- local_params = group_attributes(selector, params)
- local_selector = params[:selector].clone
- without_merged_tickets = {
- 'ticket_state.name' => {
- 'operator' => 'is not',
- 'value' => 'merged'
- }
- }
- local_selector.merge!(without_merged_tickets) # do not show merged tickets in reports
- if params[:params][:type] == 'out'
- local_selector.delete('ticket.group_id')
- end
- defaults = {
- object: 'Ticket',
- type: 'updated',
- attribute: 'group',
- start: params[:range_start],
- end: params[:range_end],
- selector: local_selector
- }
- local_params = defaults.merge(local_params)
- count = history_count(local_params)
- result.push count
- params[:range_start] = params[:range_end]
- end
- result
- end
- =begin
- result = Report::TicketMoved.items(
- range_start: Time.zone.parse('2015-01-01T00:00:00Z'),
- range_end: Time.zone.parse('2015-12-31T23:59:59Z'),
- selector: selector, # ticket selector to get only a collection of tickets
- params: { type: 'in' }, # in|out
- )
- returns
- {
- count: 123,
- ticket_ids: [4,5,1,5,0,51,5,56,7,4],
- assets: assets,
- }
- =end
- def self.items(params)
- selector = params[:selector]['ticket.group_id']
- if !selector
- return {
- count: 0,
- ticket_ids: [],
- }
- end
- local_params = group_attributes(selector, params)
- without_merged_tickets = {
- 'ticket_state.name' => {
- 'operator' => 'is not',
- 'value' => 'merged'
- }
- }
- local_selector = params[:selector].merge!(without_merged_tickets) # do not show merged tickets in reports
- if params[:params][:type] == 'out'
- local_selector.delete('ticket.group_id')
- end
- defaults = {
- object: 'Ticket',
- type: 'updated',
- attribute: 'group',
- start: params[:range_start],
- end: params[:range_end],
- selector: local_selector
- }
- local_params = defaults.merge(local_params)
- result = history(local_params)
- return result if params[:sheet].present?
- assets = {}
- result[:ticket_ids].each do |ticket_id|
- ticket_full = Ticket.find(ticket_id)
- assets = ticket_full.assets(assets)
- end
- result[:assets] = assets
- result
- end
- def self.group_attributes(selector, params)
- group_id = selector['value']
- case selector['operator']
- when 'is'
- if params[:params][:type] == 'in'
- return {
- id_not_from: group_id,
- id_to: group_id,
- }
- else
- return {
- id_from: group_id,
- id_not_to: group_id,
- }
- end
- when 'is not'
- if params[:params][:type] == 'in'
- return {
- id_from: group_id,
- id_not_to: group_id,
- }
- else
- return {
- id_not_from: group_id,
- id_to: group_id,
- }
- end
- end
- raise "Unknown selector params '#{selector.inspect}'"
- end
- end
|