MenuAdmin.vue 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286
  1. <template>
  2. <div class="box">
  3. <div>
  4. <div style="margin-bottom: 10px">
  5. <el-button type="primary" v-if="hasPerm('menu:add')" @click="addMenu">添加菜单</el-button>
  6. </div>
  7. <div>
  8. <el-table
  9. :data="tableData"
  10. border
  11. row-key="id"
  12. :height="800 + 'px'"
  13. :tree-props="{children: 'children'}"
  14. default-expand-all>
  15. <el-table-column prop="title" label="菜单名称"></el-table-column>
  16. <el-table-column
  17. prop="weight"
  18. label="菜单层级"
  19. :filters="[{ text: '菜单', value: 0 }, { text: '按钮', value: 1 }]"
  20. :filter-method="filterTag">
  21. <template slot-scope="scope">
  22. <el-tag
  23. :type="scope.row.weight === 0 ? 'primary' : 'success'"
  24. disable-transitions>{{scope.row.weight === 0 ? '菜单' : '按钮'}}</el-tag>
  25. </template>
  26. </el-table-column>
  27. <el-table-column prop="url" label="菜单路由"></el-table-column>
  28. <!-- <el-table-column prop="remark" label="备注"></el-table-column>-->
  29. <el-table-column
  30. label="操作"
  31. fixed="right">
  32. <template slot-scope="scope">
  33. <el-button size="mini" type="info" v-if="hasPerm('menu:edit')" @click="setEdit(scope.row)" style="margin-right: 10px">编辑</el-button>
  34. <!-- <el-button size="mini" type="primary" style="margin-right: 10px" @click="addChildren(scope.row, scope.$index)">添加子菜单</el-button>-->
  35. <el-popconfirm
  36. :title="scope.row.parentId === 0 ? '这是父菜单,删除后,子菜单将不复存在!确定要删除这个菜单吗' : '确定要删除这个菜单吗?'"
  37. @confirm="del(scope.row)"
  38. >
  39. <el-button size="mini" slot="reference" v-if="hasPerm('menu:del')" type="danger">删除</el-button>
  40. </el-popconfirm>
  41. </template>
  42. </el-table-column>
  43. </el-table>
  44. </div>
  45. </div>
  46. <a-modal
  47. :title="showType ? '编辑菜单' : '新增菜单'"
  48. :width="600"
  49. :visible="dialogFormVisible"
  50. @ok="add('ruleForm')"
  51. @cancel="reset"
  52. :destroyOnClose="true"
  53. >
  54. <el-form :model="form" :rules="rules" ref="ruleForm">
  55. <el-form-item prop="weight" size="mini" label="菜单层级:" :label-width="formLabelWidth">
  56. <el-radio-group v-model="form.weight">
  57. <el-radio :label="0">菜单</el-radio>
  58. <el-radio :label="1">按钮</el-radio>
  59. </el-radio-group>
  60. </el-form-item>
  61. <el-form-item size="mini" label="菜单名称" :label-width="formLabelWidth" prop="title">
  62. <el-input v-model="form.title" autocomplete="off"></el-input>
  63. </el-form-item>
  64. <el-form-item size="mini" label="父级菜单" :label-width="formLabelWidth">
  65. <a-tree-select
  66. v-model="form.parentId"
  67. style="width: 100%"
  68. :dropdownStyle="{ maxHeight: '300px', overflow: 'auto' }"
  69. :treeData="menuTreeData"
  70. placeholder="请选择父级菜单"
  71. treeDefaultExpandAll
  72. >
  73. <span slot="title" slot-scope="{ id }">{{ id }}
  74. </span>
  75. </a-tree-select>
  76. </el-form-item>
  77. <el-form-item size="mini" v-if="form.weight === 0" label="菜单地址" :label-width="formLabelWidth">
  78. <el-input v-model="form.url" autocomplete="off"></el-input>
  79. </el-form-item>
  80. <el-form-item size="mini" v-else label="权限标识" :label-width="formLabelWidth" prop="permission">
  81. <el-input v-model="form.permission" autocomplete="off"></el-input>
  82. </el-form-item>
  83. <el-form-item size="mini" label="排序" :label-width="formLabelWidth">
  84. <el-input v-model="form.sort" autocomplete="off"></el-input>
  85. </el-form-item>
  86. </el-form>
  87. </a-modal>
  88. </div>
  89. </template>
  90. <script>
  91. import { TreeSelect } from 'ant-design-vue'
  92. import { addMenu, editMenu, delMenu, getUserMenu } from '../../utils/api'
  93. export default {
  94. name: "MenuAdmin",
  95. components: {
  96. // AModal: Modal,
  97. // AForm: Form,
  98. ATreeSelect: TreeSelect
  99. },
  100. data() {
  101. return {
  102. tableData: [],
  103. showType: false,
  104. dialogFormVisible: false,
  105. form: {
  106. title: '',
  107. parentId: '',
  108. url: '',
  109. id: '',
  110. sort: '',
  111. weight: 0,
  112. permission: '',
  113. },
  114. formLabelWidth: '90px',
  115. rules: {
  116. title: [
  117. { required: true, message: '请输入菜单名称', trigger: 'blur' },
  118. ],
  119. weight: [
  120. { required: true, message: '请选择菜单层级', trigger: 'change' }
  121. ],
  122. menu: [
  123. { required: true, message: '请选择父级菜单', trigger: 'change' }
  124. ],
  125. permission: [
  126. { required: true, message: '请输入权限标识', trigger: 'blur' }
  127. ]
  128. },
  129. menuTreeData: [],
  130. }
  131. },
  132. methods: {
  133. // 拿到parentId
  134. getParentId(val) {
  135. this.form.parentId = val;
  136. },
  137. // 过滤
  138. filterTag(value, row) {
  139. return row.weight === value;
  140. },
  141. add(formName) {
  142. this.$refs[formName].validate((valid) => {
  143. if(valid) {
  144. if(this.showType) {
  145. this.setUpdate();
  146. } else {
  147. let params = {
  148. parentId: this.form.parentId,
  149. title: this.form.title,
  150. url: this.form.url,
  151. sort: this.form.sort,
  152. weight: this.form.weight,
  153. permission: this.form.permission,
  154. }
  155. addMenu(params)
  156. .then(res => {
  157. if(res.code === 10000) {
  158. this.init();
  159. this.reset();
  160. this.$message.success(res.message);
  161. }
  162. this.dialogFormVisible = false;
  163. })
  164. }
  165. } else {
  166. return false;
  167. }
  168. })
  169. this.dialogFormVisible = false;
  170. },
  171. setEdit(data) {
  172. this.showType = true;
  173. this.dialogFormVisible = true;
  174. this.form.id = data.id;
  175. this.form.title = data.title;
  176. this.form.url = data.url;
  177. this.form.parentId = data.parentId;
  178. this.form.sort = data.sort;
  179. this.form.permission = data.permission;
  180. this.form.weight = data.weight;
  181. },
  182. addMenu() {
  183. this.dialogFormVisible = true;
  184. },
  185. del(data) {
  186. delMenu({menuId: data.id})
  187. .then(res => {
  188. if(res.code === 10000) {
  189. this.init();
  190. this.$message.success(res.message);
  191. }
  192. })
  193. },
  194. setUpdate() {
  195. let params = {
  196. id: this.form.id,
  197. url: this.form.url,
  198. title: this.form.title,
  199. parentId: this.form.parentId,
  200. sort: this.form.sort,
  201. permission: this.form.permission,
  202. weight: this.form.weight,
  203. };
  204. editMenu(params)
  205. .then(res => {
  206. if(res.code === 10000) {
  207. this.init();
  208. this.reset();
  209. this.$message.success(res.message);
  210. }
  211. this.dialogFormVisible = false;
  212. })
  213. },
  214. // 重置
  215. reset() {
  216. this.form.title = '';
  217. this.form.parentId = '';
  218. this.form.url = '';
  219. this.form.id = '';
  220. this.form.sort = '';
  221. this.form.weight = 0;
  222. this.form.permission = '';
  223. this.showType = false;
  224. this.dialogFormVisible = false
  225. },
  226. init() {
  227. // getMenu()
  228. // .then(res => {
  229. // if(res.code === 10000) {
  230. // // this.tableData = res.data;
  231. // // console.log(res.data)
  232. // }
  233. // })
  234. let params = {
  235. userId: localStorage.getItem('UserId')
  236. }
  237. getUserMenu(params).then(res => {
  238. if(res.code === 10000) {
  239. this.tableData = res.data;
  240. this.menuTreeData = [
  241. {
  242. id: -1,
  243. parentId: 0,
  244. title: '顶级',
  245. value: 0,
  246. pid: 0,
  247. weight: 0,
  248. children: res.data,
  249. }
  250. ]
  251. }
  252. })
  253. // getMenuList().then(res => {
  254. // if(res.code === 10000) {
  255. // // this.menuTreeData = [
  256. // // {
  257. // // id: -1,
  258. // // parentId: 0,
  259. // // title: '顶级',
  260. // // value: 0,
  261. // // pid: 0,
  262. // // weight: 0,
  263. // // children: res.data,
  264. // // }
  265. // // ]
  266. // // console.log(res)
  267. // }
  268. // })
  269. }
  270. },
  271. mounted() {
  272. this.init();
  273. }
  274. }
  275. </script>
  276. <style scoped>
  277. .box {
  278. width: 100%;
  279. height: 100%;
  280. box-sizing: border-box;
  281. padding: 20px;
  282. }
  283. </style>