a3df2ee627a96fe74d3076c714053f13.json 12 KB

1
  1. {"remainingRequest":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/system/role/components/upDateRoleDialog.vue?vue&type=style&index=0&id=2355fe1d&lang=scss&scoped=true","dependencies":[{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/system/role/components/upDateRoleDialog.vue","mtime":1708395041892},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/css-loader/dist/cjs.js","mtime":1708395146948},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/loaders/stylePostLoader.js","mtime":1708395147772},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/postcss-loader/src/index.js","mtime":1708395147225},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/sass-loader/dist/cjs.js","mtime":1708395146389},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js","mtime":1708395147382}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:CgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCgoKCjo6di1kZWVwIC5lbC1kaWFsb2dfX2JvZHl7CiAgcGFkZGluZzogMjBweCA5NXB4ICFpbXBvcnRhbnQ7Cn0KLmRpYWxvZy1mb290ZXJ7ICAgIAogICAgZGl2IHsgICAgICAgIAogICAgICAgIGRpc3BsYXk6IGlubGluZS1ibG9jazsKICAgICAgICB3aWR0aDogODBweDsKICAgICAgICBoZWlnaHQ6IDQwcHg7CiAgICAgICAgYm9yZGVyLXJhZGl1czogMnB4OwogICAgICAgIGZvbnQtc2l6ZTogMTRweDsKICAgICAgICBsaW5lLWhlaWdodDogNDBweDsKICAgICAgICB0ZXh0LWFsaWduOiBjZW50ZXI7CiAgICAgIH0KCiAgICAgIGRpdjpob3ZlciB7CiAgICAgICAgY3Vyc29yOiBwb2ludGVyOwogICAgICB9CiAgICAgIC5zZWFyY2ggewogICAgICAgIG1hcmdpbjogMCAxMnB4OwogICAgICAgIGJhY2tncm91bmQtY29sb3I6ICMyNzY2REQ7CiAgICAgICAgY29sb3I6ICNmZmY7CiAgICAgIH0KCiAgICAgIC5zZWFyY2g6aG92ZXIgewogICAgICAgIGJhY2tncm91bmQtY29sb3I6ICM0RDg1RjQ7CiAgICAgIH0KICAgICAgLnJlc2V0IHsKICAgICAgICBjb2xvcjogIzMzMzMzNDsKICAgICAgICBib3JkZXI6IDFweCBzb2xpZCAjRDdEN0Q3OwogICAgICB9CgogICAgICAucmVzZXQ6aG92ZXIgewogICAgICAgIGNvbG9yOiAjMUY5RkZGOwogICAgICAgIGJvcmRlcjogMXB4IHNvbGlkICMxRjlGRkY7CiAgICAgIH0KfQovLyDpgInkuK3lkI5yYWRpb+aWh+acrOeahOminOiJsgo6OnYtZGVlcCAuZWwtcmFkaW9fX2lucHV0LmlzLWNoZWNrZWQrLmVsLXJhZGlvX19sYWJlbCB7CiAgICBjb2xvcjogIzI3NjZERAp9CgovKiByYWRpb+mAieS4reWQjuWwj+WchueCueeahOminOiJsiAqLwo6OnYtZGVlcCAuZWwtcmFkaW9fX2lucHV0LmlzLWNoZWNrZWQgLmVsLXJhZGlvX19pbm5lciB7CiAgICBiYWNrZ3JvdW5kOiAjMjc2NkREICFpbXBvcnRhbnQ7CiAgICBib3JkZXItY29sb3I6ICMyNzY2REQgIWltcG9ydGFudDsKfQo="},{"version":3,"sources":["upDateRoleDialog.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmKA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA","file":"upDateRoleDialog.vue","sourceRoot":"src/views/system/role/components","sourcesContent":["<template>\n <div class=\"updataRoleDialog\">\n <el-dialog width=\"636px\" center title=\"修改角色\" :visible.sync=\"updateRoleData.dialogVisible\"> \n <el-form label-width=\"100px\" ref=\"ruleForm\" :rules=\"rules\" :model=\"updateRoleData.data\">\n <el-form-item label=\"角色名称:\" prop=\"roleName\">\n <el-input v-model=\"updateRoleData.data.roleName\"></el-input>\n </el-form-item>\n <el-form-item label=\"权限字符:\" prop=\"roleKey\">\n <el-input :disabled=\"updateRoleData.data.roleId == 1\" v-model=\"updateRoleData.data.roleKey\"></el-input>\n </el-form-item>\n <el-form-item label=\"显示排序:\" prop=\"roleSort\">\n <el-input v-model=\"updateRoleData.data.roleSort\" type=\"text\"\n onkeyup=\"this.value=this.value.replace(/\\D/g,'')\"\n onafterpaste=\"this.value=this.value.replace(/\\D/g,'')\" />\n </el-form-item>\n <el-form-item label=\"状态:\" prop=\"status\">\n <el-radio :disabled=\"updateRoleData.data.roleId == 1\" v-model=\"updateRoleData.data.status\"\n label=\"1\">启用</el-radio>\n <el-radio :disabled=\"updateRoleData.data.roleId == 1\" v-model=\"updateRoleData.data.status\"\n label=\"2\">停用</el-radio>\n </el-form-item>\n <el-form-item label=\"菜单权限:\">\n <div style=\"height: 400px;overflow: auto;\">\n <el-checkbox v-model=\"checkAll\" @change=\"handleCheckAllChange\">全选</el-checkbox>\n <!-- <el-tree :data=\"meunTreeData\" :show-checkbox=\"true\" ref=\"tree\" node-key=\"id\" \n :check-strictly=\"checkStrictly\" :default-expand-all=\"true\"\n :default-checked-keys='updateRoleData.data.menuIds' \n @check-change=\"handleCheckChange\" \n >\n </el-tree> -->\n <el-tree :data=\"meunTreeData\" :show-checkbox=\"true\" ref=\"tree\" node-key=\"id\"\n :check-strictly=\"checkStrictly\" @check=\"getCurrentNode\"\n :default-checked-keys=\"this.updateRoleData.data.menuIds\" :default-expand-all=\"true\"\n @check-change=\"handleCheckChange\">\n </el-tree>\n </div>\n </el-form-item> \n </el-form>\n <span slot=\"footer\" class=\"dialog-footer\">\n <!-- <el-button @click=\"cancel()\">取 消</el-button>\n <el-button type=\"primary\" @click=\"updateRole\">保 存</el-button> -->\n <div class=\"search\" @click=\"updateRole\">保 存</div>\n <div class=\"reset\" @click=\"cancel()\">取 消</div>\n </span>\n </el-dialog>\n </div>\n</template>\n<script>\nimport { getMenuTree, addRole,roleDetaile } from '@/api/sysManage'\nexport default {\n name: 'updateRoleDialog',\n props: {\n updateRoleData: {\n type: Object,\n default: {}\n }\n },\n created() { \n this.getMenuTree() \n }, \n data() {\n return { \n checkAll: false,\n checkStrictly: true,\n defaultExpanded: [],\n meunTreeData: [],\n rules: {\n roleName: [{ required: true, message: '请输入角色名称', trigger: 'blur' }],\n roleKey: [{ required: true, message: '请输入权限字符', trigger: 'blur' }],\n roleSort: [{ required: true, message: '请输入显示排序', trigger: 'blur' }],\n status: [{ required: true, message: '请选择状态', trigger: 'blur' }],\n },\n menuIds:[]\n }\n },\n methods: {\n handleCheckAllChange(val) {\n if (this.checkAll) {\n this.checkStrictly = false\n this.$refs.tree.setCheckedNodes(this.meunTreeData);\n } else {\n this.checkStrictly = true\n this.$refs.tree.setCheckedKeys([]);\n }\n },\n getMenuTree() {\n getMenuTree().then(res => {\n if (res.code == 200) {\n this.defaultExpanded = []\n res.data.forEach(item => {\n this.defaultExpanded.push(item.id)\n })\n this.meunTreeData = res.data\n }\n })\n }, \n handleCheckChange(data, checked, indeterminate) { \n // //获取所有选中的子节点\n // let checkedKeys = this.$refs.tree.getCheckedKeys()\n // //获取所有选中的父节点(半选中)\n // let hafCheckedKeys = this.$refs.tree.getHalfCheckedKeys()\n // //组合\n // let menuIds = checkedKeys.concat(hafCheckedKeys) \n // // let menuIds = checkedKeys \n // this.menuIds = menuIds \n // // this.updateRoleData.data.menuIds = menuIds\n\n const AllcheckedNodes = this.$refs.tree.getCheckedNodes(false, true);\n let arrDeptId = []\n AllcheckedNodes.forEach((item) => {\n arrDeptId.push(item.id)\n })\n this.updateRoleData.data.menuIds = arrDeptId\n },\n updateRole() {\n this.$refs.ruleForm.validate(valid => { \n if (valid) { \n // this.handleCheckChange()\n if (this.updateRoleData.data.menuIds.length != 0) { \n // this.updateRoleData.data.menuIds = this.menuIds\n this.$emit(\"updateRoleBtn\", this.updateRoleData.data) \n } else {\n this.$message({\n type: 'warning',\n message: '请选择菜单权限!'\n });\n }\n }\n })\n },\n cancel() {\n this.updateRoleData.dialogVisible = false\n this.getMenuTree()\n },\n closeDialog() {\n this.getMenuTree()\n },\n getCurrentNode(data) {\n const node = this.$refs.tree.getNode(data);\n this.childNodes(node);\n this.parentNodes(node);\n },\n childNodes(node) { \n const len = node.childNodes.length; \n for (let i = 0; i < len; i += 1) {\n node.childNodes[i].checked = node.checked;\n this.childNodes(node.childNodes[i]);\n }\n },\n parentNodes(node) { \n if (node.parent) { \n for (const key in node) { \n if (key === 'parent') {\n node[key].checked = true;\n this.parentNodes(node[key]);\n }\n }\n }\n },\n }\n}\n</script>\n<style lang=\"scss\" scoped>\n::v-deep .el-dialog__body{\n padding: 20px 95px !important;\n}\n.dialog-footer{ \n div { \n display: inline-block;\n width: 80px;\n height: 40px;\n border-radius: 2px;\n font-size: 14px;\n line-height: 40px;\n text-align: center;\n }\n\n div:hover {\n cursor: pointer;\n }\n .search {\n margin: 0 12px;\n background-color: #2766DD;\n color: #fff;\n }\n\n .search:hover {\n background-color: #4D85F4;\n }\n .reset {\n color: #333334;\n border: 1px solid #D7D7D7;\n }\n\n .reset:hover {\n color: #1F9FFF;\n border: 1px solid #1F9FFF;\n }\n}\n// 选中后radio文本的颜色\n::v-deep .el-radio__input.is-checked+.el-radio__label {\n color: #2766DD\n}\n\n/* radio选中后小圆点的颜色 */\n::v-deep .el-radio__input.is-checked .el-radio__inner {\n background: #2766DD !important;\n border-color: #2766DD !important;\n}\n</style>"]}]}