1 line
26 KiB
JSON
1 line
26 KiB
JSON
{"remainingRequest":"G:\\project\\smart-power-ui\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!G:\\project\\smart-power-ui\\src\\views\\system\\menu\\index.vue?vue&type=script&lang=js&","dependencies":[{"path":"G:\\project\\smart-power-ui\\src\\views\\system\\menu\\index.vue","mtime":1617244452828},{"path":"G:\\project\\smart-power-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1591751767036},{"path":"G:\\project\\smart-power-ui\\node_modules\\babel-loader\\lib\\index.js","mtime":1610504270305},{"path":"G:\\project\\smart-power-ui\\node_modules\\cache-loader\\dist\\cjs.js","mtime":1591751767036},{"path":"G:\\project\\smart-power-ui\\node_modules\\vue-loader\\lib\\index.js","mtime":1610504274351}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:Ly8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KLy8KCmltcG9ydCB7CiAgbGlzdE1lbnUsCiAgZ2V0TWVudSwKICBkZWxNZW51LAogIGFkZE1lbnUsCiAgdXBkYXRlTWVudQp9IGZyb20gIkAvYXBpL3N5c3RlbS9tZW51IjsKaW1wb3J0IFRyZWVzZWxlY3QgZnJvbSAiQHJpb3BoYWUvdnVlLXRyZWVzZWxlY3QiOwppbXBvcnQgIkByaW9waGFlL3Z1ZS10cmVlc2VsZWN0L2Rpc3QvdnVlLXRyZWVzZWxlY3QuY3NzIjsKaW1wb3J0IEljb25TZWxlY3QgZnJvbSAiQC9jb21wb25lbnRzL0ljb25TZWxlY3QiOwppbXBvcnQgc3RvcmUgZnJvbSAiQC9zdG9yZSI7Cgpjb25zdCBtZW51VHlwZU9wdCA9IHsKICBTWVNURU06ICLov5DokKXoj5zljZUiLAogIFRFTkFOVDogIuS8geS4muiPnOWNlSIsCiAgUEVSU09OQUw6ICLkuKrkurroj5zljZUiCn07CmV4cG9ydCBkZWZhdWx0IHsKICBuYW1lOiAiTWVudSIsCiAgY29tcG9uZW50czogeyBUcmVlc2VsZWN0LCBJY29uU2VsZWN0IH0sCiAgZGF0YSgpIHsKICAgIHJldHVybiB7CiAgICAgIC8vIOmBrue9qeWxggogICAgICBsb2FkaW5nOiB0cnVlLAogICAgICAvLyDmmL7npLrmkJzntKLmnaHku7YKICAgICAgc2hvd1NlYXJjaDogdHJ1ZSwKICAgICAgLy8g6I+c5Y2V6KGo5qC85qCR5pWw5o2uCiAgICAgIG1lbnVMaXN0OiBbXSwKICAgICAgLy8g6I+c5Y2V5qCR6YCJ6aG5CiAgICAgIG1lbnVPcHRpb25zOiBbXSwKICAgICAgLy8g5by55Ye65bGC5qCH6aKYCiAgICAgIHRpdGxlOiAiIiwKICAgICAgLy8g5piv5ZCm5pi+56S65by55Ye65bGCCiAgICAgIG9wZW46IGZhbHNlLAogICAgICAvLyDmmL7npLrnirbmgIHmlbDmja7lrZflhbgKICAgICAgdmlzaWJsZU9wdGlvbnM6IFtdLAogICAgICBtZW51VHlwZU9wdCwKICAgICAgLy8g6I+c5Y2V54q25oCB5pWw5o2u5a2X5YW4CiAgICAgIHN0YXR1c09wdGlvbnM6IFtdLAogICAgICAvLyDmn6Xor6Llj4LmlbAKICAgICAgcXVlcnlQYXJhbXM6IHsKICAgICAgICBtZW51TmFtZTogdW5kZWZpbmVkLAogICAgICAgIHZpc2libGU6IHVuZGVmaW5lZAogICAgICB9LAogICAgICAvLyDooajljZXlj4LmlbAKICAgICAgZm9ybToge30sCiAgICAgIHRlbmFudElkOiAiIiwKICAgICAgbG9naW5Vc2VyVHlwZTogIiIsCiAgICAgIC8vIOihqOWNleagoemqjAogICAgICBydWxlczogewogICAgICAgIG1lbnVOYW1lOiBbCiAgICAgICAgICB7IHJlcXVpcmVkOiB0cnVlLCBtZXNzYWdlOiAi6I+c5Y2V5ZCN56ew5LiN6IO95Li656m6IiwgdHJpZ2dlcjogImJsdXIiIH0KICAgICAgICBdLAogICAgICAgIG9yZGVyTnVtOiBbCiAgICAgICAgICB7IHJlcXVpcmVkOiB0cnVlLCBtZXNzYWdlOiAi6I+c5Y2V6aG65bqP5LiN6IO95Li656m6IiwgdHJpZ2dlcjogImJsdXIiIH0KICAgICAgICBdLAogICAgICAgIHBhdGg6IFt7IHJlcXVpcmVkOiB0cnVlLCBtZXNzYWdlOiAi6Lev55Sx5Zyw5Z2A5LiN6IO95Li656m6IiwgdHJpZ2dlcjogImJsdXIiIH1dCiAgICAgIH0KICAgIH07CiAgfSwKICBjcmVhdGVkKCkgewogICAgdGhpcy50ZW5hbnRJZCA9IHN0b3JlLmdldHRlcnMudGVuYW50SWQ7CiAgICB0aGlzLmxvZ2luVXNlclR5cGUgPSBzdG9yZS5nZXR0ZXJzLnVzZXJUeXBlOwogICAgdGhpcy5nZXRMaXN0KCk7CiAgICB0aGlzLmdldERpY3RzKCJzeXNfc2hvd19oaWRlIikudGhlbihyZXNwb25zZSA9PiB7CiAgICAgIHRoaXMudmlzaWJsZU9wdGlvbnMgPSByZXNwb25zZS5kYXRhOwogICAgfSk7CiAgICB0aGlzLmdldERpY3RzKCJzeXNfbm9ybWFsX2Rpc2FibGUiKS50aGVuKHJlc3BvbnNlID0+IHsKICAgICAgdGhpcy5zdGF0dXNPcHRpb25zID0gcmVzcG9uc2UuZGF0YTsKICAgIH0pOwogIH0sCiAgbWV0aG9kczogewogICAgLy8g6YCJ5oup5Zu+5qCHCiAgICBzZWxlY3RlZChuYW1lKSB7CiAgICAgIHRoaXMuZm9ybS5pY29uID0gbmFtZTsKICAgIH0sCiAgICAvKiog5p+l6K+i6I+c5Y2V5YiX6KGoICovCiAgICBnZXRMaXN0KCkgewogICAgICB0aGlzLmxvYWRpbmcgPSB0cnVlOwogICAgICBsaXN0TWVudSh0aGlzLnF1ZXJ5UGFyYW1zKS50aGVuKHJlc3BvbnNlID0+IHsKICAgICAgICB0aGlzLm1lbnVMaXN0ID0gdGhpcy5oYW5kbGVUcmVlKHJlc3BvbnNlLmRhdGEsICJtZW51SWQiKTsKICAgICAgICB0aGlzLmxvYWRpbmcgPSBmYWxzZTsKICAgICAgfSk7CiAgICB9LAogICAgLyoqIOi9rOaNouiPnOWNleaVsOaNrue7k+aehCAqLwogICAgbm9ybWFsaXplcihub2RlKSB7CiAgICAgIGlmIChub2RlLmNoaWxkcmVuICYmICFub2RlLmNoaWxkcmVuLmxlbmd0aCkgewogICAgICAgIGRlbGV0ZSBub2RlLmNoaWxkcmVuOwogICAgICB9CiAgICAgIHJldHVybiB7CiAgICAgICAgaWQ6IG5vZGUubWVudUlkLAogICAgICAgIGxhYmVsOiBub2RlLm1lbnVOYW1lLAogICAgICAgIGNoaWxkcmVuOiBub2RlLmNoaWxkcmVuCiAgICAgIH07CiAgICB9LAogICAgLyoqIOafpeivouiPnOWNleS4i+aLieagkee7k+aehCAqLwogICAgZ2V0VHJlZXNlbGVjdCgpIHsKICAgICAgbGlzdE1lbnUoKS50aGVuKHJlc3BvbnNlID0+IHsKICAgICAgICB0aGlzLm1lbnVPcHRpb25zID0gW107CiAgICAgICAgY29uc3QgbWVudSA9IHsgbWVudUlkOiAwLCBtZW51TmFtZTogIuS4u+exu+ebriIsIGNoaWxkcmVuOiBbXSB9OwogICAgICAgIG1lbnUuY2hpbGRyZW4gPSB0aGlzLmhhbmRsZVRyZWUocmVzcG9uc2UuZGF0YSwgIm1lbnVJZCIpOwogICAgICAgIHRoaXMubWVudU9wdGlvbnMucHVzaChtZW51KTsKICAgICAgfSk7CiAgICB9LAogICAgLy8g5pi+56S654q25oCB5a2X5YW457+76K+RCiAgICB2aXNpYmxlRm9ybWF0KHJvdywgY29sdW1uKSB7CiAgICAgIGlmIChyb3cubWVudVR5cGUgPT0gIkYiKSB7CiAgICAgICAgcmV0dXJuICIiOwogICAgICB9CiAgICAgIHJldHVybiB0aGlzLnNlbGVjdERpY3RMYWJlbCh0aGlzLnZpc2libGVPcHRpb25zLCByb3cudmlzaWJsZSk7CiAgICB9LAogICAgLy8g6I+c5Y2V54q25oCB5a2X5YW457+76K+RCiAgICBzdGF0dXNGb3JtYXQocm93LCBjb2x1bW4pIHsKICAgICAgaWYgKHJvdy5tZW51VHlwZSA9PSAiRiIpIHsKICAgICAgICByZXR1cm4gIiI7CiAgICAgIH0KICAgICAgcmV0dXJuIHRoaXMuc2VsZWN0RGljdExhYmVsKHRoaXMuc3RhdHVzT3B0aW9ucywgcm93LnN0YXR1cyk7CiAgICB9LAogICAgLy8g5Y+W5raI5oyJ6ZKuCiAgICBjYW5jZWwoKSB7CiAgICAgIHRoaXMub3BlbiA9IGZhbHNlOwogICAgICB0aGlzLnJlc2V0KCk7CiAgICB9LAogICAgLy8g6KGo5Y2V6YeN572uCiAgICByZXNldCgpIHsKICAgICAgdGhpcy5mb3JtID0gewogICAgICAgIG1lbnVJZDogdW5kZWZpbmVkLAogICAgICAgIHBhcmVudElkOiAwLAogICAgICAgIG1lbnVOYW1lOiB1bmRlZmluZWQsCiAgICAgICAgaWNvbjogdW5kZWZpbmVkLAogICAgICAgIG1lbnVUeXBlOiAiTSIsCiAgICAgICAgb3JkZXJOdW06IHVuZGVmaW5lZCwKICAgICAgICBpc0ZyYW1lOiAiMSIsCiAgICAgICAgaXNDYWNoZTogIjAiLAogICAgICAgIHZpc2libGU6ICIwIiwKICAgICAgICBzdGF0dXM6ICIwIiwKICAgICAgICBkYXRhVHlwZTogdGhpcy50ZW5hbnRJZCA9PT0gMCA/ICJTWVNURU0iIDogIlRFTkFOVCIKICAgICAgfTsKICAgICAgdGhpcy5yZXNldEZvcm0oImZvcm0iKTsKICAgIH0sCiAgICAvKiog5pCc57Si5oyJ6ZKu5pON5L2cICovCiAgICBoYW5kbGVRdWVyeSgpIHsKICAgICAgdGhpcy5nZXRMaXN0KCk7CiAgICB9LAogICAgLyoqIOmHjee9ruaMiemSruaTjeS9nCAqLwogICAgcmVzZXRRdWVyeSgpIHsKICAgICAgdGhpcy5yZXNldEZvcm0oInF1ZXJ5Rm9ybSIpOwogICAgICB0aGlzLmhhbmRsZVF1ZXJ5KCk7CiAgICB9LAogICAgLyoqIOaWsOWinuaMiemSruaTjeS9nCAqLwogICAgaGFuZGxlQWRkKHJvdykgewogICAgICB0aGlzLnJlc2V0KCk7CiAgICAgIHRoaXMuZ2V0VHJlZXNlbGVjdCgpOwogICAgICBpZiAocm93ICE9IG51bGwgJiYgcm93Lm1lbnVJZCkgewogICAgICAgIHRoaXMuZm9ybS5wYXJlbnRJZCA9IHJvdy5tZW51SWQ7CiAgICAgIH0gZWxzZSB7CiAgICAgICAgdGhpcy5mb3JtLnBhcmVudElkID0gMDsKICAgICAgfQogICAgICB0aGlzLm9wZW4gPSB0cnVlOwogICAgICB0aGlzLnRpdGxlID0gIua3u+WKoOiPnOWNlSI7CiAgICB9LAogICAgLyoqIOS/ruaUueaMiemSruaTjeS9nCAqLwogICAgaGFuZGxlVXBkYXRlKHJvdykgewogICAgICB0aGlzLnJlc2V0KCk7CiAgICAgIHRoaXMuZ2V0VHJlZXNlbGVjdCgpOwogICAgICBnZXRNZW51KHJvdy5tZW51SWQpLnRoZW4ocmVzcG9uc2UgPT4gewogICAgICAgIHRoaXMuZm9ybSA9IHJlc3BvbnNlLmRhdGE7CiAgICAgICAgdGhpcy5vcGVuID0gdHJ1ZTsKICAgICAgICB0aGlzLnRpdGxlID0gIuS/ruaUueiPnOWNlSI7CiAgICAgIH0pOwogICAgfSwKICAgIC8qKiDmj5DkuqTmjInpkq4gKi8KICAgIHN1Ym1pdEZvcm06IGZ1bmN0aW9uKCkgewogICAgICB0aGlzLiRyZWZzWyJmb3JtIl0udmFsaWRhdGUodmFsaWQgPT4gewogICAgICAgIGlmICh2YWxpZCkgewogICAgICAgICAgaWYgKHRoaXMuZm9ybS5tZW51SWQgIT0gdW5kZWZpbmVkKSB7CiAgICAgICAgICAgIHVwZGF0ZU1lbnUodGhpcy5mb3JtKS50aGVuKHJlc3BvbnNlID0+IHsKICAgICAgICAgICAgICB0aGlzLm1zZ1N1Y2Nlc3MoIuS/ruaUueaIkOWKnyIpOwogICAgICAgICAgICAgIHRoaXMub3BlbiA9IGZhbHNlOwogICAgICAgICAgICAgIHRoaXMuZ2V0TGlzdCgpOwogICAgICAgICAgICB9KTsKICAgICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIGFkZE1lbnUodGhpcy5mb3JtKS50aGVuKHJlc3BvbnNlID0+IHsKICAgICAgICAgICAgICB0aGlzLm1zZ1N1Y2Nlc3MoIuaWsOWinuaIkOWKnyIpOwogICAgICAgICAgICAgIHRoaXMub3BlbiA9IGZhbHNlOwogICAgICAgICAgICAgIHRoaXMuZ2V0TGlzdCgpOwogICAgICAgICAgICB9KTsKICAgICAgICAgIH0KICAgICAgICB9CiAgICAgIH0pOwogICAgfSwKICAgIC8qKiDliKDpmaTmjInpkq7mk43kvZwgKi8KICAgIGhhbmRsZURlbGV0ZShyb3cpIHsKICAgICAgdGhpcy4kY29uZmlybSgi5piv5ZCm5Yig6Zmk6K+l6YCJ6aG5PyIsICLorablkYoiLCB7CiAgICAgICAgY29uZmlybUJ1dHRvblRleHQ6ICLnoa7lrpoiLAogICAgICAgIGNhbmNlbEJ1dHRvblRleHQ6ICLlj5bmtogiLAogICAgICAgIHR5cGU6ICJ3YXJuaW5nIgogICAgICB9KQogICAgICAgIC50aGVuKGZ1bmN0aW9uKCkgewogICAgICAgICAgcmV0dXJuIGRlbE1lbnUocm93Lm1lbnVJZCwgbnVsbCk7CiAgICAgICAgfSkKICAgICAgICAudGhlbigoKSA9PiB7CiAgICAgICAgICB0aGlzLmdldExpc3QoKTsKICAgICAgICAgIHRoaXMubXNnU3VjY2Vzcygi5Yig6Zmk5oiQ5YqfIik7CiAgICAgICAgfSk7CiAgICB9CiAgfQp9Owo="},{"version":3,"sources":["index.vue"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6OA;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;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;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/menu","sourcesContent":["<template>\n <div class=\"app-container\">\n <el-form :model=\"queryParams\" ref=\"queryForm\" :inline=\"true\" v-show=\"showSearch\">\n <el-form-item label=\"菜单名称\" prop=\"menuName\">\n <el-input\n v-model=\"queryParams.menuName\"\n placeholder=\"请输入菜单名称\"\n clearable\n size=\"small\"\n @keyup.enter.native=\"handleQuery\"\n />\n </el-form-item>\n <el-form-item label=\"状态\" prop=\"status\">\n <el-select v-model=\"queryParams.status\" placeholder=\"菜单状态\" clearable size=\"small\">\n <el-option\n v-for=\"dict in statusOptions\"\n :key=\"dict.dictValue\"\n :label=\"dict.dictLabel\"\n :value=\"dict.dictValue\"\n />\n </el-select>\n </el-form-item>\n <el-form-item label=\"数据类型\" prop=\"status\">\n <el-select v-model=\"queryParams.dataType\" @change=\"handleQuery\" placeholder=\"数据类型\" clearable size=\"small\">\n <el-option\n v-for=\"(keys, vals) in menuTypeOpt\"\n :key=\"keys\"\n :label=\"keys\"\n :value=\"vals\"\n />\n </el-select>\n </el-form-item>\n <el-form-item>\n <el-button type=\"primary\" icon=\"el-icon-search\" size=\"mini\" @click=\"handleQuery\">搜索</el-button>\n <el-button icon=\"el-icon-refresh\" size=\"mini\" @click=\"resetQuery\">重置</el-button>\n </el-form-item>\n </el-form>\n\n <el-row :gutter=\"10\" class=\"mb8\">\n <el-col :span=\"1.5\">\n <el-button\n type=\"primary\"\n plain\n icon=\"el-icon-plus\"\n size=\"mini\"\n @click=\"handleAdd\"\n v-hasPermi=\"['system:menu:add']\"\n >新增</el-button>\n </el-col>\n <right-toolbar :showSearch.sync=\"showSearch\" @queryTable=\"getList\"></right-toolbar>\n </el-row>\n\n <el-table\n v-loading=\"loading\"\n :data=\"menuList\"\n row-key=\"menuId\"\n :tree-props=\"{children: 'children', hasChildren: 'hasChildren'}\"\n >\n <el-table-column prop=\"menuName\" label=\"菜单名称\" :show-overflow-tooltip=\"true\" width=\"160\"></el-table-column>\n <el-table-column prop=\"icon\" label=\"图标\" align=\"center\" width=\"100\">\n <template slot-scope=\"scope\">\n <svg-icon :icon-class=\"scope.row.icon\" />\n </template>\n </el-table-column>\n <el-table-column prop=\"orderNum\" label=\"排序\" width=\"60\"></el-table-column>\n <el-table-column prop=\"perms\" label=\"权限标识\" :show-overflow-tooltip=\"true\"></el-table-column>\n <el-table-column prop=\"component\" label=\"组件路径\" :show-overflow-tooltip=\"true\"></el-table-column>\n <el-table-column prop=\"status\" label=\"状态\" :formatter=\"statusFormat\" width=\"80\"></el-table-column>\n <el-table-column label=\"创建时间\" align=\"center\" prop=\"createTime\">\n <template slot-scope=\"scope\">\n <span>{{ parseTime(scope.row.createTime) }}</span>\n </template>\n </el-table-column>\n <el-table-column label=\"操作\" align=\"center\" class-name=\"small-padding fixed-width\">\n <template slot-scope=\"scope\">\n <el-button\n size=\"mini\"\n v-if=\"scope.row.tenantId === tenantId\"\n type=\"text\"\n icon=\"el-icon-edit\"\n @click=\"handleUpdate(scope.row)\"\n v-hasPermi=\"['system:menu:edit']\"\n >修改</el-button>\n <el-button\n size=\"mini\"\n type=\"text\"\n icon=\"el-icon-plus\"\n @click=\"handleAdd(scope.row)\"\n v-hasPermi=\"['system:menu:add']\"\n >新增</el-button>\n <el-button\n v-if=\"scope.row.tenantId === tenantId\"\n size=\"mini\"\n type=\"text\"\n icon=\"el-icon-delete\"\n @click=\"handleDelete(scope.row)\"\n v-hasPermi=\"['system:menu:remove']\"\n >删除</el-button>\n </template>\n </el-table-column>\n </el-table>\n\n <!-- 添加或修改菜单对话框 -->\n <el-dialog class=\"eldialog-wrap\" :close-on-click-modal=\"false\" :title=\"title\" :visible.sync=\"open\" width=\"600px\">\n <el-form ref=\"form\" :model=\"form\" :rules=\"rules\" label-width=\"100px\">\n <el-row>\n <el-col :span=\"24\">\n <el-form-item label=\"上级菜单:\">\n <treeselect\n v-model=\"form.parentId\"\n :options=\"menuOptions\"\n :normalizer=\"normalizer\"\n :show-count=\"true\"\n placeholder=\"选择上级菜单\"\n />\n </el-form-item>\n </el-col>\n <el-col :span=\"24\">\n <el-form-item label=\"菜单类型:\" prop=\"menuType\">\n <el-radio-group v-model=\"form.menuType\">\n <el-radio label=\"M\">目录</el-radio>\n <el-radio label=\"C\">菜单</el-radio>\n <el-radio label=\"F\">按钮</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n <el-col :span=\"24\">\n <el-form-item v-if=\"form.menuType != 'F'\" label=\"菜单图标:\">\n <el-popover\n placement=\"bottom-start\"\n width=\"460\"\n trigger=\"click\"\n @show=\"$refs['iconSelect'].reset()\"\n >\n <IconSelect ref=\"iconSelect\" @selected=\"selected\" />\n <el-input slot=\"reference\" v-model=\"form.icon\" placeholder=\"点击选择图标\" readonly>\n <svg-icon\n v-if=\"form.icon\"\n slot=\"prefix\"\n :icon-class=\"form.icon\"\n class=\"el-input__icon\"\n style=\"height: 32px;width: 16px;\"\n />\n <i v-else slot=\"prefix\" class=\"el-icon-search el-input__icon\" />\n </el-input>\n </el-popover>\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item label=\"菜单名称:\" prop=\"menuName\">\n <el-input v-model=\"form.menuName\" placeholder=\"请输入菜单名称\" />\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item label=\"显示排序:\" prop=\"orderNum\">\n <el-input-number\n style=\"width: 170px;\"\n v-model=\"form.orderNum\"\n controls-position=\"right\"\n :min=\"0\"\n />\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType != 'F'\" label=\"是否外链:\">\n <el-radio-group v-model=\"form.isFrame\">\n <el-radio label=\"0\">是</el-radio>\n <el-radio label=\"1\">否</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType != 'F'\" label=\"路由地址:\" prop=\"path\">\n <el-input v-model=\"form.path\" placeholder=\"请输入路由地址\" />\n </el-form-item>\n </el-col>\n <el-col :span=\"12\" v-if=\"form.menuType == 'C'\">\n <el-form-item label=\"组件路径:\" prop=\"component\">\n <el-input v-model=\"form.component\" placeholder=\"请输入组件路径\" />\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType != 'M'\" label=\"权限标识:\">\n <el-input v-model=\"form.perms\" placeholder=\"请权限标识\" maxlength=\"50\" />\n </el-form-item>\n </el-col>\n\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType != 'F'\" label=\"显示状态:\">\n <el-radio-group v-model=\"form.visible\">\n <el-radio\n v-for=\"dict in visibleOptions\"\n :key=\"dict.dictValue\"\n :label=\"dict.dictValue\"\n >{{dict.dictLabel}}</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType != 'F'\" label=\"菜单状态:\">\n <el-radio-group v-model=\"form.status\">\n <el-radio\n v-for=\"dict in statusOptions\"\n :key=\"dict.dictValue\"\n :label=\"dict.dictValue\"\n >{{dict.dictLabel}}</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n <el-col :span=\"12\">\n <el-form-item v-if=\"form.menuType == 'C'\" label=\"是否缓存:\">\n <el-radio-group v-model=\"form.isCache\">\n <el-radio label=\"0\">缓存</el-radio>\n <el-radio label=\"1\">不缓存</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n\n <el-col :span=\"24\" v-if=\"tenantId === 0\">\n <el-form-item label=\"数据类型:\">\n <el-radio-group v-model=\"form.dataType\">\n <el-radio v-for=\"(lab, value) in menuTypeOpt\" :key=\"value\" :label=\"value\">{{lab}}</el-radio>\n </el-radio-group>\n </el-form-item>\n </el-col>\n </el-row>\n </el-form>\n <div slot=\"footer\" class=\"dialog-footer\">\n <el-button size=\"mini\" type=\"primary\" @click=\"submitForm\">确 定</el-button>\n <el-button size=\"mini\" @click=\"cancel\">取 消</el-button>\n </div>\n </el-dialog>\n </div>\n</template>\n\n<script>\nimport {\n listMenu,\n getMenu,\n delMenu,\n addMenu,\n updateMenu\n} from \"@/api/system/menu\";\nimport Treeselect from \"@riophae/vue-treeselect\";\nimport \"@riophae/vue-treeselect/dist/vue-treeselect.css\";\nimport IconSelect from \"@/components/IconSelect\";\nimport store from \"@/store\";\n\nconst menuTypeOpt = {\n SYSTEM: \"运营菜单\",\n TENANT: \"企业菜单\",\n PERSONAL: \"个人菜单\"\n};\nexport default {\n name: \"Menu\",\n components: { Treeselect, IconSelect },\n data() {\n return {\n // 遮罩层\n loading: true,\n // 显示搜索条件\n showSearch: true,\n // 菜单表格树数据\n menuList: [],\n // 菜单树选项\n menuOptions: [],\n // 弹出层标题\n title: \"\",\n // 是否显示弹出层\n open: false,\n // 显示状态数据字典\n visibleOptions: [],\n menuTypeOpt,\n // 菜单状态数据字典\n statusOptions: [],\n // 查询参数\n queryParams: {\n menuName: undefined,\n visible: undefined\n },\n // 表单参数\n form: {},\n tenantId: \"\",\n loginUserType: \"\",\n // 表单校验\n rules: {\n menuName: [\n { required: true, message: \"菜单名称不能为空\", trigger: \"blur\" }\n ],\n orderNum: [\n { required: true, message: \"菜单顺序不能为空\", trigger: \"blur\" }\n ],\n path: [{ required: true, message: \"路由地址不能为空\", trigger: \"blur\" }]\n }\n };\n },\n created() {\n this.tenantId = store.getters.tenantId;\n this.loginUserType = store.getters.userType;\n this.getList();\n this.getDicts(\"sys_show_hide\").then(response => {\n this.visibleOptions = response.data;\n });\n this.getDicts(\"sys_normal_disable\").then(response => {\n this.statusOptions = response.data;\n });\n },\n methods: {\n // 选择图标\n selected(name) {\n this.form.icon = name;\n },\n /** 查询菜单列表 */\n getList() {\n this.loading = true;\n listMenu(this.queryParams).then(response => {\n this.menuList = this.handleTree(response.data, \"menuId\");\n this.loading = false;\n });\n },\n /** 转换菜单数据结构 */\n normalizer(node) {\n if (node.children && !node.children.length) {\n delete node.children;\n }\n return {\n id: node.menuId,\n label: node.menuName,\n children: node.children\n };\n },\n /** 查询菜单下拉树结构 */\n getTreeselect() {\n listMenu().then(response => {\n this.menuOptions = [];\n const menu = { menuId: 0, menuName: \"主类目\", children: [] };\n menu.children = this.handleTree(response.data, \"menuId\");\n this.menuOptions.push(menu);\n });\n },\n // 显示状态字典翻译\n visibleFormat(row, column) {\n if (row.menuType == \"F\") {\n return \"\";\n }\n return this.selectDictLabel(this.visibleOptions, row.visible);\n },\n // 菜单状态字典翻译\n statusFormat(row, column) {\n if (row.menuType == \"F\") {\n return \"\";\n }\n return this.selectDictLabel(this.statusOptions, row.status);\n },\n // 取消按钮\n cancel() {\n this.open = false;\n this.reset();\n },\n // 表单重置\n reset() {\n this.form = {\n menuId: undefined,\n parentId: 0,\n menuName: undefined,\n icon: undefined,\n menuType: \"M\",\n orderNum: undefined,\n isFrame: \"1\",\n isCache: \"0\",\n visible: \"0\",\n status: \"0\",\n dataType: this.tenantId === 0 ? \"SYSTEM\" : \"TENANT\"\n };\n this.resetForm(\"form\");\n },\n /** 搜索按钮操作 */\n handleQuery() {\n this.getList();\n },\n /** 重置按钮操作 */\n resetQuery() {\n this.resetForm(\"queryForm\");\n this.handleQuery();\n },\n /** 新增按钮操作 */\n handleAdd(row) {\n this.reset();\n this.getTreeselect();\n if (row != null && row.menuId) {\n this.form.parentId = row.menuId;\n } else {\n this.form.parentId = 0;\n }\n this.open = true;\n this.title = \"添加菜单\";\n },\n /** 修改按钮操作 */\n handleUpdate(row) {\n this.reset();\n this.getTreeselect();\n getMenu(row.menuId).then(response => {\n this.form = response.data;\n this.open = true;\n this.title = \"修改菜单\";\n });\n },\n /** 提交按钮 */\n submitForm: function() {\n this.$refs[\"form\"].validate(valid => {\n if (valid) {\n if (this.form.menuId != undefined) {\n updateMenu(this.form).then(response => {\n this.msgSuccess(\"修改成功\");\n this.open = false;\n this.getList();\n });\n } else {\n addMenu(this.form).then(response => {\n this.msgSuccess(\"新增成功\");\n this.open = false;\n this.getList();\n });\n }\n }\n });\n },\n /** 删除按钮操作 */\n handleDelete(row) {\n this.$confirm(\"是否删除该选项?\", \"警告\", {\n confirmButtonText: \"确定\",\n cancelButtonText: \"取消\",\n type: \"warning\"\n })\n .then(function() {\n return delMenu(row.menuId, null);\n })\n .then(() => {\n this.getList();\n this.msgSuccess(\"删除成功\");\n });\n }\n }\n};\n</script>\n"]}]} |