From d743d35bfb2dede91ff4b310886ba42da30425f2 Mon Sep 17 00:00:00 2001
From: 王恒 <318726284@qq.com>
Date: 星期四, 28 八月 2025 17:31:23 +0800
Subject: [PATCH] '调整综合查一次列表'

---
 src/api/system/manage.ts                 |  140 +-
 src/views/system/manage/index.vue        | 2070 ++++++++++++++++++------------------
 src/api/system/comprehensive.ts          |   53 
 src/views/system/comprehensive/index.vue | 1017 ++++++++++++++++++
 4 files changed, 2,175 insertions(+), 1,105 deletions(-)

diff --git a/src/api/system/comprehensive.ts b/src/api/system/comprehensive.ts
new file mode 100644
index 0000000..7363ea3
--- /dev/null
+++ b/src/api/system/comprehensive.ts
@@ -0,0 +1,53 @@
+import request from "@/utils/request";
+
+// 鏌ヨ缁煎悎鏌ヤ竴娆″垪琛�
+export function listOrder(query: any) {
+  return request({
+    url: "/comprehensive/enforce/order/list",
+    method: "get",
+    params: query,
+  });
+}
+
+// 鏌ヨ缁煎悎鏌ヤ竴娆¤缁�
+export function getOrder(id: any) {
+  return request({
+    url: "/comprehensive/enforce/order/" + id,
+    method: "get",
+  });
+}
+
+// 鏂板缁煎悎鏌ヤ竴娆�
+export function addOrder(data: any) {
+  return request({
+    url: "/system/order",
+    method: "post",
+    data: data,
+  });
+}
+
+// 淇敼缁煎悎鏌ヤ竴娆�
+export function updateOrder(data: any) {
+  return request({
+    url: "/system/order",
+    method: "put",
+    data: data,
+  });
+}
+
+// 鍒犻櫎缁煎悎鏌ヤ竴娆�
+export function delOrder(id: any) {
+  return request({
+    url: "/system/order/" + id,
+    method: "delete",
+  });
+}
+
+// 涓嬭浇妯℃澘 /system/manage/exportTemplate
+export function exportTemplate(data: any) {
+  return request({
+    url: `/comprehensive/enforce/order/exportTemplate`,
+    method: 'get',
+    params: data
+  })
+}
diff --git a/src/api/system/manage.ts b/src/api/system/manage.ts
index 202e961..763c113 100644
--- a/src/api/system/manage.ts
+++ b/src/api/system/manage.ts
@@ -1,70 +1,70 @@
-import request from "@/utils/request";
-
-// 鏌ヨ璁″垝绠$悊鍒楄〃
-export function listManage(query: any) {
-  return request({
-    url: "/enforce/order/plan/selectList",
-    method: "get",
-    params: query,
-  });
-}
-
-// 鏌ヨ璁″垝绠$悊璇︾粏
-export function getManage(id: any) {
-  return request({
-    url: "/enforce/order/" + id,
-    method: "get",
-  });
-}
-
-// 鑾峰彇褰撳墠鐢ㄦ埛鐨勬満鏋刬d
-export function getOrgId() {
-  return request({
-    url: "/enforce/order/getOrgId",
-    method: "get",
-  });
-}
-
-// 鏂板璁″垝绠$悊
-export function addManage(data: any) {
-  return request({
-    url: "/enforce/order/saveInsert",
-    method: "post",
-    data: data,
-  });
-}
-
-// 淇敼璁″垝绠$悊
-export function updateManage(data: any) {
-  return request({
-    url: "/enforce/order/saveUpdate",
-    method: "post",
-    data: data,
-  });
-}
-
-// 鍒犻櫎璁″垝绠$悊
-export function delManage(id: any) {
-  return request({
-    url: "/enforce/order/" + id,
-    method: "delete",
-  });
-}
-
-// 涓嬭浇妯℃澘 /system/manage/exportTemplate
-export function exportTemplate(data: any) {
-  return request({
-    url: `/enforce/order/exportTemplate`,
-    method: 'get',
-    params: data
-  })
-}
-
-// 瀵煎嚭璁″垝绠$悊 /system/manage/exportTemplate
-export function exportManage(data: any) {
-    return request({
-      url: `/enforce/order/export `,
-      method: 'get',
-      params: data
-    })
-  }
+import request from "@/utils/request";
+
+// 鏌ヨ璁″垝绠$悊鍒楄〃
+export function listManage(query: any) {
+  return request({
+    url: "/enforce/order/plan/selectList",
+    method: "get",
+    params: query,
+  });
+}
+
+// 鏌ヨ璁″垝绠$悊璇︾粏
+export function getManage(id: any) {
+  return request({
+    url: "/enforce/order/" + id,
+    method: "get",
+  });
+}
+
+// 鑾峰彇褰撳墠鐢ㄦ埛鐨勬満鏋刬d
+export function getOrgId() {
+  return request({
+    url: "/enforce/order/getOrgId",
+    method: "get",
+  });
+}
+
+// 鏂板璁″垝绠$悊
+export function addManage(data: any) {
+  return request({
+    url: "/enforce/order/saveInsertList",
+    method: "post",
+    data: data,
+  });
+}
+
+// 淇敼璁″垝绠$悊
+export function updateManage(data: any) {
+  return request({
+    url: "/enforce/order/saveUpdate",
+    method: "post",
+    data: data,
+  });
+}
+
+// 鍒犻櫎璁″垝绠$悊
+export function delManage(id: any) {
+  return request({
+    url: "/enforce/order/" + id,
+    method: "delete",
+  });
+}
+
+// 涓嬭浇妯℃澘 /system/manage/exportTemplate
+export function exportTemplate(data: any) {
+  return request({
+    url: `/enforce/order/exportTemplate`,
+    method: 'get',
+    params: data
+  })
+}
+
+// 瀵煎嚭璁″垝绠$悊 /system/manage/exportTemplate
+export function exportManage(data: any) {
+    return request({
+      url: `/enforce/order/export `,
+      method: 'get',
+      params: data
+    })
+  }
diff --git a/src/views/system/comprehensive/index.vue b/src/views/system/comprehensive/index.vue
new file mode 100644
index 0000000..690fc68
--- /dev/null
+++ b/src/views/system/comprehensive/index.vue
@@ -0,0 +1,1017 @@
+<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-row>
+
+    <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 prop="planNo" label="搴忓彿" width="55">
+        <template #default="scope">{{ scope.$index + 1 }}</template>
+      </el-table-column>
+      <el-table-column
+        prop="planNo"
+        label="璁″垝缂栧彿"
+        width="180"
+      ></el-table-column>
+      <el-table-column
+        prop="enforceReason"
+        label="妫�鏌ヨ鍒掑悕绉�"
+        width="180"
+      ></el-table-column>
+      <el-table-column
+        prop="leadUnitName"
+        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="enforceContent"
+        label="妫�鏌ュ唴瀹�"
+        width="180"
+      ></el-table-column>
+      <el-table-column
+        prop="applyDeptNames"
+        label="鎵ц绉戝"
+        width="180"
+      ></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="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-col>
+          <el-col :span="12">
+            <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-col>
+          <el-col :span="12">
+            <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="妫�鏌ユ柟寮忥細">{{
+              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 {
+  listOrder,
+  // addManage,
+  // getManage,
+  // updateManage,
+  // delManage,
+  exportTemplate,
+  // exportManage,
+  // getOrgId,
+} from "@/api/system/comprehensive";
+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: {
+    companyName: "",
+    enforceReason: "",
+    applyOrgId: "",
+    planMonthStart: "", // 璁″垝寮�濮嬫湀浠�
+    planMonthEnd: "", // 璁″垝缁撴潫鏈堜唤
+    pageNum: 1,
+    pageSize: 10,
+  },
+  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 + "/comprehensive/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;
+  listOrder(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 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>
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