123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- module Ticket::ScreenOptions
- =begin
- list attributes
- result = Ticket::ScreenOptions.attributes_to_change(
- ticket_id: 123,
- ticket: ticket_model,
- current_user: User.find(123),
- screen: 'create_middle',
- )
- or only with user
- result = Ticket::ScreenOptions.attributes_to_change(
- current_user: User.find(123),
- )
- returns
- result = {
- :form_meta => {
- :filter => {
- :state_id => [1, 2, 4, 7, 3],
- :priority_id => [2, 1, 3],
- :type_id => [10, 5],
- :group_id => [12]
- },
- },
- }
- =end
- def self.attributes_to_change(params)
- raise 'current_user param needed' if !params[:current_user]
- if params[:ticket].blank? && params[:ticket_id].present?
- params[:ticket] = Ticket.find(params[:ticket_id])
- end
- assets = {}
- filter = {}
- type_ids = []
- if params[:ticket]
- types = %w[note phone]
- if params[:ticket].group.email_address_id
- types.push 'email'
- end
- types.each do |type_name|
- type = Ticket::Article::Type.lookup(name: type_name)
- next if type.blank?
- type_ids.push type.id
- end
- end
- filter[:type_id] = type_ids
- # get group / user relations (for bulk actions)
- dependencies = nil
- if params[:view] == 'ticket_overview'
- dependencies = { group_id: { '' => { owner_id: [] } } }
- groups = params[:current_user].groups_access(%w[create])
- agents = {}
- agent_role_ids = Role.with_permissions('ticket.agent').pluck(:id)
- agent_user_ids = User.joins(:roles).where(users: { active: true }).where('roles_users.role_id' => agent_role_ids).pluck(:id)
- groups.each do |group|
- assets = group.assets(assets)
- dependencies[:group_id][group.id] = { owner_id: [] }
- group_agent_user_ids = User.joins(', groups_users').where("users.id = groups_users.user_id AND groups_users.access = 'full' AND groups_users.group_id = ? AND users.id IN (?)", group.id, agent_user_ids).pluck(:id)
- group_agent_roles_ids = Role.joins(', roles_groups').where("roles.id = roles_groups.role_id AND roles_groups.access = 'full' AND roles_groups.group_id = ? AND roles.id IN (?)", group.id, agent_role_ids).pluck(:id)
- group_agent_role_user_ids = User.joins(:roles).where(roles: { id: group_agent_roles_ids }).pluck(:id)
- User.where(id: group_agent_user_ids.concat(group_agent_role_user_ids).uniq, active: true).pluck(:id).each do |user_id|
- dependencies[:group_id][group.id][:owner_id].push user_id
- next if agents[user_id]
- agents[user_id] = true
- next if assets[:User] && assets[:User][user_id]
- user = User.lookup(id: user_id)
- next if !user
- assets = user.assets(assets)
- end
- end
- end
- configure_attributes = nil
- if params[:ticket].present?
- configure_attributes = ObjectManager::Object.new('Ticket').attributes(params[:current_user], params[:ticket])
- end
- core_workflow = CoreWorkflow.perform(payload: {
- 'event' => 'core_workflow',
- 'request_id' => 'default',
- 'class_name' => 'Ticket',
- 'screen' => params[:screen],
- 'params' => Hash(params[:ticket]&.attributes)
- }, user: params[:current_user], assets: assets, assets_in_result: false)
- {
- assets: assets,
- form_meta: {
- filter: filter,
- dependencies: dependencies,
- configure_attributes: configure_attributes,
- core_workflow: core_workflow
- }
- }
- end
- =begin
- list tickets by customer group in state categories open and closed
- result = Ticket::ScreenOptions.list_by_customer(
- customer_id: 123,
- limit: 15, # optional, default 15
- )
- returns
- result = {
- ticket_ids_open: tickets_open,
- ticket_ids_closed: tickets_closed,
- assets: { ...list of assets... },
- }
- =end
- def self.list_by_customer(data)
- base_query = TicketPolicy::ReadScope.new(data[:current_user]).resolve
- .joins(state: :state_type)
- .where(customer_id: data[:customer_id])
- .limit(data[:limit] || 15)
- .reorder(created_at: :desc)
- open_tickets = base_query.where(ticket_state_types: { name: Ticket::StateType.names_in_category(:open) })
- closed_tickets = base_query.where(ticket_state_types: { name: Ticket::StateType.names_in_category(:closed) })
- {
- ticket_ids_open: open_tickets.map(&:id),
- ticket_ids_closed: closed_tickets.map(&:id),
- assets: (open_tickets | closed_tickets).reduce({}) { |hash, ticket| ticket.assets(hash) },
- }
- end
- end
|