工作流修改
This commit is contained in:
parent
465d3cc6e9
commit
1f0fb52513
|
@ -68,7 +68,7 @@ class State(CommonAModel):
|
||||||
STATE_FIELD_READONLY= 1 # 字段只读
|
STATE_FIELD_READONLY= 1 # 字段只读
|
||||||
STATE_FIELD_REQUIRED = 2 # 字段必填
|
STATE_FIELD_REQUIRED = 2 # 字段必填
|
||||||
STATE_FIELD_OPTIONAL = 3 # 字段可选
|
STATE_FIELD_OPTIONAL = 3 # 字段可选
|
||||||
|
STATE_FIELD_HIDDEN = 4 # 字段隐藏
|
||||||
state_filter_choices=(
|
state_filter_choices=(
|
||||||
(0, '无'),
|
(0, '无'),
|
||||||
(1, '和工单同属一及上级部门'),
|
(1, '和工单同属一及上级部门'),
|
||||||
|
@ -83,7 +83,7 @@ class State(CommonAModel):
|
||||||
enable_retreat = models.BooleanField('允许撤回', default=False, help_text='开启后允许工单创建人在此状态直接撤回工单到初始状态')
|
enable_retreat = models.BooleanField('允许撤回', default=False, help_text='开启后允许工单创建人在此状态直接撤回工单到初始状态')
|
||||||
participant_type = models.IntegerField('参与者类型', choices=state_participanttype_choices, default=1, blank=True, help_text='0.无处理人,1.个人,2.多人,3.部门,4.角色,5.变量(支持工单创建人,创建人的leader),6.脚本,7.工单的字段内容(如表单中的"测试负责人",需要为用户名或者逗号隔开的多个用户名),8.父工单的字段内容。 初始状态请选择类型5,参与人填create_by')
|
participant_type = models.IntegerField('参与者类型', choices=state_participanttype_choices, default=1, blank=True, help_text='0.无处理人,1.个人,2.多人,3.部门,4.角色,5.变量(支持工单创建人,创建人的leader),6.脚本,7.工单的字段内容(如表单中的"测试负责人",需要为用户名或者逗号隔开的多个用户名),8.父工单的字段内容。 初始状态请选择类型5,参与人填create_by')
|
||||||
participant = models.JSONField('参与者', default=list, blank=True, help_text='可以为空(无处理人的情况,如结束状态)、userid、userid列表\部门id\角色id\变量(create_by,create_by_tl)\脚本记录的id等,包含子工作流的需要设置处理人为loonrobot')
|
participant = models.JSONField('参与者', default=list, blank=True, help_text='可以为空(无处理人的情况,如结束状态)、userid、userid列表\部门id\角色id\变量(create_by,create_by_tl)\脚本记录的id等,包含子工作流的需要设置处理人为loonrobot')
|
||||||
state_fields = models.JSONField('表单字段', default=dict, help_text='json格式字典存储,包括读写属性1:只读,2:必填,3:可选. 示例:{"create_time":1,"title":2, "sn":1}, 内置特殊字段participant_info.participant_name:当前处理人信息(部门名称、角色名称),state.state_name:当前状态的状态名,workflow.workflow_name:工作流名称') # json格式存储,包括读写属性1:只读,2:必填,3:可选,4:不显示, 字典的字典
|
state_fields = models.JSONField('表单字段', default=dict, help_text='json格式字典存储,包括读写属性1:只读,2:必填,3:可选, 4:隐藏 示例:{"create_time":1,"title":2, "sn":1}, 内置特殊字段participant_info.participant_name:当前处理人信息(部门名称、角色名称),state.state_name:当前状态的状态名,workflow.workflow_name:工作流名称') # json格式存储,包括读写属性1:只读,2:必填,3:可选,4:不显示, 字典的字典
|
||||||
distribute_type = models.IntegerField('分配方式', default=1, choices=state_distribute_choices, help_text='1.主动接单(如果当前处理人实际为多人的时候,需要先接单才能处理) 2.直接处理(即使当前处理人实际为多人,也可以直接处理) 3.随机分配(如果实际为多人,则系统会随机分配给其中一个人) 4.全部处理(要求所有参与人都要处理一遍,才能进入下一步)')
|
distribute_type = models.IntegerField('分配方式', default=1, choices=state_distribute_choices, help_text='1.主动接单(如果当前处理人实际为多人的时候,需要先接单才能处理) 2.直接处理(即使当前处理人实际为多人,也可以直接处理) 3.随机分配(如果实际为多人,则系统会随机分配给其中一个人) 4.全部处理(要求所有参与人都要处理一遍,才能进入下一步)')
|
||||||
filter_policy = models.IntegerField('参与人过滤策略', default=0, choices=state_filter_choices)
|
filter_policy = models.IntegerField('参与人过滤策略', default=0, choices=state_filter_choices)
|
||||||
participant_cc = models.JSONField('抄送给', default=list, blank=True, help_text='抄送给(userid列表)')
|
participant_cc = models.JSONField('抄送给', default=list, blank=True, help_text='抄送给(userid列表)')
|
||||||
|
|
|
@ -77,6 +77,11 @@ class WorkflowViewSet(CreateUpdateModelAMixin, ModelViewSet):
|
||||||
ret['workflow'] = pk
|
ret['workflow'] = pk
|
||||||
ret['transitions'] = TransitionSerializer(instance=transitions, many=True).data
|
ret['transitions'] = TransitionSerializer(instance=transitions, many=True).data
|
||||||
field_list = CustomFieldSerializer(instance=WfService.get_workflow_custom_fields(wf), many=True).data
|
field_list = CustomFieldSerializer(instance=WfService.get_workflow_custom_fields(wf), many=True).data
|
||||||
|
for i in field_list:
|
||||||
|
if i['field_key'] in start_state.state_fields:
|
||||||
|
i['field_attribute'] = start_state.state_fields[i['field_key']]
|
||||||
|
else:
|
||||||
|
i['field_attribute'] = State.STATE_FIELD_READONLY
|
||||||
ret['field_list'] = field_list
|
ret['field_list'] = field_list
|
||||||
return Response(ret)
|
return Response(ret)
|
||||||
|
|
||||||
|
@ -150,11 +155,16 @@ class TicketViewSet(OptimizationMixin, CreateUpdateCustomMixin, CreateModelMixin
|
||||||
raise APIException('字段{}必填'.format(key))
|
raise APIException('字段{}必填'.format(key))
|
||||||
save_ticket_data = {}
|
save_ticket_data = {}
|
||||||
# 只保存必填项以及可选项
|
# 只保存必填项以及可选项
|
||||||
for key, vlaue in ticket_data:
|
for key, value in ticket_data.items():
|
||||||
if key in field_key_list and key in start_state.state_fields and start_state.state_fields[key] in [
|
if key in field_key_list and key in start_state.state_fields and start_state.state_fields[key] in [
|
||||||
State.STATE_FIELD_REQUIRED, State.STATE_FIELD_OPTIONAL]:
|
State.STATE_FIELD_REQUIRED, State.STATE_FIELD_OPTIONAL]:
|
||||||
save_ticket_data[key] = value
|
save_ticket_data[key] = value
|
||||||
ticket = serializer.save(state=start_state, create_by=request.user, act_state=Ticket.TICKET_ACT_STATE_DRAFT, belong_dept=request.user.dept) # 先创建出来
|
|
||||||
|
ticket = serializer.save(state=start_state,
|
||||||
|
create_by=request.user,
|
||||||
|
act_state=Ticket.TICKET_ACT_STATE_DRAFT,
|
||||||
|
belong_dept=request.user.dept,
|
||||||
|
ticket_data=save_ticket_data) # 先创建出来
|
||||||
|
|
||||||
next_state = WfService.get_next_state_by_transition_and_ticket_info(ticket=ticket, transition=transition)
|
next_state = WfService.get_next_state_by_transition_and_ticket_info(ticket=ticket, transition=transition)
|
||||||
participant_info = WfService.get_ticket_state_participant_info(state=next_state, ticket=ticket, ticket_data=ticket.ticket_data)
|
participant_info = WfService.get_ticket_state_participant_info(state=next_state, ticket=ticket, ticket_data=ticket.ticket_data)
|
||||||
|
|
Loading…
Reference in New Issue