eoss-ui 0.7.18 → 0.7.19

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 (245) hide show
  1. package/lib/calogin.js +233 -233
  2. package/lib/eoss-ui.common.js +775 -771
  3. package/lib/flow-list.js +81 -81
  4. package/lib/flow.js +291 -289
  5. package/lib/index.js +1 -1
  6. package/lib/main.js +142 -142
  7. package/lib/qr-code.js +13 -13
  8. package/lib/switch.js +9 -7
  9. package/package.json +160 -160
  10. package/packages/button/index.js +5 -5
  11. package/packages/button/src/main.vue +418 -418
  12. package/packages/button-group/index.js +5 -5
  13. package/packages/button-group/src/main.vue +298 -298
  14. package/packages/calendar/index.js +5 -5
  15. package/packages/calogin/index.js +5 -5
  16. package/packages/calogin/src/main.vue +412 -412
  17. package/packages/calogin/src/plugin.js +915 -915
  18. package/packages/card/index.js +5 -5
  19. package/packages/card/src/main.vue +156 -156
  20. package/packages/cascader/index.js +5 -5
  21. package/packages/cascader/src/main.vue +168 -168
  22. package/packages/checkbox-group/index.js +5 -5
  23. package/packages/checkbox-group/src/main.vue +333 -333
  24. package/packages/clients/index.js +5 -5
  25. package/packages/clients/src/main.vue +151 -151
  26. package/packages/data-table/index.js +5 -5
  27. package/packages/data-table/src/children.vue +39 -39
  28. package/packages/data-table/src/column.vue +988 -988
  29. package/packages/data-table/src/main.vue +1831 -1831
  30. package/packages/data-table/src/sizer.vue +195 -195
  31. package/packages/data-table-form/index.js +5 -5
  32. package/packages/data-table-form/src/checkbox.vue +101 -101
  33. package/packages/data-table-form/src/colgroup.vue +17 -17
  34. package/packages/data-table-form/src/main.vue +181 -181
  35. package/packages/data-table-form/src/radio.vue +65 -65
  36. package/packages/data-table-form/src/table.vue +233 -233
  37. package/packages/data-table-form/src/tbody.vue +336 -336
  38. package/packages/data-table-form/src/thead.vue +68 -68
  39. package/packages/date-picker/index.js +5 -5
  40. package/packages/date-picker/src/main.vue +236 -236
  41. package/packages/dialog/index.js +5 -5
  42. package/packages/enable-drag/index.js +5 -5
  43. package/packages/enterprise/index.js +5 -5
  44. package/packages/enterprise/src/main.vue +66 -66
  45. package/packages/error-page/index.js +5 -5
  46. package/packages/error-page/src/main.vue +44 -44
  47. package/packages/flow/index.js +5 -5
  48. package/packages/flow/src/component/Circulate.vue +413 -413
  49. package/packages/flow/src/component/CommonOpinions.vue +373 -372
  50. package/packages/flow/src/component/CustomPreset.vue +322 -322
  51. package/packages/flow/src/component/FileList.vue +97 -97
  52. package/packages/flow/src/component/FreeCirculation.vue +240 -240
  53. package/packages/flow/src/component/Preset.vue +255 -255
  54. package/packages/flow/src/component/SendMsg.vue +242 -242
  55. package/packages/flow/src/component/TimeLimit.vue +190 -190
  56. package/packages/flow/src/component/taskUnionExamine.vue +649 -649
  57. package/packages/flow/src/form.vue +121 -121
  58. package/packages/flow/src/freeStartFlow.vue +2847 -2847
  59. package/packages/flow/src/main.vue +3802 -3801
  60. package/packages/flow/src/processForm.vue +1287 -1287
  61. package/packages/flow/src/processReject.vue +308 -308
  62. package/packages/flow/src/reset.vue +941 -941
  63. package/packages/flow/src/startTaskRead.vue +691 -691
  64. package/packages/flow/src/supervise.vue +159 -159
  65. package/packages/flow/src/table.vue +58 -58
  66. package/packages/flow-group/index.js +5 -5
  67. package/packages/flow-group/src/main.vue +696 -696
  68. package/packages/flow-list/index.js +5 -5
  69. package/packages/flow-list/src/main.vue +1770 -1770
  70. package/packages/form/index.js +5 -5
  71. package/packages/form/src/main.vue +3901 -3901
  72. package/packages/form/src/table.vue +1512 -1512
  73. package/packages/handle-user/index.js +5 -5
  74. package/packages/handle-user/src/main.vue +137 -137
  75. package/packages/handler/index.js +5 -5
  76. package/packages/handler/src/main.vue +497 -497
  77. package/packages/icon/index.js +5 -5
  78. package/packages/icon/src/main.vue +104 -104
  79. package/packages/icons/index.js +5 -5
  80. package/packages/icons/src/main.vue +81 -81
  81. package/packages/input/index.js +5 -5
  82. package/packages/input/src/main.vue +356 -356
  83. package/packages/input-number/index.js +5 -5
  84. package/packages/input-number/src/main.vue +106 -106
  85. package/packages/label/index.js +5 -5
  86. package/packages/label/src/main.vue +457 -457
  87. package/packages/layout/index.js +5 -5
  88. package/packages/layout/src/item.vue +152 -152
  89. package/packages/layout/src/main.vue +31 -31
  90. package/packages/login/index.js +5 -5
  91. package/packages/login/src/main.vue +1993 -1993
  92. package/packages/login/src/resetPassword.vue +557 -557
  93. package/packages/main/index.js +5 -5
  94. package/packages/main/src/default/message.vue +249 -249
  95. package/packages/main/src/default/notice.vue +157 -157
  96. package/packages/main/src/default/userinfo.vue +502 -502
  97. package/packages/main/src/public/online.vue +89 -89
  98. package/packages/main/src/public/search.vue +464 -464
  99. package/packages/main/src/public/settings.vue +221 -221
  100. package/packages/main/src/simplicity/apps.vue +388 -388
  101. package/packages/main/src/simplicity/avatar.vue +82 -82
  102. package/packages/main/src/simplicity/handler.vue +263 -263
  103. package/packages/main/src/simplicity/index.vue +2125 -2125
  104. package/packages/main/src/simplicity/lists.vue +84 -84
  105. package/packages/main/src/simplicity/menu-list.vue +135 -135
  106. package/packages/main/src/simplicity/message.vue +259 -259
  107. package/packages/main/src/simplicity/notice.vue +190 -190
  108. package/packages/main/src/simplicity/router-page.vue +45 -45
  109. package/packages/main/src/simplicity/sub-menu.vue +264 -264
  110. package/packages/main/src/simplicity/user.vue +259 -259
  111. package/packages/main/src/simplicity/userinfo.vue +398 -398
  112. package/packages/menu/index.js +5 -5
  113. package/packages/menu/src/main.vue +584 -584
  114. package/packages/nav/index.js +5 -5
  115. package/packages/nav/src/main.vue +351 -351
  116. package/packages/notify/index.js +5 -5
  117. package/packages/notify/src/main.vue +538 -538
  118. package/packages/page/index.js +5 -5
  119. package/packages/page/src/main.vue +167 -167
  120. package/packages/pagination/index.js +5 -5
  121. package/packages/pagination/src/main.vue +96 -96
  122. package/packages/player/index.js +5 -5
  123. package/packages/player/src/main.vue +194 -194
  124. package/packages/qr-code/index.js +5 -5
  125. package/packages/qr-code/src/main.vue +170 -170
  126. package/packages/radio-group/index.js +6 -6
  127. package/packages/radio-group/src/main.vue +319 -319
  128. package/packages/retrial-auth/index.js +5 -5
  129. package/packages/retrial-auth/src/main.vue +280 -280
  130. package/packages/select/index.js +5 -5
  131. package/packages/select/src/main.vue +782 -782
  132. package/packages/select-ganged/index.js +5 -5
  133. package/packages/select-ganged/src/main.vue +724 -724
  134. package/packages/selector/index.js +5 -5
  135. package/packages/selector/src/main.vue +761 -761
  136. package/packages/selector-panel/index.js +5 -5
  137. package/packages/selector-panel/src/main.vue +1027 -1027
  138. package/packages/selector-panel/src/selection.vue +170 -170
  139. package/packages/selector-panel/src/tree.vue +129 -129
  140. package/packages/sizer/index.js +5 -5
  141. package/packages/sizer/src/main.vue +254 -254
  142. package/packages/steps/index.js +5 -5
  143. package/packages/steps/src/main.vue +181 -181
  144. package/packages/switch/index.js +5 -5
  145. package/packages/switch/src/main.vue +170 -154
  146. package/packages/table-form/index.js +5 -5
  147. package/packages/tabs/index.js +5 -5
  148. package/packages/tabs/src/main.vue +788 -788
  149. package/packages/tabs-panel/index.js +5 -5
  150. package/packages/tabs-panel/src/main.vue +29 -29
  151. package/packages/theme-chalk/src/base.scss +261 -261
  152. package/packages/theme-chalk/src/button-group.scss +176 -176
  153. package/packages/theme-chalk/src/button.scss +24 -24
  154. package/packages/theme-chalk/src/calendar.scss +113 -113
  155. package/packages/theme-chalk/src/card.scss +99 -99
  156. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  157. package/packages/theme-chalk/src/clients.scss +87 -87
  158. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  159. package/packages/theme-chalk/src/data-table.scss +293 -293
  160. package/packages/theme-chalk/src/date-picker.scss +7 -7
  161. package/packages/theme-chalk/src/dialog.scss +77 -77
  162. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  163. package/packages/theme-chalk/src/enterprise.scss +5 -5
  164. package/packages/theme-chalk/src/error-page.scss +18 -18
  165. package/packages/theme-chalk/src/flow-group.scss +110 -110
  166. package/packages/theme-chalk/src/flow-list.scss +39 -39
  167. package/packages/theme-chalk/src/flow.scss +348 -348
  168. package/packages/theme-chalk/src/form.scss +501 -501
  169. package/packages/theme-chalk/src/handle-user.scss +40 -40
  170. package/packages/theme-chalk/src/handler.scss +148 -148
  171. package/packages/theme-chalk/src/icon.scss +1817 -1817
  172. package/packages/theme-chalk/src/icons.scss +99 -99
  173. package/packages/theme-chalk/src/input.scss +9 -9
  174. package/packages/theme-chalk/src/label.scss +24 -24
  175. package/packages/theme-chalk/src/layout.scss +46 -46
  176. package/packages/theme-chalk/src/login.scss +984 -984
  177. package/packages/theme-chalk/src/main.scss +663 -663
  178. package/packages/theme-chalk/src/menu.scss +222 -222
  179. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  180. package/packages/theme-chalk/src/nav.scss +111 -111
  181. package/packages/theme-chalk/src/page.scss +3 -3
  182. package/packages/theme-chalk/src/pagination.scss +29 -29
  183. package/packages/theme-chalk/src/player.scss +9 -9
  184. package/packages/theme-chalk/src/qr-code.scss +17 -17
  185. package/packages/theme-chalk/src/radio-group.scss +9 -9
  186. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  187. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  188. package/packages/theme-chalk/src/select.scss +8 -8
  189. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  190. package/packages/theme-chalk/src/selector.scss +92 -92
  191. package/packages/theme-chalk/src/simplicity.scss +1366 -1366
  192. package/packages/theme-chalk/src/sizer.scss +36 -36
  193. package/packages/theme-chalk/src/steps.scss +88 -88
  194. package/packages/theme-chalk/src/switch.scss +3 -3
  195. package/packages/theme-chalk/src/table-form.scss +1 -1
  196. package/packages/theme-chalk/src/tabs.scss +87 -87
  197. package/packages/theme-chalk/src/tips.scss +7 -7
  198. package/packages/theme-chalk/src/toolbar.scss +179 -179
  199. package/packages/theme-chalk/src/tree-group.scss +72 -72
  200. package/packages/theme-chalk/src/tree.scss +165 -165
  201. package/packages/theme-chalk/src/upload.scss +172 -172
  202. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  203. package/packages/tips/index.js +5 -5
  204. package/packages/tips/src/main.vue +141 -141
  205. package/packages/toolbar/index.js +5 -5
  206. package/packages/toolbar/src/main.vue +430 -430
  207. package/packages/tree/index.js +5 -5
  208. package/packages/tree-group/index.js +5 -5
  209. package/packages/upload/index.js +5 -5
  210. package/packages/upload/src/main.vue +1343 -1343
  211. package/packages/upload/src/picture.js +15 -15
  212. package/packages/wujie/index.js +5 -5
  213. package/packages/wujie/src/main.vue +145 -145
  214. package/packages/wxlogin/index.js +5 -5
  215. package/packages/wxlogin/src/main.vue +128 -128
  216. package/src/config/api.js +315 -315
  217. package/src/config/image.js +2 -2
  218. package/src/index.js +163 -163
  219. package/src/utils/bus.js +3 -3
  220. package/src/utils/date-util.js +312 -312
  221. package/src/utils/http.js +50 -50
  222. package/src/utils/rules.js +18 -18
  223. package/src/utils/store.js +21 -21
  224. package/src/utils/webSocket.js +107 -107
  225. package/packages/.DS_Store +0 -0
  226. package/packages/autocomplete/.DS_Store +0 -0
  227. package/packages/calogin/.DS_Store +0 -0
  228. package/packages/date-picker/.DS_Store +0 -0
  229. package/packages/date-picker/src/.DS_Store +0 -0
  230. package/packages/flow/.DS_Store +0 -0
  231. package/packages/flow/src/.DS_Store +0 -0
  232. package/packages/flow-list/.DS_Store +0 -0
  233. package/packages/form/.DS_Store +0 -0
  234. package/packages/login/.DS_Store +0 -0
  235. package/packages/main/.DS_Store +0 -0
  236. package/packages/main/src/.DS_Store +0 -0
  237. package/packages/menu/.DS_Store +0 -0
  238. package/packages/scrollbar/.DS_Store +0 -0
  239. package/packages/select/.DS_Store +0 -0
  240. package/packages/selector/.DS_Store +0 -0
  241. package/packages/selector-panel/.DS_Store +0 -0
  242. package/packages/theme-chalk/src/.DS_Store +0 -0
  243. package/packages/upload/.DS_Store +0 -0
  244. package/src/.DS_Store +0 -0
  245. package/src/utils/.DS_Store +0 -0
@@ -1,351 +1,351 @@
1
- <template>
2
- <div
3
- ref="esNav"
4
- class="es-nav"
5
- :class="biserial ? 'es-nav-biserial' : ''"
6
- :style="{ width: boxWidth, height: height }"
7
- >
8
- <div
9
- class="es-nav-initial"
10
- v-if="biserial"
11
- :style="{
12
- width: _navWidth,
13
- left:
14
- this.overlap && !this.subMenu.length
15
- ? '15px'
16
- : show
17
- ? '-' + boxWidth
18
- : ''
19
- }"
20
- >
21
- <es-menu
22
- :class="{ 'es-nav-overlap': overlap }"
23
- v-bind="$attrs"
24
- sub-nav
25
- :data="menu"
26
- :is-default="isDefault"
27
- :deep="false"
28
- :default-active="subActive"
29
- :biserial="biserial"
30
- :menu-icons="menuIcon"
31
- :icons="icons"
32
- :sub-icon="subIcon"
33
- @select="handleTrigger"
34
- ></es-menu>
35
- </div>
36
- <div
37
- class="es-nav-main"
38
- :class="{ 'es-nav-overlap': overlap }"
39
- :biserial="biserial"
40
- :style="{
41
- width: biserial ? width : boxWidth,
42
- left: biserial ? (show ? '15px' : navWidth) : ''
43
- }"
44
- v-show="showMenu"
45
- >
46
- <div class="es-nav-title" v-if="showTitle" ref="navTitle">
47
- <span v-show="!isCollapse">{{ headline }}</span>
48
- <template v-if="showCollapse">
49
- <i
50
- v-show="!isCollapse"
51
- class="es-icon-indent es-collapse-handle"
52
- @click="handleChange"
53
- ></i>
54
- <i
55
- v-show="isCollapse"
56
- class="es-icon-increase es-collapse-handle"
57
- @click="handleChange"
58
- ></i>
59
- </template>
60
- </div>
61
- <es-menu
62
- v-bind="$attrs"
63
- :class="biserial ? 'es-nav-biserial' : ''"
64
- :data="biserial ? subMenu : menu"
65
- :collapse="isCollapse"
66
- :default-active="menuActive"
67
- :width="isTop ? boxWidth : menuWidth"
68
- :height="menuHeight"
69
- :style="{ height: menuHeight }"
70
- :is-default="isDefault"
71
- :biserial="biserial"
72
- :paddingLeft="paddingLeft"
73
- :menu-icon="menuIcon"
74
- :icons="icons"
75
- :sub-icon="subIcon"
76
- @select="handleSelect"
77
- @open="handleOpen"
78
- @close="handleClose"
79
- ></es-menu>
80
- </div>
81
- <es-enable-drag
82
- v-show="show"
83
- :distance="0"
84
- topDistance="100px"
85
- leftDistance="0px"
86
- @click="handleClick"
87
- ></es-enable-drag>
88
- </div>
89
- </template>
90
- <script>
91
- import util from 'eoss-ui/src/utils/util';
92
- import { throttle } from 'throttle-debounce';
93
- export default {
94
- name: 'EsNav',
95
- inheritAttrs: false,
96
- props: {
97
- isTop: Boolean,
98
- data: {
99
- type: Array,
100
- default: []
101
- },
102
- title: {
103
- type: [String, Boolean],
104
- default: ''
105
- },
106
- width: {
107
- type: String,
108
- default: '200px'
109
- },
110
- navWidth: {
111
- type: String,
112
- default: '70px'
113
- },
114
- showCollapse: {
115
- type: Boolean,
116
- default: true
117
- },
118
- collapse: {
119
- type: Boolean,
120
- default: false
121
- },
122
- //是否双列导航
123
- biserial: Boolean,
124
- defaultActive: [String, Array],
125
- isDefault: Boolean,
126
- paddingLeft: Number,
127
- menuIcon: String,
128
- icons: Object,
129
- subIcon: {
130
- type: Boolean,
131
- default: true
132
- },
133
- overlap: Boolean,
134
- //隐藏菜单
135
- hideSubMenu: Boolean
136
- },
137
- computed: {
138
- show() {
139
- return this.overlap && this.subMenu.length;
140
- },
141
- showMenu() {
142
- return this.biserial ? this.subMenu.length : this.menu.length;
143
- },
144
- menu() {
145
- return this.data;
146
- },
147
- showTitle() {
148
- if (this.title === false && this.showCollapse === false) {
149
- return false;
150
- }
151
- return true;
152
- },
153
- subActive() {
154
- let active =
155
- this.biserial &&
156
- Array.isArray(this.defaultActive) &&
157
- this.defaultActive.length
158
- ? this.defaultActive[0]
159
- : undefined;
160
- return active;
161
- },
162
- menuActive() {
163
- let active =
164
- typeof this.defaultActive === 'string'
165
- ? this.defaultActive
166
- : this.defaultActive && this.defaultActive.length
167
- ? this.defaultActive[this.defaultActive.length - 1]
168
- : undefined;
169
- return active;
170
- },
171
- boxWidth() {
172
- if (!this.biserial) {
173
- if (this.overlap) {
174
- return this.navWidth;
175
- }
176
- if (this.isShow) {
177
- return this.width;
178
- } else {
179
- return this.navWidth;
180
- }
181
- }
182
- return this.subMenu &&
183
- this.subMenu.length &&
184
- this.isShow &&
185
- !this.overlap &&
186
- !this.hideSubMenu
187
- ? parseInt(this.width, 10) + parseInt(this.navWidth, 10) + 'px'
188
- : this.navWidth;
189
- },
190
- _navWidth() {
191
- return this.overlap
192
- ? parseInt(this.navWidth, 10) - 30 + 'px'
193
- : this.navWidth;
194
- }
195
- },
196
- watch: {
197
- collapse(val) {
198
- this.isCollapse = this.biserial ? false : val;
199
- },
200
- title(val) {
201
- if (typeof val === 'string' && val) {
202
- this.headline = val;
203
- }
204
- },
205
- boxWidth() {
206
- this.getHeight();
207
- },
208
- biserial: {
209
- handler(val) {
210
- this.isShow = !val;
211
- this.getHeight();
212
- }
213
- },
214
- defaultActive: {
215
- immediate: true,
216
- deep: true,
217
- handler(val) {
218
- if (val && val.length) {
219
- if (typeof val !== 'string' && val.length) {
220
- this.isShow = true;
221
- if (this.biserial) {
222
- this.active = val[0];
223
- } else {
224
- this.active = val[val.length - 1];
225
- }
226
- this.menu.forEach((item) => {
227
- if (item.id === this.active) {
228
- this.subMenu = item.children || [];
229
- this.headline = this.title ? this.title : item.text;
230
- return;
231
- }
232
- });
233
- }
234
- }
235
- }
236
- },
237
- menu(val) {
238
- if (val && val.length) {
239
- if (
240
- this.defaultActive &&
241
- typeof this.defaultActive !== 'string' &&
242
- this.defaultActive.length
243
- ) {
244
- this.isShow = true;
245
- if (this.biserial) {
246
- this.active = this.defaultActive[0];
247
- } else {
248
- this.active = this.defaultActive[this.defaultActive.length - 1];
249
- }
250
- val.forEach((item) => {
251
- if (item.id === this.active) {
252
- this.subMenu = item.children || [];
253
- this.headline = this.title ? this.title : item.text;
254
- return;
255
- }
256
- });
257
- }
258
- } else {
259
- this.subMenu = [];
260
- }
261
- },
262
- showMenu(val) {
263
- if (val) {
264
- this.getHeight();
265
- }
266
- }
267
- },
268
- data() {
269
- return {
270
- menuWidth: this.width,
271
- height: '',
272
- menuHeight: '',
273
- active: '',
274
- isCollapse: this.biserial ? false : this.collapse,
275
- isShow: this.biserial ? false : true,
276
- headline: this.title,
277
- subMenu: []
278
- };
279
- },
280
- beforeCreate() {
281
- this.getHeight = throttle(500, () => {
282
- this.resetHeight();
283
- });
284
- },
285
- mounted() {
286
- this.getHeight();
287
- },
288
- methods: {
289
- //设置按钮拖动
290
- handleClick() {
291
- this.subMenu = [];
292
- },
293
- handleChange() {
294
- if (this.biserial) {
295
- this.isShow = !this.isShow;
296
- } else {
297
- this.isCollapse = !this.isCollapse;
298
- if (this.isCollapse) {
299
- this.isShow = false;
300
- this.menuWidth = this.navWidth;
301
- } else {
302
- this.isShow = true;
303
- this.menuWidth = this.width;
304
- }
305
- }
306
- },
307
- handleTrigger(res) {
308
- let { node } = res;
309
- if (node.children && node.children.length) {
310
- this.subMenu = node.children;
311
- this.headline = node.text;
312
- this.isShow = true;
313
- }
314
- this.$emit('trigger', res);
315
- },
316
- handleSelect(res) {
317
- this.$emit('select', res);
318
- },
319
- handleOpen(res) {
320
- this.$emit('open', res);
321
- },
322
- handleClose(res) {
323
- this.$emit('close', res);
324
- },
325
- resetHeight() {
326
- this.$nextTick(() => {
327
- let height = this.$refs.esNav.parentNode.offsetHeight;
328
- Array.from(this.$refs.esNav.parentNode.children).forEach((item) => {
329
- if (item !== this.$refs.esNav) {
330
- let mt = util.getStyle(item, 'margin-top');
331
- let mb = util.getStyle(item, 'margin-bottom');
332
- mt = mt ? parseInt(mt, 10) : 0;
333
- mb = mb ? parseInt(mb, 10) : 0;
334
- height -= item.offsetHeight + mt + mb;
335
- }
336
- });
337
- if (this.overlap) {
338
- height -= 15;
339
- }
340
- this.height = height + 'px';
341
- if (this.showTitle) {
342
- let theight = this.$refs.navTitle.offsetHeight;
343
- this.menuHeight = height - theight + 'px';
344
- } else {
345
- this.menuHeight = height + 'px';
346
- }
347
- });
348
- }
349
- }
350
- };
351
- </script>
1
+ <template>
2
+ <div
3
+ ref="esNav"
4
+ class="es-nav"
5
+ :class="biserial ? 'es-nav-biserial' : ''"
6
+ :style="{ width: boxWidth, height: height }"
7
+ >
8
+ <div
9
+ class="es-nav-initial"
10
+ v-if="biserial"
11
+ :style="{
12
+ width: _navWidth,
13
+ left:
14
+ this.overlap && !this.subMenu.length
15
+ ? '15px'
16
+ : show
17
+ ? '-' + boxWidth
18
+ : ''
19
+ }"
20
+ >
21
+ <es-menu
22
+ :class="{ 'es-nav-overlap': overlap }"
23
+ v-bind="$attrs"
24
+ sub-nav
25
+ :data="menu"
26
+ :is-default="isDefault"
27
+ :deep="false"
28
+ :default-active="subActive"
29
+ :biserial="biserial"
30
+ :menu-icons="menuIcon"
31
+ :icons="icons"
32
+ :sub-icon="subIcon"
33
+ @select="handleTrigger"
34
+ ></es-menu>
35
+ </div>
36
+ <div
37
+ class="es-nav-main"
38
+ :class="{ 'es-nav-overlap': overlap }"
39
+ :biserial="biserial"
40
+ :style="{
41
+ width: biserial ? width : boxWidth,
42
+ left: biserial ? (show ? '15px' : navWidth) : ''
43
+ }"
44
+ v-show="showMenu"
45
+ >
46
+ <div class="es-nav-title" v-if="showTitle" ref="navTitle">
47
+ <span v-show="!isCollapse">{{ headline }}</span>
48
+ <template v-if="showCollapse">
49
+ <i
50
+ v-show="!isCollapse"
51
+ class="es-icon-indent es-collapse-handle"
52
+ @click="handleChange"
53
+ ></i>
54
+ <i
55
+ v-show="isCollapse"
56
+ class="es-icon-increase es-collapse-handle"
57
+ @click="handleChange"
58
+ ></i>
59
+ </template>
60
+ </div>
61
+ <es-menu
62
+ v-bind="$attrs"
63
+ :class="biserial ? 'es-nav-biserial' : ''"
64
+ :data="biserial ? subMenu : menu"
65
+ :collapse="isCollapse"
66
+ :default-active="menuActive"
67
+ :width="isTop ? boxWidth : menuWidth"
68
+ :height="menuHeight"
69
+ :style="{ height: menuHeight }"
70
+ :is-default="isDefault"
71
+ :biserial="biserial"
72
+ :paddingLeft="paddingLeft"
73
+ :menu-icon="menuIcon"
74
+ :icons="icons"
75
+ :sub-icon="subIcon"
76
+ @select="handleSelect"
77
+ @open="handleOpen"
78
+ @close="handleClose"
79
+ ></es-menu>
80
+ </div>
81
+ <es-enable-drag
82
+ v-show="show"
83
+ :distance="0"
84
+ topDistance="100px"
85
+ leftDistance="0px"
86
+ @click="handleClick"
87
+ ></es-enable-drag>
88
+ </div>
89
+ </template>
90
+ <script>
91
+ import util from 'eoss-ui/src/utils/util';
92
+ import { throttle } from 'throttle-debounce';
93
+ export default {
94
+ name: 'EsNav',
95
+ inheritAttrs: false,
96
+ props: {
97
+ isTop: Boolean,
98
+ data: {
99
+ type: Array,
100
+ default: []
101
+ },
102
+ title: {
103
+ type: [String, Boolean],
104
+ default: ''
105
+ },
106
+ width: {
107
+ type: String,
108
+ default: '200px'
109
+ },
110
+ navWidth: {
111
+ type: String,
112
+ default: '70px'
113
+ },
114
+ showCollapse: {
115
+ type: Boolean,
116
+ default: true
117
+ },
118
+ collapse: {
119
+ type: Boolean,
120
+ default: false
121
+ },
122
+ //是否双列导航
123
+ biserial: Boolean,
124
+ defaultActive: [String, Array],
125
+ isDefault: Boolean,
126
+ paddingLeft: Number,
127
+ menuIcon: String,
128
+ icons: Object,
129
+ subIcon: {
130
+ type: Boolean,
131
+ default: true
132
+ },
133
+ overlap: Boolean,
134
+ //隐藏菜单
135
+ hideSubMenu: Boolean
136
+ },
137
+ computed: {
138
+ show() {
139
+ return this.overlap && this.subMenu.length;
140
+ },
141
+ showMenu() {
142
+ return this.biserial ? this.subMenu.length : this.menu.length;
143
+ },
144
+ menu() {
145
+ return this.data;
146
+ },
147
+ showTitle() {
148
+ if (this.title === false && this.showCollapse === false) {
149
+ return false;
150
+ }
151
+ return true;
152
+ },
153
+ subActive() {
154
+ let active =
155
+ this.biserial &&
156
+ Array.isArray(this.defaultActive) &&
157
+ this.defaultActive.length
158
+ ? this.defaultActive[0]
159
+ : undefined;
160
+ return active;
161
+ },
162
+ menuActive() {
163
+ let active =
164
+ typeof this.defaultActive === 'string'
165
+ ? this.defaultActive
166
+ : this.defaultActive && this.defaultActive.length
167
+ ? this.defaultActive[this.defaultActive.length - 1]
168
+ : undefined;
169
+ return active;
170
+ },
171
+ boxWidth() {
172
+ if (!this.biserial) {
173
+ if (this.overlap) {
174
+ return this.navWidth;
175
+ }
176
+ if (this.isShow) {
177
+ return this.width;
178
+ } else {
179
+ return this.navWidth;
180
+ }
181
+ }
182
+ return this.subMenu &&
183
+ this.subMenu.length &&
184
+ this.isShow &&
185
+ !this.overlap &&
186
+ !this.hideSubMenu
187
+ ? parseInt(this.width, 10) + parseInt(this.navWidth, 10) + 'px'
188
+ : this.navWidth;
189
+ },
190
+ _navWidth() {
191
+ return this.overlap
192
+ ? parseInt(this.navWidth, 10) - 30 + 'px'
193
+ : this.navWidth;
194
+ }
195
+ },
196
+ watch: {
197
+ collapse(val) {
198
+ this.isCollapse = this.biserial ? false : val;
199
+ },
200
+ title(val) {
201
+ if (typeof val === 'string' && val) {
202
+ this.headline = val;
203
+ }
204
+ },
205
+ boxWidth() {
206
+ this.getHeight();
207
+ },
208
+ biserial: {
209
+ handler(val) {
210
+ this.isShow = !val;
211
+ this.getHeight();
212
+ }
213
+ },
214
+ defaultActive: {
215
+ immediate: true,
216
+ deep: true,
217
+ handler(val) {
218
+ if (val && val.length) {
219
+ if (typeof val !== 'string' && val.length) {
220
+ this.isShow = true;
221
+ if (this.biserial) {
222
+ this.active = val[0];
223
+ } else {
224
+ this.active = val[val.length - 1];
225
+ }
226
+ this.menu.forEach((item) => {
227
+ if (item.id === this.active) {
228
+ this.subMenu = item.children || [];
229
+ this.headline = this.title ? this.title : item.text;
230
+ return;
231
+ }
232
+ });
233
+ }
234
+ }
235
+ }
236
+ },
237
+ menu(val) {
238
+ if (val && val.length) {
239
+ if (
240
+ this.defaultActive &&
241
+ typeof this.defaultActive !== 'string' &&
242
+ this.defaultActive.length
243
+ ) {
244
+ this.isShow = true;
245
+ if (this.biserial) {
246
+ this.active = this.defaultActive[0];
247
+ } else {
248
+ this.active = this.defaultActive[this.defaultActive.length - 1];
249
+ }
250
+ val.forEach((item) => {
251
+ if (item.id === this.active) {
252
+ this.subMenu = item.children || [];
253
+ this.headline = this.title ? this.title : item.text;
254
+ return;
255
+ }
256
+ });
257
+ }
258
+ } else {
259
+ this.subMenu = [];
260
+ }
261
+ },
262
+ showMenu(val) {
263
+ if (val) {
264
+ this.getHeight();
265
+ }
266
+ }
267
+ },
268
+ data() {
269
+ return {
270
+ menuWidth: this.width,
271
+ height: '',
272
+ menuHeight: '',
273
+ active: '',
274
+ isCollapse: this.biserial ? false : this.collapse,
275
+ isShow: this.biserial ? false : true,
276
+ headline: this.title,
277
+ subMenu: []
278
+ };
279
+ },
280
+ beforeCreate() {
281
+ this.getHeight = throttle(500, () => {
282
+ this.resetHeight();
283
+ });
284
+ },
285
+ mounted() {
286
+ this.getHeight();
287
+ },
288
+ methods: {
289
+ //设置按钮拖动
290
+ handleClick() {
291
+ this.subMenu = [];
292
+ },
293
+ handleChange() {
294
+ if (this.biserial) {
295
+ this.isShow = !this.isShow;
296
+ } else {
297
+ this.isCollapse = !this.isCollapse;
298
+ if (this.isCollapse) {
299
+ this.isShow = false;
300
+ this.menuWidth = this.navWidth;
301
+ } else {
302
+ this.isShow = true;
303
+ this.menuWidth = this.width;
304
+ }
305
+ }
306
+ },
307
+ handleTrigger(res) {
308
+ let { node } = res;
309
+ if (node.children && node.children.length) {
310
+ this.subMenu = node.children;
311
+ this.headline = node.text;
312
+ this.isShow = true;
313
+ }
314
+ this.$emit('trigger', res);
315
+ },
316
+ handleSelect(res) {
317
+ this.$emit('select', res);
318
+ },
319
+ handleOpen(res) {
320
+ this.$emit('open', res);
321
+ },
322
+ handleClose(res) {
323
+ this.$emit('close', res);
324
+ },
325
+ resetHeight() {
326
+ this.$nextTick(() => {
327
+ let height = this.$refs.esNav.parentNode.offsetHeight;
328
+ Array.from(this.$refs.esNav.parentNode.children).forEach((item) => {
329
+ if (item !== this.$refs.esNav) {
330
+ let mt = util.getStyle(item, 'margin-top');
331
+ let mb = util.getStyle(item, 'margin-bottom');
332
+ mt = mt ? parseInt(mt, 10) : 0;
333
+ mb = mb ? parseInt(mb, 10) : 0;
334
+ height -= item.offsetHeight + mt + mb;
335
+ }
336
+ });
337
+ if (this.overlap) {
338
+ height -= 15;
339
+ }
340
+ this.height = height + 'px';
341
+ if (this.showTitle) {
342
+ let theight = this.$refs.navTitle.offsetHeight;
343
+ this.menuHeight = height - theight + 'px';
344
+ } else {
345
+ this.menuHeight = height + 'px';
346
+ }
347
+ });
348
+ }
349
+ }
350
+ };
351
+ </script>