From d743d35bfb2dede91ff4b310886ba42da30425f2 Mon Sep 17 00:00:00 2001
From: 王恒 <318726284@qq.com>
Date: 星期四, 28 八月 2025 17:31:23 +0800
Subject: [PATCH] '调整综合查一次列表'
---
src/views/system/manage/index.vue | 2070 +++++++++++++++++++++++++++++-----------------------------
1 files changed, 1,035 insertions(+), 1,035 deletions(-)
diff --git a/src/views/system/manage/index.vue b/src/views/system/manage/index.vue
index 9dbdca9..bd72862 100644
--- a/src/views/system/manage/index.vue
+++ b/src/views/system/manage/index.vue
@@ -1,1035 +1,1035 @@
-<template>
- <div class="app-container">
- <el-form
- :model="queryParams"
- ref="queryRef"
- class="evenly-distributed-labels"
- :inline="true"
- v-show="showSearch"
- label-width="80px"
- label-position="left"
- >
- <el-form-item label="浼佷笟鍚嶇О" prop="companyName">
- <el-input
- v-model="queryParams.companyName"
- placeholder="璇疯緭鍏ヤ紒涓氬悕绉�"
- clearable
- style="width: 200px"
- @keyup.enter="handleQuery"
- />
- </el-form-item>
- <el-form-item label="鍒跺畾鏈烘瀯">
- <el-tree-select
- v-model="queryParams.applyOrgId"
- :data="deptOptions"
- :props="{ value: 'id', label: 'label', children: 'children' }"
- value-key="id"
- placeholder="璇烽�夋嫨鍒跺畾璁″垝鐨勬満鏋�"
- check-strictly
- style="width: 200px"
- />
- </el-form-item>
- <el-form-item label="鎵ф硶鏃堕棿" style="width: 290px">
- <el-date-picker
- v-model="dateRange"
- type="months"
- format="YYYY-MM"
- value-format="YYYY-MM"
- placeholder="璇烽�夋嫨璁″垝鏈堜唤"
- @change="changeDateHandler"
- />
- </el-form-item>
- <el-form-item>
- <el-button type="primary" icon="Search" @click="handleQuery"
- >鎼滅储</el-button
- >
- <el-button icon="Refresh" @click="resetQuery">閲嶇疆</el-button>
- </el-form-item>
- </el-form>
-
- <el-row :gutter="10" class="mb8">
- <el-col :span="1.5">
- <el-button
- type="primary"
- plain
- icon="Plus"
- @click="handleAdd()"
- v-hasPermi="['system:dept:add']"
- >鏂板</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="warning"
- plain
- icon="Upload"
- @click="handleImport"
- v-hasPermi="['system:user:import']"
- >瀵煎叆</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button type="success" plain icon="Download" @click="downLoadCode"
- >瀵煎嚭</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button type="primary" plain icon="View" @click="downLoadCode"
- >鍙戣捣缁煎悎鏌ヤ竴娆�</el-button
- >
- </el-col>
- </el-row>
-
- <!-- @selection-change="handleSelectionChange" -->
- <el-table
- v-if="refreshTable"
- v-loading="loading"
- :data="deptList"
- row-key="companyId"
- :default-expand-all="isExpandAll"
- :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
- >
- <!-- <el-table-column type="selection" width="55" align="center" /> -->
- <el-table-column prop="planNo" label="搴忓彿" width="55">
- <template #default="scope">{{ scope.$index + 1 }}</template>
- </el-table-column>
- <el-table-column
- prop="orderNo"
- label="璁″垝缂栧彿"
- width="180"
- ></el-table-column>
- <el-table-column
- prop="enforceReason"
- label="璁″垝鍚嶇О"
- width="180"
- ></el-table-column>
- <el-table-column
- prop="applyOrgName"
- label="鍒跺畾鏈烘瀯"
- width="180"
- ></el-table-column>
- <el-table-column
- prop="companyName"
- label="琚鏌ュ璞�"
- width="180"
- ></el-table-column>
- <el-table-column
- prop="companyCode"
- label="缁熶竴绀句細淇$敤浠g爜"
- width="180"
- ></el-table-column>
- <el-table-column prop="industry" label="鎵�灞炶涓�" width="180">
- <template #default="scope">{{
- industryToText(scope.row.industry)
- }}</template>
- </el-table-column>
- <el-table-column prop="enforceType" label="妫�鏌ユ柟寮�" width="180">
- <template #default="scope">{{
- methodToText(scope.row.enforceType)
- }}</template>
- </el-table-column>
- <el-table-column
- prop="enforceContent"
- label="妫�鏌ュ唴瀹�"
- width="180"
- ></el-table-column>
- <el-table-column
- prop="applyDeptNames"
- label="鎵ц绉戝"
- width="180"
- ></el-table-column>
- <el-table-column prop="planFrequency" label="璁″垝棰戞" width="180">
- <template #default="scope">{{ frequencyToText(scope.row) }} </template>
- </el-table-column>
- <el-table-column
- prop="planMonth"
- label="璁″垝鏈堜唤"
- width="180"
- ></el-table-column>
- <el-table-column prop="orderStatus" label="鐘舵��" width="180">
- <template #default="scope">{{
- statusToText(scope.row.checkStatus)
- }}</template>
- </el-table-column>
- <el-table-column
- label="鎿嶄綔"
- align="center"
- fixed="right"
- class-name="small-padding fixed-width"
- width="180"
- >
- <template #default="scope">
- <el-link type="info" @click="handleView(scope.row)">鏌ョ湅</el-link>
- <el-divider direction="vertical" />
- <el-link type="primary" @click="handleAdd(scope.row)">缂栬緫</el-link>
- <el-divider direction="vertical" />
- <el-link type="error" @click="handleDelete(scope.row)">鍒犻櫎</el-link>
- </template>
- </el-table-column>
- </el-table>
- <pagination
- v-show="queryParams.total > 0"
- :total="queryParams.total"
- v-model:page="queryParams.pageNum"
- v-model:limit="queryParams.pageSize"
- @pagination="getList"
- />
-
- <!-- 娣诲姞鎴栦慨鏀瑰璇濇 -->
- <el-dialog
- :title="title"
- v-model="open"
- width="700px"
- @close="closeUpdHandler"
- append-to-body
- >
- <el-form ref="deptRef" :model="form" :rules="rules" label-width="140px">
- <el-row :gutter="20">
- <el-col :span="24">
- <el-form-item label="璁″垝鍚嶇О" prop="enforceReason">
- <el-input
- v-model="form.enforceReason"
- placeholder="璇疯緭鍏ヨ鍒掑悕绉�"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item label="鍒跺畾璁″垝鐨勬満鏋�" prop="applyOrgId">
- <el-tree-select
- v-model="form.applyOrgId"
- :data="deptOptions"
- :props="{ value: 'id', label: 'label', children: 'children' }"
- value-key="id"
- placeholder="璇烽�夋嫨鍒跺畾璁″垝鐨勬満鏋�"
- check-strictly
- :default-expanded-keys="[form.applyOrgId]"
- :default-checked-keys="[form.applyOrgId]"
- @node-click="changeTreeHandler"
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鎵ц绉戝" prop="applyDeptIds">
- <el-select
- v-model="selectOffices"
- multiple
- collapse-tags
- collapse-tags-tooltip
- :max-collapse-tags="1"
- placeholder="璇烽�夋嫨鎵ц绉戝"
- style="width: 100%"
- @change="handleSelectOffices"
- >
- <el-option
- v-for="(obj, index) in officeList"
- :key="index"
- :label="obj.deptName"
- :value="obj.deptId"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20" v-if="!form.orderId">
- <el-col :span="24">
- <el-form-item label="琚鏌ョ殑瀵硅薄" prop="checkdIds">
- <el-button type="primary" @click="openFirmSelect"
- >閫夋嫨浼佷笟</el-button
- >
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20" v-else>
- <el-col :span="12">
- <el-form-item label="琚鏌ュ璞�" prop="companyName">
- <el-input
- v-model="form.companyName"
- placeholder="璇疯緭鍏ヨ妫�鏌ュ璞�"
- readonly
- disabled
- />
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="缁熶竴绀句細淇$敤浠g爜" prop="companyCode">
- <el-input
- v-model="form.companyCode"
- placeholder="璇疯緭鍏ョ粺涓�绀句細淇$敤浠g爜"
- readonly
- disabled
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20" v-if="form.checkdIds">
- <el-col :span="24">
- <el-form-item label="琚鏌ュ璞′俊鎭�">
- <el-table
- :data="checkedList"
- max-height="200px"
- style="width: 100%"
- >
- <el-table-column prop="companyName" label="浼佷笟鍚嶇О" />
- <el-table-column prop="companyCode" label="缁熶竴绀句細淇$敤浠g爜" />
- </el-table>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item label="妫�鏌ユ柟寮�" prop="enforceType">
- <el-select
- v-model="form.enforceType"
- placeholder="璇烽�夋嫨妫�鏌ユ柟寮�"
- style="width: 100%"
- >
- <el-option
- v-for="(obj, index) in enforce_type"
- :key="index"
- :label="obj.label"
- :value="obj.value"
- />
- </el-select>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鎵�灞炶涓�" prop="industry">
- <el-select
- v-model="form.industry"
- placeholder="璇烽�夋嫨鎵�灞炶涓�"
- style="width: 100%"
- >
- <el-option
- v-for="(obj, index) in industry_type"
- :key="index"
- :label="obj.label"
- :value="obj.key"
- />
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="24">
- <el-form-item label="妫�鏌ュ唴瀹�" prop="enforceContent">
- <el-input
- v-model="form.enforceContent"
- type="textarea"
- placeholder="璇疯緭鍏ユ鏌ュ唴瀹�"
- />
- </el-form-item>
- </el-col>
- </el-row>
- <el-row :gutter="20">
- <el-col :span="12">
- <el-form-item label="璁″垝棰戞" prop="planFrequency">
- <el-input v-model="form.planFrequency" placeholder="璇疯緭鍏ラ娆�">
- <template #append>
- <el-select
- v-model="form.planFrequencyUnit"
- placeholder="鍗曚綅"
- style="width: 80px"
- >
- <el-option
- v-for="(obj, index) in frequency"
- :key="index"
- :label="obj.label"
- :value="obj.key"
- />
- </el-select> </template
- ></el-input>
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="璁″垝鏈堜唤" prop="planMonth">
- <el-date-picker
- v-model="selectMonth"
- type="months"
- format="YYYY-MM"
- value-format="YYYY-MM"
- placeholder="璇烽�夋嫨璁″垝鏈堜唤"
- @change="changeMonth"
- />
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- <template #footer>
- <div class="dialog-footer">
- <el-button type="primary" @click="submitForm">纭� 瀹�</el-button>
- <el-button @click="cancel">鍙� 娑�</el-button>
- </div>
- </template>
- </el-dialog>
-
- <!-- 璁″垝瀵煎叆瀵硅瘽妗� -->
- <el-dialog
- :title="upload.title"
- v-model="upload.open"
- width="400px"
- append-to-body
- >
- <el-upload
- ref="uploadRef"
- :limit="1"
- accept=".xlsx, .xls"
- :headers="upload.headers"
- :action="upload.url + '?updateSupport=' + upload.updateSupport"
- :disabled="upload.isUploading"
- :on-progress="handleFileUploadProgress"
- :on-success="handleFileSuccess"
- :auto-upload="false"
- drag
- >
- <el-icon class="el-icon--upload"><upload-filled /></el-icon>
- <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div>
- <template #tip>
- <div class="el-upload__tip text-center">
- <div class="el-upload__tip">
- <el-checkbox
- v-model="upload.updateSupport"
- />鏄惁鏇存柊宸茬粡瀛樺湪鐨勮鍒掓暟鎹�
- </div>
- <span>浠呭厑璁稿鍏ls銆亁lsx鏍煎紡鏂囦欢銆�</span>
- <el-link
- type="primary"
- :underline="false"
- style="font-size: 12px; vertical-align: baseline"
- @click="importTemplate"
- >涓嬭浇妯℃澘</el-link
- >
- </div>
- </template>
- </el-upload>
- <template #footer>
- <div class="dialog-footer">
- <el-button type="primary" @click="submitFileForm">纭� 瀹�</el-button>
- <el-button @click="upload.open = false">鍙� 娑�</el-button>
- </div>
- </template>
- </el-dialog>
-
- <!-- 璁″垝璇︾粏 -->
- <el-dialog title="璁″垝璇︽儏" v-model="planOpen" width="700px" append-to-body>
- <el-form label-width="140px">
- <el-row>
- <el-col :span="12">
- <el-form-item label="璁″垝缂栧彿锛�">{{
- planDetail.orderNo
- }}</el-form-item>
- <el-form-item label="璁″垝鍚嶇О锛�">{{
- planDetail.enforceReason
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鍒跺畾璁″垝鐨勬満鏋勶細">{{
- planDetail.applyOrgName
- }}</el-form-item>
- <el-form-item label="琚鏌ョ殑瀵硅薄锛�">{{
- planDetail.companyName
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="缁熶竴绀句細淇$敤浠g爜锛�">{{
- planDetail.companyCode
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鎵�灞炶涓氾細">{{
- industryToText(planDetail.industry)
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="妫�鏌ユ柟寮忥細">{{
- methodToText(planDetail.enforceType)
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鎵ц绉戝锛�">{{
- planDetail.applyDeptNames
- }}</el-form-item>
- </el-col>
- <el-col :span="24">
- <el-form-item label="妫�鏌ュ唴瀹癸細">{{
- planDetail.enforceContent
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="璁″垝鏈堜唤锛�">{{
- planDetail.planMonth
- }}</el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="璁″垝棰戞锛�">
- {{ frequencyToText(planDetail) }}
- </el-form-item>
- </el-col>
- <el-col :span="12">
- <el-form-item label="鐘舵�侊細">{{
- statusToText(planDetail.checkStatus)
- }}</el-form-item>
- </el-col>
- </el-row>
- </el-form>
- <template #footer>
- <div class="dialog-footer">
- <el-button
- @click="
- planOpen = false;
- planDetail = {};
- "
- >鍏� 闂�</el-button
- >
- </div>
- </template>
- </el-dialog>
-
- <!-- 閫夋嫨浼佷笟寮圭獥 -->
- <el-dialog
- title="閫夋嫨浼佷笟"
- v-model="selectOpen"
- width="700px"
- @close="closeSelect"
- append-to-body
- >
- <el-form label-width="120px">
- <el-row :gutter="10">
- <el-col :span="10">
- <el-form-item label="浼佷笟鍚嶇О锛�">
- <el-input
- v-model="firmQueryParams.companyName"
- placeholder="璇疯緭鍏ヤ紒涓氬悕绉�"
- />
- </el-form-item>
- </el-col>
- <el-col :span="10">
- <el-form-item label="绀句細淇$敤浠g爜锛�">
- <el-input
- v-model="firmQueryParams.companyCode"
- placeholder="璇疯緭鍏ョぞ浼氫俊鐢ㄤ唬鐮�"
- />
- </el-form-item>
- </el-col>
- <el-col :span="4">
- <el-button type="primary" @click="getFirmList">鎼滅储</el-button>
- </el-col>
- </el-row>
- </el-form>
- <el-table
- :data="firmList"
- row-key="companyId"
- height="400px"
- style="width: 100%"
- @selection-change="handleSelectionChange"
- >
- <el-table-column
- type="selection"
- width="55"
- :reserve-selection="false"
- />
- <el-table-column prop="companyName" label="浼佷笟鍚嶇О" />
- <el-table-column prop="companyCode" label="缁熶竴绀句細淇$敤浠g爜" />
- <el-table-column prop="companyUser" width="100px" label="鑱旂郴浜�" />
- <el-table-column prop="companyPhone" width="120px" label="鎵嬫満鍙�" />
- </el-table>
- <pagination
- v-show="firmQueryParams.total > 0"
- :total="firmQueryParams.total"
- v-model:page="firmQueryParams.pageNum"
- v-model:limit="firmQueryParams.pageSize"
- size="small"
- @pagination="getFirmList"
- />
- <template #footer>
- <div class="dialog-footer">
- <el-button type="primary" @click="closeSelect">纭� 瀹�</el-button>
- <el-button @click="closeSelect">鍏� 闂�</el-button>
- </div>
- </template>
- </el-dialog>
- </div>
-</template>
-
-<script setup name="Dept">
-import { getToken } from "@/utils/auth";
-import {
- listManage,
- addManage,
- getManage,
- updateManage,
- delManage,
- exportTemplate,
- exportManage,
- getOrgId,
-} from "@/api/system/manage";
-import { listCompany } from "@/api/system/company/company";
-import { deptTreeSelect } from "@/api/system/user";
-import { listDept } from "@/api/system/dept";
-// import { download } from '@/utils/request'; // 涓嬭浇鏂囦欢
-import { download as downloadHttp } from "@/utils/request";
-const { proxy } = getCurrentInstance();
-const { sys_normal_disable } = proxy.useDict("sys_normal_disable");
-const { frequency, industry_type, enforce_type } = proxy.useDictPer(
- "frequency",
- "industry_type",
- "enforce_type"
-);
-
-const statusOptions = ref([
- { label: "宸叉挙鍥�", value: -1 },
- { label: "寰呮彁浜�", value: 0 },
- { label: "宸叉彁浜�", value: 1 },
- { label: "宸插鎵瑰緟鎵ц", value: 2 },
- { label: "宸叉墽琛屽緟涓婃姤", value: 3 },
- { label: "宸蹭笂鎶�", value: 4 },
-]);
-const deptList = ref([]);
-const open = ref(false);
-const loading = ref(true);
-const showSearch = ref(true);
-const title = ref("");
-const isExpandAll = ref(false);
-const refreshTable = ref(true);
-const planOpen = ref(false);
-const planDetail = ref({});
-const dateRange = ref([]);
-const selectOpen = ref(false);
-const firmList = ref([]);
-const selectMonth = ref([]);
-const deptOptions = ref(undefined);
-const selectOffices = ref([]);
-const officeList = ref([]);
-let checkedList = ref([]); // 閫変腑鐨勪紒涓氬垪琛�
-const data = reactive({
- form: {
- enforceReason: "", // 璁″垝鍚嶇О
- applyOrgId: "", // 鍒跺畾鏈烘瀯id
- applyOrgName: "", // 鍒跺畾鏈烘瀯
- applyDeptIds: "", // 鎵ц绉戝
- applyDeptNames: "", // 鎵ц绉戝鍚嶇О
- companyName: "", // 琚鏌ュ璞�
- companyId: "", // 琚鏌ュ璞d
- companyCode: "", // 缁熶竴绀句細淇$敤浠g爜
- industry: "", // 鎵�灞炶涓�
- enforceType: "", // 妫�鏌ユ柟寮�
- enforceContent: "", // 妫�鏌ュ唴瀹�
- planFrequency: "", // 璁″垝棰戞
- planFrequencyUnit: "1", // 璁″垝棰戞鍗曚綅
- planMonth: "", // 璁″垝鏈堜唤
- },
- queryParams: {
- orderType: 1,
- companyName: "",
- enforceReason: "",
- applyOrgId: "",
- planMonthStart: "", // 璁″垝寮�濮嬫湀浠�
- planMonthEnd: "", // 璁″垝缁撴潫鏈堜唤
- pageNum: 1,
- pageSize: 10,
- total: 1,
- },
- rules: {
- orderNo: [{ required: true, message: "璁″垝缂栧彿涓嶈兘涓虹┖", trigger: "blur" }],
- enforceReason: [
- { required: true, message: "璁″垝鍚嶇О涓嶈兘涓虹┖", trigger: "blur" },
- ],
- applyOrgId: [
- { required: true, message: "鍒跺畾璁″垝鐨勬満鏋勪笉鑳戒负绌�", trigger: "blur" },
- ],
- checkdIds: [
- { required: true, message: "琚鏌ュ璞′笉鑳戒负绌�", trigger: "blur" },
- ],
- companyName: [
- { required: true, message: "浼佷笟鍚嶇О涓嶈兘涓虹┖", trigger: "blur" },
- ],
- companyCode: [
- { required: true, message: "缁熶竴绀句細淇$敤浠g爜涓嶈兘涓虹┖", trigger: "blur" },
- ],
- industry: [
- { required: true, message: "鎵�灞炶涓氫笉鑳戒负绌�", trigger: "blur" },
- ],
- enforceContent: [
- { required: true, message: "妫�鏌ュ唴瀹逛笉鑳戒负绌�", trigger: "blur" },
- ],
- applyDeptIds: [
- { required: true, message: "鎵ц绉戝涓嶈兘涓虹┖", trigger: "blur" },
- ],
- planFrequency: [
- { required: true, message: "璁″垝棰戞涓嶈兘涓虹┖", trigger: "blur" },
- ],
- planMonth: [
- { required: true, message: "璁″垝鏈堜唤涓嶈兘涓虹┖", trigger: "blur" },
- ],
- enforceType: [
- { required: true, message: "妫�鏌ユ柟寮忎笉鑳戒负绌�", trigger: "blur" },
- ],
- checkStatus: [{ required: true, message: "鐘舵�佷笉鑳戒负绌�", trigger: "blur" }],
- },
- firmQueryParams: {
- pageNum: 1,
- pageSize: 10,
- total: 1,
- companyName: "",
- companyCode: "",
- },
-});
-
-// 鑾峰彇绉戝鍒楄〃
-const getOfficeList = () => {
- listDept({
- pageNum: 1,
- pageSize: 1000,
- parentId: form.value.applyOrgId,
- }).then((response) => {
- officeList.value = response.data;
- });
-};
-
-// 鏈堜唤閫夋嫨
-const changeDateHandler = (value) => {
- data.queryParams.planMonth = value.join(",");
-};
-
-// 璁″垝鏈堜唤閫夋嫨
-const changeMonth = (value) => {
- form.value.planMonth = value.join(",");
-};
-
-// 鏈烘瀯閫夋嫨
-const changeTreeHandler = (e) => {
- form.value.applyOrgId = e.id;
- form.value.applyOrgName = e.label;
- selectOffices.value = [];
- form.value.applyDeptIds = "";
- form.value.applyDeptNames = "";
- if (e.id) {
- getOfficeList();
- }
-};
-
-// 绉戝閫夋嫨
-const handleSelectOffices = (value) => {
- form.value.applyDeptNames = value
- .map((item) => {
- return officeList.value.find((obj) => obj.deptId === item).deptName;
- })
- .join(",");
- form.value.applyDeptIds = value.join(",");
-};
-
-/*** 璁″垝瀵煎叆鍙傛暟 */
-const upload = reactive({
- // 鏄惁鏄剧ず寮瑰嚭灞傦紙鐢ㄦ埛瀵煎叆锛�
- open: false,
- // 寮瑰嚭灞傛爣棰橈紙鐢ㄦ埛瀵煎叆锛�
- title: "",
- // 鏄惁绂佺敤涓婁紶
- isUploading: false,
- // 鏄惁鏇存柊宸茬粡瀛樺湪鐨勭敤鎴锋暟鎹�
- updateSupport: 0,
- // 璁剧疆涓婁紶鐨勮姹傚ご閮�
- headers: { Authorization: "Bearer " + getToken() },
- // 涓婁紶鐨勫湴鍧�
- url: import.meta.env.VITE_APP_BASE_API + "/enforce/order/importData",
-});
-/**鏂囦欢涓婁紶涓鐞� */
-const handleFileUploadProgress = (event, file, fileList) => {
- upload.isUploading = true;
-};
-/** 鏂囦欢涓婁紶鎴愬姛澶勭悊 */
-const handleFileSuccess = (response, file, fileList) => {
- upload.open = false;
- upload.isUploading = false;
- proxy.$refs["uploadRef"].handleRemove(file);
- proxy.$alert(
- "<div style='overflow: auto;overflow-x: hidden;max-height: 70vh;padding: 10px 20px 0;'>" +
- response.msg +
- "</div>",
- "瀵煎叆缁撴灉",
- {
- dangerouslyUseHTMLString: true,
- }
- );
- getList();
-};
-const { queryParams, form, rules, firmQueryParams } = toRefs(data);
-
-/** 鏌ヨ閮ㄩ棬涓嬫媺鏍戠粨鏋� */
-function getDeptTree() {
- deptTreeSelect().then((response) => {
- deptOptions.value = response.data.map((obj) => {
- obj.children = obj.children.map((child) => {
- delete child.children;
- return child;
- });
- return obj;
- });
- });
-}
-getDeptTree();
-/** 鏌ヨ璁″垝鍒楄〃 */
-function getList() {
- loading.value = true;
- listManage(queryParams.value).then((response) => {
- deptList.value = response.rows;
- data.queryParams.total = response.total;
- loading.value = false;
- });
-}
-/** 鍙栨秷鎸夐挳 */
-function cancel() {
- open.value = false;
- reset();
- getList();
-}
-/** 琛ㄥ崟閲嶇疆 */
-function reset() {
- form.value = {
- enforceReason: "", // 璁″垝鍚嶇О
- applyOrgId: "", // 鍒跺畾鏈烘瀯id
- applyOrgName: "", // 鍒跺畾鏈烘瀯
- applyDeptIds: "", // 鎵ц绉戝id
- applyDeptNames: "", // 鎵ц绉戝鍚嶇О
- checkdIds: "", // 琚鏌ュ璞d
- companyName: "", // 琚鏌ュ璞″悕绉�
- companyCode: "", // 缁熶竴绀句細淇$敤浠g爜
- enforceType: "", // 妫�鏌ユ柟寮�
- industry: "", // 鎵�灞炶涓�
- enforceContent: "", // 妫�鏌ュ唴瀹�
- planFrequency: "", // 璁″垝棰戞
- planFrequencyUnit: "1", // 璁″垝棰戞鍗曚綅
- planMonth: "", // 璁″垝鏈堜唤
- orderType: 1,
- };
- selectOffices.value = [];
- selectMonth.value = [];
- checkedList.value = [];
- proxy.$refs["deptRef"].clearValidate();
- proxy.$refs["deptRef"].resetFields();
-}
-
-function closeUpdHandler() {
- reset();
- open.value = false;
-}
-
-const queryRef = ref();
-/** 鎼滅储鎸夐挳鎿嶄綔 */
-function handleQuery() {
- getList();
-}
-/** 閲嶇疆鎸夐挳鎿嶄綔 */
-function resetQuery() {
- queryRef.value.resetFields();
- dateRange.value = [];
- queryParams.value = {
- orderType: 1,
- companyName: "",
- enforceReason: "",
- applyOrgId: "",
- planMonthStart: "", // 璁″垝寮�濮嬫湀浠�
- planMonthEnd: "", // 璁″垝缁撴潫鏈堜唤
- pageNum: 1,
- pageSize: 10,
- total: 1,
- };
- handleQuery();
-}
-function getDetails(id) {
- getManage(id).then((response) => {
- form.value = JSON.parse(JSON.stringify(response.data));
- form.value.planFrequencyUnit = form.value.planFrequencyUnit.toString();
- form.value.enforceType = Number(form.value.enforceType);
- selectMonth.value = form.value.planMonth.split(",");
- selectOffices.value = form.value.applyDeptIds
- .split(",")
- .map((item) => Number(item));
-
- getOfficeList();
- open.value = true;
- });
-}
-
-/** 璇︾粏鎸夐挳鎿嶄綔 */
-function handleView(row) {
- planOpen.value = true;
- planDetail.value = row;
- planOpen.value = true;
-}
-
-/** 鏂板鎸夐挳鎿嶄綔 */
-function handleAdd(row) {
- if (row) {
- title.value = "缂栬緫璁″垝";
- getDetails(row.orderId);
- } else {
- title.value = "娣诲姞璁″垝";
- open.value = true;
- getUserOrgId();
- }
- getFirmList();
-}
-
-/** 鎻愪氦鎸夐挳 */
-function submitForm() {
- proxy.$refs["deptRef"].validate((valid) => {
- if (valid) {
- if (form.value.orderId != undefined) {
- updateManage(form.value).then((response) => {
- proxy.$modal.msgSuccess("淇敼鎴愬姛");
- open.value = false;
- getList();
- reset();
- });
- } else {
- checkedList.value.forEach((item, index) => {
- const submitForm = { ...form.value };
- submitForm.companyId = item.companyId;
- submitForm.companyName = item.companyName;
- submitForm.companyCode = item.companyCode;
- addManage(submitForm).then((response) => {
- if (index === checkedList.value.length - 1) {
- proxy.$modal.msgSuccess("鏂板鎴愬姛");
- open.value = false;
- getList();
- reset();
- }
- });
- });
- }
- }
- });
-}
-/** 鍒犻櫎鎸夐挳鎿嶄綔 */
-function handleDelete(row) {
- proxy.$modal
- .confirm("鏄惁纭鍒犻櫎璇ユ暟鎹�?")
- .then(function () {
- return delManage(row.orderId);
- })
- .then(() => {
- getList();
- proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
- })
- .catch(() => {});
-}
-
-/** 瀵煎叆鎸夐挳鎿嶄綔 */
-function handleImport() {
- upload.title = "璁″垝瀵煎叆";
- upload.open = true;
-}
-
-/** 鎻愪氦涓婁紶鏂囦欢 */
-function submitFileForm() {
- proxy.$refs["uploadRef"].submit();
-}
-
-/** 涓嬭浇妯℃澘鎿嶄綔 */
-function importTemplate() {
- exportTemplate().then((val) => {
- downloadHttp(
- "/tool/file/download",
- {
- fileName: val.msg,
- delete: true,
- },
- "璁″垝淇℃伅妯℃澘.xlsx"
- );
- });
-}
-
-function downLoadCode() {
- exportManage().then((val) => {
- downloadHttp(
- "/tool/file/download",
- {
- fileName: val.msg,
- delete: true,
- },
- "璁″垝淇℃伅.xlsx"
- );
- });
-}
-
-function openFirmSelect() {
- selectOpen.value = true;
-}
-
-/** 鏌ヨ浼佷笟鍒楄〃 */
-function getFirmList() {
- listCompany(firmQueryParams.value).then((response) => {
- firmList.value = response.rows;
- firmQueryParams.value.total = response.total;
- });
-}
-
-function handleSelectionChange(e) {
- checkedList.value = e;
- form.value.checkdIds = e.map((item) => item.companyId).join(",");
-}
-
-function closeSelect() {
- selectOpen.value = false;
-}
-
-function industryToText(industry) {
- return industry_type.value.find((item) => item.key == industry).label;
-}
-
-function methodToText(enforceType) {
- if (!enforceType) return "";
- return enforce_type.value.find((item) => item.value == enforceType).label;
-}
-
-function frequencyToText(data) {
- if (!data.planFrequencyUnit) {
- return "";
- }
- const unit = frequency.value.find(
- (item) => item.key == data.planFrequencyUnit
- ).label;
- return `${data.planFrequency}娆�/${unit}`;
-}
-
-function statusToText(status) {
- return statusOptions.value.find((item) => item.value == status).label;
-}
-
-function getUserOrgId() {
- getOrgId().then((response) => {
- form.value.applyOrgId = Number(response.data.orgId) || '';
- form.value.applyDeptIds = response.data.deptId || "";
- if(form.value.applyDeptIds){
- selectOffices.value = form.value.applyDeptIds
- .split(",")
- .map((item) => Number(item));
- }
- if (form.value.applyOrgId) {
- getOfficeList();
- }
- });
-}
-
-getList();
-function selectableFun(e) {}
-</script>
-
-<style scoped lang="scss">
-.evenly-distributed-labels {
- :deep() {
- .el-form-item__label {
- position: relative;
- /* 璁剧疆鐩稿瀹氫綅浣滀负鏄熷彿鐨勫畾浣嶅熀鍑� */
- text-align: justify;
- text-align-last: justify;
- /* 纭繚鏈�鍚庝竴琛屼篃涓ょ瀵归綈 */
- padding-left: 10px;
- /* 涓烘槦鍙烽鐣欑┖闂� */
- display: inline-block;
- }
- }
-}
-</style>
+<template>
+ <div class="app-container">
+ <el-form
+ :model="queryParams"
+ ref="queryRef"
+ class="evenly-distributed-labels"
+ :inline="true"
+ v-show="showSearch"
+ label-width="80px"
+ label-position="left"
+ >
+ <el-form-item label="浼佷笟鍚嶇О" prop="companyName">
+ <el-input
+ v-model="queryParams.companyName"
+ placeholder="璇疯緭鍏ヤ紒涓氬悕绉�"
+ clearable
+ style="width: 200px"
+ @keyup.enter="handleQuery"
+ />
+ </el-form-item>
+ <el-form-item label="鍒跺畾鏈烘瀯">
+ <el-tree-select
+ v-model="queryParams.applyOrgId"
+ :data="deptOptions"
+ :props="{ value: 'id', label: 'label', children: 'children' }"
+ value-key="id"
+ placeholder="璇烽�夋嫨鍒跺畾璁″垝鐨勬満鏋�"
+ check-strictly
+ style="width: 200px"
+ />
+ </el-form-item>
+ <el-form-item label="鎵ф硶鏃堕棿" style="width: 290px">
+ <el-date-picker
+ v-model="dateRange"
+ type="months"
+ format="YYYY-MM"
+ value-format="YYYY-MM"
+ placeholder="璇烽�夋嫨璁″垝鏈堜唤"
+ @change="changeDateHandler"
+ />
+ </el-form-item>
+ <el-form-item>
+ <el-button type="primary" icon="Search" @click="handleQuery"
+ >鎼滅储</el-button
+ >
+ <el-button icon="Refresh" @click="resetQuery">閲嶇疆</el-button>
+ </el-form-item>
+ </el-form>
+
+ <el-row :gutter="10" class="mb8">
+ <el-col :span="1.5">
+ <el-button
+ type="primary"
+ plain
+ icon="Plus"
+ @click="handleAdd()"
+ v-hasPermi="['system:dept:add']"
+ >鏂板</el-button
+ >
+ </el-col>
+ <el-col :span="1.5">
+ <el-button
+ type="warning"
+ plain
+ icon="Upload"
+ @click="handleImport"
+ v-hasPermi="['system:user:import']"
+ >瀵煎叆</el-button
+ >
+ </el-col>
+ <el-col :span="1.5">
+ <el-button type="success" plain icon="Download" @click="downLoadCode"
+ >瀵煎嚭</el-button
+ >
+ </el-col>
+ <el-col :span="1.5">
+ <el-button type="primary" plain icon="View" @click="downLoadCode"
+ >鍙戣捣缁煎悎鏌ヤ竴娆�</el-button
+ >
+ </el-col>
+ </el-row>
+
+ <!-- @selection-change="handleSelectionChange" -->
+ <el-table
+ v-if="refreshTable"
+ v-loading="loading"
+ :data="deptList"
+ row-key="companyId"
+ :default-expand-all="isExpandAll"
+ :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
+ >
+ <!-- <el-table-column type="selection" width="55" align="center" /> -->
+ <el-table-column prop="planNo" label="搴忓彿" width="55">
+ <template #default="scope">{{ scope.$index + 1 }}</template>
+ </el-table-column>
+ <el-table-column
+ prop="orderNo"
+ label="璁″垝缂栧彿"
+ width="180"
+ ></el-table-column>
+ <el-table-column
+ prop="enforceReason"
+ label="璁″垝鍚嶇О"
+ width="180"
+ ></el-table-column>
+ <el-table-column
+ prop="applyOrgName"
+ label="鍒跺畾鏈烘瀯"
+ width="180"
+ ></el-table-column>
+ <el-table-column
+ prop="companyName"
+ label="琚鏌ュ璞�"
+ width="180"
+ ></el-table-column>
+ <el-table-column
+ prop="companyCode"
+ label="缁熶竴绀句細淇$敤浠g爜"
+ width="180"
+ ></el-table-column>
+ <el-table-column prop="industry" label="鎵�灞炶涓�" width="180">
+ <template #default="scope">{{
+ industryToText(scope.row.industry)
+ }}</template>
+ </el-table-column>
+ <el-table-column prop="enforceType" label="妫�鏌ユ柟寮�" width="180">
+ <template #default="scope">{{
+ methodToText(scope.row.enforceType)
+ }}</template>
+ </el-table-column>
+ <el-table-column
+ prop="enforceContent"
+ label="妫�鏌ュ唴瀹�"
+ width="180"
+ ></el-table-column>
+ <el-table-column
+ prop="applyDeptNames"
+ label="鎵ц绉戝"
+ width="180"
+ ></el-table-column>
+ <el-table-column prop="planFrequency" label="璁″垝棰戞" width="180">
+ <template #default="scope">{{ frequencyToText(scope.row) }} </template>
+ </el-table-column>
+ <el-table-column
+ prop="planMonth"
+ label="璁″垝鏈堜唤"
+ width="180"
+ ></el-table-column>
+ <el-table-column prop="orderStatus" label="鐘舵��" width="180">
+ <template #default="scope">{{
+ statusToText(scope.row.checkStatus)
+ }}</template>
+ </el-table-column>
+ <el-table-column
+ label="鎿嶄綔"
+ align="center"
+ fixed="right"
+ class-name="small-padding fixed-width"
+ width="180"
+ >
+ <template #default="scope">
+ <el-link type="info" @click="handleView(scope.row)">鏌ョ湅</el-link>
+ <el-divider direction="vertical" />
+ <el-link type="primary" @click="handleAdd(scope.row)">缂栬緫</el-link>
+ <el-divider direction="vertical" />
+ <el-link type="error" @click="handleDelete(scope.row)">鍒犻櫎</el-link>
+ </template>
+ </el-table-column>
+ </el-table>
+ <pagination
+ v-show="queryParams.total > 0"
+ :total="queryParams.total"
+ v-model:page="queryParams.pageNum"
+ v-model:limit="queryParams.pageSize"
+ @pagination="getList"
+ />
+
+ <!-- 娣诲姞鎴栦慨鏀瑰璇濇 -->
+ <el-dialog
+ :title="title"
+ v-model="open"
+ width="700px"
+ @close="closeUpdHandler"
+ append-to-body
+ >
+ <el-form ref="deptRef" :model="form" :rules="rules" label-width="140px">
+ <el-row :gutter="20">
+ <el-col :span="24">
+ <el-form-item label="璁″垝鍚嶇О" prop="enforceReason">
+ <el-input
+ v-model="form.enforceReason"
+ placeholder="璇疯緭鍏ヨ鍒掑悕绉�"
+ />
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20">
+ <el-col :span="12">
+ <el-form-item label="鍒跺畾璁″垝鐨勬満鏋�" prop="applyOrgId">
+ <el-tree-select
+ v-model="form.applyOrgId"
+ :data="deptOptions"
+ :props="{ value: 'id', label: 'label', children: 'children' }"
+ value-key="id"
+ placeholder="璇烽�夋嫨鍒跺畾璁″垝鐨勬満鏋�"
+ check-strictly
+ :default-expanded-keys="[form.applyOrgId]"
+ :default-checked-keys="[form.applyOrgId]"
+ @node-click="changeTreeHandler"
+ />
+ </el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鎵ц绉戝" prop="applyDeptIds">
+ <el-select
+ v-model="selectOffices"
+ multiple
+ collapse-tags
+ collapse-tags-tooltip
+ :max-collapse-tags="1"
+ placeholder="璇烽�夋嫨鎵ц绉戝"
+ style="width: 100%"
+ @change="handleSelectOffices"
+ >
+ <el-option
+ v-for="(obj, index) in officeList"
+ :key="index"
+ :label="obj.deptName"
+ :value="obj.deptId"
+ />
+ </el-select>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20" v-if="!form.orderId">
+ <el-col :span="24">
+ <el-form-item label="琚鏌ョ殑瀵硅薄" prop="checkdIds">
+ <el-button type="primary" @click="openFirmSelect"
+ >閫夋嫨浼佷笟</el-button
+ >
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20" v-else>
+ <el-col :span="12">
+ <el-form-item label="琚鏌ュ璞�" prop="companyName">
+ <el-input
+ v-model="form.companyName"
+ placeholder="璇疯緭鍏ヨ妫�鏌ュ璞�"
+ readonly
+ disabled
+ />
+ </el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="缁熶竴绀句細淇$敤浠g爜" prop="companyCode">
+ <el-input
+ v-model="form.companyCode"
+ placeholder="璇疯緭鍏ョ粺涓�绀句細淇$敤浠g爜"
+ readonly
+ disabled
+ />
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20" v-if="form.checkdIds">
+ <el-col :span="24">
+ <el-form-item label="琚鏌ュ璞′俊鎭�">
+ <el-table
+ :data="checkedList"
+ max-height="200px"
+ style="width: 100%"
+ >
+ <el-table-column prop="companyName" label="浼佷笟鍚嶇О" />
+ <el-table-column prop="companyCode" label="缁熶竴绀句細淇$敤浠g爜" />
+ </el-table>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20">
+ <el-col :span="12">
+ <el-form-item label="妫�鏌ユ柟寮�" prop="enforceType">
+ <el-select
+ v-model="form.enforceType"
+ placeholder="璇烽�夋嫨妫�鏌ユ柟寮�"
+ style="width: 100%"
+ >
+ <el-option
+ v-for="(obj, index) in enforce_type"
+ :key="index"
+ :label="obj.label"
+ :value="obj.value"
+ />
+ </el-select>
+ </el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鎵�灞炶涓�" prop="industry">
+ <el-select
+ v-model="form.industry"
+ placeholder="璇烽�夋嫨鎵�灞炶涓�"
+ style="width: 100%"
+ >
+ <el-option
+ v-for="(obj, index) in industry_type"
+ :key="index"
+ :label="obj.label"
+ :value="obj.value"
+ />
+ </el-select>
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20">
+ <el-col :span="24">
+ <el-form-item label="妫�鏌ュ唴瀹�" prop="enforceContent">
+ <el-input
+ v-model="form.enforceContent"
+ type="textarea"
+ placeholder="璇疯緭鍏ユ鏌ュ唴瀹�"
+ />
+ </el-form-item>
+ </el-col>
+ </el-row>
+ <el-row :gutter="20">
+ <el-col :span="12">
+ <el-form-item label="璁″垝棰戞" prop="planFrequency">
+ <el-input v-model="form.planFrequency" placeholder="璇疯緭鍏ラ娆�">
+ <template #append>
+ <el-select
+ v-model="form.planFrequencyUnit"
+ placeholder="鍗曚綅"
+ style="width: 80px"
+ >
+ <el-option
+ v-for="(obj, index) in frequency"
+ :key="index"
+ :label="obj.label"
+ :value="obj.value"
+ />
+ </el-select> </template
+ ></el-input>
+ </el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="璁″垝鏈堜唤" prop="planMonth">
+ <el-date-picker
+ v-model="selectMonth"
+ type="months"
+ format="YYYY-MM"
+ value-format="YYYY-MM"
+ placeholder="璇烽�夋嫨璁″垝鏈堜唤"
+ @change="changeMonth"
+ />
+ </el-form-item>
+ </el-col>
+ </el-row>
+ </el-form>
+ <template #footer>
+ <div class="dialog-footer">
+ <el-button type="primary" @click="submitForm">纭� 瀹�</el-button>
+ <el-button @click="cancel">鍙� 娑�</el-button>
+ </div>
+ </template>
+ </el-dialog>
+
+ <!-- 璁″垝瀵煎叆瀵硅瘽妗� -->
+ <el-dialog
+ :title="upload.title"
+ v-model="upload.open"
+ width="400px"
+ append-to-body
+ >
+ <el-upload
+ ref="uploadRef"
+ :limit="1"
+ accept=".xlsx, .xls"
+ :headers="upload.headers"
+ :action="upload.url + '?updateSupport=' + upload.updateSupport"
+ :disabled="upload.isUploading"
+ :on-progress="handleFileUploadProgress"
+ :on-success="handleFileSuccess"
+ :auto-upload="false"
+ drag
+ >
+ <el-icon class="el-icon--upload"><upload-filled /></el-icon>
+ <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div>
+ <template #tip>
+ <div class="el-upload__tip text-center">
+ <div class="el-upload__tip">
+ <el-checkbox
+ v-model="upload.updateSupport"
+ />鏄惁鏇存柊宸茬粡瀛樺湪鐨勮鍒掓暟鎹�
+ </div>
+ <span>浠呭厑璁稿鍏ls銆亁lsx鏍煎紡鏂囦欢銆�</span>
+ <el-link
+ type="primary"
+ :underline="false"
+ style="font-size: 12px; vertical-align: baseline"
+ @click="importTemplate"
+ >涓嬭浇妯℃澘</el-link
+ >
+ </div>
+ </template>
+ </el-upload>
+ <template #footer>
+ <div class="dialog-footer">
+ <el-button type="primary" @click="submitFileForm">纭� 瀹�</el-button>
+ <el-button @click="upload.open = false">鍙� 娑�</el-button>
+ </div>
+ </template>
+ </el-dialog>
+
+ <!-- 璁″垝璇︾粏 -->
+ <el-dialog title="璁″垝璇︽儏" v-model="planOpen" width="700px" append-to-body>
+ <el-form label-width="140px">
+ <el-row>
+ <el-col :span="12">
+ <el-form-item label="璁″垝缂栧彿锛�">{{
+ planDetail.orderNo
+ }}</el-form-item>
+ <el-form-item label="璁″垝鍚嶇О锛�">{{
+ planDetail.enforceReason
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鍒跺畾璁″垝鐨勬満鏋勶細">{{
+ planDetail.applyOrgName
+ }}</el-form-item>
+ <el-form-item label="琚鏌ョ殑瀵硅薄锛�">{{
+ planDetail.companyName
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="缁熶竴绀句細淇$敤浠g爜锛�">{{
+ planDetail.companyCode
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鎵�灞炶涓氾細">{{
+ industryToText(planDetail.industry)
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="妫�鏌ユ柟寮忥細">{{
+ methodToText(planDetail.enforceType)
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鎵ц绉戝锛�">{{
+ planDetail.applyDeptNames
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="24">
+ <el-form-item label="妫�鏌ュ唴瀹癸細">{{
+ planDetail.enforceContent
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="璁″垝鏈堜唤锛�">{{
+ planDetail.planMonth
+ }}</el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="璁″垝棰戞锛�">
+ {{ frequencyToText(planDetail) }}
+ </el-form-item>
+ </el-col>
+ <el-col :span="12">
+ <el-form-item label="鐘舵�侊細">{{
+ statusToText(planDetail.checkStatus)
+ }}</el-form-item>
+ </el-col>
+ </el-row>
+ </el-form>
+ <template #footer>
+ <div class="dialog-footer">
+ <el-button
+ @click="
+ planOpen = false;
+ planDetail = {};
+ "
+ >鍏� 闂�</el-button
+ >
+ </div>
+ </template>
+ </el-dialog>
+
+ <!-- 閫夋嫨浼佷笟寮圭獥 -->
+ <el-dialog
+ title="閫夋嫨浼佷笟"
+ v-model="selectOpen"
+ width="700px"
+ @close="closeSelect"
+ append-to-body
+ >
+ <el-form label-width="120px">
+ <el-row :gutter="10">
+ <el-col :span="10">
+ <el-form-item label="浼佷笟鍚嶇О锛�">
+ <el-input
+ v-model="firmQueryParams.companyName"
+ placeholder="璇疯緭鍏ヤ紒涓氬悕绉�"
+ />
+ </el-form-item>
+ </el-col>
+ <el-col :span="10">
+ <el-form-item label="绀句細淇$敤浠g爜锛�">
+ <el-input
+ v-model="firmQueryParams.companyCode"
+ placeholder="璇疯緭鍏ョぞ浼氫俊鐢ㄤ唬鐮�"
+ />
+ </el-form-item>
+ </el-col>
+ <el-col :span="4">
+ <el-button type="primary" @click="getFirmList">鎼滅储</el-button>
+ </el-col>
+ </el-row>
+ </el-form>
+ <el-table
+ :data="firmList"
+ row-key="companyId"
+ height="400px"
+ style="width: 100%"
+ @selection-change="handleSelectionChange"
+ >
+ <el-table-column
+ type="selection"
+ width="55"
+ :reserve-selection="false"
+ />
+ <el-table-column prop="companyName" label="浼佷笟鍚嶇О" />
+ <el-table-column prop="companyCode" label="缁熶竴绀句細淇$敤浠g爜" />
+ <el-table-column prop="companyUser" width="100px" label="鑱旂郴浜�" />
+ <el-table-column prop="companyPhone" width="120px" label="鎵嬫満鍙�" />
+ </el-table>
+ <pagination
+ v-show="firmQueryParams.total > 0"
+ :total="firmQueryParams.total"
+ v-model:page="firmQueryParams.pageNum"
+ v-model:limit="firmQueryParams.pageSize"
+ size="small"
+ @pagination="getFirmList"
+ />
+ <template #footer>
+ <div class="dialog-footer">
+ <el-button type="primary" @click="closeSelect">纭� 瀹�</el-button>
+ <el-button @click="closeSelect">鍏� 闂�</el-button>
+ </div>
+ </template>
+ </el-dialog>
+ </div>
+</template>
+
+<script setup name="Dept">
+import { getToken } from "@/utils/auth";
+import {
+ listManage,
+ addManage,
+ getManage,
+ updateManage,
+ delManage,
+ exportTemplate,
+ exportManage,
+ getOrgId,
+} from "@/api/system/manage";
+import { listCompany } from "@/api/system/company/company";
+import { deptTreeSelect } from "@/api/system/user";
+import { listDept } from "@/api/system/dept";
+// import { download } from '@/utils/request'; // 涓嬭浇鏂囦欢
+import { download as downloadHttp } from "@/utils/request";
+const { proxy } = getCurrentInstance();
+const { sys_normal_disable } = proxy.useDict("sys_normal_disable");
+const { frequency, industry_type, enforce_type } = proxy.useDictPer(
+ "frequency",
+ "industry_type",
+ "enforce_type"
+);
+
+const statusOptions = ref([
+ { label: "宸叉挙鍥�", value: -1 },
+ { label: "寰呮彁浜�", value: 0 },
+ { label: "宸叉彁浜�", value: 1 },
+ { label: "宸插鎵瑰緟鎵ц", value: 2 },
+ { label: "宸叉墽琛屽緟涓婃姤", value: 3 },
+ { label: "宸蹭笂鎶�", value: 4 },
+]);
+const deptList = ref([]);
+const open = ref(false);
+const loading = ref(true);
+const showSearch = ref(true);
+const title = ref("");
+const isExpandAll = ref(false);
+const refreshTable = ref(true);
+const planOpen = ref(false);
+const planDetail = ref({});
+const dateRange = ref([]);
+const selectOpen = ref(false);
+const firmList = ref([]);
+const selectMonth = ref([]);
+const deptOptions = ref(undefined);
+const selectOffices = ref([]);
+const officeList = ref([]);
+let checkedList = ref([]); // 閫変腑鐨勪紒涓氬垪琛�
+const data = reactive({
+ form: {
+ enforceReason: "", // 璁″垝鍚嶇О
+ applyOrgId: "", // 鍒跺畾鏈烘瀯id
+ applyOrgName: "", // 鍒跺畾鏈烘瀯
+ applyDeptIds: "", // 鎵ц绉戝
+ applyDeptNames: "", // 鎵ц绉戝鍚嶇О
+ companyName: "", // 琚鏌ュ璞�
+ companyId: "", // 琚鏌ュ璞d
+ companyCode: "", // 缁熶竴绀句細淇$敤浠g爜
+ industry: "", // 鎵�灞炶涓�
+ enforceType: "", // 妫�鏌ユ柟寮�
+ enforceContent: "", // 妫�鏌ュ唴瀹�
+ planFrequency: "", // 璁″垝棰戞
+ planFrequencyUnit: 119, // 璁″垝棰戞鍗曚綅
+ planMonth: "", // 璁″垝鏈堜唤
+ },
+ queryParams: {
+ orderType: 1,
+ companyName: "",
+ enforceReason: "",
+ applyOrgId: "",
+ planMonthStart: "", // 璁″垝寮�濮嬫湀浠�
+ planMonthEnd: "", // 璁″垝缁撴潫鏈堜唤
+ pageNum: 1,
+ pageSize: 10,
+ total: 1,
+ },
+ rules: {
+ orderNo: [{ required: true, message: "璁″垝缂栧彿涓嶈兘涓虹┖", trigger: "blur" }],
+ enforceReason: [
+ { required: true, message: "璁″垝鍚嶇О涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ applyOrgId: [
+ { required: true, message: "鍒跺畾璁″垝鐨勬満鏋勪笉鑳戒负绌�", trigger: "blur" },
+ ],
+ checkdIds: [
+ { required: true, message: "琚鏌ュ璞′笉鑳戒负绌�", trigger: "blur" },
+ ],
+ companyName: [
+ { required: true, message: "浼佷笟鍚嶇О涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ companyCode: [
+ { required: true, message: "缁熶竴绀句細淇$敤浠g爜涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ industry: [
+ { required: true, message: "鎵�灞炶涓氫笉鑳戒负绌�", trigger: "blur" },
+ ],
+ enforceContent: [
+ { required: true, message: "妫�鏌ュ唴瀹逛笉鑳戒负绌�", trigger: "blur" },
+ ],
+ applyDeptIds: [
+ { required: true, message: "鎵ц绉戝涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ planFrequency: [
+ { required: true, message: "璁″垝棰戞涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ planMonth: [
+ { required: true, message: "璁″垝鏈堜唤涓嶈兘涓虹┖", trigger: "blur" },
+ ],
+ enforceType: [
+ { required: true, message: "妫�鏌ユ柟寮忎笉鑳戒负绌�", trigger: "blur" },
+ ],
+ checkStatus: [{ required: true, message: "鐘舵�佷笉鑳戒负绌�", trigger: "blur" }],
+ },
+ firmQueryParams: {
+ pageNum: 1,
+ pageSize: 10,
+ total: 1,
+ companyName: "",
+ companyCode: "",
+ },
+});
+
+// 鑾峰彇绉戝鍒楄〃
+const getOfficeList = () => {
+ listDept({
+ pageNum: 1,
+ pageSize: 1000,
+ parentId: form.value.applyOrgId,
+ }).then((response) => {
+ officeList.value = response.data;
+ });
+};
+
+// 鏈堜唤閫夋嫨
+const changeDateHandler = (value) => {
+ data.queryParams.planMonth = value.join(",");
+};
+
+// 璁″垝鏈堜唤閫夋嫨
+const changeMonth = (value) => {
+ form.value.planMonth = value.join(",");
+};
+
+// 鏈烘瀯閫夋嫨
+const changeTreeHandler = (e) => {
+ form.value.applyOrgId = e.id;
+ form.value.applyOrgName = e.label;
+ selectOffices.value = [];
+ form.value.applyDeptIds = "";
+ form.value.applyDeptNames = "";
+ if (e.id) {
+ getOfficeList();
+ }
+};
+
+// 绉戝閫夋嫨
+const handleSelectOffices = (value) => {
+ form.value.applyDeptNames = value
+ .map((item) => {
+ return officeList.value.find((obj) => obj.deptId === item).deptName;
+ })
+ .join(",");
+ form.value.applyDeptIds = value.join(",");
+};
+
+/*** 璁″垝瀵煎叆鍙傛暟 */
+const upload = reactive({
+ // 鏄惁鏄剧ず寮瑰嚭灞傦紙鐢ㄦ埛瀵煎叆锛�
+ open: false,
+ // 寮瑰嚭灞傛爣棰橈紙鐢ㄦ埛瀵煎叆锛�
+ title: "",
+ // 鏄惁绂佺敤涓婁紶
+ isUploading: false,
+ // 鏄惁鏇存柊宸茬粡瀛樺湪鐨勭敤鎴锋暟鎹�
+ updateSupport: 0,
+ // 璁剧疆涓婁紶鐨勮姹傚ご閮�
+ headers: { Authorization: "Bearer " + getToken() },
+ // 涓婁紶鐨勫湴鍧�
+ url: import.meta.env.VITE_APP_BASE_API + "/enforce/order/importData",
+});
+/**鏂囦欢涓婁紶涓鐞� */
+const handleFileUploadProgress = (event, file, fileList) => {
+ upload.isUploading = true;
+};
+/** 鏂囦欢涓婁紶鎴愬姛澶勭悊 */
+const handleFileSuccess = (response, file, fileList) => {
+ upload.open = false;
+ upload.isUploading = false;
+ proxy.$refs["uploadRef"].handleRemove(file);
+ proxy.$alert(
+ "<div style='overflow: auto;overflow-x: hidden;max-height: 70vh;padding: 10px 20px 0;'>" +
+ response.msg +
+ "</div>",
+ "瀵煎叆缁撴灉",
+ {
+ dangerouslyUseHTMLString: true,
+ }
+ );
+ getList();
+};
+const { queryParams, form, rules, firmQueryParams } = toRefs(data);
+
+/** 鏌ヨ閮ㄩ棬涓嬫媺鏍戠粨鏋� */
+function getDeptTree() {
+ deptTreeSelect().then((response) => {
+ deptOptions.value = response.data.map((obj) => {
+ obj.children = obj.children.map((child) => {
+ delete child.children;
+ return child;
+ });
+ return obj;
+ });
+ });
+}
+getDeptTree();
+/** 鏌ヨ璁″垝鍒楄〃 */
+function getList() {
+ loading.value = true;
+ listManage(queryParams.value).then((response) => {
+ deptList.value = response.rows;
+ data.queryParams.total = response.total;
+ loading.value = false;
+ });
+}
+/** 鍙栨秷鎸夐挳 */
+function cancel() {
+ open.value = false;
+ reset();
+ getList();
+}
+/** 琛ㄥ崟閲嶇疆 */
+function reset() {
+ form.value = {
+ enforceReason: "", // 璁″垝鍚嶇О
+ applyOrgId: "", // 鍒跺畾鏈烘瀯id
+ applyOrgName: "", // 鍒跺畾鏈烘瀯
+ applyDeptIds: "", // 鎵ц绉戝id
+ applyDeptNames: "", // 鎵ц绉戝鍚嶇О
+ checkdIds: "", // 琚鏌ュ璞d
+ companyName: "", // 琚鏌ュ璞″悕绉�
+ companyCode: "", // 缁熶竴绀句細淇$敤浠g爜
+ enforceType: "", // 妫�鏌ユ柟寮�
+ industry: "", // 鎵�灞炶涓�
+ enforceContent: "", // 妫�鏌ュ唴瀹�
+ planFrequency: "", // 璁″垝棰戞
+ planFrequencyUnit: "1", // 璁″垝棰戞鍗曚綅
+ planMonth: "", // 璁″垝鏈堜唤
+ orderType: 1,
+ };
+ selectOffices.value = [];
+ selectMonth.value = [];
+ checkedList.value = [];
+ proxy.$refs["deptRef"].clearValidate();
+ proxy.$refs["deptRef"].resetFields();
+}
+
+function closeUpdHandler() {
+ reset();
+ open.value = false;
+}
+
+const queryRef = ref();
+/** 鎼滅储鎸夐挳鎿嶄綔 */
+function handleQuery() {
+ getList();
+}
+/** 閲嶇疆鎸夐挳鎿嶄綔 */
+function resetQuery() {
+ queryRef.value.resetFields();
+ dateRange.value = [];
+ queryParams.value = {
+ orderType: 1,
+ companyName: "",
+ enforceReason: "",
+ applyOrgId: "",
+ planMonthStart: "", // 璁″垝寮�濮嬫湀浠�
+ planMonthEnd: "", // 璁″垝缁撴潫鏈堜唤
+ pageNum: 1,
+ pageSize: 10,
+ total: 1,
+ };
+ handleQuery();
+}
+function getDetails(id) {
+ getManage(id).then((response) => {
+ form.value = JSON.parse(JSON.stringify(response.data));
+ form.value.planFrequencyUnit = form.value.planFrequencyUnit.toString();
+ form.value.enforceType = Number(form.value.enforceType);
+ selectMonth.value = form.value.planMonth.split(",");
+ selectOffices.value = form.value.applyDeptIds
+ .split(",")
+ .map((item) => Number(item));
+
+ getOfficeList();
+ open.value = true;
+ });
+}
+
+/** 璇︾粏鎸夐挳鎿嶄綔 */
+function handleView(row) {
+ planOpen.value = true;
+ planDetail.value = row;
+ planOpen.value = true;
+}
+
+/** 鏂板鎸夐挳鎿嶄綔 */
+function handleAdd(row) {
+ if (row) {
+ title.value = "缂栬緫璁″垝";
+ getDetails(row.orderId);
+ } else {
+ title.value = "娣诲姞璁″垝";
+ open.value = true;
+ getUserOrgId();
+ }
+ getFirmList();
+}
+
+/** 鎻愪氦鎸夐挳 */
+function submitForm() {
+ proxy.$refs["deptRef"].validate((valid) => {
+ if (valid) {
+ if (form.value.orderId != undefined) {
+ updateManage(form.value).then((response) => {
+ proxy.$modal.msgSuccess("淇敼鎴愬姛");
+ open.value = false;
+ getList();
+ reset();
+ });
+ } else {
+ const submitArr = checkedList.value.map((item, index) => {
+ const submitForm = { ...form.value };
+ submitForm.companyId = item.companyId;
+ submitForm.companyName = item.companyName;
+ submitForm.companyCode = item.companyCode;
+ return submitForm
+ });
+ addManage(submitArr).then((response) => {
+ proxy.$modal.msgSuccess("鏂板鎴愬姛");
+ open.value = false;
+ getList();
+ reset();
+ });
+ }
+ }
+ });
+}
+/** 鍒犻櫎鎸夐挳鎿嶄綔 */
+function handleDelete(row) {
+ proxy.$modal
+ .confirm("鏄惁纭鍒犻櫎璇ユ暟鎹�?")
+ .then(function () {
+ return delManage(row.orderId);
+ })
+ .then(() => {
+ getList();
+ proxy.$modal.msgSuccess("鍒犻櫎鎴愬姛");
+ })
+ .catch(() => {});
+}
+
+/** 瀵煎叆鎸夐挳鎿嶄綔 */
+function handleImport() {
+ upload.title = "璁″垝瀵煎叆";
+ upload.open = true;
+}
+
+/** 鎻愪氦涓婁紶鏂囦欢 */
+function submitFileForm() {
+ proxy.$refs["uploadRef"].submit();
+}
+
+/** 涓嬭浇妯℃澘鎿嶄綔 */
+function importTemplate() {
+ exportTemplate().then((val) => {
+ downloadHttp(
+ "/tool/file/download",
+ {
+ fileName: val.msg,
+ delete: true,
+ },
+ "璁″垝淇℃伅妯℃澘.xlsx"
+ );
+ });
+}
+
+function downLoadCode() {
+ exportManage().then((val) => {
+ downloadHttp(
+ "/tool/file/download",
+ {
+ fileName: val.msg,
+ delete: true,
+ },
+ "璁″垝淇℃伅.xlsx"
+ );
+ });
+}
+
+function openFirmSelect() {
+ selectOpen.value = true;
+}
+
+/** 鏌ヨ浼佷笟鍒楄〃 */
+function getFirmList() {
+ listCompany(firmQueryParams.value).then((response) => {
+ firmList.value = response.rows;
+ firmQueryParams.value.total = response.total;
+ });
+}
+
+function handleSelectionChange(e) {
+ checkedList.value = e;
+ form.value.checkdIds = e.map((item) => item.companyId).join(",");
+}
+
+function closeSelect() {
+ selectOpen.value = false;
+}
+
+function industryToText(industry) {
+ return industry_type.value.find((item) => item.value == industry).label;
+}
+
+function methodToText(enforceType) {
+ if (!enforceType) return "";
+ return enforce_type.value.find((item) => item.value == enforceType).label;
+}
+
+function frequencyToText(data) {
+ console.log(data.planFrequencyUnit);
+ if (!data.planFrequencyUnit) {
+ return "";
+ }
+ const unit = frequency.value.find(
+ (item) => item.value == data.planFrequencyUnit
+ ).label;
+ return `${data.planFrequency}娆�/${unit}`;
+}
+
+function statusToText(status) {
+ return statusOptions.value.find((item) => item.value == status).label;
+}
+
+function getUserOrgId() {
+ getOrgId().then((response) => {
+ form.value.applyOrgId = Number(response.data.orgId) || "";
+ form.value.applyDeptIds = response.data.deptId || "";
+ if (form.value.applyDeptIds) {
+ selectOffices.value = form.value.applyDeptIds
+ .split(",")
+ .map((item) => Number(item));
+ }
+ if (form.value.applyOrgId) {
+ getOfficeList();
+ }
+ });
+}
+
+getList();
+function selectableFun(e) {}
+</script>
+
+<style scoped lang="scss">
+.evenly-distributed-labels {
+ :deep() {
+ .el-form-item__label {
+ position: relative;
+ /* 璁剧疆鐩稿瀹氫綅浣滀负鏄熷彿鐨勫畾浣嶅熀鍑� */
+ text-align: justify;
+ text-align-last: justify;
+ /* 纭繚鏈�鍚庝竴琛屼篃涓ょ瀵归綈 */
+ padding-left: 10px;
+ /* 涓烘槦鍙烽鐣欑┖闂� */
+ display: inline-block;
+ }
+ }
+}
+</style>
--
Gitblit v1.9.1