1 |
- {"remainingRequest":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\src\\views\\system\\dept\\index.vue?vue&type=style&index=0&id=e6913484&scoped=true&lang=css&","dependencies":[{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\src\\views\\system\\dept\\index.vue","mtime":1647228900896},{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\css-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\vue-loader\\lib\\loaders\\stylePostLoader.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\postcss-loader\\src\\index.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"C:\\Users\\Administrator\\Desktop\\最新\\supervision-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:CgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKDQovKiDooajmoLznirbmgIEgKi8NCjo6di1kZWVwIC5lbC10YWcgew0KICBiYWNrZ3JvdW5kLWNvbG9yOiAjMWQ5NmZmOw0KICBib3JkZXI6IDBweDsNCiAgY29sb3I6ICNmZmY7DQogIHRleHQtYWxpZ246IGNlbnRlcjsNCiAgbGluZS1oZWlnaHQ6IDI4cHg7DQp9DQoNCi8qIOiuvue9ruaMiemSrumAj+aYjui+ueahhiAgKi8NCi5lbC1idXR0b24gew0KICBib3JkZXI6IDFweCBzb2xpZCB0cmFuc3BhcmVudDsNCn0NCi5lbC1idXR0b24tLXdhcm5pbmcuaXMtcGxhaW4gew0KICB3aWR0aDogYXV0bzsNCn0NCi8qIOWvueivneahhuiDjOaZr+minOiJsiAqLw0KOjp2LWRlZXAgLmVsLWRpYWxvZyB7DQogIGJhY2tncm91bmQ6ICMwMDRkODYgIWltcG9ydGFudDsNCn0NCjo6di1kZWVwIC5lbC10ZXh0YXJlYV9faW5uZXIgew0KICB3aWR0aDogOTMwcHg7DQogIGhlaWdodDogMTA0cHg7DQogIG1hcmdpbjogYXV0byAhaW1wb3J0YW50Ow0KfQ0KOjp2LWRlZXAgLmVsLWRpYWxvZ19faGVhZGVyIHsNCiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICM3MThhOWQ7DQp9DQo6OnYtZGVlcCAuZWwtZGlhbG9nX190aXRsZSB7DQogIGNvbG9yOiAjZmZmOw0KICBmb250OiAxOHB4Ow0KfQ0KOjp2LWRlZXAgLmVsLWRpYWxvZ19faGVhZGVyYnRuIC5lbC1kaWFsb2dfX2Nsb3NlIHsNCiAgY29sb3I6ICNmZmY7DQp9DQo6OnYtZGVlcCAuZWwtZm9ybS1pdGVtX19sYWJlbCB7DQogIGZvbnQ6IDE2cHg7DQogIGNvbG9yOiAjZmZmOw0KICB3aWR0aDogMTAwcHggIWltcG9ydGFudDsNCn0NCjo6di1kZWVwIC5lbC1pbnB1dF9faW5uZXIgew0KICAvKiB3aWR0aDogMjAwcHggIWltcG9ydGFudDsNCiAgaGVpZ2h0OiAzNnB4OyAqLw0KICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDsNCiAgY29sb3I6ICNmZmY7DQp9DQovKiDljZXkvY3moYbog4zmma/popzoibIgKi8NCjo6di1kZWVwIC52dWUtdHJlZXNlbGVjdF9fY29udHJvbCB7DQogIGJhY2tncm91bmQ6ICMwMDRkODYgIWltcG9ydGFudDsNCn0NCi8qIOWfuuacrOS/oeaBr+iDjOaZryAqLw0KLmppYmVuIHsNCiAgd2lkdGg6IDY2MHB4Ow0KICBoZWlnaHQ6IDMycHg7DQogIGJhY2tncm91bmQtaW1hZ2U6IHVybCguLi8uLi8uLi9pbWFnZXMv5bCP5qCH6aKY5bqVLnBuZyk7DQogIG1hcmdpbi1ib3R0b206IDI1cHg7DQogIGNvbG9yOiAjZmZmOw0KICBwYWRkaW5nLWxlZnQ6IDE2cHg7DQogIGxpbmUtaGVpZ2h0OiAzMnB4Ow0KfQ0KLyrosIPmlbTooajljZXpl7Tot50gKi8NCjo6di1kZWVwIC5lbC1mb3JtLWl0ZW1fX2NvbnRlbnQgew0KICB3aWR0aDogMjAwcHg7DQp9DQoNCi5jb250ZW50cyB7DQogIHBhZGRpbmc6IDBweCA0MHB4ICFpbXBvcnRhbnQ7DQp9DQovKiDkuIvmi4noj5zljZUgKi8NCi5lbC1kcm9wZG93bi1saW5rIHsNCiAgY3Vyc29yOiBwb2ludGVyOw0KICBjb2xvcjogIzQwOWVmZjsNCn0NCi5lbC1pY29uLWFycm93LWRvd24gew0KICBmb250LXNpemU6IDEycHg7DQp9DQovKiDliLfmlrDlm77moIcgKi8NCi8qIC5lbC1pY29uLXJlZnJlc2ggew0KICB3aWR0aDogNzZweDsNCiAgaGVpZ2h0OiAzNnB4Ow0KICBjb2xvcjogI2ZmZjsNCiAgYmFja2dyb3VuZC1jb2xvcjogIzFkOTZmZiAhaW1wb3J0YW50Ow0KICBib3JkZXItcmFkaXVzOiA0cHg7DQogIGJvcmRlcjogbm9uZTsNCiAgbWFyZ2luLWxlZnQ6IDIwcHg7DQogIGZvbnQtc2l6ZTogMTRweDsNCn0gKi8NCi8qIOS4i+aLieiPnOWNleWtl+S9ky/og4zmma/popzoibIgKi8NCi5lbC1zZWxlY3QtZHJvcGRvd25fX2l0ZW0uaG92ZXIsDQouZWwtc2VsZWN0LWRyb3Bkb3duX19pdGVtOmhvdmVyIHsNCiAgYmFja2dyb3VuZC1jb2xvcjogIzAwNGQ4NjsNCiAgY29sb3I6ICNmZmY7DQp9DQouZWwtc2VsZWN0LWRyb3Bkb3duX19pdGVtIHsNCiAgY29sb3I6ICNmZmY7DQp9DQovKiDml7bpl7TpgInmi6kgKi8NCjo6di1kZWVwIC5lbC1pbnB1dC0tc21hbGwgLmVsLWlucHV0X19pbm5lciB7DQogIHdpZHRoOiAyMDBweDsNCiAgaGVpZ2h0OiAzNnB4Ow0KICBsaW5lLWhlaWdodDogMzZweDsNCn0NCi5lbC1kYXRlLWVkaXRvci5lbC1pbnB1dCB7DQogIHdpZHRoOiAyMDBweDsNCiAgaGVpZ2h0OiAzNnB4Ow0KICBsaW5lLWhlaWdodDogMzZweDsNCn0NCjo6di1kZWVwIC5lbC1kYXRlLWVkaXRvci5lbC1pbnB1dCAuZWwtaW5wdXRfX2lubmVyIHsNCiAgaGVpZ2h0OiAzNnB4Ow0KICBsaW5lLWhlaWdodDogMzZweDsNCn0NCi8qIOWNleS9jeahhuiDjOaZr+minOiJsiAqLw0KOjp2LWRlZXAgLnZ1ZS10cmVlc2VsZWN0X19jb250cm9sIHsNCiAgYmFja2dyb3VuZDogIzAwNGQ4NiAhaW1wb3J0YW50Ow0KICBjb2xvcjogI2ZmZjsNCn0NCi8qIOWNleS9jeS4i+aLieiPnOWNlemAieS4reWtl+S9k+minOiJsiAqLw0KOjp2LWRlZXAgLnZ1ZS10cmVlc2VsZWN0X19zaW5nbGUtdmFsdWUgew0KICBjb2xvcjogI2ZmZiAhaW1wb3J0YW50Ow0KfQ0KLyog5YiG6aG15oyJ6ZKuICovDQo6OnYtZGVlcCAuZWwtcGFnaW5hdGlvbi5pcy1iYWNrZ3JvdW5kIC5lbC1wYWdlciBsaSB7DQogIGJhY2tncm91bmQtY29sb3I6ICMwMDRkODY7DQogIGNvbG9yOiAjZmZmOw0KfQ0KOjp2LWRlZXAgLmVsLXBhZ2luYXRpb24uaXMtYmFja2dyb3VuZCAuYnRuLW5leHQgew0KICBiYWNrZ3JvdW5kLWNvbG9yOiAjMDA0ZDg2Ow0KICBjb2xvcjogI2ZmZjsNCn0NCjo6di1kZWVwIC5lbC1wYWdpbmF0aW9uLmlzLWJhY2tncm91bmQgLmJ0bi1wcmV2LA0KLmVsLXBhZ2luYXRpb24uaXMtYmFja2dyb3VuZCAuYnRuLW5leHQsDQouZWwtcGFnaW5hdGlvbi5pcy1iYWNrZ3JvdW5kIC5lbC1wYWdlciBsaSB7DQogIGJhY2tncm91bmQ6ICMwMDRkODYgIWltcG9ydGFudDsNCiAgY29sb3I6ICNmZmYgIWltcG9ydGFudDsNCn0NCi8qIOeKtuaAgSAqLw0KLmVsLXJhZGlvIHsNCiAgY29sb3I6IHJnYigyMDQsIDE5OCwgMTk4KTsNCn0NCi8qIOiuoeaVsOWZqOaMiemSriAqLw0KOjp2LWRlZXAgLmVsLWlucHV0LW51bWJlcl9faW5jcmVhc2Ugew0KICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudCAhaW1wb3J0YW50Ow0KICBib3JkZXI6IG5vbmU7DQogIGNvbG9yOiAjY2NjY2NjOw0KICBib3JkZXItYm90dG9tOiBub25lICFpbXBvcnRhbnQ7DQp9DQo6OnYtZGVlcCAuZWwtaW5wdXQtbnVtYmVyX19kZWNyZWFzZSB7DQogIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50ICFpbXBvcnRhbnQ7DQogIGJvcmRlcjogbm9uZSAhaW1wb3J0YW50Ow0KICBjb2xvcjogI2NjY2NjYzsNCn0NCg=="},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwaA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"index.vue","sourceRoot":"src/views/system/dept","sourcesContent":["<template>\r\n <div class=\"app-container\">\r\n <el-form\r\n :model=\"queryParams\"\r\n ref=\"queryForm\"\r\n :inline=\"true\"\r\n v-show=\"showSearch\"\r\n >\r\n <el-form-item label=\"单位名称\" prop=\"deptName\" style=\"color=''\">\r\n <el-input\r\n v-model=\"queryParams.deptName\"\r\n placeholder=\"请输入单位名称\"\r\n clearable\r\n size=\"small\"\r\n @keyup.enter.native=\"handleQuery\"\r\n />\r\n </el-form-item>\r\n <el-form-item label=\"状态\" prop=\"status\">\r\n <el-select\r\n v-model=\"queryParams.status\"\r\n placeholder=\"单位状态\"\r\n clearable\r\n size=\"small\"\r\n >\r\n <el-option\r\n v-for=\"dict in dict.type.sys_normal_disable\"\r\n :key=\"dict.value\"\r\n :label=\"dict.label\"\r\n :value=\"dict.value\"\r\n />\r\n </el-select>\r\n </el-form-item>\r\n <el-form-item>\r\n <el-button icon=\"el-icon-search\" size=\"btn\" @click=\"handleQuery\"\r\n >搜索</el-button\r\n >\r\n <el-button icon=\"el-icon-refresh\" size=\"btr\" @click=\"resetQuery\"\r\n >重置</el-button\r\n >\r\n </el-form-item>\r\n </el-form>\r\n\r\n <el-row :gutter=\"10\" class=\"mb8\">\r\n <el-col :span=\"1.5\">\r\n <el-button\r\n type=\"primary\"\r\n plain\r\n icon=\"el-icon-plus\"\r\n size=\"mini\"\r\n @click=\"handleAdd\"\r\n v-hasPermi=\"['system:dept:add']\"\r\n >新增</el-button\r\n >\r\n </el-col>\r\n <el-col :span=\"1.5\">\r\n <el-button\r\n type=\"warning\"\r\n plain\r\n icon=\"el-icon-sort\"\r\n size=\"mini\"\r\n @click=\"toggleExpandAll\"\r\n >展开/折叠</el-button\r\n >\r\n </el-col>\r\n <right-toolbar\r\n :showSearch.sync=\"showSearch\"\r\n @queryTable=\"getList\"\r\n ></right-toolbar>\r\n </el-row>\r\n\r\n <el-table\r\n v-if=\"refreshTable\"\r\n v-loading=\"loading\"\r\n :data=\"deptList\"\r\n row-key=\"deptId\"\r\n :default-expand-all=\"isExpandAll\"\r\n :tree-props=\"{ children: 'children', hasChildren: 'hasChildren' }\"\r\n :header-cell-style=\"{ background: '#003C69', color: 'white' }\"\r\n @selection-change=\"handleSelectionChange\"\r\n >\r\n <el-table-column type=\"selection\" width=\"49\"> </el-table-column>\r\n <el-table-column\r\n prop=\"deptName\"\r\n label=\"单位名称\"\r\n width=\"260\"\r\n ></el-table-column>\r\n <el-table-column\r\n prop=\"orderNum\"\r\n label=\"排序\"\r\n width=\"250\"\r\n ></el-table-column>\r\n <el-table-column prop=\"status\" label=\"状态\" width=\"250\">\r\n <template slot-scope=\"scope\">\r\n <dict-tag\r\n :options=\"dict.type.sys_normal_disable\"\r\n :value=\"scope.row.status\"\r\n />\r\n </template>\r\n </el-table-column>\r\n <el-table-column\r\n label=\"创建时间\"\r\n align=\"center\"\r\n prop=\"createTime\"\r\n width=\"350\"\r\n >\r\n <template slot-scope=\"scope\">\r\n <span>{{ parseTime(scope.row.createTime) }}</span>\r\n </template>\r\n </el-table-column>\r\n <el-table-column\r\n label=\"操作\"\r\n align=\"center\"\r\n class-name=\"small-padding fixed-width\"\r\n >\r\n <template slot-scope=\"scope\">\r\n <el-button\r\n size=\"btu\"\r\n type=\"text\"\r\n @click=\"handleUpdate(scope.row)\"\r\n v-hasPermi=\"['system:dept:edit']\"\r\n ><span class=\"edit\">修改</span></el-button\r\n >\r\n <el-button\r\n size=\"btc\"\r\n type=\"text\"\r\n @click=\"handleAdd(scope.row)\"\r\n v-hasPermi=\"['system:dept:add']\"\r\n ><span class=\"plus\">新增</span></el-button\r\n >\r\n <el-button\r\n v-if=\"scope.row.parentId != 0\"\r\n size=\"btd\"\r\n type=\"text\"\r\n @click=\"handleDelete(scope.row)\"\r\n v-hasPermi=\"['system:dept:remove']\"\r\n ><span class=\"delete\">删除</span></el-button\r\n >\r\n </template>\r\n </el-table-column>\r\n </el-table>\r\n\r\n <!-- 添加或修改单位对话框 -->\r\n <el-dialog :title=\"title\" :visible.sync=\"open\" width=\"700px\" append-to-body>\r\n <div class=\"jiben\">基本信息</div>\r\n\r\n <el-form\r\n ref=\"form\"\r\n :model=\"form\"\r\n :rules=\"rules\"\r\n label-width=\"120px\"\r\n :inline=\"true\"\r\n >\r\n <el-row>\r\n <el-col :span=\"12\" v-if=\"form.parentId !== 0\">\r\n <el-form-item label=\"上级单位\" prop=\"parentId\">\r\n <treeselect\r\n v-model=\"form.parentId\"\r\n :options=\"deptOptions\"\r\n :normalizer=\"normalizer\"\r\n placeholder=\"选择上级单位\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"单位名称\" prop=\"deptName\">\r\n <el-input v-model=\"form.deptName\" placeholder=\"请输入单位名称\" />\r\n </el-form-item>\r\n </el-col>\r\n </el-row>\r\n <el-row>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"显示排序\" prop=\"orderNum\">\r\n <el-input-number\r\n v-model=\"form.orderNum\"\r\n controls-position=\"right\"\r\n :min=\"0\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"负责人\" prop=\"leader\">\r\n <el-input\r\n v-model=\"form.leader\"\r\n placeholder=\"请输入负责人\"\r\n maxlength=\"20\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n </el-row>\r\n <el-row>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"联系电话\" prop=\"phone\">\r\n <el-input\r\n v-model=\"form.phone\"\r\n placeholder=\"请输入联系电话\"\r\n maxlength=\"11\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"邮箱\" prop=\"email\">\r\n <el-input\r\n v-model=\"form.email\"\r\n placeholder=\"请输入邮箱\"\r\n maxlength=\"50\"\r\n />\r\n </el-form-item>\r\n </el-col>\r\n </el-row>\r\n <el-row>\r\n <el-col :span=\"12\">\r\n <el-form-item label=\"单位状态\">\r\n <el-radio-group v-model=\"form.status\">\r\n <el-radio\r\n v-for=\"dict in dict.type.sys_normal_disable\"\r\n :key=\"dict.value\"\r\n :label=\"dict.value\"\r\n >{{ dict.label }}</el-radio\r\n >\r\n </el-radio-group>\r\n </el-form-item>\r\n </el-col>\r\n </el-row>\r\n </el-form>\r\n <div slot=\"footer\" class=\"dialog-footer\">\r\n <el-button type=\"primary\" @click=\"submitForm\">确 定</el-button>\r\n <el-button @click=\"cancel\">取 消</el-button>\r\n </div>\r\n </el-dialog>\r\n </div>\r\n</template>\r\n\r\n<script>\r\nimport {\r\n listDept,\r\n getDept,\r\n delDept,\r\n addDept,\r\n updateDept,\r\n listDeptExcludeChild,\r\n} from \"@/api/system/dept\";\r\nimport Treeselect from \"@riophae/vue-treeselect\";\r\nimport \"@riophae/vue-treeselect/dist/vue-treeselect.css\";\r\n\r\nexport default {\r\n name: \"Dept\",\r\n dicts: [\"sys_normal_disable\"],\r\n components: { Treeselect },\r\n data() {\r\n return {\r\n // 遮罩层\r\n loading: true,\r\n // 显示搜索条件\r\n showSearch: true,\r\n // 表格树数据\r\n deptList: [],\r\n // 单位树选项\r\n deptOptions: [],\r\n // 弹出层标题\r\n title: \"\",\r\n // 是否显示弹出层\r\n open: false,\r\n // 是否展开,默认全部展开\r\n isExpandAll: true,\r\n // 重新渲染表格状态\r\n refreshTable: true,\r\n // 是否展开\r\n expand: false,\r\n // 查询参数\r\n queryParams: {\r\n deptName: undefined,\r\n status: undefined,\r\n },\r\n // 表单参数\r\n form: {},\r\n // 表单校验\r\n rules: {\r\n parentId: [\r\n { required: true, message: \"上级单位不能为空\", trigger: \"blur\" },\r\n ],\r\n deptName: [\r\n { required: true, message: \"单位名称不能为空\", trigger: \"blur\" },\r\n ],\r\n orderNum: [\r\n { required: true, message: \"显示排序不能为空\", trigger: \"blur\" },\r\n ],\r\n email: [\r\n {\r\n type: \"email\",\r\n message: \"'请输入正确的邮箱地址\",\r\n trigger: [\"blur\", \"change\"],\r\n },\r\n ],\r\n phone: [\r\n {\r\n pattern: /^1[3|4|5|6|7|8|9][0-9]\\d{8}$/,\r\n message: \"请输入正确的手机号码\",\r\n trigger: \"blur\",\r\n },\r\n ],\r\n },\r\n };\r\n },\r\n created() {\r\n this.getList();\r\n },\r\n methods: {\r\n /** 查询单位列表 */\r\n getList() {\r\n this.loading = true;\r\n listDept(this.queryParams).then((response) => {\r\n this.deptList = this.handleTree(response.data, \"deptId\");\r\n this.loading = false;\r\n });\r\n },\r\n /** 转换单位数据结构 */\r\n normalizer(node) {\r\n if (node.children && !node.children.length) {\r\n delete node.children;\r\n }\r\n return {\r\n id: node.deptId,\r\n label: node.deptName,\r\n children: node.children,\r\n };\r\n },\r\n // 取消按钮\r\n cancel() {\r\n this.open = false;\r\n this.reset();\r\n },\r\n // 表单重置\r\n reset() {\r\n this.form = {\r\n deptId: undefined,\r\n parentId: undefined,\r\n deptName: undefined,\r\n orderNum: undefined,\r\n leader: undefined,\r\n phone: undefined,\r\n email: undefined,\r\n status: \"0\",\r\n };\r\n this.resetForm(\"form\");\r\n },\r\n /** 搜索按钮操作 */\r\n handleQuery() {\r\n this.getList();\r\n },\r\n /** 重置按钮操作 */\r\n resetQuery() {\r\n this.resetForm(\"queryForm\");\r\n this.handleQuery();\r\n },\r\n /** 新增按钮操作 */\r\n handleAdd(row) {\r\n this.reset();\r\n if (row != undefined) {\r\n this.form.parentId = row.deptId;\r\n }\r\n this.open = true;\r\n this.title = \"添加单位\";\r\n listDept().then((response) => {\r\n this.deptOptions = this.handleTree(response.data, \"deptId\");\r\n });\r\n },\r\n /** 展开/折叠操作 */\r\n toggleExpandAll() {\r\n this.refreshTable = false;\r\n this.isExpandAll = !this.isExpandAll;\r\n this.$nextTick(() => {\r\n this.refreshTable = true;\r\n });\r\n },\r\n /** 修改按钮操作 */\r\n handleUpdate(row) {\r\n this.reset();\r\n getDept(row.deptId).then((response) => {\r\n this.form = response.data;\r\n this.open = true;\r\n this.title = \"修改单位\";\r\n });\r\n listDeptExcludeChild(row.deptId).then((response) => {\r\n this.deptOptions = this.handleTree(response.data, \"deptId\");\r\n });\r\n },\r\n /** 提交按钮 */\r\n submitForm: function () {\r\n this.$refs[\"form\"].validate((valid) => {\r\n if (valid) {\r\n if (this.form.deptId != undefined) {\r\n updateDept(this.form).then((response) => {\r\n this.$modal.msgSuccess(\"修改成功\");\r\n this.open = false;\r\n this.getList();\r\n });\r\n } else {\r\n addDept(this.form).then((response) => {\r\n this.$modal.msgSuccess(\"新增成功\");\r\n this.open = false;\r\n this.getList();\r\n });\r\n }\r\n }\r\n });\r\n },\r\n /** 删除按钮操作 */\r\n handleDelete(row) {\r\n this.$modal\r\n .confirm('是否确认删除名称为\"' + row.deptName + '\"的数据项?')\r\n .then(function () {\r\n return delDept(row.deptId);\r\n })\r\n .then(() => {\r\n this.getList();\r\n this.$modal.msgSuccess(\"删除成功\");\r\n })\r\n .catch(() => {});\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped>\r\n/* 表格状态 */\r\n::v-deep .el-tag {\r\n background-color: #1d96ff;\r\n border: 0px;\r\n color: #fff;\r\n text-align: center;\r\n line-height: 28px;\r\n}\r\n\r\n/* 设置按钮透明边框 */\r\n.el-button {\r\n border: 1px solid transparent;\r\n}\r\n.el-button--warning.is-plain {\r\n width: auto;\r\n}\r\n/* 对话框背景颜色 */\r\n::v-deep .el-dialog {\r\n background: #004d86 !important;\r\n}\r\n::v-deep .el-textarea__inner {\r\n width: 930px;\r\n height: 104px;\r\n margin: auto !important;\r\n}\r\n::v-deep .el-dialog__header {\r\n border-bottom: 1px solid #718a9d;\r\n}\r\n::v-deep .el-dialog__title {\r\n color: #fff;\r\n font: 18px;\r\n}\r\n::v-deep .el-dialog__headerbtn .el-dialog__close {\r\n color: #fff;\r\n}\r\n::v-deep .el-form-item__label {\r\n font: 16px;\r\n color: #fff;\r\n width: 100px !important;\r\n}\r\n::v-deep .el-input__inner {\r\n /* width: 200px !important;\r\n height: 36px; */\r\n background: transparent;\r\n color: #fff;\r\n}\r\n/* 单位框背景颜色 */\r\n::v-deep .vue-treeselect__control {\r\n background: #004d86 !important;\r\n}\r\n/* 基本信息背景 */\r\n.jiben {\r\n width: 660px;\r\n height: 32px;\r\n background-image: url(../../../images/小标题底.png);\r\n margin-bottom: 25px;\r\n color: #fff;\r\n padding-left: 16px;\r\n line-height: 32px;\r\n}\r\n/*调整表单间距 */\r\n::v-deep .el-form-item__content {\r\n width: 200px;\r\n}\r\n\r\n.contents {\r\n padding: 0px 40px !important;\r\n}\r\n/* 下拉菜单 */\r\n.el-dropdown-link {\r\n cursor: pointer;\r\n color: #409eff;\r\n}\r\n.el-icon-arrow-down {\r\n font-size: 12px;\r\n}\r\n/* 刷新图标 */\r\n/* .el-icon-refresh {\r\n width: 76px;\r\n height: 36px;\r\n color: #fff;\r\n background-color: #1d96ff !important;\r\n border-radius: 4px;\r\n border: none;\r\n margin-left: 20px;\r\n font-size: 14px;\r\n} */\r\n/* 下拉菜单字体/背景颜色 */\r\n.el-select-dropdown__item.hover,\r\n.el-select-dropdown__item:hover {\r\n background-color: #004d86;\r\n color: #fff;\r\n}\r\n.el-select-dropdown__item {\r\n color: #fff;\r\n}\r\n/* 时间选择 */\r\n::v-deep .el-input--small .el-input__inner {\r\n width: 200px;\r\n height: 36px;\r\n line-height: 36px;\r\n}\r\n.el-date-editor.el-input {\r\n width: 200px;\r\n height: 36px;\r\n line-height: 36px;\r\n}\r\n::v-deep .el-date-editor.el-input .el-input__inner {\r\n height: 36px;\r\n line-height: 36px;\r\n}\r\n/* 单位框背景颜色 */\r\n::v-deep .vue-treeselect__control {\r\n background: #004d86 !important;\r\n color: #fff;\r\n}\r\n/* 单位下拉菜单选中字体颜色 */\r\n::v-deep .vue-treeselect__single-value {\r\n color: #fff !important;\r\n}\r\n/* 分页按钮 */\r\n::v-deep .el-pagination.is-background .el-pager li {\r\n background-color: #004d86;\r\n color: #fff;\r\n}\r\n::v-deep .el-pagination.is-background .btn-next {\r\n background-color: #004d86;\r\n color: #fff;\r\n}\r\n::v-deep .el-pagination.is-background .btn-prev,\r\n.el-pagination.is-background .btn-next,\r\n.el-pagination.is-background .el-pager li {\r\n background: #004d86 !important;\r\n color: #fff !important;\r\n}\r\n/* 状态 */\r\n.el-radio {\r\n color: rgb(204, 198, 198);\r\n}\r\n/* 计数器按钮 */\r\n::v-deep .el-input-number__increase {\r\n background-color: transparent !important;\r\n border: none;\r\n color: #cccccc;\r\n border-bottom: none !important;\r\n}\r\n::v-deep .el-input-number__decrease {\r\n background-color: transparent !important;\r\n border: none !important;\r\n color: #cccccc;\r\n}\r\n</style>>\r\n\r\n"]}]}
|