mirror of
https://github.com/django-helpdesk/django-helpdesk.git
synced 2025-01-23 22:38:43 +01:00
Passing ticket status flow logic to Ticket model
This commit is contained in:
parent
6498126b87
commit
8b53ef9505
@ -471,6 +471,7 @@ class Ticket(models.Model):
|
|||||||
|
|
||||||
STATUS_CHOICES = helpdesk_settings.TICKET_STATUS_CHOICES
|
STATUS_CHOICES = helpdesk_settings.TICKET_STATUS_CHOICES
|
||||||
OPEN_STATUSES = helpdesk_settings.TICKET_OPEN_STATUSES
|
OPEN_STATUSES = helpdesk_settings.TICKET_OPEN_STATUSES
|
||||||
|
STATUS_CHOICES_FLOW = helpdesk_settings.TICKET_STATUS_CHOICES_FLOW
|
||||||
|
|
||||||
PRIORITY_CHOICES = helpdesk_settings.TICKET_PRIORITY_CHOICES
|
PRIORITY_CHOICES = helpdesk_settings.TICKET_PRIORITY_CHOICES
|
||||||
|
|
||||||
@ -710,6 +711,22 @@ class Ticket(models.Model):
|
|||||||
return u'%s%s%s' % (self.get_status_display(), held_msg, dep_msg)
|
return u'%s%s%s' % (self.get_status_display(), held_msg, dep_msg)
|
||||||
get_status = property(_get_status)
|
get_status = property(_get_status)
|
||||||
|
|
||||||
|
def _get_allowed_status_flow(self):
|
||||||
|
"""
|
||||||
|
Returns the list of allowed ticket status modifications for current state.
|
||||||
|
"""
|
||||||
|
status_id_list = self.STATUS_CHOICES_FLOW.get(self.status, ())
|
||||||
|
if status_id_list:
|
||||||
|
# keep defined statuses in order and add labels for display
|
||||||
|
status_dict = dict(helpdesk_settings.TICKET_STATUS_CHOICES)
|
||||||
|
new_statuses = [(status_id, status_dict.get(status_id, 1))
|
||||||
|
for status_id in status_id_list]
|
||||||
|
else:
|
||||||
|
# defaults to all choices if status was not mapped
|
||||||
|
new_statuses = helpdesk_settings.TICKET_STATUS_CHOICES
|
||||||
|
return new_statuses
|
||||||
|
get_allowed_status_flow = property(_get_allowed_status_flow)
|
||||||
|
|
||||||
def _get_ticket_url(self):
|
def _get_ticket_url(self):
|
||||||
"""
|
"""
|
||||||
Returns a publicly-viewable URL for this ticket, used when giving
|
Returns a publicly-viewable URL for this ticket, used when giving
|
||||||
|
@ -121,11 +121,24 @@ TICKET_STATUS_CHOICES = getattr(settings,
|
|||||||
'HELPDESK_TICKET_STATUS_CHOICES',
|
'HELPDESK_TICKET_STATUS_CHOICES',
|
||||||
DEFAULT_TICKET_STATUS_CHOICES)
|
DEFAULT_TICKET_STATUS_CHOICES)
|
||||||
|
|
||||||
|
# List of status choices considered as "open"
|
||||||
DEFAULT_TICKET_OPEN_STATUSES = (OPEN_STATUS, REOPENED_STATUS)
|
DEFAULT_TICKET_OPEN_STATUSES = (OPEN_STATUS, REOPENED_STATUS)
|
||||||
TICKET_OPEN_STATUSES = getattr(settings,
|
TICKET_OPEN_STATUSES = getattr(settings,
|
||||||
'HELPDESK_TICKET_OPEN_STATUSES',
|
'HELPDESK_TICKET_OPEN_STATUSES',
|
||||||
DEFAULT_TICKET_OPEN_STATUSES)
|
DEFAULT_TICKET_OPEN_STATUSES)
|
||||||
|
|
||||||
|
# New status list choices depending on current ticket status
|
||||||
|
DEFAULT_TICKET_STATUS_CHOICES_FLOW = {
|
||||||
|
OPEN_STATUS: (OPEN_STATUS, RESOLVED_STATUS, CLOSED_STATUS, DUPLICATE_STATUS,),
|
||||||
|
REOPENED_STATUS: (REOPENED_STATUS, RESOLVED_STATUS, CLOSED_STATUS, DUPLICATE_STATUS,),
|
||||||
|
RESOLVED_STATUS: (REOPENED_STATUS, RESOLVED_STATUS, CLOSED_STATUS,),
|
||||||
|
CLOSED_STATUS: (REOPENED_STATUS, CLOSED_STATUS,),
|
||||||
|
DUPLICATE_STATUS: (REOPENED_STATUS, DUPLICATE_STATUS,),
|
||||||
|
}
|
||||||
|
TICKET_STATUS_CHOICES_FLOW = getattr(settings,
|
||||||
|
'HELPDESK_TICKET_STATUS_CHOICES_FLOW',
|
||||||
|
DEFAULT_TICKET_STATUS_CHOICES_FLOW)
|
||||||
|
|
||||||
# Ticket priority choices
|
# Ticket priority choices
|
||||||
DEFAULT_TICKET_PRIORITY_CHOICES = (
|
DEFAULT_TICKET_PRIORITY_CHOICES = (
|
||||||
(1, _('1. Critical')),
|
(1, _('1. Critical')),
|
||||||
|
Loading…
Reference in New Issue
Block a user