瀏覽代碼

reactor:353 市州通用-承办部门审批甄别申请时,增加“修改理由”等功能

zhangchong 1 月之前
父節點
當前提交
281be50628

+ 1 - 1
.env.development

@@ -3,7 +3,7 @@ VITE_MODE_NAME=development
 # 防止部署多套系统到同一域名不同目录时,变量共用的问题 设置不同的前缀
 VITE_STORAGE_NAME=dev
 # 业务系统基础请求地址
-VITE_API_URL=http://110.188.24.28:50300
+VITE_API_URL=http://110.188.24.28:50100
 # 业务系统socket请求地址
 VITE_API_SOCKET_URL=http://110.188.24.28:50100/hubs/hotline
 # 业务系统文件上传上传请求地址

+ 11 - 0
src/api/business/discern.ts

@@ -135,6 +135,17 @@ export const discernUpdate = (data: object) => {
 		data,
 	});
 }
+/**
+ * @description 甄别修改理由
+ * @param {object} data
+ */
+export const discernUpdateReason = (data: object) => {
+	return request({
+		url: `/api/v1/Order/order_screen_alter`,
+		method: 'put',
+		data,
+	});
+}
 /**
  * @description 甄别修改提起时限
  * @param {object} data

+ 177 - 0
src/views/business/discern/components/Discern-edit-reason.vue

@@ -0,0 +1,177 @@
+<template>
+	<el-dialog
+		v-model="state.dialogVisible"
+		draggable
+		title="甄别修改理由"
+		ref="dialogRef"
+		@mouseup="mouseup"
+		:style="'transform: ' + state.transform + ';'"
+		append-to-body
+		destroy-on-close
+		:close-on-click-modal="false"
+		@close="close"
+	>
+		<div v-loading="state.loading">
+			<el-form :model="state.discernForm" label-width="110px" ref="discernFormRef">
+				<el-row :gutter="10">
+					<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
+						<el-form-item label="工单编码"> {{ state.orderDetail.no }} </el-form-item>
+					</el-col>
+					<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
+						<el-form-item label="工单标题"> {{ state.orderDetail.order?.title }} </el-form-item>
+					</el-col>
+					<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
+						<el-form-item label="申请人"> {{ state.orderDetail.creatorName }} </el-form-item>
+					</el-col>
+					<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
+						<el-form-item label="申请部门"> {{ state.orderDetail.creatorOrgName }} </el-form-item>
+					</el-col>
+					<el-col>
+						<el-form-item label="申请时间"> {{ formatDate(state.orderDetail.creationTime, 'YYYY-mm-dd HH:MM:SS') }} </el-form-item>
+					</el-col>
+					<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
+						<el-form-item label="申请理由" prop="content" :rules="[{ required: true, message: '请填写甄别申请理由', trigger: 'blur' }]">
+							<common-advice
+								@chooseAdvice="chooseAdviceDiscern"
+								v-model="state.discernForm.content"
+								placeholder="请填写甄别申请理由"
+								:loading="state.loading"
+								:commonEnum="commonEnum.Discriminate"
+								:maxlength="AppConfigInfo.handleOpinionWordLimit"
+							/>
+						</el-form-item>
+					</el-col>
+					<!--					<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
+						<el-form-item label="附件">
+							<annex-list
+								name="甄别附件"
+								ref="discernAnnexListRef"
+								v-model:format="handleFilesDiscern"
+								:businessId="state.orderDetail.orderId"
+								v-model="state.discernForm.files"
+								classify="甄别上传"
+							/>
+						</el-form-item>
+					</el-col>-->
+				</el-row>
+			</el-form>
+		</div>
+
+		<template #footer>
+			<span class="dialog-footer">
+				<el-button @click="closeDialog" class="default-button">取 消</el-button>
+				<el-button type="primary" @click="onSubmit(discernFormRef)" :loading="state.loading">确定</el-button>
+			</span>
+		</template>
+	</el-dialog>
+</template>
+
+<script setup lang="ts">
+import { defineAsyncComponent, reactive, ref } from 'vue';
+import { ElMessage, FormInstance } from 'element-plus';
+import { commonEnum } from '@/utils/constants';
+import { discernUpdateReason, screenDetail } from '@/api/business/discern';
+import { transformFile } from '@/utils/tools';
+import { formatDate } from '@/utils/formatTime';
+import { useAppConfig } from '@/stores/appConfig';
+import { storeToRefs } from 'pinia';
+
+// 引入组件
+const CommonAdvice = defineAsyncComponent(() => import('@/components/CommonAdvice/index.vue')); // 常用意见
+const AnnexList = defineAsyncComponent(() => import('@/components/AnnexList/index.vue')); // 附件列表
+// 定义子组件向父组件传值/事件
+const emit = defineEmits(['orderProcessSuccess', 'orderProcessFailed']);
+// 定义变量内容
+const state = reactive<any>({
+	dialogVisible: false, // 弹窗显示隐藏
+	discernForm: {
+		//流程表单
+		content: '', // 甄别理由
+		id:null,// 甄别id
+		files:[],// 附件
+	},
+	nextStepOptions: [], // 下一节点
+	handlerOptions: [], // 办理对象
+	transform: 'translate(0px, 0px)', // 滚动条位置
+	loading: false, // 提交按钮loading
+	workflowId: '', // 流程id
+	handlerClassifies: [], //撤回办理对象
+	handleId: '', // 流程处理ID
+	annexName: '', // 附件标题
+	inputPlaceholder: '', // 意见提示
+	orderDetail: {}, // 工单详情
+});
+const appConfigStore = useAppConfig();
+const { AppConfigInfo } = storeToRefs(appConfigStore); // 系统配置信息
+// 打开弹窗
+const openDialog = async (val: any) => {
+	state.dialogVisible = true;
+	state.loading = true;
+	try {
+		const { result } = await screenDetail(val.id);
+		state.discernForm.id = val.id;
+		state.discernForm.content = result.content ?? {};
+		state.orderDetail = result;
+		state.discernForm.files = transformFile(result.files);
+	} finally {
+		state.loading = false;
+	}
+};
+const discernFormRef = ref<RefType>(); //甄别申请表单组件
+// 设置抽屉
+const dialogRef = ref<RefType>();
+const mouseup = () => {
+	state.transform = dialogRef.value.dialogContentRef.$el.style.transform;
+};
+// 关闭弹窗
+const closeDialog = () => {
+	state.dialogVisible = false;
+};
+// 重置表单方法
+const restForm = (formEl: FormInstance | undefined) => {
+	if (!formEl) return;
+	formEl.resetFields();
+	formEl.clearValidate();
+	state.discernForm.files = [];
+};
+// 选择常用意见 填入填写框 甄别
+const chooseAdviceDiscern = (item: any) => {
+	state.discernForm.content += item.content;
+};
+const afterSubmit = (emitType?: 'orderProcessSuccess' | 'orderProcessFailed', showMessage?: boolean, message?: string) => {
+	state.loading = false;
+	closeDialog();
+	const msg = message ?? '操作成功';
+	if (showMessage) ElMessage.success(msg);
+	if (emitType) emit(emitType);
+};
+const close = () => {
+	restForm(discernFormRef.value);
+};
+// 提交
+const handleFilesDiscern = ref<EmptyArrayType>([]); // 甄别附件
+const onSubmit = (formEl: FormInstance | undefined) => {
+	if (!formEl) return;
+	formEl.validate((valid: boolean) => {
+		if (!valid) return;
+		state.loading = true;
+		const request = {
+			screenId: state.discernForm.id,
+			content: state.discernForm.content,
+			files: handleFilesDiscern.value,
+		};
+		discernUpdateReason(request)
+			.then(() => {
+				afterSubmit('orderProcessSuccess', true, '甄别修改理由成功');
+			})
+			.catch(() => {
+				afterSubmit('orderProcessFailed');
+			});
+	});
+};
+// 暴露变量
+defineExpose({
+	openDialog,
+	closeDialog,
+});
+</script>

+ 10 - 1
src/views/business/discern/todo.vue

@@ -121,7 +121,7 @@
 					<vxe-column field="order.acceptType" title="受理类型" width="100"></vxe-column>
 					<vxe-column field="order.sourceChannel" title="来源渠道" width="110"></vxe-column>
 					<vxe-column field="order.hotspotName" title="热点分类" width="150"></vxe-column>
-					<vxe-column title="操作" fixed="right" width="180" align="center" :show-overflow="false" v-if="state.queryParams.TabStatus === 0">
+					<vxe-column title="操作" fixed="right" width="250" align="center" :show-overflow="false" v-if="state.queryParams.TabStatus === 0">
 						<template #default="{ row }">
 							<!--							<el-button link type="primary" @click="onDetail(row)" title="查看甄别详情"> 甄别详情 </el-button>-->
 							<el-button
@@ -145,6 +145,7 @@
 								退回
 							</el-button>
 							<el-button link type="primary" @click="visitDetail(row)" title="查看回访明细"> 回访明细 </el-button>
+							<el-button link type="primary" @click="onEdit(row)" v-auth="'business:discern:audit:edit'" title="修改理由"> 修改理由 </el-button>
 						</template>
 					</vxe-column>
 					<vxe-column title="操作" fixed="right" width="100" align="center" :show-overflow="false" v-else>
@@ -229,6 +230,8 @@
 		<discern-audit ref="discernAuditRef" @updateList="refreshList" />
 		<!-- 甄别退回 -->
 		<discern-return ref="discernReturnRef" @updateList="refreshList" />
+		<!-- 甄别修改理由 -->
+		<discern-edit-reason ref="discernEditReasonRef" @updateList="refreshList" />
 	</div>
 </template>
 <script setup lang="tsx" name="businessDiscernTodo">
@@ -250,6 +253,7 @@ const VisitDetailCom = defineAsyncComponent(() => import('@/views/business/visit
 const pagination = defineAsyncComponent(() => import('@/components/ProTable/components/Pagination.vue')); // 分页
 const DiscernAudit = defineAsyncComponent(() => import('@/views/business/discern/components/Discern-audit.vue')); // 甄别审批
 const DiscernReturn = defineAsyncComponent(() => import('@/views/business/discern/components/Discern-return.vue')); // 甄别退回
+const DiscernEditReason = defineAsyncComponent(() => import('@/views/business/discern/components/Discern-edit-reason.vue')); // 甄别修改理由
 // 定义变量内容
 const state = reactive<any>({
 	queryParams: {
@@ -363,6 +367,11 @@ const onDetail = async (row: any) => {
 		console.log(e);
 	}
 };
+// 甄别修改理由
+const discernEditReasonRef = ref<RefType>();
+const onEdit = (row: any) => {
+	discernEditReasonRef.value.openDialog(row);
+};
 // 查看回访明细
 const visitDetailRef = ref<RefType>();
 const visitDetail = (row: any) => {

+ 1 - 1
src/views/todo/seats/accept/Knowledge.vue

@@ -46,7 +46,7 @@
 				<div v-for="(v, i) in state.knowledgeList" :key="i" class="retrieval-content-item" @click="onPreview(v)">
 					<div class="mb10" style="display: flex">
 						<p class="text-no-wrap" style="flex: 1">{{ v.title }}</p>
-						<el-button type="primary" size="small" @click.stop="changeYYType(v)" v-if="['ZiGong'].includes(themeConfig.appScope)">{{
+						<el-button type="primary" size="small" @click.stop="changeYYType(v)" v-if="['ZiGong','YiBin'].includes(themeConfig.appScope)">{{
 							v.isChoose ? '取消引用' : '引用'
 						}}</el-button>
 					</div>

+ 6 - 1
src/views/todo/seats/accept/ybAccept.vue

@@ -482,7 +482,7 @@
 								<repeat-event ref="repeatEventRef" @orderAddRepeat="orderAddRepeat" :repeatIds="state.ruleForm.repeatableEventDetails" />
 							</el-tab-pane>
 							<el-tab-pane label="知识库" name="knowledge">
-								<Knowledge ref="knowledgeRef" :formData="state.ruleForm" />
+								<Knowledge ref="knowledgeRef" :formData="state.ruleForm" @changeYYType="changeYYType"/>
 							</el-tab-pane>
 						</el-tabs>
 					</el-card>
@@ -613,6 +613,7 @@ const state = reactive<any>({
 			dicDataValue: '10',
 			dicDataName: '咨询',
 		},
+		knowledgeQuote: [], // 知识库引用
 	},
 	formLoading: false, // 表单加载状态
 	hotspotExternal: [], // 热点分类外部数据
@@ -986,6 +987,10 @@ const canHandle = computed(() => {
 		return state.ruleForm?.canHandle;
 	}
 });
+// 知识库引用
+const changeYYType = (data: any) => {
+	state.ruleForm.knowledgeQuote = data;
+};
 const buttonLoading = ref<boolean>(false);
 const isSaveSuccess = ref<boolean>(false); // 是否保存成功 保存成功后才展示办理按钮
 // 保存