执行过npm install命令的vue-element-admin源码
康凯
2022-05-20 aa4c235a8ca67ea8b731f90c951a465e92c0a865
1
{"remainingRequest":"D:\\源码\\vue-element-admin-master\\node_modules\\babel-loader\\lib\\index.js!D:\\源码\\vue-element-admin-master\\node_modules\\cache-loader\\dist\\cjs.js??ref--0-0!D:\\源码\\vue-element-admin-master\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\源码\\vue-element-admin-master\\src\\views\\permission\\role.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\源码\\vue-element-admin-master\\src\\views\\permission\\role.vue","mtime":1649647926000},{"path":"D:\\源码\\vue-element-admin-master\\babel.config.js","mtime":1649647926000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\源码\\vue-element-admin-master\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:import _objectSpread from "D:/\u6E90\u7801/vue-element-admin-master/node_modules/@babel/runtime/helpers/esm/objectSpread2.js";
import _toConsumableArray from "D:/\u6E90\u7801/vue-element-admin-master/node_modules/@babel/runtime/helpers/esm/toConsumableArray.js";
import _createForOfIteratorHelper from "D:/\u6E90\u7801/vue-element-admin-master/node_modules/@babel/runtime/helpers/esm/createForOfIteratorHelper.js";
import _asyncToGenerator from "D:/\u6E90\u7801/vue-element-admin-master/node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js";
import "core-js/modules/es.object.to-string.js";
import "core-js/modules/web.dom-collections.for-each.js";
import "core-js/modules/es.array.concat.js";
import "core-js/modules/es.array.splice.js";
import "core-js/modules/es.array.includes.js";
import "core-js/modules/es.string.includes.js";
import "core-js/modules/es.symbol.js";
import "core-js/modules/es.symbol.description.js";
import "core-js/modules/es.function.name.js";
import "core-js/modules/es.array.filter.js";
import "regenerator-runtime/runtime.js";
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
import path from 'path';
import { deepClone } from '@/utils';
import { getRoutes as _getRoutes, getRoles as _getRoles, addRole, deleteRole, updateRole } from '@/api/role';
var defaultRole = {
  key: '',
  name: '',
  description: '',
  routes: []
};
export default {
  data: function data() {
    return {
      role: Object.assign({}, defaultRole),
      routes: [],
      rolesList: [],
      dialogVisible: false,
      dialogType: 'new',
      checkStrictly: false,
      defaultProps: {
        children: 'children',
        label: 'title'
      }
    };
  },
  computed: {
    routesData: function routesData() {
      return this.routes;
    }
  },
  created: function created() {
    // Mock: get all routes and roles list from server
    this.getRoutes();
    this.getRoles();
  },
  methods: {
    getRoutes: function getRoutes() {
      var _this = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {
        var res;
        return regeneratorRuntime.wrap(function _callee$(_context) {
          while (1) {
            switch (_context.prev = _context.next) {
              case 0:
                _context.next = 2;
                return _getRoutes();

              case 2:
                res = _context.sent;
                _this.serviceRoutes = res.data;
                _this.routes = _this.generateRoutes(res.data);

              case 5:
              case "end":
                return _context.stop();
            }
          }
        }, _callee);
      }))();
    },
    getRoles: function getRoles() {
      var _this2 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2() {
        var res;
        return regeneratorRuntime.wrap(function _callee2$(_context2) {
          while (1) {
            switch (_context2.prev = _context2.next) {
              case 0:
                _context2.next = 2;
                return _getRoles();

              case 2:
                res = _context2.sent;
                _this2.rolesList = res.data;

              case 4:
              case "end":
                return _context2.stop();
            }
          }
        }, _callee2);
      }))();
    },
    // Reshape the routes structure so that it looks the same as the sidebar
    generateRoutes: function generateRoutes(routes) {
      var basePath = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '/';
      var res = [];

      var _iterator = _createForOfIteratorHelper(routes),
          _step;

      try {
        for (_iterator.s(); !(_step = _iterator.n()).done;) {
          var route = _step.value;

          // skip some route
          if (route.hidden) {
            continue;
          }

          var onlyOneShowingChild = this.onlyOneShowingChild(route.children, route);

          if (route.children && onlyOneShowingChild && !route.alwaysShow) {
            route = onlyOneShowingChild;
          }

          var data = {
            path: path.resolve(basePath, route.path),
            title: route.meta && route.meta.title
          }; // recursive child routes

          if (route.children) {
            data.children = this.generateRoutes(route.children, data.path);
          }

          res.push(data);
        }
      } catch (err) {
        _iterator.e(err);
      } finally {
        _iterator.f();
      }

      return res;
    },
    generateArr: function generateArr(routes) {
      var _this3 = this;

      var data = [];
      routes.forEach(function (route) {
        data.push(route);

        if (route.children) {
          var temp = _this3.generateArr(route.children);

          if (temp.length > 0) {
            data = [].concat(_toConsumableArray(data), _toConsumableArray(temp));
          }
        }
      });
      return data;
    },
    handleAddRole: function handleAddRole() {
      this.role = Object.assign({}, defaultRole);

      if (this.$refs.tree) {
        this.$refs.tree.setCheckedNodes([]);
      }

      this.dialogType = 'new';
      this.dialogVisible = true;
    },
    handleEdit: function handleEdit(scope) {
      var _this4 = this;

      this.dialogType = 'edit';
      this.dialogVisible = true;
      this.checkStrictly = true;
      this.role = deepClone(scope.row);
      this.$nextTick(function () {
        var routes = _this4.generateRoutes(_this4.role.routes);

        _this4.$refs.tree.setCheckedNodes(_this4.generateArr(routes)); // set checked state of a node not affects its father and child nodes


        _this4.checkStrictly = false;
      });
    },
    handleDelete: function handleDelete(_ref) {
      var _this5 = this;

      var $index = _ref.$index,
          row = _ref.row;
      this.$confirm('Confirm to remove the role?', 'Warning', {
        confirmButtonText: 'Confirm',
        cancelButtonText: 'Cancel',
        type: 'warning'
      }).then( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee3() {
        return regeneratorRuntime.wrap(function _callee3$(_context3) {
          while (1) {
            switch (_context3.prev = _context3.next) {
              case 0:
                _context3.next = 2;
                return deleteRole(row.key);

              case 2:
                _this5.rolesList.splice($index, 1);

                _this5.$message({
                  type: 'success',
                  message: 'Delete succed!'
                });

              case 4:
              case "end":
                return _context3.stop();
            }
          }
        }, _callee3);
      }))).catch(function (err) {
        console.error(err);
      });
    },
    generateTree: function generateTree(routes) {
      var basePath = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '/';
      var checkedKeys = arguments.length > 2 ? arguments[2] : undefined;
      var res = [];

      var _iterator2 = _createForOfIteratorHelper(routes),
          _step2;

      try {
        for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
          var route = _step2.value;
          var routePath = path.resolve(basePath, route.path); // recursive child routes

          if (route.children) {
            route.children = this.generateTree(route.children, routePath, checkedKeys);
          }

          if (checkedKeys.includes(routePath) || route.children && route.children.length >= 1) {
            res.push(route);
          }
        }
      } catch (err) {
        _iterator2.e(err);
      } finally {
        _iterator2.f();
      }

      return res;
    },
    confirmRole: function confirmRole() {
      var _this6 = this;

      return _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee4() {
        var isEdit, checkedKeys, index, _yield$addRole, data, _this6$role, description, key, name;

        return regeneratorRuntime.wrap(function _callee4$(_context4) {
          while (1) {
            switch (_context4.prev = _context4.next) {
              case 0:
                isEdit = _this6.dialogType === 'edit';
                checkedKeys = _this6.$refs.tree.getCheckedKeys();
                _this6.role.routes = _this6.generateTree(deepClone(_this6.serviceRoutes), '/', checkedKeys);

                if (!isEdit) {
                  _context4.next = 16;
                  break;
                }

                _context4.next = 6;
                return updateRole(_this6.role.key, _this6.role);

              case 6:
                index = 0;

              case 7:
                if (!(index < _this6.rolesList.length)) {
                  _context4.next = 14;
                  break;
                }

                if (!(_this6.rolesList[index].key === _this6.role.key)) {
                  _context4.next = 11;
                  break;
                }

                _this6.rolesList.splice(index, 1, Object.assign({}, _this6.role));

                return _context4.abrupt("break", 14);

              case 11:
                index++;
                _context4.next = 7;
                break;

              case 14:
                _context4.next = 22;
                break;

              case 16:
                _context4.next = 18;
                return addRole(_this6.role);

              case 18:
                _yield$addRole = _context4.sent;
                data = _yield$addRole.data;
                _this6.role.key = data.key;

                _this6.rolesList.push(_this6.role);

              case 22:
                _this6$role = _this6.role, description = _this6$role.description, key = _this6$role.key, name = _this6$role.name;
                _this6.dialogVisible = false;

                _this6.$notify({
                  title: 'Success',
                  dangerouslyUseHTMLString: true,
                  message: "\n            <div>Role Key: ".concat(key, "</div>\n            <div>Role Name: ").concat(name, "</div>\n            <div>Description: ").concat(description, "</div>\n          "),
                  type: 'success'
                });

              case 25:
              case "end":
                return _context4.stop();
            }
          }
        }, _callee4);
      }))();
    },
    // reference: src/view/layout/components/Sidebar/SidebarItem.vue
    onlyOneShowingChild: function onlyOneShowingChild() {
      var children = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
      var parent = arguments.length > 1 ? arguments[1] : undefined;
      var onlyOneChild = null;
      var showingChildren = children.filter(function (item) {
        return !item.hidden;
      }); // When there is only one child route, the child route is displayed by default

      if (showingChildren.length === 1) {
        onlyOneChild = showingChildren[0];
        onlyOneChild.path = path.resolve(parent.path, onlyOneChild.path);
        return onlyOneChild;
      } // Show parent if there are no child route to display


      if (showingChildren.length === 0) {
        onlyOneChild = _objectSpread(_objectSpread({}, parent), {}, {
          path: '',
          noShowingChildren: true
        });
        return onlyOneChild;
      }

      return false;
    }
  }
};"},{"version":3,"mappings":"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","names":["key","name","description","routes","data","role","rolesList","dialogVisible","dialogType","checkStrictly","defaultProps","children","label","computed","routesData","created","methods","getRoutes","res","getRoles","generateRoutes","route","path","title","generateArr","handleAddRole","handleEdit","scope","handleDelete","confirmButtonText","cancelButtonText","type","then","deleteRole","message","catch","console","generateTree","confirmRole","isEdit","checkedKeys","updateRole","index","addRole","dangerouslyUseHTMLString","onlyOneShowingChild","onlyOneChild","noShowingChildren"],"sourceRoot":"src/views/permission","sources":["role.vue"],"sourcesContent":["<template>\n  <div class=\"app-container\">\n    <el-button type=\"primary\" @click=\"handleAddRole\">New Role</el-button>\n\n    <el-table :data=\"rolesList\" style=\"width: 100%;margin-top:30px;\" border>\n      <el-table-column align=\"center\" label=\"Role Key\" width=\"220\">\n        <template slot-scope=\"scope\">\n          {{ scope.row.key }}\n        </template>\n      </el-table-column>\n      <el-table-column align=\"center\" label=\"Role Name\" width=\"220\">\n        <template slot-scope=\"scope\">\n          {{ scope.row.name }}\n        </template>\n      </el-table-column>\n      <el-table-column align=\"header-center\" label=\"Description\">\n        <template slot-scope=\"scope\">\n          {{ scope.row.description }}\n        </template>\n      </el-table-column>\n      <el-table-column align=\"center\" label=\"Operations\">\n        <template slot-scope=\"scope\">\n          <el-button type=\"primary\" size=\"small\" @click=\"handleEdit(scope)\">Edit</el-button>\n          <el-button type=\"danger\" size=\"small\" @click=\"handleDelete(scope)\">Delete</el-button>\n        </template>\n      </el-table-column>\n    </el-table>\n\n    <el-dialog :visible.sync=\"dialogVisible\" :title=\"dialogType==='edit'?'Edit Role':'New Role'\">\n      <el-form :model=\"role\" label-width=\"80px\" label-position=\"left\">\n        <el-form-item label=\"Name\">\n          <el-input v-model=\"role.name\" placeholder=\"Role Name\" />\n        </el-form-item>\n        <el-form-item label=\"Desc\">\n          <el-input\n            v-model=\"role.description\"\n            :autosize=\"{ minRows: 2, maxRows: 4}\"\n            type=\"textarea\"\n            placeholder=\"Role Description\"\n          />\n        </el-form-item>\n        <el-form-item label=\"Menus\">\n          <el-tree\n            ref=\"tree\"\n            :check-strictly=\"checkStrictly\"\n            :data=\"routesData\"\n            :props=\"defaultProps\"\n            show-checkbox\n            node-key=\"path\"\n            class=\"permission-tree\"\n          />\n        </el-form-item>\n      </el-form>\n      <div style=\"text-align:right;\">\n        <el-button type=\"danger\" @click=\"dialogVisible=false\">Cancel</el-button>\n        <el-button type=\"primary\" @click=\"confirmRole\">Confirm</el-button>\n      </div>\n    </el-dialog>\n  </div>\n</template>\n\n<script>\nimport path from 'path'\nimport { deepClone } from '@/utils'\nimport { getRoutes, getRoles, addRole, deleteRole, updateRole } from '@/api/role'\n\nconst defaultRole = {\n  key: '',\n  name: '',\n  description: '',\n  routes: []\n}\n\nexport default {\n  data() {\n    return {\n      role: Object.assign({}, defaultRole),\n      routes: [],\n      rolesList: [],\n      dialogVisible: false,\n      dialogType: 'new',\n      checkStrictly: false,\n      defaultProps: {\n        children: 'children',\n        label: 'title'\n      }\n    }\n  },\n  computed: {\n    routesData() {\n      return this.routes\n    }\n  },\n  created() {\n    // Mock: get all routes and roles list from server\n    this.getRoutes()\n    this.getRoles()\n  },\n  methods: {\n    async getRoutes() {\n      const res = await getRoutes()\n      this.serviceRoutes = res.data\n      this.routes = this.generateRoutes(res.data)\n    },\n    async getRoles() {\n      const res = await getRoles()\n      this.rolesList = res.data\n    },\n\n    // Reshape the routes structure so that it looks the same as the sidebar\n    generateRoutes(routes, basePath = '/') {\n      const res = []\n\n      for (let route of routes) {\n        // skip some route\n        if (route.hidden) { continue }\n\n        const onlyOneShowingChild = this.onlyOneShowingChild(route.children, route)\n\n        if (route.children && onlyOneShowingChild && !route.alwaysShow) {\n          route = onlyOneShowingChild\n        }\n\n        const data = {\n          path: path.resolve(basePath, route.path),\n          title: route.meta && route.meta.title\n\n        }\n\n        // recursive child routes\n        if (route.children) {\n          data.children = this.generateRoutes(route.children, data.path)\n        }\n        res.push(data)\n      }\n      return res\n    },\n    generateArr(routes) {\n      let data = []\n      routes.forEach(route => {\n        data.push(route)\n        if (route.children) {\n          const temp = this.generateArr(route.children)\n          if (temp.length > 0) {\n            data = [...data, ...temp]\n          }\n        }\n      })\n      return data\n    },\n    handleAddRole() {\n      this.role = Object.assign({}, defaultRole)\n      if (this.$refs.tree) {\n        this.$refs.tree.setCheckedNodes([])\n      }\n      this.dialogType = 'new'\n      this.dialogVisible = true\n    },\n    handleEdit(scope) {\n      this.dialogType = 'edit'\n      this.dialogVisible = true\n      this.checkStrictly = true\n      this.role = deepClone(scope.row)\n      this.$nextTick(() => {\n        const routes = this.generateRoutes(this.role.routes)\n        this.$refs.tree.setCheckedNodes(this.generateArr(routes))\n        // set checked state of a node not affects its father and child nodes\n        this.checkStrictly = false\n      })\n    },\n    handleDelete({ $index, row }) {\n      this.$confirm('Confirm to remove the role?', 'Warning', {\n        confirmButtonText: 'Confirm',\n        cancelButtonText: 'Cancel',\n        type: 'warning'\n      })\n        .then(async() => {\n          await deleteRole(row.key)\n          this.rolesList.splice($index, 1)\n          this.$message({\n            type: 'success',\n            message: 'Delete succed!'\n          })\n        })\n        .catch(err => { console.error(err) })\n    },\n    generateTree(routes, basePath = '/', checkedKeys) {\n      const res = []\n\n      for (const route of routes) {\n        const routePath = path.resolve(basePath, route.path)\n\n        // recursive child routes\n        if (route.children) {\n          route.children = this.generateTree(route.children, routePath, checkedKeys)\n        }\n\n        if (checkedKeys.includes(routePath) || (route.children && route.children.length >= 1)) {\n          res.push(route)\n        }\n      }\n      return res\n    },\n    async confirmRole() {\n      const isEdit = this.dialogType === 'edit'\n\n      const checkedKeys = this.$refs.tree.getCheckedKeys()\n      this.role.routes = this.generateTree(deepClone(this.serviceRoutes), '/', checkedKeys)\n\n      if (isEdit) {\n        await updateRole(this.role.key, this.role)\n        for (let index = 0; index < this.rolesList.length; index++) {\n          if (this.rolesList[index].key === this.role.key) {\n            this.rolesList.splice(index, 1, Object.assign({}, this.role))\n            break\n          }\n        }\n      } else {\n        const { data } = await addRole(this.role)\n        this.role.key = data.key\n        this.rolesList.push(this.role)\n      }\n\n      const { description, key, name } = this.role\n      this.dialogVisible = false\n      this.$notify({\n        title: 'Success',\n        dangerouslyUseHTMLString: true,\n        message: `\n            <div>Role Key: ${key}</div>\n            <div>Role Name: ${name}</div>\n            <div>Description: ${description}</div>\n          `,\n        type: 'success'\n      })\n    },\n    // reference: src/view/layout/components/Sidebar/SidebarItem.vue\n    onlyOneShowingChild(children = [], parent) {\n      let onlyOneChild = null\n      const showingChildren = children.filter(item => !item.hidden)\n\n      // When there is only one child route, the child route is displayed by default\n      if (showingChildren.length === 1) {\n        onlyOneChild = showingChildren[0]\n        onlyOneChild.path = path.resolve(parent.path, onlyOneChild.path)\n        return onlyOneChild\n      }\n\n      // Show parent if there are no child route to display\n      if (showingChildren.length === 0) {\n        onlyOneChild = { ... parent, path: '', noShowingChildren: true }\n        return onlyOneChild\n      }\n\n      return false\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n.app-container {\n  .roles-table {\n    margin-top: 30px;\n  }\n  .permission-tree {\n    margin-bottom: 30px;\n  }\n}\n</style>\n"]}]}