refactor: 使用Simple设计器的useFormFieldsPermission
parent
4bd020857f
commit
fe2ac97f9d
|
@ -175,10 +175,11 @@ import {
|
||||||
DEFAULT_BUTTON_SETTING,
|
DEFAULT_BUTTON_SETTING,
|
||||||
FieldPermissionType,
|
FieldPermissionType,
|
||||||
APPROVE_TYPE,
|
APPROVE_TYPE,
|
||||||
ApproveType
|
ApproveType,
|
||||||
|
ButtonSetting
|
||||||
} from '@/components/SimpleProcessDesignerV2/src/consts'
|
} from '@/components/SimpleProcessDesignerV2/src/consts'
|
||||||
import * as UserApi from '@/api/system/user'
|
import * as UserApi from '@/api/system/user'
|
||||||
import { cloneDeep } from 'lodash-es'
|
import { useFormFieldsPermission } from '@/components/SimpleProcessDesignerV2/src/node'
|
||||||
|
|
||||||
defineOptions({ name: 'ElementCustomConfig4UserTask' })
|
defineOptions({ name: 'ElementCustomConfig4UserTask' })
|
||||||
const props = defineProps({
|
const props = defineProps({
|
||||||
|
@ -206,8 +207,7 @@ const assignEmptyUserIds = ref()
|
||||||
|
|
||||||
// 操作按钮
|
// 操作按钮
|
||||||
const buttonsSettingEl = ref()
|
const buttonsSettingEl = ref()
|
||||||
const { buttonsSetting, btnDisplayNameEdit, changeBtnDisplayName, btnDisplayNameBlurEvent } =
|
const { btnDisplayNameEdit, changeBtnDisplayName, btnDisplayNameBlurEvent } = useButtonsSetting()
|
||||||
useButtonsSetting()
|
|
||||||
|
|
||||||
// 字段权限
|
// 字段权限
|
||||||
const fieldsPermissionEl = ref([])
|
const fieldsPermissionEl = ref([])
|
||||||
|
@ -300,6 +300,8 @@ const resetCustomConfigList = () => {
|
||||||
)
|
)
|
||||||
fieldsPermissionEl.value = []
|
fieldsPermissionEl.value = []
|
||||||
getNodeConfigFormFields()
|
getNodeConfigFormFields()
|
||||||
|
// 由于默认添加了发起人元素,这里需要删掉
|
||||||
|
fieldsPermissionConfig.value = fieldsPermissionConfig.value.slice(1)
|
||||||
fieldsPermissionConfig.value.forEach((element) => {
|
fieldsPermissionConfig.value.forEach((element) => {
|
||||||
element.permission =
|
element.permission =
|
||||||
fieldsPermissionList?.find((obj) => obj.field === element.field)?.permission ?? '1'
|
fieldsPermissionList?.find((obj) => obj.field === element.field)?.permission ?? '1'
|
||||||
|
@ -454,69 +456,6 @@ function useButtonsSetting() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// 表单字段权限设置
|
|
||||||
function useFormFieldsPermission(defaultPermission) {
|
|
||||||
// 字段权限配置. 需要有 field, title, permissioin 属性
|
|
||||||
const fieldsPermissionConfig = ref<Array<Record<string, string>>>([])
|
|
||||||
|
|
||||||
const formType = inject<Ref<number>>('formType') // 表单类型
|
|
||||||
|
|
||||||
const formFields = inject<Ref<string[]>>('formFields') // 流程表单字段
|
|
||||||
|
|
||||||
const getNodeConfigFormFields = (nodeFormFields?: Array<Record<string, string>>) => {
|
|
||||||
nodeFormFields = toRaw(nodeFormFields)
|
|
||||||
fieldsPermissionConfig.value =
|
|
||||||
cloneDeep(nodeFormFields) || getDefaultFieldsPermission(unref(formFields))
|
|
||||||
}
|
|
||||||
// 默认的表单权限: 获取表单的所有字段,设置字段默认权限为只读
|
|
||||||
const getDefaultFieldsPermission = (formFields?: string[]) => {
|
|
||||||
const defaultFieldsPermission: Array<Record<string, string>> = []
|
|
||||||
if (formFields) {
|
|
||||||
formFields.forEach((fieldStr: string) => {
|
|
||||||
parseFieldsSetDefaultPermission(JSON.parse(fieldStr), defaultFieldsPermission)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
return defaultFieldsPermission
|
|
||||||
}
|
|
||||||
// 解析字段。赋给默认权限
|
|
||||||
const parseFieldsSetDefaultPermission = (
|
|
||||||
rule: Record<string, any>,
|
|
||||||
fieldsPermission: Array<Record<string, string>>,
|
|
||||||
parentTitle: string = ''
|
|
||||||
) => {
|
|
||||||
const { /**type,*/ field, title: tempTitle, children } = rule
|
|
||||||
if (field && tempTitle) {
|
|
||||||
let title = tempTitle
|
|
||||||
if (parentTitle) {
|
|
||||||
title = `${parentTitle}.${tempTitle}`
|
|
||||||
}
|
|
||||||
fieldsPermission.push({
|
|
||||||
field,
|
|
||||||
title,
|
|
||||||
permission: defaultPermission
|
|
||||||
})
|
|
||||||
// TODO 子表单 需要处理子表单字段
|
|
||||||
// if (type === 'group' && rule.props?.rule && Array.isArray(rule.props.rule)) {
|
|
||||||
// // 解析子表单的字段
|
|
||||||
// rule.props.rule.forEach((item) => {
|
|
||||||
// parseFieldsSetDefaultPermission(item, fieldsPermission, title)
|
|
||||||
// })
|
|
||||||
// }
|
|
||||||
}
|
|
||||||
if (children && Array.isArray(children)) {
|
|
||||||
children.forEach((rule) => {
|
|
||||||
parseFieldsSetDefaultPermission(rule, fieldsPermission)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
formType,
|
|
||||||
fieldsPermissionConfig,
|
|
||||||
getNodeConfigFormFields
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const userOptions = ref<UserApi.UserVO[]>([]) // 用户列表
|
const userOptions = ref<UserApi.UserVO[]>([]) // 用户列表
|
||||||
onMounted(async () => {
|
onMounted(async () => {
|
||||||
// 获得用户列表
|
// 获得用户列表
|
||||||
|
|
Loading…
Reference in New Issue