haiwei-ui 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (504) hide show
  1. package/.browserslistrc +3 -0
  2. package/.eslintrc.js +20 -0
  3. package/.prettierrc +6 -0
  4. package/.vscode/settings.json +10 -0
  5. package/README.md +23 -0
  6. package/babel.config.js +10 -0
  7. package/npm/345/217/221/345/270/203/350/257/246/347/273/206/346/223/215/344/275/234/346/214/207/345/274/225.md +296 -0
  8. package/package.json +65 -0
  9. package/packages/components/box/index.vue +181 -0
  10. package/packages/components/box-col/index.vue +43 -0
  11. package/packages/components/box-row/index.vue +27 -0
  12. package/packages/components/box-small/index.vue +64 -0
  13. package/packages/components/button/index.vue +52 -0
  14. package/packages/components/button-copy/index.vue +74 -0
  15. package/packages/components/button-delete/index.vue +87 -0
  16. package/packages/components/button-delete-batch/index.vue +108 -0
  17. package/packages/components/button-has/index.vue +54 -0
  18. package/packages/components/checkbox-group/index.vue +111 -0
  19. package/packages/components/color-picker/index.vue +66 -0
  20. package/packages/components/container/index.vue +21 -0
  21. package/packages/components/date-range-picker/index.vue +117 -0
  22. package/packages/components/details/index.vue +105 -0
  23. package/packages/components/dialog/index.vue +364 -0
  24. package/packages/components/drag-sort/index.vue +50 -0
  25. package/packages/components/drag-sort-dialog/index.vue +73 -0
  26. package/packages/components/drawer/index.vue +239 -0
  27. package/packages/components/enums/sex/index.vue +3 -0
  28. package/packages/components/flex/index.vue +58 -0
  29. package/packages/components/form/index.vue +153 -0
  30. package/packages/components/form-dialog/index.vue +245 -0
  31. package/packages/components/form-page/index.vue +195 -0
  32. package/packages/components/icon/index.vue +15 -0
  33. package/packages/components/icon-picker/index.vue +52 -0
  34. package/packages/components/icon-picker/panel.vue +81 -0
  35. package/packages/components/index.js +26 -0
  36. package/packages/components/label/index.vue +39 -0
  37. package/packages/components/list/components/export/index.vue +190 -0
  38. package/packages/components/list/components/footer/index.vue +67 -0
  39. package/packages/components/list/components/header/index.vue +57 -0
  40. package/packages/components/list/components/querybar/index.vue +188 -0
  41. package/packages/components/list/components/select-column/index.vue +53 -0
  42. package/packages/components/list/components/table/index.vue +210 -0
  43. package/packages/components/list/default.js +63 -0
  44. package/packages/components/list/index.vue +500 -0
  45. package/packages/components/list-agile/index.vue +223 -0
  46. package/packages/components/list-dialog/index.vue +102 -0
  47. package/packages/components/listbox/index.vue +77 -0
  48. package/packages/components/login-default/index.vue +177 -0
  49. package/packages/components/login-neon/index.vue +171 -0
  50. package/packages/components/map/index.vue +245 -0
  51. package/packages/components/map-coord-picking/index.vue +276 -0
  52. package/packages/components/map-search/index.vue +98 -0
  53. package/packages/components/radio/index.js +12 -0
  54. package/packages/components/scrollbar/index.vue +20 -0
  55. package/packages/components/select/index.js +12 -0
  56. package/packages/components/select-whether/index.vue +42 -0
  57. package/packages/components/split/index.vue +178 -0
  58. package/packages/components/split/trigger.vue +28 -0
  59. package/packages/components/tabnav/index.vue +124 -0
  60. package/packages/components/tabs/index.vue +48 -0
  61. package/packages/components/toolbar/components/fullscreen/index.vue +22 -0
  62. package/packages/components/toolbar/components/logout/index.vue +25 -0
  63. package/packages/components/toolbar/components/skin-toggle/form.vue +100 -0
  64. package/packages/components/toolbar/components/skin-toggle/index.vue +25 -0
  65. package/packages/components/toolbar/components/userInfo/index.vue +44 -0
  66. package/packages/components/toolbar/index.vue +26 -0
  67. package/packages/components/tree-select/index.js +12 -0
  68. package/packages/components/tree-select/mixins.vue +334 -0
  69. package/packages/components/txt/index.vue +27 -0
  70. package/packages/components/update-password/index.vue +84 -0
  71. package/packages/directive/has/index.js +23 -0
  72. package/packages/directive/index.js +13 -0
  73. package/packages/index.js +209 -0
  74. package/packages/layout.vue +39 -0
  75. package/packages/library.js +5 -0
  76. package/packages/mixins/components/button.js +15 -0
  77. package/packages/mixins/components/checkbox.vue +98 -0
  78. package/packages/mixins/components/dialog.js +3 -0
  79. package/packages/mixins/components/drawer.js +3 -0
  80. package/packages/mixins/components/form-dialog-edit.js +67 -0
  81. package/packages/mixins/components/form-readonly.js +33 -0
  82. package/packages/mixins/components/form-save.js +123 -0
  83. package/packages/mixins/components/input.js +24 -0
  84. package/packages/mixins/components/list.js +36 -0
  85. package/packages/mixins/components/loading.js +20 -0
  86. package/packages/mixins/components/radio.vue +84 -0
  87. package/packages/mixins/components/select.js +293 -0
  88. package/packages/mixins/components/visible.js +24 -0
  89. package/packages/mixins/global/fontSize.js +6 -0
  90. package/packages/mixins/global/loading.js +15 -0
  91. package/packages/mixins/global/message.js +64 -0
  92. package/packages/mixins/global/setTabName.js +6 -0
  93. package/packages/mixins/index.js +51 -0
  94. package/packages/page/403/index.vue +50 -0
  95. package/packages/page/404/index.vue +50 -0
  96. package/packages/page/default/index.vue +29 -0
  97. package/packages/page/iframe/index.vue +15 -0
  98. package/packages/page/login/index.vue +19 -0
  99. package/packages/page/userInfo/index.vue +47 -0
  100. package/packages/router/index.js +100 -0
  101. package/packages/router/routes.js +60 -0
  102. package/packages/skins/pretty/components/header/components/breadcrumb/index.vue +45 -0
  103. package/packages/skins/pretty/components/header/components/theme/index.vue +39 -0
  104. package/packages/skins/pretty/components/header/components/theme/list.js +82 -0
  105. package/packages/skins/pretty/components/header/index.vue +38 -0
  106. package/packages/skins/pretty/components/main/index.vue +51 -0
  107. package/packages/skins/pretty/components/menus/index.vue +60 -0
  108. package/packages/skins/pretty/components/menus/item.vue +46 -0
  109. package/packages/skins/pretty/components/sidebar/index.vue +17 -0
  110. package/packages/skins/pretty/index.js +47 -0
  111. package/packages/skins/pretty/index.vue +16 -0
  112. package/packages/skins/pretty/preview.png +0 -0
  113. package/packages/skins/pretty/store/index.js +8 -0
  114. package/packages/skins/pretty/store/modules/sidebar.js +32 -0
  115. package/packages/skins/pretty/styles/_index.scss +30 -0
  116. package/packages/skins/pretty/styles/components/header/_index.scss +77 -0
  117. package/packages/skins/pretty/styles/components/main/_index.scss +24 -0
  118. package/packages/skins/pretty/styles/components/menus/_index.scss +80 -0
  119. package/packages/skins/pretty/styles/components/sidebar/_index.scss +28 -0
  120. package/packages/skins/pretty/styles/themes/_index.scss +20 -0
  121. package/packages/skins/pretty/styles/themes/_theme.scss +283 -0
  122. package/packages/skins/pretty/styles/themes/blue-light/_index.scss +5 -0
  123. package/packages/skins/pretty/styles/themes/blue-light/_variables.scss +38 -0
  124. package/packages/skins/pretty/styles/themes/default/_index.scss +2 -0
  125. package/packages/skins/pretty/styles/themes/default/_variables.scss +38 -0
  126. package/packages/skins/pretty/styles/themes/green/_index.scss +5 -0
  127. package/packages/skins/pretty/styles/themes/green/_variables.scss +38 -0
  128. package/packages/skins/pretty/styles/themes/green-light/_index.scss +5 -0
  129. package/packages/skins/pretty/styles/themes/green-light/_variables.scss +38 -0
  130. package/packages/skins/pretty/styles/themes/orange/_index.scss +5 -0
  131. package/packages/skins/pretty/styles/themes/orange/_variables.scss +38 -0
  132. package/packages/skins/pretty/styles/themes/orange-light/_index.scss +5 -0
  133. package/packages/skins/pretty/styles/themes/orange-light/_variables.scss +38 -0
  134. package/packages/skins/pretty/styles/themes/pink/_index.scss +5 -0
  135. package/packages/skins/pretty/styles/themes/pink/_variables.scss +40 -0
  136. package/packages/skins/pretty/styles/themes/pink-light/_index.scss +5 -0
  137. package/packages/skins/pretty/styles/themes/pink-light/_variables.scss +40 -0
  138. package/packages/store/index.js +33 -0
  139. package/packages/store/modules/account.js +133 -0
  140. package/packages/store/modules/config.js +100 -0
  141. package/packages/store/modules/dialog-menu.js +46 -0
  142. package/packages/store/modules/dialog.js +17 -0
  143. package/packages/store/modules/fullscreen.js +37 -0
  144. package/packages/store/modules/loading.js +8 -0
  145. package/packages/store/modules/page.js +404 -0
  146. package/packages/store/modules/skins.js +69 -0
  147. package/packages/store/modules/system.js +63 -0
  148. package/packages/store/modules/token.js +22 -0
  149. package/packages/styles/_element.scss +97 -0
  150. package/packages/styles/_mixins.scss +39 -0
  151. package/packages/styles/_theme.scss +82 -0
  152. package/packages/styles/_variables.scss +69 -0
  153. package/packages/styles/animation/_index.scss +37 -0
  154. package/packages/styles/animation/breadcrumb.scss +18 -0
  155. package/packages/styles/animation/fade.scss +30 -0
  156. package/packages/styles/animation/move.scss +130 -0
  157. package/packages/styles/app.scss +101 -0
  158. package/packages/styles/components/box/_index.scss +212 -0
  159. package/packages/styles/components/box-row/_index.scss +486 -0
  160. package/packages/styles/components/box-small/_index.scss +73 -0
  161. package/packages/styles/components/button/_index.scss +9 -0
  162. package/packages/styles/components/checkbox-group/_index.scss +20 -0
  163. package/packages/styles/components/color-picker/_index.scss +17 -0
  164. package/packages/styles/components/container/_index.scss +36 -0
  165. package/packages/styles/components/date-range-picker/_index.scss +6 -0
  166. package/packages/styles/components/details/_index.scss +82 -0
  167. package/packages/styles/components/details-dialog/_index.scss +19 -0
  168. package/packages/styles/components/dialog/_index.scss +147 -0
  169. package/packages/styles/components/drag-sort/_index.scss +25 -0
  170. package/packages/styles/components/drag-sort-dialog/_index.scss +9 -0
  171. package/packages/styles/components/drawer/_index.scss +199 -0
  172. package/packages/styles/components/flex/_index.scss +60 -0
  173. package/packages/styles/components/form/_index.scss +3 -0
  174. package/packages/styles/components/form-dialog/_index.scss +15 -0
  175. package/packages/styles/components/form-page/_index.scss +48 -0
  176. package/packages/styles/components/icon/_index.scss +8 -0
  177. package/packages/styles/components/icon-picker/_index.scss +62 -0
  178. package/packages/styles/components/label/_index.scss +289 -0
  179. package/packages/styles/components/list/_index.scss +270 -0
  180. package/packages/styles/components/listbox/_index.scss +57 -0
  181. package/packages/styles/components/login/_index.scss +6 -0
  182. package/packages/styles/components/login-default/_index.scss +94 -0
  183. package/packages/styles/components/login-neon/_index.scss +129 -0
  184. package/packages/styles/components/map/_index.scss +5 -0
  185. package/packages/styles/components/map-coord-picking/_index.scss +50 -0
  186. package/packages/styles/components/map-search-box/_index.scss +83 -0
  187. package/packages/styles/components/scrollbar/_index.scss +16 -0
  188. package/packages/styles/components/select/_index.scss +25 -0
  189. package/packages/styles/components/split/_index.scss +119 -0
  190. package/packages/styles/components/tabnav/_index.scss +194 -0
  191. package/packages/styles/components/tabs/_index.scss +79 -0
  192. package/packages/styles/components/toolbar/_index.scss +120 -0
  193. package/packages/styles/components/tree/_index.scss +7 -0
  194. package/packages/styles/components/tree-select/_index.scss +47 -0
  195. package/packages/styles/components/txt/_index.scss +17 -0
  196. package/packages/styles/components/upload-dialog/_index.scss +54 -0
  197. package/packages/styles/components/upload-multiple/_index.scss +29 -0
  198. package/packages/styles/components/upload-single/_index.scss +23 -0
  199. package/packages/styles/directive/drop/_index.scss +3 -0
  200. package/packages/styles/directive/resizable/_index.scss +105 -0
  201. package/packages/styles/helper/_background.scss +22 -0
  202. package/packages/styles/helper/_border.scss +99 -0
  203. package/packages/styles/helper/_boxshadow.scss +4 -0
  204. package/packages/styles/helper/_fontsize.scss +6 -0
  205. package/packages/styles/helper/_index.scss +19 -0
  206. package/packages/styles/helper/_margin.scss +22 -0
  207. package/packages/styles/helper/_padding.scss +22 -0
  208. package/packages/styles/helper/_pull.scss +9 -0
  209. package/packages/styles/helper/_text.scss +58 -0
  210. package/packages/utils/assist.js +56 -0
  211. package/packages/utils/const.js +12 -0
  212. package/packages/utils/db.js +32 -0
  213. package/packages/utils/dom.js +156 -0
  214. package/packages/utils/http.js +307 -0
  215. package/packages/utils/load-routes.js +37 -0
  216. package/packages/utils/menu.js +53 -0
  217. package/packages/utils/regex.js +7 -0
  218. package/packages/utils/resize-event.js +40 -0
  219. package/packages/utils/token.js +24 -0
  220. package/packages/vuter/attributes.json +41 -0
  221. package/packages/vuter/tags.json +28 -0
  222. package/postcss.config.js +5 -0
  223. package/public/css/index.css +288 -0
  224. package/public/images/favicon.ico +0 -0
  225. package/public/images/login/bg1.jpg +0 -0
  226. package/public/images/login/bg2.jpg +0 -0
  227. package/public/images/login/bg3.jpg +0 -0
  228. package/public/images/login/bg4.jpg +0 -0
  229. package/public/images/logo.png +0 -0
  230. package/public/images/logo.svg +21 -0
  231. package/public/images/motto.png +0 -0
  232. package/public/index.html +54 -0
  233. package/public/lib/font/iconfont.js +1 -0
  234. package/script/npm_install.bat +4 -0
  235. package/script/npm_install.ps1 +13 -0
  236. package/script/npm_publish.bat +4 -0
  237. package/script/npm_publish.ps1 +12 -0
  238. package/script/npm_update.bat +4 -0
  239. package/script/npm_update.ps1 +13 -0
  240. package/src/api/account.js +47 -0
  241. package/src/api/actions.js +18 -0
  242. package/src/api/config.js +78 -0
  243. package/src/components/code-preview/index.vue +77 -0
  244. package/src/components/index.js +7 -0
  245. package/src/components/tmpl/components/attributes/index.vue +19 -0
  246. package/src/components/tmpl/components/events/index.vue +15 -0
  247. package/src/components/tmpl/components/methods/index.vue +15 -0
  248. package/src/components/tmpl/components/slots/index.vue +14 -0
  249. package/src/components/tmpl/index.vue +77 -0
  250. package/src/index.js +25 -0
  251. package/src/main.js +31 -0
  252. package/src/menus/index.js +18 -0
  253. package/src/routes.js +3 -0
  254. package/src/store.js +3 -0
  255. package/src/style/element-ui.scss +11 -0
  256. package/src/utils/menus-loader.js +15 -0
  257. package/src/views/components/advanced/details/_index/data/attrs.js +51 -0
  258. package/src/views/components/advanced/details/_index/data/events.js +7 -0
  259. package/src/views/components/advanced/details/_index/data/slots.js +10 -0
  260. package/src/views/components/advanced/details/_index/index.vue +24 -0
  261. package/src/views/components/advanced/details/_index/page.js +16 -0
  262. package/src/views/components/advanced/details/demo1/demo.vue +59 -0
  263. package/src/views/components/advanced/details/demo1/index.vue +21 -0
  264. package/src/views/components/advanced/details/demo1/page.js +14 -0
  265. package/src/views/components/advanced/drag-sort/_index/data/attrs.js +9 -0
  266. package/src/views/components/advanced/drag-sort/_index/data/events.js +12 -0
  267. package/src/views/components/advanced/drag-sort/_index/index.vue +24 -0
  268. package/src/views/components/advanced/drag-sort/_index/page.js +16 -0
  269. package/src/views/components/advanced/drag-sort/demo1/demo.vue +34 -0
  270. package/src/views/components/advanced/drag-sort/demo1/index.vue +21 -0
  271. package/src/views/components/advanced/drag-sort/demo1/page.js +14 -0
  272. package/src/views/components/advanced/drag-sort-dialog/_index/data/attrs.js +58 -0
  273. package/src/views/components/advanced/drag-sort-dialog/_index/data/events.js +12 -0
  274. package/src/views/components/advanced/drag-sort-dialog/_index/index.vue +28 -0
  275. package/src/views/components/advanced/drag-sort-dialog/_index/page.js +16 -0
  276. package/src/views/components/advanced/drag-sort-dialog/demo1/demo.vue +36 -0
  277. package/src/views/components/advanced/drag-sort-dialog/demo1/index.vue +21 -0
  278. package/src/views/components/advanced/drag-sort-dialog/demo1/page.js +14 -0
  279. package/src/views/components/advanced/list/_index/data/attrs.js +177 -0
  280. package/src/views/components/advanced/list/_index/data/events.js +87 -0
  281. package/src/views/components/advanced/list/_index/data/methods.js +18 -0
  282. package/src/views/components/advanced/list/_index/data/slots.js +46 -0
  283. package/src/views/components/advanced/list/_index/index.vue +87 -0
  284. package/src/views/components/advanced/list/_index/page.js +16 -0
  285. package/src/views/components/advanced/list/demo1/demo.vue +90 -0
  286. package/src/views/components/advanced/list/demo1/index.vue +21 -0
  287. package/src/views/components/advanced/list/demo1/page.js +14 -0
  288. package/src/views/components/advanced/list/demo2/demo.vue +78 -0
  289. package/src/views/components/advanced/list/demo2/index.vue +21 -0
  290. package/src/views/components/advanced/list/demo2/page.js +14 -0
  291. package/src/views/components/advanced/list/demo4/demo.vue +56 -0
  292. package/src/views/components/advanced/list/demo4/index.vue +21 -0
  293. package/src/views/components/advanced/list/demo4/page.js +14 -0
  294. package/src/views/components/advanced/list-dialog/_index/data/attrs.js +58 -0
  295. package/src/views/components/advanced/list-dialog/_index/data/events.js +22 -0
  296. package/src/views/components/advanced/list-dialog/_index/data/methods.js +6 -0
  297. package/src/views/components/advanced/list-dialog/_index/data/slots.js +6 -0
  298. package/src/views/components/advanced/list-dialog/_index/index.vue +31 -0
  299. package/src/views/components/advanced/list-dialog/_index/page.js +16 -0
  300. package/src/views/components/advanced/list-dialog/demo1/demo.vue +75 -0
  301. package/src/views/components/advanced/list-dialog/demo1/index.vue +21 -0
  302. package/src/views/components/advanced/list-dialog/demo1/page.js +14 -0
  303. package/src/views/components/advanced/listbox/_index/data/attrs.js +30 -0
  304. package/src/views/components/advanced/listbox/_index/data/events.js +7 -0
  305. package/src/views/components/advanced/listbox/_index/data/slots.js +6 -0
  306. package/src/views/components/advanced/listbox/_index/index.vue +27 -0
  307. package/src/views/components/advanced/listbox/_index/page.js +16 -0
  308. package/src/views/components/advanced/listbox/demo1/demo.vue +74 -0
  309. package/src/views/components/advanced/listbox/demo1/index.vue +21 -0
  310. package/src/views/components/advanced/listbox/demo1/page.js +14 -0
  311. package/src/views/components/base/box/_index/data/attrs.js +128 -0
  312. package/src/views/components/base/box/_index/data/events.js +17 -0
  313. package/src/views/components/base/box/_index/data/methods.js +17 -0
  314. package/src/views/components/base/box/_index/data/slots.js +26 -0
  315. package/src/views/components/base/box/_index/index.vue +37 -0
  316. package/src/views/components/base/box/_index/page.js +16 -0
  317. package/src/views/components/base/box/demo1/demo.vue +33 -0
  318. package/src/views/components/base/box/demo1/index.vue +21 -0
  319. package/src/views/components/base/box/demo1/page.js +14 -0
  320. package/src/views/components/base/box/demo2/demo.vue +9 -0
  321. package/src/views/components/base/box/demo2/index.vue +21 -0
  322. package/src/views/components/base/box/demo2/page.js +14 -0
  323. package/src/views/components/base/box/demo3/demo.vue +31 -0
  324. package/src/views/components/base/box/demo3/index.vue +21 -0
  325. package/src/views/components/base/box/demo3/page.js +14 -0
  326. package/src/views/components/base/box/demo4/demo.vue +58 -0
  327. package/src/views/components/base/box/demo4/index.vue +21 -0
  328. package/src/views/components/base/box/demo4/page.js +14 -0
  329. package/src/views/components/base/box-col/_index/data/attrs.js +30 -0
  330. package/src/views/components/base/box-col/_index/data/slots.js +6 -0
  331. package/src/views/components/base/box-col/_index/index.vue +27 -0
  332. package/src/views/components/base/box-col/_index/page.js +16 -0
  333. package/src/views/components/base/box-col/demo1/demo.vue +23 -0
  334. package/src/views/components/base/box-col/demo1/index.vue +21 -0
  335. package/src/views/components/base/box-col/demo1/page.js +14 -0
  336. package/src/views/components/base/box-row/_index/data/attrs.js +16 -0
  337. package/src/views/components/base/box-row/_index/data/slots.js +6 -0
  338. package/src/views/components/base/box-row/_index/index.vue +30 -0
  339. package/src/views/components/base/box-row/_index/page.js +16 -0
  340. package/src/views/components/base/box-row/demo1/demo.vue +26 -0
  341. package/src/views/components/base/box-row/demo1/index.vue +21 -0
  342. package/src/views/components/base/box-row/demo1/page.js +15 -0
  343. package/src/views/components/base/box-small/_index/data/attrs.js +44 -0
  344. package/src/views/components/base/box-small/_index/data/events.js +7 -0
  345. package/src/views/components/base/box-small/_index/index.vue +30 -0
  346. package/src/views/components/base/box-small/_index/page.js +16 -0
  347. package/src/views/components/base/box-small/demo1/demo.vue +50 -0
  348. package/src/views/components/base/box-small/demo1/index.vue +21 -0
  349. package/src/views/components/base/box-small/demo1/page.js +14 -0
  350. package/src/views/components/base/button/_index/data/attrs.js +86 -0
  351. package/src/views/components/base/button/_index/data/events.js +7 -0
  352. package/src/views/components/base/button/_index/data/slots.js +6 -0
  353. package/src/views/components/base/button/_index/index.vue +28 -0
  354. package/src/views/components/base/button/_index/page.js +16 -0
  355. package/src/views/components/base/button/demo1/demo.vue +76 -0
  356. package/src/views/components/base/button/demo1/index.vue +21 -0
  357. package/src/views/components/base/button/demo1/page.js +14 -0
  358. package/src/views/components/base/button/demo2/demo.vue +92 -0
  359. package/src/views/components/base/button/demo2/index.vue +21 -0
  360. package/src/views/components/base/button/demo2/page.js +14 -0
  361. package/src/views/components/base/container/_index/data/attrs.js +16 -0
  362. package/src/views/components/base/container/_index/index.vue +25 -0
  363. package/src/views/components/base/container/_index/page.js +16 -0
  364. package/src/views/components/base/dialog/_index/data/attrs.js +128 -0
  365. package/src/views/components/base/dialog/_index/data/events.js +27 -0
  366. package/src/views/components/base/dialog/_index/data/methods.js +22 -0
  367. package/src/views/components/base/dialog/_index/data/slots.js +18 -0
  368. package/src/views/components/base/dialog/_index/index.vue +28 -0
  369. package/src/views/components/base/dialog/_index/page.js +16 -0
  370. package/src/views/components/base/dialog/demo1/demo.vue +75 -0
  371. package/src/views/components/base/dialog/demo1/index.vue +21 -0
  372. package/src/views/components/base/dialog/demo1/page.js +14 -0
  373. package/src/views/components/base/drawer/_index/data/attrs.js +121 -0
  374. package/src/views/components/base/drawer/_index/data/events.js +27 -0
  375. package/src/views/components/base/drawer/_index/data/slots.js +22 -0
  376. package/src/views/components/base/drawer/_index/index.vue +30 -0
  377. package/src/views/components/base/drawer/_index/page.js +16 -0
  378. package/src/views/components/base/drawer/demo1/demo.vue +24 -0
  379. package/src/views/components/base/drawer/demo1/index.vue +22 -0
  380. package/src/views/components/base/drawer/demo1/page.js +14 -0
  381. package/src/views/components/base/flex/_index/data/attrs.js +37 -0
  382. package/src/views/components/base/flex/_index/data/slots.js +18 -0
  383. package/src/views/components/base/flex/_index/index.vue +27 -0
  384. package/src/views/components/base/flex/_index/page.js +16 -0
  385. package/src/views/components/base/flex/demo1/demo.vue +59 -0
  386. package/src/views/components/base/flex/demo1/index.vue +24 -0
  387. package/src/views/components/base/flex/demo1/page.js +14 -0
  388. package/src/views/components/base/label/_index/data/attrs.js +51 -0
  389. package/src/views/components/base/label/_index/data/slots.js +6 -0
  390. package/src/views/components/base/label/_index/index.vue +25 -0
  391. package/src/views/components/base/label/_index/page.js +16 -0
  392. package/src/views/components/base/label/demo1/demo.vue +23 -0
  393. package/src/views/components/base/label/demo1/index.vue +24 -0
  394. package/src/views/components/base/label/demo1/page.js +14 -0
  395. package/src/views/components/base/scrollbar/_index/data/attrs.js +9 -0
  396. package/src/views/components/base/scrollbar/_index/data/methods.js +6 -0
  397. package/src/views/components/base/scrollbar/_index/index.vue +27 -0
  398. package/src/views/components/base/scrollbar/_index/page.js +15 -0
  399. package/src/views/components/base/scrollbar/demo1/demo.vue +76 -0
  400. package/src/views/components/base/scrollbar/demo1/index.vue +21 -0
  401. package/src/views/components/base/scrollbar/demo1/page.js +14 -0
  402. package/src/views/components/base/split/_index/data/attrs.js +37 -0
  403. package/src/views/components/base/split/_index/data/events.js +17 -0
  404. package/src/views/components/base/split/_index/index.vue +29 -0
  405. package/src/views/components/base/split/_index/page.js +16 -0
  406. package/src/views/components/base/split/demo1/demo.vue +27 -0
  407. package/src/views/components/base/split/demo1/index.vue +21 -0
  408. package/src/views/components/base/split/demo1/page.js +14 -0
  409. package/src/views/components/base/tabs/_index/data/attrs.js +9 -0
  410. package/src/views/components/base/tabs/_index/data/events.js +12 -0
  411. package/src/views/components/base/tabs/_index/data/methods.js +12 -0
  412. package/src/views/components/base/tabs/_index/data/slots.js +6 -0
  413. package/src/views/components/base/tabs/_index/index.vue +31 -0
  414. package/src/views/components/base/tabs/_index/page.js +16 -0
  415. package/src/views/components/base/tabs/demo1/demo.vue +79 -0
  416. package/src/views/components/base/tabs/demo1/index.vue +24 -0
  417. package/src/views/components/base/tabs/demo1/page.js +14 -0
  418. package/src/views/components/base/txt/_index/data/attrs.js +9 -0
  419. package/src/views/components/base/txt/_index/data/slots.js +6 -0
  420. package/src/views/components/base/txt/_index/index.vue +27 -0
  421. package/src/views/components/base/txt/_index/page.js +16 -0
  422. package/src/views/components/base/txt/demo1/demo.vue +21 -0
  423. package/src/views/components/base/txt/demo1/index.vue +24 -0
  424. package/src/views/components/base/txt/demo1/page.js +14 -0
  425. package/src/views/components/form/checkbox-group/_index/data/attrs.js +51 -0
  426. package/src/views/components/form/checkbox-group/_index/data/events.js +12 -0
  427. package/src/views/components/form/checkbox-group/_index/data/methods.js +14 -0
  428. package/src/views/components/form/checkbox-group/_index/data/slots.js +6 -0
  429. package/src/views/components/form/checkbox-group/_index/index.vue +49 -0
  430. package/src/views/components/form/checkbox-group/_index/page.js +16 -0
  431. package/src/views/components/form/checkbox-group/demo1/demo.vue +84 -0
  432. package/src/views/components/form/checkbox-group/demo1/index.vue +21 -0
  433. package/src/views/components/form/checkbox-group/demo1/page.js +14 -0
  434. package/src/views/components/form/color-picker/_index/data/attrs.js +58 -0
  435. package/src/views/components/form/color-picker/_index/data/events.js +7 -0
  436. package/src/views/components/form/color-picker/_index/index.vue +24 -0
  437. package/src/views/components/form/color-picker/_index/page.js +16 -0
  438. package/src/views/components/form/color-picker/demo1/demo.vue +44 -0
  439. package/src/views/components/form/color-picker/demo1/index.vue +21 -0
  440. package/src/views/components/form/color-picker/demo1/page.js +14 -0
  441. package/src/views/components/form/date-range-picker/_index/data/attrs.js +37 -0
  442. package/src/views/components/form/date-range-picker/_index/data/events.js +7 -0
  443. package/src/views/components/form/date-range-picker/_index/index.vue +28 -0
  444. package/src/views/components/form/date-range-picker/_index/page.js +16 -0
  445. package/src/views/components/form/date-range-picker/demo1/demo.vue +35 -0
  446. package/src/views/components/form/date-range-picker/demo1/index.vue +21 -0
  447. package/src/views/components/form/date-range-picker/demo1/page.js +14 -0
  448. package/src/views/components/form/form/_index/data/attrs.js +93 -0
  449. package/src/views/components/form/form/_index/data/events.js +19 -0
  450. package/src/views/components/form/form/_index/data/methods.js +14 -0
  451. package/src/views/components/form/form/_index/index.vue +26 -0
  452. package/src/views/components/form/form/_index/page.js +16 -0
  453. package/src/views/components/form/form/demo1/demo.vue +89 -0
  454. package/src/views/components/form/form/demo1/index.vue +21 -0
  455. package/src/views/components/form/form/demo1/page.js +14 -0
  456. package/src/views/components/form/form-dialog/_index/data/attrs.js +191 -0
  457. package/src/views/components/form/form-dialog/_index/data/events.js +39 -0
  458. package/src/views/components/form/form-dialog/_index/data/methods.js +14 -0
  459. package/src/views/components/form/form-dialog/_index/index.vue +26 -0
  460. package/src/views/components/form/form-dialog/_index/page.js +16 -0
  461. package/src/views/components/form/form-dialog/demo1/demo.vue +81 -0
  462. package/src/views/components/form/form-dialog/demo1/index.vue +24 -0
  463. package/src/views/components/form/form-dialog/demo1/page.js +14 -0
  464. package/src/views/components/form/form-page/_index/data/attrs.js +135 -0
  465. package/src/views/components/form/form-page/_index/data/events.js +35 -0
  466. package/src/views/components/form/form-page/_index/data/methods.js +14 -0
  467. package/src/views/components/form/form-page/_index/index.vue +30 -0
  468. package/src/views/components/form/form-page/_index/page.js +16 -0
  469. package/src/views/components/form/form-page/demo1/demo.vue +41 -0
  470. package/src/views/components/form/form-page/demo1/index.vue +21 -0
  471. package/src/views/components/form/form-page/demo1/page.js +14 -0
  472. package/src/views/components/form/icon-picker/_index/data/attrs.js +16 -0
  473. package/src/views/components/form/icon-picker/_index/data/events.js +7 -0
  474. package/src/views/components/form/icon-picker/_index/index.vue +29 -0
  475. package/src/views/components/form/icon-picker/_index/page.js +16 -0
  476. package/src/views/components/form/icon-picker/demo1/demo.vue +47 -0
  477. package/src/views/components/form/icon-picker/demo1/index.vue +21 -0
  478. package/src/views/components/form/icon-picker/demo1/page.js +14 -0
  479. package/src/views/components/form/select/_index/data/attrs.js +79 -0
  480. package/src/views/components/form/select/_index/data/events.js +32 -0
  481. package/src/views/components/form/select/_index/data/methods.js +6 -0
  482. package/src/views/components/form/select/_index/index.vue +27 -0
  483. package/src/views/components/form/select/_index/page.js +16 -0
  484. package/src/views/components/form/select/demo1/demo.vue +61 -0
  485. package/src/views/components/form/select/demo1/index.vue +21 -0
  486. package/src/views/components/form/select/demo1/page.js +14 -0
  487. package/src/views/components/form/select/demo2/index.vue +42 -0
  488. package/src/views/components/form/select/demo2/page.js +14 -0
  489. package/src/views/components/map/map-coord-picking/_index/data/attrs.js +100 -0
  490. package/src/views/components/map/map-coord-picking/_index/data/events.js +1 -0
  491. package/src/views/components/map/map-coord-picking/_index/data/methods.js +1 -0
  492. package/src/views/components/map/map-coord-picking/_index/data/slots.js +1 -0
  493. package/src/views/components/map/map-coord-picking/_index/index.vue +29 -0
  494. package/src/views/components/map/map-coord-picking/_index/page.js +16 -0
  495. package/src/views/components/map/map-coord-picking/demo1/demo.vue +51 -0
  496. package/src/views/components/map/map-coord-picking/demo1/index.vue +21 -0
  497. package/src/views/components/map/map-coord-picking/demo1/page.js +14 -0
  498. package/src/views/components/menus.js +84 -0
  499. package/src/views/login/index.js +23 -0
  500. package/src/views/run/index.vue +57 -0
  501. package/src/views/run/page.js +15 -0
  502. package/vue.config.js +65 -0
  503. package//345/217/221/345/270/203/350/204/232/346/234/254/344/277/256/345/244/215/350/257/264/346/230/216.md +92 -0
  504. package//351/241/271/347/233/256/346/224/271/345/220/215/345/256/214/346/210/220/346/200/273/347/273/223.md +74 -0
@@ -0,0 +1,100 @@
1
+ <template>
2
+ <nm-drawer class="nm-skin-toggle" v-bind="deawer" :visible.sync="visible_" v-on="on">
3
+ <el-divider>皮肤</el-divider>
4
+ <section class="skin-list">
5
+ <div v-for="item in list" :key="item.code" :class="['skin-list-item', model.name === item.code ? 'active' : '']" @click="onSkinChange(item)">
6
+ <div class="img">
7
+ <img :src="item.preview" />
8
+ </div>
9
+ <div class="text">
10
+ <span>{{ item.name }}</span
11
+ >&nbsp;&nbsp;
12
+ <el-popover placement="left" :title="item.name" width="700" trigger="click">
13
+ <img style="width:100%" :src="item.preview" />
14
+ <nm-button slot="reference" type="text" text="查看大图" />
15
+ </el-popover>
16
+ </div>
17
+ </div>
18
+ </section>
19
+ <el-divider>主题</el-divider>
20
+ <section class="theme-list">
21
+ <div :class="['theme-list-item', model.theme === item.name ? 'active' : '']" v-for="item in themes" :key="item.name" :style="{ backgroundColor: item.color }" @click="onThemeChange(item)"></div>
22
+ </section>
23
+ <el-divider>字号</el-divider>
24
+ <section class="fontsize-list">
25
+ <el-radio v-model="model.fontSize" label="default" border>默认</el-radio>
26
+ <el-radio v-model="model.fontSize" label="medium" border size="medium">中号</el-radio>
27
+ <el-radio v-model="model.fontSize" label="small" border size="small">小号</el-radio>
28
+ <el-radio v-model="model.fontSize" label="mini" border size="mini">超小</el-radio>
29
+ </section>
30
+
31
+ <template v-slot:footer>
32
+ <nm-button type="success" text="保存" @click="onSave" />
33
+ </template>
34
+ </nm-drawer>
35
+ </template>
36
+ <script>
37
+ import drawer from '../../../../mixins/components/drawer'
38
+ import { mapState, mapMutations } from 'vuex'
39
+ export default {
40
+ mixins: [drawer],
41
+ data() {
42
+ return {
43
+ deawer: {
44
+ header: true,
45
+ footer: true,
46
+ title: '皮肤设置',
47
+ icon: 'skin',
48
+ width: '650px',
49
+ fullscreen: false,
50
+ modal: false
51
+ },
52
+ model: {
53
+ name: '',
54
+ theme: '',
55
+ fontSize: ''
56
+ },
57
+ on: {
58
+ success: this.onSuccess,
59
+ open: this.onOpen
60
+ }
61
+ }
62
+ },
63
+ computed: {
64
+ ...mapState('app/system', { saveSkin: s => s.actions.saveSkin }),
65
+ ...mapState('app/skins', ['current', 'list']),
66
+ currSkin() {
67
+ return this.list.find(m => m.code === this.model.name)
68
+ },
69
+ themes() {
70
+ return this.currSkin ? this.currSkin.themes : []
71
+ }
72
+ },
73
+ methods: {
74
+ ...mapMutations('app/skins', ['toggle', 'init']),
75
+ onSuccess() {
76
+ this.$emit('success')
77
+ },
78
+ onOpen() {
79
+ this.model = {
80
+ name: this.current.name,
81
+ theme: this.current.theme,
82
+ fontSize: this.current.fontSize || 'default'
83
+ }
84
+ },
85
+ onSkinChange(skin) {
86
+ this.model.name = skin.code
87
+ this.model.theme = skin.themes[0].name
88
+ this.model.fontSize = 'default'
89
+ },
90
+ onThemeChange(theme) {
91
+ this.model.theme = theme.name
92
+ },
93
+ onSave() {
94
+ this.saveSkin(this.model).then(() => {
95
+ this.init(this.model)
96
+ })
97
+ }
98
+ }
99
+ }
100
+ </script>
@@ -0,0 +1,25 @@
1
+ <template>
2
+ <div class="nm-toolbar-item">
3
+ <nm-button class="nm-toolbar-button" type="text" @click="open">
4
+ <nm-icon name="skin" />
5
+ </nm-button>
6
+
7
+ <toggle-form :visible.sync="visible" />
8
+ </div>
9
+ </template>
10
+ <script>
11
+ import ToggleForm from './form'
12
+ export default {
13
+ components: { ToggleForm },
14
+ data() {
15
+ return {
16
+ visible: false
17
+ }
18
+ },
19
+ methods: {
20
+ open() {
21
+ this.visible = true
22
+ }
23
+ }
24
+ }
25
+ </script>
@@ -0,0 +1,44 @@
1
+ <template>
2
+ <div class="nm-toolbar-item">
3
+ <el-dropdown trigger="click">
4
+ <nm-button class="nm-toolbar-button" type="text">
5
+ <nm-icon name="user" />
6
+ </nm-button>
7
+
8
+ <el-dropdown-menu class="nm-header-userinfo-dropdown" slot="dropdown">
9
+ <el-dropdown-item>
10
+ <nm-button type="text" text="账户信息" icon="user" @click="openUserInfo" />
11
+ </el-dropdown-item>
12
+ <el-dropdown-item>
13
+ <nm-button type="text" text="修改密码" icon="password" @click="updatePassword.visiable = true" />
14
+ </el-dropdown-item>
15
+ </el-dropdown-menu>
16
+ </el-dropdown>
17
+
18
+ <!--修改密码-->
19
+ <nm-update-password :visible.sync="updatePassword.visiable" />
20
+ </div>
21
+ </template>
22
+ <script>
23
+ import { mapState, mapGetters } from 'vuex'
24
+ import NmUpdatePassword from '../../../update-password'
25
+ export default {
26
+ components: { NmUpdatePassword },
27
+ data() {
28
+ return {
29
+ updatePassword: {
30
+ visiable: false
31
+ }
32
+ }
33
+ },
34
+ computed: {
35
+ ...mapState('app/account', { userName: 'name' }),
36
+ ...mapGetters('app/config', ['userPage'])
37
+ },
38
+ methods: {
39
+ openUserInfo() {
40
+ this.$router.push({ name: this.userPage, query: { tn_: '账户信息' } })
41
+ }
42
+ }
43
+ }
44
+ </script>
@@ -0,0 +1,26 @@
1
+ <template>
2
+ <div class="nm-toolbar">
3
+ <template v-for="t in customToolbars">
4
+ <component :key="t" :is="`nm-toolbar-${t}`" />
5
+ </template>
6
+ <nm-skin-toggle v-if="toolbar.skin" />
7
+ <nm-userinfo v-if="toolbar.userInfo" />
8
+ <nm-fullscreen v-if="toolbar.fullscreen" />
9
+ <nm-logout v-if="toolbar.logout" />
10
+ </div>
11
+ </template>
12
+ <script>
13
+ import { mapState } from 'vuex'
14
+ import NmFullscreen from './components/fullscreen'
15
+ import NmLogout from './components/logout'
16
+ import NmSkinToggle from './components/skin-toggle'
17
+ import NmUserinfo from './components/userInfo'
18
+ export default {
19
+ name: 'Toolbar',
20
+ components: { NmFullscreen, NmLogout, NmSkinToggle, NmUserinfo },
21
+ computed: {
22
+ ...mapState('app/config', { toolbar: s => s.component.toolbar }),
23
+ ...mapState('app/system', { customToolbars: s => s.customToolbars })
24
+ }
25
+ }
26
+ </script>
@@ -0,0 +1,12 @@
1
+ import mixins from './mixins.vue'
2
+ export default {
3
+ name: 'TreeSelect',
4
+ mixins: [mixins],
5
+ props: {
6
+ /**数据请求方法 */
7
+ action: {
8
+ type: Function,
9
+ required: true
10
+ }
11
+ }
12
+ }
@@ -0,0 +1,334 @@
1
+ <template>
2
+ <!--使用popover来实现下拉效果-->
3
+ <el-popover ref="popover" :popper-class="popperClass" v-model="visible" :width="width">
4
+ <nm-box page header no-scrollbar :title="title_" :icon="icon" footer :loading="showLoading">
5
+ <template v-slot:toolbar>
6
+ <!--全部折叠按钮-->
7
+ <el-tooltip v-if="collapseAll" effect="dark" :content="collapsed ? '展开全部' : '折叠全部'" placement="top">
8
+ <nm-button :icon="collapsed ? 'unfold' : 'fold'" @click="onCollapseAll" />
9
+ </el-tooltip>
10
+ <!--刷新按钮-->
11
+ <nm-button v-if="refresh" icon="refresh" @click="refreshTree" />
12
+ </template>
13
+ <section class="nm-tree-select-content">
14
+ <!--搜索框-->
15
+ <div class="nm-tree-select-search-wrapper">
16
+ <el-input :size="fontSize" v-if="filterable" class="nm-tree-select-search" v-model="keyword" placeholder="请输入内容" prefix-icon="el-icon-search"> </el-input>
17
+ </div>
18
+ <!--树结构-->
19
+ <div class="nm-tree-select-tree-wrapper">
20
+ <div class="nm-tree-select-tree-main">
21
+ <nm-scrollbar horizontal>
22
+ <el-tree ref="tree" v-bind="treeOptions" v-on="treeOn"> </el-tree>
23
+ </nm-scrollbar>
24
+ </div>
25
+ </div>
26
+ </section>
27
+ <!--按钮-->
28
+ <template v-slot:footer>
29
+ <div style="float:left">
30
+ <span style="float:left;font-size:12px;">
31
+ {{ multiple ? '多选' : '单选' }}
32
+ <span v-if="multiple && multipleLimit > 0"
33
+ >(<label class="nm-size-13 nm-text-danger nm-p-3">{{ selection.length }}/{{ multipleLimit }}</label
34
+ >)</span
35
+ >
36
+ </span>
37
+ </div>
38
+ <el-button type="text" @click="save">确定</el-button>
39
+ <el-button class="nm-text-warning" type="text" @click="reset">重置</el-button>
40
+ <el-button class="nm-text-info" type="text" @click="visible = false">取消</el-button>
41
+ </template>
42
+ </nm-box>
43
+ <!--展示-->
44
+ <el-input
45
+ ref="input"
46
+ :value="label"
47
+ class="nm-tree-select-input"
48
+ :placeholder="placeholder"
49
+ :disabled="disabled"
50
+ :suffix-icon="visible ? 'el-icon-arrow-up' : 'el-icon-arrow-down'"
51
+ readonly
52
+ slot="reference"
53
+ >
54
+ </el-input>
55
+ </el-popover>
56
+ </template>
57
+ <script>
58
+ export default {
59
+ data() {
60
+ return {
61
+ title_: this.title,
62
+ /**树配置 */
63
+ treeOptions: {
64
+ data: [],
65
+ nodeKey: 'id',
66
+ props: {
67
+ children: 'children',
68
+ label: 'label'
69
+ },
70
+ showCheckbox: true,
71
+ checkStrictly: true,
72
+ defaultExpandAll: this.defaultExpandAll,
73
+ defaultExpandedKeys: [],
74
+ filterNodeMethod: this.filterNode
75
+ },
76
+ /**树事件 */
77
+ treeOn: {
78
+ check: this.onCheck,
79
+ 'node-expand': this.onNodeExpand,
80
+ 'node-collapse': this.onNodeCollapse
81
+ },
82
+ /**是否显示 */
83
+ visible: false,
84
+ /**输入框显示文本 */
85
+ label: '',
86
+ /**过滤关键字 */
87
+ keyword: '',
88
+ /**已选项 */
89
+ selection: [],
90
+ /**折叠状态 */
91
+ collapsed: false,
92
+ /**加载动画 */
93
+ loading: false
94
+ }
95
+ },
96
+ props: {
97
+ value: [String, Number, Array],
98
+ placeholder: {
99
+ type: String,
100
+ default: '请选择...'
101
+ },
102
+ /**头部标题 */
103
+ title: {
104
+ type: String,
105
+ default: '请选择'
106
+ },
107
+ /**图标 */
108
+ icon: {
109
+ type: String,
110
+ default: 'tree'
111
+ },
112
+ /**宽度 */
113
+ width: {
114
+ type: String,
115
+ default: '250px'
116
+ },
117
+ /**高度 */
118
+ height: {
119
+ type: String,
120
+ default: '400px'
121
+ },
122
+ /**可搜索的 */
123
+ filterable: Boolean,
124
+ /**禁用的 */
125
+ disabled: Boolean,
126
+ /**多选 */
127
+ multiple: Boolean,
128
+ /**多选时最多可以选择的项目数,为 0 则不限制 */
129
+ multipleLimit: {
130
+ type: Number,
131
+ default: 0
132
+ },
133
+ /**多选时展示用的分隔符 */
134
+ separator: {
135
+ type: String,
136
+ default: '/'
137
+ },
138
+ /**是否显示折叠/展开全部按钮 */
139
+ collapseAll: Boolean,
140
+ /**默认展开所有 */
141
+ defaultExpandAll: Boolean,
142
+ /**不显示加载动画 */
143
+ noLoading: Boolean,
144
+ /**是否显示刷新按钮 */
145
+ refresh: Boolean
146
+ },
147
+ computed: {
148
+ popperClass() {
149
+ return `nm-tree-select-popover ${this.filterable ? 'filterable' : ''}`
150
+ },
151
+ selection_() {
152
+ let sl = this.selection
153
+ return this.multiple ? sl.map(m => m) : sl.length > 0 ? sl[0] : null
154
+ },
155
+ /**已选中的值 */
156
+ value_() {
157
+ let sl = this.selection
158
+ return this.multiple ? sl.map(m => m.id) : sl.length > 0 ? sl[0].id : ''
159
+ },
160
+ showLoading() {
161
+ return !this.noLoading && this.loading
162
+ }
163
+ },
164
+ methods: {
165
+ refreshTree() {
166
+ this.loading = true
167
+ this.action().then(data => {
168
+ this.treeOptions.data = data
169
+ this.change()
170
+ this.loading = false
171
+ })
172
+ },
173
+ /**
174
+ * @description 选项更改处理
175
+ */
176
+ change() {
177
+ if (!this.value) return
178
+
179
+ let data = this.treeOptions.data
180
+ if (data.length < 1) return
181
+
182
+ let value = this.multiple ? this.value : [this.value]
183
+
184
+ //设置显示文本
185
+ this.setLabel(value)
186
+ //清除已选项
187
+ this.selection = []
188
+ //要展开的选项
189
+ this.treeOptions.defaultExpandedKeys = value
190
+
191
+ this.$nextTick(() => {
192
+ this.setCheckedKeys(value)
193
+ this.$emit('change', this.value_, this.selection_)
194
+ })
195
+ },
196
+ /**保存 */
197
+ save() {
198
+ if (this.multiple && this.multipleLimit > 0 && this.selection.length > this.multipleLimit) {
199
+ this.showLimitMsg()
200
+ return
201
+ }
202
+ this.setLabel(this.multiple ? this.value_ : [this.value_])
203
+ this.$emit('input', this.value_)
204
+ this.$emit('change', this.value_, this.selection_)
205
+ this.visible = false
206
+ },
207
+ /**重置 */
208
+ reset() {
209
+ this.selection = this.multiple ? [] : ''
210
+ this.setCheckedKeys([])
211
+
212
+ this.setLabel(this.multiple ? this.value_ : [this.value_])
213
+ this.$emit('input', this.value_)
214
+ this.$emit('change', this.value_, this.selection_)
215
+ },
216
+ setLabel(ids) {
217
+ let datas = []
218
+ if (ids && ids.length > 0) {
219
+ ids.map(m => {
220
+ let nodeData = this.getNodeData(this.treeOptions.data, m)
221
+ if (nodeData) {
222
+ datas.push(nodeData)
223
+ }
224
+ })
225
+ }
226
+ this.label = datas.map(m => m.label).join(` ${this.separator} `)
227
+ },
228
+ //递归获取当前数据对象
229
+ getNodeData(list, id) {
230
+ for (let i = 0; i < list.length; i++) {
231
+ const m = list[i]
232
+ if (m.id === id) {
233
+ return m
234
+ }
235
+
236
+ if (m.children) {
237
+ const nodeData = this.getNodeData(m.children, id)
238
+ if (nodeData != null) return nodeData
239
+ }
240
+ }
241
+ return null
242
+ },
243
+ /**设置选中 */
244
+ setCheckedKeys(keys) {
245
+ this.$refs.tree.setCheckedKeys(keys || this.selection.map(m => m.id))
246
+ },
247
+ /**过滤方法 */
248
+ filterNode(value, data) {
249
+ if (!value) return true
250
+ return data.label.indexOf(value) !== -1
251
+ },
252
+ /**显示限制提醒消息 */
253
+ showLimitMsg() {
254
+ this._warning(`最多只能选择${this.multipleLimit}个`)
255
+ },
256
+ /**复选框点击事件 */
257
+ onCheck(data, curr) {
258
+ const { checkedNodes, checkedKeys } = curr
259
+ if (this.multiple) {
260
+ if (this.multipleLimit > 0 && checkedKeys.length > this.multipleLimit) {
261
+ this.showLimitMsg()
262
+ this.setCheckedKeys() //恢复
263
+ return
264
+ }
265
+ this.selection = checkedNodes.map(m => m.item)
266
+ } else {
267
+ this.selection = checkedKeys.length > 0 ? [data.item] : []
268
+ this.setCheckedKeys()
269
+ }
270
+
271
+ this.$emit('check', data, curr)
272
+ },
273
+ /**折叠展开全部事件 */
274
+ onCollapseAll() {
275
+ this.collapsed = !this.collapsed
276
+ let treeStore = this.$refs.tree.store
277
+ for (var i = 0; i < treeStore._getAllNodes().length; i++) {
278
+ treeStore._getAllNodes()[i].expanded = !this.collapsed
279
+ }
280
+ },
281
+ /**节点被点击时的回调 */
282
+ onNodeClick(data, node, cmp) {
283
+ this.$emit('node-click', data, node, cmp)
284
+ },
285
+ /**节点选中状态发生变化时的回调 */
286
+ onCheckChange(data, checked, indeterminate) {
287
+ this.$emit('check-change', data, checked, indeterminate)
288
+ },
289
+ /**当前选中节点变化时触发的事件 */
290
+ onCurrentChange(data, node) {
291
+ this.$emit('current-change', data, node)
292
+ },
293
+ /**节点被展开时触发的事件 */
294
+ onNodeExpand(data, node, cmp) {
295
+ //记录展开的节点
296
+ this.treeOptions.defaultExpandedKeys.push(data.id)
297
+ this.$emit('node-expand', data, node, cmp)
298
+ },
299
+ /**节点被关闭时触发的事件 */
300
+ onNodeCollapse(data, node, cmp) {
301
+ //移除展开的节点
302
+ this.$_.pull(this.treeOptions.defaultExpandedKeys, data.id)
303
+ this.$emit('node-collapse', data, node, cmp)
304
+ }
305
+ },
306
+ created() {
307
+ this.refreshTree()
308
+ },
309
+ mounted() {
310
+ this.$nextTick(() => {
311
+ //初始化宽高
312
+ let el = this.$refs.popover.$el.querySelector('.el-popover')
313
+ el.style.height = this.height
314
+ el.style.width = this.width
315
+ })
316
+ },
317
+ watch: {
318
+ title(val) {
319
+ this.title_ = val
320
+ },
321
+ value(val) {
322
+ if (val !== this.value_) {
323
+ this.change()
324
+ }
325
+ },
326
+ defaultExpandAll(val) {
327
+ this.treeOptions.defaultExpandAll = val
328
+ },
329
+ keyword(val) {
330
+ if (this.filterable) this.$refs.tree.filter(val)
331
+ }
332
+ }
333
+ }
334
+ </script>
@@ -0,0 +1,27 @@
1
+ <template>
2
+ <div :class="['nm-txt', 'nm-text-' + this.type, 'nm-size-' + this.size, { 'nm-text-icon': icon }]">
3
+ <nm-icon v-if="icon" :name="type" />
4
+ <slot>{{ text }}</slot>
5
+ </div>
6
+ </template>
7
+ <script>
8
+ export default {
9
+ name: 'Txt',
10
+ props: {
11
+ // 文本
12
+ text: String,
13
+ // 类型 primary\success\warning\danger
14
+ type: {
15
+ type: String,
16
+ default: 'warning'
17
+ },
18
+ /** 显示图标 */
19
+ icon: Boolean,
20
+ /** 字体大小 */
21
+ size: {
22
+ type: [Number, String],
23
+ default: 12
24
+ }
25
+ }
26
+ }
27
+ </script>
@@ -0,0 +1,84 @@
1
+ <template>
2
+ <nm-form-dialog
3
+ ref="form"
4
+ title="修改密码"
5
+ class="nm-update-password"
6
+ width="400px"
7
+ icon="password"
8
+ :model="model"
9
+ :rules="rules"
10
+ :action="updatePassword"
11
+ :visible.sync="visible_"
12
+ success-msg-text="修改成功"
13
+ @success="logout"
14
+ >
15
+ <el-alert title="提示" type="warning" description="密码修改成功后,需要重新登录" show-icon :closable="false"></el-alert>
16
+ <el-row>
17
+ <el-col :span="18" :offset="2">
18
+ <el-form-item label="原密码:" prop="oldPassword">
19
+ <el-input type="password" v-model="model.oldPassword"></el-input>
20
+ </el-form-item>
21
+ <el-form-item label="新密码:" prop="newPassword">
22
+ <el-input type="password" v-model="model.newPassword"></el-input>
23
+ </el-form-item>
24
+ <el-form-item label="确认密码:" prop="confirmPassword">
25
+ <el-input type="password" v-model="model.confirmPassword"></el-input>
26
+ </el-form-item>
27
+ </el-col>
28
+ </el-row>
29
+ </nm-form-dialog>
30
+ </template>
31
+ <script>
32
+ import visible from '../../mixins/components/visible.js'
33
+ import { mapState, mapActions } from 'vuex'
34
+
35
+ export default {
36
+ name: 'UpdatePassword',
37
+ mixins: [visible],
38
+ data() {
39
+ // 密码验证
40
+ const validator = (rule, value, callback) => {
41
+ if (value === '') {
42
+ callback(new Error('请输入确认密码'))
43
+ } else if (value !== this.model.newPassword) {
44
+ callback(new Error('两次输入密码不一致!'))
45
+ } else {
46
+ callback()
47
+ }
48
+ }
49
+ return {
50
+ model: {
51
+ oldPassword: '',
52
+ newPassword: '',
53
+ confirmPassword: ''
54
+ },
55
+ rules: {
56
+ oldPassword: [{ required: true, message: '请输入原密码' }],
57
+ newPassword: [
58
+ { required: true, message: '请输入新密码' },
59
+ { min: 6, message: '密码长度不能小于6' }
60
+ ],
61
+ confirmPassword: [{ validator }]
62
+ }
63
+ }
64
+ },
65
+ computed: {
66
+ ...mapState('app/system', { updatePassword: s => s.actions.updatePassword })
67
+ },
68
+ methods: {
69
+ ...mapActions('app/system', ['logout'])
70
+ }
71
+ }
72
+ </script>
73
+ <style lang="scss" scoped>
74
+ .nm-update-password {
75
+ .el-alert {
76
+ margin-top: -5px;
77
+ margin-bottom: 10px;
78
+ line-height: 15px;
79
+ }
80
+ .el-visible__footer {
81
+ line-height: 15px;
82
+ }
83
+ }
84
+ </style>
@@ -0,0 +1,23 @@
1
+ import { store } from '../../store'
2
+
3
+ // 按钮权限指令
4
+ const has = {
5
+ inserted: (el, binding) => {
6
+ // 如果编码为空则始终显示
7
+ if (!binding.value) return
8
+
9
+ // 验证是否开启按钮验证
10
+ if (store.state.app.config.permission.button) {
11
+ var buttons = store.state.app.account.buttons
12
+ const code = binding.value
13
+ if (buttons.every(c => c.toLowerCase() !== code.toLowerCase())) {
14
+ el.parentNode.removeChild(el)
15
+ }
16
+ }
17
+ }
18
+ }
19
+
20
+ export default {
21
+ name: 'Has',
22
+ directive: has
23
+ }
@@ -0,0 +1,13 @@
1
+ import lib from '../library'
2
+ import has from './has'
3
+
4
+ const directives = [has]
5
+
6
+ const install = {
7
+ install: Vue => {
8
+ directives.forEach(o => {
9
+ Vue.directive(`${lib.prefix}${o.name}`, o.directive)
10
+ })
11
+ }
12
+ }
13
+ export default install