@silver-formily/element-plus 3.0.0 → 3.0.1
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.
- package/README.en-US.md +32 -32
- package/README.md +32 -32
- package/esm/__builtins__/configs/index.mjs.map +1 -1
- package/esm/__builtins__/index.mjs +18 -18
- package/esm/__builtins__/shared/loading.mjs.map +1 -1
- package/esm/__builtins__/shared/simple-version-compare.mjs.map +1 -1
- package/esm/__builtins__/shared/transform-component.mjs.map +1 -1
- package/esm/__builtins__/shared/use-enter-submit.mjs.map +1 -1
- package/esm/__builtins__/shared/utils.mjs.map +1 -1
- package/esm/array-base/index.mjs +63 -59
- package/esm/array-base/index.mjs.map +1 -1
- package/esm/array-base/symbols.mjs.map +1 -1
- package/esm/array-base/utils.mjs +37 -31
- package/esm/array-base/utils.mjs.map +1 -1
- package/esm/array-cards/index.mjs +36 -33
- package/esm/array-cards/index.mjs.map +1 -1
- package/esm/array-collapse/index.mjs +39 -37
- package/esm/array-collapse/index.mjs.map +1 -1
- package/esm/array-collapse/utils.mjs +9 -2
- package/esm/array-collapse/utils.mjs.map +1 -1
- package/esm/array-items/index.mjs +38 -34
- package/esm/array-items/index.mjs.map +1 -1
- package/esm/array-list-tabs/index.mjs +38 -36
- package/esm/array-list-tabs/index.mjs.map +1 -1
- package/esm/array-list-tabs/utils.mjs +12 -5
- package/esm/array-list-tabs/utils.mjs.map +1 -1
- package/esm/array-table/index.mjs +62 -60
- package/esm/array-table/index.mjs.map +1 -1
- package/esm/array-table/utils.mjs +18 -11
- package/esm/array-table/utils.mjs.map +1 -1
- package/esm/array-tabs/index.mjs +28 -25
- package/esm/array-tabs/index.mjs.map +1 -1
- package/esm/autocomplete/index.mjs +22 -18
- package/esm/autocomplete/index.mjs.map +1 -1
- package/esm/cascader/index.mjs +22 -18
- package/esm/cascader/index.mjs.map +1 -1
- package/esm/checkbox/index.mjs +20 -16
- package/esm/checkbox/index.mjs.map +1 -1
- package/esm/color-picker/index.mjs +9 -6
- package/esm/color-picker/index.mjs.map +1 -1
- package/esm/color-picker-panel/index.mjs +9 -6
- package/esm/color-picker-panel/index.mjs.map +1 -1
- package/esm/date-picker/index.mjs +14 -11
- package/esm/date-picker/index.mjs.map +1 -1
- package/esm/date-picker/utils.mjs.map +1 -1
- package/esm/date-picker-panel/index.mjs +14 -11
- package/esm/date-picker-panel/index.mjs.map +1 -1
- package/esm/editable/index.mjs +33 -30
- package/esm/editable/index.mjs.map +1 -1
- package/esm/form/form.mjs +6 -6
- package/esm/form/form.mjs.map +1 -1
- package/esm/form-button-group/index.mjs +18 -14
- package/esm/form-button-group/index.mjs.map +1 -1
- package/esm/form-button-group/utils.mjs +9 -2
- package/esm/form-button-group/utils.mjs.map +1 -1
- package/esm/form-collapse/index.mjs +21 -18
- package/esm/form-collapse/index.mjs.map +1 -1
- package/esm/form-collapse/utils.mjs.map +1 -1
- package/esm/form-dialog/index.d.ts +1 -1
- package/esm/form-dialog/index.mjs +22 -22
- package/esm/form-dialog/index.mjs.map +1 -1
- package/esm/form-dialog/types.d.ts +13 -5
- package/esm/form-drawer/index.d.ts +1 -1
- package/esm/form-drawer/index.mjs +21 -21
- package/esm/form-drawer/index.mjs.map +1 -1
- package/esm/form-drawer/types.d.ts +13 -5
- package/esm/form-grid/hooks.mjs.map +1 -1
- package/esm/form-grid/index.mjs +21 -18
- package/esm/form-grid/index.mjs.map +1 -1
- package/esm/form-item/index.mjs +55 -53
- package/esm/form-item/index.mjs.map +1 -1
- package/esm/form-item/utils.mjs.map +1 -1
- package/esm/form-layout/form-layout.mjs +14 -10
- package/esm/form-layout/form-layout.mjs.map +1 -1
- package/esm/form-layout/utils.mjs.map +1 -1
- package/esm/form-step/index.mjs +30 -27
- package/esm/form-step/index.mjs.map +1 -1
- package/esm/form-step/utils.mjs.map +1 -1
- package/esm/form-tab/hooks.mjs.map +1 -1
- package/esm/form-tab/index.mjs +25 -23
- package/esm/form-tab/index.mjs.map +1 -1
- package/esm/form-tab/utils.mjs.map +1 -1
- package/esm/index.mjs +72 -72
- package/esm/input/index.mjs +30 -26
- package/esm/input/index.mjs.map +1 -1
- package/esm/input-number/index.mjs +11 -8
- package/esm/input-number/index.mjs.map +1 -1
- package/esm/input-tag/index.mjs +20 -16
- package/esm/input-tag/index.mjs.map +1 -1
- package/esm/mention/index.mjs +24 -20
- package/esm/mention/index.mjs.map +1 -1
- package/esm/pagination/components/jumper.mjs.map +1 -1
- package/esm/pagination/components/next.mjs.map +1 -1
- package/esm/pagination/components/pager.mjs.map +1 -1
- package/esm/pagination/components/prev.mjs.map +1 -1
- package/esm/pagination/components/total.mjs.map +1 -1
- package/esm/pagination/pagination.mjs.map +1 -1
- package/esm/password/index.mjs.map +1 -1
- package/esm/preview-text/index.mjs +31 -27
- package/esm/preview-text/index.mjs.map +1 -1
- package/esm/preview-text/utils.mjs.map +1 -1
- package/esm/query-form/default-components.mjs.map +1 -1
- package/esm/query-form/hooks.mjs.map +1 -1
- package/esm/query-form/index.mjs +51 -48
- package/esm/query-form/index.mjs.map +1 -1
- package/esm/query-form-item/index.mjs +37 -34
- package/esm/query-form-item/index.mjs.map +1 -1
- package/esm/radio/index.mjs +29 -25
- package/esm/radio/index.mjs.map +1 -1
- package/esm/rate/index.mjs +13 -10
- package/esm/rate/index.mjs.map +1 -1
- package/esm/reset/index.mjs.map +1 -1
- package/esm/segmented/index.mjs +16 -12
- package/esm/segmented/index.mjs.map +1 -1
- package/esm/select/index.mjs +26 -22
- package/esm/select/index.mjs.map +1 -1
- package/esm/select-table/index.mjs +16 -12
- package/esm/select-table/index.mjs.map +1 -1
- package/esm/shared/overlay-elements.mjs.map +1 -1
- package/esm/slider/index.mjs +13 -10
- package/esm/slider/index.mjs.map +1 -1
- package/esm/submit/index.mjs.map +1 -1
- package/esm/switch/index.mjs.map +1 -1
- package/esm/time-picker/index.mjs +9 -6
- package/esm/time-picker/index.mjs.map +1 -1
- package/esm/time-select/index.mjs +9 -6
- package/esm/time-select/index.mjs.map +1 -1
- package/esm/transfer/index.mjs.map +1 -1
- package/esm/tree/index.mjs +33 -29
- package/esm/tree/index.mjs.map +1 -1
- package/esm/tree/utils.mjs.map +1 -1
- package/esm/tree-select/index.mjs +18 -14
- package/esm/tree-select/index.mjs.map +1 -1
- package/esm/upload/index.mjs +10 -7
- package/esm/upload/index.mjs.map +1 -1
- package/esm/vendor/sizes.mjs.map +1 -1
- package/package.json +6 -5
package/README.en-US.md
CHANGED
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
# Silver Formily Element Plus
|
|
2
|
-
|
|
3
|
-
[](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
|
+
[](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
|
-
[](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
|
+
[](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'\
|
|
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,23 +1,23 @@
|
|
|
1
1
|
import { stylePrefix as r } from "./configs/index.mjs";
|
|
2
|
-
import {
|
|
3
|
-
import { getTransitionDuration as
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
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";
|
|
7
7
|
export {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
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,
|
|
19
19
|
r as stylePrefix,
|
|
20
|
-
|
|
21
|
-
|
|
20
|
+
y as useCleanAttrs,
|
|
21
|
+
s 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'\
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"simple-version-compare.mjs","sources":["../../../src/__builtins__/shared/simple-version-compare.ts"],"sourcesContent":["function normalizeVersion(v: string) {\
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transform-component.mjs","sources":["../../../src/__builtins__/shared/transform-component.ts"],"sourcesContent":["import type { IComponentMapper } from '@silver-formily/vue'\
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-enter-submit.mjs","sources":["../../../src/__builtins__/shared/use-enter-submit.ts"],"sourcesContent":["import type { Ref } from 'vue'\
|
|
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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.mjs","sources":["../../../src/__builtins__/shared/utils.ts"],"sourcesContent":["import type { Component, ComputedRef, Slot, VNode } from 'vue'\
|
|
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;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;"}
|
package/esm/array-base/index.mjs
CHANGED
|
@@ -1,12 +1,16 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
6
|
-
import
|
|
1
|
+
import { ElLink as m } from "element-plus";
|
|
2
|
+
import "@formily/reactive";
|
|
3
|
+
import "@vueuse/core";
|
|
4
|
+
import { defineComponent as l, unref as a, openBlock as i, createBlock as f, normalizeClass as c, withCtx as h, createTextVNode as _, toDisplayString as v, createCommentVNode 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";
|
|
7
11
|
import { ArrayBaseSymbol as H, ItemSymbol as N } from "./symbols.mjs";
|
|
8
12
|
import { isArr as x } from "@formily/shared";
|
|
9
|
-
import '../styles/array-base/index.css';const P = /* @__PURE__ */
|
|
13
|
+
import '../styles/array-base/index.css';const P = /* @__PURE__ */ l({
|
|
10
14
|
name: "ArrayBaseAddition",
|
|
11
15
|
__name: "array-base-addition",
|
|
12
16
|
props: {
|
|
@@ -16,39 +20,39 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ o({
|
|
|
16
20
|
},
|
|
17
21
|
setup(n) {
|
|
18
22
|
const r = n, t = B(), e = p();
|
|
19
|
-
function
|
|
20
|
-
const s =
|
|
23
|
+
function o() {
|
|
24
|
+
const s = g(r.defaultValue, e?.schema.value);
|
|
21
25
|
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));
|
|
22
26
|
}
|
|
23
|
-
return (s, A) => a(e).field.value.pattern === "editable" ? (i(),
|
|
27
|
+
return (s, A) => a(e).field.value.pattern === "editable" ? (i(), f(a(m), {
|
|
24
28
|
key: 0,
|
|
25
29
|
class: c(`${a(d)}-addition`),
|
|
26
|
-
icon: a(
|
|
27
|
-
underline: a(
|
|
30
|
+
icon: a(R),
|
|
31
|
+
underline: a(b)(),
|
|
28
32
|
role: "button",
|
|
29
33
|
"aria-label": "添加条目",
|
|
30
|
-
onClick:
|
|
34
|
+
onClick: o
|
|
31
35
|
}, {
|
|
32
36
|
default: h(() => [
|
|
33
|
-
|
|
37
|
+
_(v(a(t).title || r.title), 1)
|
|
34
38
|
]),
|
|
35
39
|
_: 1
|
|
36
|
-
}, 8, ["class", "icon", "underline"])) :
|
|
40
|
+
}, 8, ["class", "icon", "underline"])) : y("", !0);
|
|
37
41
|
}
|
|
38
|
-
}), K = /* @__PURE__ */
|
|
42
|
+
}), K = /* @__PURE__ */ l({
|
|
39
43
|
name: "ArrayBaseIndex",
|
|
40
44
|
__name: "array-base-index",
|
|
41
45
|
setup(n) {
|
|
42
|
-
const r =
|
|
46
|
+
const r = k();
|
|
43
47
|
return (t, e) => (i(), C("span", {
|
|
44
48
|
class: c(`${a(d)}-index`)
|
|
45
49
|
}, [
|
|
46
50
|
u(t.$slots, "default", { index: a(r) }, () => [
|
|
47
|
-
|
|
51
|
+
_(" #" + v(a(r) + 1) + ". ", 1)
|
|
48
52
|
])
|
|
49
53
|
], 2));
|
|
50
54
|
}
|
|
51
|
-
}), L = /* @__PURE__ */
|
|
55
|
+
}), L = /* @__PURE__ */ l({
|
|
52
56
|
name: "ArrayBaseInner",
|
|
53
57
|
inheritAttrs: !1,
|
|
54
58
|
__name: "array-base-inner",
|
|
@@ -57,16 +61,16 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ o({
|
|
|
57
61
|
keyMap: {}
|
|
58
62
|
},
|
|
59
63
|
setup(n) {
|
|
60
|
-
const r = n, t = B(), e =
|
|
64
|
+
const r = n, t = B(), e = D();
|
|
61
65
|
return M(H, {
|
|
62
66
|
field: t,
|
|
63
67
|
schema: e,
|
|
64
68
|
props: r,
|
|
65
69
|
attrs: w(),
|
|
66
70
|
keyMap: r.keyMap
|
|
67
|
-
}), (
|
|
71
|
+
}), (o, s) => u(o.$slots, "default");
|
|
68
72
|
}
|
|
69
|
-
}), T = /* @__PURE__ */
|
|
73
|
+
}), T = /* @__PURE__ */ l({
|
|
70
74
|
name: "ArrayBaseItem",
|
|
71
75
|
__name: "array-base-item",
|
|
72
76
|
props: {
|
|
@@ -76,118 +80,118 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ o({
|
|
|
76
80
|
setup(n) {
|
|
77
81
|
return M(N, n), (t, e) => u(t.$slots, "default");
|
|
78
82
|
}
|
|
79
|
-
}), j = /* @__PURE__ */
|
|
83
|
+
}), j = /* @__PURE__ */ l({
|
|
80
84
|
name: "ArrayBaseMoveDown",
|
|
81
85
|
__name: "array-base-move-down",
|
|
82
86
|
props: {
|
|
83
87
|
title: {}
|
|
84
88
|
},
|
|
85
89
|
setup(n) {
|
|
86
|
-
const r = n, t =
|
|
87
|
-
function
|
|
90
|
+
const r = n, t = k(), e = p();
|
|
91
|
+
function o() {
|
|
88
92
|
x(e?.keyMap) && e.keyMap.splice(
|
|
89
93
|
t.value + 1,
|
|
90
94
|
0,
|
|
91
95
|
e.keyMap.splice(t.value, 1)[0]
|
|
92
96
|
), e?.field.value.moveDown(t.value), e?.attrs?.moveDown?.(t.value);
|
|
93
97
|
}
|
|
94
|
-
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(),
|
|
98
|
+
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
|
|
95
99
|
key: 0,
|
|
96
100
|
class: c(`${a(d)}-move-down`),
|
|
97
101
|
size: "small",
|
|
98
|
-
icon: a(
|
|
99
|
-
underline: a(
|
|
102
|
+
icon: a(S),
|
|
103
|
+
underline: a(b)(),
|
|
100
104
|
role: "button",
|
|
101
105
|
"aria-label": "下移条目",
|
|
102
|
-
onClick: $(
|
|
106
|
+
onClick: $(o, ["stop"])
|
|
103
107
|
}, {
|
|
104
108
|
default: h(() => [
|
|
105
109
|
u(s.$slots, "default", {}, () => [
|
|
106
|
-
|
|
110
|
+
_(v(r.title), 1)
|
|
107
111
|
])
|
|
108
112
|
]),
|
|
109
113
|
_: 3
|
|
110
|
-
}, 8, ["class", "icon", "underline"])) :
|
|
114
|
+
}, 8, ["class", "icon", "underline"])) : y("", !0);
|
|
111
115
|
}
|
|
112
|
-
}), q = /* @__PURE__ */
|
|
116
|
+
}), q = /* @__PURE__ */ l({
|
|
113
117
|
name: "ArrayBaseMoveUp",
|
|
114
118
|
__name: "array-base-move-up",
|
|
115
119
|
props: {
|
|
116
120
|
title: {}
|
|
117
121
|
},
|
|
118
122
|
setup(n) {
|
|
119
|
-
const r = n, t =
|
|
120
|
-
function
|
|
123
|
+
const r = n, t = k(), e = p();
|
|
124
|
+
function o() {
|
|
121
125
|
x(e?.keyMap) && e.keyMap.splice(
|
|
122
126
|
t.value - 1,
|
|
123
127
|
0,
|
|
124
128
|
e.keyMap.splice(t.value, 1)[0]
|
|
125
129
|
), e?.field.value.moveUp(t.value), e?.attrs?.moveUp?.(t.value);
|
|
126
130
|
}
|
|
127
|
-
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(),
|
|
131
|
+
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
|
|
128
132
|
key: 0,
|
|
129
133
|
class: c(`${a(d)}-move-up`),
|
|
130
134
|
size: "small",
|
|
131
|
-
icon: a(
|
|
132
|
-
underline: a(
|
|
135
|
+
icon: a(U),
|
|
136
|
+
underline: a(b)(),
|
|
133
137
|
role: "button",
|
|
134
138
|
"aria-label": "上移条目",
|
|
135
|
-
onClick: $(
|
|
139
|
+
onClick: $(o, ["stop"])
|
|
136
140
|
}, {
|
|
137
141
|
default: h(() => [
|
|
138
142
|
u(s.$slots, "default", {}, () => [
|
|
139
|
-
|
|
143
|
+
_(v(r.title), 1)
|
|
140
144
|
])
|
|
141
145
|
]),
|
|
142
146
|
_: 3
|
|
143
|
-
}, 8, ["class", "icon", "underline"])) :
|
|
147
|
+
}, 8, ["class", "icon", "underline"])) : y("", !0);
|
|
144
148
|
}
|
|
145
|
-
}), G = /* @__PURE__ */
|
|
149
|
+
}), G = /* @__PURE__ */ l({
|
|
146
150
|
name: "ArrayBaseRemove",
|
|
147
151
|
__name: "array-base-remove",
|
|
148
152
|
props: {
|
|
149
153
|
title: {}
|
|
150
154
|
},
|
|
151
155
|
setup(n) {
|
|
152
|
-
const r = n, t =
|
|
153
|
-
function
|
|
156
|
+
const r = n, t = k(), e = p();
|
|
157
|
+
function o() {
|
|
154
158
|
x(e?.keyMap) && e?.keyMap?.splice(t.value, 1), e?.field.value.remove(t.value), e?.attrs?.remove?.(t.value);
|
|
155
159
|
}
|
|
156
|
-
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(),
|
|
160
|
+
return (s, A) => a(e)?.field.value.pattern === "editable" ? (i(), f(a(m), {
|
|
157
161
|
key: 0,
|
|
158
162
|
class: c(`${a(d)}-remove`),
|
|
159
163
|
size: "small",
|
|
160
|
-
icon: a(
|
|
161
|
-
underline: a(
|
|
164
|
+
icon: a(V),
|
|
165
|
+
underline: a(b)(),
|
|
162
166
|
role: "button",
|
|
163
167
|
"aria-label": "移除条目",
|
|
164
|
-
onClick: $(
|
|
168
|
+
onClick: $(o, ["stop"])
|
|
165
169
|
}, {
|
|
166
170
|
default: h(() => [
|
|
167
171
|
u(s.$slots, "default", {}, () => [
|
|
168
|
-
|
|
172
|
+
_(v(r.title), 1)
|
|
169
173
|
])
|
|
170
174
|
]),
|
|
171
175
|
_: 3
|
|
172
|
-
}, 8, ["class", "icon", "underline"])) :
|
|
176
|
+
}, 8, ["class", "icon", "underline"])) : y("", !0);
|
|
173
177
|
}
|
|
174
|
-
}), J = /* @__PURE__ */
|
|
178
|
+
}), J = /* @__PURE__ */ l({
|
|
175
179
|
name: "ArrayBaseSortHandle",
|
|
176
180
|
__name: "array-base-sort-handle",
|
|
177
181
|
setup(n) {
|
|
178
182
|
const r = p();
|
|
179
|
-
return (t, e) => a(r).field.value?.pattern === "editable" ? (i(),
|
|
183
|
+
return (t, e) => a(r).field.value?.pattern === "editable" ? (i(), f(a(m), {
|
|
180
184
|
key: 0,
|
|
181
185
|
class: c(`${a(d)}-sort-handle`),
|
|
182
186
|
size: "small",
|
|
183
|
-
icon: a(
|
|
184
|
-
underline: a(
|
|
187
|
+
icon: a(z),
|
|
188
|
+
underline: a(b)(),
|
|
185
189
|
role: "button",
|
|
186
190
|
"aria-label": "拖拽排序",
|
|
187
191
|
"aria-dropeffect": "move"
|
|
188
|
-
}, null, 8, ["class", "icon", "underline"])) :
|
|
192
|
+
}, null, 8, ["class", "icon", "underline"])) : y("", !0);
|
|
189
193
|
}
|
|
190
|
-
}),
|
|
194
|
+
}), oe = I(L, {
|
|
191
195
|
Index: K,
|
|
192
196
|
Item: T,
|
|
193
197
|
SortHandle: J,
|
|
@@ -196,11 +200,11 @@ import '../styles/array-base/index.css';const P = /* @__PURE__ */ o({
|
|
|
196
200
|
MoveDown: j,
|
|
197
201
|
MoveUp: q,
|
|
198
202
|
useArray: p,
|
|
199
|
-
useIndex:
|
|
200
|
-
useKey:
|
|
201
|
-
useRecord:
|
|
203
|
+
useIndex: k,
|
|
204
|
+
useKey: F,
|
|
205
|
+
useRecord: E
|
|
202
206
|
});
|
|
203
207
|
export {
|
|
204
|
-
|
|
208
|
+
oe as ArrayBase
|
|
205
209
|
};
|
|
206
210
|
//# 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>\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":"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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>\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 +1 @@
|
|
|
1
|
-
{"version":3,"file":"symbols.mjs","sources":["../../src/array-base/symbols.ts"],"sourcesContent":["import type { InjectionKey } from 'vue'\
|
|
1
|
+
{"version":3,"file":"symbols.mjs","sources":["../../src/array-base/symbols.ts"],"sourcesContent":["import type { InjectionKey } from 'vue'\nimport type { IArrayBaseContext, IArrayBaseItemProps } from './types'\n\nexport const ArrayBaseSymbol: InjectionKey<IArrayBaseContext> = Symbol('ArrayBaseContext')\nexport const ItemSymbol: InjectionKey<IArrayBaseItemProps> = Symbol('ItemContext')\n"],"names":["ArrayBaseSymbol","ItemSymbol"],"mappings":"AAGO,MAAMA,2BAA0D,kBAAkB,GAC5EC,2BAAuD,aAAa;"}
|