@opentiny/vue-renderless 3.21.2 → 3.23.0

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 (331) hide show
  1. package/amount/index.js +4 -4
  2. package/anchor/index.js +1 -1
  3. package/async-flowchart/index.js +1 -1
  4. package/autocomplete/index.js +4 -1
  5. package/autocomplete/vue.js +3 -3
  6. package/base-select/index.js +20 -21
  7. package/base-select/vue.js +2 -2
  8. package/calendar/index.js +2 -2
  9. package/calendar-bar/index.js +2 -2
  10. package/calendar-bar/vue.js +1 -1
  11. package/calendar-view/index.js +91 -25
  12. package/calendar-view/vue.js +6 -4
  13. package/card/index.js +1 -1
  14. package/card-template/index.js +1 -1
  15. package/carousel/index.js +4 -4
  16. package/carousel/vue.js +1 -1
  17. package/cascader/index.js +21 -11
  18. package/cascader/vue.js +6 -5
  19. package/cascader-menu/vue.js +2 -2
  20. package/cascader-mobile/index.js +1 -1
  21. package/cascader-node/vue.js +11 -1
  22. package/cascader-panel/index.js +4 -4
  23. package/cascader-panel/node.js +3 -4
  24. package/cascader-panel/vue.js +1 -1
  25. package/cascader-select/column-index.js +2 -2
  26. package/cascader-view/index.js +1 -1
  27. package/chart-bar/index.js +1 -1
  28. package/chart-candle/index.js +1 -1
  29. package/chart-core/deps/utils.js +6 -6
  30. package/chart-core/index.js +1 -1
  31. package/chart-funnel/index.js +1 -1
  32. package/chart-gauge/index.js +1 -1
  33. package/chart-line/index.js +1 -1
  34. package/chart-map/index.js +1 -1
  35. package/chart-pie/index.js +1 -1
  36. package/chart-radar/index.js +1 -1
  37. package/chart-sankey/index.js +1 -1
  38. package/chart-scatter/index.js +1 -1
  39. package/chart-waterfall/index.js +1 -1
  40. package/chart-wordcloud/index.js +1 -1
  41. package/checkbox/index.js +1 -1
  42. package/collapse-item/vue.js +1 -1
  43. package/column-list-item/index.js +1 -1
  44. package/common/deps/dom.js +20 -196
  45. package/common/deps/infinite-scroll.js +4 -43
  46. package/common/deps/popup-manager.js +1 -200
  47. package/container/index.js +2 -2
  48. package/crop/index.js +3 -3
  49. package/currency/index.js +2 -2
  50. package/date-panel/index.js +82 -26
  51. package/date-panel/vue.js +53 -21
  52. package/date-picker/vue.js +1 -1
  53. package/date-picker-mobile/index.js +1 -1
  54. package/date-range/index.js +74 -37
  55. package/date-range/vue.js +27 -23
  56. package/date-table/index.js +8 -5
  57. package/date-table/vue.js +1 -1
  58. package/dialog-box/index.js +3 -3
  59. package/dialog-box/vue.js +1 -1
  60. package/dialog-select/index.js +15 -4
  61. package/dialog-select/vue.js +7 -4
  62. package/drawer/index.js +2 -2
  63. package/drop-times/index.js +1 -1
  64. package/dropdown/index.js +11 -3
  65. package/dropdown/vue.js +2 -2
  66. package/dropdown-item/index.js +1 -1
  67. package/dropdown-item/mf.js +1 -1
  68. package/dropdown-menu/index.js +1 -1
  69. package/espace/vue.js +2 -2
  70. package/fall-menu/index.js +3 -3
  71. package/file-upload/index.js +16 -13
  72. package/file-upload/vue.js +2 -2
  73. package/filter/vue.js +1 -1
  74. package/filter-panel/vue.js +1 -2
  75. package/floating-button/index.js +1 -1
  76. package/flowchart/index.js +3 -3
  77. package/flowchart/vue.js +1 -1
  78. package/fluent-editor/index.js +5 -7
  79. package/fluent-editor/options.js +2 -2
  80. package/form/index.js +20 -2
  81. package/form-item/index.js +6 -6
  82. package/fullscreen/index.js +1 -1
  83. package/fullscreen/vue.js +1 -1
  84. package/grid/plugins/export.js +8 -2
  85. package/grid/plugins/exportExcel.js +3 -3
  86. package/grid/plugins/resize.js +2 -2
  87. package/grid/static/base/helperEqualCompare.js +1 -1
  88. package/grid/static/base/isPlainObject.js +1 -1
  89. package/grid/utils/common.js +2 -2
  90. package/grid/utils/dom.js +12 -7
  91. package/grid/utils/event.js +4 -4
  92. package/hrapprover/index.js +1 -1
  93. package/image/index.js +3 -3
  94. package/image-viewer/index.js +4 -6
  95. package/image-viewer/vue.js +1 -1
  96. package/input/index.js +2 -2
  97. package/input/vue.js +1 -1
  98. package/ip-address/index.js +17 -21
  99. package/ip-address/vue.js +1 -1
  100. package/link-menu/index.js +1 -1
  101. package/link-menu/vue.js +1 -1
  102. package/load-list/index.js +1 -1
  103. package/load-list/vue.js +4 -4
  104. package/loading/index.js +2 -2
  105. package/menu/vue.js +1 -1
  106. package/milestone/index.js +6 -45
  107. package/modal/index.js +5 -5
  108. package/month-range/index.js +48 -5
  109. package/month-range/vue.js +19 -15
  110. package/month-table/index.js +5 -5
  111. package/month-table/vue.js +1 -1
  112. package/nav-menu/index.js +7 -7
  113. package/notify/index.js +3 -3
  114. package/number-animation/index.js +53 -0
  115. package/number-animation/vue.js +27 -0
  116. package/numeric/index.js +5 -5
  117. package/option/index.js +1 -1
  118. package/option/vue.js +2 -1
  119. package/package.json +3 -2
  120. package/pager/index.js +28 -16
  121. package/pager/vue.js +27 -16
  122. package/panel/index.js +1 -1
  123. package/picker/index.js +28 -23
  124. package/picker/vue.js +6 -6
  125. package/picker-column/index.js +1 -1
  126. package/pop-upload/vue.js +1 -1
  127. package/popconfirm/vue.js +1 -1
  128. package/popeditor/index.js +6 -6
  129. package/popeditor/vue.js +2 -2
  130. package/popover/index.js +3 -3
  131. package/popover/vue.js +1 -1
  132. package/popup/index.js +3 -3
  133. package/pull-refresh/index.js +1 -1
  134. package/pull-refresh-mobile-first/index.js +1 -1
  135. package/pull-refresh-mobile-first/vue.js +4 -4
  136. package/quarter-panel/index.js +2 -2
  137. package/quarter-panel/vue.js +1 -1
  138. package/radio-group/index.js +1 -1
  139. package/rate/index.js +1 -1
  140. package/rate/vue.js +1 -1
  141. package/recycle-scroller/index.js +2 -2
  142. package/recycle-scroller/vue.js +1 -1
  143. package/rich-text/index.js +1 -1
  144. package/rich-text/table-module.js +2 -2
  145. package/river/river.js +1 -1
  146. package/river/vue.js +1 -1
  147. package/scrollbar/vue-bar.js +1 -1
  148. package/scrollbar/vue.js +1 -1
  149. package/search/index.js +3 -3
  150. package/select/index.js +26 -22
  151. package/select/vue.js +8 -7
  152. package/select-dropdown/vue.js +5 -5
  153. package/selected-box/index.js +1 -1
  154. package/signature/index.js +1 -1
  155. package/signature/vue.js +2 -2
  156. package/skeleton/index.js +1 -1
  157. package/slider/index.js +4 -4
  158. package/slider-button-group/slide-button.js +2 -2
  159. package/split/index.js +2 -2
  160. package/split/vue.js +1 -1
  161. package/statistic/index.js +1 -1
  162. package/steps/index.js +2 -3
  163. package/steps/slide-bar.js +2 -2
  164. package/sticky/vue.js +4 -4
  165. package/tab-bar/index.js +2 -2
  166. package/tab-item-mf/vue.js +1 -1
  167. package/tab-nav/index.js +4 -4
  168. package/tabbar/index.js +1 -1
  169. package/tabbar/vue.js +1 -1
  170. package/tabbar-item/index.js +1 -1
  171. package/tabs-mf/index.js +9 -5
  172. package/tabs-mf/vue-bar.js +5 -4
  173. package/tabs-mf/vue-swipe.js +1 -1
  174. package/tabs-mf/vue.js +2 -2
  175. package/tabs-mf/wheel.js +3 -3
  176. package/tag-group/vue.js +2 -2
  177. package/tall-storage/index.js +1 -1
  178. package/tall-storage/vue.js +1 -1
  179. package/time/index.js +1 -1
  180. package/time/vue.js +1 -1
  181. package/time-line/index.js +1 -1
  182. package/time-line-new/index.js +1 -1
  183. package/time-panel/index.js +2 -2
  184. package/time-panel/vue.js +1 -1
  185. package/time-range/index.js +1 -1
  186. package/time-range/vue.js +1 -1
  187. package/time-spinner/index.js +4 -4
  188. package/time-spinner/vue.js +1 -1
  189. package/timeline-item/index.js +1 -1
  190. package/toggle-menu/index.js +1 -1
  191. package/tooltip/index.js +2 -2
  192. package/tooltip/vue.js +2 -2
  193. package/top-box/index.js +3 -3
  194. package/transfer/index.js +42 -1
  195. package/transfer/vue.js +64 -24
  196. package/transfer-panel/index.js +6 -1
  197. package/tree/index.js +9 -9
  198. package/tree/vue.js +2 -2
  199. package/tree-node/index.js +1 -1
  200. package/tree-node/vue.js +1 -1
  201. package/tree-select/index.js +68 -22
  202. package/tree-select/vue.js +27 -3
  203. package/types/async-flowchart.type.d.ts +2 -14
  204. package/types/breadcrumb-item.type.d.ts +5 -1
  205. package/types/breadcrumb.type.d.ts +5 -1
  206. package/types/button-group.type.d.ts +5 -1
  207. package/types/button.type.d.ts +2 -2
  208. package/types/cascader.type.d.ts +6 -1
  209. package/types/date-table.type.d.ts +1 -120
  210. package/types/dropdown.type.d.ts +1 -1
  211. package/types/label.type.d.ts +1 -53
  212. package/types/loading.type.d.ts +12 -0
  213. package/types/numeric.type.d.ts +3 -22
  214. package/types/pager.type.d.ts +12 -7
  215. package/types/popconfirm.type.d.ts +2 -0
  216. package/types/steps.type.d.ts +1 -0
  217. package/types/tag-group.type.d.ts +2 -14
  218. package/types/tag.type.d.ts +4 -4
  219. package/types/tooltip.type.d.ts +3 -13
  220. package/types/transfer.type.d.ts +3 -0
  221. package/types/user-head.type.d.ts +0 -4
  222. package/upload/index.js +1 -1
  223. package/upload-list/index.js +1 -1
  224. package/upload-list/vue.js +4 -4
  225. package/user/index.js +7 -7
  226. package/user/vue.js +15 -2
  227. package/user-contact/vue.js +2 -2
  228. package/virtual-scroll-box/index.js +2 -2
  229. package/wizard/index.js +3 -3
  230. package/year-range/index.js +61 -11
  231. package/year-range/vue.js +33 -20
  232. package/year-table/index.js +10 -5
  233. package/avatar/index.js +0 -30
  234. package/avatar/vue.js +0 -22
  235. package/common/array.js +0 -115
  236. package/common/bigInt.js +0 -315
  237. package/common/browser.js +0 -81
  238. package/common/calendar/calendar.js +0 -97
  239. package/common/dataset/index.js +0 -99
  240. package/common/date.js +0 -354
  241. package/common/decimal.js +0 -155
  242. package/common/deps/ResizeObserver.js +0 -456
  243. package/common/deps/after-leave.js +0 -27
  244. package/common/deps/clickoutside.js +0 -75
  245. package/common/deps/date-util.js +0 -255
  246. package/common/deps/date.js +0 -286
  247. package/common/deps/debounce.js +0 -8
  248. package/common/deps/eSpaceCtrl.js +0 -304
  249. package/common/deps/fastdom/async.js +0 -41
  250. package/common/deps/fastdom/index.js +0 -9
  251. package/common/deps/fastdom/sandbox.js +0 -53
  252. package/common/deps/fastdom/singleton.js +0 -88
  253. package/common/deps/fullscreen/apis.js +0 -143
  254. package/common/deps/fullscreen/screenfull.js +0 -165
  255. package/common/deps/memorize.js +0 -124
  256. package/common/deps/observe-visibility.js +0 -106
  257. package/common/deps/popper.js +0 -616
  258. package/common/deps/repeat-click.js +0 -29
  259. package/common/deps/resize-event.js +0 -39
  260. package/common/deps/scroll-into-view.js +0 -29
  261. package/common/deps/scrollbar-width.js +0 -33
  262. package/common/deps/throttle.js +0 -45
  263. package/common/deps/touch-emulator.js +0 -103
  264. package/common/deps/touch.js +0 -37
  265. package/common/deps/tree-model/node.js +0 -475
  266. package/common/deps/tree-model/tree-store.js +0 -312
  267. package/common/deps/tree-model/util.js +0 -24
  268. package/common/deps/upload-ajax.js +0 -81
  269. package/common/deps/useEventListener.js +0 -54
  270. package/common/deps/useInstanceSlots.js +0 -22
  271. package/common/deps/useRect.js +0 -25
  272. package/common/deps/useRelation.js +0 -89
  273. package/common/deps/useTouch.js +0 -68
  274. package/common/deps/useUserAgent.js +0 -16
  275. package/common/deps/useWindowSize.js +0 -23
  276. package/common/deps/vue-emitter.js +0 -34
  277. package/common/deps/vue-popper.js +0 -180
  278. package/common/deps/vue-popup.js +0 -138
  279. package/common/event.js +0 -46
  280. package/common/form/const.js +0 -10
  281. package/common/function.js +0 -28
  282. package/common/global.js +0 -11
  283. package/common/index.js +0 -259
  284. package/common/object.js +0 -227
  285. package/common/prop-util.js +0 -43
  286. package/common/runtime.js +0 -79
  287. package/common/string.js +0 -417
  288. package/common/type.js +0 -66
  289. package/common/validate/index.js +0 -10
  290. package/common/validate/messages.js +0 -65
  291. package/common/validate/rules/enum.js +0 -12
  292. package/common/validate/rules/index.js +0 -18
  293. package/common/validate/rules/pattern.js +0 -20
  294. package/common/validate/rules/range.js +0 -52
  295. package/common/validate/rules/required.js +0 -11
  296. package/common/validate/rules/type.js +0 -100
  297. package/common/validate/rules/whitespace.js +0 -10
  298. package/common/validate/schema.js +0 -290
  299. package/common/validate/util.js +0 -211
  300. package/common/validate/validations/array.js +0 -22
  301. package/common/validate/validations/date.js +0 -31
  302. package/common/validate/validations/enum.js +0 -22
  303. package/common/validate/validations/float.js +0 -22
  304. package/common/validate/validations/index.js +0 -46
  305. package/common/validate/validations/integer.js +0 -22
  306. package/common/validate/validations/method.js +0 -21
  307. package/common/validate/validations/number.js +0 -25
  308. package/common/validate/validations/pattern.js +0 -21
  309. package/common/validate/validations/required.js +0 -11
  310. package/common/validate/validations/string.js +0 -33
  311. package/common/validate/validations/type.js +0 -29
  312. package/index-bar/index.js +0 -66
  313. package/index-bar/vue.js +0 -73
  314. package/index-bar-anchor/vue.js +0 -16
  315. package/label/index.js +0 -56
  316. package/label/vue.js +0 -26
  317. package/list/index.js +0 -13
  318. package/list/vue.js +0 -17
  319. package/mask/index.js +0 -13
  320. package/mask/vue.js +0 -18
  321. package/mini-picker/index.js +0 -165
  322. package/mini-picker/vue.js +0 -122
  323. package/multi-select/index.js +0 -394
  324. package/multi-select/vue.js +0 -113
  325. package/multi-select-item/index.js +0 -23
  326. package/multi-select-item/vue.js +0 -31
  327. package/toast/index.js +0 -7
  328. package/toast/vue.js +0 -19
  329. package/types/toast.type.d.ts +0 -63
  330. package/wheel/index.js +0 -165
  331. package/wheel/vue.js +0 -79
@@ -2,11 +2,11 @@ import {
2
2
  __spreadProps,
3
3
  __spreadValues
4
4
  } from "../chunk-G2ADBYYC.js";
5
- import { extend } from "../common/object";
6
- import { xss, log, crypt } from "@opentiny/utils";
7
- import uploadAjax from "../common/deps/upload-ajax";
8
- import { isObject } from "../common/type";
9
- import { isEmptyObject } from "../common/type";
5
+ import { extend } from "@opentiny/utils";
6
+ import { xss, logger, sha256 } from "@opentiny/utils";
7
+ import { uploadAjax } from "@opentiny/utils";
8
+ import { isObject } from "@opentiny/utils";
9
+ import { isEmptyObject } from "@opentiny/utils";
10
10
  let initTokenPromise = null;
11
11
  const noopFnCreator = (fn, propName) => {
12
12
  const noFn = () => {
@@ -276,7 +276,10 @@ const properFileSize = ({
276
276
  if (state.isEdm || Array.isArray(props.fileSize) && props.fileSize[1]) {
277
277
  if (!isNaN(Number(maxSize)) && file.size > maxSize * 1024 * 1024) {
278
278
  Modal.message({
279
- message: t(constants.EDM.EXCEED, { maxSize: api.formatFileSize(Number(maxSize * 1024 * 1024)) }),
279
+ message: t(constants.EDM.EXCEED, {
280
+ fileName: file.name,
281
+ maxSize: api.formatFileSize(Number(maxSize * 1024 * 1024))
282
+ }),
280
283
  status: "warning"
281
284
  });
282
285
  return false;
@@ -292,7 +295,7 @@ const properFileSize = ({
292
295
  const userMin = props.fileSize && (props.fileSize[0] || props.fileSize) || 0;
293
296
  if (file.size <= userMin * 1024) {
294
297
  Modal.message({
295
- message: `${t(constants.EDM.SIZE, { minSize: api.formatFileSize(Number(userMin), "K"), sizeUnit: "" })}`,
298
+ message: `${t(constants.EDM.SIZE, { fileName: file.name, minSize: api.formatFileSize(Number(userMin), "KB"), sizeUnit: "" })}`,
296
299
  status: "warning"
297
300
  });
298
301
  return false;
@@ -379,7 +382,7 @@ const getFileHash = ({
379
382
  reader.onload = async (e) => {
380
383
  if (file.status === constants.FILE_STATUS.FAIL)
381
384
  return;
382
- const hash = await crypt.sha256(e.target && e.target.result);
385
+ const hash = sha256(e.target && e.target.result);
383
386
  file.hash = file.raw.hash = hash;
384
387
  resolve(hash);
385
388
  emit("hash-progress", 100);
@@ -1303,14 +1306,14 @@ const afterDownload = ({ api, state }) => ({ batchIndex, range, data, file, isBa
1303
1306
  range.index,
1304
1307
  "]"
1305
1308
  ];
1306
- log.logger.warn(msgArray.join(""));
1309
+ logger.warn(msgArray.join(""));
1307
1310
  delete state.downloadReplayAtoms[key];
1308
1311
  } else {
1309
1312
  if (state.downloadReplayAtoms[key] === void 0) {
1310
1313
  state.downloadReplayAtoms[key] = 0;
1311
1314
  }
1312
1315
  const msgArray = ["replay ", countDownloadReplay, "! [docId:", file.docId, ", chunk:", range.index, "]"];
1313
- log.logger.warn(msgArray.join(""));
1316
+ logger.warn(msgArray.join(""));
1314
1317
  state.downloadReplayAtoms[key] += 1;
1315
1318
  api.downloadFileInner({ batchIndex, range, file, isBatch, isChunk, isLessThan17G });
1316
1319
  }
@@ -1502,14 +1505,14 @@ const afterUpload = ({
1502
1505
  file.chunk,
1503
1506
  "]"
1504
1507
  ];
1505
- log.logger.warn(msgArray.join(""));
1508
+ logger.warn(msgArray.join(""));
1506
1509
  delete state.replayAtoms[key];
1507
1510
  } else {
1508
1511
  if (state.replayAtoms[key] === void 0) {
1509
1512
  state.replayAtoms[key] = 0;
1510
1513
  }
1511
1514
  const msgArray = ["replay ", countReplay, "! [docId:", file.docId, ", chunk:", file.chunk, "]"];
1512
- log.logger.warn(msgArray.join(""));
1515
+ logger.warn(msgArray.join(""));
1513
1516
  state.replayAtoms[key] += 1;
1514
1517
  api.segmentUpload(batchIndex, file, progress);
1515
1518
  }
@@ -1590,7 +1593,7 @@ const segmentUpload = ({
1590
1593
  reader.readAsArrayBuffer(file2);
1591
1594
  reader.onload = async (e) => {
1592
1595
  if (props.edm.isCheckCode === true) {
1593
- const hash = await crypt.sha256(e.target && e.target.result);
1596
+ const hash = sha256(e.target && e.target.result);
1594
1597
  file2.hash = hash;
1595
1598
  }
1596
1599
  resolve(file2);
@@ -1,6 +1,6 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
2
  import { downloadFile as ordinaryDownload } from "../upload-list";
3
- import { formatFileSize } from "../common/string";
3
+ import { formatFileSize } from "@opentiny/utils";
4
4
  import {
5
5
  initService,
6
6
  getNewTabPreviewUrl,
@@ -76,7 +76,7 @@ import {
76
76
  closeRecordPanel,
77
77
  getTipMessage
78
78
  } from "./index";
79
- import { isEmptyObject } from "../common/type";
79
+ import { isEmptyObject } from "@opentiny/utils";
80
80
  const api = [
81
81
  "state",
82
82
  "getNewTabPreviewUrl",
package/filter/vue.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { on, off } from "../common/deps/dom";
2
+ import { on, off } from "@opentiny/utils";
3
3
  import {
4
4
  panelToggle,
5
5
  filterSelectOption,
@@ -1,6 +1,6 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
2
  import { doDestroy, show, hide, popoverShow, popoverHide, handleClear, handleDocumentClick, togglePanel } from "./index";
3
- import { on, off } from "../common/deps/dom";
3
+ import { on, off } from "@opentiny/utils";
4
4
  const api = ["state", "doDestroy", "show", "hide", "popoverShow", "popoverHide", "handleClear", "togglePanel"];
5
5
  const renderless = (props, { reactive, onMounted, onBeforeUnmount }, { vm, emit }) => {
6
6
  const state = reactive({
@@ -18,7 +18,6 @@ const renderless = (props, { reactive, onMounted, onBeforeUnmount }, { vm, emit
18
18
  doDestroy: doDestroy({ vm }),
19
19
  handleDocumentClick: handleDocumentClick({ vm, state })
20
20
  });
21
- handleDocumentClick;
22
21
  onMounted(() => {
23
22
  on(document, "click", api2.handleDocumentClick);
24
23
  });
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { off, on } from "../common/deps/dom";
2
+ import { off, on } from "@opentiny/utils";
3
3
  const getClientWidth = ({ state, vm }) => () => {
4
4
  if (vm.$refs.floatingButton) {
5
5
  state.centerSpace = (document.documentElement.clientWidth - vm.$refs.floatingButton.clientWidth) / 2;
@@ -2,9 +2,9 @@ import {
2
2
  __spreadProps,
3
3
  __spreadValues
4
4
  } from "../chunk-G2ADBYYC.js";
5
- import debounce from "../common/deps/debounce";
6
- import { omitText as omit } from "../common/string";
7
- import { fastdom } from "../common/deps/fastdom";
5
+ import { debounce } from "@opentiny/utils";
6
+ import { omitText as omit } from "@opentiny/utils";
7
+ import { fastdom } from "@opentiny/utils";
8
8
  const compute = ({ api, markRaw, props, state }) => () => {
9
9
  const { data, config } = props;
10
10
  const { nodes, links } = data;
package/flowchart/vue.js CHANGED
@@ -27,7 +27,7 @@ import {
27
27
  setAdjustY,
28
28
  runAdjustYTask
29
29
  } from "./index";
30
- import throttle from "../common/deps/throttle";
30
+ import { throttle } from "@opentiny/utils";
31
31
  const api = [
32
32
  "state",
33
33
  "clearHoverAfterLink",
@@ -1,10 +1,10 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { extend } from "../common/object";
3
- import { isNull } from "../common/type";
2
+ import { extend } from "@opentiny/utils";
3
+ import { isNull } from "@opentiny/utils";
4
4
  import { xss } from "@opentiny/utils";
5
5
  import { set } from "../chart-core/deps/utils";
6
- import { on, off } from "../common/deps/dom";
7
- import PopupManager from "../common/deps/popup-manager";
6
+ import { on, off } from "@opentiny/utils";
7
+ import { PopupManager } from "@opentiny/utils";
8
8
  const init = ({
9
9
  api,
10
10
  emit,
@@ -145,10 +145,8 @@ const handleCompositionend = ({ state }) => (event) => {
145
145
  let data = state.quill.container.innerHTML;
146
146
  let range = state.quill.getSelection(true);
147
147
  const [mentionItem, offset] = state.quill.getLeaf(range.index);
148
- if (mentionItem.statics.blotName === "break" || mentionItem.statics.blotName === "text" && offset === 0) {
149
- state.quill.clipboard.dangerouslyPasteHTML(data);
150
- }
151
148
  if (mentionItem.statics.blotName === "break") {
149
+ state.quill.clipboard.dangerouslyPasteHTML(data);
152
150
  state.quill.setSelection(range.index + event.data.length);
153
151
  } else {
154
152
  let pattern = /[\u4E00-\u9FA5\uF900-\uFA2D]/;
@@ -2,7 +2,7 @@ import {
2
2
  __spreadProps,
3
3
  __spreadValues
4
4
  } from "../chunk-G2ADBYYC.js";
5
- import { isNull } from "../common/type";
5
+ import { isNull } from "@opentiny/utils";
6
6
  const fontFamilyConfig = [
7
7
  "songti",
8
8
  "yahei",
@@ -123,7 +123,7 @@ const listAutofillHandler = ({ FluentEditor, state }) => (range, context) => {
123
123
  }
124
124
  state.quill.insertText(range.index, " ", FluentEditor.sources.USER);
125
125
  state.quill.history.cutoff();
126
- const delta = new FluentEditor.imports["delta"]().retain(range.index - offset).delete(length + 1).retain(line.length() - 2 - offset).retain(1, { list: { value } });
126
+ const delta = new FluentEditor.imports.delta().retain(range.index - offset).delete(length + 1).retain(line.length() - 2 - offset).retain(1, { list: { value } });
127
127
  state.quill.updateContents(delta, FluentEditor.sources.USER);
128
128
  state.quill.history.cutoff();
129
129
  state.quill.setSelection(range.index - length, FluentEditor.sources.SILENT);
package/form/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { merge } from "../common/object";
2
+ import { merge } from "@opentiny/utils";
3
3
  const watchRules = ({ api, props, state }) => (newRules = {}, oldRules = {}) => {
4
4
  const newValidFields = Object.keys(newRules);
5
5
  const oldValidFields = Object.keys(oldRules);
@@ -114,7 +114,9 @@ const validate = ({ props, state }) => (callback) => {
114
114
  Object.keys(field2).forEach((item) => invalidFieldArr.push(item));
115
115
  }
116
116
  if (typeof callback === "function" && ++count === state.fields.length) {
117
- callback(valid, invalidFields, invalidFieldArr);
117
+ const sortField = sortFields(state.fields, invalidFields);
118
+ const sortFieldArr = sortFields(state.fields, invalidFieldArr);
119
+ callback(valid, sortField, sortFieldArr);
118
120
  }
119
121
  });
120
122
  });
@@ -122,6 +124,22 @@ const validate = ({ props, state }) => (callback) => {
122
124
  return promise;
123
125
  }
124
126
  };
127
+ const sortFields = (fileds, val) => {
128
+ const arrField = fileds.map((item) => item.prop);
129
+ if (Object.prototype.toString.call(val) === "[object Object]") {
130
+ const keys = Object.keys(val);
131
+ const sortKeys = keys.sort((a, b) => arrField.indexOf(a) - arrField.indexOf(b));
132
+ const sortedObject = sortKeys.reduce((acc, key) => {
133
+ acc[key] = val[key];
134
+ return acc;
135
+ }, {});
136
+ return sortedObject;
137
+ }
138
+ if (Array.isArray(val)) {
139
+ val.sort((x, y) => arrField.indexOf(x) - arrField.indexOf(y));
140
+ return val;
141
+ }
142
+ };
125
143
  const validateField = (state) => (props, cb) => {
126
144
  props = [].concat(props);
127
145
  const fields = state.fields.filter((field) => props.includes(field.prop));
@@ -1,10 +1,10 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { POSITION, VALIDATE_STATE } from "../common";
3
- import { omitText } from "../common/string";
4
- import { merge } from "../common/object";
5
- import Validator from "../common/validate";
6
- import { isNull } from "../common/type";
7
- import debounce from "../common/deps/debounce";
2
+ import { POSITION, VALIDATE_STATE } from "@opentiny/utils";
3
+ import { omitText } from "@opentiny/utils";
4
+ import { merge } from "@opentiny/utils";
5
+ import { Validator } from "@opentiny/utils";
6
+ import { isNull } from "@opentiny/utils";
7
+ import { debounce } from "@opentiny/utils";
8
8
  const watchError = (state) => (value) => {
9
9
  if (!isNull(value) && state.getValidateType === "tip") {
10
10
  state.canShowTip = true;
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { on, off } from "../common/deps/dom";
2
+ import { on, off } from "@opentiny/utils";
3
3
  const toggle = ({ state, api }) => (value) => {
4
4
  if (value === void 0) {
5
5
  if (state.isFullscreen) {
package/fullscreen/vue.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import sf from "../common/deps/fullscreen/screenfull";
2
+ import { sf } from "@opentiny/utils";
3
3
  import {
4
4
  exit,
5
5
  enter,
@@ -2,7 +2,7 @@ import {
2
2
  __spreadValues
3
3
  } from "../../chunk-G2ADBYYC.js";
4
4
  import { xss } from "@opentiny/utils";
5
- import browser from "../../common/browser";
5
+ import { browserInfo } from "@opentiny/utils";
6
6
  import { toTreeArray } from "../static";
7
7
  import { getCellValue, getFuncText } from "../utils";
8
8
  import { exportExcel } from "./exportExcel";
@@ -39,6 +39,12 @@ const getCsvContent = ($table, opts, oColumns, oData) => {
39
39
  const { columns, datas } = getCsvData(opts, oData, oColumns, tableEl);
40
40
  let content = "\uFEFF";
41
41
  const transfrom = (str) => {
42
+ if (str === null || str === void 0) {
43
+ return "" + tab;
44
+ }
45
+ if (typeof str === "number" && isNaN(str)) {
46
+ return "-" + tab;
47
+ }
42
48
  if (typeof str === "string" && str.replace(/ /g, "").match(/[\s,"]/)) {
43
49
  str = '"' + str.replace(/"/g, '""') + '"';
44
50
  }
@@ -73,7 +79,7 @@ const getCsvContent = ($table, opts, oColumns, oData) => {
73
79
  return content;
74
80
  };
75
81
  const getCsvUrl = (opts, content) => {
76
- if (window.Blob && window.URL && window.URL.createObjectURL && browser.name !== "safari") {
82
+ if (window.Blob && window.URL && window.URL.createObjectURL && browserInfo.name !== "safari") {
77
83
  return URL.createObjectURL(new Blob([content], { type: "text/csv;charset=utf-8" }));
78
84
  }
79
85
  return `data:attachment/csv;charset=utf-8,${encodeURIComponent(content)}`;
@@ -1,7 +1,7 @@
1
1
  import "../../chunk-G2ADBYYC.js";
2
- import { extend } from "../../common/object";
3
- import browser from "../../common/browser";
4
- const isIE = browser.name === "ie";
2
+ import { extend } from "@opentiny/utils";
3
+ import { browserInfo } from "@opentiny/utils";
4
+ const isIE = browserInfo.name === "ie";
5
5
  const rgbRegExp = /^rgba?\((\d+),\s(\d+),\s(\d+)([\s\S]*)\)$/;
6
6
  const hexRegExp = /^#([a-zA-Z0-9]{3}|[a-zA-Z0-9]{6})$/;
7
7
  function computeColor(rgbColor) {
@@ -1,5 +1,5 @@
1
1
  import "../../chunk-G2ADBYYC.js";
2
- import browser from "../../common/browser";
2
+ import { browserInfo } from "@opentiny/utils";
3
3
  import { remove } from "../static";
4
4
  let resizeTimeout;
5
5
  let defaultInterval = 250;
@@ -58,7 +58,7 @@ class ResizeObserverPolyfill {
58
58
  remove(eventStore, (item) => item === this);
59
59
  }
60
60
  }
61
- const Resize = browser.isDoc ? window.ResizeObserver || ResizeObserverPolyfill : ResizeObserverPolyfill;
61
+ const Resize = browserInfo.isDoc ? window.ResizeObserver || ResizeObserverPolyfill : ResizeObserverPolyfill;
62
62
  var resize_default = Resize;
63
63
  export {
64
64
  resize_default as default
@@ -1,5 +1,5 @@
1
1
  import "../../../chunk-G2ADBYYC.js";
2
- import { isDate, isRegExp } from "../../../common/type";
2
+ import { isDate, isRegExp } from "@opentiny/utils";
3
3
  import isNumber from "./isNumber";
4
4
  import isString from "./isString";
5
5
  import isBoolean from "./isBoolean";
@@ -1,5 +1,5 @@
1
1
  import "../../../chunk-G2ADBYYC.js";
2
- import { isPlainObject } from "../../../common/type";
2
+ import { isPlainObject } from "@opentiny/utils";
3
3
  var isPlainObject_default = isPlainObject;
4
4
  export {
5
5
  isPlainObject_default as default
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  __spreadValues
3
3
  } from "../../chunk-G2ADBYYC.js";
4
- import { isNull } from "../../common/type";
5
- import { find } from "../../common/array";
4
+ import { isNull } from "@opentiny/utils";
5
+ import { find } from "@opentiny/utils";
6
6
  import { get, isFunction, set } from "../static";
7
7
  const gridSize = ["medium", "small", "mini"];
8
8
  const getSize = ({ size, $parent }) => size || ($parent && gridSize.includes($parent.size) ? $parent.size : null);
package/grid/utils/dom.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import "../../chunk-G2ADBYYC.js";
2
2
  import { getRowid } from "./common";
3
- import { hasClass, getDomNode } from "../../common/deps/dom";
4
- import { getActualTarget } from "../../common/event";
3
+ import { hasClass, getDomNode } from "@opentiny/utils";
4
+ import { getActualTarget } from "@opentiny/utils";
5
5
  import { arrayIndexOf } from "../static";
6
6
  const ATTR_NAME = "data-rowid";
7
7
  const CELL_CLS = ".tiny-grid-cell";
@@ -21,7 +21,16 @@ const rowToVisible = ($table, row) => {
21
21
  if (tableBodyVnode) {
22
22
  const gridbodyEl = tableBodyVnode.$el;
23
23
  const trEl = gridbodyEl.querySelector(`[${ATTR_NAME}="${getRowid($table, row)}"]`);
24
- if (trEl) {
24
+ if ($table.scrollYLoad) {
25
+ const isOutOfBody = () => {
26
+ const bodyRect = $table.$el.getBoundingClientRect();
27
+ const trRect = trEl.getBoundingClientRect();
28
+ return trRect.top + trRect.height / 2 > bodyRect.top + bodyRect.height;
29
+ };
30
+ if (!trEl || isOutOfBody()) {
31
+ gridbodyEl.scrollTop = ($table.afterFullData.indexOf(row) - 1) * $table.scrollYStore.rowHeight;
32
+ }
33
+ } else if (trEl) {
25
34
  const bodyHeight = gridbodyEl.clientHeight;
26
35
  const bodySrcollTop = gridbodyEl.scrollTop;
27
36
  const trOffsetTop = trEl.offsetTop + (trEl.offsetParent ? trEl.offsetParent.offsetTop : 0);
@@ -31,10 +40,6 @@ const rowToVisible = ($table, row) => {
31
40
  } else if (trOffsetTop + trHeight >= bodyHeight + bodySrcollTop) {
32
41
  gridbodyEl.scrollTop = bodySrcollTop + trHeight;
33
42
  }
34
- } else {
35
- if ($table.scrollYLoad) {
36
- gridbodyEl.scrollTop = ($table.afterFullData.indexOf(row) - 1) * $table.scrollYStore.rowHeight;
37
- }
38
43
  }
39
44
  }
40
45
  });
@@ -1,8 +1,8 @@
1
1
  import "../../chunk-G2ADBYYC.js";
2
- import browser from "../../common/browser";
2
+ import { browserInfo } from "@opentiny/utils";
3
3
  import { remove } from "../static";
4
- import { on } from "../../common/deps/dom";
5
- const wheelName = browser.isDoc && /Firefox/i.test(navigator.userAgent) ? "DOMMouseScroll" : "mousewheel";
4
+ import { on } from "@opentiny/utils";
5
+ const wheelName = browserInfo.isDoc && /Firefox/i.test(navigator.userAgent) ? "DOMMouseScroll" : "mousewheel";
6
6
  const eventStore = [];
7
7
  const invoke = ({ comp, type, cb }, event) => {
8
8
  if (type === event.type || type === "mousewheel" && event.type === wheelName) {
@@ -25,7 +25,7 @@ const GlobalEvent = {
25
25
  eventStore.filter((item) => item.capture).forEach((item) => invoke(item, event));
26
26
  }
27
27
  };
28
- if (browser.isDoc) {
28
+ if (browserInfo.isDoc) {
29
29
  on(document, "keydown", GlobalEvent.trigger);
30
30
  on(document, "contextmenu", GlobalEvent.trigger);
31
31
  on(window, "mousedown", GlobalEvent.trigger);
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { extend } from "../common/object";
2
+ import { extend } from "@opentiny/utils";
3
3
  const getHrList = ({ api, props, state }) => (deptCode) => {
4
4
  state.loading = true;
5
5
  const params = {
package/image/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { on, off, getScrollContainer, isInContainer } from "../common/deps/dom";
3
- import { typeOf } from "../common/type";
2
+ import { on, off, getScrollContainer, isInContainer } from "@opentiny/utils";
3
+ import { typeOf } from "@opentiny/utils";
4
4
  import { rafThrottle } from "../image-viewer";
5
5
  import { xss } from "@opentiny/utils";
6
6
  const isSupportObjectFit = () => document.documentElement.style.objectFit !== void 0;
@@ -112,7 +112,7 @@ const mounted = ({ props, api }) => () => {
112
112
  }
113
113
  };
114
114
  const filterImageUrl = (props) => () => {
115
- const isBase64 = /^data:image\/(png|jpg|jpeg|gif);base64,([a-zA-Z0-9+/]+={0,2})/;
115
+ const isBase64 = /^data:(image|application)\/(png|jpg|jpeg|gif|octet-stream|svg\+xml);base64,([a-zA-Z0-9+/]+={0,2})/;
116
116
  return isBase64.test(props.src) ? props.src : xss.filterUrl(props.src);
117
117
  };
118
118
  export {
@@ -1,13 +1,11 @@
1
1
  import {
2
2
  __spreadValues
3
3
  } from "../chunk-G2ADBYYC.js";
4
- import { on, off } from "../common/deps/dom";
5
- import { KEY_CODE } from "../common";
6
- import PopupManager from "../common/deps/popup-manager";
4
+ import { on, off } from "@opentiny/utils";
5
+ import { KEY_CODE } from "@opentiny/utils";
6
+ import { PopupManager } from "@opentiny/utils";
7
7
  import { xss } from "@opentiny/utils";
8
- import { isBrowser } from "../common/browser";
9
- const isFirefox = () => isBrowser ? !!window.navigator.userAgent.match(/firefox/i) : false;
10
- const mousewheelEventName = isFirefox() ? "DOMMouseScroll" : "mousewheel";
8
+ const mousewheelEventName = "mousewheel";
11
9
  const rafThrottle = (fn) => {
12
10
  let locked = false;
13
11
  return function(...args) {
@@ -210,7 +210,7 @@ const initWatch = ({ watch, state, api: api2, props, nextTick, vm }) => {
210
210
  () => {
211
211
  state.urlList = props.urlList;
212
212
  },
213
- { deep: true }
213
+ { deep: true, immediate: true }
214
214
  );
215
215
  };
216
216
  const renderless = (props, { computed, onMounted, onBeforeUnmount, onUpdated, reactive, watch, inject, provide }, { t, parent, nextTick, emit, constants, vm, mode }) => {
package/input/index.js CHANGED
@@ -1,5 +1,6 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { omitText } from "../common/string";
2
+ import { omitText } from "@opentiny/utils";
3
+ import { isServer } from "@opentiny/utils";
3
4
  const HIDDEN_STYLE = `
4
5
  height:0 !important;visibility:hidden !important;overflow:hidden !important;
5
6
  position:absolute !important;z-index:-1000 !important;top:0 !important;right:0 !important
@@ -30,7 +31,6 @@ const STYLE = {
30
31
  BorderTopWidth: "border-top-width",
31
32
  BorderBottomWidth: "border-bottom-width"
32
33
  };
33
- const isServer = typeof window === "undefined";
34
34
  const isKorean = (text) => /([(\uAC00-\uD7AF)|(\u3130-\u318F)])+/gi.test(text);
35
35
  const showBox = (state) => () => {
36
36
  if (state.inputDisabled) {
package/input/vue.js CHANGED
@@ -40,7 +40,7 @@ import {
40
40
  handleTextareaMouseUp
41
41
  } from "./index";
42
42
  import useStorageBox from "../tall-storage/vue-storage-box";
43
- import { on, off } from "../common/deps/dom";
43
+ import { on, off } from "@opentiny/utils";
44
44
  const api = [
45
45
  "blur",
46
46
  "showBox",
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { KEY_CODE, IPTHRESHOLD } from "../common";
2
+ import { KEY_CODE, IPTHRESHOLD } from "@opentiny/utils";
3
3
  const isIP6 = (str) => /^IPv6$/i.test(str);
4
4
  const isIP4 = (str) => /^IPv4$/i.test(str);
5
5
  const ipValidator = ({ props, api }) => (value) => {
@@ -53,29 +53,25 @@ const getValue = ({ api, props, state }) => () => {
53
53
  };
54
54
  const setValue = ({ api, props, state }) => (value) => {
55
55
  var _a;
56
- if (value) {
57
- if ((_a = api == null ? void 0 : api.ipValidator) == null ? void 0 : _a.call(api, value)) {
58
- if (api.isIP6(props.type)) {
59
- state.address = value.split(":").map((item) => ({ value: item }));
60
- if (state.address.length < 8) {
61
- let insertIndex = 0;
62
- state.address.forEach((item, index) => {
63
- if (item.value === "") {
64
- item.value = "0000";
65
- insertIndex = index;
66
- }
67
- });
68
- for (let i = 0; i <= 8 - state.address.length; i++) {
69
- state.address.splice(insertIndex, 0, { value: "0000" });
70
- }
71
- }
72
- } else {
73
- state.address = value.split(".").map((item) => ({ value: item }));
56
+ if (!value || !((_a = api == null ? void 0 : api.ipValidator) == null ? void 0 : _a.call(api, value))) {
57
+ const createValue = () => ({ value: "" });
58
+ state.address = api.isIP6(props.type) ? Array.from({ length: 8 }, createValue) : Array.from({ length: 4 }, createValue);
59
+ return;
60
+ }
61
+ if (api.isIP6(props.type)) {
62
+ state.address = value.split(":").map((item) => ({ value: item }));
63
+ if (state.address.length < 8) {
64
+ const missingCount = 8 - state.address.length;
65
+ const emptyIndex = state.address.findIndex((item) => item.value === "");
66
+ const insertIndex = emptyIndex >= 0 ? emptyIndex : 0;
67
+ if (emptyIndex >= 0) {
68
+ state.address[emptyIndex].value = "0000";
74
69
  }
70
+ const newItems = Array(missingCount).fill({ value: "0000" });
71
+ state.address.splice(insertIndex, 0, ...newItems);
75
72
  }
76
73
  } else {
77
- const createValue = () => ({ value: "" });
78
- state.address = api.isIP6(props.type) ? new Array(8).fill("").map(createValue) : new Array(4).fill("").map(createValue);
74
+ state.address = value.split(".").map((item) => ({ value: item }));
79
75
  }
80
76
  };
81
77
  const activeEvent = ({
package/ip-address/vue.js CHANGED
@@ -17,7 +17,7 @@ import {
17
17
  keyup,
18
18
  keydown
19
19
  } from "./index";
20
- import { KEY_CODE } from "../common";
20
+ import { KEY_CODE } from "@opentiny/utils";
21
21
  const api = ["state", "focus", "inputEvent", "blur", "keyup", "keydown", "change", "select"];
22
22
  const initState = ({
23
23
  reactive,
@@ -3,7 +3,7 @@ import {
3
3
  __spreadValues
4
4
  } from "../chunk-G2ADBYYC.js";
5
5
  import { mapTree } from "../grid/static";
6
- import { copyArray } from "../common/object";
6
+ import { copyArray } from "@opentiny/utils";
7
7
  const dialogTitle = ({ constants, props, t }) => () => props.title || t(constants.DIALOG_TITLE);
8
8
  const showDialog = (state) => () => state.boxVisibility = true;
9
9
  const hideDialog = ({ api, state, vm, props }) => () => {
package/link-menu/vue.js CHANGED
@@ -11,7 +11,7 @@ import {
11
11
  disabledTreeNode,
12
12
  initService
13
13
  } from "./index";
14
- import { copyArray } from "../common/object";
14
+ import { copyArray } from "@opentiny/utils";
15
15
  import { setMenuKey } from "../tree-menu";
16
16
  const api = [
17
17
  "state",
@@ -1,5 +1,5 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import { isDisplayNone } from "../common/deps/dom";
2
+ import { isDisplayNone } from "@opentiny/utils";
3
3
  const clickList = ({ emit, props }) => () => {
4
4
  const list = {
5
5
  id: props.id,
package/load-list/vue.js CHANGED
@@ -1,9 +1,9 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
2
  import { clickList, check, clickErrorText } from "./index";
3
- import { getScrollParent } from "../common/deps/dom";
4
- import { useRect } from "../common/deps/useRect";
5
- import { useEventListener } from "../common/deps/useEventListener";
6
- import debounce from "../common/deps/debounce";
3
+ import { getScrollParent } from "@opentiny/utils";
4
+ import { useRect } from "@opentiny/vue-hooks";
5
+ import { useEventListener } from "@opentiny/vue-hooks";
6
+ import { debounce } from "@opentiny/utils";
7
7
  const api = ["state", "clickList", "check", "clickErrorText"];
8
8
  const renderless = (props, {
9
9
  inject,
package/loading/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import "../chunk-G2ADBYYC.js";
2
- import afterLeave from "../common/deps/after-leave";
3
- import { removeClass } from "../common/deps/dom";
2
+ import { afterLeave } from "@opentiny/utils";
3
+ import { removeClass } from "@opentiny/utils";
4
4
  const handleAfterLeave = (emit) => () => {
5
5
  emit("after-leave");
6
6
  };