eoss-ui 0.6.52 → 0.6.54

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