@opentiny/vue-renderless 3.6.0 → 3.6.1-alpha.2

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 (482) hide show
  1. package/README.md +7 -26
  2. package/action-menu/index.js +15 -15
  3. package/action-menu/vue.js +17 -22
  4. package/action-sheet/index.js +53 -68
  5. package/action-sheet/vue.js +28 -54
  6. package/alert/index.js +10 -21
  7. package/alert/vue.js +19 -33
  8. package/amount/index.js +205 -308
  9. package/amount/vue.js +113 -187
  10. package/anchor/index.js +102 -173
  11. package/anchor/vue.js +26 -47
  12. package/area/index.js +93 -153
  13. package/area/vue.js +26 -62
  14. package/autocomplete/index.js +115 -157
  15. package/autocomplete/vue.js +84 -159
  16. package/autonavi-map/index.js +12 -22
  17. package/avatar/index.js +28 -31
  18. package/avatar/vue.js +16 -19
  19. package/badge/index.js +11 -15
  20. package/badge/vue.js +19 -27
  21. package/baidu-map/index.js +12 -22
  22. package/breadcrumb/index.js +8 -7
  23. package/breadcrumb/vue.js +15 -22
  24. package/breadcrumb-item/index.js +14 -26
  25. package/breadcrumb-item/vue.js +20 -28
  26. package/bulletin-board/index.js +19 -22
  27. package/bulletin-board/vue.js +26 -33
  28. package/button/index.js +14 -18
  29. package/button/vue.js +26 -38
  30. package/button-group/index.js +19 -24
  31. package/button-group/vue.js +32 -45
  32. package/calendar/index.js +168 -203
  33. package/calendar/vue.js +89 -100
  34. package/card-template/index.js +29 -37
  35. package/card-template/vue.js +18 -30
  36. package/carousel/index.js +125 -198
  37. package/carousel/vue.js +132 -188
  38. package/carousel-item/index.js +55 -80
  39. package/carousel-item/vue.js +42 -42
  40. package/cascader/index.js +329 -460
  41. package/cascader/vue.js +159 -319
  42. package/cascader-menu/index.js +32 -39
  43. package/cascader-menu/vue.js +21 -30
  44. package/cascader-node/index.js +41 -60
  45. package/cascader-node/vue.js +27 -59
  46. package/cascader-panel/index.js +229 -311
  47. package/cascader-panel/node.js +118 -190
  48. package/cascader-panel/store.js +49 -76
  49. package/cascader-panel/vue.js +125 -197
  50. package/chart-bar/index.js +129 -439
  51. package/chart-boxplot/index.js +78 -219
  52. package/chart-candle/index.js +134 -379
  53. package/chart-core/deps/constants.js +70 -49
  54. package/chart-core/deps/numerify.js +106 -147
  55. package/chart-core/deps/utils.js +118 -121
  56. package/chart-core/index.js +302 -469
  57. package/chart-core/modules/animation.js +7 -5
  58. package/chart-core/modules/extend.js +18 -19
  59. package/chart-core/modules/mark.js +7 -3
  60. package/chart-core/vue.js +81 -120
  61. package/chart-funnel/index.js +47 -126
  62. package/chart-gauge/index.js +54 -128
  63. package/chart-graph/index.js +22 -35
  64. package/chart-heatmap/index.js +116 -362
  65. package/chart-line/index.js +98 -289
  66. package/chart-liquidfill/index.js +35 -100
  67. package/chart-map/index.js +64 -217
  68. package/chart-pie/index.js +93 -274
  69. package/chart-radar/index.js +59 -135
  70. package/chart-sankey/index.js +51 -137
  71. package/chart-scatter/index.js +118 -313
  72. package/chart-sunburst/index.js +25 -33
  73. package/chart-tree/index.js +43 -85
  74. package/chart-waterfall/index.js +77 -210
  75. package/chart-wordcloud/index.js +36 -85
  76. package/checkbox/index.js +82 -133
  77. package/checkbox/vue.js +62 -132
  78. package/checkbox-button/index.js +60 -96
  79. package/checkbox-button/vue.js +53 -135
  80. package/checkbox-group/index.js +6 -11
  81. package/checkbox-group/vue.js +22 -27
  82. package/chunk-PKUHTIDK.js +37 -0
  83. package/col/index.js +89 -119
  84. package/col/vue.js +21 -31
  85. package/collapse/index.js +31 -40
  86. package/collapse/vue.js +24 -32
  87. package/collapse-item/index.js +22 -36
  88. package/collapse-item/vue.js +22 -42
  89. package/common/array.js +51 -56
  90. package/common/bigInt.js +187 -243
  91. package/common/browser.js +35 -31
  92. package/common/dataset/index.js +74 -110
  93. package/common/date.js +199 -201
  94. package/common/decimal.js +94 -142
  95. package/common/deps/ResizeObserver.js +188 -208
  96. package/common/deps/after-leave.js +12 -10
  97. package/common/deps/clickoutside.js +32 -36
  98. package/common/deps/date-util.js +139 -166
  99. package/common/deps/date.js +206 -241
  100. package/common/deps/debounce.js +8 -4
  101. package/common/deps/dom.js +75 -68
  102. package/common/deps/eSpaceCtrl.js +170 -153
  103. package/common/deps/fullscreen/apis.js +51 -65
  104. package/common/deps/fullscreen/screenfull.js +61 -45
  105. package/common/deps/letter-only.js +12 -8
  106. package/common/deps/memorize.js +100 -125
  107. package/common/deps/modal-queue.js +6 -2
  108. package/common/deps/number-only.js +13 -9
  109. package/common/deps/popper.js +280 -372
  110. package/common/deps/popup-manager.js +71 -75
  111. package/common/deps/repeat-click.js +14 -10
  112. package/common/deps/requestAnimationFrame.js +13 -13
  113. package/common/deps/resize-event.js +15 -10
  114. package/common/deps/scroll-into-view.js +13 -13
  115. package/common/deps/scrollbar-width.js +22 -18
  116. package/common/deps/throttle.js +15 -11
  117. package/common/deps/touch.js +24 -22
  118. package/common/deps/tree-model/node.js +374 -524
  119. package/common/deps/tree-model/tree-store.js +251 -352
  120. package/common/deps/tree-model/util.js +10 -4
  121. package/common/deps/upload-ajax.js +28 -24
  122. package/common/deps/vue-emitter.js +15 -11
  123. package/common/deps/vue-popper.js +181 -214
  124. package/common/deps/vue-popup.js +118 -168
  125. package/common/event.js +10 -9
  126. package/common/index.js +180 -194
  127. package/common/object.js +92 -91
  128. package/common/runtime.js +78 -51
  129. package/common/string.js +194 -266
  130. package/common/type.js +49 -51
  131. package/common/validate/index.js +8 -4
  132. package/common/validate/messages.js +64 -67
  133. package/common/validate/rules/enum.js +10 -6
  134. package/common/validate/rules/index.js +18 -14
  135. package/common/validate/rules/pattern.js +9 -5
  136. package/common/validate/rules/range.js +26 -39
  137. package/common/validate/rules/required.js +8 -10
  138. package/common/validate/rules/type.js +67 -79
  139. package/common/validate/rules/whitespace.js +8 -4
  140. package/common/validate/schema.js +159 -199
  141. package/common/validate/util.js +95 -82
  142. package/common/validate/validations/array.js +14 -17
  143. package/common/validate/validations/date.js +16 -20
  144. package/common/validate/validations/enum.js +14 -16
  145. package/common/validate/validations/float.js +13 -15
  146. package/common/validate/validations/index.js +28 -24
  147. package/common/validate/validations/integer.js +13 -15
  148. package/common/validate/validations/method.js +13 -15
  149. package/common/validate/validations/number.js +15 -17
  150. package/common/validate/validations/pattern.js +14 -16
  151. package/common/validate/validations/required.js +10 -14
  152. package/common/validate/validations/string.js +19 -15
  153. package/common/validate/validations/type.js +17 -13
  154. package/common/xss.js +202 -184
  155. package/company/index.js +34 -49
  156. package/company/vue.js +23 -29
  157. package/container/index.js +72 -98
  158. package/container/vue.js +36 -61
  159. package/country/index.js +33 -47
  160. package/country/vue.js +24 -29
  161. package/credit-card/index.js +72 -86
  162. package/credit-card/vue.js +49 -104
  163. package/credit-card-form/index.js +97 -129
  164. package/credit-card-form/vue.js +102 -133
  165. package/crop/index.js +175 -294
  166. package/crop/vue.js +132 -144
  167. package/currency/index.js +49 -67
  168. package/currency/vue.js +25 -34
  169. package/date-panel/index.js +384 -524
  170. package/date-panel/vue.js +178 -289
  171. package/date-picker/index.js +198 -260
  172. package/date-picker/vue.js +97 -155
  173. package/date-range/index.js +324 -435
  174. package/date-range/vue.js +154 -273
  175. package/date-table/index.js +279 -391
  176. package/date-table/vue.js +63 -139
  177. package/dept/index.js +196 -291
  178. package/dept/vue.js +74 -144
  179. package/detail-page/index.js +72 -131
  180. package/detail-page/vue.js +53 -128
  181. package/dialog-box/index.js +178 -248
  182. package/dialog-box/vue.js +111 -201
  183. package/drop-roles/index.js +44 -65
  184. package/drop-roles/vue.js +23 -31
  185. package/drop-times/index.js +21 -22
  186. package/drop-times/vue.js +19 -23
  187. package/dropdown/index.js +182 -253
  188. package/dropdown/vue.js +55 -101
  189. package/dropdown-item/index.js +113 -167
  190. package/dropdown-item/vue.js +73 -121
  191. package/dropdown-menu/index.js +85 -111
  192. package/dropdown-menu/vue.js +23 -36
  193. package/espace/index.js +86 -106
  194. package/espace/vue.js +26 -48
  195. package/exception/index.js +9 -12
  196. package/exception/vue.js +15 -22
  197. package/fall-menu/index.js +81 -110
  198. package/fall-menu/vue.js +32 -78
  199. package/file-upload/index.js +1081 -1713
  200. package/file-upload/vue.js +175 -417
  201. package/floatbar/index.js +8 -5
  202. package/floatbar/vue.js +13 -16
  203. package/form/index.js +124 -165
  204. package/form/vue.js +54 -66
  205. package/form-item/index.js +255 -328
  206. package/form-item/vue.js +97 -198
  207. package/fullscreen/index.js +95 -127
  208. package/fullscreen/vue.js +36 -72
  209. package/grid/core/index.js +7 -3
  210. package/grid/core/interceptor.js +28 -20
  211. package/grid/core/storeMap.js +11 -7
  212. package/grid/plugins/export.js +72 -95
  213. package/grid/plugins/exportExcel.js +244 -561
  214. package/grid/plugins/header.js +22 -21
  215. package/grid/plugins/resize.js +45 -62
  216. package/grid/static/array/arrayEach.js +7 -3
  217. package/grid/static/array/arrayIndexOf.js +7 -3
  218. package/grid/static/array/eachTree.js +17 -21
  219. package/grid/static/array/every.js +6 -2
  220. package/grid/static/array/filterTree.js +17 -12
  221. package/grid/static/array/find.js +7 -3
  222. package/grid/static/array/findTree.js +19 -30
  223. package/grid/static/array/helperCreateIterateHandle.js +31 -39
  224. package/grid/static/array/helperCreateTreeFunc.js +18 -16
  225. package/grid/static/array/includes.js +6 -4
  226. package/grid/static/array/lastArrayEach.js +7 -3
  227. package/grid/static/array/map.js +11 -10
  228. package/grid/static/array/mapTree.js +19 -23
  229. package/grid/static/array/slice.js +7 -3
  230. package/grid/static/array/sortBy.js +32 -34
  231. package/grid/static/array/sum.js +14 -13
  232. package/grid/static/array/toArray.js +6 -6
  233. package/grid/static/array/toTreeArray.js +13 -15
  234. package/grid/static/base/clear.js +18 -14
  235. package/grid/static/base/clone.js +11 -17
  236. package/grid/static/base/destructuring.js +14 -10
  237. package/grid/static/base/each.js +8 -4
  238. package/grid/static/base/eqNull.js +7 -5
  239. package/grid/static/base/findIndexOf.js +8 -4
  240. package/grid/static/base/get.js +21 -17
  241. package/grid/static/base/has.js +21 -20
  242. package/grid/static/base/hasOwnProp.js +5 -3
  243. package/grid/static/base/helperCreateGetObjects.js +13 -9
  244. package/grid/static/base/helperCreateInInObjectString.js +8 -4
  245. package/grid/static/base/helperCreateInTypeof.js +8 -5
  246. package/grid/static/base/helperCreateIndexOf.js +19 -18
  247. package/grid/static/base/helperCreateiterateIndexOf.js +20 -19
  248. package/grid/static/base/helperDefaultCompare.js +5 -1
  249. package/grid/static/base/helperDeleteProperty.js +7 -3
  250. package/grid/static/base/helperEqualCompare.js +27 -29
  251. package/grid/static/base/helperGetHGSKeys.js +5 -3
  252. package/grid/static/base/indexOf.js +7 -3
  253. package/grid/static/base/isArray.js +7 -3
  254. package/grid/static/base/isBoolean.js +5 -3
  255. package/grid/static/base/isDate.js +7 -3
  256. package/grid/static/base/isEmpty.js +7 -3
  257. package/grid/static/base/isEqual.js +10 -10
  258. package/grid/static/base/isFunction.js +5 -3
  259. package/grid/static/base/isNaN.js +6 -4
  260. package/grid/static/base/isNull.js +5 -3
  261. package/grid/static/base/isNumber.js +5 -3
  262. package/grid/static/base/isObject.js +5 -4
  263. package/grid/static/base/isPlainObject.js +6 -2
  264. package/grid/static/base/isRegExp.js +7 -3
  265. package/grid/static/base/isSet.js +6 -4
  266. package/grid/static/base/isString.js +5 -3
  267. package/grid/static/base/isUndefined.js +5 -3
  268. package/grid/static/base/keys.js +7 -3
  269. package/grid/static/base/lastEach.js +8 -4
  270. package/grid/static/base/remove.js +20 -20
  271. package/grid/static/base/set.js +22 -18
  272. package/grid/static/base/toJSONString.js +5 -3
  273. package/grid/static/base/toStringJSON.js +10 -5
  274. package/grid/static/base/uniqueId.js +6 -4
  275. package/grid/static/browse/browse.js +25 -22
  276. package/grid/static/function/property.js +6 -6
  277. package/grid/static/function/throttle.js +18 -14
  278. package/grid/static/index.js +111 -55
  279. package/grid/static/number/helperCreateToNumber.js +12 -10
  280. package/grid/static/number/toNumber.js +7 -3
  281. package/grid/static/object/assign.js +20 -20
  282. package/grid/static/object/extend.js +7 -3
  283. package/grid/static/object/lastObjectEach.js +9 -5
  284. package/grid/static/object/objectEach.js +8 -4
  285. package/grid/static/object/objectMap.js +11 -7
  286. package/grid/static/object/values.js +15 -7
  287. package/grid/static/static/staticDocument.js +7 -4
  288. package/grid/static/static/staticHGKeyRE.js +6 -2
  289. package/grid/static/static/staticParseInt.js +6 -2
  290. package/grid/static/static/staticStrUndefined.js +6 -2
  291. package/grid/static/static/staticWindow.js +7 -4
  292. package/grid/static/string/template.js +10 -8
  293. package/grid/static/string/toString.js +12 -8
  294. package/grid/utils/column.js +11 -14
  295. package/grid/utils/common.js +84 -102
  296. package/grid/utils/dom.js +104 -117
  297. package/grid/utils/event.js +23 -28
  298. package/grid/utils/index.js +8 -5
  299. package/hrapprover/index.js +80 -105
  300. package/hrapprover/vue.js +45 -90
  301. package/image/index.js +107 -175
  302. package/image/vue.js +56 -126
  303. package/image-viewer/index.js +328 -416
  304. package/image-viewer/vue.js +131 -206
  305. package/index-bar/index.js +42 -51
  306. package/index-bar/vue.js +53 -74
  307. package/index-bar-anchor/vue.js +14 -18
  308. package/input/index.js +232 -302
  309. package/input/vue.js +181 -284
  310. package/ip-address/index.js +168 -335
  311. package/ip-address/vue.js +95 -160
  312. package/layout/vue.js +7 -4
  313. package/link/index.js +9 -10
  314. package/link/vue.js +15 -23
  315. package/link-menu/index.js +86 -128
  316. package/link-menu/vue.js +55 -118
  317. package/list/index.js +12 -12
  318. package/list/vue.js +15 -15
  319. package/loading/index.js +22 -21
  320. package/loading/vue.js +15 -18
  321. package/locales/index.js +72 -104
  322. package/locales/vue.js +23 -41
  323. package/logon-user/index.js +14 -19
  324. package/logon-user/vue.js +17 -20
  325. package/logout/index.js +58 -96
  326. package/logout/vue.js +15 -19
  327. package/milestone/index.js +53 -76
  328. package/milestone/vue.js +28 -26
  329. package/mini-picker/index.js +155 -219
  330. package/mini-picker/vue.js +98 -118
  331. package/modal/index.js +386 -735
  332. package/modal/vue.js +81 -117
  333. package/month-range/index.js +108 -143
  334. package/month-range/vue.js +57 -85
  335. package/month-table/index.js +157 -202
  336. package/month-table/vue.js +42 -64
  337. package/multi-select/index.js +150 -214
  338. package/multi-select/vue.js +58 -102
  339. package/nav-menu/index.js +276 -410
  340. package/nav-menu/vue.js +110 -174
  341. package/notify/index.js +59 -81
  342. package/notify/vue.js +42 -57
  343. package/numeric/index.js +231 -363
  344. package/numeric/vue.js +78 -202
  345. package/option/index.js +44 -72
  346. package/option/vue.js +66 -179
  347. package/option-group/index.js +12 -17
  348. package/option-group/vue.js +25 -30
  349. package/package.json +32 -84
  350. package/pager-item/index.js +91 -103
  351. package/pager-item/vue.js +36 -48
  352. package/panel/index.js +22 -28
  353. package/panel/vue.js +17 -23
  354. package/picker/index.js +689 -963
  355. package/picker/timezone.js +1174 -974
  356. package/picker/vue.js +187 -389
  357. package/picker-column/index.js +182 -232
  358. package/picker-column/vue.js +71 -130
  359. package/pop-upload/index.js +162 -321
  360. package/pop-upload/vue.js +143 -273
  361. package/popeditor/index.js +528 -807
  362. package/popeditor/vue.js +165 -334
  363. package/popover/index.js +160 -219
  364. package/popover/vue.js +76 -162
  365. package/popup/index.js +90 -128
  366. package/popup/vue.js +39 -112
  367. package/progress/index.js +108 -171
  368. package/progress/vue.js +65 -115
  369. package/pull-refresh/index.js +118 -132
  370. package/pull-refresh/vue.js +38 -66
  371. package/radio/index.js +41 -77
  372. package/radio/vue.js +35 -92
  373. package/radio-button/index.js +35 -54
  374. package/radio-button/vue.js +28 -61
  375. package/radio-group/index.js +46 -48
  376. package/radio-group/vue.js +26 -30
  377. package/rate/index.js +158 -197
  378. package/rate/vue.js +90 -138
  379. package/roles/index.js +48 -77
  380. package/roles/vue.js +20 -32
  381. package/row/index.js +15 -16
  382. package/row/vue.js +20 -19
  383. package/scroll-text/index.js +17 -22
  384. package/scroll-text/vue.js +18 -27
  385. package/scrollbar/index.js +87 -115
  386. package/scrollbar/vue-bar.js +23 -46
  387. package/scrollbar/vue.js +25 -33
  388. package/search/index.js +67 -95
  389. package/search/vue.js +80 -100
  390. package/select/index.js +1094 -1584
  391. package/select/vue.js +342 -672
  392. package/select-dropdown/index.js +18 -23
  393. package/select-dropdown/vue.js +56 -112
  394. package/slide-bar/index.js +58 -85
  395. package/slide-bar/vue.js +21 -47
  396. package/slider/index.js +276 -373
  397. package/slider/vue.js +94 -144
  398. package/split/index.js +74 -123
  399. package/split/vue.js +63 -116
  400. package/steps/vue.js +8 -3
  401. package/switch/index.js +35 -43
  402. package/switch/vue.js +32 -58
  403. package/tab-bar/index.js +48 -46
  404. package/tab-bar/vue.js +14 -12
  405. package/tab-dropdown/index.js +11 -10
  406. package/tab-dropdown/vue.js +14 -11
  407. package/tab-item/index.js +20 -35
  408. package/tab-item/vue.js +22 -42
  409. package/tab-nav/index.js +194 -227
  410. package/tab-nav/vue.js +62 -83
  411. package/tabbar/index.js +23 -30
  412. package/tabbar/vue.js +22 -45
  413. package/tabbar-item/index.js +39 -51
  414. package/tabbar-item/vue.js +23 -48
  415. package/table/index.js +69 -103
  416. package/table/vue.js +37 -61
  417. package/tabs/index.js +125 -174
  418. package/tabs/vue.js +98 -143
  419. package/tag/index.js +13 -18
  420. package/tag/vue.js +11 -16
  421. package/tall-storage/index.js +87 -106
  422. package/tall-storage/vue-storage-box.js +14 -20
  423. package/tall-storage/vue.js +27 -35
  424. package/text-popup/index.js +48 -70
  425. package/text-popup/vue.js +27 -60
  426. package/time/index.js +71 -113
  427. package/time/vue.js +65 -108
  428. package/time-line/index.js +30 -56
  429. package/time-line/vue.js +23 -46
  430. package/time-panel/index.js +112 -175
  431. package/time-panel/scrollIntoView.js +12 -10
  432. package/time-panel/vue.js +64 -94
  433. package/time-range/index.js +123 -184
  434. package/time-range/vue.js +63 -115
  435. package/time-spinner/index.js +139 -179
  436. package/time-spinner/vue.js +72 -110
  437. package/toggle-menu/index.js +68 -98
  438. package/toggle-menu/vue.js +64 -54
  439. package/tooltip/index.js +127 -168
  440. package/tooltip/vue.js +81 -134
  441. package/top-box/index.js +46 -79
  442. package/top-box/vue.js +34 -62
  443. package/transfer/index.js +184 -263
  444. package/transfer/vue.js +65 -134
  445. package/transfer-panel/index.js +240 -329
  446. package/transfer-panel/vue.js +127 -232
  447. package/tree/index.js +422 -591
  448. package/tree/vue.js +163 -249
  449. package/tree-menu/index.js +97 -122
  450. package/tree-menu/vue.js +57 -39
  451. package/tree-node/index.js +180 -248
  452. package/tree-node/vue.js +107 -202
  453. package/upload/index.js +201 -276
  454. package/upload/vue.js +51 -82
  455. package/upload-dragger/index.js +38 -49
  456. package/upload-dragger/vue.js +16 -24
  457. package/upload-list/index.js +41 -50
  458. package/upload-list/vue.js +21 -27
  459. package/user/index.js +356 -510
  460. package/user/vue.js +50 -97
  461. package/user-account/index.js +16 -21
  462. package/user-account/vue.js +20 -23
  463. package/user-contact/index.js +11 -10
  464. package/user-contact/vue.js +15 -15
  465. package/user-head/index.js +69 -84
  466. package/user-head/vue.js +24 -45
  467. package/user-link/index.js +31 -41
  468. package/user-link/vue.js +23 -46
  469. package/wheel/index.js +136 -161
  470. package/wheel/vue.js +64 -95
  471. package/wizard/index.js +83 -102
  472. package/wizard/vue.js +19 -34
  473. package/year-table/index.js +31 -37
  474. package/year-table/vue.js +17 -21
  475. package/rich-text/clipboard.js +0 -77
  476. package/rich-text/index.js +0 -176
  477. package/rich-text/module/file-upload.js +0 -118
  478. package/rich-text/module/image-drop.js +0 -54
  479. package/rich-text/module/image-upload.js +0 -84
  480. package/rich-text/options.js +0 -187
  481. package/rich-text/table-module.js +0 -557
  482. package/rich-text/vue.js +0 -149
package/user/index.js CHANGED
@@ -1,82 +1,67 @@
1
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
- import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
- import debounce from '@opentiny/vue-renderless/common/deps/debounce';
4
- import { toDateStr } from '@opentiny/vue-renderless/common/date';
5
- import { toJsonStr } from '@opentiny/vue-renderless/common/object';
6
- import { toJson } from '@opentiny/vue-renderless/common/string';
7
- import { log } from '@opentiny/vue-renderless/common';
8
- var request = {
1
+ import "../chunk-PKUHTIDK.js";
2
+ import debounce from "@opentiny/vue-renderless/common/deps/debounce";
3
+ import { toDateStr } from "@opentiny/vue-renderless/common/date";
4
+ import { toJsonStr } from "@opentiny/vue-renderless/common/object";
5
+ import { toJson } from "@opentiny/vue-renderless/common/string";
6
+ import { log } from "@opentiny/vue-renderless/common";
7
+ const request = {
9
8
  timmer: null,
10
9
  group: {},
11
10
  requests: [],
12
11
  cache: {},
13
12
  batch: 0,
14
- addRequest: function addRequest(_ref) {
15
- var _this = this;
16
- var param = _ref.param,
17
- cb = _ref.cb;
18
- this.requests.push({
19
- param: param,
20
- cb: cb,
21
- result: []
22
- });
23
- var valueField = param.valueField,
24
- queryIds = param.queryIds;
13
+ addRequest({ param, cb }) {
14
+ this.requests.push({ param, cb, result: [] });
15
+ const { valueField, queryIds } = param;
25
16
  if (!this.group[valueField]) {
26
17
  this.group[valueField] = [];
27
18
  }
28
- queryIds.forEach(function (id) {
29
- if (!~_this.group[valueField].indexOf(id)) {
30
- !_this.group[valueField].push(id);
19
+ queryIds.forEach((id) => {
20
+ if (!~this.group[valueField].indexOf(id)) {
21
+ !this.group[valueField].push(id);
31
22
  }
32
23
  });
33
24
  },
34
- removeRequest: function removeRequest(item) {
35
- var idx = this.requests.indexOf(item);
25
+ removeRequest(item) {
26
+ const idx = this.requests.indexOf(item);
36
27
  this.requests.splice(idx, 1);
37
28
  },
38
- clearRequest: function clearRequest() {
29
+ clearRequest() {
39
30
  this.timmer = null;
40
31
  this.group = {};
41
32
  this.requests = [];
42
33
  this.cache = {};
43
34
  this.batch = 0;
44
35
  },
45
- getParams: function getParams() {
46
- var _this2 = this;
47
- var args = [];
48
- var _loop = function _loop(key) {
49
- if (Object.prototype.hasOwnProperty.call(_this2.group, key)) {
50
- var all = _this2.group[key];
51
- var items = _this2.splitArr(all, _this2.batch);
52
- if (key === 'userId') {
53
- args.push.apply(args, _toConsumableArray(items.map(function (item) {
54
- return item.join(',');
55
- })));
36
+ getParams() {
37
+ const args = [];
38
+ for (let key in this.group) {
39
+ if (Object.prototype.hasOwnProperty.call(this.group, key)) {
40
+ const all = this.group[key];
41
+ const items = this.splitArr(all, this.batch);
42
+ if (key === "userId") {
43
+ args.push(...items.map((item) => item.join(",")));
56
44
  } else {
57
- args.push.apply(args, _toConsumableArray(items.map(function (item) {
58
- return _defineProperty({
45
+ args.push(
46
+ ...items.map((item) => ({
59
47
  valueField: key,
60
- valueSplit: item.valueSplit
61
- }, key, item.join(','));
62
- })));
48
+ valueSplit: item.valueSplit,
49
+ [key]: item.join(",")
50
+ }))
51
+ );
63
52
  }
64
53
  }
65
- };
66
- for (var key in this.group) {
67
- _loop(key);
68
54
  }
69
55
  return args;
70
56
  },
71
- setCache: function setCache(data, valueField) {
72
- var _this3 = this;
73
- var me = this;
57
+ setCache(data, valueField) {
58
+ const me = this;
74
59
  if (valueField && !this.group[valueField]) {
75
60
  this.group[valueField] = [];
76
61
  }
77
- data.forEach(function (item) {
78
- for (var key in _this3.group) {
79
- if (Object.prototype.hasOwnProperty.call(_this3.group, key)) {
62
+ data.forEach((item) => {
63
+ for (let key in this.group) {
64
+ if (Object.prototype.hasOwnProperty.call(this.group, key)) {
80
65
  if (!me.cache[key]) {
81
66
  me.cache[key] = {};
82
67
  }
@@ -85,550 +70,411 @@ var request = {
85
70
  }
86
71
  });
87
72
  },
88
- singleRequest: function singleRequest(param, api, cb) {
89
- var queryIds = param.queryIds,
90
- valueField = param.valueField,
91
- valueSplit = param.valueSplit;
92
- var queryStr = queryIds.join(',');
93
- var params = valueField === 'userId' ? queryStr : _defineProperty({
94
- valueField: valueField,
95
- valueSplit: valueSplit
96
- }, valueField, queryStr);
97
- api.fetchW3Accounts(params).then(function (data) {
73
+ singleRequest(param, api, cb) {
74
+ const { queryIds, valueField, valueSplit } = param;
75
+ const queryStr = queryIds.join(",");
76
+ const params = valueField === "userId" ? queryStr : { valueField, valueSplit, [valueField]: queryStr };
77
+ api.fetchW3Accounts(params).then((data) => {
98
78
  cb(data);
99
- })["catch"](function (e) {
100
- cb({
101
- error: e
102
- });
79
+ }).catch((e) => {
80
+ cb({ error: e });
103
81
  });
104
82
  },
105
- batchRequest: function batchRequest(api) {
106
- var _this4 = this;
107
- var me = this;
108
- var reqParamsSeq = me.getParams();
109
- var reqLen = reqParamsSeq.length;
110
- reqParamsSeq.forEach(function (params) {
111
- api.fetchW3Accounts(params).then(function (data) {
83
+ batchRequest(api) {
84
+ const me = this;
85
+ const reqParamsSeq = me.getParams();
86
+ let reqLen = reqParamsSeq.length;
87
+ reqParamsSeq.forEach((params) => {
88
+ api.fetchW3Accounts(params).then((data) => {
112
89
  me.setCache(data);
113
- me.requests.slice().forEach(function (reqItem) {
114
- var param = reqItem.param,
115
- cb = reqItem.cb;
116
- var queryIds = param.queryIds,
117
- valueField = param.valueField;
118
- queryIds.forEach(function (id) {
119
- var user = me.cache[valueField] && me.cache[valueField][id];
120
- user && reqItem.result.indexOf(user) === -1 && reqItem.result.push(user);
90
+ me.requests.slice().forEach((reqItem) => {
91
+ const { param, cb } = reqItem;
92
+ const { queryIds, valueField } = param;
93
+ queryIds.forEach((id) => {
94
+ const user = me.cache[valueField] && me.cache[valueField][id];
95
+ user && !reqItem.result.includes(user) && reqItem.result.push(user);
121
96
  });
122
97
  if (reqItem.result.length === queryIds.length) {
123
98
  me.removeRequest(reqItem);
124
99
  cb(reqItem.result);
125
100
  }
126
101
  });
127
- })["finally"](function () {
102
+ }).finally(() => {
128
103
  reqLen--;
129
- var errors = [];
104
+ const errors = [];
130
105
  if (!reqLen) {
131
- _this4.requests.forEach(function (_ref4) {
132
- var cb = _ref4.cb,
133
- result = _ref4.result,
134
- param = _ref4.param;
135
- var queryIds = param.queryIds,
136
- valueField = param.valueField;
106
+ this.requests.forEach(({ cb, result, param }) => {
107
+ const { queryIds, valueField } = param;
137
108
  cb(result);
138
- queryIds.forEach(function (id) {
139
- if (!_this4.cache[valueField] || !_this4.cache[valueField][id]) {
109
+ queryIds.forEach((id) => {
110
+ if (!this.cache[valueField] || !this.cache[valueField][id]) {
140
111
  errors.push(id);
141
112
  }
142
113
  });
143
114
  });
144
- errors.length && log("user [".concat(errors.join(','), "] not found"), 'warn');
145
- _this4.clearRequest();
115
+ errors.length && log(`user [${errors.join(",")}] not found`, "warn");
116
+ this.clearRequest();
146
117
  }
147
118
  });
148
119
  });
149
120
  },
150
- setBatch: function setBatch(batch) {
151
- if (typeof batch !== 'number' || batch <= 0) {
121
+ setBatch(batch) {
122
+ if (typeof batch !== "number" || batch <= 0) {
152
123
  batch = 50;
153
124
  }
154
125
  if (batch <= 500 && this.batch < batch) {
155
126
  this.batch = batch;
156
127
  }
157
128
  },
158
- getusers: function getusers(_ref5) {
159
- var _this5 = this;
160
- var param = _ref5.param,
161
- api = _ref5.api,
162
- batch = _ref5.batch,
163
- cb = _ref5.cb;
129
+ getusers({ param, api, batch, cb }) {
164
130
  if (batch !== false) {
165
131
  this.setBatch(batch);
166
132
  clearTimeout(this.timmer);
167
- this.addRequest({
168
- param: param,
169
- cb: cb
170
- });
171
- this.timmer = setTimeout(function () {
172
- return _this5.batchRequest(api);
173
- }, 100);
133
+ this.addRequest({ param, cb });
134
+ this.timmer = setTimeout(() => this.batchRequest(api), 100);
174
135
  } else {
175
136
  this.singleRequest(param, api, cb);
176
137
  }
177
138
  },
178
- splitArr: function splitArr(arr, num) {
179
- var result = [];
139
+ splitArr(arr, num) {
140
+ let result = [];
180
141
  if (arr.length && num > 0) {
181
- var just = arr.length % num === 0;
182
- var part = Math.floor(arr.length / num);
183
- var len = just ? part : part + 1;
184
- for (var i = 0; i < len; i++) {
142
+ const just = arr.length % num === 0;
143
+ const part = Math.floor(arr.length / num);
144
+ const len = just ? part : part + 1;
145
+ for (let i = 0; i < len; i++) {
185
146
  result.push(arr.slice(i * num, (i + 1) * num));
186
147
  }
187
148
  }
188
149
  return result;
189
150
  }
190
151
  };
191
- export var suggestUser = function suggestUser(api) {
192
- return function (query) {
193
- return new Promise(function (resolve, reject) {
194
- api.fetchSuggestUser(query).then(function (users) {
195
- if (users.length) {
196
- resolve(users);
197
- } else {
198
- resolve({
199
- invalid: query
200
- });
201
- }
202
- })["catch"](reject);
152
+ const suggestUser = (api) => (query) => new Promise((resolve, reject) => {
153
+ api.fetchSuggestUser(query).then((users) => {
154
+ if (users.length) {
155
+ resolve(users);
156
+ } else {
157
+ resolve({ invalid: query });
158
+ }
159
+ }).catch(reject);
160
+ });
161
+ const updateOptions = ({ props, state, nextTick }) => (usersList) => {
162
+ const { valueField, textField, noDataText } = props;
163
+ const values = [].concat(state.user || []);
164
+ const options = [].concat(state.selected);
165
+ const hides = [];
166
+ let count = 0;
167
+ usersList.forEach((users) => {
168
+ users.forEach((user) => {
169
+ const u = user[valueField];
170
+ user._show = true;
171
+ count++;
172
+ if (!~values.indexOf(u)) {
173
+ values.push(u);
174
+ options.push(user);
175
+ } else {
176
+ hides.push(u);
177
+ }
203
178
  });
204
- };
179
+ });
180
+ state.selected.forEach((us) => {
181
+ us._show = !!~hides.indexOf(us[valueField]);
182
+ });
183
+ !count && !noDataText && (state.visible = false);
184
+ if (!props.sortByFetchData) {
185
+ options.sort((a, b) => a[textField] > b[textField] ? 1 : -1);
186
+ }
187
+ state.options = options;
188
+ return nextTick();
205
189
  };
206
- export var updateOptions = function updateOptions(_ref6) {
207
- var props = _ref6.props,
208
- state = _ref6.state,
209
- nextTick = _ref6.nextTick;
210
- return function (usersList) {
211
- var valueField = props.valueField,
212
- textField = props.textField,
213
- noDataText = props.noDataText;
214
- var values = [].concat(state.user || []);
215
- var options = [].concat(state.selected);
216
- var hides = [];
217
- var count = 0;
218
- usersList.forEach(function (users) {
219
- users.forEach(function (user) {
220
- var u = user[valueField];
221
- user._show = true;
222
- count++;
223
- if (!~values.indexOf(u)) {
224
- values.push(u);
225
- options.push(user);
226
- } else {
227
- hides.push(u);
228
- }
229
- });
230
- });
231
- state.selected.forEach(function (us) {
232
- us._show = !!~hides.indexOf(us[valueField]);
233
- });
234
- !count && !noDataText && (state.visible = false);
235
- if (!props.sortByFetchData) {
236
- options.sort(function (a, b) {
237
- return a[textField] > b[textField] ? 1 : -1;
238
- });
239
- }
240
- state.options = options;
190
+ const autoSelect = ({ props, state, nextTick }) => (usersList) => {
191
+ if (!usersList.length) {
241
192
  return nextTick();
242
- };
243
- };
244
- export var autoSelect = function autoSelect(_ref7) {
245
- var props = _ref7.props,
246
- state = _ref7.state,
247
- nextTick = _ref7.nextTick;
248
- return function (usersList) {
249
- if (!usersList.length) {
250
- return nextTick();
251
- }
252
- var values = props.multiple ? [].concat(state.user) : [];
253
- usersList.forEach(function (list) {
254
- if (list.length === 1) {
255
- var value = list[0][props.valueField];
256
- !~values.indexOf(value) && values.push(value);
257
- if (props.autoClose) {
258
- state.visible = false;
259
- }
193
+ }
194
+ const values = props.multiple ? [].concat(state.user) : [];
195
+ usersList.forEach((list) => {
196
+ if (list.length === 1) {
197
+ const value = list[0][props.valueField];
198
+ !~values.indexOf(value) && values.push(value);
199
+ if (props.autoClose) {
200
+ state.visible = false;
260
201
  }
261
- });
262
- if (!values.length) {
263
- return nextTick();
264
- }
265
- if (props.multiple) {
266
- state.user.length !== values.length && (state.user = values);
267
- } else {
268
- state.user = values[0];
269
202
  }
203
+ });
204
+ if (!values.length) {
270
205
  return nextTick();
271
- };
206
+ }
207
+ if (props.multiple) {
208
+ state.user.length !== values.length && (state.user = values);
209
+ } else {
210
+ state.user = values[0];
211
+ }
212
+ return nextTick();
272
213
  };
273
- export var searchMethod = function searchMethod(_ref8) {
274
- var api = _ref8.api,
275
- props = _ref8.props,
276
- state = _ref8.state,
277
- emit = _ref8.emit;
278
- return debounce(props.delay, function (query) {
279
- if (query && query.length >= props.suggestLength) {
280
- state.loading = true;
281
- state.visible = true;
282
- var multiple = props.multiple;
283
- var suggests;
284
- if (multiple) {
285
- suggests = query.split(new RegExp("[".concat(props.textSplit.split('').join('\\'), "]"))).filter(function (q) {
286
- return q && q.length >= props.suggestLength;
287
- }).map(function (q) {
288
- return api.suggestUser(q.trim());
289
- });
290
- } else {
291
- suggests = [api.suggestUser(query.trim())];
292
- }
293
- Promise.all(suggests).then(function (users) {
294
- var failList = [];
295
- var usersList = [];
296
- users.forEach(function (item) {
297
- if (item.invalid) {
298
- failList.push(item.invalid);
299
- } else {
300
- usersList.push(item);
301
- }
302
- });
303
- if (failList.length) {
304
- emit('error', failList);
214
+ const searchMethod = ({ api, props, state, emit }) => debounce(props.delay, (query) => {
215
+ if (query && query.length >= props.suggestLength) {
216
+ state.loading = true;
217
+ state.visible = true;
218
+ const { multiple } = props;
219
+ let suggests;
220
+ if (multiple) {
221
+ suggests = query.split(new RegExp(`[${props.textSplit.split("").join("\\")}]`)).filter((q) => q && q.length >= props.suggestLength).map((q) => api.suggestUser(q.trim()));
222
+ } else {
223
+ suggests = [api.suggestUser(query.trim())];
224
+ }
225
+ Promise.all(suggests).then((users) => {
226
+ const failList = [];
227
+ const usersList = [];
228
+ users.forEach((item) => {
229
+ if (item.invalid) {
230
+ failList.push(item.invalid);
231
+ } else {
232
+ usersList.push(item);
305
233
  }
306
- api.updateOptions(usersList).then(function () {
307
- api.autoSelect(usersList).then(function () {
308
- api.userChange(state.user);
309
- state.loading = false;
310
- });
234
+ });
235
+ if (failList.length) {
236
+ emit("error", failList);
237
+ }
238
+ api.updateOptions(usersList).then(() => {
239
+ api.autoSelect(usersList).then(() => {
240
+ api.userChange(state.user);
241
+ state.loading = false;
311
242
  });
312
243
  });
313
- }
314
- });
315
- };
316
- export var setSelected = function setSelected(_ref9) {
317
- var api = _ref9.api,
318
- props = _ref9.props,
319
- state = _ref9.state;
320
- return function (value) {
321
- var values = Array.isArray(value) ? value.map(function (v) {
322
- return String(v).toLocaleLowerCase();
323
- }) : String(value).toLocaleLowerCase().split(props.valueSplit);
324
- state.selected = state.options.filter(function (user) {
325
- return ~values.indexOf(String(user[props.valueField]).toLocaleLowerCase());
326
244
  });
327
- props.cache && api.cacheUser(state.selected);
328
- };
245
+ }
246
+ });
247
+ const setSelected = ({ api, props, state }) => (value) => {
248
+ const values = Array.isArray(value) ? value.map((v) => String(v).toLocaleLowerCase()) : String(value).toLocaleLowerCase().split(props.valueSplit);
249
+ state.selected = state.options.filter((user) => ~values.indexOf(String(user[props.valueField]).toLocaleLowerCase()));
250
+ props.cache && api.cacheUser(state.selected);
329
251
  };
330
- export var userChange = function userChange(_ref10) {
331
- var api = _ref10.api,
332
- emit = _ref10.emit,
333
- props = _ref10.props,
334
- state = _ref10.state;
335
- return function (value) {
336
- var multiple = props.multiple;
337
- var newVal = multiple && Array.isArray(value) ? value.join(props.valueSplit) : String(value || '');
338
- api.setSelected(newVal);
339
- if (typeof state.lastValue === 'string' && state.lastValue !== null && state.lastValue.toLocaleLowerCase() !== newVal.toLocaleLowerCase()) {
340
- emit('update:modelValue', newVal);
341
- emit('change', newVal, state.selected);
342
- }
343
- state.lastValue = newVal;
344
- };
252
+ const userChange = ({ api, emit, props, state }) => (value) => {
253
+ const { multiple } = props;
254
+ let newVal = multiple && Array.isArray(value) ? value.join(props.valueSplit) : String(value || "");
255
+ api.setSelected(newVal);
256
+ if (typeof state.lastValue === "string" && state.lastValue !== null && state.lastValue.toLocaleLowerCase() !== newVal.toLocaleLowerCase()) {
257
+ emit("update:modelValue", newVal);
258
+ emit("change", newVal, state.selected);
259
+ }
260
+ state.lastValue = newVal;
345
261
  };
346
- var syncCacheIds = function syncCacheIds(ids, props, queryIds, cacheData) {
347
- var valueField = props.valueField,
348
- cacheFields = props.cacheFields,
349
- cacheKey = props.cacheKey;
350
- var cacheUsers = toJson(window.localStorage.getItem(cacheKey)) || {};
351
- ids.forEach(function (id) {
262
+ const syncCacheIds = (ids, props, queryIds, cacheData) => {
263
+ const { valueField, cacheFields, cacheKey } = props;
264
+ const cacheUsers = toJson(window.localStorage.getItem(cacheKey)) || {};
265
+ ids.forEach((id) => {
352
266
  if (cacheUsers[id]) {
353
- var _cacheUser = cacheUsers[id];
354
- var textField = props.textField === 'userCN' || props.textField === 'userId' || props.textField === 'dept' ? '' : props.textField;
355
- if (textField !== '' && !_cacheUser.a) {
267
+ const cacheUser2 = cacheUsers[id];
268
+ const textField = props.textField === "userCN" || props.textField === "userId" || props.textField === "dept" ? "" : props.textField;
269
+ if (textField !== "" && !cacheUser2.a) {
356
270
  window.localStorage.removeItem(cacheKey);
357
271
  queryIds.push(id);
358
272
  }
359
- var user = _defineProperty({
360
- userId: _cacheUser.i,
361
- userCN: _cacheUser.u,
362
- dept: _cacheUser.d,
363
- employeeNumber: _cacheUser.e
364
- }, textField, _cacheUser.a);
365
- cacheFields.forEach(function (field) {
366
- user[field] = _cacheUser[field];
273
+ const user = {
274
+ userId: cacheUser2.i,
275
+ userCN: cacheUser2.u,
276
+ dept: cacheUser2.d,
277
+ employeeNumber: cacheUser2.e,
278
+ [textField]: cacheUser2.a
279
+ };
280
+ cacheFields.forEach((field) => {
281
+ user[field] = cacheUser2[field];
367
282
  });
368
- cacheData.push(Object.assign(user, _defineProperty({}, valueField, cacheUsers[id].p || cacheUsers[id].i)));
283
+ cacheData.push(
284
+ Object.assign(user, {
285
+ [valueField]: cacheUsers[id].p || cacheUsers[id].i
286
+ })
287
+ );
369
288
  } else {
370
289
  queryIds.push(id);
371
290
  }
372
291
  });
373
292
  };
374
- export var getUsers = function getUsers(_ref11) {
375
- var api = _ref11.api,
376
- props = _ref11.props,
377
- state = _ref11.state;
378
- return function (value) {
379
- var valueField = props.valueField,
380
- cache = props.cache;
381
- var ids = Array.isArray(value) ? value : value.split(props.valueSplit);
382
- var cacheData = [];
383
- var queryIds = cache ? [] : ids;
384
- if (cache) {
385
- syncCacheIds(ids, props, queryIds, cacheData);
386
- request.setCache(cacheData, valueField);
387
- if (!queryIds.length) {
388
- return Promise.resolve(cacheData);
389
- }
293
+ const getUsers = ({ api, props, state }) => (value) => {
294
+ const { valueField, cache } = props;
295
+ const ids = Array.isArray(value) ? value : value.split(props.valueSplit);
296
+ const cacheData = [];
297
+ const queryIds = cache ? [] : ids;
298
+ if (cache) {
299
+ syncCacheIds(ids, props, queryIds, cacheData);
300
+ request.setCache(cacheData, valueField);
301
+ if (!queryIds.length) {
302
+ return Promise.resolve(cacheData);
390
303
  }
391
- var param = {
392
- valueSplit: props.valueSplit,
393
- valueField: valueField,
394
- queryIds: queryIds
304
+ }
305
+ const param = { valueSplit: props.valueSplit, valueField, queryIds };
306
+ return new Promise((resolve, reject) => {
307
+ const cb = (data) => {
308
+ if (data.error) {
309
+ reject(data.error);
310
+ } else {
311
+ resolve(data.concat(cacheData));
312
+ }
395
313
  };
396
- return new Promise(function (resolve, reject) {
397
- var cb = function cb(data) {
398
- if (data.error) {
399
- reject(data.error);
400
- } else {
401
- resolve(data.concat(cacheData));
402
- }
403
- };
404
- request.getusers({
405
- param: param,
406
- api: api,
407
- batch: state.batch,
408
- cb: cb
409
- });
410
- });
411
- };
314
+ request.getusers({ param, api, batch: state.batch, cb });
315
+ });
412
316
  };
413
- export var updateCache = function updateCache(_ref12) {
414
- var props = _ref12.props,
415
- state = _ref12.state;
416
- return function () {
417
- var users = toJson(window.localStorage.getItem(props.cacheKey)) || {};
418
- var currDate = toDateStr(new Date(), 'yyyyMMdd');
419
- if (currDate !== users.t) {
420
- users.t = currDate;
421
- for (var u in users) {
422
- if (u !== 't') {
423
- var user = users[u];
424
- if (user.r > 0) {
425
- user.r = 0;
426
- } else {
427
- user.r--;
428
- }
317
+ const updateCache = ({ props, state }) => () => {
318
+ const users = toJson(window.localStorage.getItem(props.cacheKey)) || {};
319
+ const currDate = toDateStr(new Date(), "yyyyMMdd");
320
+ if (currDate !== users.t) {
321
+ users.t = currDate;
322
+ for (let u in users) {
323
+ if (u !== "t") {
324
+ let user = users[u];
325
+ if (user.r > 0) {
326
+ user.r = 0;
327
+ } else {
328
+ user.r--;
429
329
  }
430
330
  }
431
331
  }
432
- state.cache = users;
433
- };
332
+ }
333
+ state.cache = users;
434
334
  };
435
- export var saveCache = function saveCache(_ref13) {
436
- var props = _ref13.props;
437
- return function (cache) {
438
- window.localStorage.setItem(props.cacheKey, toJsonStr(cache));
439
- };
335
+ const saveCache = ({ props }) => (cache) => {
336
+ window.localStorage.setItem(props.cacheKey, toJsonStr(cache));
440
337
  };
441
- export var cacheUser = function cacheUser(_ref14) {
442
- var api = _ref14.api,
443
- props = _ref14.props,
444
- service = _ref14.service;
445
- return function (users) {
446
- var valueField = props.valueField,
447
- cacheKey = props.cacheKey;
448
- var cacheUser = toJson(window.localStorage.getItem(cacheKey)) || {};
449
- var cacheFields = service.userCache;
450
- var user;
451
- var _loop2 = function _loop2() {
452
- var u = users[i];
453
- var key = u[valueField];
454
- user = cacheUser[key];
455
- if (user) {
456
- user.r++;
457
- } else {
458
- var us = {
459
- p: u[valueField],
460
- i: u[cacheFields.userId],
461
- u: u[cacheFields.userCN],
462
- d: u[cacheFields.dept],
463
- e: u[cacheFields.eno],
464
- a: ~['userCN', 'userId', 'dept'].indexOf(props.textField) ? null : u[props.textField],
465
- r: 0
466
- };
467
- props.cacheFields.forEach(function (field) {
468
- us[field] = u[field];
469
- });
470
- cacheUser[key] = us;
471
- }
472
- };
473
- for (var i = 0; i < users.length; i++) {
474
- _loop2();
475
- }
476
- try {
477
- api.saveCache(cacheUser);
478
- } catch (e) {
479
- var sortUsers = Object.keys(cacheUser).sort(function (a, b) {
480
- return cacheUser[a].r < cacheUser[b].r ? 1 : -1;
338
+ const cacheUser = ({ api, props, service }) => (users) => {
339
+ const { valueField, cacheKey } = props;
340
+ const cacheUser2 = toJson(window.localStorage.getItem(cacheKey)) || {};
341
+ const cacheFields = service.userCache;
342
+ let user;
343
+ for (let i = 0; i < users.length; i++) {
344
+ const u = users[i];
345
+ const key = u[valueField];
346
+ user = cacheUser2[key];
347
+ if (user) {
348
+ user.r++;
349
+ } else {
350
+ const us = {
351
+ p: u[valueField],
352
+ i: u[cacheFields.userId],
353
+ u: u[cacheFields.userCN],
354
+ d: u[cacheFields.dept],
355
+ e: u[cacheFields.eno],
356
+ a: ~["userCN", "userId", "dept"].indexOf(props.textField) ? null : u[props.textField],
357
+ r: 0
358
+ };
359
+ props.cacheFields.forEach((field) => {
360
+ us[field] = u[field];
481
361
  });
482
- var cutUser = sortUsers.splice(0, sortUsers.length / 2);
483
- var newCache = {};
484
- for (var _i in cutUser) {
485
- if (Object.prototype.hasOwnProperty.call(cutUser, _i)) {
486
- newCache[cutUser[_i]] = cacheUser[cutUser[_i]];
487
- }
362
+ cacheUser2[key] = us;
363
+ }
364
+ }
365
+ try {
366
+ api.saveCache(cacheUser2);
367
+ } catch (e) {
368
+ const sortUsers = Object.keys(cacheUser2).sort((a, b) => cacheUser2[a].r < cacheUser2[b].r ? 1 : -1);
369
+ const cutUser = sortUsers.splice(0, sortUsers.length / 2);
370
+ const newCache = {};
371
+ for (let i in cutUser) {
372
+ if (Object.prototype.hasOwnProperty.call(cutUser, i)) {
373
+ newCache[cutUser[i]] = cacheUser2[cutUser[i]];
488
374
  }
489
- api.saveCache(newCache);
490
375
  }
491
- };
376
+ api.saveCache(newCache);
377
+ }
492
378
  };
493
- export var useSortable = function useSortable(_ref15) {
494
- var api = _ref15.api,
495
- props = _ref15.props,
496
- state = _ref15.state,
497
- refs = _ref15.refs;
498
- return function () {
499
- var selectDom = refs.select.$el;
500
- if (props.sortable && props.multiple && !state.sortable) {
501
- var tagsDom = selectDom.querySelector('.aui-select__tags>span');
502
- state.sortable = props.sortable.create(tagsDom, {
503
- handle: '.aui-tag',
504
- ghostClass: 'aui-user__ghost',
505
- onEnd: function onEnd(_ref16) {
506
- var newIndex = _ref16.newIndex,
507
- oldIndex = _ref16.oldIndex;
508
- var currUser = state.user.splice(oldIndex, 1)[0];
509
- state.user.splice(newIndex, 0, currUser);
510
- api.userChange(state.user);
511
- }
512
- });
513
- }
514
- };
379
+ const useSortable = ({ api, props, state, refs }) => () => {
380
+ const selectDom = refs.select.$el;
381
+ if (props.sortable && props.multiple && !state.sortable) {
382
+ const tagsDom = selectDom.querySelector(".tiny-select__tags>span");
383
+ state.sortable = props.sortable.create(tagsDom, {
384
+ handle: ".tiny-tag",
385
+ ghostClass: "tiny-user__ghost",
386
+ onEnd: ({ newIndex, oldIndex }) => {
387
+ let currUser = state.user.splice(oldIndex, 1)[0];
388
+ state.user.splice(newIndex, 0, currUser);
389
+ api.userChange(state.user);
390
+ }
391
+ });
392
+ }
515
393
  };
516
- export var visibleChange = function visibleChange(_ref17) {
517
- var state = _ref17.state,
518
- emit = _ref17.emit;
519
- return function (show) {
520
- if (!show) {
521
- state.visible = show;
522
- state.options = state.selected.map(function (user) {
523
- return Object.assign(user, {
524
- _show: true
525
- });
526
- });
527
- }
528
- emit('visible-change', show);
529
- };
394
+ const visibleChange = ({ state, emit }) => (show) => {
395
+ if (!show) {
396
+ state.visible = show;
397
+ state.options = state.selected.map((user) => Object.assign(user, { _show: true }));
398
+ }
399
+ emit("visible-change", show);
530
400
  };
531
- export var initUser = function initUser(_ref18) {
532
- var api = _ref18.api,
533
- props = _ref18.props,
534
- state = _ref18.state;
535
- return function (value) {
536
- if (value === state.lastValue) {
537
- return;
538
- }
539
- state.user = !props.multiple ? '' : [];
540
- if (typeof value === 'number') {
541
- value = String(value);
542
- }
543
- if (!value) {
544
- state.options = [];
545
- state.selected = [];
546
- api.userChange(value);
547
- return;
548
- }
549
- value && api.getUsers(value).then(function (info) {
550
- info.sort(function (a, b) {
551
- return value.indexOf(String(a[props.valueField])) > value.indexOf(String(b[props.valueField])) ? 1 : -1;
552
- });
553
- var list = info.map(function (user) {
554
- user._show = true;
555
- return user[props.valueField];
556
- });
557
- state.options = info;
558
- state.user = props.multiple ? list : list[0];
559
- api.userChange(value);
401
+ const initUser = ({ api, props, state }) => (value) => {
402
+ if (value === state.lastValue) {
403
+ return;
404
+ }
405
+ state.user = !props.multiple ? "" : [];
406
+ if (typeof value === "number") {
407
+ value = String(value);
408
+ }
409
+ if (!value) {
410
+ state.options = [];
411
+ state.selected = [];
412
+ api.userChange(value);
413
+ return;
414
+ }
415
+ value && api.getUsers(value).then((info) => {
416
+ info.sort((a, b) => value.indexOf(String(a[props.valueField])) > value.indexOf(String(b[props.valueField])) ? 1 : -1);
417
+ const list = info.map((user) => {
418
+ user._show = true;
419
+ return user[props.valueField];
560
420
  });
561
- };
421
+ state.options = info;
422
+ state.user = props.multiple ? list : list[0];
423
+ api.userChange(value);
424
+ });
562
425
  };
563
- export var handleBlur = function handleBlur(_ref19) {
564
- var constants = _ref19.constants,
565
- dispatch = _ref19.dispatch,
566
- state = _ref19.state;
567
- return function () {
568
- dispatch(constants.COMPONENT_NAME.FormItem, constants.EVENT_NAME.FormBlur, state.user);
569
- };
426
+ const handleBlur = ({ constants, dispatch, state }) => () => {
427
+ dispatch(constants.COMPONENT_NAME.FormItem, constants.EVENT_NAME.FormBlur, state.user);
570
428
  };
571
- export var initService = function initService(_ref20) {
572
- var props = _ref20.props,
573
- service = _ref20.service;
574
- var noopFnCreator = function noopFnCreator(propName) {
575
- return function () {
576
- if (propName) {
577
- return Promise.reject(new Error("[TINY Error][User]] Prop ".concat(propName, " is not configured")));
578
- } else {
579
- return Promise.reject(new Error('[TINY Error][User]] This component depends on @opentiny/vue-service'));
580
- }
581
- };
429
+ const initService = ({ props, service }) => {
430
+ const noopFnCreator = (propName) => () => {
431
+ if (propName) {
432
+ return Promise.reject(new Error(`[TINY Error][User]] Prop ${propName} is not configured`));
433
+ } else {
434
+ return Promise.reject(new Error("[TINY Error][User]] This component depends on @opentiny/vue-service"));
435
+ }
582
436
  };
583
- var $service = service || {};
584
- var _$service$common = $service.common,
585
- common = _$service$common === void 0 ? {} : _$service$common,
586
- _$service$setting = $service.setting,
587
- setting = _$service$setting === void 0 ? {} : _$service$setting,
588
- _$service$base = $service.base,
589
- base = _$service$base === void 0 ? {} : _$service$base;
590
- var fetchUser = $service.fetchUser,
591
- fetchW3Accounts = $service.fetchW3Accounts,
592
- fetchSuggestUser = $service.fetchSuggestUser,
593
- fetchUserByUserId = $service.fetchUserByUserId;
594
- var _setting$options = setting.options,
595
- options = _setting$options === void 0 ? {} : _setting$options;
596
- var _options$UserCache = options.UserCache,
597
- UserCache = _options$UserCache === void 0 ? {
598
- uuid: 'uuid',
599
- userId: 'userId',
600
- userCN: 'userCN',
601
- dept: 'dept',
602
- eno: 'employeeNumber'
603
- } : _options$UserCache,
604
- _options$User = options.User,
605
- User = _options$User === void 0 ? {
606
- batch: 50
607
- } : _options$User;
437
+ const $service = service || {};
438
+ const { common = {}, setting = {}, base = {} } = $service;
439
+ const { fetchUser, fetchW3Accounts, fetchSuggestUser, fetchUserByUserId } = $service;
440
+ const { options = {} } = setting;
441
+ const { UserCache = { uuid: "uuid", userId: "userId", userCN: "userCN", dept: "dept", eno: "employeeNumber" }, User = { batch: 50 } } = options;
608
442
  return {
609
- fetchUser: props.fetchUser || fetchUser || noopFnCreator('fetchUser'),
610
- fetchW3Accounts: props.fetchW3Accounts || fetchW3Accounts || noopFnCreator('fetchW3Accounts'),
611
- fetchSuggestUser: props.fetchSuggestUser || fetchSuggestUser || noopFnCreator('fetchSuggestUser'),
612
- fetchUserByUserId: props.fetchUserByUserId || fetchUserByUserId || noopFnCreator('fetchUserByUserId'),
613
- getUserImageUrl: props.getUserImageUrl || common.getUserImageUrl || noopFnCreator('getUserImageUrl'),
614
- getLangData: props.getLangData || base.getLangData || noopFnCreator('getLangData'),
615
- getUserInfo: props.getUserInfo || base.getUserInfo || noopFnCreator('getUserInfo'),
443
+ fetchUser: props.fetchUser || fetchUser || noopFnCreator("fetchUser"),
444
+ fetchW3Accounts: props.fetchW3Accounts || fetchW3Accounts || noopFnCreator("fetchW3Accounts"),
445
+ fetchSuggestUser: props.fetchSuggestUser || fetchSuggestUser || noopFnCreator("fetchSuggestUser"),
446
+ fetchUserByUserId: props.fetchUserByUserId || fetchUserByUserId || noopFnCreator("fetchUserByUserId"),
447
+ getUserImageUrl: props.getUserImageUrl || common.getUserImageUrl || noopFnCreator("getUserImageUrl"),
448
+ getLangData: props.getLangData || base.getLangData || noopFnCreator("getLangData"),
449
+ getUserInfo: props.getUserInfo || base.getUserInfo || noopFnCreator("getUserInfo"),
616
450
  userCache: props.UserCache || UserCache,
617
451
  batch: User.batch
618
452
  };
619
453
  };
620
- export var filter = function filter(_ref21) {
621
- var props = _ref21.props,
622
- state = _ref21.state;
623
- return function () {
624
- if (props.multiple && props.hideSelected) {
625
- var selectedUsers = state.user.map(function (value) {
626
- return typeof value === 'string' ? value.toLocaleLowerCase() : value;
627
- });
628
- return state.options.filter(function (user) {
629
- return !~selectedUsers.indexOf(typeof user[props.valueField] === 'string' ? user[props.valueField].toLocaleLowerCase() : user[props.valueField]);
630
- });
631
- }
632
- return state.options;
633
- };
634
- };
454
+ const filter = ({ props, state }) => () => {
455
+ if (props.multiple && props.hideSelected) {
456
+ const selectedUsers = state.user.map((value) => typeof value === "string" ? value.toLocaleLowerCase() : value);
457
+ return state.options.filter(
458
+ (user) => !~selectedUsers.indexOf(typeof user[props.valueField] === "string" ? user[props.valueField].toLocaleLowerCase() : user[props.valueField])
459
+ );
460
+ }
461
+ return state.options;
462
+ };
463
+ export {
464
+ autoSelect,
465
+ cacheUser,
466
+ filter,
467
+ getUsers,
468
+ handleBlur,
469
+ initService,
470
+ initUser,
471
+ saveCache,
472
+ searchMethod,
473
+ setSelected,
474
+ suggestUser,
475
+ updateCache,
476
+ updateOptions,
477
+ useSortable,
478
+ userChange,
479
+ visibleChange
480
+ };