2f05f5031962ec2ce329db1f8f3b49ba.json 32 KB

1
  1. {"remainingRequest":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js!E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js??ref--0-2!E:\\item\\newItem\\admin\\src\\pages\\setting\\systemRole\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"E:\\item\\newItem\\admin\\src\\pages\\setting\\systemRole\\index.vue","mtime":1677828270238},{"path":"E:\\item\\newItem\\admin\\babel.config.js","mtime":1677828270071},{"path":"E:\\item\\newItem\\admin\\.babelrc","mtime":1677828270070},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"E:\\item\\newItem\\admin\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000},{"path":"E:\\item\\newItem\\admin\\node_modules\\iview-loader\\index.js","mtime":1570440814000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _asyncToGenerator from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import _objectSpread from "E:/item/newItem/admin/node_modules/@vue/babel-preset-app/node_modules/@babel/runtime/helpers/esm/objectSpread2.js";
import "regenerator-runtime/runtime.js";
import "core-js/modules/es.array.splice.js";
import "core-js/modules/es.array.map.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import { mapState } from 'vuex';
import { roleListApi, roleSetStatusApi, menusListApi, roleCreatApi, roleInfoApi } from '@/api/setting';
export default {
  name: 'systemrRole',
  data: function data() {
    return {
      spinShow: false,
      modals: false,
      total: 0,
      grid: {
        xl: 7,
        lg: 7,
        md: 12,
        sm: 24,
        xs: 24
      },
      loading: false,
      formValidate: {
        status: '',
        role_name: '',
        page: 1,
        limit: 20
      },
      columns1: [{
        title: 'ID',
        key: 'id',
        width: 80
      }, {
        title: '身份昵称',
        key: 'role_name',
        minWidth: 120
      }, {
        title: '权限',
        key: 'rules',
        tooltip: true,
        width: 1000
      }, {
        title: '状态',
        slot: 'is_shows',
        minWidth: 120
      }, {
        title: '操作',
        slot: 'action',
        fixed: 'right',
        minWidth: 120
      }],
      tableList: [],
      formInline: {
        role_name: '',
        status: 0,
        checked_menus: [],
        id: 0
      },
      menusList: [],
      modelTit: '',
      ruleValidate: {
        role_name: [{
          required: true,
          message: '请输入身份昵称',
          trigger: 'blur'
        }],
        status: [{
          required: true,
          type: 'number',
          message: '请选择是否开启',
          trigger: 'change'
        }] // checked_menus: [
        //     { required: true, validator: validateStatus, trigger: 'change' }
        // ]

      }
    };
  },
  computed: _objectSpread(_objectSpread({}, mapState('media', ['isMobile'])), {}, {
    labelWidth: function labelWidth() {
      return this.isMobile ? undefined : 75;
    },
    labelPosition: function labelPosition() {
      return this.isMobile ? 'top' : 'left';
    },
    labelPosition2: function labelPosition2() {
      return this.isMobile ? 'top' : 'right';
    }
  }),
  created: function created() {
    this.getList();
  },
  methods: {
    // 添加
    add: function add(name) {
      this.formInline.id = 0;
      this.modelTit = name;
      this.modals = true;
      this.getmenusList();
    },
    // 删除
    del: function del(row, tit, num) {
      var _this = this;

      var delfromData = {
        title: tit,
        num: num,
        url: "setting/role/".concat(row.id),
        method: 'DELETE',
        ids: ''
      };
      this.$modalSure(delfromData).then(function (res) {
        _this.$Message.success(res.msg);

        _this.tableList.splice(num, 1);
      }).catch(function (res) {
        _this.$Message.error(res.msg);
      });
    },
    // 修改是否显示
    onchangeIsShow: function onchangeIsShow(row) {
      var _this2 = this;

      var data = {
        id: row.id,
        status: row.status
      };
      roleSetStatusApi(data).then( /*#__PURE__*/function () {
        var _ref = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee(res) {
          return regeneratorRuntime.wrap(function _callee$(_context) {
            while (1) {
              switch (_context.prev = _context.next) {
                case 0:
                  _this2.$Message.success(res.msg);

                case 1:
                case "end":
                  return _context.stop();
              }
            }
          }, _callee);
        }));

        return function (_x) {
          return _ref.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this2.$Message.error(res.msg);
      });
    },
    // 列表
    getList: function getList() {
      var _this3 = this;

      this.loading = true;
      this.formValidate.status = this.formValidate.status || '';
      roleListApi(this.formValidate).then( /*#__PURE__*/function () {
        var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(res) {
          var data;
          return regeneratorRuntime.wrap(function _callee2$(_context2) {
            while (1) {
              switch (_context2.prev = _context2.next) {
                case 0:
                  data = res.data;
                  _this3.tableList = data.list;
                  _this3.total = res.data.count;
                  _this3.loading = false;

                case 4:
                case "end":
                  return _context2.stop();
              }
            }
          }, _callee2);
        }));

        return function (_x2) {
          return _ref2.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this3.loading = false;

        _this3.$Message.error(res.msg);
      });
    },
    pageChange: function pageChange(index) {
      this.formValidate.page = index;
      this.getList();
    },
    // 表格搜索
    userSearchs: function userSearchs() {
      this.formValidate.page = 1;
      this.getList();
    },
    // 编辑
    edit: function edit(row, name) {
      this.modelTit = name;
      this.formInline.id = row.id;
      this.modals = true;
      this.rows = row;
      this.getIofo(row);
    },
    // 菜单列表
    getmenusList: function getmenusList() {
      var _this4 = this;

      this.spinShow = true;
      menusListApi().then( /*#__PURE__*/function () {
        var _ref3 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3(res) {
          var data;
          return regeneratorRuntime.wrap(function _callee3$(_context3) {
            while (1) {
              switch (_context3.prev = _context3.next) {
                case 0:
                  data = res.data;
                  _this4.menusList = data.menus;

                  _this4.menusList.map(function (item, index) {
                    if (item.title === '主页') {
                      item.checked = true;
                      item.disableCheckbox = true;

                      if (item.children.length) {
                        item.children.map(function (v) {
                          v.checked = true;
                          v.disableCheckbox = true;
                        });
                      }
                    }

                    item.expand = false;
                  });

                  _this4.spinShow = false;

                case 4:
                case "end":
                  return _context3.stop();
              }
            }
          }, _callee3);
        }));

        return function (_x3) {
          return _ref3.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this4.spinShow = false;

        _this4.$Message.error(res.msg);
      });
    },
    // 详情
    getIofo: function getIofo(row) {
      var _this5 = this;

      this.spinShow = true;
      roleInfoApi(row.id).then( /*#__PURE__*/function () {
        var _ref4 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4(res) {
          var data;
          return regeneratorRuntime.wrap(function _callee4$(_context4) {
            while (1) {
              switch (_context4.prev = _context4.next) {
                case 0:
                  data = res.data;
                  _this5.formInline = data.role || _this5.formInline;
                  _this5.formInline.checked_menus = _this5.formInline.rules;

                  _this5.tidyRes(data.menus);

                  _this5.spinShow = false;

                case 5:
                case "end":
                  return _context4.stop();
              }
            }
          }, _callee4);
        }));

        return function (_x4) {
          return _ref4.apply(this, arguments);
        };
      }()).catch(function (res) {
        _this5.spinShow = false;

        _this5.$Message.error(res.msg);
      });
    },
    tidyRes: function tidyRes(menus) {
      var _this6 = this;

      var data = [];
      menus.map(function (menu) {
        if (menu.title === '主页') {
          menu.checked = true;
          menu.disableCheckbox = true;

          if (menu.children.length) {
            menu.children.map(function (v) {
              v.checked = true;
              v.disableCheckbox = true;
            });
          }

          data.push(menu);
        } else {
          data.push(_this6.initMenu(menu));
        }
      });
      this.$set(this, 'menusList', data);
    },
    initMenu: function initMenu(menu) {
      var _this7 = this;

      var data = {},
          checkMenus = ',' + this.formInline.checked_menus + ',';
      data.title = menu.title;
      data.id = menu.id;

      if (menu.children && menu.children.length > 0) {
        data.children = [];
        menu.children.map(function (child) {
          data.children.push(_this7.initMenu(child));
        });
      } else {
        data.checked = checkMenus.indexOf(String(',' + data.id + ',')) !== -1;
        data.expand = !data.checked;
      }

      return data;
    },
    // 提交
    handleSubmit: function handleSubmit(name) {
      var _this8 = this;

      this.$refs[name].validate(function (valid) {
        if (valid) {
          _this8.formInline.checked_menus = [];

          _this8.$refs.tree.getCheckedAndIndeterminateNodes().map(function (node) {
            _this8.formInline.checked_menus.push(node.id);
          });

          if (_this8.formInline.checked_menus.length === 0) return _this8.$Message.warning('请至少选择一个权限');
          roleCreatApi(_this8.formInline).then( /*#__PURE__*/function () {
            var _ref5 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee5(res) {
              return regeneratorRuntime.wrap(function _callee5$(_context5) {
                while (1) {
                  switch (_context5.prev = _context5.next) {
                    case 0:
                      _this8.$Message.success(res.msg);

                      _this8.modals = false;

                      _this8.getList();

                      _this8.$refs[name].resetFields();

                      _this8.formInline.checked_menus = [];

                    case 5:
                    case "end":
                      return _context5.stop();
                  }
                }
              }, _callee5);
            }));

            return function (_x5) {
              return _ref5.apply(this, arguments);
            };
          }()).catch(function (res) {
            _this8.$Message.error(res.msg);
          });
        } else {
          return false;
        }
      });
    },
    onCancel: function onCancel() {
      this.$refs['formInline'].resetFields();
      this.formInline.checked_menus = [];
    }
  }
};"},{"version":3,"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2HA;AACA;AACA;EACAA,mBADA;EAEAC,IAFA,kBAEA;IACA;MACAC,eADA;MAEAC,aAFA;MAGAC,QAHA;MAIAC;QACAC,KADA;QAEAC,KAFA;QAGAC,MAHA;QAIAC,MAJA;QAKAC;MALA,CAJA;MAWAC,cAXA;MAYAC;QACAC,UADA;QAEAC,aAFA;QAGAC,OAHA;QAIAC;MAJA,CAZA;MAkBAC,WACA;QACAC,WADA;QAEAC,SAFA;QAGAC;MAHA,CADA,EAMA;QACAF,aADA;QAEAC,gBAFA;QAGAE;MAHA,CANA,EAWA;QACAH,WADA;QAEAC,YAFA;QAGAG,aAHA;QAIAF;MAJA,CAXA,EAiBA;QACAF,WADA;QAEAK,gBAFA;QAGAF;MAHA,CAjBA,EAsBA;QACAH,WADA;QAEAK,cAFA;QAGAC,cAHA;QAIAH;MAJA,CAtBA,CAlBA;MA+CAI,aA/CA;MAgDAC;QACAZ,aADA;QAEAD,SAFA;QAGAc,iBAHA;QAIAC;MAJA,CAhDA;MAsDAC,aAtDA;MAuDAC,YAvDA;MAwDAC;QACAjB;UAAAkB;UAAAC;UAAAC;QAAA,EADA;QAEArB;UAAAmB;UAAAG;UAAAF;UAAAC;QAAA,EAFA,CAGA;QACA;QACA;;MALA;IAxDA;EAgEA,CAnEA;EAoEAE,0CACAC,+BADA;IAEAC,UAFA,wBAEA;MACA;IACA,CAJA;IAKAC,aALA,2BAKA;MACA;IACA,CAPA;IAQAC,cARA,4BAQA;MACA;IACA;EAVA,EApEA;EAgFAC,OAhFA,qBAgFA;IACA;EACA,CAlFA;EAmFAC;IACA;IACAC,GAFA,eAEA3C,IAFA,EAEA;MACA;MACA;MACA;MACA;IACA,CAPA;IAQA;IACA4C,GATA,eASAC,GATA,EASAC,GATA,EASAC,GATA,EASA;MAAA;;MACA;QACA7B,UADA;QAEA6B,QAFA;QAGAC,mCAHA;QAIAC,gBAJA;QAKAC;MALA;MAOA,6BACAC,IADA,CACA;QACA;;QACA;MACA,CAJA,EAKAC,KALA,CAKA;QACA;MACA,CAPA;IAQA,CAzBA;IA0BA;IACAC,cA3BA,0BA2BAR,GA3BA,EA2BA;MAAA;;MACA;QACAjB,UADA;QAEAf;MAFA;MAIAyC,uBACAH,IADA;QAAA,mEACA;UAAA;YAAA;cAAA;gBAAA;kBACA;;gBADA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CADA;;QAAA;UAAA;QAAA;MAAA,KAIAC,KAJA,CAIA;QACA;MACA,CANA;IAOA,CAvCA;IAwCA;IACAG,OAzCA,qBAyCA;MAAA;;MACA;MACA;MACAC,+BACAL,IADA;QAAA,oEACA;UAAA;UAAA;YAAA;cAAA;gBAAA;kBACAlD,IADA,GACAwD,QADA;kBAEA;kBACA;kBACA;;gBAJA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CADA;;QAAA;UAAA;QAAA;MAAA,KAOAL,KAPA,CAOA;QACA;;QACA;MACA,CAVA;IAWA,CAvDA;IAwDAM,UAxDA,sBAwDAC,KAxDA,EAwDA;MACA;MACA;IACA,CA3DA;IA4DA;IACAC,WA7DA,yBA6DA;MACA;MACA;IACA,CAhEA;IAiEA;IACAC,IAlEA,gBAkEAhB,GAlEA,EAkEA7C,IAlEA,EAkEA;MACA;MACA;MACA;MACA;MACA;IACA,CAxEA;IAyEA;IACA8D,YA1EA,0BA0EA;MAAA;;MACA;MACAC,eACAZ,IADA;QAAA,oEACA;UAAA;UAAA;YAAA;cAAA;gBAAA;kBACAlD,IADA,GACAwD,QADA;kBAEA;;kBACA;oBACA;sBACAO;sBACAA;;sBACA;wBACAA;0BACAC;0BACAA;wBACA,CAHA;sBAIA;oBACA;;oBACAD;kBACA,CAZA;;kBAaA;;gBAhBA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CADA;;QAAA;UAAA;QAAA;MAAA,KAmBAZ,KAnBA,CAmBA;QACA;;QACA;MACA,CAtBA;IAuBA,CAnGA;IAoGA;IACAc,OArGA,mBAqGArB,GArGA,EAqGA;MAAA;;MACA;MACAsB,oBACAhB,IADA;QAAA,oEACA;UAAA;UAAA;YAAA;cAAA;gBAAA;kBACAlD,IADA,GACAwD,QADA;kBAEA;kBACA;;kBACA;;kBACA;;gBALA;gBAAA;kBAAA;cAAA;YAAA;UAAA;QAAA,CADA;;QAAA;UAAA;QAAA;MAAA,KAQAL,KARA,CAQA;QACA;;QACA;MACA,CAXA;IAYA,CAnHA;IAoHAgB,OApHA,mBAoHAC,KApHA,EAoHA;MAAA;;MACA;MACAA;QACA;UACAC;UACAA;;UACA;YACAA;cACAL;cACAA;YACA,CAHA;UAIA;;UACAhE;QACA,CAVA,MAUA;UACAA;QACA;MACA,CAdA;MAeA;IACA,CAtIA;IAuIAsE,QAvIA,oBAuIAD,IAvIA,EAuIA;MAAA;;MACA;MAAA,IACAE,sDADA;MAEAvE;MACAA;;MACA;QACAA;QACAqE;UACArE;QACA,CAFA;MAGA,CALA,MAKA;QACAA;QACAA;MACA;;MACA;IACA,CAtJA;IAuJA;IACAwE,YAxJA,wBAwJAzE,IAxJA,EAwJA;MAAA;;MACA;QACA;UACA;;UACA;YACA;UACA,CAFA;;UAGA;UACA0E,gCACAvB,IADA;YAAA,oEACA;cAAA;gBAAA;kBAAA;oBAAA;sBACA;;sBACA;;sBACA;;sBACA;;sBACA;;oBALA;oBAAA;sBAAA;kBAAA;gBAAA;cAAA;YAAA,CADA;;YAAA;cAAA;YAAA;UAAA,KAQAC,KARA,CAQA;YACA;UACA,CAVA;QAWA,CAjBA,MAiBA;UACA;QACA;MACA,CArBA;IAsBA,CA/KA;IAgLAuB,QAhLA,sBAgLA;MACA;MACA;IACA;EAnLA;AAnFA","names":["name","data","spinShow","modals","total","grid","xl","lg","md","sm","xs","loading","formValidate","status","role_name","page","limit","columns1","title","key","width","minWidth","tooltip","slot","fixed","tableList","formInline","checked_menus","id","menusList","modelTit","ruleValidate","required","message","trigger","type","computed","mapState","labelWidth","labelPosition","labelPosition2","created","methods","add","del","row","tit","num","url","method","ids","then","catch","onchangeIsShow","roleSetStatusApi","getList","roleListApi","res","pageChange","index","userSearchs","edit","getmenusList","menusListApi","item","v","getIofo","roleInfoApi","tidyRes","menus","menu","initMenu","checkMenus","handleSubmit","roleCreatApi","onCancel"],"sourceRoot":"src/pages/setting/systemRole","sources":["index.vue"],"sourcesContent":["<template>\r\n <div>\r\n <Card :bordered=\"false\" dis-hover class=\"ivu-mt\">\r\n <Form\r\n ref=\"formValidate\"\r\n :model=\"formValidate\"\r\n :label-width=\"labelWidth\"\r\n :label-position=\"labelPosition\"\r\n @submit.native.prevent\r\n >\r\n <Row type=\"flex\" :gutter=\"24\">\r\n <Col v-bind=\"grid\">\r\n <FormItem label=\"状态:\" label-for=\"status\">\r\n <Select v-model=\"formValidate.status\" placeholder=\"请选择\" @on-change=\"userSearchs\" clearable>\r\n <Option value=\"1\">显示</Option>\r\n <Option value=\"0\">不显示</Option>\r\n </Select>\r\n </FormItem>\r\n </Col>\r\n <Col v-bind=\"grid\">\r\n <FormItem label=\"身份昵称:\" label-for=\"role_name\">\r\n <Input\r\n search\r\n enter-button\r\n placeholder=\"请输入身份昵称\"\r\n v-model=\"formValidate.role_name\"\r\n @on-search=\"userSearchs\"\r\n />\r\n </FormItem>\r\n </Col>\r\n </Row>\r\n <Row type=\"flex\">\r\n <Col v-bind=\"grid\">\r\n <Button v-auth=\"['setting-system_role-add']\" type=\"primary\" icon=\"md-add\" @click=\"add('添加')\"\r\n >添加身份</Button\r\n >\r\n </Col>\r\n </Row>\r\n </Form>\r\n <Table\r\n :columns=\"columns1\"\r\n :data=\"tableList\"\r\n ref=\"table\"\r\n class=\"mt25\"\r\n :loading=\"loading\"\r\n highlight-row\r\n no-userFrom-text=\"暂无数据\"\r\n no-filtered-userFrom-text=\"暂无筛选结果\"\r\n >\r\n <template slot-scope=\"{ row, index }\" slot=\"is_shows\">\r\n <i-switch\r\n v-model=\"row.status\"\r\n :value=\"row.status\"\r\n :true-value=\"1\"\r\n :false-value=\"0\"\r\n @on-change=\"onchangeIsShow(row)\"\r\n size=\"large\"\r\n >\r\n <span slot=\"open\">显示</span>\r\n <span slot=\"close\">隐藏</span>\r\n </i-switch>\r\n </template>\r\n <template slot-scope=\"{ row, index }\" slot=\"action\">\r\n <a @click=\"edit(row, '编辑')\">编辑</a>\r\n <Divider type=\"vertical\" />\r\n <a @click=\"del(row, '删除', index)\">删除</a>\r\n </template>\r\n </Table>\r\n <div class=\"acea-row row-right page\">\r\n <Page\r\n :total=\"total\"\r\n :current=\"formValidate.page\"\r\n show-elevator\r\n show-total\r\n @on-change=\"pageChange\"\r\n :page-size=\"formValidate.limit\"\r\n />\r\n </div>\r\n </Card>\r\n <!-- 新增编辑-->\r\n <Modal\r\n v-model=\"modals\"\r\n @on-cancel=\"onCancel\"\r\n scrollable\r\n footer-hide\r\n closable\r\n :title=\"`${modelTit}身份`\"\r\n :mask-closable=\"false\"\r\n width=\"600\"\r\n >\r\n <Form\r\n ref=\"formInline\"\r\n :model=\"formInline\"\r\n :rules=\"ruleValidate\"\r\n :label-width=\"100\"\r\n :label-position=\"labelPosition2\"\r\n @submit.native.prevent\r\n >\r\n <FormItem label=\"身份名称:\" label-for=\"role_name\" prop=\"role_name\">\r\n <Input placeholder=\"请输入身份昵称\" v-model=\"formInline.role_name\" />\r\n </FormItem>\r\n <FormItem label=\"是否开启:\" prop=\"status\">\r\n <RadioGroup v-model=\"formInline.status\">\r\n <Radio :label=\"1\">开启</Radio>\r\n <Radio :label=\"0\">关闭</Radio>\r\n </RadioGroup>\r\n </FormItem>\r\n <FormItem label=\"权限:\">\r\n <div class=\"trees-coadd\">\r\n <div class=\"scollhide\">\r\n <div class=\"iconlist\">\r\n <Tree :data=\"menusList\" show-checkbox ref=\"tree\"></Tree>\r\n </div>\r\n </div>\r\n </div>\r\n </FormItem>\r\n <Spin size=\"large\" fix v-if=\"spinShow\"></Spin>\r\n <Button type=\"primary\" size=\"large\" long @click=\"handleSubmit('formInline')\">提交</Button>\r\n </Form>\r\n </Modal>\r\n </div>\r\n</template>\r\n<script>\r\nimport { mapState } from 'vuex';\r\nimport { roleListApi, roleSetStatusApi, menusListApi, roleCreatApi, roleInfoApi } from '@/api/setting';\r\nexport default {\r\n name: 'systemrRole',\r\n data() {\r\n return {\r\n spinShow: false,\r\n modals: false,\r\n total: 0,\r\n grid: {\r\n xl: 7,\r\n lg: 7,\r\n md: 12,\r\n sm: 24,\r\n xs: 24,\r\n },\r\n loading: false,\r\n formValidate: {\r\n status: '',\r\n role_name: '',\r\n page: 1,\r\n limit: 20,\r\n },\r\n columns1: [\r\n {\r\n title: 'ID',\r\n key: 'id',\r\n width: 80,\r\n },\r\n {\r\n title: '身份昵称',\r\n key: 'role_name',\r\n minWidth: 120,\r\n },\r\n {\r\n title: '权限',\r\n key: 'rules',\r\n tooltip: true,\r\n width: 1000,\r\n },\r\n {\r\n title: '状态',\r\n slot: 'is_shows',\r\n minWidth: 120,\r\n },\r\n {\r\n title: '操作',\r\n slot: 'action',\r\n fixed: 'right',\r\n minWidth: 120,\r\n },\r\n ],\r\n tableList: [],\r\n formInline: {\r\n role_name: '',\r\n status: 0,\r\n checked_menus: [],\r\n id: 0,\r\n },\r\n menusList: [],\r\n modelTit: '',\r\n ruleValidate: {\r\n role_name: [{ required: true, message: '请输入身份昵称', trigger: 'blur' }],\r\n status: [{ required: true, type: 'number', message: '请选择是否开启', trigger: 'change' }],\r\n // checked_menus: [\r\n // { required: true, validator: validateStatus, trigger: 'change' }\r\n // ]\r\n },\r\n };\r\n },\r\n computed: {\r\n ...mapState('media', ['isMobile']),\r\n labelWidth() {\r\n return this.isMobile ? undefined : 75;\r\n },\r\n labelPosition() {\r\n return this.isMobile ? 'top' : 'left';\r\n },\r\n labelPosition2() {\r\n return this.isMobile ? 'top' : 'right';\r\n },\r\n },\r\n created() {\r\n this.getList();\r\n },\r\n methods: {\r\n // 添加\r\n add(name) {\r\n this.formInline.id = 0;\r\n this.modelTit = name;\r\n this.modals = true;\r\n this.getmenusList();\r\n },\r\n // 删除\r\n del(row, tit, num) {\r\n let delfromData = {\r\n title: tit,\r\n num: num,\r\n url: `setting/role/${row.id}`,\r\n method: 'DELETE',\r\n ids: '',\r\n };\r\n this.$modalSure(delfromData)\r\n .then((res) => {\r\n this.$Message.success(res.msg);\r\n this.tableList.splice(num, 1);\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n },\r\n // 修改是否显示\r\n onchangeIsShow(row) {\r\n let data = {\r\n id: row.id,\r\n status: row.status,\r\n };\r\n roleSetStatusApi(data)\r\n .then(async (res) => {\r\n this.$Message.success(res.msg);\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n },\r\n // 列表\r\n getList() {\r\n this.loading = true;\r\n this.formValidate.status = this.formValidate.status || '';\r\n roleListApi(this.formValidate)\r\n .then(async (res) => {\r\n let data = res.data;\r\n this.tableList = data.list;\r\n this.total = res.data.count;\r\n this.loading = false;\r\n })\r\n .catch((res) => {\r\n this.loading = false;\r\n this.$Message.error(res.msg);\r\n });\r\n },\r\n pageChange(index) {\r\n this.formValidate.page = index;\r\n this.getList();\r\n },\r\n // 表格搜索\r\n userSearchs() {\r\n this.formValidate.page = 1;\r\n this.getList();\r\n },\r\n // 编辑\r\n edit(row, name) {\r\n this.modelTit = name;\r\n this.formInline.id = row.id;\r\n this.modals = true;\r\n this.rows = row;\r\n this.getIofo(row);\r\n },\r\n // 菜单列表\r\n getmenusList() {\r\n this.spinShow = true;\r\n menusListApi()\r\n .then(async (res) => {\r\n let data = res.data;\r\n this.menusList = data.menus;\r\n this.menusList.map((item, index) => {\r\n if (item.title === '主页') {\r\n item.checked = true;\r\n item.disableCheckbox = true;\r\n if (item.children.length) {\r\n item.children.map((v) => {\r\n v.checked = true;\r\n v.disableCheckbox = true;\r\n });\r\n }\r\n }\r\n item.expand = false;\r\n });\r\n this.spinShow = false;\r\n })\r\n .catch((res) => {\r\n this.spinShow = false;\r\n this.$Message.error(res.msg);\r\n });\r\n },\r\n // 详情\r\n getIofo(row) {\r\n this.spinShow = true;\r\n roleInfoApi(row.id)\r\n .then(async (res) => {\r\n let data = res.data;\r\n this.formInline = data.role || this.formInline;\r\n this.formInline.checked_menus = this.formInline.rules;\r\n this.tidyRes(data.menus);\r\n this.spinShow = false;\r\n })\r\n .catch((res) => {\r\n this.spinShow = false;\r\n this.$Message.error(res.msg);\r\n });\r\n },\r\n tidyRes(menus) {\r\n let data = [];\r\n menus.map((menu) => {\r\n if (menu.title === '主页') {\r\n menu.checked = true;\r\n menu.disableCheckbox = true;\r\n if (menu.children.length) {\r\n menu.children.map((v) => {\r\n v.checked = true;\r\n v.disableCheckbox = true;\r\n });\r\n }\r\n data.push(menu);\r\n } else {\r\n data.push(this.initMenu(menu));\r\n }\r\n });\r\n this.$set(this, 'menusList', data);\r\n },\r\n initMenu(menu) {\r\n let data = {},\r\n checkMenus = ',' + this.formInline.checked_menus + ',';\r\n data.title = menu.title;\r\n data.id = menu.id;\r\n if (menu.children && menu.children.length > 0) {\r\n data.children = [];\r\n menu.children.map((child) => {\r\n data.children.push(this.initMenu(child));\r\n });\r\n } else {\r\n data.checked = checkMenus.indexOf(String(',' + data.id + ',')) !== -1;\r\n data.expand = !data.checked;\r\n }\r\n return data;\r\n },\r\n // 提交\r\n handleSubmit(name) {\r\n this.$refs[name].validate((valid) => {\r\n if (valid) {\r\n this.formInline.checked_menus = [];\r\n this.$refs.tree.getCheckedAndIndeterminateNodes().map((node) => {\r\n this.formInline.checked_menus.push(node.id);\r\n });\r\n if (this.formInline.checked_menus.length === 0) return this.$Message.warning('请至少选择一个权限');\r\n roleCreatApi(this.formInline)\r\n .then(async (res) => {\r\n this.$Message.success(res.msg);\r\n this.modals = false;\r\n this.getList();\r\n this.$refs[name].resetFields();\r\n this.formInline.checked_menus = [];\r\n })\r\n .catch((res) => {\r\n this.$Message.error(res.msg);\r\n });\r\n } else {\r\n return false;\r\n }\r\n });\r\n },\r\n onCancel() {\r\n this.$refs['formInline'].resetFields();\r\n this.formInline.checked_menus = [];\r\n },\r\n },\r\n};\r\n</script>\r\n\r\n<style scoped lang=\"stylus\">\r\n.trees-coadd\r\n width: 100%;\r\n height: 385px;\r\n .scollhide\r\n width: 100%;\r\n height: 100%;\r\n overflow-x: hidden;\r\n overflow-y: scroll;\r\n // margin-left: 18px;\r\n.scollhide::-webkit-scrollbar {\r\n display: none;\r\n}\r\n</style>\r\n"]}]}