trabajo-afectivo/lib/stats/ticket_load_measure.rb

66 lines
1.8 KiB
Ruby
Raw Normal View History

# Copyright (C) 2012-2021 Zammad Foundation, http://zammad-foundation.org/
2015-09-06 22:42:11 +00:00
class Stats::TicketLoadMeasure
def self.generate(user)
open_state_ids = Ticket::State.by_category(:open).pluck(:id)
2015-09-06 23:17:54 +00:00
2015-09-06 22:42:11 +00:00
# owned tickets
2015-09-06 23:17:54 +00:00
count = Ticket.where(owner_id: user.id, state_id: open_state_ids).count
2015-09-06 22:42:11 +00:00
# get total open
total = Ticket.where(group_id: user.group_ids_access('full'), state_id: open_state_ids).count
2015-09-06 22:42:11 +00:00
average = '-'
state = 'good'
2015-09-06 23:17:54 +00:00
load_measure_precent = 0
2015-09-06 22:42:11 +00:00
if count > total
total = count
end
2016-07-26 22:02:28 +00:00
if total.nonzero?
load_measure_precent = (count.to_f / (total.to_f / 100)).round(1)
2015-09-06 23:17:54 +00:00
end
2015-09-06 22:42:11 +00:00
{
used_for_average: load_measure_precent,
average_per_agent: average,
percent: load_measure_precent,
state: state,
own: count,
total: total,
2015-09-06 22:42:11 +00:00
}
end
def self.average_state(result, _user_id)
return result if !result.key?(:used_for_average)
if result[:total] < 1 || result[:average_per_agent].to_d == BigDecimal('0.0')
result[:state] = 'supergood'
return result
end
in_percent = (result[:used_for_average].to_f / (result[:average_per_agent].to_f / 100)).round(1)
result[:average_per_agent_in_percent] = in_percent
result[:state] = if in_percent >= 90
'supergood'
elsif in_percent >= 65
'good'
elsif in_percent >= 40
'ok'
elsif in_percent >= 20
'bad'
else
'superbad'
end
# convert result[:used_for_average] in percent to related total
result[:average_per_agent] = ((result[:total].to_f / 100) * result[:average_per_agent]).round(1)
result
end
2015-09-06 22:42:11 +00:00
end