trabajo-afectivo/app/models/ticket/overviews.rb

178 lines
4.8 KiB
Ruby
Raw Normal View History

2014-02-03 19:23:00 +00:00
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
module Ticket::Overviews
=begin
all overview by user
result = Ticket::Overviews.all(
:current_user => User.find(123),
)
returns
result = [overview1, overview2]
=end
def self.all (data)
# get customer overviews
if data[:current_user].role?('Customer')
role = Role.find_by( name: 'Customer' )
if data[:current_user].organization_id && data[:current_user].organization.shared
overviews = Overview.where( role_id: role.id, active: true )
else
overviews = Overview.where( role_id: role.id, organization_shared: false, active: true )
end
return overviews
2015-04-27 21:27:51 +00:00
end
# get agent overviews
return if !data[:current_user].role?( 'Agent' )
role = Role.find_by( name: 'Agent' )
Overview.where( role_id: role.id, active: true )
end
=begin
selected overview by user
result = Ticket::Overviews.list(
current_user: User.find(123),
view: 'some_view_url',
)
returns
result = {
tickets: tickets, # [ticket1, ticket2, ticket3]
tickets_count: tickets_count, # count of tickets
overview: overview_selected_raw, # overview attributes
}
=end
def self.list (data)
overviews = all(data)
return if !overviews
# build up attributes hash
overview_selected = nil
overview_selected_raw = nil
overviews.each { |overview|
# remember selected view
if data[:view] && data[:view] == overview.link
overview_selected = overview
overview_selected_raw = Marshal.load( Marshal.dump(overview.attributes) )
end
# replace e.g. 'current_user.id' with current_user.id
overview.condition.each { |attribute, content|
next if !content
next if !content.respond_to?(:key?)
next if !content['value']
next if content['value'].class != String && content['value'].class != Array
if content['value'].class == String
parts = content['value'].split( '.', 2 )
next if !parts[0]
next if !parts[1]
next if parts[0] != 'current_user'
overview.condition[attribute]['value'] = data[:current_user][parts[1].to_sym]
next
end
content['value'].each {|item|
next if item.class != String
parts = item.split('.', 2)
next if !parts[0]
next if !parts[1]
next if parts[0] != 'current_user'
item = data[:current_user][parts[1].to_sym]
}
}
}
if data[:view] && !overview_selected
fail "No such view '#{data[:view]}'"
end
# get only tickets with permissions
access_condition = Ticket.access_condition( data[:current_user] )
2015-04-27 21:27:51 +00:00
# overview meta for navbar
if !overview_selected
# loop each overview
result = []
overviews.each { |overview|
query_condition, bind_condition = Ticket._selectors(overview.condition)
# get count
count = Ticket.where( access_condition ).where( query_condition, *bind_condition ).count()
# get meta info
all = {
name: overview.name,
prio: overview.prio,
link: overview.link,
2015-04-27 21:27:51 +00:00
}
# push to result data
result.push all.merge( { count: count } )
}
return result
end
# get result list
if data[:array]
order_by = overview_selected[:order][:by].to_s + ' ' + overview_selected[:order][:direction].to_s
if overview_selected.group_by && !overview_selected.group_by.empty?
order_by = overview_selected.group_by + '_id, ' + order_by
end
query_condition, bind_condition = Ticket._selectors(overview_selected.condition)
tickets = Ticket.select('id')
.where( access_condition )
.where( query_condition, *bind_condition )
.order( order_by )
.limit( 500 )
ticket_ids = []
tickets.each { |ticket|
ticket_ids.push ticket.id
}
tickets_count = Ticket.where( access_condition ).where( query_condition, *bind_condition ).count()
return {
ticket_ids: ticket_ids,
tickets_count: tickets_count,
overview: overview_selected_raw,
}
end
# get tickets for overview
data[:start_page] ||= 1
query_condition, bind_condition = Ticket._selectors(overview_selected.condition)
tickets = Ticket.where( access_condition )
.where( query_condition, *bind_condition )
.order( overview_selected[:order][:by].to_s + ' ' + overview_selected[:order][:direction].to_s )
tickets_count = Ticket.where( access_condition ).where( query_condition, *bind_condition ).count()
{
tickets: tickets,
tickets_count: tickets_count,
overview: overview_selected_raw,
}
end
2014-02-03 19:23:00 +00:00
end