index.vue 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryRef" :inline="true" v-show="showSearch" label-width="68px">
  4. <!-- <el-form-item label="行政相对人名称" prop="administrativePartyName">-->
  5. <!-- <el-input-->
  6. <!-- v-model="queryParams.administrativePartyName"-->
  7. <!-- placeholder="请输入行政相对人名称"-->
  8. <!-- clearable-->
  9. <!-- @keyup.enter="handleQuery"-->
  10. <!-- />-->
  11. <!-- </el-form-item>-->
  12. <el-form-item label="行政相对人代码" prop="administrativePartyCode">
  13. <el-input
  14. v-model="queryParams.administrativePartyCode"
  15. placeholder="请输入行政相对人代码"
  16. clearable
  17. @keyup.enter="handleQuery"
  18. />
  19. </el-form-item>
  20. <!-- <el-form-item label="法定代表人姓名" prop="legalRepresentativeName">-->
  21. <!-- <el-input-->
  22. <!-- v-model="queryParams.legalRepresentativeName"-->
  23. <!-- placeholder="请输入法定代表人姓名"-->
  24. <!-- clearable-->
  25. <!-- @keyup.enter="handleQuery"-->
  26. <!-- />-->
  27. <!-- </el-form-item>-->
  28. <!-- <el-form-item label="法定代表人证件号码" prop="legalRepresentativeIdNumber">-->
  29. <!-- <el-input-->
  30. <!-- v-model="queryParams.legalRepresentativeIdNumber"-->
  31. <!-- placeholder="请输入法定代表人证件号码"-->
  32. <!-- clearable-->
  33. <!-- @keyup.enter="handleQuery"-->
  34. <!-- />-->
  35. <!-- </el-form-item>-->
  36. <!-- <el-form-item label="检查形式" prop="inspectionForm">-->
  37. <!-- <el-input-->
  38. <!-- v-model="queryParams.inspectionForm"-->
  39. <!-- placeholder="请输入检查形式"-->
  40. <!-- clearable-->
  41. <!-- @keyup.enter="handleQuery"-->
  42. <!-- />-->
  43. <!-- </el-form-item>-->
  44. <!-- <el-form-item label="检查方式" prop="inspectionMethod">-->
  45. <!-- <el-input-->
  46. <!-- v-model="queryParams.inspectionMethod"-->
  47. <!-- placeholder="请输入检查方式"-->
  48. <!-- clearable-->
  49. <!-- @keyup.enter="handleQuery"-->
  50. <!-- />-->
  51. <!-- </el-form-item>-->
  52. <!-- <el-form-item label="关联文书号" prop="relatedDocumentNumber">-->
  53. <!-- <el-input-->
  54. <!-- v-model="queryParams.relatedDocumentNumber"-->
  55. <!-- placeholder="请输入关联文书号"-->
  56. <!-- clearable-->
  57. <!-- @keyup.enter="handleQuery"-->
  58. <!-- />-->
  59. <!-- </el-form-item>-->
  60. <!-- <el-form-item label="监督检查日期" prop="inspectionDate">-->
  61. <!-- <el-date-picker clearable-->
  62. <!-- v-model="queryParams.inspectionDate"-->
  63. <!-- type="date"-->
  64. <!-- value-format="YYYY-MM-DD"-->
  65. <!-- placeholder="请选择监督检查日期">-->
  66. <!-- </el-date-picker>-->
  67. <!-- </el-form-item>-->
  68. <!-- <el-form-item label="监督检查机关名称" prop="supervisionAuthorityName">-->
  69. <!-- <el-input-->
  70. <!-- v-model="queryParams.supervisionAuthorityName"-->
  71. <!-- placeholder="请输入监督检查机关名称"-->
  72. <!-- clearable-->
  73. <!-- @keyup.enter="handleQuery"-->
  74. <!-- />-->
  75. <!-- </el-form-item>-->
  76. <!-- <el-form-item label="监督检查机关代码" prop="supervisionAuthorityCode">-->
  77. <!-- <el-input-->
  78. <!-- v-model="queryParams.supervisionAuthorityCode"-->
  79. <!-- placeholder="请输入监督检查机关代码"-->
  80. <!-- clearable-->
  81. <!-- @keyup.enter="handleQuery"-->
  82. <!-- />-->
  83. <!-- </el-form-item>-->
  84. <!-- <el-form-item label="备注" prop="remarks">-->
  85. <!-- <el-input-->
  86. <!-- v-model="queryParams.remarks"-->
  87. <!-- placeholder="请输入备注"-->
  88. <!-- clearable-->
  89. <!-- @keyup.enter="handleQuery"-->
  90. <!-- />-->
  91. <!-- </el-form-item>-->
  92. <el-form-item>
  93. <el-button type="primary" icon="Search" @click="handleQuery">搜索</el-button>
  94. <el-button icon="Refresh" @click="resetQuery">重置</el-button>
  95. </el-form-item>
  96. <el-form-item>
  97. <el-row :gutter="10" class="mb8">
  98. <!-- <el-col :span="1.5">-->
  99. <!-- <el-button-->
  100. <!-- type="primary"-->
  101. <!-- plain-->
  102. <!-- icon="Plus"-->
  103. <!-- @click="handleAdd"-->
  104. <!-- v-hasPermi="['basicData:supervision:add']"-->
  105. <!-- >新增</el-button>-->
  106. <!-- </el-col>-->
  107. <!-- <el-col :span="1.5">-->
  108. <!-- <el-button-->
  109. <!-- type="success"-->
  110. <!-- plain-->
  111. <!-- icon="Edit"-->
  112. <!-- :disabled="single"-->
  113. <!-- @click="handleUpdate"-->
  114. <!-- v-hasPermi="['basicData:supervision:edit']"-->
  115. <!-- >修改</el-button>-->
  116. <!-- </el-col>-->
  117. <el-col :span="1.5">
  118. <el-button
  119. type="danger"
  120. plain
  121. icon="Delete"
  122. @click="handleDelete"
  123. v-hasPermi="['basicData:supervision:remove']"
  124. >删除</el-button>
  125. </el-col>
  126. <el-col :span="1.5">
  127. <el-button
  128. type="warning"
  129. plain
  130. icon="Download"
  131. :disabled="!supervisionList.length"
  132. @click="handleExport"
  133. v-hasPermi="['basicData:supervision:export']"
  134. >导出</el-button>
  135. </el-col>
  136. <el-col :span="1.5">
  137. <el-button type="info" plain icon="Upload" @click="handleImport"
  138. v-hasPermi="['system:user:import']">导入
  139. </el-button>
  140. </el-col>
  141. <!-- <right-toolbar v-model:showSearch="showSearch" @queryTable="getList"></right-toolbar>-->
  142. </el-row>
  143. </el-form-item>
  144. </el-form>
  145. <el-table v-loading="loading" :data="supervisionList" height="650" @selection-change="handleSelectionChange">
  146. <!-- <el-table-column type="selection" width="55" align="center" />-->
  147. <!-- <el-table-column label="主键" align="center" prop="id" />-->
  148. <el-table-column label="行政相对人名称" align="center" prop="administrativePartyName" :show-overflow-tooltip='true' />
  149. <el-table-column label="行政相对人类别" align="center" prop="administrativePartyType" :show-overflow-tooltip='true' />
  150. <el-table-column label="行政相对人代码" align="center" prop="administrativePartyCode" width="200" />
  151. <el-table-column label="法定代表人姓名" align="center" prop="legalRepresentativeName" :show-overflow-tooltip='true' />
  152. <el-table-column label="法定代表人证件类型" align="center" prop="legalRepresentativeIdType" :show-overflow-tooltip='true' />
  153. <el-table-column label="法定代表人证件号码" align="center" prop="legalRepresentativeIdNumber" :show-overflow-tooltip='true' />
  154. <el-table-column label="检查形式" align="center" prop="inspectionForm" :show-overflow-tooltip='true' />
  155. <el-table-column label="检查方式" align="center" prop="inspectionMethod" :show-overflow-tooltip='true' />
  156. <el-table-column label="监督检查内容" align="center" prop="supervisionInspectionContent" :show-overflow-tooltip='true' />
  157. <el-table-column label="检查结果" align="center" prop="inspectionResult" :show-overflow-tooltip='true' />
  158. <el-table-column label="关联文书号" align="center" prop="relatedDocumentNumber" :show-overflow-tooltip='true' />
  159. <el-table-column label="监督检查日期" align="center" prop="inspectionDate" width="180" :show-overflow-tooltip='true'>
  160. <template #default="scope">
  161. <span>{{ parseTime(scope.row.inspectionDate, '{y}-{m}-{d}') }}</span>
  162. </template>
  163. </el-table-column>
  164. <el-table-column label="监督检查机关名称" align="center" prop="supervisionAuthorityName" :show-overflow-tooltip='true' />
  165. <el-table-column label="监督检查机关代码" align="center" prop="supervisionAuthorityCode" :show-overflow-tooltip='true' />
  166. <el-table-column label="备注" align="center" prop="remarks" :show-overflow-tooltip='true' />
  167. <!-- <el-table-column label="操作" align="center" class-name="small-padding fixed-width">-->
  168. <!-- <template #default="scope">-->
  169. <!-- <el-button-->
  170. <!-- type="text"-->
  171. <!-- icon="Edit"-->
  172. <!-- @click="handleUpdate(scope.row)"-->
  173. <!-- v-hasPermi="['basicData:supervision:edit']"-->
  174. <!-- >修改</el-button>-->
  175. <!-- <el-button-->
  176. <!-- type="text"-->
  177. <!-- icon="Delete"-->
  178. <!-- @click="handleDelete(scope.row)"-->
  179. <!-- v-hasPermi="['basicData:supervision:remove']"-->
  180. <!-- >删除</el-button>-->
  181. <!-- </template>-->
  182. <!-- </el-table-column>-->
  183. </el-table>
  184. <div style="position: fixed;bottom: 20px;right: 10px;">
  185. <pagination
  186. v-show="total>0"
  187. :total="total"
  188. v-model:page="queryParams.pageNum"
  189. v-model:limit="queryParams.pageSize"
  190. @pagination="getList"
  191. />
  192. </div>
  193. <el-dialog :title="upload.title" v-model="upload.open" width="400px" append-to-body>
  194. <el-upload ref="uploadRef" :limit="1" accept=".xlsx, .xls" :headers="upload.headers"
  195. :action="upload.url + '?updateSupport=' + upload.updateSupport" :disabled="upload.isUploading"
  196. :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess" :auto-upload="false" drag>
  197. <el-icon class="el-icon--upload"><upload-filled /></el-icon>
  198. <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
  199. <template #tip>
  200. <div class="el-upload__tip text-center">
  201. <span>仅允许导入xls、xlsx格式文件。</span>
  202. </div>
  203. </template>
  204. </el-upload>
  205. <template #footer>
  206. <div class="dialog-footer">
  207. <el-button type="primary" @click="submitFileForm">确 定</el-button>
  208. <el-button @click="upload.open = false">取 消</el-button>
  209. </div>
  210. </template>
  211. </el-dialog>
  212. <!-- 添加或修改行政监督对话框 -->
  213. <el-dialog :title="title" v-model="open" width="500px" append-to-body>
  214. <el-form ref="supervisionRef" :model="form" :rules="rules" label-width="80px">
  215. <el-form-item label="行政相对人名称" prop="administrativePartyName">
  216. <el-input v-model="form.administrativePartyName" placeholder="请输入行政相对人名称" />
  217. </el-form-item>
  218. <el-form-item label="行政相对人代码" prop="administrativePartyCode">
  219. <el-input v-model="form.administrativePartyCode" placeholder="请输入行政相对人代码" />
  220. </el-form-item>
  221. <el-form-item label="法定代表人姓名" prop="legalRepresentativeName">
  222. <el-input v-model="form.legalRepresentativeName" placeholder="请输入法定代表人姓名" />
  223. </el-form-item>
  224. <el-form-item label="法定代表人证件号码" prop="legalRepresentativeIdNumber">
  225. <el-input v-model="form.legalRepresentativeIdNumber" placeholder="请输入法定代表人证件号码" />
  226. </el-form-item>
  227. <el-form-item label="检查形式" prop="inspectionForm">
  228. <el-input v-model="form.inspectionForm" placeholder="请输入检查形式" />
  229. </el-form-item>
  230. <el-form-item label="检查方式" prop="inspectionMethod">
  231. <el-input v-model="form.inspectionMethod" placeholder="请输入检查方式" />
  232. </el-form-item>
  233. <el-form-item label="监督检查内容">
  234. <editor v-model="form.supervisionInspectionContent" :min-height="192"/>
  235. </el-form-item>
  236. <el-form-item label="检查结果" prop="inspectionResult">
  237. <el-input v-model="form.inspectionResult" type="textarea" placeholder="请输入内容" />
  238. </el-form-item>
  239. <el-form-item label="关联文书号" prop="relatedDocumentNumber">
  240. <el-input v-model="form.relatedDocumentNumber" placeholder="请输入关联文书号" />
  241. </el-form-item>
  242. <el-form-item label="监督检查日期" prop="inspectionDate">
  243. <el-date-picker clearable
  244. v-model="form.inspectionDate"
  245. type="date"
  246. value-format="YYYY-MM-DD"
  247. placeholder="请选择监督检查日期">
  248. </el-date-picker>
  249. </el-form-item>
  250. <el-form-item label="监督检查机关名称" prop="supervisionAuthorityName">
  251. <el-input v-model="form.supervisionAuthorityName" placeholder="请输入监督检查机关名称" />
  252. </el-form-item>
  253. <el-form-item label="监督检查机关代码" prop="supervisionAuthorityCode">
  254. <el-input v-model="form.supervisionAuthorityCode" placeholder="请输入监督检查机关代码" />
  255. </el-form-item>
  256. <el-form-item label="备注" prop="remarks">
  257. <el-input v-model="form.remarks" placeholder="请输入备注" />
  258. </el-form-item>
  259. </el-form>
  260. <template #footer>
  261. <div class="dialog-footer">
  262. <el-button type="primary" @click="submitForm">确 定</el-button>
  263. <el-button @click="cancel">取 消</el-button>
  264. </div>
  265. </template>
  266. </el-dialog>
  267. </div>
  268. </template>
  269. <script setup name="Supervision">
  270. import { listSupervision, getSupervision, delSupervision, addSupervision, updateSupervision } from "@/api/basicData/supervision";
  271. import {reactive} from "vue";
  272. import {getToken} from "../../../../utils/auth";
  273. import {ElMessage} from "element-plus";
  274. import {likeQueryMethod} from "../../../../utils/likeQueryMethod";
  275. const { proxy } = getCurrentInstance();
  276. const supervisionList = ref([]);
  277. const open = ref(false);
  278. const loading = ref(true);
  279. const showSearch = ref(true);
  280. const ids = ref([]);
  281. const single = ref(true);
  282. const multiple = ref(true);
  283. const total = ref(0);
  284. const title = ref("");
  285. const upload = reactive({
  286. // 是否显示弹出层(用户导入)
  287. open: false,
  288. // 弹出层标题(用户导入)
  289. title: '',
  290. // 是否禁用上传
  291. isUploading: false,
  292. // 设置上传的请求头部
  293. headers: {Authorization: getToken()},
  294. // 上传的地址
  295. url: import.meta.env.VITE_APP_BASE_API + '/crmAdministrativeSupervision/importData'
  296. })
  297. const handleFileSuccess = (e)=>{
  298. if(e.code == 200){
  299. ElMessage({
  300. type:"success",
  301. message:e.msg
  302. })
  303. getList()
  304. }
  305. }
  306. function submitFileForm() {
  307. proxy.$refs['uploadRef'].submit()
  308. upload.open = false;
  309. // setTimeout(getList,1000)
  310. }
  311. function handleImport() {
  312. let toServerObj = likeQueryMethod('administrative_party_code', queryParams.value.administrativePartyCode, queryParams.value.pageNum, queryParams.value.pageSize);
  313. listSupervision(toServerObj).then(res=>{
  314. if(res.records.length >0){
  315. ElMessage({
  316. type:'warning',
  317. message:'当前已经有数据,请删除后再导入'
  318. })
  319. return
  320. }else {
  321. upload.title = '用户导入'
  322. upload.open = true
  323. }
  324. })
  325. }
  326. const data = reactive({
  327. form: {},
  328. queryParams: {
  329. pageNum: 1,
  330. pageSize: 20,
  331. administrativePartyName: null,
  332. administrativePartyType: null,
  333. administrativePartyCode: '',
  334. legalRepresentativeName: null,
  335. legalRepresentativeIdType: null,
  336. legalRepresentativeIdNumber: null,
  337. inspectionForm: null,
  338. inspectionMethod: null,
  339. supervisionInspectionContent: null,
  340. inspectionResult: null,
  341. relatedDocumentNumber: null,
  342. inspectionDate: null,
  343. supervisionAuthorityName: null,
  344. supervisionAuthorityCode: null,
  345. remarks: null,
  346. },
  347. rules: {
  348. }
  349. });
  350. const { queryParams, form, rules } = toRefs(data);
  351. /** 查询行政监督列表 */
  352. function getList() {
  353. loading.value = true;
  354. let toServerObj = likeQueryMethod('administrative_party_code', queryParams.value.administrativePartyCode, queryParams.value.pageNum, queryParams.value.pageSize);
  355. listSupervision(toServerObj).then(response => {
  356. supervisionList.value = response.records;
  357. total.value = response.total;
  358. loading.value = false;
  359. });
  360. }
  361. // 取消按钮
  362. function cancel() {
  363. open.value = false;
  364. reset();
  365. }
  366. // 表单重置
  367. function reset() {
  368. form.value = {
  369. id: null,
  370. administrativePartyName: null,
  371. administrativePartyType: null,
  372. administrativePartyCode: '',
  373. legalRepresentativeName: null,
  374. legalRepresentativeIdType: null,
  375. legalRepresentativeIdNumber: null,
  376. inspectionForm: null,
  377. inspectionMethod: null,
  378. supervisionInspectionContent: null,
  379. inspectionResult: null,
  380. relatedDocumentNumber: null,
  381. inspectionDate: null,
  382. supervisionAuthorityName: null,
  383. supervisionAuthorityCode: null,
  384. remarks: null,
  385. createTime: null,
  386. updateTime: null
  387. };
  388. proxy.resetForm("supervisionRef");
  389. }
  390. /** 搜索按钮操作 */
  391. function handleQuery() {
  392. queryParams.value.pageNum = 1;
  393. getList();
  394. }
  395. /** 重置按钮操作 */
  396. function resetQuery() {
  397. proxy.resetForm("queryRef");
  398. handleQuery();
  399. }
  400. // 多选框选中数据
  401. function handleSelectionChange(selection) {
  402. ids.value = selection.map(item => item.id);
  403. single.value = selection.length != 1;
  404. multiple.value = !selection.length;
  405. }
  406. /** 新增按钮操作 */
  407. function handleAdd() {
  408. reset();
  409. open.value = true;
  410. title.value = "添加行政监督";
  411. }
  412. /** 修改按钮操作 */
  413. function handleUpdate(row) {
  414. reset();
  415. const id = row.id || ids.value
  416. getSupervision(id).then(response => {
  417. form.value = response.data;
  418. open.value = true;
  419. title.value = "修改行政监督";
  420. });
  421. }
  422. /** 提交按钮 */
  423. function submitForm() {
  424. proxy.$refs["supervisionRef"].validate(valid => {
  425. if (valid) {
  426. if (form.value.id != null) {
  427. updateSupervision(form.value).then(response => {
  428. proxy.$modal.msgSuccess("修改成功");
  429. open.value = false;
  430. getList();
  431. });
  432. } else {
  433. addSupervision(form.value).then(response => {
  434. proxy.$modal.msgSuccess("新增成功");
  435. open.value = false;
  436. getList();
  437. });
  438. }
  439. }
  440. });
  441. }
  442. /** 删除按钮操作 */
  443. async function handleDelete(row) {
  444. const res = await delSupervision();
  445. if(res.code == 200){
  446. ElMessage({
  447. type:'success',
  448. message:'删除成功'
  449. })
  450. getList();
  451. }
  452. // const ids = row.id || ids.value;
  453. // proxy.$modal.confirm('是否确认删除行政监督编号为"' + ids + '"的数据项?').then(function() {
  454. // return delSupervision(ids);
  455. // }).then(() => {
  456. // getList();
  457. // proxy.$modal.msgSuccess("删除成功");
  458. // }).catch(() => {});
  459. }
  460. /** 导出按钮操作 */
  461. function handleExport() {
  462. proxy.download('crmAdministrativeSupervision/exportData', {
  463. ...queryParams.value
  464. }, `行政监督_${new Date().getTime()}.xlsx`)
  465. }
  466. getList();
  467. </script>