update 支持选择组
This commit is contained in:
parent
45c7bcd580
commit
6fe5a7db4d
@ -153,7 +153,7 @@
|
|||||||
</el-form>
|
</el-form>
|
||||||
<UserSelect ref="userSelectRef" :data="formData.candidateUsers" @confirm-call-back="userSelectCallBack"></UserSelect>
|
<UserSelect ref="userSelectRef" :data="formData.candidateUsers" @confirm-call-back="userSelectCallBack"></UserSelect>
|
||||||
<UserSelect ref="singleUserSelectRef" :data="formData.assignee" :multiple="false" @confirm-call-back="singleUserSelectCallBack"></UserSelect>
|
<UserSelect ref="singleUserSelectRef" :data="formData.assignee" :multiple="false" @confirm-call-back="singleUserSelectCallBack"></UserSelect>
|
||||||
<RoleSelect ref="roleSelectRef" v-model="formData.roles"></RoleSelect>
|
<RoleSelect ref="roleSelectRef" :data="formData.candidateGroups" @confirm-call-back="roleSelectCallBack"></RoleSelect>
|
||||||
<DueDate ref="dueDateRef" v-model="formData.dueDate"></DueDate>
|
<DueDate ref="dueDateRef" v-model="formData.dueDate"></DueDate>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -168,7 +168,7 @@ import { TaskPanel } from 'bpmnDesign';
|
|||||||
import { AllocationTypeEnum, MultipleUserAuditTypeEnum, SpecifyDescEnum } from '@/enums/bpmn/IndexEnums';
|
import { AllocationTypeEnum, MultipleUserAuditTypeEnum, SpecifyDescEnum } from '@/enums/bpmn/IndexEnums';
|
||||||
import { BellFilled, Checked, InfoFilled } from '@element-plus/icons-vue';
|
import { BellFilled, Checked, InfoFilled } from '@element-plus/icons-vue';
|
||||||
import { UserVO } from '@/api/system/user/types';
|
import { UserVO } from '@/api/system/user/types';
|
||||||
import useModelerStore from '@/store/modules/modeler';
|
import { RoleVO } from '@/api/system/role/types';
|
||||||
|
|
||||||
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
||||||
|
|
||||||
@ -176,7 +176,7 @@ interface PropType {
|
|||||||
element: Element;
|
element: Element;
|
||||||
}
|
}
|
||||||
const props = withDefaults(defineProps<PropType>(), {});
|
const props = withDefaults(defineProps<PropType>(), {});
|
||||||
const { modeling, showConfig, nameChange, idChange, updateProperties, getExtensionElements, createModdleElement } = usePanel({
|
const { showConfig, nameChange, idChange, updateProperties, getExtensionElements, createModdleElement } = usePanel({
|
||||||
element: toRaw(props.element)
|
element: toRaw(props.element)
|
||||||
});
|
});
|
||||||
const { parseData } = useParseElement({
|
const { parseData } = useParseElement({
|
||||||
@ -218,21 +218,25 @@ const openDueDate = () => {
|
|||||||
const singleUserSelectCallBack = (data: UserVO[]) => {
|
const singleUserSelectCallBack = (data: UserVO[]) => {
|
||||||
const user: UserVO = data.length !== 0 ? data[0] : undefined;
|
const user: UserVO = data.length !== 0 ? data[0] : undefined;
|
||||||
updateProperties({ 'flowable:assignee': user?.userId });
|
updateProperties({ 'flowable:assignee': user?.userId });
|
||||||
assignee.value = user;
|
assignee.value = user ? user : { userName: '' };
|
||||||
const extensionElements = getExtensionElements();
|
formData.value.assignee = String(user?.userId);
|
||||||
let extAssigneeElement = extensionElements.get('values').find((item) => item.$type === 'flowable:extAssignee');
|
let extensionElements = getExtensionElements();
|
||||||
if (!extAssigneeElement) {
|
extensionElements.values = extensionElements.get('values').filter((item) => item.$type !== 'flowable:extAssignee');
|
||||||
extAssigneeElement = createModdleElement('flowable:extAssignee', { body: '' }, extensionElements);
|
if (user) {
|
||||||
|
const extAssigneeElement = createModdleElement('flowable:extAssignee', { body: '' }, extensionElements);
|
||||||
extensionElements.get('values').push(extAssigneeElement);
|
extensionElements.get('values').push(extAssigneeElement);
|
||||||
|
extAssigneeElement.body = JSON.stringify({ userName: user.userName, userId: user.userId });
|
||||||
|
}
|
||||||
|
if (extensionElements.values.length === 0) {
|
||||||
|
extensionElements = undefined;
|
||||||
}
|
}
|
||||||
extAssigneeElement.body = JSON.stringify({ userName: user.userName, userId: user.userId });
|
|
||||||
updateProperties({ extensionElements: extensionElements });
|
updateProperties({ extensionElements: extensionElements });
|
||||||
};
|
};
|
||||||
const userSelectCallBack = (data: UserVO[]) => {
|
const userSelectCallBack = (data: UserVO[]) => {
|
||||||
let extensionElements = getExtensionElements();
|
let extensionElements = getExtensionElements();
|
||||||
extensionElements.values = extensionElements.values.filter((item) => item.$type !== 'flowable:extCandidateUsers');
|
extensionElements.values = extensionElements.values.filter((item) => item.$type !== 'flowable:extCandidateUsers');
|
||||||
if (data.length === 0) {
|
if (data.length === 0) {
|
||||||
formData.value.candidateUsers = '';
|
formData.value.candidateUsers = undefined;
|
||||||
updateProperties({ 'flowable:candidateUsers': undefined });
|
updateProperties({ 'flowable:candidateUsers': undefined });
|
||||||
} else {
|
} else {
|
||||||
const userIds = data.map((item) => item.userId).join(',');
|
const userIds = data.map((item) => item.userId).join(',');
|
||||||
@ -254,8 +258,22 @@ const userSelectCallBack = (data: UserVO[]) => {
|
|||||||
updateProperties({ extensionElements: extensionElements });
|
updateProperties({ extensionElements: extensionElements });
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const roleSelectCallBack = (data: RoleVO[]) => {
|
||||||
|
if (data.length === 0) {
|
||||||
|
formData.value.candidateGroups = '';
|
||||||
|
updateProperties({ 'flowable:candidateGroups': undefined });
|
||||||
|
} else {
|
||||||
|
const roleIds = data.map((item) => item.roleId).join(',');
|
||||||
|
formData.value.candidateGroups = roleIds;
|
||||||
|
updateProperties({ 'flowable:candidateGroups': roleIds });
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
const taskTabClick = (e) => {
|
const taskTabClick = (e) => {
|
||||||
formData.value.roles = [];
|
formData.value.candidateGroups = '';
|
||||||
|
formData.value.candidateUsers = '';
|
||||||
|
formData.value.assignee = '';
|
||||||
|
assignee.value = {};
|
||||||
};
|
};
|
||||||
|
|
||||||
const syncChange = (newVal) => {
|
const syncChange = (newVal) => {
|
||||||
@ -269,24 +287,12 @@ const selectUserLength = computed(() => {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
const selectRoleLength = computed(() => {
|
const selectRoleLength = computed(() => {
|
||||||
if (formData.value.roles) {
|
if (formData.value.candidateGroups) {
|
||||||
return formData.value.roles.length;
|
return formData.value.candidateGroups.split(',').length;
|
||||||
} else {
|
} else {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
watch(
|
|
||||||
() => formData.value.roles,
|
|
||||||
(newVal: Record<string, any>[]) => {
|
|
||||||
if (newVal?.length > 0) {
|
|
||||||
const roleIds = newVal.map((item) => item.roleId).join(',');
|
|
||||||
updateProperties({ 'flowable:candidateGroups': roleIds });
|
|
||||||
} else {
|
|
||||||
updateProperties({ 'flowable:candidateGroups': undefined });
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{ deep: true }
|
|
||||||
);
|
|
||||||
watch(
|
watch(
|
||||||
() => formData.value.async,
|
() => formData.value.async,
|
||||||
(newVal: boolean) => {
|
(newVal: boolean) => {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user