n20-common-lib 1.2.8 → 1.2.9

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 (189) hide show
  1. package/README.md +2 -2
  2. package/package.json +87 -87
  3. package/src/_qiankun/index.js +113 -113
  4. package/src/_qiankun/postMessage.js +48 -48
  5. package/src/assets/css/_coreLib.scss +35 -35
  6. package/src/assets/css/cl-anchor.scss +23 -23
  7. package/src/assets/css/cl-approve-card.scss +58 -58
  8. package/src/assets/css/cl-dialog.scss +99 -99
  9. package/src/assets/css/cl-drag-list.scss +22 -22
  10. package/src/assets/css/cl-empty.scss +10 -10
  11. package/src/assets/css/cl-expandable-pane.scss +26 -26
  12. package/src/assets/css/cl-expandable.scss +24 -24
  13. package/src/assets/css/cl-file-upload-table.scss +11 -11
  14. package/src/assets/css/cl-filter.scss +4 -4
  15. package/src/assets/css/cl-flow-step.scss +185 -185
  16. package/src/assets/css/cl-footer-box.scss +10 -10
  17. package/src/assets/css/cl-form-item.scss +454 -454
  18. package/src/assets/css/cl-general-card.scss +11 -11
  19. package/src/assets/css/cl-layout-aside.scss +88 -88
  20. package/src/assets/css/cl-layout-content.scss +16 -16
  21. package/src/assets/css/cl-layout-header.scss +73 -73
  22. package/src/assets/css/cl-layout-tabs.scss +87 -87
  23. package/src/assets/css/cl-layout.scss +97 -97
  24. package/src/assets/css/cl-login-temporary.scss +37 -37
  25. package/src/assets/css/cl-message.scss +75 -75
  26. package/src/assets/css/cl-more-tab.scss +98 -98
  27. package/src/assets/css/cl-nav-menu.scss +5 -5
  28. package/src/assets/css/cl-pagination.scss +65 -65
  29. package/src/assets/css/cl-secondary-tab.scss +39 -39
  30. package/src/assets/css/cl-showcolumn.scss +23 -23
  31. package/src/assets/css/cl-sifting.scss +51 -51
  32. package/src/assets/css/cl-statis.scss +42 -42
  33. package/src/assets/css/cl-step.scss +73 -73
  34. package/src/assets/css/cl-suspend.scss +19 -19
  35. package/src/assets/css/cl-tertiary-tab.scss +9 -9
  36. package/src/assets/css/cl-upload.scss +41 -41
  37. package/src/assets/css/cl-worn-pagination.scss +50 -50
  38. package/src/assets/css/el-button.scss +173 -173
  39. package/src/assets/css/el-table.scss +79 -79
  40. package/src/assets/css/element-variables.scss +1061 -1061
  41. package/src/assets/css/element.dev.scss +21 -21
  42. package/src/assets/css/font-icon.scss +27 -27
  43. package/src/assets/css/index.dev.scss +4 -4
  44. package/src/assets/css/index.scss +11 -11
  45. package/src/assets/css/normalize.scss +726 -726
  46. package/src/assets/css/rootvar.scss +139 -139
  47. package/src/assets/css/select.scss +25 -25
  48. package/src/assets/css/title-pop.scss +4 -4
  49. package/src/assets/getJsonc.js +50 -50
  50. package/src/assets/realUrl.js +12 -12
  51. package/src/components/.DS_Store +0 -0
  52. package/src/components/Anchor/AnchorItem.vue +29 -29
  53. package/src/components/Anchor/index.vue +185 -185
  54. package/src/components/ApprovalButtons/index.vue +232 -232
  55. package/src/components/ApprovalCard/index.vue +128 -128
  56. package/src/components/ApprovalRecord/approvalImg.vue +39 -39
  57. package/src/components/ApprovalRecord/index.vue +59 -59
  58. package/src/components/Button/button-group.vue +150 -150
  59. package/src/components/Button/icon-group-button.vue +61 -61
  60. package/src/components/Button/index.vue +56 -56
  61. package/src/components/CascaderArea/index.vue +81 -81
  62. package/src/components/ContentLoading/index.vue +41 -41
  63. package/src/components/ContentNull/index.vue +19 -19
  64. package/src/components/DatePicker/index.vue +27 -27
  65. package/src/components/DatePicker/por.vue +169 -169
  66. package/src/components/Dialog/index.vue +26 -26
  67. package/src/components/Dialog/indexO.vue +116 -116
  68. package/src/components/DragList/index.vue +68 -68
  69. package/src/components/Empty/img/abnormal.svg +108 -108
  70. package/src/components/Empty/img/dispose.svg +71 -71
  71. package/src/components/Empty/img/empty.svg +57 -57
  72. package/src/components/Empty/img/general.svg +58 -58
  73. package/src/components/Empty/img/lock.svg +57 -57
  74. package/src/components/Empty/img/network.svg +59 -59
  75. package/src/components/Empty/img/relevant.svg +68 -68
  76. package/src/components/Empty/img/search.svg +72 -72
  77. package/src/components/Empty/index.vue +92 -92
  78. package/src/components/Expandable/index.vue +49 -49
  79. package/src/components/Expandable/main.vue +52 -52
  80. package/src/components/FileExportAsync/index.vue +174 -174
  81. package/src/components/FileUploadTable/index.vue +484 -484
  82. package/src/components/Filters/index.vue +369 -369
  83. package/src/components/Filters/indexO.vue +104 -104
  84. package/src/components/FlowStep/index.vue +68 -68
  85. package/src/components/FooterBox/index.vue +21 -21
  86. package/src/components/GeneralCard/index.vue +15 -15
  87. package/src/components/InputNumber/index.vue +153 -153
  88. package/src/components/InputNumber/numberRange.vue +47 -47
  89. package/src/components/InputSearch/index.vue +75 -75
  90. package/src/components/Layout/.DS_Store +0 -0
  91. package/src/components/Layout/AsideNav/index.vue +119 -119
  92. package/src/components/Layout/AsideNav/menuItem.vue +34 -34
  93. package/src/components/Layout/AsideNav/submenuTitle.vue +26 -26
  94. package/src/components/Layout/HeaderWrap/changePwd.vue +215 -215
  95. package/src/components/Layout/HeaderWrap/index.vue +348 -348
  96. package/src/components/Layout/HeaderWrap/noticePop.vue +300 -300
  97. package/src/components/Layout/SubContent/index.vue +131 -131
  98. package/src/components/Layout/TabsNav/index.vue +170 -170
  99. package/src/components/Layout/index.vue +529 -529
  100. package/src/components/Layout/utils.js +12 -12
  101. package/src/components/LoginTemporary/form.vue +537 -537
  102. package/src/components/LoginTemporary/index.vue +122 -122
  103. package/src/components/LoginTemporary/qrcode.vue +90 -90
  104. package/src/components/LoginTemporary/retrievePw.vue +28 -28
  105. package/src/components/LoginTemporary/utils.js +73 -73
  106. package/src/components/MicroApp/index.js +67 -67
  107. package/src/components/MicroFrame/index.vue +95 -95
  108. package/src/components/MoreTab/index.vue +232 -232
  109. package/src/components/NavMenu/index.vue +60 -60
  110. package/src/components/NstcG6Components/NstcDialog/NstcDialog.vue +184 -184
  111. package/src/components/PageLayout/page.vue +15 -15
  112. package/src/components/Pagination/index.vue +96 -96
  113. package/src/components/SecondaryTab/index.vue +58 -58
  114. package/src/components/SelectLazy/index.vue +75 -75
  115. package/src/components/SelectTree/SelectTreeLazy.vue +241 -241
  116. package/src/components/SelectTree/index.vue +205 -205
  117. package/src/components/ShowColumn/index.vue +204 -204
  118. package/src/components/Sifting/index.vue +99 -99
  119. package/src/components/Statis/index.vue +97 -97
  120. package/src/components/Statis/statisItem.vue +54 -54
  121. package/src/components/Statis/statisPopover.vue +55 -55
  122. package/src/components/Step/index.vue +38 -38
  123. package/src/components/Suspend/index.vue +72 -72
  124. package/src/components/Table/index.vue +179 -179
  125. package/src/components/Table/indexO.vue +149 -149
  126. package/src/components/Task/index.vue +26 -26
  127. package/src/components/TertiaryTab/index.vue +53 -53
  128. package/src/components/TimePicker/index.vue +28 -28
  129. package/src/components/Upload/index.vue +242 -242
  130. package/src/components/WornPagination/index.vue +73 -73
  131. package/src/directives/VClickOutside/index.js +19 -19
  132. package/src/directives/VHas/index.js +32 -32
  133. package/src/directives/VMove/index.js +42 -42
  134. package/src/directives/VTitle/index.js +64 -64
  135. package/src/directives/VTitle/tooltip.vue +21 -21
  136. package/src/index.js +225 -225
  137. package/src/plugins/CompatibleOld/index.js +57 -57
  138. package/src/plugins/Print/index.js +4 -4
  139. package/src/plugins/Print/print-js/.babelrc +12 -12
  140. package/src/plugins/Print/print-js/LICENSE +21 -21
  141. package/src/plugins/Print/print-js/README.md +98 -98
  142. package/src/plugins/Print/print-js/dist/print.css +96 -96
  143. package/src/plugins/Print/print-js/dist/print.js +990 -990
  144. package/src/plugins/Print/print-js/package.json +60 -60
  145. package/src/plugins/Print/print-js/src/index.d.ts +45 -45
  146. package/src/plugins/Print/print-js/src/index.js +10 -10
  147. package/src/plugins/Print/print-js/src/js/browser.js +33 -33
  148. package/src/plugins/Print/print-js/src/js/functions.js +103 -103
  149. package/src/plugins/Print/print-js/src/js/html.js +70 -70
  150. package/src/plugins/Print/print-js/src/js/image.js +48 -48
  151. package/src/plugins/Print/print-js/src/js/init.js +168 -168
  152. package/src/plugins/Print/print-js/src/js/json.js +109 -109
  153. package/src/plugins/Print/print-js/src/js/modal.js +62 -62
  154. package/src/plugins/Print/print-js/src/js/pdf.js +62 -62
  155. package/src/plugins/Print/print-js/src/js/print.js +102 -102
  156. package/src/plugins/Print/print-js/src/js/raw-html.js +15 -15
  157. package/src/plugins/Print/print-js/src/sass/index.scss +13 -13
  158. package/src/plugins/Print/print-js/src/sass/modules/_colors.scss +9 -9
  159. package/src/plugins/Print/print-js/src/sass/partials/_modal.scss +40 -40
  160. package/src/plugins/Print/print-js/src/sass/partials/_spinner.scss +45 -45
  161. package/src/plugins/Print/print.js +2 -2
  162. package/src/plugins/Print/print.scss +1 -1
  163. package/src/plugins/SetMenuTree/index.vue +41 -41
  164. package/src/plugins/SetMenuTree/logoIcon.vue +37 -37
  165. package/src/plugins/SetMenuTree/setmenutree.vue +427 -427
  166. package/src/plugins/SetMenuTree/utils.js +74 -74
  167. package/src/plugins/Sign/InfosecNetSignCNGAgent.min.js +2000 -2000
  168. package/src/plugins/Sign/index.js +65 -65
  169. package/src/plugins/Sign/sign.js +1 -1
  170. package/src/plugins/setTabsForSub.js +2 -2
  171. package/src/utils/auth.js +53 -53
  172. package/src/utils/axios.js +203 -203
  173. package/src/utils/downloadBlob.js +19 -19
  174. package/src/utils/forEachs.js +16 -16
  175. package/src/utils/getScrollContainer.js +43 -43
  176. package/src/utils/i18n/cn2hk.json +1270 -1270
  177. package/src/utils/i18n/index.js +54 -54
  178. package/src/utils/list2tree.js +36 -36
  179. package/src/utils/msgboxPor.js +26 -26
  180. package/src/utils/print.js +161 -161
  181. package/src/utils/relaNo.js +69 -69
  182. package/src/utils/repairElementUI.js +66 -66
  183. package/src/utils/urlToGo.js +82 -82
  184. package/style/css/normalize.scss +723 -726
  185. package/style/pageDemo/demo-1.vue +130 -131
  186. package/style/pageDemo/demo-2.vue +35 -35
  187. package/style/pageDemo/demo-3.vue +22 -22
  188. package/style/pageDemo/seeCode.js +20 -20
  189. package/style/server-config.jsonc +663 -596
@@ -1,131 +1,131 @@
1
- <template>
2
- <keep-alive v-if="dnsKey">
3
- <router-view
4
- ref="content-cache"
5
- :key="$route.path"
6
- class="content-box"
7
- :no-cache="$route.meta.noCache"
8
- />
9
- </keep-alive>
10
- <router-view
11
- v-else
12
- ref="content-cache"
13
- class="content-box"
14
- :no-cache="$route.meta.noCache"
15
- />
16
- </template>
17
-
18
- <script>
19
- const TestProduction = process.env.VUE_APP_TestProduction === 'true'
20
-
21
- import { setRela } from '../../../utils/relaNo'
22
- const routerBase = process.env.BASE_URL
23
- const routerBaseRe = new RegExp('^' + routerBase)
24
-
25
- export default {
26
- name: 'SubContent',
27
- props: {
28
- appNo: {
29
- type: String,
30
- default: process.env.VUE_APP_NAME
31
- },
32
- isTest: {
33
- type: Boolean,
34
- default: false
35
- }
36
- },
37
- data() {
38
- return {
39
- dnsKey: this.isTest || TestProduction
40
- }
41
- },
42
- watch: {
43
- $route: {
44
- handler(vn, vo) {
45
- if (vo.meta.noCache) {
46
- this.removeOcache({ path: vo.path })
47
- }
48
- }
49
- }
50
- },
51
- created() {
52
- setRela(this.appNo)
53
-
54
- window.addEventListener('message', this.watchMessage)
55
-
56
- setTimeout(() => {
57
- this.pendingRemoveCaches()
58
- }, 60)
59
- },
60
- activated() {
61
- window.addEventListener('message', this.watchMessage)
62
-
63
- setTimeout(() => {
64
- this.pendingRemoveCaches()
65
- }, 60)
66
- },
67
- deactivated() {
68
- window.removeEventListener('message', this.watchMessage)
69
- },
70
- beforeDestroy() {
71
- window.removeEventListener('message', this.watchMessage)
72
- },
73
- methods: {
74
- watchMessage(ev) {
75
- const { targetName, originName } = ev.data
76
- if (targetName === '*' && originName === 'main') {
77
- this.pendingRemoveCaches()
78
- }
79
- },
80
- pendingRemoveCaches() {
81
- for (let key in window._pending_update_cache) {
82
- if (routerBaseRe.test(key) && window._pending_update_cache[key]) {
83
- let cacheKey = key.replace(routerBaseRe, '/')
84
- if (cacheKey === this.$route.path) {
85
- let path = this.$route.path
86
- let oTab = JSON.parse(
87
- JSON.stringify({
88
- path: this.$route.path,
89
- query: this.$route.query
90
- })
91
- )
92
-
93
- this.$router.replace('/loading')
94
- this.removeOcache({ path: path })
95
- setTimeout(() => {
96
- this.$router.replace(oTab)
97
- }, 300)
98
- } else {
99
- this.removeOcache({ path: cacheKey })
100
- }
101
- }
102
- }
103
- },
104
- removeOcache({ path }) {
105
- if (!this.dnsKey) return
106
-
107
- let componentInstance =
108
- this.$refs['content-cache']?.$vnode.parent.componentInstance
109
-
110
- if (componentInstance) {
111
- let kI = componentInstance.keys.findIndex((k) => k === path)
112
- if (kI !== -1) {
113
- let destroy = componentInstance.cache[path].componentInstance.destroy
114
- destroy && destroy()
115
-
116
- delete componentInstance.cache[path]
117
- componentInstance.keys.splice(kI, 1)
118
-
119
- let spath = path.replace(/^\//, routerBase)
120
- delete window._pending_update_cache[spath]
121
- }
122
-
123
- // console.log({
124
- // cache: componentInstance.cache,
125
- // keys: componentInstance.keys
126
- // })
127
- }
128
- }
129
- }
130
- }
131
- </script>
1
+ <template>
2
+ <keep-alive v-if="dnsKey">
3
+ <router-view
4
+ ref="content-cache"
5
+ :key="$route.path"
6
+ class="content-box"
7
+ :no-cache="$route.meta.noCache"
8
+ />
9
+ </keep-alive>
10
+ <router-view
11
+ v-else
12
+ ref="content-cache"
13
+ class="content-box"
14
+ :no-cache="$route.meta.noCache"
15
+ />
16
+ </template>
17
+
18
+ <script>
19
+ const TestProduction = process.env.VUE_APP_TestProduction === 'true'
20
+
21
+ import { setRela } from '../../../utils/relaNo'
22
+ const routerBase = process.env.BASE_URL
23
+ const routerBaseRe = new RegExp('^' + routerBase)
24
+
25
+ export default {
26
+ name: 'SubContent',
27
+ props: {
28
+ appNo: {
29
+ type: String,
30
+ default: process.env.VUE_APP_NAME
31
+ },
32
+ isTest: {
33
+ type: Boolean,
34
+ default: false
35
+ }
36
+ },
37
+ data() {
38
+ return {
39
+ dnsKey: this.isTest || TestProduction
40
+ }
41
+ },
42
+ watch: {
43
+ $route: {
44
+ handler(vn, vo) {
45
+ if (vo.meta.noCache) {
46
+ this.removeOcache({ path: vo.path })
47
+ }
48
+ }
49
+ }
50
+ },
51
+ created() {
52
+ setRela(this.appNo)
53
+
54
+ window.addEventListener('message', this.watchMessage)
55
+
56
+ setTimeout(() => {
57
+ this.pendingRemoveCaches()
58
+ }, 60)
59
+ },
60
+ activated() {
61
+ window.addEventListener('message', this.watchMessage)
62
+
63
+ setTimeout(() => {
64
+ this.pendingRemoveCaches()
65
+ }, 60)
66
+ },
67
+ deactivated() {
68
+ window.removeEventListener('message', this.watchMessage)
69
+ },
70
+ beforeDestroy() {
71
+ window.removeEventListener('message', this.watchMessage)
72
+ },
73
+ methods: {
74
+ watchMessage(ev) {
75
+ const { targetName, originName } = ev.data
76
+ if (targetName === '*' && originName === 'main') {
77
+ this.pendingRemoveCaches()
78
+ }
79
+ },
80
+ pendingRemoveCaches() {
81
+ for (let key in window._pending_update_cache) {
82
+ if (routerBaseRe.test(key) && window._pending_update_cache[key]) {
83
+ let cacheKey = key.replace(routerBaseRe, '/')
84
+ if (cacheKey === this.$route.path) {
85
+ let path = this.$route.path
86
+ let oTab = JSON.parse(
87
+ JSON.stringify({
88
+ path: this.$route.path,
89
+ query: this.$route.query
90
+ })
91
+ )
92
+
93
+ this.$router.replace('/loading')
94
+ this.removeOcache({ path: path })
95
+ setTimeout(() => {
96
+ this.$router.replace(oTab)
97
+ }, 300)
98
+ } else {
99
+ this.removeOcache({ path: cacheKey })
100
+ }
101
+ }
102
+ }
103
+ },
104
+ removeOcache({ path }) {
105
+ if (!this.dnsKey) return
106
+
107
+ let componentInstance =
108
+ this.$refs['content-cache']?.$vnode.parent.componentInstance
109
+
110
+ if (componentInstance) {
111
+ let kI = componentInstance.keys.findIndex((k) => k === path)
112
+ if (kI !== -1) {
113
+ let destroy = componentInstance.cache[path].componentInstance.destroy
114
+ destroy && destroy()
115
+
116
+ delete componentInstance.cache[path]
117
+ componentInstance.keys.splice(kI, 1)
118
+
119
+ let spath = path.replace(/^\//, routerBase)
120
+ delete window._pending_update_cache[spath]
121
+ }
122
+
123
+ // console.log({
124
+ // cache: componentInstance.cache,
125
+ // keys: componentInstance.keys
126
+ // })
127
+ }
128
+ }
129
+ }
130
+ }
131
+ </script>
@@ -1,170 +1,170 @@
1
- /* 多页签导航 */
2
- <template>
3
- <el-tabs
4
- ref="nav-tabs"
5
- :value="activeNav"
6
- type="card"
7
- closable
8
- @tab-click="tabClick"
9
- @tab-remove="tabClose"
10
- @contextmenu.native.prevent="tabContextmenu"
11
- @mousewheel.native.prevent="tabScroll"
12
- >
13
- <el-tab-pane
14
- v-for="tab in tabList"
15
- :key="tab.uuid"
16
- :label="tab | tabLabelF"
17
- :name="tab.uuid"
18
- :tab-info="tab"
19
- />
20
- <el-dropdown
21
- trigger="click"
22
- placement="bottom"
23
- style="display: none"
24
- @command="menuCommand"
25
- >
26
- <span>右键菜单</span>
27
- <el-dropdown-menu
28
- ref="contextMenu"
29
- v-click-outside="clickOut"
30
- class="tab-nav-context-menu"
31
- >
32
- <el-dropdown-item command="refresh">{{
33
- '刷新当前标签' | $l(i18n)
34
- }}</el-dropdown-item>
35
- <el-dropdown-item
36
- v-if="!menuInTab || !menuInTab.keep"
37
- command="close"
38
- >{{ '关闭当前标签' | $l(i18n) }}</el-dropdown-item
39
- >
40
- <el-dropdown-item command="closeNexts">{{
41
- '关闭右侧标签' | $l(i18n)
42
- }}</el-dropdown-item>
43
- <el-dropdown-item command="closeOthers">{{
44
- '关闭其他标签' | $l(i18n)
45
- }}</el-dropdown-item>
46
- </el-dropdown-menu>
47
- </el-dropdown>
48
- </el-tabs>
49
- </template>
50
-
51
- <script>
52
- import { labelF } from '../utils'
53
- const i18n = {
54
- 刷新当前标签: {
55
- en: 'Refresh current label'
56
- },
57
- 关闭当前标签: {
58
- en: 'Close current label'
59
- },
60
- 关闭右侧标签: {
61
- en: 'Close right label'
62
- },
63
- 关闭其他标签: {
64
- en: 'Close other labels'
65
- }
66
- }
67
-
68
- export default {
69
- filters: {
70
- tabLabelF: labelF
71
- },
72
- props: {
73
- tabList: {
74
- type: Array,
75
- default: () => []
76
- },
77
- activeNav: {
78
- type: String,
79
- default: undefined
80
- }
81
- },
82
- data() {
83
- return {
84
- showContextMenu: false,
85
- menuInTab: undefined,
86
- i18n
87
- }
88
- },
89
- methods: {
90
- tabClick(C) {
91
- let item = C.$attrs['tab-info']
92
- this.$emit('tab-click', item)
93
- },
94
- tabClose(uuid) {
95
- this.$emit('tab-close', { uuid })
96
- },
97
- tabContextmenu(ev) {
98
- let emitTab = undefined
99
- ev.path.some((dom) => {
100
- if (dom.classList.contains('el-tabs__item')) {
101
- emitTab = dom
102
- return true
103
- } else if (dom === ev.currentTarget) {
104
- return true
105
- }
106
- })
107
- if (emitTab) {
108
- let uuid = emitTab.getAttribute('id').replace('tab-', '')
109
- this._tabContextmenu(uuid, emitTab)
110
- }
111
- },
112
- _tabContextmenu(uuid, dom) {
113
- this.menuInTab = this.tabList.find((t) => t.uuid === uuid)
114
-
115
- let contextMenu = this.$refs.contextMenu
116
- if (this.showContextMenu) {
117
- contextMenu.showPopper = false
118
- this.showContextMenu = false
119
-
120
- contextMenu.referenceElm = dom
121
- setTimeout(() => {
122
- contextMenu.showPopper = true
123
- this.showContextMenu = true
124
- }, 400)
125
- } else {
126
- contextMenu.referenceElm = dom
127
- contextMenu.showPopper = true
128
- this.showContextMenu = true
129
- }
130
- },
131
- clickOut() {
132
- if (this.showContextMenu) {
133
- this.$refs.contextMenu.showPopper = false
134
- this.showContextMenu = false
135
- this.menuInTab = undefined
136
- }
137
- },
138
- menuCommand(c) {
139
- switch (c) {
140
- case 'refresh':
141
- this.$emit('tab-refresh', { uuid: this.menuInTab.uuid })
142
- break
143
- case 'close':
144
- this.$emit('tab-close', { uuid: this.menuInTab.uuid })
145
- break
146
- case 'closeNexts':
147
- this.$emit('tab-close-nexts', this.menuInTab.uuid)
148
- break
149
- case 'closeOthers':
150
- this.$emit('tab-close-others', this.menuInTab.uuid)
151
- break
152
- }
153
-
154
- this.clickOut()
155
- },
156
- tabScroll(ev) {
157
- let isPrev = ev.wheelDelta < 0
158
- let refNav = this.$refs['nav-tabs'].$refs['nav']
159
- if (isPrev) {
160
- refNav.scrollNext()
161
- } else {
162
- refNav.scrollPrev()
163
- }
164
- }
165
- }
166
- }
167
- </script>
168
-
169
- <style>
170
- </style>
1
+ /* 多页签导航 */
2
+ <template>
3
+ <el-tabs
4
+ ref="nav-tabs"
5
+ :value="activeNav"
6
+ type="card"
7
+ closable
8
+ @tab-click="tabClick"
9
+ @tab-remove="tabClose"
10
+ @contextmenu.native.prevent="tabContextmenu"
11
+ @mousewheel.native.prevent="tabScroll"
12
+ >
13
+ <el-tab-pane
14
+ v-for="tab in tabList"
15
+ :key="tab.uuid"
16
+ :label="tab | tabLabelF"
17
+ :name="tab.uuid"
18
+ :tab-info="tab"
19
+ />
20
+ <el-dropdown
21
+ trigger="click"
22
+ placement="bottom"
23
+ style="display: none"
24
+ @command="menuCommand"
25
+ >
26
+ <span>右键菜单</span>
27
+ <el-dropdown-menu
28
+ ref="contextMenu"
29
+ v-click-outside="clickOut"
30
+ class="tab-nav-context-menu"
31
+ >
32
+ <el-dropdown-item command="refresh">{{
33
+ '刷新当前标签' | $l(i18n)
34
+ }}</el-dropdown-item>
35
+ <el-dropdown-item
36
+ v-if="!menuInTab || !menuInTab.keep"
37
+ command="close"
38
+ >{{ '关闭当前标签' | $l(i18n) }}</el-dropdown-item
39
+ >
40
+ <el-dropdown-item command="closeNexts">{{
41
+ '关闭右侧标签' | $l(i18n)
42
+ }}</el-dropdown-item>
43
+ <el-dropdown-item command="closeOthers">{{
44
+ '关闭其他标签' | $l(i18n)
45
+ }}</el-dropdown-item>
46
+ </el-dropdown-menu>
47
+ </el-dropdown>
48
+ </el-tabs>
49
+ </template>
50
+
51
+ <script>
52
+ import { labelF } from '../utils'
53
+ const i18n = {
54
+ 刷新当前标签: {
55
+ en: 'Refresh current label'
56
+ },
57
+ 关闭当前标签: {
58
+ en: 'Close current label'
59
+ },
60
+ 关闭右侧标签: {
61
+ en: 'Close right label'
62
+ },
63
+ 关闭其他标签: {
64
+ en: 'Close other labels'
65
+ }
66
+ }
67
+
68
+ export default {
69
+ filters: {
70
+ tabLabelF: labelF
71
+ },
72
+ props: {
73
+ tabList: {
74
+ type: Array,
75
+ default: () => []
76
+ },
77
+ activeNav: {
78
+ type: String,
79
+ default: undefined
80
+ }
81
+ },
82
+ data() {
83
+ return {
84
+ showContextMenu: false,
85
+ menuInTab: undefined,
86
+ i18n
87
+ }
88
+ },
89
+ methods: {
90
+ tabClick(C) {
91
+ let item = C.$attrs['tab-info']
92
+ this.$emit('tab-click', item)
93
+ },
94
+ tabClose(uuid) {
95
+ this.$emit('tab-close', { uuid })
96
+ },
97
+ tabContextmenu(ev) {
98
+ let emitTab = undefined
99
+ ev.path.some((dom) => {
100
+ if (dom.classList.contains('el-tabs__item')) {
101
+ emitTab = dom
102
+ return true
103
+ } else if (dom === ev.currentTarget) {
104
+ return true
105
+ }
106
+ })
107
+ if (emitTab) {
108
+ let uuid = emitTab.getAttribute('id').replace('tab-', '')
109
+ this._tabContextmenu(uuid, emitTab)
110
+ }
111
+ },
112
+ _tabContextmenu(uuid, dom) {
113
+ this.menuInTab = this.tabList.find((t) => t.uuid === uuid)
114
+
115
+ let contextMenu = this.$refs.contextMenu
116
+ if (this.showContextMenu) {
117
+ contextMenu.showPopper = false
118
+ this.showContextMenu = false
119
+
120
+ contextMenu.referenceElm = dom
121
+ setTimeout(() => {
122
+ contextMenu.showPopper = true
123
+ this.showContextMenu = true
124
+ }, 400)
125
+ } else {
126
+ contextMenu.referenceElm = dom
127
+ contextMenu.showPopper = true
128
+ this.showContextMenu = true
129
+ }
130
+ },
131
+ clickOut() {
132
+ if (this.showContextMenu) {
133
+ this.$refs.contextMenu.showPopper = false
134
+ this.showContextMenu = false
135
+ this.menuInTab = undefined
136
+ }
137
+ },
138
+ menuCommand(c) {
139
+ switch (c) {
140
+ case 'refresh':
141
+ this.$emit('tab-refresh', { uuid: this.menuInTab.uuid })
142
+ break
143
+ case 'close':
144
+ this.$emit('tab-close', { uuid: this.menuInTab.uuid })
145
+ break
146
+ case 'closeNexts':
147
+ this.$emit('tab-close-nexts', this.menuInTab.uuid)
148
+ break
149
+ case 'closeOthers':
150
+ this.$emit('tab-close-others', this.menuInTab.uuid)
151
+ break
152
+ }
153
+
154
+ this.clickOut()
155
+ },
156
+ tabScroll(ev) {
157
+ let isPrev = ev.wheelDelta < 0
158
+ let refNav = this.$refs['nav-tabs'].$refs['nav']
159
+ if (isPrev) {
160
+ refNav.scrollNext()
161
+ } else {
162
+ refNav.scrollPrev()
163
+ }
164
+ }
165
+ }
166
+ }
167
+ </script>
168
+
169
+ <style>
170
+ </style>