eoss-ui 0.6.88 → 0.6.90

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 (249) hide show
  1. package/lib/calogin.js +233 -233
  2. package/lib/eoss-ui.common.js +933 -859
  3. package/lib/flow-list.js +81 -81
  4. package/lib/flow.js +364 -305
  5. package/lib/index.js +1 -1
  6. package/lib/main.js +132 -132
  7. package/lib/qr-code.js +13 -13
  8. package/lib/selector.js +99 -84
  9. package/lib/theme-chalk/index.css +1 -1
  10. package/lib/theme-chalk/selector.css +1 -1
  11. package/package.json +160 -160
  12. package/packages/button/index.js +5 -5
  13. package/packages/button/src/main.vue +418 -418
  14. package/packages/button-group/index.js +5 -5
  15. package/packages/button-group/src/main.vue +298 -298
  16. package/packages/calendar/index.js +5 -5
  17. package/packages/calogin/index.js +5 -5
  18. package/packages/calogin/src/main.vue +412 -412
  19. package/packages/calogin/src/plugin.js +915 -915
  20. package/packages/card/index.js +5 -5
  21. package/packages/card/src/main.vue +156 -156
  22. package/packages/cascader/index.js +5 -5
  23. package/packages/cascader/src/main.vue +168 -168
  24. package/packages/checkbox-group/index.js +5 -5
  25. package/packages/checkbox-group/src/main.vue +333 -333
  26. package/packages/clients/index.js +5 -5
  27. package/packages/clients/src/main.vue +151 -151
  28. package/packages/data-table/index.js +5 -5
  29. package/packages/data-table/src/children.vue +39 -39
  30. package/packages/data-table/src/column.vue +990 -990
  31. package/packages/data-table/src/main.vue +1822 -1822
  32. package/packages/data-table/src/sizer.vue +195 -195
  33. package/packages/data-table-form/index.js +5 -5
  34. package/packages/data-table-form/src/checkbox.vue +101 -101
  35. package/packages/data-table-form/src/colgroup.vue +17 -17
  36. package/packages/data-table-form/src/main.vue +181 -181
  37. package/packages/data-table-form/src/radio.vue +65 -65
  38. package/packages/data-table-form/src/table.vue +233 -233
  39. package/packages/data-table-form/src/tbody.vue +336 -336
  40. package/packages/data-table-form/src/thead.vue +68 -68
  41. package/packages/date-picker/index.js +5 -5
  42. package/packages/date-picker/src/main.vue +236 -236
  43. package/packages/dialog/index.js +5 -5
  44. package/packages/enable-drag/index.js +5 -5
  45. package/packages/enterprise/index.js +5 -5
  46. package/packages/enterprise/src/main.vue +66 -66
  47. package/packages/error-page/index.js +5 -5
  48. package/packages/error-page/src/main.vue +44 -44
  49. package/packages/flow/index.js +5 -5
  50. package/packages/flow/src/component/Circulate.vue +400 -400
  51. package/packages/flow/src/component/CommonOpinions.vue +364 -364
  52. package/packages/flow/src/component/CustomPreset.vue +322 -322
  53. package/packages/flow/src/component/FileList.vue +99 -99
  54. package/packages/flow/src/component/Preset.vue +255 -255
  55. package/packages/flow/src/component/SendMsg.vue +241 -241
  56. package/packages/flow/src/component/TimeLimit.vue +190 -190
  57. package/packages/flow/src/component/taskUnionExamine.vue +640 -640
  58. package/packages/flow/src/form.vue +121 -121
  59. package/packages/flow/src/freeStartFlow.vue +2844 -2844
  60. package/packages/flow/src/main.vue +3659 -3657
  61. package/packages/flow/src/processForm.vue +1245 -1245
  62. package/packages/flow/src/processReject.vue +296 -296
  63. package/packages/flow/src/reset.vue +941 -918
  64. package/packages/flow/src/selectUser.vue +1 -1
  65. package/packages/flow/src/startTaskRead.vue +684 -684
  66. package/packages/flow/src/supervise.vue +152 -152
  67. package/packages/flow/src/table.vue +58 -58
  68. package/packages/flow-group/index.js +5 -5
  69. package/packages/flow-group/src/main.vue +692 -692
  70. package/packages/flow-list/index.js +5 -5
  71. package/packages/flow-list/src/main.vue +1770 -1770
  72. package/packages/form/index.js +5 -5
  73. package/packages/form/src/main.vue +3814 -3814
  74. package/packages/form/src/table.vue +1508 -1508
  75. package/packages/handle-user/index.js +5 -5
  76. package/packages/handle-user/src/main.vue +138 -138
  77. package/packages/handler/index.js +5 -5
  78. package/packages/handler/src/main.vue +493 -493
  79. package/packages/icon/index.js +5 -5
  80. package/packages/icon/src/main.vue +101 -101
  81. package/packages/icons/index.js +5 -5
  82. package/packages/icons/src/main.vue +81 -81
  83. package/packages/input/index.js +5 -5
  84. package/packages/input/src/main.vue +356 -356
  85. package/packages/input-number/index.js +5 -5
  86. package/packages/input-number/src/main.vue +106 -106
  87. package/packages/label/index.js +5 -5
  88. package/packages/label/src/main.vue +457 -457
  89. package/packages/layout/index.js +5 -5
  90. package/packages/layout/src/item.vue +152 -152
  91. package/packages/layout/src/main.vue +31 -31
  92. package/packages/login/index.js +5 -5
  93. package/packages/login/src/main.vue +1998 -1998
  94. package/packages/login/src/resetPassword.vue +562 -562
  95. package/packages/main/index.js +5 -5
  96. package/packages/main/src/default/message.vue +249 -249
  97. package/packages/main/src/default/notice.vue +157 -157
  98. package/packages/main/src/default/userinfo.vue +503 -503
  99. package/packages/main/src/public/online.vue +89 -89
  100. package/packages/main/src/public/search.vue +458 -458
  101. package/packages/main/src/public/settings.vue +221 -221
  102. package/packages/main/src/simplicity/apps.vue +388 -388
  103. package/packages/main/src/simplicity/avatar.vue +82 -82
  104. package/packages/main/src/simplicity/handler.vue +259 -259
  105. package/packages/main/src/simplicity/index.vue +2102 -2102
  106. package/packages/main/src/simplicity/lists.vue +84 -84
  107. package/packages/main/src/simplicity/menu-list.vue +135 -135
  108. package/packages/main/src/simplicity/message.vue +259 -259
  109. package/packages/main/src/simplicity/notice.vue +190 -190
  110. package/packages/main/src/simplicity/router-page.vue +45 -45
  111. package/packages/main/src/simplicity/sub-menu.vue +264 -264
  112. package/packages/main/src/simplicity/user.vue +260 -260
  113. package/packages/main/src/simplicity/userinfo.vue +308 -308
  114. package/packages/menu/index.js +5 -5
  115. package/packages/menu/src/main.vue +584 -584
  116. package/packages/nav/index.js +5 -5
  117. package/packages/nav/src/main.vue +351 -351
  118. package/packages/notify/index.js +5 -5
  119. package/packages/notify/src/main.vue +538 -538
  120. package/packages/page/index.js +5 -5
  121. package/packages/page/src/main.vue +167 -167
  122. package/packages/pagination/index.js +5 -5
  123. package/packages/pagination/src/main.vue +96 -96
  124. package/packages/player/index.js +5 -5
  125. package/packages/player/src/main.vue +194 -194
  126. package/packages/qr-code/index.js +5 -5
  127. package/packages/qr-code/src/main.vue +170 -170
  128. package/packages/radio-group/index.js +6 -6
  129. package/packages/radio-group/src/main.vue +319 -319
  130. package/packages/retrial-auth/index.js +5 -5
  131. package/packages/retrial-auth/src/main.vue +280 -280
  132. package/packages/select/index.js +5 -5
  133. package/packages/select/src/main.vue +778 -778
  134. package/packages/select-ganged/index.js +5 -5
  135. package/packages/select-ganged/src/main.vue +724 -724
  136. package/packages/selector/index.js +5 -5
  137. package/packages/selector/src/main.vue +747 -745
  138. package/packages/selector-panel/index.js +5 -5
  139. package/packages/selector-panel/src/main.vue +1027 -1027
  140. package/packages/selector-panel/src/selection.vue +170 -170
  141. package/packages/selector-panel/src/tree.vue +129 -129
  142. package/packages/sizer/index.js +5 -5
  143. package/packages/sizer/src/main.vue +254 -254
  144. package/packages/steps/index.js +5 -5
  145. package/packages/steps/src/main.vue +181 -181
  146. package/packages/switch/index.js +5 -5
  147. package/packages/switch/src/main.vue +154 -154
  148. package/packages/table-form/index.js +5 -5
  149. package/packages/tabs/index.js +5 -5
  150. package/packages/tabs/src/main.vue +788 -788
  151. package/packages/tabs-panel/index.js +5 -5
  152. package/packages/tabs-panel/src/main.vue +29 -29
  153. package/packages/theme-chalk/lib/index.css +1 -1
  154. package/packages/theme-chalk/lib/selector.css +1 -1
  155. package/packages/theme-chalk/src/base.scss +261 -261
  156. package/packages/theme-chalk/src/button-group.scss +176 -176
  157. package/packages/theme-chalk/src/button.scss +24 -24
  158. package/packages/theme-chalk/src/calendar.scss +113 -113
  159. package/packages/theme-chalk/src/card.scss +99 -99
  160. package/packages/theme-chalk/src/checkbox-group.scss +8 -8
  161. package/packages/theme-chalk/src/clients.scss +87 -87
  162. package/packages/theme-chalk/src/data-table-form.scss +67 -67
  163. package/packages/theme-chalk/src/data-table.scss +293 -293
  164. package/packages/theme-chalk/src/date-picker.scss +7 -7
  165. package/packages/theme-chalk/src/dialog.scss +77 -77
  166. package/packages/theme-chalk/src/enable-drag.scss +181 -181
  167. package/packages/theme-chalk/src/enterprise.scss +5 -5
  168. package/packages/theme-chalk/src/error-page.scss +18 -18
  169. package/packages/theme-chalk/src/flow-group.scss +110 -110
  170. package/packages/theme-chalk/src/flow-list.scss +39 -39
  171. package/packages/theme-chalk/src/flow.scss +348 -348
  172. package/packages/theme-chalk/src/form.scss +499 -499
  173. package/packages/theme-chalk/src/handle-user.scss +40 -40
  174. package/packages/theme-chalk/src/handler.scss +143 -143
  175. package/packages/theme-chalk/src/icon.scss +1817 -1817
  176. package/packages/theme-chalk/src/icons.scss +99 -99
  177. package/packages/theme-chalk/src/input.scss +9 -9
  178. package/packages/theme-chalk/src/label.scss +24 -24
  179. package/packages/theme-chalk/src/layout.scss +46 -46
  180. package/packages/theme-chalk/src/login.scss +984 -984
  181. package/packages/theme-chalk/src/main.scss +663 -663
  182. package/packages/theme-chalk/src/menu.scss +222 -222
  183. package/packages/theme-chalk/src/mixins/color.scss +117 -117
  184. package/packages/theme-chalk/src/nav.scss +111 -111
  185. package/packages/theme-chalk/src/page.scss +3 -3
  186. package/packages/theme-chalk/src/pagination.scss +29 -29
  187. package/packages/theme-chalk/src/player.scss +9 -9
  188. package/packages/theme-chalk/src/qr-code.scss +17 -17
  189. package/packages/theme-chalk/src/radio-group.scss +9 -9
  190. package/packages/theme-chalk/src/retrial-auth.scss +38 -38
  191. package/packages/theme-chalk/src/select-ganged.scss +8 -8
  192. package/packages/theme-chalk/src/select.scss +8 -8
  193. package/packages/theme-chalk/src/selector-panel.scss +204 -204
  194. package/packages/theme-chalk/src/selector.scss +92 -91
  195. package/packages/theme-chalk/src/simplicity.scss +1355 -1355
  196. package/packages/theme-chalk/src/sizer.scss +36 -36
  197. package/packages/theme-chalk/src/steps.scss +88 -88
  198. package/packages/theme-chalk/src/switch.scss +3 -3
  199. package/packages/theme-chalk/src/table-form.scss +1 -1
  200. package/packages/theme-chalk/src/tabs.scss +87 -87
  201. package/packages/theme-chalk/src/tips.scss +7 -7
  202. package/packages/theme-chalk/src/toolbar.scss +179 -179
  203. package/packages/theme-chalk/src/tree-group.scss +72 -72
  204. package/packages/theme-chalk/src/tree.scss +165 -165
  205. package/packages/theme-chalk/src/upload.scss +172 -172
  206. package/packages/theme-chalk/src/wxlogin.scss +3 -3
  207. package/packages/tips/index.js +5 -5
  208. package/packages/tips/src/main.vue +141 -141
  209. package/packages/toolbar/index.js +5 -5
  210. package/packages/toolbar/src/main.vue +430 -430
  211. package/packages/tree/index.js +5 -5
  212. package/packages/tree-group/index.js +5 -5
  213. package/packages/upload/index.js +5 -5
  214. package/packages/upload/src/main.vue +1348 -1348
  215. package/packages/upload/src/picture.js +15 -15
  216. package/packages/wujie/index.js +5 -5
  217. package/packages/wujie/src/main.vue +145 -145
  218. package/packages/wxlogin/index.js +5 -5
  219. package/packages/wxlogin/src/main.vue +128 -128
  220. package/src/config/api.js +294 -294
  221. package/src/config/image.js +2 -2
  222. package/src/index.js +163 -163
  223. package/src/utils/bus.js +3 -3
  224. package/src/utils/date-util.js +312 -312
  225. package/src/utils/http.js +50 -50
  226. package/src/utils/rules.js +18 -18
  227. package/src/utils/store.js +21 -21
  228. package/src/utils/webSocket.js +107 -107
  229. package/packages/.DS_Store +0 -0
  230. package/packages/autocomplete/.DS_Store +0 -0
  231. package/packages/calogin/.DS_Store +0 -0
  232. package/packages/date-picker/.DS_Store +0 -0
  233. package/packages/date-picker/src/.DS_Store +0 -0
  234. package/packages/flow/.DS_Store +0 -0
  235. package/packages/flow/src/.DS_Store +0 -0
  236. package/packages/flow-list/.DS_Store +0 -0
  237. package/packages/form/.DS_Store +0 -0
  238. package/packages/login/.DS_Store +0 -0
  239. package/packages/main/.DS_Store +0 -0
  240. package/packages/main/src/.DS_Store +0 -0
  241. package/packages/menu/.DS_Store +0 -0
  242. package/packages/scrollbar/.DS_Store +0 -0
  243. package/packages/select/.DS_Store +0 -0
  244. package/packages/selector/.DS_Store +0 -0
  245. package/packages/selector-panel/.DS_Store +0 -0
  246. package/packages/theme-chalk/src/.DS_Store +0 -0
  247. package/packages/upload/.DS_Store +0 -0
  248. package/src/.DS_Store +0 -0
  249. package/src/utils/.DS_Store +0 -0
@@ -1,458 +1,458 @@
1
- <template>
2
- <div class="es-public-search-box">
3
- <el-input
4
- class="es-public-search-input"
5
- placeholder="请输入关键字"
6
- clearable
7
- prefix-icon="el-icon-search"
8
- v-model="keyWords"
9
- round
10
- ></el-input>
11
- <el-tabs class="es-public-search-tabs" v-model="active">
12
- <el-tab-pane label="综合" name="0">
13
- <el-scrollbar class="es-scrollbar">
14
- <template v-for="(item, index) in types">
15
- <div
16
- v-if="item.records && item.records.length"
17
- class="es-public-search-content"
18
- :key="item.id"
19
- >
20
- <div class="es-public-search-title">{{ item.name }}</div>
21
- <ul class="es-public-search-list">
22
- <li
23
- v-for="(ele, idx) in item.records.slice(0, 3)"
24
- class="es-public-search-list-item"
25
- :key="ele.id || `${item.id}_${ele.title}_${idx}`"
26
- @click="handleClick(ele, item)"
27
- >
28
- <es-icon
29
- class="es-public-search-item-icon"
30
- v-bind="getIcon(ele, item)"
31
- :style="setStyle(ele, index)"
32
- ></es-icon>
33
- <div class="es-public-search-item-name">
34
- {{ ele.name || ele.title || ele.text }}
35
- </div>
36
- <div class="es-public-search-item-texts" v-if="ele.summary">
37
- {{ ele.summary }}
38
- </div>
39
- <div class="es-public-search-item-texts">
40
- <template v-if="Array.isArray(ele.infos || ele.footer)">
41
- <span
42
- v-for="(text, idx) in ele.infos || ele.footer"
43
- class="es-public-search-item-text"
44
- :key="idx"
45
- >{{ text }}</span
46
- >
47
- </template>
48
- <template v-else>{{ ele.infos || ele.footer }}</template>
49
- </div>
50
- </li>
51
- </ul>
52
- <div class="es-public-search-more">
53
- <span
54
- class="es-public-search-more-text"
55
- @click="handleTabs(item, index)"
56
- >在<span class="es-public-search-more-quote">{{
57
- item.name
58
- }}</span
59
- >中搜索全部</span
60
- >
61
- </div>
62
- </div>
63
- </template>
64
- </el-scrollbar>
65
- </el-tab-pane>
66
- <template v-for="(item, index) in types">
67
- <el-tab-pane
68
- :label="item.name"
69
- :name="item.id || String(index + 1)"
70
- :key="item.id"
71
- lazy
72
- v-loading="loadings[item.id || String(index)]"
73
- element-loading-background="rgba(0, 0, 0, 0.01)"
74
- element-loading-text="加载中..."
75
- v-if="!hides.includes(item.name) && !item.hide"
76
- >
77
- <el-scrollbar
78
- class="es-scrollbar es-public-search-scrollbar"
79
- :infinite-scroll="
80
- () => {
81
- handleSearchd(item, index);
82
- }
83
- "
84
- :infinite-scroll-disabled="disabled"
85
- :infinite-scroll-immediate="false"
86
- >
87
- <div class="es-public-search-info" v-show="keyWords">
88
- {{ item.totalCount }}条与"<span
89
- class="es-public-search-more-quote"
90
- >{{ keyWords }}</span
91
- >"相关的搜索结果
92
- </div>
93
- <ul class="es-public-search-lists">
94
- <li
95
- v-for="(ele, idx) in item.records"
96
- class="es-public-search-list-item"
97
- :key="ele.id || `${item.id}_${ele.title}_${idx}`"
98
- @click="handleClick(ele, item)"
99
- >
100
- <es-icon
101
- class="es-public-search-item-icon"
102
- v-bind="getIcon(ele, item)"
103
- :style="setStyle(ele, index)"
104
- ></es-icon>
105
- <div class="es-public-search-item-name">
106
- {{ ele.name || ele.title || ele.text }}
107
- </div>
108
- <div class="es-public-search-item-texts" v-if="ele.summary">
109
- {{ ele.summary }}
110
- </div>
111
- <div class="es-public-search-item-texts">
112
- <template v-if="Array.isArray(ele.infos || ele.footer)">
113
- <span
114
- v-for="(text, idx) in ele.infos || ele.footer"
115
- class="es-public-search-item-text"
116
- :key="idx"
117
- >{{ text }}</span
118
- >
119
- </template>
120
- <template v-else>{{ ele.infos || ele.footer }}</template>
121
- </div>
122
- </li>
123
- </ul>
124
- <p
125
- class="es-public-search-no-more"
126
- v-if="noMore[item.id || String(index)]"
127
- >
128
- 没有更多了
129
- </p>
130
- </el-scrollbar>
131
- </el-tab-pane>
132
- </template>
133
- </el-tabs>
134
- <es-dialog :title="title" :visible.sync="visible" size="max">
135
- <iframe width="100%" height="100%" frameborder="0" :src="url"></iframe>
136
- </es-dialog>
137
- </div>
138
- </template>
139
-
140
- <script>
141
- import util from 'eoss-ui/src/utils/util';
142
- import { searchType } from 'eoss-ui/src/config/api.js';
143
- import { debounce } from 'throttle-debounce';
144
- export default {
145
- name: 'Search',
146
- components: {},
147
- props: {
148
- menuIcon: {
149
- type: String,
150
- default: 'es-icon-application'
151
- },
152
- menus: {
153
- type: Array,
154
- default() {
155
- return [];
156
- }
157
- },
158
- apps: {
159
- type: Array,
160
- default() {
161
- return [];
162
- }
163
- },
164
- searchType: {
165
- type: String,
166
- default: searchType
167
- },
168
- pageSize: {
169
- type: Number,
170
- default: 10
171
- },
172
- hides: {
173
- type: Array,
174
- default() {
175
- return [];
176
- }
177
- }
178
- },
179
- data() {
180
- return {
181
- icons: {
182
- ppt: 'es-icon-ppt',
183
- png: 'es-icon-picture',
184
- gif: 'es-icon-picture',
185
- jpg: 'es-icon-picture',
186
- xls: 'es-icon-excel',
187
- xlsx: 'es-icon-excel',
188
- docx: 'es-icon-word',
189
- doc: 'es-icon-word',
190
- rar: 'es-icon-zip',
191
- zip: 'es-icon-zip',
192
- txt: 'es-icon-txt',
193
- ipa: 'es-icon-ios',
194
- apk: 'es-icon-android',
195
- mp4: 'es-icon-video',
196
- avi: 'es-icon-video',
197
- mp3: 'es-icon-audioo',
198
- wma: 'es-icon-audioo',
199
- pdf: 'es-icon-pdf'
200
- },
201
- colors: [
202
- '#46D3BA',
203
- '#2591F7',
204
- '#40C274',
205
- '#E34D59',
206
- '#FF9C52',
207
- '#17C27B'
208
- ],
209
- keyWords: '',
210
- active: '0',
211
- types: [],
212
- lists: [],
213
- loadings: {},
214
- noMore: {},
215
- isLoading: false,
216
- title: '',
217
- visible: false,
218
- url: ''
219
- };
220
- },
221
- computed: {
222
- loading() {
223
- return this.active == '0' && this.isLoading;
224
- },
225
- disabled() {
226
- return this.loadings[this.active] || this.noMore[this.active];
227
- }
228
- },
229
- watch: {
230
- keyWords(val) {
231
- this.handleSearchAll(val);
232
- }
233
- },
234
- beforeCreate() {
235
- this.handleSearchAll = debounce(500, (res) => {
236
- this.searchAll(res);
237
- });
238
- this.handleSearchd = debounce(500, (obj, index) => {
239
- this.handleSearch(obj, index, false);
240
- });
241
- },
242
- created() {
243
- this.getTypes();
244
- },
245
- mounted() {},
246
- methods: {
247
- getIcon(res, item) {
248
- let icon;
249
- let cls;
250
- if (res.icon || res.icons) {
251
- icon = this.icons[(res.icon || res.icons).toLowerCase()];
252
- if (!icon) {
253
- if (res.icon == '#last' || res.icons == '#last') {
254
- let title = res.title || res.name || res.text;
255
- icon = title.substr(-1, 1);
256
- cls = 'es-public-search-item-icon-text';
257
- } else {
258
- cls = 'es-public-search-item-icons';
259
- icon = res.icon || res.icons;
260
- }
261
- }
262
- } else {
263
- let title = res.title || res.name || res.text;
264
- let key = title.split('.')[1];
265
- icon = key ? this.icons[key.toLowerCase()] : '';
266
- if (!icon) {
267
- icon =
268
- item.name == '菜单' || item.name == '应用'
269
- ? this.menuIcon
270
- : title.substr(-1, 1);
271
- cls = 'es-public-search-item-icon-text';
272
- }
273
- }
274
- return { class: cls, contents: icon };
275
- },
276
- setStyle(res, index) {
277
- if (res.icon || res.icons) {
278
- let icon = this.icons[(res.icon || res.icons).toLowerCase()];
279
- if (!icon && res.icon != '#last') {
280
- return { backgroundColor: this.colors[index % this.colors.length] };
281
- }
282
- } else {
283
- return { backgroundColor: this.colors[index % this.colors.length] };
284
- }
285
- return {};
286
- },
287
- getTypes() {
288
- util
289
- .ajax({
290
- url: this.searchType,
291
- method: 'post',
292
- format: false,
293
- data: {
294
- terminalType: 'web'
295
- }
296
- })
297
- .then((res) => {
298
- if (res.rCode == 0) {
299
- let { results } = res;
300
- let loadings = {};
301
- let noMore = {};
302
- let types = results.catalog.map((item, index) => {
303
- loadings[item.id || String(index)] = false;
304
- noMore[item.id || String(index)] = false;
305
- return {
306
- ...item,
307
- pageNum: 0,
308
- pageCount: 1,
309
- records: [],
310
- hide:
311
- item.name == '应用' && this.apps.length == 0 ? true : false
312
- };
313
- });
314
- this.types = types;
315
- this.loadings = loadings;
316
- this.noMore = noMore;
317
- }
318
- });
319
- },
320
- searchAll(keyWords) {
321
- for (let i = 0; i < this.types.length; i++) {
322
- let item = this.types[i];
323
- if (keyWords && !this.hides.includes(item.name) && !item.hide) {
324
- if (item.name == '菜单' && this.menus.length) {
325
- this.isLoading = false;
326
- this.types[i].records = this.searchData(this.menus, keyWords);
327
- this.types[i].totalCount = this.types[i].records.length;
328
- this.types[i].pageCount = 1;
329
- this.types[i].pageNum = 1;
330
- this.$set(this.loadings, item.id || String(i), false);
331
- this.$set(this.noMore, item.id || String(i), true);
332
- } else if (item.name == '应用' && this.apps.length) {
333
- this.isLoading = false;
334
- this.types[i].records = this.searchData(this.apps, keyWords);
335
- this.types[i].totalCount = this.types[i].records.length;
336
- this.types[i].pageCount = 1;
337
- this.types[i].pageNum = 1;
338
- this.$set(this.loadings, item.id || String(i), false);
339
- this.$set(this.noMore, item.id || String(i), true);
340
- } else if (item.dataRequestUrl) {
341
- this.isLoading = true;
342
- this.handleSearch(item, i, true);
343
- } else {
344
- this.types[i].records = [];
345
- this.types[i].totalCount = 0;
346
- this.types[i].pageCount = 1;
347
- this.types[i].pageNum = 0;
348
- this.$set(this.loadings, item.id || String(i), false);
349
- this.$set(this.noMore, item.id || String(i), true);
350
- }
351
- } else {
352
- this.isLoading = false;
353
- this.types[i].records = [];
354
- this.types[i].totalCount = 0;
355
- this.types[i].pageCount = 1;
356
- this.types[i].pageNum = 0;
357
- this.$set(this.loadings, item.id || String(i), false);
358
- this.$set(this.noMore, item.id || String(i), true);
359
- }
360
- }
361
- },
362
- searchData(data, name) {
363
- let records = [];
364
- data.forEach((item) => {
365
- let words = item.name || item.text;
366
- if (words.indexOf(name) > -1 && item.permission !== false) {
367
- records.push(item);
368
- }
369
- if (item.children && item.children.length) {
370
- records = records.concat(this.searchData(item.children, name));
371
- }
372
- if (item.fourthTabs && item.fourthTabs.length) {
373
- records = records.concat(this.searchData(item.fourthTabs, name));
374
- }
375
- });
376
- return records;
377
- },
378
- handleSearch(obj, index, reset) {
379
- if (obj.pageNum < obj.pageCount && this.keyWords) {
380
- this.$set(this.loadings, obj.id || String(index), true);
381
- if (this.active == '0') {
382
- this.isLoading = true;
383
- }
384
- util
385
- .ajax({
386
- url: obj.dataRequestUrl,
387
- method: 'post',
388
- format: false,
389
- data: {
390
- pageNum: obj.pageNum + 1,
391
- pageSize: this.pageSize,
392
- search: this.keyWords,
393
- terminalType: 'web'
394
- }
395
- })
396
- .then((res) => {
397
- this.$set(this.loadings, obj.id || String(index), false);
398
- let flag = false;
399
- for (let i in this.loadings) {
400
- if (this.loadings[i]) {
401
- flag = true;
402
- break;
403
- }
404
- }
405
- if (!flag) {
406
- this.isLoading = false;
407
- }
408
- if (res.rCode == 0) {
409
- let { results } = res;
410
- obj.totalCount = results.totalCount;
411
- obj.pageCount = results.pageCount;
412
- obj.pageNum = results.pageNum;
413
- obj.records = reset
414
- ? results.records
415
- : obj.records.concat(results.records);
416
- this.$set(
417
- this.noMore,
418
- obj.id || String(index),
419
- results.pageNum >= results.pageCount
420
- );
421
- } else {
422
- this.types[index].records = [];
423
- this.types[index].totalCount = 0;
424
- this.types[index].pageCount = 1;
425
- this.types[index].pageNum = 0;
426
- this.$set(this.loadings, obj.id || String(index), false);
427
- this.$set(this.noMore, obj.id || String(index), true);
428
- }
429
- })
430
- .catch((err) => {
431
- this.isLoading = false;
432
- this.types[index].records = [];
433
- this.types[index].totalCount = 0;
434
- this.types[index].pageCount = 1;
435
- this.types[index].pageNum = 0;
436
- this.$set(this.loadings, obj.id || String(index), false);
437
- this.$set(this.noMore, obj.id || String(index), true);
438
- if (err.message && err.message !== 'canceled') {
439
- this.$message.error(err.message);
440
- }
441
- });
442
- }
443
- },
444
- handleTabs(res, index) {
445
- this.active = res.id || String(index + 1);
446
- },
447
- handleClick(res, parent) {
448
- if (res.detailUrl) {
449
- this.title = res.title;
450
- this.url = res.detailUrl;
451
- this.visible = true;
452
- } else {
453
- this.$emit('select', res, parent);
454
- }
455
- }
456
- }
457
- };
458
- </script>
1
+ <template>
2
+ <div class="es-public-search-box">
3
+ <el-input
4
+ class="es-public-search-input"
5
+ placeholder="请输入关键字"
6
+ clearable
7
+ prefix-icon="el-icon-search"
8
+ v-model="keyWords"
9
+ round
10
+ ></el-input>
11
+ <el-tabs class="es-public-search-tabs" v-model="active">
12
+ <el-tab-pane label="综合" name="0">
13
+ <el-scrollbar class="es-scrollbar">
14
+ <template v-for="(item, index) in types">
15
+ <div
16
+ v-if="item.records && item.records.length"
17
+ class="es-public-search-content"
18
+ :key="item.id"
19
+ >
20
+ <div class="es-public-search-title">{{ item.name }}</div>
21
+ <ul class="es-public-search-list">
22
+ <li
23
+ v-for="(ele, idx) in item.records.slice(0, 3)"
24
+ class="es-public-search-list-item"
25
+ :key="ele.id || `${item.id}_${ele.title}_${idx}`"
26
+ @click="handleClick(ele, item)"
27
+ >
28
+ <es-icon
29
+ class="es-public-search-item-icon"
30
+ v-bind="getIcon(ele, item)"
31
+ :style="setStyle(ele, index)"
32
+ ></es-icon>
33
+ <div class="es-public-search-item-name">
34
+ {{ ele.name || ele.title || ele.text }}
35
+ </div>
36
+ <div class="es-public-search-item-texts" v-if="ele.summary">
37
+ {{ ele.summary }}
38
+ </div>
39
+ <div class="es-public-search-item-texts">
40
+ <template v-if="Array.isArray(ele.infos || ele.footer)">
41
+ <span
42
+ v-for="(text, idx) in ele.infos || ele.footer"
43
+ class="es-public-search-item-text"
44
+ :key="idx"
45
+ >{{ text }}</span
46
+ >
47
+ </template>
48
+ <template v-else>{{ ele.infos || ele.footer }}</template>
49
+ </div>
50
+ </li>
51
+ </ul>
52
+ <div class="es-public-search-more">
53
+ <span
54
+ class="es-public-search-more-text"
55
+ @click="handleTabs(item, index)"
56
+ >在<span class="es-public-search-more-quote">{{
57
+ item.name
58
+ }}</span
59
+ >中搜索全部</span
60
+ >
61
+ </div>
62
+ </div>
63
+ </template>
64
+ </el-scrollbar>
65
+ </el-tab-pane>
66
+ <template v-for="(item, index) in types">
67
+ <el-tab-pane
68
+ :label="item.name"
69
+ :name="item.id || String(index + 1)"
70
+ :key="item.id"
71
+ lazy
72
+ v-loading="loadings[item.id || String(index)]"
73
+ element-loading-background="rgba(0, 0, 0, 0.01)"
74
+ element-loading-text="加载中..."
75
+ v-if="!hides.includes(item.name) && !item.hide"
76
+ >
77
+ <el-scrollbar
78
+ class="es-scrollbar es-public-search-scrollbar"
79
+ :infinite-scroll="
80
+ () => {
81
+ handleSearchd(item, index);
82
+ }
83
+ "
84
+ :infinite-scroll-disabled="disabled"
85
+ :infinite-scroll-immediate="false"
86
+ >
87
+ <div class="es-public-search-info" v-show="keyWords">
88
+ {{ item.totalCount }}条与"<span
89
+ class="es-public-search-more-quote"
90
+ >{{ keyWords }}</span
91
+ >"相关的搜索结果
92
+ </div>
93
+ <ul class="es-public-search-lists">
94
+ <li
95
+ v-for="(ele, idx) in item.records"
96
+ class="es-public-search-list-item"
97
+ :key="ele.id || `${item.id}_${ele.title}_${idx}`"
98
+ @click="handleClick(ele, item)"
99
+ >
100
+ <es-icon
101
+ class="es-public-search-item-icon"
102
+ v-bind="getIcon(ele, item)"
103
+ :style="setStyle(ele, index)"
104
+ ></es-icon>
105
+ <div class="es-public-search-item-name">
106
+ {{ ele.name || ele.title || ele.text }}
107
+ </div>
108
+ <div class="es-public-search-item-texts" v-if="ele.summary">
109
+ {{ ele.summary }}
110
+ </div>
111
+ <div class="es-public-search-item-texts">
112
+ <template v-if="Array.isArray(ele.infos || ele.footer)">
113
+ <span
114
+ v-for="(text, idx) in ele.infos || ele.footer"
115
+ class="es-public-search-item-text"
116
+ :key="idx"
117
+ >{{ text }}</span
118
+ >
119
+ </template>
120
+ <template v-else>{{ ele.infos || ele.footer }}</template>
121
+ </div>
122
+ </li>
123
+ </ul>
124
+ <p
125
+ class="es-public-search-no-more"
126
+ v-if="noMore[item.id || String(index)]"
127
+ >
128
+ 没有更多了
129
+ </p>
130
+ </el-scrollbar>
131
+ </el-tab-pane>
132
+ </template>
133
+ </el-tabs>
134
+ <es-dialog :title="title" :visible.sync="visible" size="max">
135
+ <iframe width="100%" height="100%" frameborder="0" :src="url"></iframe>
136
+ </es-dialog>
137
+ </div>
138
+ </template>
139
+
140
+ <script>
141
+ import util from 'eoss-ui/src/utils/util';
142
+ import { searchType } from 'eoss-ui/src/config/api.js';
143
+ import { debounce } from 'throttle-debounce';
144
+ export default {
145
+ name: 'Search',
146
+ components: {},
147
+ props: {
148
+ menuIcon: {
149
+ type: String,
150
+ default: 'es-icon-application'
151
+ },
152
+ menus: {
153
+ type: Array,
154
+ default() {
155
+ return [];
156
+ }
157
+ },
158
+ apps: {
159
+ type: Array,
160
+ default() {
161
+ return [];
162
+ }
163
+ },
164
+ searchType: {
165
+ type: String,
166
+ default: searchType
167
+ },
168
+ pageSize: {
169
+ type: Number,
170
+ default: 10
171
+ },
172
+ hides: {
173
+ type: Array,
174
+ default() {
175
+ return [];
176
+ }
177
+ }
178
+ },
179
+ data() {
180
+ return {
181
+ icons: {
182
+ ppt: 'es-icon-ppt',
183
+ png: 'es-icon-picture',
184
+ gif: 'es-icon-picture',
185
+ jpg: 'es-icon-picture',
186
+ xls: 'es-icon-excel',
187
+ xlsx: 'es-icon-excel',
188
+ docx: 'es-icon-word',
189
+ doc: 'es-icon-word',
190
+ rar: 'es-icon-zip',
191
+ zip: 'es-icon-zip',
192
+ txt: 'es-icon-txt',
193
+ ipa: 'es-icon-ios',
194
+ apk: 'es-icon-android',
195
+ mp4: 'es-icon-video',
196
+ avi: 'es-icon-video',
197
+ mp3: 'es-icon-audioo',
198
+ wma: 'es-icon-audioo',
199
+ pdf: 'es-icon-pdf'
200
+ },
201
+ colors: [
202
+ '#46D3BA',
203
+ '#2591F7',
204
+ '#40C274',
205
+ '#E34D59',
206
+ '#FF9C52',
207
+ '#17C27B'
208
+ ],
209
+ keyWords: '',
210
+ active: '0',
211
+ types: [],
212
+ lists: [],
213
+ loadings: {},
214
+ noMore: {},
215
+ isLoading: false,
216
+ title: '',
217
+ visible: false,
218
+ url: ''
219
+ };
220
+ },
221
+ computed: {
222
+ loading() {
223
+ return this.active == '0' && this.isLoading;
224
+ },
225
+ disabled() {
226
+ return this.loadings[this.active] || this.noMore[this.active];
227
+ }
228
+ },
229
+ watch: {
230
+ keyWords(val) {
231
+ this.handleSearchAll(val);
232
+ }
233
+ },
234
+ beforeCreate() {
235
+ this.handleSearchAll = debounce(500, (res) => {
236
+ this.searchAll(res);
237
+ });
238
+ this.handleSearchd = debounce(500, (obj, index) => {
239
+ this.handleSearch(obj, index, false);
240
+ });
241
+ },
242
+ created() {
243
+ this.getTypes();
244
+ },
245
+ mounted() {},
246
+ methods: {
247
+ getIcon(res, item) {
248
+ let icon;
249
+ let cls;
250
+ if (res.icon || res.icons) {
251
+ icon = this.icons[(res.icon || res.icons).toLowerCase()];
252
+ if (!icon) {
253
+ if (res.icon == '#last' || res.icons == '#last') {
254
+ let title = res.title || res.name || res.text;
255
+ icon = title.substr(-1, 1);
256
+ cls = 'es-public-search-item-icon-text';
257
+ } else {
258
+ cls = 'es-public-search-item-icons';
259
+ icon = res.icon || res.icons;
260
+ }
261
+ }
262
+ } else {
263
+ let title = res.title || res.name || res.text;
264
+ let key = title.split('.')[1];
265
+ icon = key ? this.icons[key.toLowerCase()] : '';
266
+ if (!icon) {
267
+ icon =
268
+ item.name == '菜单' || item.name == '应用'
269
+ ? this.menuIcon
270
+ : title.substr(-1, 1);
271
+ cls = 'es-public-search-item-icon-text';
272
+ }
273
+ }
274
+ return { class: cls, contents: icon };
275
+ },
276
+ setStyle(res, index) {
277
+ if (res.icon || res.icons) {
278
+ let icon = this.icons[(res.icon || res.icons).toLowerCase()];
279
+ if (!icon && res.icon != '#last') {
280
+ return { backgroundColor: this.colors[index % this.colors.length] };
281
+ }
282
+ } else {
283
+ return { backgroundColor: this.colors[index % this.colors.length] };
284
+ }
285
+ return {};
286
+ },
287
+ getTypes() {
288
+ util
289
+ .ajax({
290
+ url: this.searchType,
291
+ method: 'post',
292
+ format: false,
293
+ data: {
294
+ terminalType: 'web'
295
+ }
296
+ })
297
+ .then((res) => {
298
+ if (res.rCode == 0) {
299
+ let { results } = res;
300
+ let loadings = {};
301
+ let noMore = {};
302
+ let types = results.catalog.map((item, index) => {
303
+ loadings[item.id || String(index)] = false;
304
+ noMore[item.id || String(index)] = false;
305
+ return {
306
+ ...item,
307
+ pageNum: 0,
308
+ pageCount: 1,
309
+ records: [],
310
+ hide:
311
+ item.name == '应用' && this.apps.length == 0 ? true : false
312
+ };
313
+ });
314
+ this.types = types;
315
+ this.loadings = loadings;
316
+ this.noMore = noMore;
317
+ }
318
+ });
319
+ },
320
+ searchAll(keyWords) {
321
+ for (let i = 0; i < this.types.length; i++) {
322
+ let item = this.types[i];
323
+ if (keyWords && !this.hides.includes(item.name) && !item.hide) {
324
+ if (item.name == '菜单' && this.menus.length) {
325
+ this.isLoading = false;
326
+ this.types[i].records = this.searchData(this.menus, keyWords);
327
+ this.types[i].totalCount = this.types[i].records.length;
328
+ this.types[i].pageCount = 1;
329
+ this.types[i].pageNum = 1;
330
+ this.$set(this.loadings, item.id || String(i), false);
331
+ this.$set(this.noMore, item.id || String(i), true);
332
+ } else if (item.name == '应用' && this.apps.length) {
333
+ this.isLoading = false;
334
+ this.types[i].records = this.searchData(this.apps, keyWords);
335
+ this.types[i].totalCount = this.types[i].records.length;
336
+ this.types[i].pageCount = 1;
337
+ this.types[i].pageNum = 1;
338
+ this.$set(this.loadings, item.id || String(i), false);
339
+ this.$set(this.noMore, item.id || String(i), true);
340
+ } else if (item.dataRequestUrl) {
341
+ this.isLoading = true;
342
+ this.handleSearch(item, i, true);
343
+ } else {
344
+ this.types[i].records = [];
345
+ this.types[i].totalCount = 0;
346
+ this.types[i].pageCount = 1;
347
+ this.types[i].pageNum = 0;
348
+ this.$set(this.loadings, item.id || String(i), false);
349
+ this.$set(this.noMore, item.id || String(i), true);
350
+ }
351
+ } else {
352
+ this.isLoading = false;
353
+ this.types[i].records = [];
354
+ this.types[i].totalCount = 0;
355
+ this.types[i].pageCount = 1;
356
+ this.types[i].pageNum = 0;
357
+ this.$set(this.loadings, item.id || String(i), false);
358
+ this.$set(this.noMore, item.id || String(i), true);
359
+ }
360
+ }
361
+ },
362
+ searchData(data, name) {
363
+ let records = [];
364
+ data.forEach((item) => {
365
+ let words = item.name || item.text;
366
+ if (words.indexOf(name) > -1 && item.permission !== false) {
367
+ records.push(item);
368
+ }
369
+ if (item.children && item.children.length) {
370
+ records = records.concat(this.searchData(item.children, name));
371
+ }
372
+ if (item.fourthTabs && item.fourthTabs.length) {
373
+ records = records.concat(this.searchData(item.fourthTabs, name));
374
+ }
375
+ });
376
+ return records;
377
+ },
378
+ handleSearch(obj, index, reset) {
379
+ if (obj.pageNum < obj.pageCount && this.keyWords) {
380
+ this.$set(this.loadings, obj.id || String(index), true);
381
+ if (this.active == '0') {
382
+ this.isLoading = true;
383
+ }
384
+ util
385
+ .ajax({
386
+ url: obj.dataRequestUrl,
387
+ method: 'post',
388
+ format: false,
389
+ data: {
390
+ pageNum: obj.pageNum + 1,
391
+ pageSize: this.pageSize,
392
+ search: this.keyWords,
393
+ terminalType: 'web'
394
+ }
395
+ })
396
+ .then((res) => {
397
+ this.$set(this.loadings, obj.id || String(index), false);
398
+ let flag = false;
399
+ for (let i in this.loadings) {
400
+ if (this.loadings[i]) {
401
+ flag = true;
402
+ break;
403
+ }
404
+ }
405
+ if (!flag) {
406
+ this.isLoading = false;
407
+ }
408
+ if (res.rCode == 0) {
409
+ let { results } = res;
410
+ obj.totalCount = results.totalCount;
411
+ obj.pageCount = results.pageCount;
412
+ obj.pageNum = results.pageNum;
413
+ obj.records = reset
414
+ ? results.records
415
+ : obj.records.concat(results.records);
416
+ this.$set(
417
+ this.noMore,
418
+ obj.id || String(index),
419
+ results.pageNum >= results.pageCount
420
+ );
421
+ } else {
422
+ this.types[index].records = [];
423
+ this.types[index].totalCount = 0;
424
+ this.types[index].pageCount = 1;
425
+ this.types[index].pageNum = 0;
426
+ this.$set(this.loadings, obj.id || String(index), false);
427
+ this.$set(this.noMore, obj.id || String(index), true);
428
+ }
429
+ })
430
+ .catch((err) => {
431
+ this.isLoading = false;
432
+ this.types[index].records = [];
433
+ this.types[index].totalCount = 0;
434
+ this.types[index].pageCount = 1;
435
+ this.types[index].pageNum = 0;
436
+ this.$set(this.loadings, obj.id || String(index), false);
437
+ this.$set(this.noMore, obj.id || String(index), true);
438
+ if (err.message && err.message !== 'canceled') {
439
+ this.$message.error(err.message);
440
+ }
441
+ });
442
+ }
443
+ },
444
+ handleTabs(res, index) {
445
+ this.active = res.id || String(index + 1);
446
+ },
447
+ handleClick(res, parent) {
448
+ if (res.detailUrl) {
449
+ this.title = res.title;
450
+ this.url = res.detailUrl;
451
+ this.visible = true;
452
+ } else {
453
+ this.$emit('select', res, parent);
454
+ }
455
+ }
456
+ }
457
+ };
458
+ </script>