vft 0.0.5 → 0.0.6
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.css +1 -1
- package/es/component.mjs +9 -6
- package/es/component.mjs.map +1 -1
- package/es/components/avatar/avatar.vue2.mjs +12 -11
- package/es/components/avatar/avatar.vue2.mjs.map +1 -1
- package/es/components/avatar/index.mjs +2 -0
- package/es/components/avatar/index.mjs.map +1 -1
- package/es/components/back-top/back-top.vue2.mjs +20 -18
- package/es/components/back-top/back-top.vue2.mjs.map +1 -1
- package/es/components/back-top/index.mjs +2 -0
- package/es/components/back-top/index.mjs.map +1 -1
- package/es/components/divider/divider.vue2.mjs +4 -2
- package/es/components/divider/divider.vue2.mjs.map +1 -1
- package/es/components/divider/index.mjs +5 -3
- package/es/components/divider/index.mjs.map +1 -1
- package/es/components/empty/empty.vue2.mjs.map +1 -1
- package/es/components/empty/index.mjs +7 -5
- package/es/components/empty/index.mjs.map +1 -1
- package/es/components/exception/index.mjs +5 -3
- package/es/components/exception/index.mjs.map +1 -1
- package/es/components/icon/icon.vue2.mjs +11 -10
- package/es/components/icon/icon.vue2.mjs.map +1 -1
- package/es/components/icon/index.mjs +5 -3
- package/es/components/icon/index.mjs.map +1 -1
- package/es/components/index.d.ts +1 -0
- package/es/components/index.mjs +11 -6
- package/es/components/index.mjs.map +1 -1
- package/es/components/result/index.mjs +5 -3
- package/es/components/result/index.mjs.map +1 -1
- package/es/components/result/result.vue2.mjs +4 -2
- package/es/components/result/result.vue2.mjs.map +1 -1
- package/es/components/tabs/index.d.ts +356 -0
- package/es/components/tabs/index.mjs +15 -0
- package/es/components/tabs/index.mjs.map +1 -0
- package/es/components/tabs/style/css.d.ts +0 -0
- package/es/components/tabs/style/css.mjs +3 -0
- package/es/components/tabs/style/css.mjs.map +1 -0
- package/es/components/tabs/style/index.d.ts +0 -0
- package/es/components/tabs/style/index.mjs +3 -0
- package/es/components/tabs/style/index.mjs.map +1 -0
- package/es/components/tabs/tab-bar.vue.d.ts +51 -0
- package/es/components/tabs/tab-bar.vue.mjs +5 -0
- package/es/components/tabs/tab-bar.vue.mjs.map +1 -0
- package/es/components/tabs/tab-bar.vue2.mjs +53 -0
- package/es/components/tabs/tab-bar.vue2.mjs.map +1 -0
- package/es/components/tabs/tab-nav.vue.d.ts +121 -0
- package/es/components/tabs/tab-nav.vue.mjs +5 -0
- package/es/components/tabs/tab-nav.vue.mjs.map +1 -0
- package/es/components/tabs/tab-nav.vue2.mjs +167 -0
- package/es/components/tabs/tab-nav.vue2.mjs.map +1 -0
- package/es/components/tabs/tab-pane.vue.d.ts +45 -0
- package/es/components/tabs/tab-pane.vue.mjs +5 -0
- package/es/components/tabs/tab-pane.vue.mjs.map +1 -0
- package/es/components/tabs/tab-pane.vue2.mjs +57 -0
- package/es/components/tabs/tab-pane.vue2.mjs.map +1 -0
- package/es/components/tabs/tabs.vue.d.ts +159 -0
- package/es/components/tabs/tabs.vue.mjs +5 -0
- package/es/components/tabs/tabs.vue.mjs.map +1 -0
- package/es/components/tabs/tabs.vue2.mjs +151 -0
- package/es/components/tabs/tabs.vue2.mjs.map +1 -0
- package/es/components/tabs/types.d.ts +58 -0
- package/es/components/tabs/types.mjs +5 -0
- package/es/components/tabs/types.mjs.map +1 -0
- package/es/hooks/index.d.ts +1 -0
- package/es/hooks/index.mjs +6 -4
- package/es/hooks/index.mjs.map +1 -1
- package/es/hooks/use-ordered-children/index.d.ts +8 -0
- package/es/hooks/use-ordered-children/index.mjs +27 -0
- package/es/hooks/use-ordered-children/index.mjs.map +1 -0
- package/es/index.d.ts +1 -1
- package/es/index.mjs +42 -35
- package/es/index.mjs.map +1 -1
- package/es/package.json.mjs +1 -1
- package/es/style.css +1 -1
- package/es/theme-style/src/tabs.scss.mjs +5 -0
- package/es/theme-style/src/tabs.scss.mjs.map +1 -0
- package/es/utils/index.mjs +23 -10
- package/es/utils/index.mjs.map +1 -1
- package/es/utils/vue/index.d.ts +1 -0
- package/es/utils/vue/index.mjs +18 -5
- package/es/utils/vue/index.mjs.map +1 -1
- package/es/utils/vue/vnode.d.ts +51 -0
- package/es/utils/vue/vnode.mjs +67 -0
- package/es/utils/vue/vnode.mjs.map +1 -0
- package/lib/component.js +1 -1
- package/lib/component.js.map +1 -1
- package/lib/components/avatar/avatar.vue2.js +1 -1
- package/lib/components/avatar/avatar.vue2.js.map +1 -1
- package/lib/components/avatar/index.js +1 -1
- package/lib/components/avatar/index.js.map +1 -1
- package/lib/components/back-top/back-top.vue2.js +1 -1
- package/lib/components/back-top/back-top.vue2.js.map +1 -1
- package/lib/components/back-top/index.js +1 -1
- package/lib/components/back-top/index.js.map +1 -1
- package/lib/components/divider/divider.vue2.js +1 -1
- package/lib/components/divider/divider.vue2.js.map +1 -1
- package/lib/components/divider/index.js +1 -1
- package/lib/components/divider/index.js.map +1 -1
- package/lib/components/empty/empty.vue2.js.map +1 -1
- package/lib/components/empty/index.js +1 -1
- package/lib/components/empty/index.js.map +1 -1
- package/lib/components/exception/index.js +1 -1
- package/lib/components/exception/index.js.map +1 -1
- package/lib/components/icon/icon.vue2.js +1 -1
- package/lib/components/icon/icon.vue2.js.map +1 -1
- package/lib/components/icon/index.js +1 -1
- package/lib/components/icon/index.js.map +1 -1
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +1 -1
- package/lib/components/result/index.js +1 -1
- package/lib/components/result/index.js.map +1 -1
- package/lib/components/result/result.vue2.js +1 -1
- package/lib/components/result/result.vue2.js.map +1 -1
- package/lib/components/tabs/index.d.ts +356 -0
- package/lib/components/tabs/index.js +2 -0
- package/lib/components/tabs/index.js.map +1 -0
- package/lib/components/tabs/style/css.d.ts +0 -0
- package/lib/components/tabs/style/css.js +2 -0
- package/lib/components/tabs/style/css.js.map +1 -0
- package/lib/components/tabs/style/index.d.ts +0 -0
- package/lib/components/tabs/style/index.js +2 -0
- package/lib/components/tabs/style/index.js.map +1 -0
- package/lib/components/tabs/tab-bar.vue.d.ts +51 -0
- package/lib/components/tabs/tab-bar.vue.js +2 -0
- package/lib/components/tabs/tab-bar.vue.js.map +1 -0
- package/lib/components/tabs/tab-bar.vue2.js +2 -0
- package/lib/components/tabs/tab-bar.vue2.js.map +1 -0
- package/lib/components/tabs/tab-nav.vue.d.ts +121 -0
- package/lib/components/tabs/tab-nav.vue.js +2 -0
- package/lib/components/tabs/tab-nav.vue.js.map +1 -0
- package/lib/components/tabs/tab-nav.vue2.js +2 -0
- package/lib/components/tabs/tab-nav.vue2.js.map +1 -0
- package/lib/components/tabs/tab-pane.vue.d.ts +45 -0
- package/lib/components/tabs/tab-pane.vue.js +2 -0
- package/lib/components/tabs/tab-pane.vue.js.map +1 -0
- package/lib/components/tabs/tab-pane.vue2.js +2 -0
- package/lib/components/tabs/tab-pane.vue2.js.map +1 -0
- package/lib/components/tabs/tabs.vue.d.ts +159 -0
- package/lib/components/tabs/tabs.vue.js +2 -0
- package/lib/components/tabs/tabs.vue.js.map +1 -0
- package/lib/components/tabs/tabs.vue2.js +2 -0
- package/lib/components/tabs/tabs.vue2.js.map +1 -0
- package/lib/components/tabs/types.d.ts +58 -0
- package/lib/components/tabs/types.js +2 -0
- package/lib/components/tabs/types.js.map +1 -0
- package/lib/hooks/index.d.ts +1 -0
- package/lib/hooks/index.js +1 -1
- package/lib/hooks/use-ordered-children/index.d.ts +8 -0
- package/lib/hooks/use-ordered-children/index.js +2 -0
- package/lib/hooks/use-ordered-children/index.js.map +1 -0
- package/lib/index.d.ts +1 -1
- package/lib/index.js +1 -1
- package/lib/index.js.map +1 -1
- package/lib/package.json.js +1 -1
- package/lib/theme-style/src/tabs.scss.js +2 -0
- package/lib/theme-style/src/tabs.scss.js.map +1 -0
- package/lib/utils/index.js +1 -1
- package/lib/utils/vue/index.d.ts +1 -0
- package/lib/utils/vue/index.js +1 -1
- package/lib/utils/vue/vnode.d.ts +51 -0
- package/lib/utils/vue/vnode.js +2 -0
- package/lib/utils/vue/vnode.js.map +1 -0
- package/package.json +1 -1
- package/theme-style/index.css +1 -1
- package/theme-style/src/index.scss +1 -0
- package/theme-style/src/tabs.scss +582 -0
- package/theme-style/vft-tabs.css +1 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../../../packages/components/result/index.ts"],"sourcesContent":["import { withInstall } from '@vft-ui/utils'\n\nimport Result from './result.vue'\n\nexport const VftResult = withInstall(Result)\nexport default VftResult\n"],"names":["VftResult","withInstall","Result"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../packages/components/result/index.ts"],"sourcesContent":["import { withInstall } from '@vft-ui/utils'\n\nimport Result from './result.vue'\n\nexport const VftResult = withInstall(Result)\nexport default VftResult\n"],"names":["VftResult","withInstall","Result"],"mappings":";;;;;AAIa,MAAAA,IAAYC,EAAYC,CAAM;"}
|
|
@@ -1,18 +1,20 @@
|
|
|
1
1
|
import { defineComponent as u, getCurrentInstance as d, useSlots as f, computed as v, h as e } from "vue";
|
|
2
2
|
import { singleAttrToObj as _, renderTNode as b } from "@vft/utils";
|
|
3
3
|
import { useNamespace as x } from "../../hooks/use-namespace/index.mjs";
|
|
4
|
+
import "@vue/shared";
|
|
4
5
|
import "../divider/index.mjs";
|
|
5
6
|
import { VftIcon as C } from "../icon/index.mjs";
|
|
6
7
|
import "../avatar/index.mjs";
|
|
7
8
|
import "../empty/index.mjs";
|
|
8
9
|
import "./index.mjs";
|
|
9
10
|
import "../exception/index.mjs";
|
|
11
|
+
import "../tabs/index.mjs";
|
|
10
12
|
const o = (
|
|
11
13
|
/* hoist-static*/
|
|
12
14
|
x("result")
|
|
13
15
|
), I = u({
|
|
14
16
|
name: o.b()
|
|
15
|
-
}),
|
|
17
|
+
}), w = /* @__PURE__ */ u({
|
|
16
18
|
...I,
|
|
17
19
|
props: {
|
|
18
20
|
title: null,
|
|
@@ -51,6 +53,6 @@ const o = (
|
|
|
51
53
|
}
|
|
52
54
|
});
|
|
53
55
|
export {
|
|
54
|
-
|
|
56
|
+
w as default
|
|
55
57
|
};
|
|
56
58
|
//# sourceMappingURL=result.vue2.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"result.vue2.mjs","sources":["../../../../../packages/components/result/result.vue"],"sourcesContent":["<script lang=\"ts\">\nconst ns = /* hoist-static*/ useNamespace('result')\n\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({\n name: ns.b()\n});</script>\n<script setup lang=\"ts\">\nimport { renderTNode, singleAttrToObj } from '@vft/utils';\nimport { h, getCurrentInstance, computed, useSlots } from 'vue';\nimport { useNamespace } from '@vft-ui/
|
|
1
|
+
{"version":3,"file":"result.vue2.mjs","sources":["../../../../../packages/components/result/result.vue"],"sourcesContent":["<script lang=\"ts\">\nconst ns = /* hoist-static*/ useNamespace('result')\n\nimport { defineComponent as DO_defineComponent } from 'vue';\nexport default /*#__PURE__*/ DO_defineComponent({\n name: ns.b()\n});</script>\n<script setup lang=\"ts\">\nimport { renderTNode, singleAttrToObj } from '@vft/utils';\nimport { h, getCurrentInstance, computed, useSlots } from 'vue';\nimport { useNamespace } from '@vft-ui/hooks';\nimport { type IconProps, VftIcon } from '@vft-ui/components';\n\ninterface Props {\n title?: string | number;\n subTitle?: string | number;\n icon?: IconProps;\n}\n\ndefineProps({\n \"title\": null,\n \"subTitle\": null,\n \"icon\": null\n})\n\n\n\n;\n\nconst instance = getCurrentInstance()!;\n\nconst slots = useSlots();\n\nconst _icon = computed(() => {\n return singleAttrToObj(__props.icon, 'icon') as IconProps;\n});\n\nconst vIcon = _icon.value?.icon ? h('div', {\n class: ns.e('icon')\n}, [h(VftIcon, { ..._icon.value })]) : slots.default?.();\n\nconst vCon = (attrName: string) => {\n const nodeCon = renderTNode(instance, attrName);\n return nodeCon ? h(\n 'div',\n {\n class: ns.e(attrName)\n }, [h('p', {}, { default: () => nodeCon })]\n ) : null;\n};\n\ndefineRender(() => {\n return (\n h(\n 'div', { class: ns.b() }, {\n default: () => [\n vIcon,\n vCon('title'),\n vCon('sub-title'),\n slots.extra ? h('div', { class: ns.e('extra') }, { default: ()=> slots.extra?.() }) : null\n ]\n }\n )\n );\n});\n</script>\n"],"names":["ns","useNamespace","__default__","DO_defineComponent","instance","getCurrentInstance","slots","useSlots","_icon","computed","singleAttrToObj","__props","vIcon","_a","h","VftIcon","_b","vCon","attrName","nodeCon","renderTNode"],"mappings":";;;;;;;;;;;AACA,MAAMA;AAAA;AAAA,EAAuBC,EAAa,QAAQ;AAAA,GAGlDC,IAA6BC,EAAmB;AAAA,EAC9C,MAAMH,EAAG,EAAE;AACb,CAAC;;;;;;;;;AAuBD,UAAMI,IAAWC,KAEXC,IAAQC,KAERC,IAAQC,EAAS,MACdC,EAAgBC,EAAQ,MAAM,MAAM,CAC5C,GAEKC,KAAQC,IAAAL,EAAM,UAAN,QAAAK,EAAa,OAAOC,EAAE,OAAO;AAAA,MACzC,OAAOd,EAAG,EAAE,MAAM;AAAA,IACjB,GAAA,CAACc,EAAEC,GAAS,EAAE,GAAGP,EAAM,MAAO,CAAA,CAAC,CAAC,KAAIQ,IAAAV,EAAM,YAAN,gBAAAU,EAAA,KAAAV,IAEjCW,IAAO,CAACC,MAAqB;AAC3B,YAAAC,IAAUC,EAAYhB,GAAUc,CAAQ;AAC9C,aAAOC,IAAUL;AAAA,QACf;AAAA,QACA;AAAA,UACE,OAAOd,EAAG,EAAEkB,CAAQ;AAAA,QACtB;AAAA,QAAG,CAACJ,EAAE,KAAK,CAAC,GAAG,EAAE,SAAS,MAAMK,EAAQ,CAAC,CAAC;AAAA,MACxC,IAAA;AAAA,IAAA;AAGO,WAAA,MAETL;AAAA,MACE;AAAA,MAAO,EAAE,OAAOd,EAAG,IAAI;AAAA,MAAG;AAAA,QACxB,SAAS,MAAM;AAAA,UACbY;AAAA,UACAK,EAAK,OAAO;AAAA,UACZA,EAAK,WAAW;AAAA,UAChBX,EAAM,QAAQQ,EAAE,OAAO,EAAE,OAAOd,EAAG,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,MAAA;;AAAK,oBAAAa,IAAAP,EAAM,UAAN,gBAAAO,EAAA,KAAAP;AAAA,YAAiB,CAAA,IAAI;AAAA,QACxF;AAAA,MACF;AAAA,IAAA;AAAA;;"}
|
|
@@ -0,0 +1,356 @@
|
|
|
1
|
+
export declare const VftTabs: import("vft/es/utils").SFCWithInstall<import("vue").DefineComponent<{
|
|
2
|
+
type: {
|
|
3
|
+
type: import("vue").PropType<import("./types").TabsType | undefined>;
|
|
4
|
+
required: false;
|
|
5
|
+
};
|
|
6
|
+
closable: {
|
|
7
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
8
|
+
required: false;
|
|
9
|
+
};
|
|
10
|
+
addable: {
|
|
11
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
12
|
+
required: false;
|
|
13
|
+
};
|
|
14
|
+
modelValue: {
|
|
15
|
+
type: import("vue").PropType<Numberish>;
|
|
16
|
+
required: true;
|
|
17
|
+
};
|
|
18
|
+
editable: {
|
|
19
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
20
|
+
required: false;
|
|
21
|
+
};
|
|
22
|
+
tabPosition: {
|
|
23
|
+
type: import("vue").PropType<"left" | "right" | "top" | "bottom" | undefined>;
|
|
24
|
+
required: false;
|
|
25
|
+
};
|
|
26
|
+
beforeLeave: {
|
|
27
|
+
type: import("vue").PropType<Function | undefined>;
|
|
28
|
+
required: false;
|
|
29
|
+
};
|
|
30
|
+
stretch: {
|
|
31
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
32
|
+
required: false;
|
|
33
|
+
};
|
|
34
|
+
closeIconCfg: {
|
|
35
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
36
|
+
required: false;
|
|
37
|
+
};
|
|
38
|
+
addIconCfg: {
|
|
39
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
40
|
+
required: false;
|
|
41
|
+
};
|
|
42
|
+
arrowLeftIconCfg: {
|
|
43
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
44
|
+
required: false;
|
|
45
|
+
};
|
|
46
|
+
arrowRightIconCfg: {
|
|
47
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
48
|
+
required: false;
|
|
49
|
+
};
|
|
50
|
+
}, {
|
|
51
|
+
currentName: import("vue").Ref<Numberish>;
|
|
52
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
|
|
53
|
+
"update:modelValue": (name: Numberish) => boolean;
|
|
54
|
+
tabClick: (pane: {
|
|
55
|
+
uid: number;
|
|
56
|
+
slots: Readonly<{
|
|
57
|
+
[name: string]: import("vue").Slot | undefined;
|
|
58
|
+
}>;
|
|
59
|
+
props: {
|
|
60
|
+
label: string;
|
|
61
|
+
name: Numberish;
|
|
62
|
+
closable: boolean;
|
|
63
|
+
disabled: boolean;
|
|
64
|
+
lazy: boolean;
|
|
65
|
+
};
|
|
66
|
+
paneName: string | number | undefined;
|
|
67
|
+
active: boolean;
|
|
68
|
+
index: string | undefined;
|
|
69
|
+
isClosable: boolean;
|
|
70
|
+
attrs: Record<string, any>;
|
|
71
|
+
}, ev: Event) => boolean;
|
|
72
|
+
tabContextMenu: (pane: {
|
|
73
|
+
uid: number;
|
|
74
|
+
slots: Readonly<{
|
|
75
|
+
[name: string]: import("vue").Slot | undefined;
|
|
76
|
+
}>;
|
|
77
|
+
props: {
|
|
78
|
+
label: string;
|
|
79
|
+
name: Numberish;
|
|
80
|
+
closable: boolean;
|
|
81
|
+
disabled: boolean;
|
|
82
|
+
lazy: boolean;
|
|
83
|
+
};
|
|
84
|
+
paneName: string | number | undefined;
|
|
85
|
+
active: boolean;
|
|
86
|
+
index: string | undefined;
|
|
87
|
+
isClosable: boolean;
|
|
88
|
+
attrs: Record<string, any>;
|
|
89
|
+
}, index: number, ev: Event) => boolean;
|
|
90
|
+
tabChange: (name: Numberish) => boolean;
|
|
91
|
+
edit: (paneName: Numberish | undefined, action: "remove" | "add") => boolean;
|
|
92
|
+
tabRemove: (name: Numberish) => boolean;
|
|
93
|
+
tabAdd: () => true;
|
|
94
|
+
}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
95
|
+
type: {
|
|
96
|
+
type: import("vue").PropType<import("./types").TabsType | undefined>;
|
|
97
|
+
required: false;
|
|
98
|
+
};
|
|
99
|
+
closable: {
|
|
100
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
101
|
+
required: false;
|
|
102
|
+
};
|
|
103
|
+
addable: {
|
|
104
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
105
|
+
required: false;
|
|
106
|
+
};
|
|
107
|
+
modelValue: {
|
|
108
|
+
type: import("vue").PropType<Numberish>;
|
|
109
|
+
required: true;
|
|
110
|
+
};
|
|
111
|
+
editable: {
|
|
112
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
113
|
+
required: false;
|
|
114
|
+
};
|
|
115
|
+
tabPosition: {
|
|
116
|
+
type: import("vue").PropType<"left" | "right" | "top" | "bottom" | undefined>;
|
|
117
|
+
required: false;
|
|
118
|
+
};
|
|
119
|
+
beforeLeave: {
|
|
120
|
+
type: import("vue").PropType<Function | undefined>;
|
|
121
|
+
required: false;
|
|
122
|
+
};
|
|
123
|
+
stretch: {
|
|
124
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
125
|
+
required: false;
|
|
126
|
+
};
|
|
127
|
+
closeIconCfg: {
|
|
128
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
129
|
+
required: false;
|
|
130
|
+
};
|
|
131
|
+
addIconCfg: {
|
|
132
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
133
|
+
required: false;
|
|
134
|
+
};
|
|
135
|
+
arrowLeftIconCfg: {
|
|
136
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
137
|
+
required: false;
|
|
138
|
+
};
|
|
139
|
+
arrowRightIconCfg: {
|
|
140
|
+
type: import("vue").PropType<import("..").IconProps | undefined>;
|
|
141
|
+
required: false;
|
|
142
|
+
};
|
|
143
|
+
}>> & {
|
|
144
|
+
"onUpdate:modelValue"?: ((name: Numberish) => any) | undefined;
|
|
145
|
+
onTabClick?: ((pane: {
|
|
146
|
+
uid: number;
|
|
147
|
+
slots: Readonly<{
|
|
148
|
+
[name: string]: import("vue").Slot | undefined;
|
|
149
|
+
}>;
|
|
150
|
+
props: {
|
|
151
|
+
label: string;
|
|
152
|
+
name: Numberish;
|
|
153
|
+
closable: boolean;
|
|
154
|
+
disabled: boolean;
|
|
155
|
+
lazy: boolean;
|
|
156
|
+
};
|
|
157
|
+
paneName: string | number | undefined;
|
|
158
|
+
active: boolean;
|
|
159
|
+
index: string | undefined;
|
|
160
|
+
isClosable: boolean;
|
|
161
|
+
attrs: Record<string, any>;
|
|
162
|
+
}, ev: Event) => any) | undefined;
|
|
163
|
+
onTabContextMenu?: ((pane: {
|
|
164
|
+
uid: number;
|
|
165
|
+
slots: Readonly<{
|
|
166
|
+
[name: string]: import("vue").Slot | undefined;
|
|
167
|
+
}>;
|
|
168
|
+
props: {
|
|
169
|
+
label: string;
|
|
170
|
+
name: Numberish;
|
|
171
|
+
closable: boolean;
|
|
172
|
+
disabled: boolean;
|
|
173
|
+
lazy: boolean;
|
|
174
|
+
};
|
|
175
|
+
paneName: string | number | undefined;
|
|
176
|
+
active: boolean;
|
|
177
|
+
index: string | undefined;
|
|
178
|
+
isClosable: boolean;
|
|
179
|
+
attrs: Record<string, any>;
|
|
180
|
+
}, index: number, ev: Event) => any) | undefined;
|
|
181
|
+
onTabChange?: ((name: Numberish) => any) | undefined;
|
|
182
|
+
onEdit?: ((paneName: Numberish | undefined, action: "remove" | "add") => any) | undefined;
|
|
183
|
+
onTabRemove?: ((name: Numberish) => any) | undefined;
|
|
184
|
+
onTabAdd?: (() => any) | undefined;
|
|
185
|
+
}, {}>> & {
|
|
186
|
+
new (...args: any[]): {
|
|
187
|
+
$: import("vue").ComponentInternalInstance;
|
|
188
|
+
$data: {};
|
|
189
|
+
$props: Partial<{}> & Omit<Readonly<import("vue").ExtractPropTypes<{
|
|
190
|
+
label: {
|
|
191
|
+
type: import("vue").PropType<string | undefined>;
|
|
192
|
+
required: false;
|
|
193
|
+
};
|
|
194
|
+
name: {
|
|
195
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
196
|
+
required: false;
|
|
197
|
+
};
|
|
198
|
+
closable: {
|
|
199
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
200
|
+
required: false;
|
|
201
|
+
};
|
|
202
|
+
disabled: {
|
|
203
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
204
|
+
required: false;
|
|
205
|
+
};
|
|
206
|
+
lazy: {
|
|
207
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
208
|
+
required: false;
|
|
209
|
+
};
|
|
210
|
+
}>> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, never>;
|
|
211
|
+
$attrs: {
|
|
212
|
+
[x: string]: unknown;
|
|
213
|
+
};
|
|
214
|
+
$refs: {
|
|
215
|
+
[x: string]: unknown;
|
|
216
|
+
};
|
|
217
|
+
$slots: Readonly<{
|
|
218
|
+
[name: string]: import("vue").Slot | undefined;
|
|
219
|
+
}>;
|
|
220
|
+
$root: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
|
|
221
|
+
$parent: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null;
|
|
222
|
+
$emit: (event: string, ...args: any[]) => void;
|
|
223
|
+
$el: any;
|
|
224
|
+
$options: import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
|
|
225
|
+
label: {
|
|
226
|
+
type: import("vue").PropType<string | undefined>;
|
|
227
|
+
required: false;
|
|
228
|
+
};
|
|
229
|
+
name: {
|
|
230
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
231
|
+
required: false;
|
|
232
|
+
};
|
|
233
|
+
closable: {
|
|
234
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
235
|
+
required: false;
|
|
236
|
+
};
|
|
237
|
+
disabled: {
|
|
238
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
239
|
+
required: false;
|
|
240
|
+
};
|
|
241
|
+
lazy: {
|
|
242
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
243
|
+
required: false;
|
|
244
|
+
};
|
|
245
|
+
}>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string> & {
|
|
246
|
+
beforeCreate?: ((() => void) | (() => void)[]) | undefined;
|
|
247
|
+
created?: ((() => void) | (() => void)[]) | undefined;
|
|
248
|
+
beforeMount?: ((() => void) | (() => void)[]) | undefined;
|
|
249
|
+
mounted?: ((() => void) | (() => void)[]) | undefined;
|
|
250
|
+
beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
|
|
251
|
+
updated?: ((() => void) | (() => void)[]) | undefined;
|
|
252
|
+
activated?: ((() => void) | (() => void)[]) | undefined;
|
|
253
|
+
deactivated?: ((() => void) | (() => void)[]) | undefined;
|
|
254
|
+
beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
|
|
255
|
+
beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
|
|
256
|
+
destroyed?: ((() => void) | (() => void)[]) | undefined;
|
|
257
|
+
unmounted?: ((() => void) | (() => void)[]) | undefined;
|
|
258
|
+
renderTracked?: (((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[]) | undefined;
|
|
259
|
+
renderTriggered?: (((e: import("vue").DebuggerEvent) => void) | ((e: import("vue").DebuggerEvent) => void)[]) | undefined;
|
|
260
|
+
errorCaptured?: (((err: unknown, instance: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void) | ((err: unknown, instance: import("vue").ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, import("vue").ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string>, {}> | null, info: string) => boolean | void)[]) | undefined;
|
|
261
|
+
};
|
|
262
|
+
$forceUpdate: () => void;
|
|
263
|
+
$nextTick: typeof import("vue").nextTick;
|
|
264
|
+
$watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: import("vue").WatchOptions<boolean> | undefined): import("vue").WatchStopHandle;
|
|
265
|
+
} & Readonly<import("vue").ExtractPropTypes<{
|
|
266
|
+
label: {
|
|
267
|
+
type: import("vue").PropType<string | undefined>;
|
|
268
|
+
required: false;
|
|
269
|
+
};
|
|
270
|
+
name: {
|
|
271
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
272
|
+
required: false;
|
|
273
|
+
};
|
|
274
|
+
closable: {
|
|
275
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
276
|
+
required: false;
|
|
277
|
+
};
|
|
278
|
+
disabled: {
|
|
279
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
280
|
+
required: false;
|
|
281
|
+
};
|
|
282
|
+
lazy: {
|
|
283
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
284
|
+
required: false;
|
|
285
|
+
};
|
|
286
|
+
}>> & import("vue").ShallowUnwrapRef<{}> & {} & import("vue").ComponentCustomProperties & {};
|
|
287
|
+
__isFragment?: undefined;
|
|
288
|
+
__isTeleport?: undefined;
|
|
289
|
+
__isSuspense?: undefined;
|
|
290
|
+
} & import("vue").ComponentOptionsBase<Readonly<import("vue").ExtractPropTypes<{
|
|
291
|
+
label: {
|
|
292
|
+
type: import("vue").PropType<string | undefined>;
|
|
293
|
+
required: false;
|
|
294
|
+
};
|
|
295
|
+
name: {
|
|
296
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
297
|
+
required: false;
|
|
298
|
+
};
|
|
299
|
+
closable: {
|
|
300
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
301
|
+
required: false;
|
|
302
|
+
};
|
|
303
|
+
disabled: {
|
|
304
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
305
|
+
required: false;
|
|
306
|
+
};
|
|
307
|
+
lazy: {
|
|
308
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
309
|
+
required: false;
|
|
310
|
+
};
|
|
311
|
+
}>>, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, {}, {}, string> & import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps;
|
|
312
|
+
export declare const VftTabPane: import("vft/es/utils").SFCWithInstall<import("vue").DefineComponent<{
|
|
313
|
+
label: {
|
|
314
|
+
type: import("vue").PropType<string | undefined>;
|
|
315
|
+
required: false;
|
|
316
|
+
};
|
|
317
|
+
name: {
|
|
318
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
319
|
+
required: false;
|
|
320
|
+
};
|
|
321
|
+
closable: {
|
|
322
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
323
|
+
required: false;
|
|
324
|
+
};
|
|
325
|
+
disabled: {
|
|
326
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
327
|
+
required: false;
|
|
328
|
+
};
|
|
329
|
+
lazy: {
|
|
330
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
331
|
+
required: false;
|
|
332
|
+
};
|
|
333
|
+
}, {}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
334
|
+
label: {
|
|
335
|
+
type: import("vue").PropType<string | undefined>;
|
|
336
|
+
required: false;
|
|
337
|
+
};
|
|
338
|
+
name: {
|
|
339
|
+
type: import("vue").PropType<Numberish | undefined>;
|
|
340
|
+
required: false;
|
|
341
|
+
};
|
|
342
|
+
closable: {
|
|
343
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
344
|
+
required: false;
|
|
345
|
+
};
|
|
346
|
+
disabled: {
|
|
347
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
348
|
+
required: false;
|
|
349
|
+
};
|
|
350
|
+
lazy: {
|
|
351
|
+
type: import("vue").PropType<boolean | undefined>;
|
|
352
|
+
required: false;
|
|
353
|
+
};
|
|
354
|
+
}>>, {}>>;
|
|
355
|
+
export default VftTabs;
|
|
356
|
+
export * from './types';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { withInstall as o, withNoopInstall as m } from "../../utils/vue/install.mjs";
|
|
2
|
+
import "vue";
|
|
3
|
+
import "@vue/shared";
|
|
4
|
+
import "@vft/utils";
|
|
5
|
+
import r from "./tabs.vue2.mjs";
|
|
6
|
+
import t from "./tab-pane.vue2.mjs";
|
|
7
|
+
import { TabsRootContextKey as b } from "./types.mjs";
|
|
8
|
+
const e = o(r, t), l = m(t);
|
|
9
|
+
export {
|
|
10
|
+
b as TabsRootContextKey,
|
|
11
|
+
l as VftTabPane,
|
|
12
|
+
e as VftTabs,
|
|
13
|
+
e as default
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../packages/components/tabs/index.ts"],"sourcesContent":["import { withInstall, withNoopInstall } from '@vft-ui/utils'\nimport Tabs from './tabs.vue';\nimport TabPane from './tab-pane.vue';\n\nexport const VftTabs = withInstall(Tabs, TabPane)\nexport const VftTabPane = withNoopInstall(TabPane)\nexport default VftTabs\n\nexport * from './types';\n"],"names":["VftTabs","withInstall","Tabs","TabPane","VftTabPane","withNoopInstall"],"mappings":";;;;;;;AAIa,MAAAA,IAAUC,EAAYC,GAAMC,CAAO,GACnCC,IAAaC,EAAgBF,CAAO;"}
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
File without changes
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import type { PropType as __PropType } from 'vue';
|
|
2
|
+
import type { CSSProperties } from 'vue';
|
|
3
|
+
declare const _sfc_main: import("vue").DefineComponent<{
|
|
4
|
+
tabs: {
|
|
5
|
+
type: __PropType<{
|
|
6
|
+
uid: number;
|
|
7
|
+
slots: Readonly<{
|
|
8
|
+
[name: string]: import("vue").Slot | undefined;
|
|
9
|
+
}>;
|
|
10
|
+
props: {
|
|
11
|
+
label: string;
|
|
12
|
+
name: Numberish;
|
|
13
|
+
closable: boolean;
|
|
14
|
+
disabled: boolean;
|
|
15
|
+
lazy: boolean;
|
|
16
|
+
};
|
|
17
|
+
paneName: string | number | undefined;
|
|
18
|
+
active: boolean;
|
|
19
|
+
index: string | undefined;
|
|
20
|
+
isClosable: boolean;
|
|
21
|
+
attrs: Record<string, any>;
|
|
22
|
+
}[]>;
|
|
23
|
+
required: true;
|
|
24
|
+
};
|
|
25
|
+
}, {
|
|
26
|
+
ref: import("vue").Ref<HTMLDivElement | undefined>;
|
|
27
|
+
update: () => CSSProperties;
|
|
28
|
+
}, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
|
|
29
|
+
tabs: {
|
|
30
|
+
type: __PropType<{
|
|
31
|
+
uid: number;
|
|
32
|
+
slots: Readonly<{
|
|
33
|
+
[name: string]: import("vue").Slot | undefined;
|
|
34
|
+
}>;
|
|
35
|
+
props: {
|
|
36
|
+
label: string;
|
|
37
|
+
name: Numberish;
|
|
38
|
+
closable: boolean;
|
|
39
|
+
disabled: boolean;
|
|
40
|
+
lazy: boolean;
|
|
41
|
+
};
|
|
42
|
+
paneName: string | number | undefined;
|
|
43
|
+
active: boolean;
|
|
44
|
+
index: string | undefined;
|
|
45
|
+
isClosable: boolean;
|
|
46
|
+
attrs: Record<string, any>;
|
|
47
|
+
}[]>;
|
|
48
|
+
required: true;
|
|
49
|
+
};
|
|
50
|
+
}>>, {}>;
|
|
51
|
+
export default _sfc_main;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-bar.vue.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { defineComponent as $, getCurrentInstance as S, inject as C, ref as g, watch as N, nextTick as R, computed as k, openBlock as B, createElementBlock as F, normalizeClass as P, unref as c, normalizeStyle as T } from "vue";
|
|
2
|
+
import { TabsRootContextKey as L } from "./types.mjs";
|
|
3
|
+
import { useNamespace as j } from "../../hooks/use-namespace/index.mjs";
|
|
4
|
+
import "@vue/shared";
|
|
5
|
+
import { capitalize as p } from "@vft/utils";
|
|
6
|
+
import { useResizeObserver as D } from "@vueuse/core";
|
|
7
|
+
const G = /* @__PURE__ */ $({
|
|
8
|
+
__name: "tab-bar",
|
|
9
|
+
props: {
|
|
10
|
+
tabs: null
|
|
11
|
+
},
|
|
12
|
+
setup(h, { expose: x }) {
|
|
13
|
+
const s = h, _ = S(), l = C(L), f = j("tabs"), a = g(), m = g(), v = () => {
|
|
14
|
+
let t = 0, e = 0;
|
|
15
|
+
const o = ["top", "bottom"].includes(l.props.tabPosition) ? "width" : "height", u = o === "width" ? "x" : "y", z = u === "x" ? "left" : "top";
|
|
16
|
+
return s.tabs.every((b) => {
|
|
17
|
+
var d, y;
|
|
18
|
+
const r = (y = (d = _.parent) == null ? void 0 : d.refs) == null ? void 0 : y[`tab-${b.uid}`];
|
|
19
|
+
if (!r)
|
|
20
|
+
return !1;
|
|
21
|
+
if (!b.active)
|
|
22
|
+
return !0;
|
|
23
|
+
t = r[`offset${p(z)}`], e = r[`client${p(o)}`];
|
|
24
|
+
const i = window.getComputedStyle(r);
|
|
25
|
+
return o === "width" && (s.tabs.length > 1 && (e -= Number.parseFloat(i.paddingLeft) + Number.parseFloat(i.paddingRight)), t += Number.parseFloat(i.paddingLeft)), !1;
|
|
26
|
+
}), {
|
|
27
|
+
[o]: `${e}px`,
|
|
28
|
+
transform: `translate${p(u)}(${t}px)`
|
|
29
|
+
};
|
|
30
|
+
}, n = () => m.value = v();
|
|
31
|
+
N(
|
|
32
|
+
() => s.tabs,
|
|
33
|
+
async () => {
|
|
34
|
+
await R(), n();
|
|
35
|
+
},
|
|
36
|
+
{ immediate: !0 }
|
|
37
|
+
);
|
|
38
|
+
const w = k(() => l.props.tabPosition);
|
|
39
|
+
return D(a, () => n()), x({
|
|
40
|
+
ref: a,
|
|
41
|
+
update: n
|
|
42
|
+
}), (t, e) => (B(), F("div", {
|
|
43
|
+
ref_key: "barRef",
|
|
44
|
+
ref: a,
|
|
45
|
+
class: P([c(f).e("active-bar"), c(f).is(c(w))]),
|
|
46
|
+
style: T(m.value)
|
|
47
|
+
}, null, 6));
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
export {
|
|
51
|
+
G as default
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=tab-bar.vue2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tab-bar.vue2.mjs","sources":["../../../../../packages/components/tabs/tab-bar.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { type TabsPaneContext, TabsRootContextKey } from './types';\nimport { useNamespace } from '@vft-ui/hooks';\nimport { capitalize } from '@vft/utils';\nimport { getCurrentInstance, inject, nextTick, ref, watch, computed } from 'vue';\nimport { useResizeObserver } from '@vueuse/core';\n\nimport type { CSSProperties } from 'vue';\n\nconst props = defineProps({\n \"tabs\": null\n});\n\nconst instance = getCurrentInstance()!;\nconst rootTabs = inject(TabsRootContextKey)!;\n\nconst ns = useNamespace('tabs');\n\nconst barRef = ref<HTMLDivElement>();\nconst barStyle = ref<CSSProperties>();\n\nconst getBarStyle = (): CSSProperties => {\n let offset = 0;\n let tabSize = 0;\n\n const sizeName = ['top', 'bottom'].includes(rootTabs.props.tabPosition!)\n ? 'width'\n : 'height';\n const sizeDir = sizeName === 'width' ? 'x' : 'y';\n const position = sizeDir === 'x' ? 'left' : 'top';\n\n props.tabs.every((tab) => {\n const $el = instance.parent?.refs?.[`tab-${tab.uid}`] as HTMLElement;\n if (!$el) return false;\n\n if (!tab.active) {\n return true;\n }\n offset = $el[`offset${capitalize(position)}`];\n tabSize = $el[`client${capitalize(sizeName)}`];\n\n const tabStyles = window.getComputedStyle($el);\n\n if (sizeName === 'width') {\n if (props.tabs.length > 1) {\n tabSize -=\n Number.parseFloat(tabStyles.paddingLeft) +\n Number.parseFloat(tabStyles.paddingRight);\n }\n offset += Number.parseFloat(tabStyles.paddingLeft);\n }\n return false;\n });\n\n return {\n [sizeName]: `${tabSize}px`,\n transform: `translate${capitalize(sizeDir)}(${offset}px)`\n };\n};\n\nconst update = () => (barStyle.value = getBarStyle());\n\nwatch(\n () => props.tabs,\n async () => {\n await nextTick();\n update();\n },\n { immediate: true }\n);\n\nconst _tabPosition = computed(() => {\n return rootTabs.props.tabPosition!;\n});\n\nuseResizeObserver(barRef, () => update());\n\ndefineExpose({\n ref: barRef,\n update\n});\n</script>\n\n<template>\n <div\n ref=\"barRef\"\n :class=\"[ns.e('active-bar'), ns.is(_tabPosition)]\"\n :style=\"barStyle\"\n />\n</template>\n"],"names":["instance","getCurrentInstance","rootTabs","inject","TabsRootContextKey","ns","useNamespace","barRef","ref","barStyle","getBarStyle","offset","tabSize","sizeName","sizeDir","position","props","tab","$el","_b","_a","capitalize","tabStyles","update","watch","nextTick","_tabPosition","computed","useResizeObserver","expose"],"mappings":";;;;;;;;;;;;iBAaMA,IAAWC,KACXC,IAAWC,EAAOC,CAAkB,GAEpCC,IAAKC,EAAa,MAAM,GAExBC,IAASC,KACTC,IAAWD,KAEXE,IAAc,MAAqB;AACvC,UAAIC,IAAS,GACTC,IAAU;AAER,YAAAC,IAAW,CAAC,OAAO,QAAQ,EAAE,SAASX,EAAS,MAAM,WAAY,IACnE,UACA,UACEY,IAAUD,MAAa,UAAU,MAAM,KACvCE,IAAWD,MAAY,MAAM,SAAS;AAEtC,aAAAE,EAAA,KAAK,MAAM,CAACC,MAAQ;;AACxB,cAAMC,KAAMC,KAAAC,IAAApB,EAAS,WAAT,gBAAAoB,EAAiB,SAAjB,gBAAAD,EAAwB,OAAOF,EAAI;AAC/C,YAAI,CAACC;AAAY,iBAAA;AAEb,YAAA,CAACD,EAAI;AACA,iBAAA;AAET,QAAAN,IAASO,EAAI,SAASG,EAAWN,CAAQ,GAAG,GAC5CH,IAAUM,EAAI,SAASG,EAAWR,CAAQ,GAAG;AAEvC,cAAAS,IAAY,OAAO,iBAAiBJ,CAAG;AAE7C,eAAIL,MAAa,YACXG,EAAM,KAAK,SAAS,MAEpBJ,KAAA,OAAO,WAAWU,EAAU,WAAW,IACvC,OAAO,WAAWA,EAAU,YAAY,IAElCX,KAAA,OAAO,WAAWW,EAAU,WAAW,IAE5C;AAAA,MAAA,CACR,GAEM;AAAA,QACL,CAACT,CAAQ,GAAG,GAAGD;AAAA,QACf,WAAW,YAAYS,EAAWP,CAAO,KAAKH;AAAA,MAAA;AAAA,IAChD,GAGIY,IAAS,MAAOd,EAAS,QAAQC,EAAY;AAEnD,IAAAc;AAAA,MACE,MAAMR,EAAM;AAAA,MACZ,YAAY;AACV,cAAMS,EAAS,GACRF;MACT;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IAAA;AAGd,UAAAG,IAAeC,EAAS,MACrBzB,EAAS,MAAM,WACvB;AAEiB,WAAA0B,EAAArB,GAAQ,MAAMgB,EAAA,CAAQ,GAE3BM,EAAA;AAAA,MACX,KAAKtB;AAAA,MACL,QAAAgB;AAAA,IAAA,CACD;;;;;;;;"}
|