123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- import json
- from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage
- from django.db.models import Q
- from apps.workflow.models import CustomField
- from service.base_service import BaseService
- from service.common.log_service import auto_log
- class WorkflowCustomFieldService(BaseService):
- def __init__(self):
- pass
- @classmethod
- @auto_log
- def get_workflow_custom_field(cls, workflow_id: int):
- """
- 获取工作流的自定义字段信息
- update workflow custom field
- :param workflow_id:
- :return:
- """
- custom_field_queryset = CustomField.objects.filter(workflow_id=workflow_id).all()
- format_custom_field_dict = {}
- for custom_field in custom_field_queryset:
- if custom_field.label:
- label = custom_field.label
- else:
- label = '{}'
- format_custom_field_dict[custom_field.field_key] = dict(
- workflow_id=custom_field.workflow_id, field_type_id=custom_field.field_type_id,
- field_name=custom_field.field_name,order_id=custom_field.order_id,
- default_value=custom_field.default_value, description=custom_field.description,
- field_template=custom_field.field_template, boolean_field_display=custom_field.boolean_field_display,
- field_choice=custom_field.field_choice, placeholder=custom_field.placeholder, label=label)
- return True, format_custom_field_dict
- @classmethod
- @auto_log
- def get_workflow_custom_field_name_list(cls, workflow_id: int):
- """
- 获取工作流自定义字段
- get workflow custom field, field_key list
- :param workflow_id:
- :return:
- """
- custom_field_queryset = CustomField.objects.filter(workflow_id=workflow_id).all()
- return True, dict(
- ticket_custom_field_key_list=[custom_field.field_key for custom_field in custom_field_queryset])
- @classmethod
- @auto_log
- def get_workflow_custom_field_list(cls, workflow_id: int, query_value: str, page: int, per_page: int):
- """
- 获取工作流自定义字段的列表
- get workflow custom field restful info list
- :param workflow_id:
- :param query_value:
- :param page:
- :param per_page:
- :return:
- """
- query_params = Q(is_deleted=False, workflow_id=workflow_id)
- if query_value:
- query_params &= Q(field_key__contains=query_value) | Q(description__contains=query_value) \
- | Q(field_name__contains=query_value)
- workflow_custom_field_queryset = CustomField.objects.filter(query_params).order_by('id')
- paginator = Paginator(workflow_custom_field_queryset, per_page)
- try:
- workflow_custom_field_result_paginator = paginator.page(page)
- except PageNotAnInteger:
- workflow_custom_field_result_paginator = paginator.page(1)
- except EmptyPage:
- # If page is out of range (e.g. 9999), deliver last page of results
- workflow_custom_field_result_paginator = paginator.page(paginator.num_pages)
- workflow_custom_field_result_list = workflow_custom_field_result_paginator.object_list
- workflow_custom_field_result_restful_list = []
- for workflow_custom_field_result_object in workflow_custom_field_result_list:
- custom_field_dict = workflow_custom_field_result_object.get_dict()
- custom_field_dict['boolean_field_display'] = json.loads(custom_field_dict['boolean_field_display'])
- custom_field_dict['field_choice'] = json.loads(custom_field_dict['field_choice'])
- custom_field_dict['label'] = json.loads(custom_field_dict['label']) if custom_field_dict['label'] else {}
- workflow_custom_field_result_restful_list.append(custom_field_dict)
- return True, dict(workflow_custom_field_result_restful_list=workflow_custom_field_result_restful_list,
- paginator_info=dict(per_page=per_page, page=page, total=paginator.count))
- @classmethod
- @auto_log
- def add_record(cls, workflow_id: int, field_type_id: int, field_key: str, field_name: str, order_id: int, default_value: str, description: str, field_template: str,
- boolean_field_display: str, field_choice: str, label: str, creator: str):
- """
- 新增自定义字段记录
- add workflow custom field record
- :param workflow_id:
- :param field_type_id:
- :param field_key:
- :param field_name:
- :param order_id:
- :param default_value:
- :param description:
- :param field_template:
- :param boolean_field_display:
- :param field_choice:
- :param label:
- :param creator:
- :return:
- """
- custom_field_obj = CustomField(workflow_id=workflow_id, field_type_id=field_type_id, field_key=field_key,
- field_name=field_name, order_id=order_id, default_value=default_value,
- description=description, field_template=field_template,
- boolean_field_display=boolean_field_display,
- field_choice=field_choice, label=label, creator=creator)
- custom_field_obj.save()
- return True, dict(custom_field_id=custom_field_obj.id)
- @classmethod
- @auto_log
- def edit_record(cls, custom_field_id: int, workflow_id: int, field_type_id: int, field_key: str, field_name: str,
- order_id: int, default_value: str, description: str, field_template: str,
- boolean_field_display: str, field_choice: str, label: str)->tuple:
- """
- 修改自定义字段记录
- update custom field record
- :param custom_field_id:
- :param workflow_id:
- :param field_type_id:
- :param field_key:
- :param field_name:
- :param order_id:
- :param default_value:
- :param description:
- :param field_template:
- :param boolean_field_display:
- :param field_choice:
- :param label:
- :param creator:
- :return:
- """
- custom_filed_queryset = CustomField.objects.filter(id=custom_field_id)
- if custom_filed_queryset:
- custom_filed_queryset.update(workflow_id=workflow_id, field_type_id=field_type_id, field_key=field_key,
- field_name=field_name, order_id=order_id, default_value=default_value,
- description=description, field_template=field_template,
- boolean_field_display=boolean_field_display,
- field_choice=field_choice, label=label)
- return True, ''
- @classmethod
- @auto_log
- def delete_record(cls, custom_field_id: int)->tuple:
- """
- 删除记录
- :param custom_field_id:
- :return:
- """
- custom_field_queryset = CustomField.objects.filter(id=custom_field_id)
- if custom_field_queryset:
- custom_field_queryset.update(is_deleted=True)
- return True, ''
- workflow_custom_field_service_ins = WorkflowCustomFieldService()
|