yc-design-vue 2.1.0 → 2.1.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/dist/index.umd.js +1 -1
- package/es/Progress/ProgressCircle.vue.js +1 -1
- package/es/Typography/TypographyBase.vue.js +2 -2
- package/es/Upload/Upload.vue.js +5 -1
- package/es/Upload/UploadButton.vue.js +3 -1
- package/es/Upload/UploadDrag.vue.d.ts +4 -1
- package/es/Upload/UploadDrag.vue.js +9 -3
- package/es/Upload/hooks/useUpload.d.ts +2 -0
- package/es/Upload/hooks/useUpload.js +2 -1
- package/es/_shared/icons/IconCopy.vue.js +1 -19
- package/es/_shared/icons/IconCopy.vue2.js +19 -1
- package/es/_shared/icons/IconEdit.vue.js +1 -19
- package/es/_shared/icons/IconEdit.vue2.js +19 -1
- package/es/_shared/icons/IconExclamation.vue.js +1 -30
- package/es/_shared/icons/IconExclamation.vue2.js +30 -1
- package/lib/Progress/ProgressCircle.vue.js +1 -1
- package/lib/Typography/TypographyBase.vue.js +1 -1
- package/lib/Upload/Upload.vue.js +1 -1
- package/lib/Upload/UploadButton.vue.js +1 -1
- package/lib/Upload/UploadDrag.vue.d.ts +4 -1
- package/lib/Upload/UploadDrag.vue.js +1 -1
- package/lib/Upload/hooks/useUpload.d.ts +2 -0
- package/lib/Upload/hooks/useUpload.js +1 -1
- package/lib/_shared/icons/IconCopy.vue.js +1 -1
- package/lib/_shared/icons/IconCopy.vue2.js +1 -1
- package/lib/_shared/icons/IconEdit.vue.js +1 -1
- package/lib/_shared/icons/IconEdit.vue2.js +1 -1
- package/lib/_shared/icons/IconExclamation.vue.js +1 -1
- package/lib/_shared/icons/IconExclamation.vue2.js +1 -1
- package/package.json +1 -1
@@ -5,7 +5,7 @@ import { valueToPx } from "../_shared/utils/dom.js";
|
|
5
5
|
/* empty css */
|
6
6
|
/* empty css */
|
7
7
|
import _sfc_main$1 from "../_shared/icons/IconCheck.vue.js";
|
8
|
-
import _sfc_main$2 from "../_shared/icons/IconExclamation.
|
8
|
+
import _sfc_main$2 from "../_shared/icons/IconExclamation.vue2.js";
|
9
9
|
import { TYPE_ICON_COLOR_MAP } from "../_shared/constants/index.js";
|
10
10
|
const _hoisted_1 = ["aria-valuenow"];
|
11
11
|
const _hoisted_2 = ["viewBox"];
|
@@ -6,8 +6,8 @@ import { useClipboard } from "../node_modules/@vueuse/core/index.js";
|
|
6
6
|
/* empty css */
|
7
7
|
/* empty css */
|
8
8
|
/* empty css */
|
9
|
-
import _sfc_main$3 from "../_shared/icons/IconCopy.
|
10
|
-
import _sfc_main$1 from "../_shared/icons/IconEdit.
|
9
|
+
import _sfc_main$3 from "../_shared/icons/IconCopy.vue2.js";
|
10
|
+
import _sfc_main$1 from "../_shared/icons/IconEdit.vue2.js";
|
11
11
|
import _sfc_main$2 from "../_shared/icons/IconInfo.vue.js";
|
12
12
|
import Input from "../Input/index.js";
|
13
13
|
import Tooltip from "../Tooltip/index.js";
|
package/es/Upload/Upload.vue.js
CHANGED
@@ -48,6 +48,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
48
48
|
limit,
|
49
49
|
draggable,
|
50
50
|
disabled,
|
51
|
+
isOverDropZone,
|
51
52
|
handleFiles,
|
52
53
|
handleUpload
|
53
54
|
} = useUpload(uploadRef, props, emits);
|
@@ -93,7 +94,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
93
94
|
(...args) => unref(handleUpload) && unref(handleUpload)(...args))
|
94
95
|
}, [
|
95
96
|
unref(limit) <= 0 || unref(computedFileList).length < unref(limit) ? renderSlot(_ctx.$slots, "upload-button", { key: 0 }, () => [
|
96
|
-
unref(draggable) ? (openBlock(), createBlock(_sfc_main$1, {
|
97
|
+
unref(draggable) ? (openBlock(), createBlock(_sfc_main$1, {
|
98
|
+
key: 0,
|
99
|
+
"is-over-drop-zone": unref(isOverDropZone)
|
100
|
+
}, null, 8, ["is-over-drop-zone"])) : (openBlock(), createBlock(_sfc_main$2, { key: 1 }))
|
97
101
|
]) : createCommentVNode("", true)
|
98
102
|
], 2)) : createCommentVNode("", true),
|
99
103
|
_ctx.showFileList && unref(computedFileList).length ? (openBlock(), createBlock(UploadFileList, { key: 1 }, createSlots({ _: 2 }, [
|
@@ -5,6 +5,7 @@ import "../_shared/utils/dom.js";
|
|
5
5
|
/* empty css */
|
6
6
|
/* empty css */
|
7
7
|
import _sfc_main$1 from "../_shared/icons/IconUpload.vue2.js";
|
8
|
+
import { useI18n } from "../_shared/utils/locale.js";
|
8
9
|
import Button from "../Button/index.js";
|
9
10
|
const _hoisted_1 = { class: "yc-upload-button" };
|
10
11
|
const _hoisted_2 = {
|
@@ -15,6 +16,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
15
16
|
__name: "UploadButton",
|
16
17
|
setup(__props) {
|
17
18
|
const { tip, disabled } = useUploadContext().inject();
|
19
|
+
const { t } = useI18n();
|
18
20
|
return (_ctx, _cache) => {
|
19
21
|
return openBlock(), createElementBlock("div", _hoisted_1, [
|
20
22
|
createVNode(unref(Button), {
|
@@ -25,7 +27,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
25
27
|
createVNode(unref(_sfc_main$1))
|
26
28
|
]),
|
27
29
|
default: withCtx(() => [
|
28
|
-
|
30
|
+
createTextVNode(" " + toDisplayString(unref(t)("upload.buttonText")), 1)
|
29
31
|
]),
|
30
32
|
_: 1
|
31
33
|
}, 8, ["disabled"]),
|
@@ -1,2 +1,5 @@
|
|
1
|
-
|
1
|
+
type __VLS_Props = {
|
2
|
+
isOverDropZone: boolean;
|
3
|
+
};
|
4
|
+
declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
|
2
5
|
export default _default;
|
@@ -5,15 +5,21 @@ import "../_shared/utils/dom.js";
|
|
5
5
|
/* empty css */
|
6
6
|
/* empty css */
|
7
7
|
import _sfc_main$1 from "../_shared/icons/IconPlus.vue.js";
|
8
|
+
import { useI18n } from "../_shared/utils/locale.js";
|
8
9
|
const _hoisted_1 = { class: "yc-upload-drag-icon" };
|
9
|
-
const _hoisted_2 = {
|
10
|
+
const _hoisted_2 = { class: "yc-upload-drag-text" };
|
11
|
+
const _hoisted_3 = {
|
10
12
|
key: 0,
|
11
13
|
class: "yc-upload-tip text-ellipsis"
|
12
14
|
};
|
13
15
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
14
16
|
__name: "UploadDrag",
|
17
|
+
props: {
|
18
|
+
isOverDropZone: { type: Boolean }
|
19
|
+
},
|
15
20
|
setup(__props) {
|
16
21
|
const { tip, disabled } = useUploadContext().inject();
|
22
|
+
const { t } = useI18n();
|
17
23
|
return (_ctx, _cache) => {
|
18
24
|
return openBlock(), createElementBlock("div", {
|
19
25
|
class: normalizeClass([
|
@@ -26,8 +32,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
26
32
|
createElementVNode("div", _hoisted_1, [
|
27
33
|
createVNode(unref(_sfc_main$1))
|
28
34
|
]),
|
29
|
-
|
30
|
-
unref(tip) ? (openBlock(), createElementBlock("div",
|
35
|
+
createElementVNode("div", _hoisted_2, toDisplayString(unref(t)(`upload.${_ctx.isOverDropZone ? "dragHover" : "drag"}`)), 1),
|
36
|
+
unref(tip) ? (openBlock(), createElementBlock("div", _hoisted_3, toDisplayString(unref(tip)), 1)) : createCommentVNode("", true)
|
31
37
|
], 2);
|
32
38
|
};
|
33
39
|
}
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { FileItem, UploadEmits, UploadProps } from '../type';
|
2
2
|
import { Ref } from 'vue';
|
3
3
|
export default function useUpload(uploadRef: Ref<HTMLDivElement | undefined>, _props?: UploadProps, _emits?: UploadEmits): {
|
4
|
+
isOverDropZone: import('vue').ShallowRef<boolean>;
|
4
5
|
handleUpload: (e: MouseEvent) => Promise<void>;
|
5
6
|
handleFiles: (fileData: File[] | FileList | null) => Promise<void>;
|
6
7
|
computedFileList: Ref<FileItem[]>;
|
@@ -26,6 +27,7 @@ export default function useUpload(uploadRef: Ref<HTMLDivElement | undefined>, _p
|
|
26
27
|
handleDelFile: (fileItem: FileItem) => Promise<void>;
|
27
28
|
emits: UploadEmits;
|
28
29
|
} | {
|
30
|
+
isOverDropZone: import('vue').ShallowRef<boolean>;
|
29
31
|
handleUpload: (e: MouseEvent) => Promise<void>;
|
30
32
|
handleFiles: (fileData: File[] | FileList | null) => Promise<void>;
|
31
33
|
computedFileList: import('vue').WritableComputedRef<FileItem[], FileItem[]>;
|
@@ -29,7 +29,7 @@ function useUpload(uploadRef, _props, _emits) {
|
|
29
29
|
reset: true
|
30
30
|
});
|
31
31
|
onChange((files) => handleFiles(files));
|
32
|
-
useDropZone(uploadRef, {
|
32
|
+
const { isOverDropZone } = useDropZone(uploadRef, {
|
33
33
|
dataTypes: accept.value ? accept.value.split(",") : void 0,
|
34
34
|
multiple: multiple.value,
|
35
35
|
preventDefaultForUnhandled: true,
|
@@ -94,6 +94,7 @@ function useUpload(uploadRef, _props, _emits) {
|
|
94
94
|
};
|
95
95
|
return {
|
96
96
|
...context,
|
97
|
+
isOverDropZone,
|
97
98
|
handleUpload,
|
98
99
|
handleFiles
|
99
100
|
};
|
@@ -1,22 +1,4 @@
|
|
1
|
-
import
|
2
|
-
import "../utils/dom.js";
|
3
|
-
/* empty css */
|
4
|
-
/* empty css */
|
5
|
-
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
-
/* empty css */
|
7
|
-
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
-
__name: "IconCopy",
|
9
|
-
setup(__props) {
|
10
|
-
return (_ctx, _cache) => {
|
11
|
-
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
-
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
-
createElementVNode("path", { d: "M20 6h18a2 2 0 0 1 2 2v22M8 16v24c0 1.105.891 2 1.996 2h20.007A1.99 1.99 0 0 0 32 40.008V15.997A1.997 1.997 0 0 0 30 14H10a2 2 0 0 0-2 2Z" }, null, -1)
|
14
|
-
])]),
|
15
|
-
_: 1
|
16
|
-
}, 16);
|
17
|
-
};
|
18
|
-
}
|
19
|
-
});
|
1
|
+
import _sfc_main from "./IconCopy.vue2.js";
|
20
2
|
export {
|
21
3
|
_sfc_main as default
|
22
4
|
};
|
@@ -1,4 +1,22 @@
|
|
1
|
-
import
|
1
|
+
import { defineComponent, createBlock, openBlock, unref, normalizeProps, guardReactiveProps, withCtx, createElementVNode } from "vue";
|
2
|
+
import "../utils/dom.js";
|
3
|
+
/* empty css */
|
4
|
+
/* empty css */
|
5
|
+
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
+
/* empty css */
|
7
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
+
__name: "IconCopy",
|
9
|
+
setup(__props) {
|
10
|
+
return (_ctx, _cache) => {
|
11
|
+
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
+
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
+
createElementVNode("path", { d: "M20 6h18a2 2 0 0 1 2 2v22M8 16v24c0 1.105.891 2 1.996 2h20.007A1.99 1.99 0 0 0 32 40.008V15.997A1.997 1.997 0 0 0 30 14H10a2 2 0 0 0-2 2Z" }, null, -1)
|
14
|
+
])]),
|
15
|
+
_: 1
|
16
|
+
}, 16);
|
17
|
+
};
|
18
|
+
}
|
19
|
+
});
|
2
20
|
export {
|
3
21
|
_sfc_main as default
|
4
22
|
};
|
@@ -1,22 +1,4 @@
|
|
1
|
-
import
|
2
|
-
import "../utils/dom.js";
|
3
|
-
/* empty css */
|
4
|
-
/* empty css */
|
5
|
-
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
-
/* empty css */
|
7
|
-
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
-
__name: "IconEdit",
|
9
|
-
setup(__props) {
|
10
|
-
return (_ctx, _cache) => {
|
11
|
-
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
-
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
-
createElementVNode("path", { d: "m30.48 19.038 5.733-5.734a1 1 0 0 0 0-1.414l-5.586-5.586a1 1 0 0 0-1.414 0l-5.734 5.734m7 7L15.763 33.754a1 1 0 0 1-.59.286l-6.048.708a1 1 0 0 1-1.113-1.069l.477-6.31a1 1 0 0 1 .29-.631l14.7-14.7m7 7-7-7M6 42h36" }, null, -1)
|
14
|
-
])]),
|
15
|
-
_: 1
|
16
|
-
}, 16);
|
17
|
-
};
|
18
|
-
}
|
19
|
-
});
|
1
|
+
import _sfc_main from "./IconEdit.vue2.js";
|
20
2
|
export {
|
21
3
|
_sfc_main as default
|
22
4
|
};
|
@@ -1,4 +1,22 @@
|
|
1
|
-
import
|
1
|
+
import { defineComponent, createBlock, openBlock, unref, normalizeProps, guardReactiveProps, withCtx, createElementVNode } from "vue";
|
2
|
+
import "../utils/dom.js";
|
3
|
+
/* empty css */
|
4
|
+
/* empty css */
|
5
|
+
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
+
/* empty css */
|
7
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
+
__name: "IconEdit",
|
9
|
+
setup(__props) {
|
10
|
+
return (_ctx, _cache) => {
|
11
|
+
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
+
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
+
createElementVNode("path", { d: "m30.48 19.038 5.733-5.734a1 1 0 0 0 0-1.414l-5.586-5.586a1 1 0 0 0-1.414 0l-5.734 5.734m7 7L15.763 33.754a1 1 0 0 1-.59.286l-6.048.708a1 1 0 0 1-1.113-1.069l.477-6.31a1 1 0 0 1 .29-.631l14.7-14.7m7 7-7-7M6 42h36" }, null, -1)
|
14
|
+
])]),
|
15
|
+
_: 1
|
16
|
+
}, 16);
|
17
|
+
};
|
18
|
+
}
|
19
|
+
});
|
2
20
|
export {
|
3
21
|
_sfc_main as default
|
4
22
|
};
|
@@ -1,33 +1,4 @@
|
|
1
|
-
import
|
2
|
-
import "../utils/dom.js";
|
3
|
-
/* empty css */
|
4
|
-
/* empty css */
|
5
|
-
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
-
/* empty css */
|
7
|
-
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
-
__name: "IconExclamation",
|
9
|
-
setup(__props) {
|
10
|
-
return (_ctx, _cache) => {
|
11
|
-
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
-
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
-
createElementVNode("path", { d: "M23 9h2v21h-2z" }, null, -1),
|
14
|
-
createElementVNode("path", {
|
15
|
-
fill: "currentColor",
|
16
|
-
stroke: "none",
|
17
|
-
d: "M23 9h2v21h-2z"
|
18
|
-
}, null, -1),
|
19
|
-
createElementVNode("path", { d: "M23 37h2v2h-2z" }, null, -1),
|
20
|
-
createElementVNode("path", {
|
21
|
-
fill: "currentColor",
|
22
|
-
stroke: "none",
|
23
|
-
d: "M23 37h2v2h-2z"
|
24
|
-
}, null, -1)
|
25
|
-
])]),
|
26
|
-
_: 1
|
27
|
-
}, 16);
|
28
|
-
};
|
29
|
-
}
|
30
|
-
});
|
1
|
+
import _sfc_main from "./IconExclamation.vue2.js";
|
31
2
|
export {
|
32
3
|
_sfc_main as default
|
33
4
|
};
|
@@ -1,4 +1,33 @@
|
|
1
|
-
import
|
1
|
+
import { defineComponent, createBlock, openBlock, unref, normalizeProps, guardReactiveProps, withCtx, createElementVNode } from "vue";
|
2
|
+
import "../utils/dom.js";
|
3
|
+
/* empty css */
|
4
|
+
/* empty css */
|
5
|
+
import _sfc_main$1 from "../components/Icon/index.vue3.js";
|
6
|
+
/* empty css */
|
7
|
+
const _sfc_main = /* @__PURE__ */ defineComponent({
|
8
|
+
__name: "IconExclamation",
|
9
|
+
setup(__props) {
|
10
|
+
return (_ctx, _cache) => {
|
11
|
+
return openBlock(), createBlock(unref(_sfc_main$1), normalizeProps(guardReactiveProps(_ctx.$attrs)), {
|
12
|
+
default: withCtx(() => [..._cache[0] || (_cache[0] = [
|
13
|
+
createElementVNode("path", { d: "M23 9h2v21h-2z" }, null, -1),
|
14
|
+
createElementVNode("path", {
|
15
|
+
fill: "currentColor",
|
16
|
+
stroke: "none",
|
17
|
+
d: "M23 9h2v21h-2z"
|
18
|
+
}, null, -1),
|
19
|
+
createElementVNode("path", { d: "M23 37h2v2h-2z" }, null, -1),
|
20
|
+
createElementVNode("path", {
|
21
|
+
fill: "currentColor",
|
22
|
+
stroke: "none",
|
23
|
+
d: "M23 37h2v2h-2z"
|
24
|
+
}, null, -1)
|
25
|
+
])]),
|
26
|
+
_: 1
|
27
|
+
}, 16);
|
28
|
+
};
|
29
|
+
}
|
30
|
+
});
|
2
31
|
export {
|
3
32
|
_sfc_main as default
|
4
33
|
};
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),r=require("../_shared/utils/is.js"),l=require("../_shared/utils/dom.js");,/* empty css */,/* empty css */;/* empty css */const t=require("../_shared/icons/IconCheck.vue.js"),o=require("../_shared/icons/IconExclamation.
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),r=require("../_shared/utils/is.js"),l=require("../_shared/utils/dom.js");,/* empty css */,/* empty css */;/* empty css */const t=require("../_shared/icons/IconCheck.vue.js"),o=require("../_shared/icons/IconExclamation.vue2.js"),s=require("../_shared/constants/index.js"),a=["aria-valuenow"],c=["viewBox"],n={key:0},u=["id"],i=["offset","stop-color"],d=["cx","cy","r","stroke-width"],p=["cx","cy","r","stroke-width"],m={key:2,class:e.normalizeClass("yc-progress-circle-text")},v=e.defineComponent({__name:"ProgressCircle",props:{type:{},percent:{},status:{},size:{},text:{},showText:{type:Boolean},width:{},strokeWidth:{},pathStrokeWidth:{},color:{},trackColor:{}},setup(v){const k=v,{size:f,width:y,color:h,strokeWidth:x,pathStrokeWidth:B}=e.toRefs(k);let _=0;const g=e.computed(()=>r.isObject(h.value)),C=e.computed(()=>x.value??("mini"===f.value?y.value/2:{mini:4,small:3,medium:4,large:4}[f.value])),E=e.computed(()=>B.value?B.value:"mini"===f.value?C.value:Math.max(2,C.value-2)),w=e.computed(()=>(y.value-C.value)/2),O=e.computed(()=>2*Math.PI*w.value),j=e.computed(()=>y.value/2),z=e.computed(()=>(_+=1,`yc-progress-circle-linear-gradient-${_}`));return(v,k)=>(e.openBlock(),e.createElementBlock("div",{role:"progressbar","aria-valuemin":"0","aria-valuemax":"100","aria-valuenow":v.percent,class:e.normalizeClass("yc-progress-circle-wrapper"),style:e.normalizeStyle({width:e.unref(l.valueToPx)(e.unref(y)),height:e.unref(l.valueToPx)(e.unref(y))})},["circle"===v.type&&"mini"===e.unref(f)&&"success"===v.status?(e.openBlock(),e.createBlock(e.unref(t.default),{key:0,style:e.normalizeStyle({fontSize:e.unref(y)-2,color:e.unref(h)??e.unref(s.TYPE_ICON_COLOR_MAP).success})},null,8,["style"])):(e.openBlock(),e.createElementBlock("svg",{key:1,viewBox:`0 0 ${e.unref(y)} ${e.unref(y)}`,class:e.normalizeClass("yc-progress-circle-svg")},[e.unref(r.isObject)(e.unref(h))?(e.openBlock(),e.createElementBlock("defs",n,[e.createElementVNode("linearGradient",{id:z.value,x1:"0",y1:"1",x2:"0",y2:"0"},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(Object.keys(e.unref(h)),r=>(e.openBlock(),e.createElementBlock("stop",{key:r,offset:r,"stop-color":e.unref(h)[r]},null,8,i))),128))],8,u)])):e.createCommentVNode("",!0),e.createElementVNode("circle",{class:e.normalizeClass("yc-progress-circle-bg"),fill:"none",cx:j.value,cy:j.value,r:w.value,"stroke-width":E.value,style:e.normalizeStyle({stroke:v.trackColor})},null,12,d),e.createElementVNode("circle",{class:e.normalizeClass("yc-progress-circle-bar"),fill:"none",cx:j.value,cy:j.value,r:w.value,"stroke-width":C.value,style:e.normalizeStyle({stroke:g.value?`url(#${z.value})`:e.unref(h),strokeDasharray:O.value,strokeDashoffset:(v.percent>=1?0:1-v.percent)*O.value})},null,12,p)],8,c)),v.showText&&"mini"!==e.unref(f)?(e.openBlock(),e.createElementBlock("div",m,[e.renderSlot(v.$slots,"text",{percent:v.percent},()=>["danger"===v.status?(e.openBlock(),e.createBlock(e.unref(o.default),{key:0,color:e.unref(s.TYPE_ICON_COLOR_MAP).error},null,8,["color"])):"success"===v.status?(e.openBlock(),e.createBlock(e.unref(t.default),{key:1,color:e.unref(s.TYPE_ICON_COLOR_MAP).success},null,8,["color"])):(e.openBlock(),e.createElementBlock(e.Fragment,{key:2},[e.createTextVNode(e.toDisplayString(v.text),1)],64))])])):e.createCommentVNode("",!0)],12,a))}});exports.default=v;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("../_shared/utils/dom.js"),o=require("../_shared/utils/locale.js"),l=require("../_shared/utils/control.js"),a=require("../node_modules/@vueuse/core/index.js");,/* empty css */,/* empty css */;/* empty css */const n=require("../_shared/icons/IconCopy.
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("../_shared/utils/dom.js"),o=require("../_shared/utils/locale.js"),l=require("../_shared/utils/control.js"),a=require("../node_modules/@vueuse/core/index.js");,/* empty css */,/* empty css */;/* empty css */const n=require("../_shared/icons/IconCopy.vue2.js"),r=require("../_shared/icons/IconEdit.vue2.js"),u=require("../_shared/icons/IconInfo.vue.js"),d=require("../Input/index.js"),p=require("../Tooltip/index.js"),s=e.defineComponent({name:"TypographyBase",__name:"TypographyBase",props:{tag:{default:"span"},type:{default:void 0},bold:{type:Boolean,default:!1},disabled:{type:Boolean},mark:{type:Boolean,default:!1},underline:{type:Boolean,default:!1},delete:{type:Boolean,default:!1},code:{type:Boolean,default:!1},editable:{type:Boolean,default:!1},editing:{type:Boolean,default:void 0},defaultEditing:{type:Boolean,default:!1},editText:{default:""},copyable:{type:Boolean,default:!1},copyText:{default:""},copyDelay:{default:3e3},editTooltiProps:{default:()=>({})},copyTooltiProps:{default:()=>({})}},emits:["update:editing","update:editText","edit-start","change","copy","edit-end"],setup(s,{emit:i}){const c=s,y=i,{editing:f,defaultEditing:v,editText:g,copyText:m,copyable:h,copyDelay:B,code:k,mark:x,delete:_,underline:T,bold:C}=e.toRefs(c),{t:b}=o.useI18n(),{isSupported:j,copy:q}=a.useClipboard(),V=e.ref(!1),E=e.ref(),I=e.ref(),N=l.useControlValue(f,v.value,e=>{y("update:editing",e)}),w=l.useControlValue(g,"",e=>{y("update:editText",e),y("change",e)}),P=e.computed(()=>{const e=[x.value,k.value,_.value,T.value,C.value];return["mark","code","del","u","b"].filter((t,o)=>e[o])}),S=e.defineComponent({props:{tags:{type:Array,default:()=>[]}},setup:(t,{slots:o})=>()=>{var l;const{tags:a}=e.toRefs(t),n=(t,o)=>o>=a.value.length?t:e.h(a.value[o],null,n(t,o+1));return n(null==(l=o.default)?void 0:l.call(o),0)}}),D=async()=>{var e;N.value=!0,w.value=w.value?w.value:t.getDomText(E),y("edit-start"),await t.sleep(0),null==(e=I.value)||e.focus()},R=()=>{N.value=!1,y("edit-end")},$=async()=>{if(!h.value||!j.value||V.value)return;const e=m.value||t.getDomText(E);q(e),y("copy",e),V.value=!0,await t.sleep(B.value),V.value=!1};return(t,o)=>(e.openBlock(),e.createBlock(e.resolveDynamicComponent(t.tag),{class:e.normalizeClass(["yc-typography",{[`yc-typography-${t.type}`]:t.type,"yc-typography-bold":e.unref(C),"yc-typography-disabled":t.disabled,"yc-typography-underline":e.unref(T),"yc-typography-delete":e.unref(_)}]),ref_key:"contentRef",ref:E},{default:e.withCtx(()=>[e.unref(N)?(e.openBlock(),e.createBlock(e.unref(d.default),{key:0,modelValue:e.unref(w),"onUpdate:modelValue":o[0]||(o[0]=t=>e.isRef(w)?w.value=t:null),ref_key:"inputRef",ref:I,onBlur:R},null,8,["modelValue"])):(e.openBlock(),e.createBlock(e.unref(S),{key:1,tags:P.value},{default:e.withCtx(()=>[e.renderSlot(t.$slots,"default")]),_:3},8,["tags"])),t.editable&&!e.unref(N)?(e.openBlock(),e.createElementBlock("span",{key:2,class:"yc-typography-operation-edit",onClick:D},[e.createVNode(e.unref(p.default),e.mergeProps({content:e.unref(b)("typography.edit"),position:"top"},t.editTooltiProps),{default:e.withCtx(()=>[e.createElementVNode("span",null,[e.createVNode(e.unref(r.default))])]),_:1},16,["content"])])):e.createCommentVNode("",!0),e.unref(h)?(e.openBlock(),e.createElementBlock("span",{key:3,class:"yc-typography-operation-copy",onClick:$},[e.createVNode(e.unref(p.default),e.mergeProps({position:"top"},t.copyTooltiProps),{content:e.withCtx(()=>[e.renderSlot(t.$slots,"copy-tooltip",{copied:V.value},()=>[e.createTextVNode(e.toDisplayString(e.unref(b)("typography."+(V.value?"copied":"copy"))),1)])]),default:e.withCtx(()=>[e.createElementVNode("span",null,[e.renderSlot(t.$slots,"copy-icon",{copied:V.value},()=>[V.value?(e.openBlock(),e.createBlock(e.unref(u.default),{key:0,color:"rgb(0, 180, 42)"})):(e.openBlock(),e.createBlock(e.unref(n.default),{key:1}))])])]),_:3},16)])):e.createCommentVNode("",!0)]),_:3},8,["class"]))}});exports.default=s;
|
package/lib/Upload/Upload.vue.js
CHANGED
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("./hooks/useUpload.js"),o=require("./UploadButton.vue.js");;/* empty css */const l=require("./UploadDrag.vue.js");;/* empty css */const a=require("./UploadFileList.vue.js"),u=require("./UploadPictureCard.vue.js"),n=e.defineComponent({name:"Upload",__name:"Upload",props:{fileList:{default:void 0},defaultFileList:{default:()=>[]},accept:{default:void 0},disabled:{type:Boolean,default:!1},multiple:{type:Boolean,default:!1},directory:{type:Boolean,default:!1},draggable:{type:Boolean,default:!1},tip:{default:""},name:{type:[String,Function],default:void 0},limit:{default:0},showFileList:{type:Boolean,default:!0},showRemoveButton:{type:Boolean,default:!0},showUploadButton:{type:Boolean,default:!0},showPreviewButton:{type:Boolean,default:!0},download:{type:Boolean,default:!1},showLink:{type:Boolean,default:!0},imageLoading:{default:"lazy"},listType:{default:"text"},customIcon:{default:()=>({})},imagePreview:{type:Boolean},onBeforeUpload:{type:Function,default:()=>!0},onBeforeRemove:{type:Function,default:()=>Promise.resolve(!0)},onButtonClick:{type:Function,default:()=>{}}},emits:["update:fileList","exceed-limit","change","preview"],setup(n,{expose:
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("./hooks/useUpload.js"),o=require("./UploadButton.vue.js");;/* empty css */const l=require("./UploadDrag.vue.js");;/* empty css */const a=require("./UploadFileList.vue.js"),u=require("./UploadPictureCard.vue.js"),n=e.defineComponent({name:"Upload",__name:"Upload",props:{fileList:{default:void 0},defaultFileList:{default:()=>[]},accept:{default:void 0},disabled:{type:Boolean,default:!1},multiple:{type:Boolean,default:!1},directory:{type:Boolean,default:!1},draggable:{type:Boolean,default:!1},tip:{default:""},name:{type:[String,Function],default:void 0},limit:{default:0},showFileList:{type:Boolean,default:!0},showRemoveButton:{type:Boolean,default:!0},showUploadButton:{type:Boolean,default:!0},showPreviewButton:{type:Boolean,default:!0},download:{type:Boolean,default:!1},showLink:{type:Boolean,default:!0},imageLoading:{default:"lazy"},listType:{default:"text"},customIcon:{default:()=>({})},imagePreview:{type:Boolean},onBeforeUpload:{type:Function,default:()=>!0},onBeforeRemove:{type:Function,default:()=>Promise.resolve(!0)},onButtonClick:{type:Function,default:()=>{}}},emits:["update:fileList","exceed-limit","change","preview"],setup(n,{expose:r,emit:d}){const i=e.useSlots(),p=n,s=d,c=e.ref(),{computedFileList:f,limit:m,draggable:y,disabled:B,isOverDropZone:v,handleFiles:k,handleUpload:g}=t.default(c,p,s);return r({updateFile(e,t){const o=f.value.findIndex(t=>t.uid==e);-1!=o&&(f.value[o]={...f.value[o],name:t.name,file:t,status:"init",percent:0,url:URL.createObjectURL(t)})},upload(e){k(e)}}),(t,n)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["yc-upload-wrapper",`yc-upload-wrapper-type-${t.listType}`,{"yc-upload-disabled":e.unref(B)}])},["picture-card"!=t.listType?(e.openBlock(),e.createElementBlock(e.Fragment,{key:0},[t.showUploadButton?(e.openBlock(),e.createElementBlock("div",{key:0,class:e.normalizeClass(["yc-upload",{"yc-upload-draggable":e.unref(y)}]),ref_key:"uploadRef",ref:c,onClick:n[0]||(n[0]=(...t)=>e.unref(g)&&e.unref(g)(...t))},[e.unref(m)<=0||e.unref(f).length<e.unref(m)?e.renderSlot(t.$slots,"upload-button",{key:0},()=>[e.unref(y)?(e.openBlock(),e.createBlock(l.default,{key:0,"is-over-drop-zone":e.unref(v)},null,8,["is-over-drop-zone"])):(e.openBlock(),e.createBlock(o.default,{key:1}))]):e.createCommentVNode("",!0)],2)):e.createCommentVNode("",!0),t.showFileList&&e.unref(f).length?(e.openBlock(),e.createBlock(a.default,{key:1},e.createSlots({_:2},[i["extra-button"]?{name:"extra-button",fn:e.withCtx(o=>[e.renderSlot(t.$slots,"extra-button",e.normalizeProps(e.guardReactiveProps(o)))]),key:"0"}:void 0,i["upload-item"]?{name:"upload-item",fn:e.withCtx(o=>[e.renderSlot(t.$slots,"upload-item",e.normalizeProps(e.guardReactiveProps(o)))]),key:"1"}:void 0]),1024)):e.createCommentVNode("",!0)],64)):(e.openBlock(),e.createBlock(u.default,{key:1}))],2))}});exports.default=n;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("./hooks/useContext.js");require("../_shared/utils/dom.js"),/* empty css */,/* empty css */;/* empty css */const o=,/* empty css */n=require("../Button/index.js"),
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),t=require("./hooks/useContext.js");require("../_shared/utils/dom.js"),/* empty css */,/* empty css */;/* empty css */const o=,/* empty css */n=require("../_shared/utils/locale.js"),r=require("../Button/index.js"),s={class:"yc-upload-button"},u={key:0,class:"yc-upload-tip text-ellipsis"},i=e.defineComponent({__name:"UploadButton",setup(i){const{tip:d,disabled:a}=t.default().inject(),{t:l}=n.useI18n();return(t,n)=>(e.openBlock(),e.createElementBlock("div",s,[e.createVNode(e.unref(r.default),{disabled:e.unref(a),type:"primary"},{icon:e.withCtx(()=>[e.createVNode(e.unref(o.default))]),default:e.withCtx(()=>[e.createTextVNode(" "+e.toDisplayString(e.unref(l)("upload.buttonText")),1)]),_:1},8,["disabled"]),e.unref(d)?(e.openBlock(),e.createElementBlock("div",u,e.toDisplayString(e.unref(d)),1)):e.createCommentVNode("",!0)]))}});exports.default=i;
|
@@ -1,2 +1,5 @@
|
|
1
|
-
|
1
|
+
type __VLS_Props = {
|
2
|
+
isOverDropZone: boolean;
|
3
|
+
};
|
4
|
+
declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, HTMLDivElement>;
|
2
5
|
export default _default;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),o=require("./hooks/useContext.js");require("../_shared/utils/dom.js"),/* empty css */,/* empty css */;/* empty css */const
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),o=require("./hooks/useContext.js");require("../_shared/utils/dom.js"),/* empty css */,/* empty css */;/* empty css */const r=require("../_shared/icons/IconPlus.vue.js"),s=require("../_shared/utils/locale.js"),t={class:"yc-upload-drag-icon"},n={class:"yc-upload-drag-text"},a={key:0,class:"yc-upload-tip text-ellipsis"},d=e.defineComponent({__name:"UploadDrag",props:{isOverDropZone:{type:Boolean}},setup(d){const{tip:l,disabled:i}=o.default().inject(),{t:u}=s.useI18n();return(o,s)=>(e.openBlock(),e.createElementBlock("div",{class:e.normalizeClass(["yc-upload-drag",{"yc-upload-drag-disabled":e.unref(i)}])},[e.createElementVNode("div",t,[e.createVNode(e.unref(r.default))]),e.createElementVNode("div",n,e.toDisplayString(e.unref(u)("upload."+(o.isOverDropZone?"dragHover":"drag"))),1),e.unref(l)?(e.openBlock(),e.createElementBlock("div",a,e.toDisplayString(e.unref(l)),1)):e.createCommentVNode("",!0)],2))}});exports.default=d;
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { FileItem, UploadEmits, UploadProps } from '../type';
|
2
2
|
import { Ref } from 'vue';
|
3
3
|
export default function useUpload(uploadRef: Ref<HTMLDivElement | undefined>, _props?: UploadProps, _emits?: UploadEmits): {
|
4
|
+
isOverDropZone: import('vue').ShallowRef<boolean>;
|
4
5
|
handleUpload: (e: MouseEvent) => Promise<void>;
|
5
6
|
handleFiles: (fileData: File[] | FileList | null) => Promise<void>;
|
6
7
|
computedFileList: Ref<FileItem[]>;
|
@@ -26,6 +27,7 @@ export default function useUpload(uploadRef: Ref<HTMLDivElement | undefined>, _p
|
|
26
27
|
handleDelFile: (fileItem: FileItem) => Promise<void>;
|
27
28
|
emits: UploadEmits;
|
28
29
|
} | {
|
30
|
+
isOverDropZone: import('vue').ShallowRef<boolean>;
|
29
31
|
handleUpload: (e: MouseEvent) => Promise<void>;
|
30
32
|
handleFiles: (fileData: File[] | FileList | null) => Promise<void>;
|
31
33
|
computedFileList: import('vue').WritableComputedRef<FileItem[], FileItem[]>;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../node_modules/nanoid/index.browser.js");require("vue");const t=require("../../_shared/utils/is.js"),l=require("../../node_modules/@vueuse/core/index.js"),n=require("./useContext.js");exports.default=function(u,
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("../../node_modules/nanoid/index.browser.js");require("vue");const t=require("../../_shared/utils/is.js"),l=require("../../node_modules/@vueuse/core/index.js"),n=require("./useContext.js");exports.default=function(i,u,o){let r;r=u&&o?n.default().provide(u,o):n.default().inject();const{computedFileList:a,disabled:s,limit:d,accept:c,directory:v,multiple:p,name:m,onBeforeUpload:f,onButtonClick:h,emits:g}=r,{onChange:y,open:j}=l.useFileDialog({directory:v.value,multiple:p.value,accept:c.value,reset:!0});y(e=>q(e));const{isOverDropZone:x}=l.useDropZone(i,{dataTypes:c.value?c.value.split(","):void 0,multiple:p.value,preventDefaultForUnhandled:!0,onDrop:e=>q(e)}),D=(e=0)=>d.value>0&&e+a.value.length>d.value,b=e=>m?t.isString(m)?m:m(e):e.name,q=async l=>{const n=[...l||[]],i=[];for(const e of n){let l=!0;try{l=await(null==f?void 0:f(e))}catch{l=!1}!l&&t.isFunction(f)||i.push(e)}if(!i.length||s.value||D(i.length)){if(!D(null==i?void 0:i.length))return;g("exceed-limit",a.value,i)}else a.value=[...a.value,...i.map(t=>{const l={name:t.name,uid:e.nanoid(),file:t,status:"init",percent:0,url:URL.createObjectURL(t)};return{...l,name:b(l)}})],g("change",a.value,[...i])};return{...r,isOverDropZone:x,handleUpload:async e=>{if(s.value)return;let t;try{if(t=null==h?void 0:h(e),t instanceof Promise)return;j()}catch(l){throw l}},handleFiles:q}};
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./IconCopy.vue2.js");exports.default=e.default;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue");require("../utils/dom.js"),/* empty css */;/* empty css */const o=require("../components/Icon/index.vue3.js");;/* empty css */const n=e.defineComponent({__name:"IconCopy",setup:n=>(n,t)=>(e.openBlock(),e.createBlock(e.unref(o.default),e.normalizeProps(e.guardReactiveProps(n.$attrs)),{default:e.withCtx(()=>[...t[0]||(t[0]=[e.createElementVNode("path",{d:"M20 6h18a2 2 0 0 1 2 2v22M8 16v24c0 1.105.891 2 1.996 2h20.007A1.99 1.99 0 0 0 32 40.008V15.997A1.997 1.997 0 0 0 30 14H10a2 2 0 0 0-2 2Z"},null,-1)])]),_:1},16))});exports.default=n;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./IconEdit.vue2.js");exports.default=e.default;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue");require("../utils/dom.js"),/* empty css */;/* empty css */const n=require("../components/Icon/index.vue3.js");;/* empty css */const o=e.defineComponent({__name:"IconEdit",setup:o=>(o,t)=>(e.openBlock(),e.createBlock(e.unref(n.default),e.normalizeProps(e.guardReactiveProps(o.$attrs)),{default:e.withCtx(()=>[...t[0]||(t[0]=[e.createElementVNode("path",{d:"m30.48 19.038 5.733-5.734a1 1 0 0 0 0-1.414l-5.586-5.586a1 1 0 0 0-1.414 0l-5.734 5.734m7 7L15.763 33.754a1 1 0 0 1-.59.286l-6.048.708a1 1 0 0 1-1.113-1.069l.477-6.31a1 1 0 0 1 .29-.631l14.7-14.7m7 7-7-7M6 42h36"},null,-1)])]),_:1},16))});exports.default=o;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("./IconExclamation.vue2.js");exports.default=e.default;
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue");require("../utils/dom.js"),/* empty css */;/* empty css */const n=require("../components/Icon/index.vue3.js");;/* empty css */const t=e.defineComponent({__name:"IconExclamation",setup:t=>(t,o)=>(e.openBlock(),e.createBlock(e.unref(n.default),e.normalizeProps(e.guardReactiveProps(t.$attrs)),{default:e.withCtx(()=>[...o[0]||(o[0]=[e.createElementVNode("path",{d:"M23 9h2v21h-2z"},null,-1),e.createElementVNode("path",{fill:"currentColor",stroke:"none",d:"M23 9h2v21h-2z"},null,-1),e.createElementVNode("path",{d:"M23 37h2v2h-2z"},null,-1),e.createElementVNode("path",{fill:"currentColor",stroke:"none",d:"M23 37h2v2h-2z"},null,-1)])]),_:1},16))});exports.default=t;
|