@silver-formily/element-plus 2.4.0 → 3.0.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 (180) hide show
  1. package/README.en-US.md +32 -32
  2. package/README.md +32 -32
  3. package/esm/__builtins__/configs/index.mjs.map +1 -1
  4. package/esm/__builtins__/index.mjs +18 -18
  5. package/esm/__builtins__/shared/loading.mjs.map +1 -1
  6. package/esm/__builtins__/shared/simple-version-compare.mjs.map +1 -1
  7. package/esm/__builtins__/shared/transform-component.d.ts +1 -1
  8. package/esm/__builtins__/shared/transform-component.mjs.map +1 -1
  9. package/esm/__builtins__/shared/use-enter-submit.mjs.map +1 -1
  10. package/esm/__builtins__/shared/utils.mjs +0 -2
  11. package/esm/__builtins__/shared/utils.mjs.map +1 -1
  12. package/esm/array-base/index.mjs +59 -63
  13. package/esm/array-base/index.mjs.map +1 -1
  14. package/esm/array-base/symbols.mjs +1 -1
  15. package/esm/array-base/symbols.mjs.map +1 -1
  16. package/esm/array-base/utils.mjs +31 -38
  17. package/esm/array-base/utils.mjs.map +1 -1
  18. package/esm/array-cards/index.mjs +33 -36
  19. package/esm/array-cards/index.mjs.map +1 -1
  20. package/esm/array-collapse/index.mjs +38 -43
  21. package/esm/array-collapse/index.mjs.map +1 -1
  22. package/esm/array-collapse/utils.mjs +2 -9
  23. package/esm/array-collapse/utils.mjs.map +1 -1
  24. package/esm/array-items/index.mjs +34 -38
  25. package/esm/array-items/index.mjs.map +1 -1
  26. package/esm/array-list-tabs/index.mjs +39 -41
  27. package/esm/array-list-tabs/index.mjs.map +1 -1
  28. package/esm/array-list-tabs/utils.mjs +5 -12
  29. package/esm/array-list-tabs/utils.mjs.map +1 -1
  30. package/esm/array-table/index.mjs +63 -68
  31. package/esm/array-table/index.mjs.map +1 -1
  32. package/esm/array-table/utils.mjs +11 -18
  33. package/esm/array-table/utils.mjs.map +1 -1
  34. package/esm/array-tabs/index.mjs +25 -29
  35. package/esm/array-tabs/index.mjs.map +1 -1
  36. package/esm/autocomplete/autocomplete.d.ts +16 -16
  37. package/esm/autocomplete/index.d.ts +8 -8
  38. package/esm/autocomplete/index.mjs +18 -24
  39. package/esm/autocomplete/index.mjs.map +1 -1
  40. package/esm/cascader/index.mjs +18 -22
  41. package/esm/cascader/index.mjs.map +1 -1
  42. package/esm/checkbox/index.d.ts +27 -27
  43. package/esm/checkbox/index.mjs +21 -30
  44. package/esm/checkbox/index.mjs.map +1 -1
  45. package/esm/color-picker/index.mjs +6 -9
  46. package/esm/color-picker/index.mjs.map +1 -1
  47. package/esm/color-picker-panel/index.mjs +6 -9
  48. package/esm/color-picker-panel/index.mjs.map +1 -1
  49. package/esm/date-picker/index.mjs +11 -14
  50. package/esm/date-picker/index.mjs.map +1 -1
  51. package/esm/date-picker/utils.mjs.map +1 -1
  52. package/esm/date-picker-panel/index.mjs +11 -14
  53. package/esm/date-picker-panel/index.mjs.map +1 -1
  54. package/esm/editable/editable.d.ts +12 -12
  55. package/esm/editable/index.d.ts +6 -6
  56. package/esm/editable/index.mjs +49 -58
  57. package/esm/editable/index.mjs.map +1 -1
  58. package/esm/env.d.d.ts +1 -0
  59. package/esm/form/form.mjs +10 -10
  60. package/esm/form/form.mjs.map +1 -1
  61. package/esm/form-button-group/index.mjs +14 -25
  62. package/esm/form-button-group/index.mjs.map +1 -1
  63. package/esm/form-button-group/utils.mjs +2 -9
  64. package/esm/form-button-group/utils.mjs.map +1 -1
  65. package/esm/form-collapse/index.mjs +19 -22
  66. package/esm/form-collapse/index.mjs.map +1 -1
  67. package/esm/form-collapse/utils.mjs +0 -2
  68. package/esm/form-collapse/utils.mjs.map +1 -1
  69. package/esm/form-dialog/index.mjs +63 -70
  70. package/esm/form-dialog/index.mjs.map +1 -1
  71. package/esm/form-drawer/index.mjs +62 -69
  72. package/esm/form-drawer/index.mjs.map +1 -1
  73. package/esm/form-grid/form-grid.d.ts +2 -2
  74. package/esm/form-grid/hooks.d.ts +1 -2
  75. package/esm/form-grid/hooks.mjs +4 -11
  76. package/esm/form-grid/hooks.mjs.map +1 -1
  77. package/esm/form-grid/index.mjs +39 -40
  78. package/esm/form-grid/index.mjs.map +1 -1
  79. package/esm/form-item/index.mjs +57 -65
  80. package/esm/form-item/index.mjs.map +1 -1
  81. package/esm/form-item/types.d.ts +8 -6
  82. package/esm/form-item/utils.mjs.map +1 -1
  83. package/esm/form-layout/form-layout.mjs +12 -16
  84. package/esm/form-layout/form-layout.mjs.map +1 -1
  85. package/esm/form-layout/utils.mjs +2 -2
  86. package/esm/form-layout/utils.mjs.map +1 -1
  87. package/esm/form-step/index.mjs +27 -30
  88. package/esm/form-step/index.mjs.map +1 -1
  89. package/esm/form-step/utils.mjs +0 -3
  90. package/esm/form-step/utils.mjs.map +1 -1
  91. package/esm/form-tab/hooks.d.ts +2 -1
  92. package/esm/form-tab/hooks.mjs +13 -20
  93. package/esm/form-tab/hooks.mjs.map +1 -1
  94. package/esm/form-tab/index.mjs +38 -41
  95. package/esm/form-tab/index.mjs.map +1 -1
  96. package/esm/form-tab/utils.mjs.map +1 -1
  97. package/esm/index.mjs +76 -76
  98. package/esm/input/index.mjs +26 -30
  99. package/esm/input/index.mjs.map +1 -1
  100. package/esm/input-number/index.d.ts +15 -15
  101. package/esm/input-number/index.mjs +8 -11
  102. package/esm/input-number/index.mjs.map +1 -1
  103. package/esm/input-tag/index.mjs +16 -20
  104. package/esm/input-tag/index.mjs.map +1 -1
  105. package/esm/mention/index.mjs +20 -24
  106. package/esm/mention/index.mjs.map +1 -1
  107. package/esm/pagination/components/jumper.mjs.map +1 -1
  108. package/esm/pagination/components/next.mjs.map +1 -1
  109. package/esm/pagination/components/pager.mjs.map +1 -1
  110. package/esm/pagination/components/prev.mjs.map +1 -1
  111. package/esm/pagination/components/total.mjs.map +1 -1
  112. package/esm/pagination/pagination.mjs +1 -1
  113. package/esm/pagination/pagination.mjs.map +1 -1
  114. package/esm/password/index.mjs.map +1 -1
  115. package/esm/preview-text/index.mjs +27 -40
  116. package/esm/preview-text/index.mjs.map +1 -1
  117. package/esm/preview-text/utils.mjs +1 -1
  118. package/esm/preview-text/utils.mjs.map +1 -1
  119. package/esm/query-form/default-components.mjs.map +1 -1
  120. package/esm/query-form/hooks.mjs.map +1 -1
  121. package/esm/query-form/index.d.ts +3 -3
  122. package/esm/query-form/index.mjs +55 -61
  123. package/esm/query-form/index.mjs.map +1 -1
  124. package/esm/query-form/query-form.d.ts +1 -1
  125. package/esm/query-form/types.d.ts +1 -1
  126. package/esm/query-form-item/index.mjs +37 -44
  127. package/esm/query-form-item/index.mjs.map +1 -1
  128. package/esm/radio/index.d.ts +18 -18
  129. package/esm/radio/index.mjs +30 -39
  130. package/esm/radio/index.mjs.map +1 -1
  131. package/esm/rate/index.mjs +10 -13
  132. package/esm/rate/index.mjs.map +1 -1
  133. package/esm/reset/index.mjs +2 -2
  134. package/esm/reset/index.mjs.map +1 -1
  135. package/esm/segmented/index.mjs +13 -17
  136. package/esm/segmented/index.mjs.map +1 -1
  137. package/esm/select/index.d.ts +16 -16
  138. package/esm/select/index.mjs +22 -26
  139. package/esm/select/index.mjs.map +1 -1
  140. package/esm/select-table/index.d.ts +6 -6
  141. package/esm/select-table/index.mjs +16 -21
  142. package/esm/select-table/index.mjs.map +1 -1
  143. package/esm/select-table/select-table.d.ts +2 -2
  144. package/esm/shared/overlay-elements.mjs.map +1 -1
  145. package/esm/slider/index.mjs +10 -13
  146. package/esm/slider/index.mjs.map +1 -1
  147. package/esm/styles/form-grid/index.css +1 -1
  148. package/esm/submit/index.mjs +3 -3
  149. package/esm/submit/index.mjs.map +1 -1
  150. package/esm/switch/index.d.ts +9 -9
  151. package/esm/switch/index.mjs.map +1 -1
  152. package/esm/time-picker/index.mjs +6 -9
  153. package/esm/time-picker/index.mjs.map +1 -1
  154. package/esm/time-select/index.d.ts +12 -12
  155. package/esm/time-select/index.mjs +6 -9
  156. package/esm/time-select/index.mjs.map +1 -1
  157. package/esm/transfer/index.d.ts +12 -12
  158. package/esm/transfer/index.mjs.map +1 -1
  159. package/esm/tree/index.mjs +29 -33
  160. package/esm/tree/index.mjs.map +1 -1
  161. package/esm/tree/utils.mjs +0 -2
  162. package/esm/tree/utils.mjs.map +1 -1
  163. package/esm/tree-select/index.mjs +14 -18
  164. package/esm/tree-select/index.mjs.map +1 -1
  165. package/esm/upload/index.d.ts +12 -12
  166. package/esm/upload/index.mjs +10 -13
  167. package/esm/upload/index.mjs.map +1 -1
  168. package/esm/upload/upload.d.ts +24 -24
  169. package/esm/vendor/icon.mjs.map +1 -1
  170. package/esm/vendor/lodash.mjs +111 -85
  171. package/esm/vendor/lodash.mjs.map +1 -1
  172. package/esm/vendor/runtime.mjs +23 -29
  173. package/esm/vendor/runtime.mjs.map +1 -1
  174. package/esm/vendor/shared.esm-bundler.mjs +2 -7
  175. package/esm/vendor/shared.esm-bundler.mjs.map +1 -1
  176. package/esm/vendor/sizes.mjs.map +1 -1
  177. package/esm/vendor/types.mjs +5 -5
  178. package/esm/vendor/types.mjs.map +1 -1
  179. package/package.json +56 -82
  180. package/LICENSE +0 -21
package/README.en-US.md CHANGED
@@ -1,32 +1,32 @@
1
- # Silver Formily Element Plus
2
-
3
- [![codecov](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus/graph/badge.svg?token=LZF15NPLJU)](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus)
4
-
5
- English | [简体中文](README.md)
6
-
7
- Formily bindings for Element Plus, focused on consistent UI behavior, flexible configuration, and richer form scenarios.
8
-
9
- ## Documentation
10
-
11
- https://element-plus.silver-formily.org/
12
-
13
- ## Features
14
-
15
- - 💡 Unified component style
16
- - 🔌 Flexible dependencies (Formily + Element Plus as peerDependencies)
17
- - 🔑 Complete form components plus scenario components
18
- - ♿️ Better accessibility with enhanced FormItem
19
- - ✅ Comprehensive testing for new components
20
- - 📝 Vue template syntax based for readability and performance
21
-
22
- ## Installation
23
-
24
- ```bash
25
- pnpm add @silver-formily/element-plus
26
- ```
27
-
28
- This package relies on peer dependencies such as Formily, Element Plus, Vue, and @silver-formily/vue. Refer to the documentation or package.json for compatible versions and setup details.
29
-
30
- ## License
31
-
32
- MIT
1
+ # Silver Formily Element Plus
2
+
3
+ [![codecov](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus/graph/badge.svg?token=LZF15NPLJU)](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus)
4
+
5
+ English | [简体中文](README.md)
6
+
7
+ Formily bindings for Element Plus, focused on consistent UI behavior, flexible configuration, and richer form scenarios.
8
+
9
+ ## Documentation
10
+
11
+ https://element-plus.silver-formily.org/
12
+
13
+ ## Features
14
+
15
+ - 💡 Unified component style
16
+ - 🔌 Flexible dependencies (Formily + Element Plus as peerDependencies)
17
+ - 🔑 Complete form components plus scenario components
18
+ - ♿️ Better accessibility with enhanced FormItem
19
+ - ✅ Comprehensive testing for new components
20
+ - 📝 Vue template syntax based for readability and performance
21
+
22
+ ## Installation
23
+
24
+ ```bash
25
+ pnpm add @silver-formily/element-plus
26
+ ```
27
+
28
+ This package relies on peer dependencies such as Formily, Element Plus, Vue, and @silver-formily/vue. Refer to the documentation or package.json for compatible versions and setup details.
29
+
30
+ ## License
31
+
32
+ MIT
package/README.md CHANGED
@@ -1,32 +1,32 @@
1
- # Silver Formily Element Plus
2
-
3
- [![codecov](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus/graph/badge.svg?token=LZF15NPLJU)](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus)
4
-
5
- 简体中文 | [English](README.en-US.md)
6
-
7
- 基于 Element Plus 的 Formily 组件库封装,提供一致的组件风格、灵活的配置能力以及更丰富的表单场景。
8
-
9
- ## 文档
10
-
11
- https://element-plus.silver-formily.org/
12
-
13
- ## 特性
14
-
15
- - 💡 统一的组件风格
16
- - 🔌 灵活的依赖策略(Formily 与 Element Plus 作为 peerDependencies)
17
- - 🔑 完整的表单组件与扩展场景组件
18
- - ♿️ 更好的无障碍支持与 FormItem 体验
19
- - ✅ 新组件具备完善测试保障
20
- - 📝 基于 Vue 模板语法,易读且性能友好
21
-
22
- ## 安装
23
-
24
- ```bash
25
- pnpm add @silver-formily/element-plus
26
- ```
27
-
28
- 本包依赖 Formily、Element Plus、Vue、@silver-formily/vue 等 peerDependencies。请查看文档或 package.json 获取兼容版本与配置说明。
29
-
30
- ## 开源协议
31
-
32
- MIT
1
+ # Silver Formily Element Plus
2
+
3
+ [![codecov](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus/graph/badge.svg?token=LZF15NPLJU)](https://codecov.io/gh/hezhengxu2018/silver-formily-element-plus)
4
+
5
+ 简体中文 | [English](README.en-US.md)
6
+
7
+ 基于 Element Plus 的 Formily 组件库封装,提供一致的组件风格、灵活的配置能力以及更丰富的表单场景。
8
+
9
+ ## 文档
10
+
11
+ https://element-plus.silver-formily.org/
12
+
13
+ ## 特性
14
+
15
+ - 💡 统一的组件风格
16
+ - 🔌 灵活的依赖策略(Formily 与 Element Plus 作为 peerDependencies)
17
+ - 🔑 完整的表单组件与扩展场景组件
18
+ - ♿️ 更好的无障碍支持与 FormItem 体验
19
+ - ✅ 新组件具备完善测试保障
20
+ - 📝 基于 Vue 模板语法,易读且性能友好
21
+
22
+ ## 安装
23
+
24
+ ```bash
25
+ pnpm add @silver-formily/element-plus
26
+ ```
27
+
28
+ 本包依赖 Formily、Element Plus、Vue、@silver-formily/vue 等 peerDependencies。请查看文档或 package.json 获取兼容版本与配置说明。
29
+
30
+ ## 开源协议
31
+
32
+ MIT
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../src/__builtins__/configs/index.ts"],"sourcesContent":["export const stylePrefix = 'formily-element-plus'\n"],"names":["stylePrefix"],"mappings":"AAAO,MAAMA,IAAc;"}
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/__builtins__/configs/index.ts"],"sourcesContent":["export const stylePrefix = 'formily-element-plus'\r\n"],"names":["stylePrefix"],"mappings":"AAAO,MAAMA,IAAc;"}
@@ -1,23 +1,23 @@
1
1
  import { stylePrefix as r } from "./configs/index.mjs";
2
- import { loadElConfigProvider as i } from "./shared/load-config-provider.mjs";
3
- import { getTransitionDuration as p, loading as m, useDebonceSubmitting as s } from "./shared/loading.mjs";
4
- import { lt as l, quickVersionCompare as f } from "./shared/simple-version-compare.mjs";
5
- import { mapReadPretty as d } from "./shared/transform-component.mjs";
6
- import { compatibleUnderlineProp as c, composeExport as g, hasSlotContent as C, isVnodeEmpty as P, isVueOptions as b, useCleanAttrs as y } from "./shared/utils.mjs";
2
+ import { compatibleUnderlineProp as i, composeExport as n, hasSlotContent as p, isVnodeEmpty as m, isVueOptions as s, useCleanAttrs as a } from "./shared/utils.mjs";
3
+ import { getTransitionDuration as f, loading as x, useDebonceSubmitting as d } from "./shared/loading.mjs";
4
+ import { loadElConfigProvider as c } from "./shared/load-config-provider.mjs";
5
+ import { lt as C, quickVersionCompare as P } from "./shared/simple-version-compare.mjs";
6
+ import { mapReadPretty as y } from "./shared/transform-component.mjs";
7
7
  export {
8
- c as compatibleUnderlineProp,
9
- g as composeExport,
10
- p as getTransitionDuration,
11
- C as hasSlotContent,
12
- P as isVnodeEmpty,
13
- b as isVueOptions,
14
- i as loadElConfigProvider,
15
- m as loading,
16
- l as lt,
17
- d as mapReadPretty,
18
- f as quickVersionCompare,
8
+ i as compatibleUnderlineProp,
9
+ n as composeExport,
10
+ f as getTransitionDuration,
11
+ p as hasSlotContent,
12
+ m as isVnodeEmpty,
13
+ s as isVueOptions,
14
+ c as loadElConfigProvider,
15
+ x as loading,
16
+ C as lt,
17
+ y as mapReadPretty,
18
+ P as quickVersionCompare,
19
19
  r as stylePrefix,
20
- y as useCleanAttrs,
21
- s as useDebonceSubmitting
20
+ a as useCleanAttrs,
21
+ d as useDebonceSubmitting
22
22
  };
23
23
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"loading.mjs","sources":["../../../src/__builtins__/shared/loading.ts"],"sourcesContent":["import type { Form } from '@formily/core'\nimport { reaction } from '@formily/reactive'\nimport { useDebounceFn } from '@vueuse/core'\nimport { ElLoading } from 'element-plus'\nimport { ref } from 'vue'\n\nexport async function loading(loadingText = 'Loading...', processor: () => Promise<any>) {\n let loadingInstance\n const loading = setTimeout(() => {\n loadingInstance = ElLoading.service({\n text: loadingText,\n background: 'transparent',\n })\n }, 100)\n try {\n return await processor()\n }\n finally {\n loadingInstance?.close()\n clearTimeout(loading)\n }\n}\n\n/**\n * 获取当前element-plus的过渡时长并转换为毫秒\n * @param cssVarName CSS 变量名,默认为 '--el-transition-duration'\n * @param defaultValue 默认值(毫秒),默认为 200\n * @returns 过渡时长(毫秒)\n */\nexport function getTransitionDuration(cssVarName = '--el-transition-duration', defaultValue = 200): number {\n const cssVar = getComputedStyle(document.documentElement)\n .getPropertyValue(cssVarName)\n .trim()\n if (!cssVar) {\n return defaultValue\n }\n const durationMatch = cssVar.match(/^([\\d.]+)\\s*(s|ms)?$/)\n if (!durationMatch) {\n return defaultValue\n }\n\n const value = Number.parseFloat(durationMatch[1])\n const unit = durationMatch[2] || 'ms'\n\n switch (unit) {\n case 's': {\n return value * 1000\n }\n case 'ms': {\n return value\n }\n }\n}\n\nexport function useDebonceSubmitting(form: Form) {\n const internalSubmitting = ref(false)\n const transitionDuration = getTransitionDuration()\n\n const setSubmittingFalse = useDebounceFn(() => {\n internalSubmitting.value = false\n }, () => transitionDuration)\n\n reaction(() => form.submitting, (val) => {\n if (val === false) {\n setSubmittingFalse()\n }\n else {\n internalSubmitting.value = val\n }\n })\n\n return {\n internalSubmitting,\n }\n}\n"],"names":["loading","loadingText","processor","loadingInstance","ElLoading","getTransitionDuration","cssVarName","defaultValue","cssVar","durationMatch","value","useDebonceSubmitting","form","internalSubmitting","ref","transitionDuration","setSubmittingFalse","useDebounceFn","reaction","val"],"mappings":";;;;AAMA,eAAsBA,EAAQC,IAAc,cAAcC,GAA+B;AACvF,MAAIC;AACJ,QAAMH,IAAU,WAAW,MAAM;AAC/B,IAAAG,IAAkBC,EAAU,QAAQ;AAAA,MAClC,MAAMH;AAAA,MACN,YAAY;AAAA,IAAA,CACb;AAAA,EACH,GAAG,GAAG;AACN,MAAI;AACF,WAAO,MAAMC,EAAA;AAAA,EACf,UAAA;AAEE,IAAAC,GAAiB,MAAA,GACjB,aAAaH,CAAO;AAAA,EACtB;AACF;AAQO,SAASK,EAAsBC,IAAa,4BAA4BC,IAAe,KAAa;AACzG,QAAMC,IAAS,iBAAiB,SAAS,eAAe,EACrD,iBAAiBF,CAAU,EAC3B,KAAA;AACH,MAAI,CAACE;AACH,WAAOD;AAET,QAAME,IAAgBD,EAAO,MAAM,sBAAsB;AACzD,MAAI,CAACC;AACH,WAAOF;AAGT,QAAMG,IAAQ,OAAO,WAAWD,EAAc,CAAC,CAAC;AAGhD,UAFaA,EAAc,CAAC,KAAK,MAEzB;AAAA,IACN,KAAK;AACH,aAAOC,IAAQ;AAAA,IAEjB,KAAK;AACH,aAAOA;AAAA,EACT;AAEJ;AAEO,SAASC,EAAqBC,GAAY;AAC/C,QAAMC,IAAqBC,EAAI,EAAK,GAC9BC,IAAqBV,EAAA,GAErBW,IAAqBC,EAAc,MAAM;AAC7C,IAAAJ,EAAmB,QAAQ;AAAA,EAC7B,GAAG,MAAME,CAAkB;AAE3B,SAAAG,EAAS,MAAMN,EAAK,YAAY,CAACO,MAAQ;AACvC,IAAIA,MAAQ,KACVH,EAAA,IAGAH,EAAmB,QAAQM;AAAA,EAE/B,CAAC,GAEM;AAAA,IACL,oBAAAN;AAAA,EAAA;AAEJ;"}
1
+ {"version":3,"file":"loading.mjs","sources":["../../../src/__builtins__/shared/loading.ts"],"sourcesContent":["import type { Form } from '@formily/core'\r\nimport { reaction } from '@formily/reactive'\r\nimport { useDebounceFn } from '@vueuse/core'\r\nimport { ElLoading } from 'element-plus'\r\nimport { ref } from 'vue'\r\n\r\nexport async function loading(loadingText = 'Loading...', processor: () => Promise<any>) {\r\n let loadingInstance\r\n const loading = setTimeout(() => {\r\n loadingInstance = ElLoading.service({\r\n text: loadingText,\r\n background: 'transparent',\r\n })\r\n }, 100)\r\n try {\r\n return await processor()\r\n }\r\n finally {\r\n loadingInstance?.close()\r\n clearTimeout(loading)\r\n }\r\n}\r\n\r\n/**\r\n * 获取当前element-plus的过渡时长并转换为毫秒\r\n * @param cssVarName CSS 变量名,默认为 '--el-transition-duration'\r\n * @param defaultValue 默认值(毫秒),默认为 200\r\n * @returns 过渡时长(毫秒)\r\n */\r\nexport function getTransitionDuration(cssVarName = '--el-transition-duration', defaultValue = 200): number {\r\n const cssVar = getComputedStyle(document.documentElement)\r\n .getPropertyValue(cssVarName)\r\n .trim()\r\n if (!cssVar) {\r\n return defaultValue\r\n }\r\n const durationMatch = cssVar.match(/^([\\d.]+)\\s*(s|ms)?$/)\r\n if (!durationMatch) {\r\n return defaultValue\r\n }\r\n\r\n const value = Number.parseFloat(durationMatch[1])\r\n const unit = durationMatch[2] || 'ms'\r\n\r\n switch (unit) {\r\n case 's': {\r\n return value * 1000\r\n }\r\n case 'ms': {\r\n return value\r\n }\r\n }\r\n}\r\n\r\nexport function useDebonceSubmitting(form: Form) {\r\n const internalSubmitting = ref(false)\r\n const transitionDuration = getTransitionDuration()\r\n\r\n const setSubmittingFalse = useDebounceFn(() => {\r\n internalSubmitting.value = false\r\n }, () => transitionDuration)\r\n\r\n reaction(() => form.submitting, (val) => {\r\n if (val === false) {\r\n setSubmittingFalse()\r\n }\r\n else {\r\n internalSubmitting.value = val\r\n }\r\n })\r\n\r\n return {\r\n internalSubmitting,\r\n }\r\n}\r\n"],"names":["loading","loadingText","processor","loadingInstance","ElLoading","getTransitionDuration","cssVarName","defaultValue","cssVar","durationMatch","value","useDebonceSubmitting","form","internalSubmitting","ref","transitionDuration","setSubmittingFalse","useDebounceFn","reaction","val"],"mappings":";;;;AAMA,eAAsBA,EAAQC,IAAc,cAAcC,GAA+B;AACvF,MAAIC;AACJ,QAAMH,IAAU,WAAW,MAAM;AAC/B,IAAAG,IAAkBC,EAAU,QAAQ;AAAA,MAClC,MAAMH;AAAA,MACN,YAAY;AAAA,IAAA,CACb;AAAA,EACH,GAAG,GAAG;AACN,MAAI;AACF,WAAO,MAAMC,EAAA;AAAA,EACf,UAAA;AAEE,IAAAC,GAAiB,MAAA,GACjB,aAAaH,CAAO;AAAA,EACtB;AACF;AAQO,SAASK,EAAsBC,IAAa,4BAA4BC,IAAe,KAAa;AACzG,QAAMC,IAAS,iBAAiB,SAAS,eAAe,EACrD,iBAAiBF,CAAU,EAC3B,KAAA;AACH,MAAI,CAACE;AACH,WAAOD;AAET,QAAME,IAAgBD,EAAO,MAAM,sBAAsB;AACzD,MAAI,CAACC;AACH,WAAOF;AAGT,QAAMG,IAAQ,OAAO,WAAWD,EAAc,CAAC,CAAC;AAGhD,UAFaA,EAAc,CAAC,KAAK,MAEzB;AAAA,IACN,KAAK;AACH,aAAOC,IAAQ;AAAA,IAEjB,KAAK;AACH,aAAOA;AAAA,EACT;AAEJ;AAEO,SAASC,EAAqBC,GAAY;AAC/C,QAAMC,IAAqBC,EAAI,EAAK,GAC9BC,IAAqBV,EAAA,GAErBW,IAAqBC,EAAc,MAAM;AAC7C,IAAAJ,EAAmB,QAAQ;AAAA,EAC7B,GAAG,MAAME,CAAkB;AAE3B,SAAAG,EAAS,MAAMN,EAAK,YAAY,CAACO,MAAQ;AACvC,IAAIA,MAAQ,KACVH,EAAA,IAGAH,EAAmB,QAAQM;AAAA,EAE/B,CAAC,GAEM;AAAA,IACL,oBAAAN;AAAA,EAAA;AAEJ;"}
@@ -1 +1 @@
1
- {"version":3,"file":"simple-version-compare.mjs","sources":["../../../src/__builtins__/shared/simple-version-compare.ts"],"sourcesContent":["function normalizeVersion(v: string) {\n return v.split('.').map((n) => {\n const num = Number.parseInt(n, 10)\n return Number.isNaN(num) ? '0'.padStart(10, '0') : num.toString().padStart(10, '0')\n }).join('.')\n}\n\nexport function quickVersionCompare(v1: string, v2: string): number {\n const nv1 = normalizeVersion(v1)\n const nv2 = normalizeVersion(v2)\n return nv1 > nv2 ? 1 : (nv1 < nv2 ? -1 : 0)\n}\n\nexport function lt(v1: string, v2: string): boolean {\n return quickVersionCompare(v1, v2) < 0\n}\n"],"names":["normalizeVersion","v","n","num","quickVersionCompare","v1","v2","nv1","nv2","lt"],"mappings":"AAAA,SAASA,EAAiBC,GAAW;AACnC,SAAOA,EAAE,MAAM,GAAG,EAAE,IAAI,CAACC,MAAM;AAC7B,UAAMC,IAAM,OAAO,SAASD,GAAG,EAAE;AACjC,WAAO,OAAO,MAAMC,CAAG,IAAI,IAAI,SAAS,IAAI,GAAG,IAAIA,EAAI,SAAA,EAAW,SAAS,IAAI,GAAG;AAAA,EACpF,CAAC,EAAE,KAAK,GAAG;AACb;AAEO,SAASC,EAAoBC,GAAYC,GAAoB;AAClE,QAAMC,IAAMP,EAAiBK,CAAE,GACzBG,IAAMR,EAAiBM,CAAE;AAC/B,SAAOC,IAAMC,IAAM,IAAKD,IAAMC,IAAM,KAAK;AAC3C;AAEO,SAASC,EAAGJ,GAAYC,GAAqB;AAClD,SAAOF,EAAoBC,GAAIC,CAAE,IAAI;AACvC;"}
1
+ {"version":3,"file":"simple-version-compare.mjs","sources":["../../../src/__builtins__/shared/simple-version-compare.ts"],"sourcesContent":["function normalizeVersion(v: string) {\r\n return v.split('.').map((n) => {\r\n const num = Number.parseInt(n, 10)\r\n return Number.isNaN(num) ? '0'.padStart(10, '0') : num.toString().padStart(10, '0')\r\n }).join('.')\r\n}\r\n\r\nexport function quickVersionCompare(v1: string, v2: string): number {\r\n const nv1 = normalizeVersion(v1)\r\n const nv2 = normalizeVersion(v2)\r\n return nv1 > nv2 ? 1 : (nv1 < nv2 ? -1 : 0)\r\n}\r\n\r\nexport function lt(v1: string, v2: string): boolean {\r\n return quickVersionCompare(v1, v2) < 0\r\n}\r\n"],"names":["normalizeVersion","v","n","num","quickVersionCompare","v1","v2","nv1","nv2","lt"],"mappings":"AAAA,SAASA,EAAiBC,GAAW;AACnC,SAAOA,EAAE,MAAM,GAAG,EAAE,IAAI,CAACC,MAAM;AAC7B,UAAMC,IAAM,OAAO,SAASD,GAAG,EAAE;AACjC,WAAO,OAAO,MAAMC,CAAG,IAAI,IAAI,SAAS,IAAI,GAAG,IAAIA,EAAI,SAAA,EAAW,SAAS,IAAI,GAAG;AAAA,EACpF,CAAC,EAAE,KAAK,GAAG;AACb;AAEO,SAASC,EAAoBC,GAAYC,GAAoB;AAClE,QAAMC,IAAMP,EAAiBK,CAAE,GACzBG,IAAMR,EAAiBM,CAAE;AAC/B,SAAOC,IAAMC,IAAM,IAAKD,IAAMC,IAAM,KAAK;AAC3C;AAEO,SAASC,EAAGJ,GAAYC,GAAqB;AAClD,SAAOF,EAAoBC,GAAIC,CAAE,IAAI;AACvC;"}
@@ -1,3 +1,3 @@
1
- import { IComponentMapper } from '@silver-formily/vue';
1
+ import { IComponentMapper } from '../../../../vue/src';
2
2
  import { Component } from 'vue';
3
3
  export declare function mapReadPretty(component: Component, readPrettyProps?: Record<string, any>): IComponentMapper;
@@ -1 +1 @@
1
- {"version":3,"file":"transform-component.mjs","sources":["../../../src/__builtins__/shared/transform-component.ts"],"sourcesContent":["import type { IComponentMapper } from '@silver-formily/vue'\nimport type { Component } from 'vue'\nimport { isVoidField } from '@formily/core'\nimport { observer } from '@silver-formily/reactive-vue'\nimport { useField } from '@silver-formily/vue'\nimport { defineComponent, h } from 'vue'\n\n// fork from https://github.com/alibaba/formily/blob/7c64c671252adf85471ac5aabfddbaf4fc537354/packages/vue/src/shared/connect.ts#L65\nexport function mapReadPretty(\n component: Component,\n readPrettyProps?: Record<string, any>,\n): IComponentMapper {\n const mapper = (target: Component) => {\n return observer(\n defineComponent({\n name: target.name ? `Read${target.name}` : `ReadComponent`,\n setup(props, { attrs, slots, listeners }: Record<string, any>) {\n const fieldRef = useField()\n return () => {\n const field = fieldRef.value\n const isEditableReadPretty = !!field?.data?.readPretty\n return h(\n field && !isVoidField(field) && (field.pattern === 'readPretty' || isEditableReadPretty)\n ? component\n : target,\n {\n attrs: {\n ...readPrettyProps,\n ...attrs,\n },\n on: listeners,\n },\n slots,\n )\n }\n },\n }),\n )\n }\n\n return mapper as unknown as IComponentMapper\n}\n"],"names":["mapReadPretty","component","readPrettyProps","target","observer","defineComponent","props","attrs","slots","listeners","fieldRef","useField","field","isEditableReadPretty","h","isVoidField"],"mappings":";;;;AAQO,SAASA,EACdC,GACAC,GACkB;AA6BlB,SA5Be,CAACC,MACPC;AAAA,IACLC,EAAgB;AAAA,MACd,MAAMF,EAAO,OAAO,OAAOA,EAAO,IAAI,KAAK;AAAA,MAC3C,MAAMG,GAAO,EAAE,OAAAC,GAAO,OAAAC,GAAO,WAAAC,KAAkC;AAC7D,cAAMC,IAAWC,EAAA;AACjB,eAAO,MAAM;AACX,gBAAMC,IAAQF,EAAS,OACjBG,IAAuB,CAAC,CAACD,GAAO,MAAM;AAC5C,iBAAOE;AAAA,YACLF,KAAS,CAACG,EAAYH,CAAK,MAAMA,EAAM,YAAY,gBAAgBC,KAC/DZ,IACAE;AAAA,YACJ;AAAA,cACE,OAAO;AAAA,gBACL,GAAGD;AAAA,gBACH,GAAGK;AAAA,cAAA;AAAA,cAEL,IAAIE;AAAA,YAAA;AAAA,YAEND;AAAA,UAAA;AAAA,QAEJ;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EAAA;AAKP;"}
1
+ {"version":3,"file":"transform-component.mjs","sources":["../../../src/__builtins__/shared/transform-component.ts"],"sourcesContent":["import type { IComponentMapper } from '@silver-formily/vue'\r\nimport type { Component } from 'vue'\r\nimport { isVoidField } from '@formily/core'\r\nimport { observer } from '@silver-formily/reactive-vue'\r\nimport { useField } from '@silver-formily/vue'\r\nimport { defineComponent, h } from 'vue'\r\n\r\n// fork from https://github.com/alibaba/formily/blob/7c64c671252adf85471ac5aabfddbaf4fc537354/packages/vue/src/shared/connect.ts#L65\r\nexport function mapReadPretty(\r\n component: Component,\r\n readPrettyProps?: Record<string, any>,\r\n): IComponentMapper {\r\n const mapper = (target: Component) => {\r\n return observer(\r\n defineComponent({\r\n name: target.name ? `Read${target.name}` : `ReadComponent`,\r\n setup(props, { attrs, slots, listeners }: Record<string, any>) {\r\n const fieldRef = useField()\r\n return () => {\r\n const field = fieldRef.value\r\n const isEditableReadPretty = !!field?.data?.readPretty\r\n return h(\r\n field && !isVoidField(field) && (field.pattern === 'readPretty' || isEditableReadPretty)\r\n ? component\r\n : target,\r\n {\r\n attrs: {\r\n ...readPrettyProps,\r\n ...attrs,\r\n },\r\n on: listeners,\r\n },\r\n slots,\r\n )\r\n }\r\n },\r\n }),\r\n )\r\n }\r\n\r\n return mapper as unknown as IComponentMapper\r\n}\r\n"],"names":["mapReadPretty","component","readPrettyProps","target","observer","defineComponent","props","attrs","slots","listeners","fieldRef","useField","field","isEditableReadPretty","h","isVoidField"],"mappings":";;;;AAQO,SAASA,EACdC,GACAC,GACkB;AA6BlB,SA5Be,CAACC,MACPC;AAAA,IACLC,EAAgB;AAAA,MACd,MAAMF,EAAO,OAAO,OAAOA,EAAO,IAAI,KAAK;AAAA,MAC3C,MAAMG,GAAO,EAAE,OAAAC,GAAO,OAAAC,GAAO,WAAAC,KAAkC;AAC7D,cAAMC,IAAWC,EAAA;AACjB,eAAO,MAAM;AACX,gBAAMC,IAAQF,EAAS,OACjBG,IAAuB,CAAC,CAACD,GAAO,MAAM;AAC5C,iBAAOE;AAAA,YACLF,KAAS,CAACG,EAAYH,CAAK,MAAMA,EAAM,YAAY,gBAAgBC,KAC/DZ,IACAE;AAAA,YACJ;AAAA,cACE,OAAO;AAAA,gBACL,GAAGD;AAAA,gBACH,GAAGK;AAAA,cAAA;AAAA,cAEL,IAAIE;AAAA,YAAA;AAAA,YAEND;AAAA,UAAA;AAAA,QAEJ;AAAA,MACF;AAAA,IAAA,CACD;AAAA,EAAA;AAKP;"}
@@ -1 +1 @@
1
- {"version":3,"file":"use-enter-submit.mjs","sources":["../../../src/__builtins__/shared/use-enter-submit.ts"],"sourcesContent":["import type { Ref } from 'vue'\nimport { useEventListener } from '@vueuse/core'\nimport { computed, onBeforeUnmount, watch } from 'vue'\n\nexport interface UseEnterSubmitOptions {\n visible: Ref<boolean>\n resolve: () => void\n submitting: Ref<boolean>\n getContainer: () => HTMLElement | null\n enabled?: Ref<boolean> | boolean\n}\n\nconst runtimeWindow = globalThis.window === undefined ? undefined : globalThis\n\nexport function useEnterSubmit({ visible, resolve, submitting, getContainer, enabled = true }: UseEnterSubmitOptions) {\n let stopListener: (() => void) | null = null\n const enabledRef = computed(() => {\n if (typeof enabled === 'boolean')\n return enabled\n\n return enabled?.value ?? true\n })\n\n const shouldSkipSubmit = (event: KeyboardEvent) => {\n if (\n event.isComposing\n || event.shiftKey\n || event.altKey\n || event.ctrlKey\n || event.metaKey\n || !visible.value\n || !enabledRef.value\n || submitting.value\n || event.defaultPrevented\n ) {\n return true\n }\n\n const container = getContainer()\n if (!container || !(event.target instanceof Node) || !container.contains(event.target))\n return true\n\n const target = event.target as HTMLElement | null\n if (target?.closest('textarea,[contenteditable=true]'))\n return true\n\n return false\n }\n\n const handleEnterSubmit = (event: KeyboardEvent) => {\n if (event.key !== 'Enter' || shouldSkipSubmit(event))\n return\n\n event.preventDefault()\n resolve()\n }\n\n const toggleListener = (shouldListen: boolean) => {\n if (stopListener) {\n stopListener()\n stopListener = null\n }\n\n if (shouldListen && runtimeWindow) {\n stopListener = useEventListener(runtimeWindow, 'keydown', handleEnterSubmit, {\n passive: false,\n })\n }\n }\n\n watch([visible, enabledRef], ([visibleValue, enabledValue]) => {\n toggleListener(visibleValue && enabledValue)\n }, { immediate: true })\n\n onBeforeUnmount(() => toggleListener(false))\n}\n"],"names":["runtimeWindow","useEnterSubmit","visible","resolve","submitting","getContainer","enabled","stopListener","enabledRef","computed","shouldSkipSubmit","event","container","handleEnterSubmit","toggleListener","shouldListen","useEventListener","watch","visibleValue","enabledValue","onBeforeUnmount"],"mappings":";;AAYA,MAAMA,IAAgB,WAAW,WAAW,SAAY,SAAY;AAE7D,SAASC,EAAe,EAAE,SAAAC,GAAS,SAAAC,GAAS,YAAAC,GAAY,cAAAC,GAAc,SAAAC,IAAU,MAA+B;AACpH,MAAIC,IAAoC;AACxC,QAAMC,IAAaC,EAAS,MACtB,OAAOH,KAAY,YACdA,IAEFA,GAAS,SAAS,EAC1B,GAEKI,IAAmB,CAACC,MAAyB;AACjD,QACEA,EAAM,eACHA,EAAM,YACNA,EAAM,UACNA,EAAM,WACNA,EAAM,WACN,CAACT,EAAQ,SACT,CAACM,EAAW,SACZJ,EAAW,SACXO,EAAM;AAET,aAAO;AAGT,UAAMC,IAAYP,EAAA;AAKlB,WAJI,IAACO,KAAa,EAAED,EAAM,kBAAkB,SAAS,CAACC,EAAU,SAASD,EAAM,MAAM,KAGtEA,EAAM,QACT,QAAQ,iCAAiC;AAAA,EAIvD,GAEME,IAAoB,CAACF,MAAyB;AAClD,IAAIA,EAAM,QAAQ,WAAWD,EAAiBC,CAAK,MAGnDA,EAAM,eAAA,GACNR,EAAA;AAAA,EACF,GAEMW,IAAiB,CAACC,MAA0B;AAChD,IAAIR,MACFA,EAAA,GACAA,IAAe,OAGbQ,KAAgBf,MAClBO,IAAeS,EAAiBhB,GAAe,WAAWa,GAAmB;AAAA,MAC3E,SAAS;AAAA,IAAA,CACV;AAAA,EAEL;AAEA,EAAAI,EAAM,CAACf,GAASM,CAAU,GAAG,CAAC,CAACU,GAAcC,CAAY,MAAM;AAC7D,IAAAL,EAAeI,KAAgBC,CAAY;AAAA,EAC7C,GAAG,EAAE,WAAW,IAAM,GAEtBC,EAAgB,MAAMN,EAAe,EAAK,CAAC;AAC7C;"}
1
+ {"version":3,"file":"use-enter-submit.mjs","sources":["../../../src/__builtins__/shared/use-enter-submit.ts"],"sourcesContent":["import type { Ref } from 'vue'\r\nimport { useEventListener } from '@vueuse/core'\r\nimport { computed, onBeforeUnmount, watch } from 'vue'\r\n\r\nexport interface UseEnterSubmitOptions {\r\n visible: Ref<boolean>\r\n resolve: () => void\r\n submitting: Ref<boolean>\r\n getContainer: () => HTMLElement | null\r\n enabled?: Ref<boolean> | boolean\r\n}\r\n\r\nconst runtimeWindow = globalThis.window === undefined ? undefined : globalThis\r\n\r\nexport function useEnterSubmit({ visible, resolve, submitting, getContainer, enabled = true }: UseEnterSubmitOptions) {\r\n let stopListener: (() => void) | null = null\r\n const enabledRef = computed(() => {\r\n if (typeof enabled === 'boolean')\r\n return enabled\r\n\r\n return enabled?.value ?? true\r\n })\r\n\r\n const shouldSkipSubmit = (event: KeyboardEvent) => {\r\n if (\r\n event.isComposing\r\n || event.shiftKey\r\n || event.altKey\r\n || event.ctrlKey\r\n || event.metaKey\r\n || !visible.value\r\n || !enabledRef.value\r\n || submitting.value\r\n || event.defaultPrevented\r\n ) {\r\n return true\r\n }\r\n\r\n const container = getContainer()\r\n if (!container || !(event.target instanceof Node) || !container.contains(event.target))\r\n return true\r\n\r\n const target = event.target as HTMLElement | null\r\n if (target?.closest('textarea,[contenteditable=true]'))\r\n return true\r\n\r\n return false\r\n }\r\n\r\n const handleEnterSubmit = (event: KeyboardEvent) => {\r\n if (event.key !== 'Enter' || shouldSkipSubmit(event))\r\n return\r\n\r\n event.preventDefault()\r\n resolve()\r\n }\r\n\r\n const toggleListener = (shouldListen: boolean) => {\r\n if (stopListener) {\r\n stopListener()\r\n stopListener = null\r\n }\r\n\r\n if (shouldListen && runtimeWindow) {\r\n stopListener = useEventListener(runtimeWindow, 'keydown', handleEnterSubmit, {\r\n passive: false,\r\n })\r\n }\r\n }\r\n\r\n watch([visible, enabledRef], ([visibleValue, enabledValue]) => {\r\n toggleListener(visibleValue && enabledValue)\r\n }, { immediate: true })\r\n\r\n onBeforeUnmount(() => toggleListener(false))\r\n}\r\n"],"names":["runtimeWindow","useEnterSubmit","visible","resolve","submitting","getContainer","enabled","stopListener","enabledRef","computed","shouldSkipSubmit","event","container","handleEnterSubmit","toggleListener","shouldListen","useEventListener","watch","visibleValue","enabledValue","onBeforeUnmount"],"mappings":";;AAYA,MAAMA,IAAgB,WAAW,WAAW,SAAY,SAAY;AAE7D,SAASC,EAAe,EAAE,SAAAC,GAAS,SAAAC,GAAS,YAAAC,GAAY,cAAAC,GAAc,SAAAC,IAAU,MAA+B;AACpH,MAAIC,IAAoC;AACxC,QAAMC,IAAaC,EAAS,MACtB,OAAOH,KAAY,YACdA,IAEFA,GAAS,SAAS,EAC1B,GAEKI,IAAmB,CAACC,MAAyB;AACjD,QACEA,EAAM,eACHA,EAAM,YACNA,EAAM,UACNA,EAAM,WACNA,EAAM,WACN,CAACT,EAAQ,SACT,CAACM,EAAW,SACZJ,EAAW,SACXO,EAAM;AAET,aAAO;AAGT,UAAMC,IAAYP,EAAA;AAKlB,WAJI,IAACO,KAAa,EAAED,EAAM,kBAAkB,SAAS,CAACC,EAAU,SAASD,EAAM,MAAM,KAGtEA,EAAM,QACT,QAAQ,iCAAiC;AAAA,EAIvD,GAEME,IAAoB,CAACF,MAAyB;AAClD,IAAIA,EAAM,QAAQ,WAAWD,EAAiBC,CAAK,MAGnDA,EAAM,eAAA,GACNR,EAAA;AAAA,EACF,GAEMW,IAAiB,CAACC,MAA0B;AAChD,IAAIR,MACFA,EAAA,GACAA,IAAe,OAGbQ,KAAgBf,MAClBO,IAAeS,EAAiBhB,GAAe,WAAWa,GAAmB;AAAA,MAC3E,SAAS;AAAA,IAAA,CACV;AAAA,EAEL;AAEA,EAAAI,EAAM,CAACf,GAASM,CAAU,GAAG,CAAC,CAACU,GAAcC,CAAY,MAAM;AAC7D,IAAAL,EAAeI,KAAgBC,CAAY;AAAA,EAC7C,GAAG,EAAE,WAAW,IAAM,GAEtBC,EAAgB,MAAMN,EAAe,EAAK,CAAC;AAC7C;"}
@@ -18,7 +18,6 @@ function C(t) {
18
18
  function T(t, r) {
19
19
  return Object.assign(t, r);
20
20
  }
21
- /* istanbul ignore next -- @preserve */
22
21
  function o(t) {
23
22
  return t.every((r) => !!(r.type === s || r.type === p && typeof r.children == "string" && !r.children.trim() || r.type === c && o(r.children)));
24
23
  }
@@ -26,7 +25,6 @@ function b(t) {
26
25
  return t ? !o(t()) : !1;
27
26
  }
28
27
  function d() {
29
- /* istanbul ignore next -- @preserve */
30
28
  return m(a, "2.9.9") ? !1 : "never";
31
29
  }
32
30
  export {
@@ -1 +1 @@
1
- {"version":3,"file":"utils.mjs","sources":["../../../src/__builtins__/shared/utils.ts"],"sourcesContent":["import type { Component, ComputedRef, Slot, VNode } from 'vue'\nimport { isPlainObj } from '@formily/shared'\nimport { useAttrs, version } from 'element-plus'\nimport { omit } from 'lodash-es'\nimport { Comment, computed, Fragment, Text } from 'vue'\nimport { lt } from './simple-version-compare'\n\nexport function useCleanAttrs(removeAttrsList: string[] = []): {\n props: ComputedRef<Record<string, any>>\n} {\n const attrs = useAttrs()\n const props = computed(() => {\n const DEFAULT_REMOVE_ATTRS = ['value', 'onChange', 'attrs', 'on', 'readOnly']\n if (isPlainObj(attrs.value.attrs)) {\n return omit({ ...attrs.value, ...attrs.value.attrs }, DEFAULT_REMOVE_ATTRS.concat(removeAttrsList))\n }\n return omit(attrs.value, DEFAULT_REMOVE_ATTRS.concat(removeAttrsList))\n })\n return {\n props,\n }\n}\n\nexport function isVueOptions(options: any): options is Component {\n return (\n options\n && (typeof options.template === 'string'\n || typeof options.render === 'function')\n )\n}\n\nexport function composeExport<T0 extends object, T1 extends object>(\n s0: T0,\n s1: T1,\n): T0 & T1 {\n return Object.assign(s0, s1)\n}\n\n// Adapted from https://github.com/vuejs/vue-next/blob/ca17162e377e0a0bf3fae9d92d0fdcb32084a9fe/packages/runtime-core/src/helpers/renderSlot.ts#L77\n/* istanbul ignore next -- @preserve */\nexport function isVnodeEmpty(vnodes: Array<VNode>) {\n return vnodes.every((node: VNode) => {\n if (node.type === Comment) {\n return true\n }\n\n if (node.type === Text && typeof node.children === 'string' && !node.children.trim()) {\n return true\n }\n\n if (\n node.type === Fragment\n && isVnodeEmpty(node.children as Array<VNode>)\n ) {\n return true\n }\n\n return false\n })\n}\n\nexport function hasSlotContent(slot: Slot<any> | undefined) {\n if (!slot) {\n return false\n }\n return !isVnodeEmpty(slot())\n}\n\nexport function compatibleUnderlineProp() {\n /* istanbul ignore next -- @preserve */\n return lt(version, '2.9.9') ? false : 'never'\n}\n"],"names":["useCleanAttrs","removeAttrsList","attrs","useAttrs","computed","DEFAULT_REMOVE_ATTRS","isPlainObj","omit","isVueOptions","options","composeExport","s0","s1","isVnodeEmpty","vnodes","node","Comment","Text","Fragment","hasSlotContent","slot","compatibleUnderlineProp","lt","version"],"mappings":";;;;;AAOO,SAASA,EAAcC,IAA4B,IAExD;AACA,QAAMC,IAAQC,EAAA;AAQd,SAAO;AAAA,IACL,OARYC,EAAS,MAAM;AAC3B,YAAMC,IAAuB,CAAC,SAAS,YAAY,SAAS,MAAM,UAAU;AAC5E,aAAIC,EAAWJ,EAAM,MAAM,KAAK,IACvBK,EAAK,EAAE,GAAGL,EAAM,OAAO,GAAGA,EAAM,MAAM,MAAA,GAASG,EAAqB,OAAOJ,CAAe,CAAC,IAE7FM,EAAKL,EAAM,OAAOG,EAAqB,OAAOJ,CAAe,CAAC;AAAA,IACvE,CAAC;AAAA,EAEC;AAEJ;AAEO,SAASO,EAAaC,GAAoC;AAC/D,SACEA,MACI,OAAOA,EAAQ,YAAa,YAC3B,OAAOA,EAAQ,UAAW;AAEnC;AAEO,SAASC,EACdC,GACAC,GACS;AACT,SAAO,OAAO,OAAOD,GAAIC,CAAE;AAC7B;AAGA;AACO,SAASC,EAAaC,GAAsB;AACjD,SAAOA,EAAO,MAAM,CAACC,MACf,GAAAA,EAAK,SAASC,KAIdD,EAAK,SAASE,KAAQ,OAAOF,EAAK,YAAa,YAAY,CAACA,EAAK,SAAS,KAAA,KAK5EA,EAAK,SAASG,KACXL,EAAaE,EAAK,QAAwB,EAMhD;AACH;AAEO,SAASI,EAAeC,GAA6B;AAC1D,SAAKA,IAGE,CAACP,EAAaO,GAAM,IAFlB;AAGX;AAEO,SAASC,IAA0B;AAAA,EAAA;AAExC,SAAOC,EAAGC,GAAS,OAAO,IAAI,KAAQ;AACxC;"}
1
+ {"version":3,"file":"utils.mjs","sources":["../../../src/__builtins__/shared/utils.ts"],"sourcesContent":["import type { Component, ComputedRef, Slot, VNode } from 'vue'\r\nimport { isPlainObj } from '@formily/shared'\r\nimport { useAttrs, version } from 'element-plus'\r\nimport { omit } from 'lodash-es'\r\nimport { Comment, computed, Fragment, Text } from 'vue'\r\nimport { lt } from './simple-version-compare'\r\n\r\nexport function useCleanAttrs(removeAttrsList: string[] = []): {\r\n props: ComputedRef<Record<string, any>>\r\n} {\r\n const attrs = useAttrs()\r\n const props = computed(() => {\r\n const DEFAULT_REMOVE_ATTRS = ['value', 'onChange', 'attrs', 'on', 'readOnly']\r\n if (isPlainObj(attrs.value.attrs)) {\r\n return omit({ ...attrs.value, ...attrs.value.attrs }, DEFAULT_REMOVE_ATTRS.concat(removeAttrsList))\r\n }\r\n return omit(attrs.value, DEFAULT_REMOVE_ATTRS.concat(removeAttrsList))\r\n })\r\n return {\r\n props,\r\n }\r\n}\r\n\r\nexport function isVueOptions(options: any): options is Component {\r\n return (\r\n options\r\n && (typeof options.template === 'string'\r\n || typeof options.render === 'function')\r\n )\r\n}\r\n\r\nexport function composeExport<T0 extends object, T1 extends object>(\r\n s0: T0,\r\n s1: T1,\r\n): T0 & T1 {\r\n return Object.assign(s0, s1)\r\n}\r\n\r\n// Adapted from https://github.com/vuejs/vue-next/blob/ca17162e377e0a0bf3fae9d92d0fdcb32084a9fe/packages/runtime-core/src/helpers/renderSlot.ts#L77\r\n/* istanbul ignore next -- @preserve */\r\nexport function isVnodeEmpty(vnodes: Array<VNode>) {\r\n return vnodes.every((node: VNode) => {\r\n if (node.type === Comment) {\r\n return true\r\n }\r\n\r\n if (node.type === Text && typeof node.children === 'string' && !node.children.trim()) {\r\n return true\r\n }\r\n\r\n if (\r\n node.type === Fragment\r\n && isVnodeEmpty(node.children as Array<VNode>)\r\n ) {\r\n return true\r\n }\r\n\r\n return false\r\n })\r\n}\r\n\r\nexport function hasSlotContent(slot: Slot<any> | undefined) {\r\n if (!slot) {\r\n return false\r\n }\r\n return !isVnodeEmpty(slot())\r\n}\r\n\r\nexport function compatibleUnderlineProp() {\r\n /* istanbul ignore next -- @preserve */\r\n return lt(version, '2.9.9') ? false : 'never'\r\n}\r\n"],"names":["useCleanAttrs","removeAttrsList","attrs","useAttrs","computed","DEFAULT_REMOVE_ATTRS","isPlainObj","omit","isVueOptions","options","composeExport","s0","s1","isVnodeEmpty","vnodes","node","Comment","Text","Fragment","hasSlotContent","slot","compatibleUnderlineProp","lt","version"],"mappings":";;;;;AAOO,SAASA,EAAcC,IAA4B,IAExD;AACA,QAAMC,IAAQC,EAAA;AAQd,SAAO;AAAA,IACL,OARYC,EAAS,MAAM;AAC3B,YAAMC,IAAuB,CAAC,SAAS,YAAY,SAAS,MAAM,UAAU;AAC5E,aAAIC,EAAWJ,EAAM,MAAM,KAAK,IACvBK,EAAK,EAAE,GAAGL,EAAM,OAAO,GAAGA,EAAM,MAAM,MAAA,GAASG,EAAqB,OAAOJ,CAAe,CAAC,IAE7FM,EAAKL,EAAM,OAAOG,EAAqB,OAAOJ,CAAe,CAAC;AAAA,IACvE,CAAC;AAAA,EAEC;AAEJ;AAEO,SAASO,EAAaC,GAAoC;AAC/D,SACEA,MACI,OAAOA,EAAQ,YAAa,YAC3B,OAAOA,EAAQ,UAAW;AAEnC;AAEO,SAASC,EACdC,GACAC,GACS;AACT,SAAO,OAAO,OAAOD,GAAIC,CAAE;AAC7B;AAIO,SAASC,EAAaC,GAAsB;AACjD,SAAOA,EAAO,MAAM,CAACC,MACf,GAAAA,EAAK,SAASC,KAIdD,EAAK,SAASE,KAAQ,OAAOF,EAAK,YAAa,YAAY,CAACA,EAAK,SAAS,KAAA,KAK5EA,EAAK,SAASG,KACXL,EAAaE,EAAK,QAAwB,EAMhD;AACH;AAEO,SAASI,EAAeC,GAA6B;AAC1D,SAAKA,IAGE,CAACP,EAAaO,GAAM,IAFlB;AAGX;AAEO,SAASC,IAA0B;AAExC,SAAOC,EAAGC,GAAS,OAAO,IAAI,KAAQ;AACxC;"}
@@ -1,16 +1,12 @@
1
- import { ElLink as m } from "element-plus";
2
- import "@formily/reactive";
3
- import "@vueuse/core";
4
- import { defineComponent as l, createBlock as f, createCommentVNode as _, unref as a, openBlock as i, normalizeClass as c, withCtx as h, createTextVNode as v, toDisplayString as y, createElementBlock as C, renderSlot as u, provide as M, useAttrs as w, withModifiers as $ } from "vue";
5
- import "@formily/core";
6
- import "@silver-formily/reactive-vue";
7
- import { useField as B, useFieldSchema as D } from "@silver-formily/vue";
8
- import { compatibleUnderlineProp as b, composeExport as I } from "../__builtins__/shared/utils.mjs";
9
- import { Plus as R, ArrowDown as S, ArrowUp as U, Delete as V, Rank as z } from "@element-plus/icons-vue";
10
- import { useArray as p, prefixCls as d, getDefaultValue as g, useIndex as k, useRecord as E, useKey as F } from "./utils.mjs";
1
+ import { defineComponent as o, unref as a, openBlock as i, createBlock as m, normalizeClass as c, withCtx as h, createTextVNode as f, toDisplayString as _, createCommentVNode as v, createElementBlock as C, renderSlot as u, provide as M, useAttrs as w, withModifiers as $ } from "vue";
2
+ import { Plus as D, ArrowDown as I, ArrowUp as R, Delete as S, Rank as U } from "@element-plus/icons-vue";
3
+ import { useField as B, useFieldSchema as V } from "@silver-formily/vue";
4
+ import { ElLink as y } from "element-plus";
5
+ import { useArray as p, prefixCls as d, getDefaultValue as z, useIndex as b, useRecord as g, useKey as E } from "./utils.mjs";
6
+ import { compatibleUnderlineProp as k, composeExport as F } from "../__builtins__/shared/utils.mjs";
11
7
  import { ArrayBaseSymbol as H, ItemSymbol as N } from "./symbols.mjs";
12
8
  import { isArr as x } from "@formily/shared";
13
- import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
9
+ import '../styles/array-base/index.css';const P = /* @__PURE__ */ o({
14
10
  name: "ArrayBaseAddition",
15
11
  __name: "array-base-addition",
16
12
  props: {
@@ -20,39 +16,39 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
20
16
  },
21
17
  setup(n) {
22
18
  const r = n, t = B(), e = p();
23
- function o() {
24
- const s = g(r.defaultValue, e?.schema.value);
19
+ function l() {
20
+ const s = z(r.defaultValue, e?.schema.value);
25
21
  r.method === "unshift" ? (e?.field?.value.unshift(s), e.attrs?.add?.(0)) : (e?.field?.value.push(s), e.attrs?.add?.(e?.field?.value?.value?.length - 1));
26
22
  }
27
- return (s, A) => a(e).field.value.pattern === "editable" ? (i(), f(a(m), {
23
+ return (s, A) => a(e).field.value.pattern === "editable" ? (i(), m(a(y), {
28
24
  key: 0,
29
25
  class: c(`${a(d)}-addition`),
30
- icon: a(R),
31
- underline: a(b)(),
26
+ icon: a(D),
27
+ underline: a(k)(),
32
28
  role: "button",
33
29
  "aria-label": "添加条目",
34
- onClick: o
30
+ onClick: l
35
31
  }, {
36
32
  default: h(() => [
37
- v(y(a(t).title || r.title), 1)
33
+ f(_(a(t).title || r.title), 1)
38
34
  ]),
39
35
  _: 1
40
- }, 8, ["class", "icon", "underline"])) : _("", !0);
36
+ }, 8, ["class", "icon", "underline"])) : v("", !0);
41
37
  }
42
- }), K = /* @__PURE__ */ l({
38
+ }), K = /* @__PURE__ */ o({
43
39
  name: "ArrayBaseIndex",
44
40
  __name: "array-base-index",
45
41
  setup(n) {
46
- const r = k();
42
+ const r = b();
47
43
  return (t, e) => (i(), C("span", {
48
44
  class: c(`${a(d)}-index`)
49
45
  }, [
50
46
  u(t.$slots, "default", { index: a(r) }, () => [
51
- v(" #" + y(a(r) + 1) + ". ", 1)
47
+ f(" #" + _(a(r) + 1) + ". ", 1)
52
48
  ])
53
49
  ], 2));
54
50
  }
55
- }), L = /* @__PURE__ */ l({
51
+ }), L = /* @__PURE__ */ o({
56
52
  name: "ArrayBaseInner",
57
53
  inheritAttrs: !1,
58
54
  __name: "array-base-inner",
@@ -61,16 +57,16 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
61
57
  keyMap: {}
62
58
  },
63
59
  setup(n) {
64
- const r = n, t = B(), e = D();
60
+ const r = n, t = B(), e = V();
65
61
  return M(H, {
66
62
  field: t,
67
63
  schema: e,
68
64
  props: r,
69
65
  attrs: w(),
70
66
  keyMap: r.keyMap
71
- }), (o, s) => u(o.$slots, "default");
67
+ }), (l, s) => u(l.$slots, "default");
72
68
  }
73
- }), T = /* @__PURE__ */ l({
69
+ }), T = /* @__PURE__ */ o({
74
70
  name: "ArrayBaseItem",
75
71
  __name: "array-base-item",
76
72
  props: {
@@ -80,118 +76,118 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
80
76
  setup(n) {
81
77
  return M(N, n), (t, e) => u(t.$slots, "default");
82
78
  }
83
- }), j = /* @__PURE__ */ l({
79
+ }), j = /* @__PURE__ */ o({
84
80
  name: "ArrayBaseMoveDown",
85
81
  __name: "array-base-move-down",
86
82
  props: {
87
83
  title: {}
88
84
  },
89
85
  setup(n) {
90
- const r = n, t = k(), e = p();
91
- function o() {
86
+ const r = n, t = b(), e = p();
87
+ function l() {
92
88
  x(e?.keyMap) && e.keyMap.splice(
93
89
  t.value + 1,
94
90
  0,
95
91
  e.keyMap.splice(t.value, 1)[0]
96
92
  ), e?.field.value.moveDown(t.value), e?.attrs?.moveDown?.(t.value);
97
93
  }
98
- return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
94
+ return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), m(a(y), {
99
95
  key: 0,
100
96
  class: c(`${a(d)}-move-down`),
101
97
  size: "small",
102
- icon: a(S),
103
- underline: a(b)(),
98
+ icon: a(I),
99
+ underline: a(k)(),
104
100
  role: "button",
105
101
  "aria-label": "下移条目",
106
- onClick: $(o, ["stop"])
102
+ onClick: $(l, ["stop"])
107
103
  }, {
108
104
  default: h(() => [
109
105
  u(s.$slots, "default", {}, () => [
110
- v(y(r.title), 1)
106
+ f(_(r.title), 1)
111
107
  ])
112
108
  ]),
113
109
  _: 3
114
- }, 8, ["class", "icon", "underline"])) : _("", !0);
110
+ }, 8, ["class", "icon", "underline"])) : v("", !0);
115
111
  }
116
- }), q = /* @__PURE__ */ l({
112
+ }), q = /* @__PURE__ */ o({
117
113
  name: "ArrayBaseMoveUp",
118
114
  __name: "array-base-move-up",
119
115
  props: {
120
116
  title: {}
121
117
  },
122
118
  setup(n) {
123
- const r = n, t = k(), e = p();
124
- function o() {
119
+ const r = n, t = b(), e = p();
120
+ function l() {
125
121
  x(e?.keyMap) && e.keyMap.splice(
126
122
  t.value - 1,
127
123
  0,
128
124
  e.keyMap.splice(t.value, 1)[0]
129
125
  ), e?.field.value.moveUp(t.value), e?.attrs?.moveUp?.(t.value);
130
126
  }
131
- return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
127
+ return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), m(a(y), {
132
128
  key: 0,
133
129
  class: c(`${a(d)}-move-up`),
134
130
  size: "small",
135
- icon: a(U),
136
- underline: a(b)(),
131
+ icon: a(R),
132
+ underline: a(k)(),
137
133
  role: "button",
138
134
  "aria-label": "上移条目",
139
- onClick: $(o, ["stop"])
135
+ onClick: $(l, ["stop"])
140
136
  }, {
141
137
  default: h(() => [
142
138
  u(s.$slots, "default", {}, () => [
143
- v(y(r.title), 1)
139
+ f(_(r.title), 1)
144
140
  ])
145
141
  ]),
146
142
  _: 3
147
- }, 8, ["class", "icon", "underline"])) : _("", !0);
143
+ }, 8, ["class", "icon", "underline"])) : v("", !0);
148
144
  }
149
- }), G = /* @__PURE__ */ l({
145
+ }), G = /* @__PURE__ */ o({
150
146
  name: "ArrayBaseRemove",
151
147
  __name: "array-base-remove",
152
148
  props: {
153
149
  title: {}
154
150
  },
155
151
  setup(n) {
156
- const r = n, t = k(), e = p();
157
- function o() {
152
+ const r = n, t = b(), e = p();
153
+ function l() {
158
154
  x(e?.keyMap) && e?.keyMap?.splice(t.value, 1), e?.field.value.remove(t.value), e?.attrs?.remove?.(t.value);
159
155
  }
160
- return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
156
+ return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), m(a(y), {
161
157
  key: 0,
162
158
  class: c(`${a(d)}-remove`),
163
159
  size: "small",
164
- icon: a(V),
165
- underline: a(b)(),
160
+ icon: a(S),
161
+ underline: a(k)(),
166
162
  role: "button",
167
163
  "aria-label": "移除条目",
168
- onClick: $(o, ["stop"])
164
+ onClick: $(l, ["stop"])
169
165
  }, {
170
166
  default: h(() => [
171
167
  u(s.$slots, "default", {}, () => [
172
- v(y(r.title), 1)
168
+ f(_(r.title), 1)
173
169
  ])
174
170
  ]),
175
171
  _: 3
176
- }, 8, ["class", "icon", "underline"])) : _("", !0);
172
+ }, 8, ["class", "icon", "underline"])) : v("", !0);
177
173
  }
178
- }), J = /* @__PURE__ */ l({
174
+ }), J = /* @__PURE__ */ o({
179
175
  name: "ArrayBaseSortHandle",
180
176
  __name: "array-base-sort-handle",
181
177
  setup(n) {
182
178
  const r = p();
183
- return (t, e) => a(r).field.value?.pattern === "editable" ? (i(), f(a(m), {
179
+ return (t, e) => a(r).field.value?.pattern === "editable" ? (i(), m(a(y), {
184
180
  key: 0,
185
181
  class: c(`${a(d)}-sort-handle`),
186
182
  size: "small",
187
- icon: a(z),
188
- underline: a(b)(),
183
+ icon: a(U),
184
+ underline: a(k)(),
189
185
  role: "button",
190
186
  "aria-label": "拖拽排序",
191
187
  "aria-dropeffect": "move"
192
- }, null, 8, ["class", "icon", "underline"])) : _("", !0);
188
+ }, null, 8, ["class", "icon", "underline"])) : v("", !0);
193
189
  }
194
- }), oe = I(L, {
190
+ }), te = F(L, {
195
191
  Index: K,
196
192
  Item: T,
197
193
  SortHandle: J,
@@ -200,11 +196,11 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
200
196
  MoveDown: j,
201
197
  MoveUp: q,
202
198
  useArray: p,
203
- useIndex: k,
204
- useKey: F,
205
- useRecord: E
199
+ useIndex: b,
200
+ useKey: E,
201
+ useRecord: g
206
202
  });
207
203
  export {
208
- oe as ArrayBase
204
+ te as ArrayBase
209
205
  };
210
206
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../src/array-base/array-base-addition.vue","../../src/array-base/array-base-index.vue","../../src/array-base/array-base-inner.vue","../../src/array-base/array-base-item.vue","../../src/array-base/array-base-move-down.vue","../../src/array-base/array-base-move-up.vue","../../src/array-base/array-base-remove.vue","../../src/array-base/array-base-sort-handle.vue","../../src/array-base/index.ts"],"sourcesContent":["<script lang=\"ts\" setup>\nimport type { IArrayBaseAdditionProps } from './types'\nimport { Plus } from '@element-plus/icons-vue'\nimport { useField } from '@silver-formily/vue'\nimport { ElLink } from 'element-plus'\nimport { compatibleUnderlineProp } from '../__builtins__'\nimport { getDefaultValue, prefixCls, useArray } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseAddition',\n})\n\nconst props = withDefaults(defineProps<IArrayBaseAdditionProps>(), {\n method: 'push',\n})\n\nconst self = useField()\nconst base = useArray()\n\nfunction onAddItemClick() {\n const defaultValue = getDefaultValue(props.defaultValue, base?.schema.value)\n if (props.method === 'unshift') {\n base?.field?.value.unshift(defaultValue)\n base.attrs?.add?.(0)\n }\n else {\n base?.field?.value.push(defaultValue)\n base.attrs?.add?.(base?.field?.value?.value?.length - 1)\n }\n}\n</script>\n\n<template>\n <ElLink\n v-if=\"base.field.value.pattern === 'editable'\"\n :class=\"`${prefixCls}-addition`\"\n :icon=\"Plus\"\n :underline=\"compatibleUnderlineProp()\"\n role=\"button\"\n aria-label=\"添加条目\"\n @click=\"onAddItemClick\"\n >\n {{ self.title || props.title }}\n </ElLink>\n</template>\n","<script lang=\"ts\" setup>\nimport { prefixCls, useIndex } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseIndex',\n})\n\nconst index = useIndex()\n</script>\n\n<template>\n <span :class=\"`${prefixCls}-index`\">\n <slot :index=\"index\">\n #{{ index + 1 }}.\n </slot>\n </span>\n</template>\n","<script lang=\"ts\" setup>\nimport type { ArrayField } from '@formily/core'\nimport type { IArrayBaseProps } from './types'\nimport { useField, useFieldSchema } from '@silver-formily/vue'\nimport { provide, useAttrs } from 'vue'\nimport { ArrayBaseSymbol } from './symbols'\n\ndefineOptions({\n name: 'ArrayBaseInner',\n inheritAttrs: false,\n})\n\nconst props = defineProps<IArrayBaseProps>()\n\nconst field = useField<ArrayField>()\nconst schema = useFieldSchema()\n\nprovide(ArrayBaseSymbol, {\n field,\n schema,\n props,\n attrs: useAttrs(),\n keyMap: props.keyMap,\n})\n</script>\n\n<template>\n <slot />\n</template>\n","<script lang=\"ts\" setup>\nimport type { IArrayBaseItemProps } from './types'\nimport { provide } from 'vue'\nimport { ItemSymbol } from './symbols'\n\ndefineOptions({\n name: 'ArrayBaseItem',\n})\n\nconst props = defineProps<IArrayBaseItemProps>()\n\nprovide(ItemSymbol, props)\n</script>\n\n<template>\n <slot />\n</template>\n","<script lang=\"ts\" setup>\nimport type { IArrayBaseOperationProps } from './types'\nimport { ArrowDown } from '@element-plus/icons-vue'\nimport { isArr } from '@formily/shared'\nimport { ElLink } from 'element-plus'\nimport { compatibleUnderlineProp } from '../__builtins__'\nimport { prefixCls, useArray, useIndex } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseMoveDown',\n})\n\nconst props = defineProps<IArrayBaseOperationProps>()\n\nconst indexRef = useIndex()\nconst base = useArray()\n\nfunction handleClick() {\n if (isArr(base?.keyMap)) {\n base.keyMap.splice(\n indexRef.value + 1,\n 0,\n base.keyMap.splice(indexRef.value, 1)[0],\n )\n }\n base?.field.value.moveDown(indexRef.value as number)\n base?.attrs?.moveDown?.(indexRef.value as number)\n}\n</script>\n\n<template>\n <ElLink\n v-if=\"base?.field.value.pattern === 'editable'\"\n :class=\"`${prefixCls}-move-down`\"\n size=\"small\"\n :icon=\"ArrowDown\"\n :underline=\"compatibleUnderlineProp()\"\n role=\"button\"\n aria-label=\"下移条目\"\n @click.stop=\"handleClick\"\n >\n <slot>\n {{ props.title }}\n </slot>\n </ElLink>\n</template>\n","<script lang=\"ts\" setup>\nimport type { IArrayBaseOperationProps } from './types'\nimport { ArrowUp } from '@element-plus/icons-vue'\nimport { isArr } from '@formily/shared'\nimport { ElLink } from 'element-plus'\nimport { compatibleUnderlineProp } from '../__builtins__'\nimport { prefixCls, useArray, useIndex } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseMoveUp',\n})\n\nconst props = defineProps<IArrayBaseOperationProps>()\n\nconst indexRef = useIndex()\nconst base = useArray()\n\nfunction handleClick() {\n if (isArr(base?.keyMap)) {\n base.keyMap.splice(\n indexRef.value - 1,\n 0,\n base.keyMap.splice(indexRef.value, 1)[0],\n )\n }\n base?.field.value.moveUp(indexRef.value as number)\n base?.attrs?.moveUp?.(indexRef.value as number)\n}\n</script>\n\n<template>\n <ElLink\n v-if=\"base?.field.value.pattern === 'editable'\"\n :class=\"`${prefixCls}-move-up`\"\n size=\"small\"\n :icon=\"ArrowUp\"\n :underline=\"compatibleUnderlineProp()\"\n role=\"button\"\n aria-label=\"上移条目\"\n @click.stop=\"handleClick\"\n >\n <slot>\n {{ props.title }}\n </slot>\n </ElLink>\n</template>\n","<script lang=\"ts\" setup>\nimport type { IArrayBaseOperationProps } from './types'\nimport { Delete } from '@element-plus/icons-vue'\nimport { isArr } from '@formily/shared'\nimport { ElLink } from 'element-plus'\nimport { compatibleUnderlineProp } from '../__builtins__'\nimport { prefixCls, useArray, useIndex } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseRemove',\n})\n\nconst props = defineProps<IArrayBaseOperationProps>()\n\nconst indexRef = useIndex()\nconst base = useArray()\n\nfunction handleClick() {\n if (isArr(base?.keyMap)) {\n base?.keyMap?.splice(indexRef.value, 1)\n }\n\n base?.field.value.remove(indexRef.value as number)\n base?.attrs?.remove?.(indexRef.value as number)\n}\n</script>\n\n<template>\n <ElLink\n v-if=\"base?.field.value.pattern === 'editable'\"\n :class=\"`${prefixCls}-remove`\"\n size=\"small\"\n :icon=\"Delete\"\n :underline=\"compatibleUnderlineProp()\"\n role=\"button\"\n aria-label=\"移除条目\"\n @click.stop=\"handleClick\"\n >\n <slot>\n {{ props.title }}\n </slot>\n </ElLink>\n</template>\n","<script lang=\"ts\" setup>\nimport { Rank } from '@element-plus/icons-vue'\nimport { ElLink } from 'element-plus'\nimport { compatibleUnderlineProp } from '../__builtins__'\nimport { prefixCls, useArray } from './utils'\n\ndefineOptions({\n name: 'ArrayBaseSortHandle',\n})\n\nconst array = useArray()\n</script>\n\n<template>\n <ElLink\n v-if=\"array.field.value?.pattern === 'editable'\"\n :class=\"`${prefixCls}-sort-handle`\"\n size=\"small\"\n :icon=\"Rank\"\n :underline=\"compatibleUnderlineProp()\"\n role=\"button\"\n aria-label=\"拖拽排序\"\n aria-dropeffect=\"move\"\n />\n</template>\n","import { composeExport } from '../__builtins__/shared'\nimport ArrayBaseAddition from './array-base-addition.vue'\nimport ArrayBaseIndex from './array-base-index.vue'\nimport ArrayBaseInner from './array-base-inner.vue'\nimport ArrayBaseItem from './array-base-item.vue'\nimport ArrayBaseMoveDown from './array-base-move-down.vue'\nimport ArrayBaseMoveUp from './array-base-move-up.vue'\nimport ArrayBaseRemove from './array-base-remove.vue'\nimport ArrayBaseSortHandle from './array-base-sort-handle.vue'\nimport { useArray, useIndex, useKey, useRecord } from './utils'\nimport './style.scss'\n\nexport const ArrayBase = composeExport(ArrayBaseInner, {\n Index: ArrayBaseIndex,\n Item: ArrayBaseItem,\n SortHandle: ArrayBaseSortHandle,\n Addition: ArrayBaseAddition,\n Remove: ArrayBaseRemove,\n MoveDown: ArrayBaseMoveDown,\n MoveUp: ArrayBaseMoveUp,\n useArray,\n useIndex,\n useKey,\n useRecord,\n})\n"],"names":["props","__props","self","useField","base","useArray","onAddItemClick","defaultValue","getDefaultValue","_unref","_createBlock","ElLink","prefixCls","Plus","compatibleUnderlineProp","_createTextVNode","_toDisplayString","index","useIndex","_createElementBlock","_renderSlot","_ctx","field","schema","useFieldSchema","provide","ArrayBaseSymbol","useAttrs","ItemSymbol","indexRef","handleClick","isArr","ArrowDown","ArrowUp","Delete","array","Rank","ArrayBase","composeExport","ArrayBaseInner","ArrayBaseIndex","ArrayBaseItem","ArrayBaseSortHandle","ArrayBaseAddition","ArrayBaseRemove","ArrayBaseMoveDown","ArrayBaseMoveUp","useKey","useRecord"],"mappings":"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"}
1
+ {"version":3,"file":"index.mjs","sources":["../../src/array-base/array-base-addition.vue","../../src/array-base/array-base-index.vue","../../src/array-base/array-base-inner.vue","../../src/array-base/array-base-item.vue","../../src/array-base/array-base-move-down.vue","../../src/array-base/array-base-move-up.vue","../../src/array-base/array-base-remove.vue","../../src/array-base/array-base-sort-handle.vue","../../src/array-base/index.ts"],"sourcesContent":["<script lang=\"ts\" setup>\r\nimport type { IArrayBaseAdditionProps } from './types'\r\nimport { Plus } from '@element-plus/icons-vue'\r\nimport { useField } from '@silver-formily/vue'\r\nimport { ElLink } from 'element-plus'\r\nimport { compatibleUnderlineProp } from '../__builtins__'\r\nimport { getDefaultValue, prefixCls, useArray } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseAddition',\r\n})\r\n\r\nconst props = withDefaults(defineProps<IArrayBaseAdditionProps>(), {\r\n method: 'push',\r\n})\r\n\r\nconst self = useField()\r\nconst base = useArray()\r\n\r\nfunction onAddItemClick() {\r\n const defaultValue = getDefaultValue(props.defaultValue, base?.schema.value)\r\n if (props.method === 'unshift') {\r\n base?.field?.value.unshift(defaultValue)\r\n base.attrs?.add?.(0)\r\n }\r\n else {\r\n base?.field?.value.push(defaultValue)\r\n base.attrs?.add?.(base?.field?.value?.value?.length - 1)\r\n }\r\n}\r\n</script>\r\n\r\n<template>\r\n <ElLink\r\n v-if=\"base.field.value.pattern === 'editable'\"\r\n :class=\"`${prefixCls}-addition`\"\r\n :icon=\"Plus\"\r\n :underline=\"compatibleUnderlineProp()\"\r\n role=\"button\"\r\n aria-label=\"添加条目\"\r\n @click=\"onAddItemClick\"\r\n >\r\n {{ self.title || props.title }}\r\n </ElLink>\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport { prefixCls, useIndex } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseIndex',\r\n})\r\n\r\nconst index = useIndex()\r\n</script>\r\n\r\n<template>\r\n <span :class=\"`${prefixCls}-index`\">\r\n <slot :index=\"index\">\r\n #{{ index + 1 }}.\r\n </slot>\r\n </span>\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport type { ArrayField } from '@formily/core'\r\nimport type { IArrayBaseProps } from './types'\r\nimport { useField, useFieldSchema } from '@silver-formily/vue'\r\nimport { provide, useAttrs } from 'vue'\r\nimport { ArrayBaseSymbol } from './symbols'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseInner',\r\n inheritAttrs: false,\r\n})\r\n\r\nconst props = defineProps<IArrayBaseProps>()\r\n\r\nconst field = useField<ArrayField>()\r\nconst schema = useFieldSchema()\r\n\r\nprovide(ArrayBaseSymbol, {\r\n field,\r\n schema,\r\n props,\r\n attrs: useAttrs(),\r\n keyMap: props.keyMap,\r\n})\r\n</script>\r\n\r\n<template>\r\n <slot />\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport type { IArrayBaseItemProps } from './types'\r\nimport { provide } from 'vue'\r\nimport { ItemSymbol } from './symbols'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseItem',\r\n})\r\n\r\nconst props = defineProps<IArrayBaseItemProps>()\r\n\r\nprovide(ItemSymbol, props)\r\n</script>\r\n\r\n<template>\r\n <slot />\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport type { IArrayBaseOperationProps } from './types'\r\nimport { ArrowDown } from '@element-plus/icons-vue'\r\nimport { isArr } from '@formily/shared'\r\nimport { ElLink } from 'element-plus'\r\nimport { compatibleUnderlineProp } from '../__builtins__'\r\nimport { prefixCls, useArray, useIndex } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseMoveDown',\r\n})\r\n\r\nconst props = defineProps<IArrayBaseOperationProps>()\r\n\r\nconst indexRef = useIndex()\r\nconst base = useArray()\r\n\r\nfunction handleClick() {\r\n if (isArr(base?.keyMap)) {\r\n base.keyMap.splice(\r\n indexRef.value + 1,\r\n 0,\r\n base.keyMap.splice(indexRef.value, 1)[0],\r\n )\r\n }\r\n base?.field.value.moveDown(indexRef.value as number)\r\n base?.attrs?.moveDown?.(indexRef.value as number)\r\n}\r\n</script>\r\n\r\n<template>\r\n <ElLink\r\n v-if=\"base?.field.value.pattern === 'editable'\"\r\n :class=\"`${prefixCls}-move-down`\"\r\n size=\"small\"\r\n :icon=\"ArrowDown\"\r\n :underline=\"compatibleUnderlineProp()\"\r\n role=\"button\"\r\n aria-label=\"下移条目\"\r\n @click.stop=\"handleClick\"\r\n >\r\n <slot>\r\n {{ props.title }}\r\n </slot>\r\n </ElLink>\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport type { IArrayBaseOperationProps } from './types'\r\nimport { ArrowUp } from '@element-plus/icons-vue'\r\nimport { isArr } from '@formily/shared'\r\nimport { ElLink } from 'element-plus'\r\nimport { compatibleUnderlineProp } from '../__builtins__'\r\nimport { prefixCls, useArray, useIndex } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseMoveUp',\r\n})\r\n\r\nconst props = defineProps<IArrayBaseOperationProps>()\r\n\r\nconst indexRef = useIndex()\r\nconst base = useArray()\r\n\r\nfunction handleClick() {\r\n if (isArr(base?.keyMap)) {\r\n base.keyMap.splice(\r\n indexRef.value - 1,\r\n 0,\r\n base.keyMap.splice(indexRef.value, 1)[0],\r\n )\r\n }\r\n base?.field.value.moveUp(indexRef.value as number)\r\n base?.attrs?.moveUp?.(indexRef.value as number)\r\n}\r\n</script>\r\n\r\n<template>\r\n <ElLink\r\n v-if=\"base?.field.value.pattern === 'editable'\"\r\n :class=\"`${prefixCls}-move-up`\"\r\n size=\"small\"\r\n :icon=\"ArrowUp\"\r\n :underline=\"compatibleUnderlineProp()\"\r\n role=\"button\"\r\n aria-label=\"上移条目\"\r\n @click.stop=\"handleClick\"\r\n >\r\n <slot>\r\n {{ props.title }}\r\n </slot>\r\n </ElLink>\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport type { IArrayBaseOperationProps } from './types'\r\nimport { Delete } from '@element-plus/icons-vue'\r\nimport { isArr } from '@formily/shared'\r\nimport { ElLink } from 'element-plus'\r\nimport { compatibleUnderlineProp } from '../__builtins__'\r\nimport { prefixCls, useArray, useIndex } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseRemove',\r\n})\r\n\r\nconst props = defineProps<IArrayBaseOperationProps>()\r\n\r\nconst indexRef = useIndex()\r\nconst base = useArray()\r\n\r\nfunction handleClick() {\r\n if (isArr(base?.keyMap)) {\r\n base?.keyMap?.splice(indexRef.value, 1)\r\n }\r\n\r\n base?.field.value.remove(indexRef.value as number)\r\n base?.attrs?.remove?.(indexRef.value as number)\r\n}\r\n</script>\r\n\r\n<template>\r\n <ElLink\r\n v-if=\"base?.field.value.pattern === 'editable'\"\r\n :class=\"`${prefixCls}-remove`\"\r\n size=\"small\"\r\n :icon=\"Delete\"\r\n :underline=\"compatibleUnderlineProp()\"\r\n role=\"button\"\r\n aria-label=\"移除条目\"\r\n @click.stop=\"handleClick\"\r\n >\r\n <slot>\r\n {{ props.title }}\r\n </slot>\r\n </ElLink>\r\n</template>\r\n","<script lang=\"ts\" setup>\r\nimport { Rank } from '@element-plus/icons-vue'\r\nimport { ElLink } from 'element-plus'\r\nimport { compatibleUnderlineProp } from '../__builtins__'\r\nimport { prefixCls, useArray } from './utils'\r\n\r\ndefineOptions({\r\n name: 'ArrayBaseSortHandle',\r\n})\r\n\r\nconst array = useArray()\r\n</script>\r\n\r\n<template>\r\n <ElLink\r\n v-if=\"array.field.value?.pattern === 'editable'\"\r\n :class=\"`${prefixCls}-sort-handle`\"\r\n size=\"small\"\r\n :icon=\"Rank\"\r\n :underline=\"compatibleUnderlineProp()\"\r\n role=\"button\"\r\n aria-label=\"拖拽排序\"\r\n aria-dropeffect=\"move\"\r\n />\r\n</template>\r\n","import { composeExport } from '../__builtins__/shared'\r\nimport ArrayBaseAddition from './array-base-addition.vue'\r\nimport ArrayBaseIndex from './array-base-index.vue'\r\nimport ArrayBaseInner from './array-base-inner.vue'\r\nimport ArrayBaseItem from './array-base-item.vue'\r\nimport ArrayBaseMoveDown from './array-base-move-down.vue'\r\nimport ArrayBaseMoveUp from './array-base-move-up.vue'\r\nimport ArrayBaseRemove from './array-base-remove.vue'\r\nimport ArrayBaseSortHandle from './array-base-sort-handle.vue'\r\nimport { useArray, useIndex, useKey, useRecord } from './utils'\r\nimport './style.scss'\r\n\r\nexport const ArrayBase = composeExport(ArrayBaseInner, {\r\n Index: ArrayBaseIndex,\r\n Item: ArrayBaseItem,\r\n SortHandle: ArrayBaseSortHandle,\r\n Addition: ArrayBaseAddition,\r\n Remove: ArrayBaseRemove,\r\n MoveDown: ArrayBaseMoveDown,\r\n MoveUp: ArrayBaseMoveUp,\r\n useArray,\r\n useIndex,\r\n useKey,\r\n useRecord,\r\n})\r\n"],"names":["props","__props","self","useField","base","useArray","onAddItemClick","defaultValue","getDefaultValue","_unref","_createBlock","ElLink","prefixCls","Plus","compatibleUnderlineProp","_createTextVNode","_toDisplayString","index","useIndex","_createElementBlock","_renderSlot","_ctx","field","schema","useFieldSchema","provide","ArrayBaseSymbol","useAttrs","ItemSymbol","indexRef","handleClick","isArr","ArrowDown","ArrowUp","Delete","array","Rank","ArrayBase","composeExport","ArrayBaseInner","ArrayBaseIndex","ArrayBaseItem","ArrayBaseSortHandle","ArrayBaseAddition","ArrayBaseRemove","ArrayBaseMoveDown","ArrayBaseMoveUp","useKey","useRecord"],"mappings":";;;;;;;;;;;;;;;;;AAYA,UAAMA,IAAQC,GAIRC,IAAOC,EAAA,GACPC,IAAOC,EAAA;AAEb,aAASC,IAAiB;AACxB,YAAMC,IAAeC,EAAgBR,EAAM,cAAcI,GAAM,OAAO,KAAK;AAC3E,MAAIJ,EAAM,WAAW,aACnBI,GAAM,OAAO,MAAM,QAAQG,CAAY,GACvCH,EAAK,OAAO,MAAM,CAAC,MAGnBA,GAAM,OAAO,MAAM,KAAKG,CAAY,GACpCH,EAAK,OAAO,MAAMA,GAAM,OAAO,OAAO,OAAO,SAAS,CAAC;AAAA,IAE3D;qBAKUK,EAAAL,CAAA,EAAK,MAAM,MAAM,YAAO,mBADhCM,EAUSD,EAAAE,CAAA,GAAA;AAAA;MARN,YAAUF,EAAAG,CAAA,CAAS,WAAA;AAAA,MACnB,MAAMH,EAAAI,CAAA;AAAA,MACN,WAAWJ,EAAAK,CAAA,EAAA;AAAA,MACZ,MAAK;AAAA,MACL,cAAW;AAAA,MACV,SAAOR;AAAA,IAAA;iBAER,MAA+B;AAAA,QAA5BS,EAAAC,EAAAP,EAAAP,CAAA,EAAK,SAASF,EAAM,KAAK,GAAA,CAAA;AAAA,MAAA;;;;;;;;ACnChC,UAAMiB,IAAQC,EAAA;2BAIZC,EAIO,QAAA;AAAA,MAJA,YAAUV,EAAAG,CAAA,CAAS,QAAA;AAAA,IAAA;MACxBQ,EAEOC,EAAA,QAAA,WAAA,EAFA,OAAOZ,EAAAQ,CAAA,EAAA,GAAd,MAEO;AAAA,UAFc,OAClBD,EAAGP,EAAAQ,CAAA,IAAK,CAAA,IAAO,MAClB,CAAA;AAAA,MAAA;;;;;;;;;;;;ACFJ,UAAMjB,IAAQC,GAERqB,IAAQnB,EAAA,GACRoB,IAASC,EAAA;AAEf,WAAAC,EAAQC,GAAiB;AAAA,MACvB,OAAAJ;AAAA,MACA,QAAAC;AAAA,MACA,OAAAvB;AAAA,MACA,OAAO2B,EAAA;AAAA,MACP,QAAQ3B,EAAM;AAAA,IAAA,CACf,aAICoB,EAAQC,EAAA,QAAA,SAAA;AAAA;;;;;;;;;AChBV,WAAAI,EAAQG,GAFM3B,CAEW,aAIvBmB,EAAQC,EAAA,QAAA,SAAA;AAAA;;;;;;;;ACHV,UAAMrB,IAAQC,GAER4B,IAAWX,EAAA,GACXd,IAAOC,EAAA;AAEb,aAASyB,IAAc;AACrB,MAAIC,EAAM3B,GAAM,MAAM,KACpBA,EAAK,OAAO;AAAA,QACVyB,EAAS,QAAQ;AAAA,QACjB;AAAA,QACAzB,EAAK,OAAO,OAAOyB,EAAS,OAAO,CAAC,EAAE,CAAC;AAAA,MAAA,GAG3CzB,GAAM,MAAM,MAAM,SAASyB,EAAS,KAAe,GACnDzB,GAAM,OAAO,WAAWyB,EAAS,KAAe;AAAA,IAClD;qBAKUpB,EAAAL,CAAA,GAAM,MAAM,MAAM,YAAO,mBADjCM,EAaSD,EAAAE,CAAA,GAAA;AAAA;MAXN,YAAUF,EAAAG,CAAA,CAAS,YAAA;AAAA,MACpB,MAAK;AAAA,MACJ,MAAMH,EAAAuB,CAAA;AAAA,MACN,WAAWvB,EAAAK,CAAA,EAAA;AAAA,MACZ,MAAK;AAAA,MACL,cAAW;AAAA,MACV,WAAYgB,GAAW,CAAA,MAAA,CAAA;AAAA,IAAA;iBAExB,MAEO;AAAA,QAFPV,EAEOC,yBAFP,MAEO;AAAA,UADFN,EAAAC,EAAAhB,EAAM,KAAK,GAAA,CAAA;AAAA,QAAA;;;;;;;;;;;;AC9BpB,UAAMA,IAAQC,GAER4B,IAAWX,EAAA,GACXd,IAAOC,EAAA;AAEb,aAASyB,IAAc;AACrB,MAAIC,EAAM3B,GAAM,MAAM,KACpBA,EAAK,OAAO;AAAA,QACVyB,EAAS,QAAQ;AAAA,QACjB;AAAA,QACAzB,EAAK,OAAO,OAAOyB,EAAS,OAAO,CAAC,EAAE,CAAC;AAAA,MAAA,GAG3CzB,GAAM,MAAM,MAAM,OAAOyB,EAAS,KAAe,GACjDzB,GAAM,OAAO,SAASyB,EAAS,KAAe;AAAA,IAChD;qBAKUpB,EAAAL,CAAA,GAAM,MAAM,MAAM,YAAO,mBADjCM,EAaSD,EAAAE,CAAA,GAAA;AAAA;MAXN,YAAUF,EAAAG,CAAA,CAAS,UAAA;AAAA,MACpB,MAAK;AAAA,MACJ,MAAMH,EAAAwB,CAAA;AAAA,MACN,WAAWxB,EAAAK,CAAA,EAAA;AAAA,MACZ,MAAK;AAAA,MACL,cAAW;AAAA,MACV,WAAYgB,GAAW,CAAA,MAAA,CAAA;AAAA,IAAA;iBAExB,MAEO;AAAA,QAFPV,EAEOC,yBAFP,MAEO;AAAA,UADFN,EAAAC,EAAAhB,EAAM,KAAK,GAAA,CAAA;AAAA,QAAA;;;;;;;;;;;;AC9BpB,UAAMA,IAAQC,GAER4B,IAAWX,EAAA,GACXd,IAAOC,EAAA;AAEb,aAASyB,IAAc;AACrB,MAAIC,EAAM3B,GAAM,MAAM,KACpBA,GAAM,QAAQ,OAAOyB,EAAS,OAAO,CAAC,GAGxCzB,GAAM,MAAM,MAAM,OAAOyB,EAAS,KAAe,GACjDzB,GAAM,OAAO,SAASyB,EAAS,KAAe;AAAA,IAChD;qBAKUpB,EAAAL,CAAA,GAAM,MAAM,MAAM,YAAO,mBADjCM,EAaSD,EAAAE,CAAA,GAAA;AAAA;MAXN,YAAUF,EAAAG,CAAA,CAAS,SAAA;AAAA,MACpB,MAAK;AAAA,MACJ,MAAMH,EAAAyB,CAAA;AAAA,MACN,WAAWzB,EAAAK,CAAA,EAAA;AAAA,MACZ,MAAK;AAAA,MACL,cAAW;AAAA,MACV,WAAYgB,GAAW,CAAA,MAAA,CAAA;AAAA,IAAA;iBAExB,MAEO;AAAA,QAFPV,EAEOC,yBAFP,MAEO;AAAA,UADFN,EAAAC,EAAAhB,EAAM,KAAK,GAAA,CAAA;AAAA,QAAA;;;;;;;;;AC7BpB,UAAMmC,IAAQ9B,EAAA;qBAKJI,EAAA0B,CAAA,EAAM,MAAM,OAAO,YAAO,mBADlCzB,EASED,EAAAE,CAAA,GAAA;AAAA;MAPC,YAAUF,EAAAG,CAAA,CAAS,cAAA;AAAA,MACpB,MAAK;AAAA,MACJ,MAAMH,EAAA2B,CAAA;AAAA,MACN,WAAW3B,EAAAK,CAAA,EAAA;AAAA,MACZ,MAAK;AAAA,MACL,cAAW;AAAA,MACX,mBAAgB;AAAA,IAAA;;ICVPuB,KAAYC,EAAcC,GAAgB;AAAA,EACrD,OAAOC;AAAAA,EACP,MAAMC;AAAAA,EACN,YAAYC;AAAAA,EACZ,UAAUC;AAAAA,EACV,QAAQC;AAAAA,EACR,UAAUC;AAAAA,EACV,QAAQC;AAAAA,EACR,UAAAzC;AAAA,EACA,UAAAa;AAAA,EACA,QAAA6B;AAAA,EACA,WAAAC;AACF,CAAC;"}