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.
Files changed (167) hide show
  1. package/dist/index.css +1 -1
  2. package/es/component.mjs +9 -6
  3. package/es/component.mjs.map +1 -1
  4. package/es/components/avatar/avatar.vue2.mjs +12 -11
  5. package/es/components/avatar/avatar.vue2.mjs.map +1 -1
  6. package/es/components/avatar/index.mjs +2 -0
  7. package/es/components/avatar/index.mjs.map +1 -1
  8. package/es/components/back-top/back-top.vue2.mjs +20 -18
  9. package/es/components/back-top/back-top.vue2.mjs.map +1 -1
  10. package/es/components/back-top/index.mjs +2 -0
  11. package/es/components/back-top/index.mjs.map +1 -1
  12. package/es/components/divider/divider.vue2.mjs +4 -2
  13. package/es/components/divider/divider.vue2.mjs.map +1 -1
  14. package/es/components/divider/index.mjs +5 -3
  15. package/es/components/divider/index.mjs.map +1 -1
  16. package/es/components/empty/empty.vue2.mjs.map +1 -1
  17. package/es/components/empty/index.mjs +7 -5
  18. package/es/components/empty/index.mjs.map +1 -1
  19. package/es/components/exception/index.mjs +5 -3
  20. package/es/components/exception/index.mjs.map +1 -1
  21. package/es/components/icon/icon.vue2.mjs +11 -10
  22. package/es/components/icon/icon.vue2.mjs.map +1 -1
  23. package/es/components/icon/index.mjs +5 -3
  24. package/es/components/icon/index.mjs.map +1 -1
  25. package/es/components/index.d.ts +1 -0
  26. package/es/components/index.mjs +11 -6
  27. package/es/components/index.mjs.map +1 -1
  28. package/es/components/result/index.mjs +5 -3
  29. package/es/components/result/index.mjs.map +1 -1
  30. package/es/components/result/result.vue2.mjs +4 -2
  31. package/es/components/result/result.vue2.mjs.map +1 -1
  32. package/es/components/tabs/index.d.ts +356 -0
  33. package/es/components/tabs/index.mjs +15 -0
  34. package/es/components/tabs/index.mjs.map +1 -0
  35. package/es/components/tabs/style/css.d.ts +0 -0
  36. package/es/components/tabs/style/css.mjs +3 -0
  37. package/es/components/tabs/style/css.mjs.map +1 -0
  38. package/es/components/tabs/style/index.d.ts +0 -0
  39. package/es/components/tabs/style/index.mjs +3 -0
  40. package/es/components/tabs/style/index.mjs.map +1 -0
  41. package/es/components/tabs/tab-bar.vue.d.ts +51 -0
  42. package/es/components/tabs/tab-bar.vue.mjs +5 -0
  43. package/es/components/tabs/tab-bar.vue.mjs.map +1 -0
  44. package/es/components/tabs/tab-bar.vue2.mjs +53 -0
  45. package/es/components/tabs/tab-bar.vue2.mjs.map +1 -0
  46. package/es/components/tabs/tab-nav.vue.d.ts +121 -0
  47. package/es/components/tabs/tab-nav.vue.mjs +5 -0
  48. package/es/components/tabs/tab-nav.vue.mjs.map +1 -0
  49. package/es/components/tabs/tab-nav.vue2.mjs +167 -0
  50. package/es/components/tabs/tab-nav.vue2.mjs.map +1 -0
  51. package/es/components/tabs/tab-pane.vue.d.ts +45 -0
  52. package/es/components/tabs/tab-pane.vue.mjs +5 -0
  53. package/es/components/tabs/tab-pane.vue.mjs.map +1 -0
  54. package/es/components/tabs/tab-pane.vue2.mjs +57 -0
  55. package/es/components/tabs/tab-pane.vue2.mjs.map +1 -0
  56. package/es/components/tabs/tabs.vue.d.ts +159 -0
  57. package/es/components/tabs/tabs.vue.mjs +5 -0
  58. package/es/components/tabs/tabs.vue.mjs.map +1 -0
  59. package/es/components/tabs/tabs.vue2.mjs +151 -0
  60. package/es/components/tabs/tabs.vue2.mjs.map +1 -0
  61. package/es/components/tabs/types.d.ts +58 -0
  62. package/es/components/tabs/types.mjs +5 -0
  63. package/es/components/tabs/types.mjs.map +1 -0
  64. package/es/hooks/index.d.ts +1 -0
  65. package/es/hooks/index.mjs +6 -4
  66. package/es/hooks/index.mjs.map +1 -1
  67. package/es/hooks/use-ordered-children/index.d.ts +8 -0
  68. package/es/hooks/use-ordered-children/index.mjs +27 -0
  69. package/es/hooks/use-ordered-children/index.mjs.map +1 -0
  70. package/es/index.d.ts +1 -1
  71. package/es/index.mjs +42 -35
  72. package/es/index.mjs.map +1 -1
  73. package/es/package.json.mjs +1 -1
  74. package/es/style.css +1 -1
  75. package/es/theme-style/src/tabs.scss.mjs +5 -0
  76. package/es/theme-style/src/tabs.scss.mjs.map +1 -0
  77. package/es/utils/index.mjs +23 -10
  78. package/es/utils/index.mjs.map +1 -1
  79. package/es/utils/vue/index.d.ts +1 -0
  80. package/es/utils/vue/index.mjs +18 -5
  81. package/es/utils/vue/index.mjs.map +1 -1
  82. package/es/utils/vue/vnode.d.ts +51 -0
  83. package/es/utils/vue/vnode.mjs +67 -0
  84. package/es/utils/vue/vnode.mjs.map +1 -0
  85. package/lib/component.js +1 -1
  86. package/lib/component.js.map +1 -1
  87. package/lib/components/avatar/avatar.vue2.js +1 -1
  88. package/lib/components/avatar/avatar.vue2.js.map +1 -1
  89. package/lib/components/avatar/index.js +1 -1
  90. package/lib/components/avatar/index.js.map +1 -1
  91. package/lib/components/back-top/back-top.vue2.js +1 -1
  92. package/lib/components/back-top/back-top.vue2.js.map +1 -1
  93. package/lib/components/back-top/index.js +1 -1
  94. package/lib/components/back-top/index.js.map +1 -1
  95. package/lib/components/divider/divider.vue2.js +1 -1
  96. package/lib/components/divider/divider.vue2.js.map +1 -1
  97. package/lib/components/divider/index.js +1 -1
  98. package/lib/components/divider/index.js.map +1 -1
  99. package/lib/components/empty/empty.vue2.js.map +1 -1
  100. package/lib/components/empty/index.js +1 -1
  101. package/lib/components/empty/index.js.map +1 -1
  102. package/lib/components/exception/index.js +1 -1
  103. package/lib/components/exception/index.js.map +1 -1
  104. package/lib/components/icon/icon.vue2.js +1 -1
  105. package/lib/components/icon/icon.vue2.js.map +1 -1
  106. package/lib/components/icon/index.js +1 -1
  107. package/lib/components/icon/index.js.map +1 -1
  108. package/lib/components/index.d.ts +1 -0
  109. package/lib/components/index.js +1 -1
  110. package/lib/components/result/index.js +1 -1
  111. package/lib/components/result/index.js.map +1 -1
  112. package/lib/components/result/result.vue2.js +1 -1
  113. package/lib/components/result/result.vue2.js.map +1 -1
  114. package/lib/components/tabs/index.d.ts +356 -0
  115. package/lib/components/tabs/index.js +2 -0
  116. package/lib/components/tabs/index.js.map +1 -0
  117. package/lib/components/tabs/style/css.d.ts +0 -0
  118. package/lib/components/tabs/style/css.js +2 -0
  119. package/lib/components/tabs/style/css.js.map +1 -0
  120. package/lib/components/tabs/style/index.d.ts +0 -0
  121. package/lib/components/tabs/style/index.js +2 -0
  122. package/lib/components/tabs/style/index.js.map +1 -0
  123. package/lib/components/tabs/tab-bar.vue.d.ts +51 -0
  124. package/lib/components/tabs/tab-bar.vue.js +2 -0
  125. package/lib/components/tabs/tab-bar.vue.js.map +1 -0
  126. package/lib/components/tabs/tab-bar.vue2.js +2 -0
  127. package/lib/components/tabs/tab-bar.vue2.js.map +1 -0
  128. package/lib/components/tabs/tab-nav.vue.d.ts +121 -0
  129. package/lib/components/tabs/tab-nav.vue.js +2 -0
  130. package/lib/components/tabs/tab-nav.vue.js.map +1 -0
  131. package/lib/components/tabs/tab-nav.vue2.js +2 -0
  132. package/lib/components/tabs/tab-nav.vue2.js.map +1 -0
  133. package/lib/components/tabs/tab-pane.vue.d.ts +45 -0
  134. package/lib/components/tabs/tab-pane.vue.js +2 -0
  135. package/lib/components/tabs/tab-pane.vue.js.map +1 -0
  136. package/lib/components/tabs/tab-pane.vue2.js +2 -0
  137. package/lib/components/tabs/tab-pane.vue2.js.map +1 -0
  138. package/lib/components/tabs/tabs.vue.d.ts +159 -0
  139. package/lib/components/tabs/tabs.vue.js +2 -0
  140. package/lib/components/tabs/tabs.vue.js.map +1 -0
  141. package/lib/components/tabs/tabs.vue2.js +2 -0
  142. package/lib/components/tabs/tabs.vue2.js.map +1 -0
  143. package/lib/components/tabs/types.d.ts +58 -0
  144. package/lib/components/tabs/types.js +2 -0
  145. package/lib/components/tabs/types.js.map +1 -0
  146. package/lib/hooks/index.d.ts +1 -0
  147. package/lib/hooks/index.js +1 -1
  148. package/lib/hooks/use-ordered-children/index.d.ts +8 -0
  149. package/lib/hooks/use-ordered-children/index.js +2 -0
  150. package/lib/hooks/use-ordered-children/index.js.map +1 -0
  151. package/lib/index.d.ts +1 -1
  152. package/lib/index.js +1 -1
  153. package/lib/index.js.map +1 -1
  154. package/lib/package.json.js +1 -1
  155. package/lib/theme-style/src/tabs.scss.js +2 -0
  156. package/lib/theme-style/src/tabs.scss.js.map +1 -0
  157. package/lib/utils/index.js +1 -1
  158. package/lib/utils/vue/index.d.ts +1 -0
  159. package/lib/utils/vue/index.js +1 -1
  160. package/lib/utils/vue/vnode.d.ts +51 -0
  161. package/lib/utils/vue/vnode.js +2 -0
  162. package/lib/utils/vue/vnode.js.map +1 -0
  163. package/package.json +1 -1
  164. package/theme-style/index.css +1 -1
  165. package/theme-style/src/index.scss +1 -0
  166. package/theme-style/src/tabs.scss +582 -0
  167. 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":";;;AAIa,MAAAA,IAAYC,EAAYC,CAAM;"}
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
- }), k = /* @__PURE__ */ u({
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
- k as default
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/use';\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;;"}
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,3 @@
1
+ import "vft/theme-style/base.css";
2
+ import "vft/theme-style/vft-tabs.css";
3
+ //# sourceMappingURL=css.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
File without changes
@@ -0,0 +1,3 @@
1
+ import "../../../theme-style/src/base.scss.mjs";
2
+ import "../../../theme-style/src/tabs.scss.mjs";
3
+ //# sourceMappingURL=index.mjs.map
@@ -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,5 @@
1
+ import f from "./tab-bar.vue2.mjs";
2
+ export {
3
+ f as default
4
+ };
5
+ //# sourceMappingURL=tab-bar.vue.mjs.map
@@ -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;;;;;;;;"}