@auronui/vue 1.0.5 → 1.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/cjs/index.cjs +314 -45
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/components/tabs/Tab.js.map +1 -1
- package/dist/components/tabs/Tab.vue_vue_type_script_setup_true_lang.js +2 -0
- package/dist/components/tabs/Tab.vue_vue_type_script_setup_true_lang.js.map +1 -1
- package/dist/components/tabs/TabList.js.map +1 -1
- package/dist/components/tabs/TabList.vue_vue_type_script_setup_true_lang.js +262 -3
- package/dist/components/tabs/TabList.vue_vue_type_script_setup_true_lang.js.map +1 -1
- package/dist/components/tabs/Tabs.js.map +1 -1
- package/dist/components/tabs/Tabs.vue_vue_type_script_setup_true_lang.js +14 -6
- package/dist/components/tabs/Tabs.vue_vue_type_script_setup_true_lang.js.map +1 -1
- package/dist/components/tabs/tabs.context.js.map +1 -1
- package/package.json +4 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tab.js","names":[],"sources":["../../../src/components/tabs/Tab.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsTrigger } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n value: string\n disabled?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsTrigger\n :value=\"props.value\"\n :disabled=\"props.disabled\"\n :class=\"composeClassName(ctx.slotFns.value.tab(), props.class)\"\n >\n <slot />\n </TabsTrigger>\n</template>\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"Tab.js","names":[],"sources":["../../../src/components/tabs/Tab.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsTrigger } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n value: string\n disabled?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsTrigger\n :value=\"props.value\"\n :disabled=\"props.disabled\"\n :data-tab-value=\"props.value\"\n :class=\"composeClassName(ctx.slotFns.value.tab(), props.class)\"\n >\n <slot />\n </TabsTrigger>\n</template>\n"],"mappings":""}
|
|
@@ -17,6 +17,7 @@ var Tab_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComp
|
|
|
17
17
|
return openBlock(), createBlock(unref(TabsTrigger), {
|
|
18
18
|
value: props.value,
|
|
19
19
|
disabled: props.disabled,
|
|
20
|
+
"data-tab-value": props.value,
|
|
20
21
|
class: normalizeClass(unref(composeClassName)(unref(ctx).slotFns.value.tab(), props.class))
|
|
21
22
|
}, {
|
|
22
23
|
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
@@ -24,6 +25,7 @@ var Tab_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComp
|
|
|
24
25
|
}, 8, [
|
|
25
26
|
"value",
|
|
26
27
|
"disabled",
|
|
28
|
+
"data-tab-value",
|
|
27
29
|
"class"
|
|
28
30
|
]);
|
|
29
31
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tab.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/Tab.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsTrigger } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n value: string\n disabled?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsTrigger\n :value=\"props.value\"\n :disabled=\"props.disabled\"\n :class=\"composeClassName(ctx.slotFns.value.tab(), props.class)\"\n >\n <slot />\n </TabsTrigger>\n</template>\n"],"mappings":";;;;;;;;;;;;;EAKA,MAAM,QAAQ;EAMd,MAAM,MAAM,eAAc;;uBAIxB,
|
|
1
|
+
{"version":3,"file":"Tab.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/Tab.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsTrigger } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n value: string\n disabled?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsTrigger\n :value=\"props.value\"\n :disabled=\"props.disabled\"\n :data-tab-value=\"props.value\"\n :class=\"composeClassName(ctx.slotFns.value.tab(), props.class)\"\n >\n <slot />\n </TabsTrigger>\n</template>\n"],"mappings":";;;;;;;;;;;;;EAKA,MAAM,QAAQ;EAMd,MAAM,MAAM,eAAc;;uBAIxB,YAOc,MAAA,YAAA,EAAA;IANX,OAAO,MAAM;IACb,UAAU,MAAM;IAChB,kBAAgB,MAAM;IACtB,OAAK,eAAE,MAAA,iBAAgB,CAAC,MAAA,IAAG,CAAC,QAAQ,MAAM,KAAG,EAAI,MAAM,MAAK,CAAA;;2BAErD,CAAR,WAAQ,KAAA,QAAA,UAAA,CAAA,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabList.js","names":[],"sources":["../../../src/components/tabs/TabList.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsList } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n loop?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), props.class)\"\n >\n <slot />\n </TabsList>\n</template>\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"TabList.js","names":[],"sources":["../../../src/components/tabs/TabList.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ref, computed, nextTick, onMounted, watch } from 'vue'\nimport { useTemplateRef } from 'vue'\nimport { TabsList } from 'reka-ui'\nimport { useResizeObserver, onClickOutside } from '@vueuse/core'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\nimport Button from '../button/Button.vue'\n\nconst props = defineProps<{\n loop?: boolean\n overflow?: 'arrows' | 'dropdown'\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n\n// ── Arrows mode ─────────────────────────────────────────────────────────────\nconst scrollWrapperEl = useTemplateRef<HTMLElement>('scrollWrapperEl')\nconst canScrollLeft = ref(false)\nconst canScrollRight = ref(false)\n\nfunction updateScrollButtons() {\n const el = scrollWrapperEl.value\n if (!el) { canScrollLeft.value = false; canScrollRight.value = false; return }\n canScrollLeft.value = el.scrollLeft > 1\n canScrollRight.value = el.scrollLeft + el.clientWidth < el.scrollWidth - 1\n}\n\nfunction scrollTabs(dir: 'left' | 'right') {\n const el = scrollWrapperEl.value\n if (!el) return\n el.scrollBy({ left: dir === 'left' ? -200 : 200, behavior: 'smooth' })\n // Poll briefly after smooth scroll starts so button states update\n setTimeout(updateScrollButtons, 150)\n setTimeout(updateScrollButtons, 350)\n}\n\nwatch(scrollWrapperEl, (el, oldEl) => {\n if (oldEl) oldEl.removeEventListener('scroll', updateScrollButtons)\n if (el) {\n el.addEventListener('scroll', updateScrollButtons, { passive: true })\n nextTick(updateScrollButtons)\n }\n}, { immediate: true })\n\nuseResizeObserver(scrollWrapperEl, () => nextTick(updateScrollButtons))\n\n// ── Dropdown mode ────────────────────────────────────────────────────────────\ninterface OverflowTab {\n value: string\n label: string\n disabled: boolean\n}\n\nconst containerEl = useTemplateRef<HTMLElement>('containerEl')\n// Button component ref — use .$el to reach the underlying DOM element for offsetWidth\nconst moreBtnEl = useTemplateRef<InstanceType<typeof Button>>('moreBtnEl')\nconst dropdownEl = useTemplateRef<HTMLElement>('dropdownEl')\n\nconst hiddenTabs = ref<OverflowTab[]>([])\nconst dropdownOpen = ref(false)\nconst hasOverflow = computed(() => hiddenTabs.value.length > 0)\n// Pre-measured natural width of the more button (measured once on mount before it's visible)\nlet moreBtnNaturalWidth = 48\n\nonClickOutside(dropdownEl, () => { dropdownOpen.value = false })\n\nfunction computeOverflow() {\n if (!containerEl.value) return\n\n const allTabs = Array.from(\n containerEl.value.querySelectorAll('[data-tab-value]'),\n ) as HTMLElement[]\n\n // Reveal all tabs first\n allTabs.forEach(t => t.removeAttribute('data-overflow-hidden'))\n\n // Tabs use w-full and shrink to share the container width, so offsetWidth after\n // a normal render would be containerWidth/n — useless for overflow detection.\n // Force each tab to its natural content width for measurement only (no paint flash:\n // all DOM reads/writes happen synchronously within this JS task before the next frame).\n const listEl = containerEl.value.querySelector('[role=\"tablist\"]') as HTMLElement | null\n if (listEl) {\n listEl.style.overflow = 'visible'\n allTabs.forEach(t => { t.style.flexShrink = '0'; t.style.width = 'auto' })\n void listEl.offsetWidth // force reflow so offsetWidth reads below are accurate\n }\n\n const containerWidth = containerEl.value.clientWidth\n const tabWidths = allTabs.map(t => t.offsetWidth)\n const totalWidth = tabWidths.reduce((sum, w) => sum + w, 0)\n\n // Restore layout before any early-return so tabs always look correct\n if (listEl) {\n listEl.style.overflow = ''\n allTabs.forEach(t => { t.style.flexShrink = ''; t.style.width = '' })\n }\n\n if (totalWidth <= containerWidth) {\n hiddenTabs.value = []\n return\n }\n\n // More button is in-flow (display:none when no overflow, display:flex when visible).\n // Use the pre-measured natural width so the calculation is accurate on the first run\n // before the button becomes visible.\n const available = containerWidth - moreBtnNaturalWidth\n\n let accumulated = 0\n const newHidden: OverflowTab[] = []\n const visibleEls: HTMLElement[] = []\n\n for (let i = 0; i < allTabs.length; i++) {\n const tab = allTabs[i]\n const w = tabWidths[i]\n if (accumulated + w <= available) {\n accumulated += w\n visibleEls.push(tab)\n } else {\n newHidden.push({\n value: tab.getAttribute('data-tab-value') ?? '',\n label: tab.textContent?.trim() ?? '',\n disabled: tab.hasAttribute('data-disabled') || tab.getAttribute('aria-disabled') === 'true',\n })\n tab.setAttribute('data-overflow-hidden', '')\n }\n }\n\n // If the active tab ended up hidden, swap it with the last visible tab\n const activeValue = ctx.currentValue.value\n if (activeValue) {\n const hiddenActiveIdx = newHidden.findIndex(t => t.value === activeValue)\n if (hiddenActiveIdx !== -1 && visibleEls.length > 0) {\n const displacedEl = visibleEls[visibleEls.length - 1]\n const activeEl = allTabs.find(t => t.getAttribute('data-tab-value') === activeValue)\n\n if (displacedEl && activeEl) {\n // Swap: make displaced tab hidden, active tab visible\n displacedEl.setAttribute('data-overflow-hidden', '')\n activeEl.removeAttribute('data-overflow-hidden')\n\n const displaced: OverflowTab = {\n value: displacedEl.getAttribute('data-tab-value') ?? '',\n label: displacedEl.textContent?.trim() ?? '',\n disabled: displacedEl.hasAttribute('data-disabled') || displacedEl.getAttribute('aria-disabled') === 'true',\n }\n newHidden.splice(hiddenActiveIdx, 1)\n newHidden.unshift(displaced)\n }\n }\n }\n\n hiddenTabs.value = newHidden\n}\n\nuseResizeObserver(containerEl, () => nextTick(computeOverflow))\nonMounted(() => {\n // Pre-measure the more button's natural width before it becomes visible (display:none).\n // Temporarily show it, read offsetWidth, then hide again — happens before first paint.\n const btnEl = (moreBtnEl.value as InstanceType<typeof Button> | null)?.$el as HTMLElement | null\n if (btnEl) {\n btnEl.style.display = 'flex'\n void btnEl.offsetWidth\n moreBtnNaturalWidth = btnEl.offsetWidth\n btnEl.style.display = ''\n }\n nextTick(computeOverflow)\n})\n\n// Recompute when the active tab changes so the active tab is always visible\nwatch(() => ctx.currentValue.value, () => {\n if (props.overflow === 'dropdown') nextTick(computeOverflow)\n})\n\n// When overflow state first transitions false→true the more button enters the flex flow,\n// narrowing the container. Re-run once so the tab count reflects the reduced available space.\nwatch(hasOverflow, () => {\n if (props.overflow === 'dropdown') nextTick(computeOverflow)\n})\n\nfunction selectOverflowTab(value: string) {\n ctx.changeTab(value)\n dropdownOpen.value = false\n}\n</script>\n\n<template>\n <!-- ── Default (no overflow behaviour) ───────────────────────────────────── -->\n <TabsList\n v-if=\"!props.overflow\"\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), props.class)\"\n >\n <slot />\n </TabsList>\n\n <!-- ── Arrows mode ────────────────────────────────────────────────────────── -->\n <div\n v-else-if=\"props.overflow === 'arrows'\"\n class=\"tabs__list-container tabs__list-container--arrows\"\n :class=\"{ 'has-left': canScrollLeft, 'has-right': canScrollRight }\"\n >\n <Button\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n :is-icon-only=\"true\"\n :class=\"composeClassName('tabs__arrow tabs__arrow--left', canScrollLeft && 'is-visible')\"\n aria-label=\"Scroll tabs left\"\n tabindex=\"-1\"\n @click=\"scrollTabs('left')\"\n >\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M9 11L5 7L9 3\" stroke=\"currentColor\" stroke-width=\"1.75\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n\n <div ref=\"scrollWrapperEl\" class=\"tabs__scroll-wrapper\">\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), 'tabs__list--scroll', props.class)\"\n >\n <slot />\n </TabsList>\n </div>\n\n <Button\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n :is-icon-only=\"true\"\n :class=\"composeClassName('tabs__arrow tabs__arrow--right', canScrollRight && 'is-visible')\"\n aria-label=\"Scroll tabs right\"\n tabindex=\"-1\"\n @click=\"scrollTabs('right')\"\n >\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M5 3L9 7L5 11\" stroke=\"currentColor\" stroke-width=\"1.75\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n </div>\n\n <!-- ── Dropdown mode ──────────────────────────────────────────────────────── -->\n <div\n v-else-if=\"props.overflow === 'dropdown'\"\n ref=\"containerEl\"\n class=\"tabs__list-container tabs__list-container--dropdown\"\n >\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), 'tabs__list--clipped', props.class)\"\n >\n <slot />\n </TabsList>\n\n <!-- Always rendered so offsetWidth is measurable; visibility toggled via CSS -->\n <div\n ref=\"dropdownEl\"\n class=\"tabs__more\"\n :class=\"{ 'tabs__more--visible': hasOverflow }\"\n >\n <Button\n ref=\"moreBtnEl\"\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n class=\"tabs__more-btn\"\n :aria-expanded=\"dropdownOpen\"\n aria-haspopup=\"menu\"\n @click=\"dropdownOpen = !dropdownOpen\"\n >\n +{{ hiddenTabs.length }}\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M2 4L6 8L10 4\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n\n <div v-if=\"dropdownOpen\" class=\"tabs__overflow-menu\" role=\"menu\">\n <Button\n v-for=\"tab in hiddenTabs\"\n :key=\"tab.value\"\n variant=\"ghost\"\n radius=\"lg\"\n class=\"tabs__overflow-item\"\n role=\"menuitem\"\n :disabled=\"tab.disabled\"\n @click=\"selectOverflowTab(tab.value)\"\n >\n {{ tab.label }}\n </Button>\n </div>\n </div>\n </div>\n</template>\n"],"mappings":""}
|
|
@@ -1,25 +1,284 @@
|
|
|
1
1
|
import { composeClassName } from "../../utils/composeClassName.js";
|
|
2
|
+
import Button_default from "../button/Button.js";
|
|
2
3
|
import { useTabsInject } from "./tabs.context.js";
|
|
3
|
-
import { createBlock, defineComponent, normalizeClass, openBlock, renderSlot, unref, withCtx } from "vue";
|
|
4
|
+
import { Fragment, computed, createBlock, createCommentVNode, createElementBlock, createElementVNode, createTextVNode, createVNode, defineComponent, nextTick, normalizeClass, onMounted, openBlock, ref, renderList, renderSlot, toDisplayString, unref, useTemplateRef, watch, withCtx } from "vue";
|
|
5
|
+
import { onClickOutside, useResizeObserver } from "@vueuse/core";
|
|
4
6
|
import { TabsList } from "reka-ui";
|
|
5
7
|
//#region src/components/tabs/TabList.vue?vue&type=script&setup=true&lang.ts
|
|
8
|
+
var _hoisted_1 = {
|
|
9
|
+
key: 0,
|
|
10
|
+
class: "tabs__overflow-menu",
|
|
11
|
+
role: "menu"
|
|
12
|
+
};
|
|
6
13
|
var TabList_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineComponent({
|
|
7
14
|
__name: "TabList",
|
|
8
15
|
props: {
|
|
9
16
|
loop: { type: Boolean },
|
|
17
|
+
overflow: {},
|
|
10
18
|
class: {}
|
|
11
19
|
},
|
|
12
20
|
setup(__props) {
|
|
13
21
|
const props = __props;
|
|
14
22
|
const ctx = useTabsInject();
|
|
23
|
+
const scrollWrapperEl = useTemplateRef("scrollWrapperEl");
|
|
24
|
+
const canScrollLeft = ref(false);
|
|
25
|
+
const canScrollRight = ref(false);
|
|
26
|
+
function updateScrollButtons() {
|
|
27
|
+
const el = scrollWrapperEl.value;
|
|
28
|
+
if (!el) {
|
|
29
|
+
canScrollLeft.value = false;
|
|
30
|
+
canScrollRight.value = false;
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
canScrollLeft.value = el.scrollLeft > 1;
|
|
34
|
+
canScrollRight.value = el.scrollLeft + el.clientWidth < el.scrollWidth - 1;
|
|
35
|
+
}
|
|
36
|
+
function scrollTabs(dir) {
|
|
37
|
+
const el = scrollWrapperEl.value;
|
|
38
|
+
if (!el) return;
|
|
39
|
+
el.scrollBy({
|
|
40
|
+
left: dir === "left" ? -200 : 200,
|
|
41
|
+
behavior: "smooth"
|
|
42
|
+
});
|
|
43
|
+
setTimeout(updateScrollButtons, 150);
|
|
44
|
+
setTimeout(updateScrollButtons, 350);
|
|
45
|
+
}
|
|
46
|
+
watch(scrollWrapperEl, (el, oldEl) => {
|
|
47
|
+
if (oldEl) oldEl.removeEventListener("scroll", updateScrollButtons);
|
|
48
|
+
if (el) {
|
|
49
|
+
el.addEventListener("scroll", updateScrollButtons, { passive: true });
|
|
50
|
+
nextTick(updateScrollButtons);
|
|
51
|
+
}
|
|
52
|
+
}, { immediate: true });
|
|
53
|
+
useResizeObserver(scrollWrapperEl, () => nextTick(updateScrollButtons));
|
|
54
|
+
const containerEl = useTemplateRef("containerEl");
|
|
55
|
+
const moreBtnEl = useTemplateRef("moreBtnEl");
|
|
56
|
+
const dropdownEl = useTemplateRef("dropdownEl");
|
|
57
|
+
const hiddenTabs = ref([]);
|
|
58
|
+
const dropdownOpen = ref(false);
|
|
59
|
+
const hasOverflow = computed(() => hiddenTabs.value.length > 0);
|
|
60
|
+
let moreBtnNaturalWidth = 48;
|
|
61
|
+
onClickOutside(dropdownEl, () => {
|
|
62
|
+
dropdownOpen.value = false;
|
|
63
|
+
});
|
|
64
|
+
function computeOverflow() {
|
|
65
|
+
if (!containerEl.value) return;
|
|
66
|
+
const allTabs = Array.from(containerEl.value.querySelectorAll("[data-tab-value]"));
|
|
67
|
+
allTabs.forEach((t) => t.removeAttribute("data-overflow-hidden"));
|
|
68
|
+
const listEl = containerEl.value.querySelector("[role=\"tablist\"]");
|
|
69
|
+
if (listEl) {
|
|
70
|
+
listEl.style.overflow = "visible";
|
|
71
|
+
allTabs.forEach((t) => {
|
|
72
|
+
t.style.flexShrink = "0";
|
|
73
|
+
t.style.width = "auto";
|
|
74
|
+
});
|
|
75
|
+
listEl.offsetWidth;
|
|
76
|
+
}
|
|
77
|
+
const containerWidth = containerEl.value.clientWidth;
|
|
78
|
+
const tabWidths = allTabs.map((t) => t.offsetWidth);
|
|
79
|
+
const totalWidth = tabWidths.reduce((sum, w) => sum + w, 0);
|
|
80
|
+
if (listEl) {
|
|
81
|
+
listEl.style.overflow = "";
|
|
82
|
+
allTabs.forEach((t) => {
|
|
83
|
+
t.style.flexShrink = "";
|
|
84
|
+
t.style.width = "";
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
if (totalWidth <= containerWidth) {
|
|
88
|
+
hiddenTabs.value = [];
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
const available = containerWidth - moreBtnNaturalWidth;
|
|
92
|
+
let accumulated = 0;
|
|
93
|
+
const newHidden = [];
|
|
94
|
+
const visibleEls = [];
|
|
95
|
+
for (let i = 0; i < allTabs.length; i++) {
|
|
96
|
+
const tab = allTabs[i];
|
|
97
|
+
const w = tabWidths[i];
|
|
98
|
+
if (accumulated + w <= available) {
|
|
99
|
+
accumulated += w;
|
|
100
|
+
visibleEls.push(tab);
|
|
101
|
+
} else {
|
|
102
|
+
newHidden.push({
|
|
103
|
+
value: tab.getAttribute("data-tab-value") ?? "",
|
|
104
|
+
label: tab.textContent?.trim() ?? "",
|
|
105
|
+
disabled: tab.hasAttribute("data-disabled") || tab.getAttribute("aria-disabled") === "true"
|
|
106
|
+
});
|
|
107
|
+
tab.setAttribute("data-overflow-hidden", "");
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
const activeValue = ctx.currentValue.value;
|
|
111
|
+
if (activeValue) {
|
|
112
|
+
const hiddenActiveIdx = newHidden.findIndex((t) => t.value === activeValue);
|
|
113
|
+
if (hiddenActiveIdx !== -1 && visibleEls.length > 0) {
|
|
114
|
+
const displacedEl = visibleEls[visibleEls.length - 1];
|
|
115
|
+
const activeEl = allTabs.find((t) => t.getAttribute("data-tab-value") === activeValue);
|
|
116
|
+
if (displacedEl && activeEl) {
|
|
117
|
+
displacedEl.setAttribute("data-overflow-hidden", "");
|
|
118
|
+
activeEl.removeAttribute("data-overflow-hidden");
|
|
119
|
+
const displaced = {
|
|
120
|
+
value: displacedEl.getAttribute("data-tab-value") ?? "",
|
|
121
|
+
label: displacedEl.textContent?.trim() ?? "",
|
|
122
|
+
disabled: displacedEl.hasAttribute("data-disabled") || displacedEl.getAttribute("aria-disabled") === "true"
|
|
123
|
+
};
|
|
124
|
+
newHidden.splice(hiddenActiveIdx, 1);
|
|
125
|
+
newHidden.unshift(displaced);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
hiddenTabs.value = newHidden;
|
|
130
|
+
}
|
|
131
|
+
useResizeObserver(containerEl, () => nextTick(computeOverflow));
|
|
132
|
+
onMounted(() => {
|
|
133
|
+
const btnEl = moreBtnEl.value?.$el;
|
|
134
|
+
if (btnEl) {
|
|
135
|
+
btnEl.style.display = "flex";
|
|
136
|
+
btnEl.offsetWidth;
|
|
137
|
+
moreBtnNaturalWidth = btnEl.offsetWidth;
|
|
138
|
+
btnEl.style.display = "";
|
|
139
|
+
}
|
|
140
|
+
nextTick(computeOverflow);
|
|
141
|
+
});
|
|
142
|
+
watch(() => ctx.currentValue.value, () => {
|
|
143
|
+
if (props.overflow === "dropdown") nextTick(computeOverflow);
|
|
144
|
+
});
|
|
145
|
+
watch(hasOverflow, () => {
|
|
146
|
+
if (props.overflow === "dropdown") nextTick(computeOverflow);
|
|
147
|
+
});
|
|
148
|
+
function selectOverflowTab(value) {
|
|
149
|
+
ctx.changeTab(value);
|
|
150
|
+
dropdownOpen.value = false;
|
|
151
|
+
}
|
|
15
152
|
return (_ctx, _cache) => {
|
|
16
|
-
return openBlock(), createBlock(unref(TabsList), {
|
|
153
|
+
return !props.overflow ? (openBlock(), createBlock(unref(TabsList), {
|
|
154
|
+
key: 0,
|
|
17
155
|
loop: props.loop ?? true,
|
|
18
156
|
class: normalizeClass(unref(composeClassName)(unref(ctx).slotFns.value.tabList(), props.class))
|
|
19
157
|
}, {
|
|
20
158
|
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
21
159
|
_: 3
|
|
22
|
-
}, 8, ["loop", "class"])
|
|
160
|
+
}, 8, ["loop", "class"])) : props.overflow === "arrows" ? (openBlock(), createElementBlock("div", {
|
|
161
|
+
key: 1,
|
|
162
|
+
class: normalizeClass(["tabs__list-container tabs__list-container--arrows", {
|
|
163
|
+
"has-left": canScrollLeft.value,
|
|
164
|
+
"has-right": canScrollRight.value
|
|
165
|
+
}])
|
|
166
|
+
}, [
|
|
167
|
+
createVNode(Button_default, {
|
|
168
|
+
variant: "secondary",
|
|
169
|
+
size: "sm",
|
|
170
|
+
radius: "full",
|
|
171
|
+
"is-icon-only": true,
|
|
172
|
+
class: normalizeClass(unref(composeClassName)("tabs__arrow tabs__arrow--left", canScrollLeft.value && "is-visible")),
|
|
173
|
+
"aria-label": "Scroll tabs left",
|
|
174
|
+
tabindex: "-1",
|
|
175
|
+
onClick: _cache[0] || (_cache[0] = ($event) => scrollTabs("left"))
|
|
176
|
+
}, {
|
|
177
|
+
default: withCtx(() => [..._cache[3] || (_cache[3] = [createElementVNode("svg", {
|
|
178
|
+
width: "14",
|
|
179
|
+
height: "14",
|
|
180
|
+
viewBox: "0 0 14 14",
|
|
181
|
+
fill: "none",
|
|
182
|
+
"aria-hidden": "true"
|
|
183
|
+
}, [createElementVNode("path", {
|
|
184
|
+
d: "M9 11L5 7L9 3",
|
|
185
|
+
stroke: "currentColor",
|
|
186
|
+
"stroke-width": "1.75",
|
|
187
|
+
"stroke-linecap": "round",
|
|
188
|
+
"stroke-linejoin": "round"
|
|
189
|
+
})], -1)])]),
|
|
190
|
+
_: 1
|
|
191
|
+
}, 8, ["class"]),
|
|
192
|
+
createElementVNode("div", {
|
|
193
|
+
ref_key: "scrollWrapperEl",
|
|
194
|
+
ref: scrollWrapperEl,
|
|
195
|
+
class: "tabs__scroll-wrapper"
|
|
196
|
+
}, [createVNode(unref(TabsList), {
|
|
197
|
+
loop: props.loop ?? true,
|
|
198
|
+
class: normalizeClass(unref(composeClassName)(unref(ctx).slotFns.value.tabList(), "tabs__list--scroll", props.class))
|
|
199
|
+
}, {
|
|
200
|
+
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
201
|
+
_: 3
|
|
202
|
+
}, 8, ["loop", "class"])], 512),
|
|
203
|
+
createVNode(Button_default, {
|
|
204
|
+
variant: "secondary",
|
|
205
|
+
size: "sm",
|
|
206
|
+
radius: "full",
|
|
207
|
+
"is-icon-only": true,
|
|
208
|
+
class: normalizeClass(unref(composeClassName)("tabs__arrow tabs__arrow--right", canScrollRight.value && "is-visible")),
|
|
209
|
+
"aria-label": "Scroll tabs right",
|
|
210
|
+
tabindex: "-1",
|
|
211
|
+
onClick: _cache[1] || (_cache[1] = ($event) => scrollTabs("right"))
|
|
212
|
+
}, {
|
|
213
|
+
default: withCtx(() => [..._cache[4] || (_cache[4] = [createElementVNode("svg", {
|
|
214
|
+
width: "14",
|
|
215
|
+
height: "14",
|
|
216
|
+
viewBox: "0 0 14 14",
|
|
217
|
+
fill: "none",
|
|
218
|
+
"aria-hidden": "true"
|
|
219
|
+
}, [createElementVNode("path", {
|
|
220
|
+
d: "M5 3L9 7L5 11",
|
|
221
|
+
stroke: "currentColor",
|
|
222
|
+
"stroke-width": "1.75",
|
|
223
|
+
"stroke-linecap": "round",
|
|
224
|
+
"stroke-linejoin": "round"
|
|
225
|
+
})], -1)])]),
|
|
226
|
+
_: 1
|
|
227
|
+
}, 8, ["class"])
|
|
228
|
+
], 2)) : props.overflow === "dropdown" ? (openBlock(), createElementBlock("div", {
|
|
229
|
+
key: 2,
|
|
230
|
+
ref_key: "containerEl",
|
|
231
|
+
ref: containerEl,
|
|
232
|
+
class: "tabs__list-container tabs__list-container--dropdown"
|
|
233
|
+
}, [createVNode(unref(TabsList), {
|
|
234
|
+
loop: props.loop ?? true,
|
|
235
|
+
class: normalizeClass(unref(composeClassName)(unref(ctx).slotFns.value.tabList(), "tabs__list--clipped", props.class))
|
|
236
|
+
}, {
|
|
237
|
+
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
238
|
+
_: 3
|
|
239
|
+
}, 8, ["loop", "class"]), createElementVNode("div", {
|
|
240
|
+
ref_key: "dropdownEl",
|
|
241
|
+
ref: dropdownEl,
|
|
242
|
+
class: normalizeClass(["tabs__more", { "tabs__more--visible": hasOverflow.value }])
|
|
243
|
+
}, [createVNode(Button_default, {
|
|
244
|
+
ref_key: "moreBtnEl",
|
|
245
|
+
ref: moreBtnEl,
|
|
246
|
+
variant: "secondary",
|
|
247
|
+
size: "sm",
|
|
248
|
+
radius: "full",
|
|
249
|
+
class: "tabs__more-btn",
|
|
250
|
+
"aria-expanded": dropdownOpen.value,
|
|
251
|
+
"aria-haspopup": "menu",
|
|
252
|
+
onClick: _cache[2] || (_cache[2] = ($event) => dropdownOpen.value = !dropdownOpen.value)
|
|
253
|
+
}, {
|
|
254
|
+
default: withCtx(() => [createTextVNode(" +" + toDisplayString(hiddenTabs.value.length) + " ", 1), _cache[5] || (_cache[5] = createElementVNode("svg", {
|
|
255
|
+
width: "12",
|
|
256
|
+
height: "12",
|
|
257
|
+
viewBox: "0 0 12 12",
|
|
258
|
+
fill: "none",
|
|
259
|
+
"aria-hidden": "true"
|
|
260
|
+
}, [createElementVNode("path", {
|
|
261
|
+
d: "M2 4L6 8L10 4",
|
|
262
|
+
stroke: "currentColor",
|
|
263
|
+
"stroke-width": "1.5",
|
|
264
|
+
"stroke-linecap": "round",
|
|
265
|
+
"stroke-linejoin": "round"
|
|
266
|
+
})], -1))]),
|
|
267
|
+
_: 1
|
|
268
|
+
}, 8, ["aria-expanded"]), dropdownOpen.value ? (openBlock(), createElementBlock("div", _hoisted_1, [(openBlock(true), createElementBlock(Fragment, null, renderList(hiddenTabs.value, (tab) => {
|
|
269
|
+
return openBlock(), createBlock(Button_default, {
|
|
270
|
+
key: tab.value,
|
|
271
|
+
variant: "ghost",
|
|
272
|
+
radius: "lg",
|
|
273
|
+
class: "tabs__overflow-item",
|
|
274
|
+
role: "menuitem",
|
|
275
|
+
disabled: tab.disabled,
|
|
276
|
+
onClick: ($event) => selectOverflowTab(tab.value)
|
|
277
|
+
}, {
|
|
278
|
+
default: withCtx(() => [createTextVNode(toDisplayString(tab.label), 1)]),
|
|
279
|
+
_: 2
|
|
280
|
+
}, 1032, ["disabled", "onClick"]);
|
|
281
|
+
}), 128))])) : createCommentVNode("", true)], 2)], 512)) : createCommentVNode("", true);
|
|
23
282
|
};
|
|
24
283
|
}
|
|
25
284
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TabList.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/TabList.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { TabsList } from 'reka-ui'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\n\nconst props = defineProps<{\n loop?: boolean\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n</script>\n\n<template>\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), props.class)\"\n >\n <slot />\n </TabsList>\n</template>\n"],"mappings":";;;;;;;;;;;;EAKA,MAAM,QAAQ;EAKd,MAAM,MAAM,eAAc;;uBAIxB,YAKW,MAAA,SAAA,EAAA;IAJR,MAAM,MAAM,QAAI;IAChB,OAAK,eAAE,MAAA,iBAAgB,CAAC,MAAA,IAAG,CAAC,QAAQ,MAAM,SAAO,EAAI,MAAM,MAAK,CAAA;;2BAEzD,CAAR,WAAQ,KAAA,QAAA,UAAA,CAAA,CAAA"}
|
|
1
|
+
{"version":3,"file":"TabList.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/TabList.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { ref, computed, nextTick, onMounted, watch } from 'vue'\nimport { useTemplateRef } from 'vue'\nimport { TabsList } from 'reka-ui'\nimport { useResizeObserver, onClickOutside } from '@vueuse/core'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsInject } from './tabs.context'\nimport Button from '../button/Button.vue'\n\nconst props = defineProps<{\n loop?: boolean\n overflow?: 'arrows' | 'dropdown'\n class?: string\n}>()\n\nconst ctx = useTabsInject()\n\n// ── Arrows mode ─────────────────────────────────────────────────────────────\nconst scrollWrapperEl = useTemplateRef<HTMLElement>('scrollWrapperEl')\nconst canScrollLeft = ref(false)\nconst canScrollRight = ref(false)\n\nfunction updateScrollButtons() {\n const el = scrollWrapperEl.value\n if (!el) { canScrollLeft.value = false; canScrollRight.value = false; return }\n canScrollLeft.value = el.scrollLeft > 1\n canScrollRight.value = el.scrollLeft + el.clientWidth < el.scrollWidth - 1\n}\n\nfunction scrollTabs(dir: 'left' | 'right') {\n const el = scrollWrapperEl.value\n if (!el) return\n el.scrollBy({ left: dir === 'left' ? -200 : 200, behavior: 'smooth' })\n // Poll briefly after smooth scroll starts so button states update\n setTimeout(updateScrollButtons, 150)\n setTimeout(updateScrollButtons, 350)\n}\n\nwatch(scrollWrapperEl, (el, oldEl) => {\n if (oldEl) oldEl.removeEventListener('scroll', updateScrollButtons)\n if (el) {\n el.addEventListener('scroll', updateScrollButtons, { passive: true })\n nextTick(updateScrollButtons)\n }\n}, { immediate: true })\n\nuseResizeObserver(scrollWrapperEl, () => nextTick(updateScrollButtons))\n\n// ── Dropdown mode ────────────────────────────────────────────────────────────\ninterface OverflowTab {\n value: string\n label: string\n disabled: boolean\n}\n\nconst containerEl = useTemplateRef<HTMLElement>('containerEl')\n// Button component ref — use .$el to reach the underlying DOM element for offsetWidth\nconst moreBtnEl = useTemplateRef<InstanceType<typeof Button>>('moreBtnEl')\nconst dropdownEl = useTemplateRef<HTMLElement>('dropdownEl')\n\nconst hiddenTabs = ref<OverflowTab[]>([])\nconst dropdownOpen = ref(false)\nconst hasOverflow = computed(() => hiddenTabs.value.length > 0)\n// Pre-measured natural width of the more button (measured once on mount before it's visible)\nlet moreBtnNaturalWidth = 48\n\nonClickOutside(dropdownEl, () => { dropdownOpen.value = false })\n\nfunction computeOverflow() {\n if (!containerEl.value) return\n\n const allTabs = Array.from(\n containerEl.value.querySelectorAll('[data-tab-value]'),\n ) as HTMLElement[]\n\n // Reveal all tabs first\n allTabs.forEach(t => t.removeAttribute('data-overflow-hidden'))\n\n // Tabs use w-full and shrink to share the container width, so offsetWidth after\n // a normal render would be containerWidth/n — useless for overflow detection.\n // Force each tab to its natural content width for measurement only (no paint flash:\n // all DOM reads/writes happen synchronously within this JS task before the next frame).\n const listEl = containerEl.value.querySelector('[role=\"tablist\"]') as HTMLElement | null\n if (listEl) {\n listEl.style.overflow = 'visible'\n allTabs.forEach(t => { t.style.flexShrink = '0'; t.style.width = 'auto' })\n void listEl.offsetWidth // force reflow so offsetWidth reads below are accurate\n }\n\n const containerWidth = containerEl.value.clientWidth\n const tabWidths = allTabs.map(t => t.offsetWidth)\n const totalWidth = tabWidths.reduce((sum, w) => sum + w, 0)\n\n // Restore layout before any early-return so tabs always look correct\n if (listEl) {\n listEl.style.overflow = ''\n allTabs.forEach(t => { t.style.flexShrink = ''; t.style.width = '' })\n }\n\n if (totalWidth <= containerWidth) {\n hiddenTabs.value = []\n return\n }\n\n // More button is in-flow (display:none when no overflow, display:flex when visible).\n // Use the pre-measured natural width so the calculation is accurate on the first run\n // before the button becomes visible.\n const available = containerWidth - moreBtnNaturalWidth\n\n let accumulated = 0\n const newHidden: OverflowTab[] = []\n const visibleEls: HTMLElement[] = []\n\n for (let i = 0; i < allTabs.length; i++) {\n const tab = allTabs[i]\n const w = tabWidths[i]\n if (accumulated + w <= available) {\n accumulated += w\n visibleEls.push(tab)\n } else {\n newHidden.push({\n value: tab.getAttribute('data-tab-value') ?? '',\n label: tab.textContent?.trim() ?? '',\n disabled: tab.hasAttribute('data-disabled') || tab.getAttribute('aria-disabled') === 'true',\n })\n tab.setAttribute('data-overflow-hidden', '')\n }\n }\n\n // If the active tab ended up hidden, swap it with the last visible tab\n const activeValue = ctx.currentValue.value\n if (activeValue) {\n const hiddenActiveIdx = newHidden.findIndex(t => t.value === activeValue)\n if (hiddenActiveIdx !== -1 && visibleEls.length > 0) {\n const displacedEl = visibleEls[visibleEls.length - 1]\n const activeEl = allTabs.find(t => t.getAttribute('data-tab-value') === activeValue)\n\n if (displacedEl && activeEl) {\n // Swap: make displaced tab hidden, active tab visible\n displacedEl.setAttribute('data-overflow-hidden', '')\n activeEl.removeAttribute('data-overflow-hidden')\n\n const displaced: OverflowTab = {\n value: displacedEl.getAttribute('data-tab-value') ?? '',\n label: displacedEl.textContent?.trim() ?? '',\n disabled: displacedEl.hasAttribute('data-disabled') || displacedEl.getAttribute('aria-disabled') === 'true',\n }\n newHidden.splice(hiddenActiveIdx, 1)\n newHidden.unshift(displaced)\n }\n }\n }\n\n hiddenTabs.value = newHidden\n}\n\nuseResizeObserver(containerEl, () => nextTick(computeOverflow))\nonMounted(() => {\n // Pre-measure the more button's natural width before it becomes visible (display:none).\n // Temporarily show it, read offsetWidth, then hide again — happens before first paint.\n const btnEl = (moreBtnEl.value as InstanceType<typeof Button> | null)?.$el as HTMLElement | null\n if (btnEl) {\n btnEl.style.display = 'flex'\n void btnEl.offsetWidth\n moreBtnNaturalWidth = btnEl.offsetWidth\n btnEl.style.display = ''\n }\n nextTick(computeOverflow)\n})\n\n// Recompute when the active tab changes so the active tab is always visible\nwatch(() => ctx.currentValue.value, () => {\n if (props.overflow === 'dropdown') nextTick(computeOverflow)\n})\n\n// When overflow state first transitions false→true the more button enters the flex flow,\n// narrowing the container. Re-run once so the tab count reflects the reduced available space.\nwatch(hasOverflow, () => {\n if (props.overflow === 'dropdown') nextTick(computeOverflow)\n})\n\nfunction selectOverflowTab(value: string) {\n ctx.changeTab(value)\n dropdownOpen.value = false\n}\n</script>\n\n<template>\n <!-- ── Default (no overflow behaviour) ───────────────────────────────────── -->\n <TabsList\n v-if=\"!props.overflow\"\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), props.class)\"\n >\n <slot />\n </TabsList>\n\n <!-- ── Arrows mode ────────────────────────────────────────────────────────── -->\n <div\n v-else-if=\"props.overflow === 'arrows'\"\n class=\"tabs__list-container tabs__list-container--arrows\"\n :class=\"{ 'has-left': canScrollLeft, 'has-right': canScrollRight }\"\n >\n <Button\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n :is-icon-only=\"true\"\n :class=\"composeClassName('tabs__arrow tabs__arrow--left', canScrollLeft && 'is-visible')\"\n aria-label=\"Scroll tabs left\"\n tabindex=\"-1\"\n @click=\"scrollTabs('left')\"\n >\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M9 11L5 7L9 3\" stroke=\"currentColor\" stroke-width=\"1.75\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n\n <div ref=\"scrollWrapperEl\" class=\"tabs__scroll-wrapper\">\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), 'tabs__list--scroll', props.class)\"\n >\n <slot />\n </TabsList>\n </div>\n\n <Button\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n :is-icon-only=\"true\"\n :class=\"composeClassName('tabs__arrow tabs__arrow--right', canScrollRight && 'is-visible')\"\n aria-label=\"Scroll tabs right\"\n tabindex=\"-1\"\n @click=\"scrollTabs('right')\"\n >\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M5 3L9 7L5 11\" stroke=\"currentColor\" stroke-width=\"1.75\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n </div>\n\n <!-- ── Dropdown mode ──────────────────────────────────────────────────────── -->\n <div\n v-else-if=\"props.overflow === 'dropdown'\"\n ref=\"containerEl\"\n class=\"tabs__list-container tabs__list-container--dropdown\"\n >\n <TabsList\n :loop=\"props.loop ?? true\"\n :class=\"composeClassName(ctx.slotFns.value.tabList(), 'tabs__list--clipped', props.class)\"\n >\n <slot />\n </TabsList>\n\n <!-- Always rendered so offsetWidth is measurable; visibility toggled via CSS -->\n <div\n ref=\"dropdownEl\"\n class=\"tabs__more\"\n :class=\"{ 'tabs__more--visible': hasOverflow }\"\n >\n <Button\n ref=\"moreBtnEl\"\n variant=\"secondary\"\n size=\"sm\"\n radius=\"full\"\n class=\"tabs__more-btn\"\n :aria-expanded=\"dropdownOpen\"\n aria-haspopup=\"menu\"\n @click=\"dropdownOpen = !dropdownOpen\"\n >\n +{{ hiddenTabs.length }}\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" aria-hidden=\"true\">\n <path d=\"M2 4L6 8L10 4\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n </svg>\n </Button>\n\n <div v-if=\"dropdownOpen\" class=\"tabs__overflow-menu\" role=\"menu\">\n <Button\n v-for=\"tab in hiddenTabs\"\n :key=\"tab.value\"\n variant=\"ghost\"\n radius=\"lg\"\n class=\"tabs__overflow-item\"\n role=\"menuitem\"\n :disabled=\"tab.disabled\"\n @click=\"selectOverflowTab(tab.value)\"\n >\n {{ tab.label }}\n </Button>\n </div>\n </div>\n </div>\n</template>\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tabs.js","names":[],"sources":["../../../src/components/tabs/Tabs.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, toRef } from 'vue'\nimport { TabsRoot } from 'reka-ui'\nimport { tabsVariants, type TabsVariants } from '@auronui/styles'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsProvide } from './tabs.context'\n\nconst props = withDefaults(defineProps<{\n modelValue?: string\n defaultValue?: string\n orientation?: 'horizontal' | 'vertical'\n variant?: TabsVariants['variant']\n activationMode?: 'automatic' | 'manual'\n class?: string\n}>(), {\n orientation: 'horizontal',\n variant: 'primary',\n activationMode: 'automatic',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst slotFns = computed(() => tabsVariants({ variant: props.variant }))\n\nuseTabsProvide({\n slotFns,\n orientation: toRef(props, 'orientation'),\n})\n</script>\n\n<template>\n <TabsRoot\n :model-value=\"
|
|
1
|
+
{"version":3,"file":"Tabs.js","names":[],"sources":["../../../src/components/tabs/Tabs.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, ref, toRef, watch } from 'vue'\nimport { TabsRoot } from 'reka-ui'\nimport { tabsVariants, type TabsVariants } from '@auronui/styles'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsProvide } from './tabs.context'\n\nconst props = withDefaults(defineProps<{\n modelValue?: string\n defaultValue?: string\n orientation?: 'horizontal' | 'vertical'\n variant?: TabsVariants['variant']\n activationMode?: 'automatic' | 'manual'\n class?: string\n}>(), {\n orientation: 'horizontal',\n variant: 'primary',\n activationMode: 'automatic',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst internalValue = ref<string | undefined>(props.modelValue ?? props.defaultValue)\n\nwatch(() => props.modelValue, (v) => {\n if (v !== undefined) internalValue.value = v\n})\n\nfunction changeTab(value: string) {\n internalValue.value = value\n emit('update:modelValue', value)\n}\n\nconst slotFns = computed(() => tabsVariants({ variant: props.variant }))\n\nuseTabsProvide({\n slotFns,\n orientation: toRef(props, 'orientation'),\n currentValue: internalValue,\n changeTab,\n})\n</script>\n\n<template>\n <TabsRoot\n :model-value=\"internalValue\"\n :orientation=\"props.orientation\"\n :activation-mode=\"props.activationMode\"\n :class=\"composeClassName(slotFns.base(), props.class)\"\n :data-orientation=\"props.orientation\"\n @update:model-value=\"changeTab\"\n >\n <slot />\n </TabsRoot>\n</template>\n"],"mappings":""}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { composeClassName } from "../../utils/composeClassName.js";
|
|
2
2
|
import { useTabsProvide } from "./tabs.context.js";
|
|
3
|
-
import { computed, createBlock, defineComponent, normalizeClass, openBlock, renderSlot, toRef, unref, withCtx } from "vue";
|
|
3
|
+
import { computed, createBlock, defineComponent, normalizeClass, openBlock, ref, renderSlot, toRef, unref, watch, withCtx } from "vue";
|
|
4
4
|
import { tabsVariants } from "@auronui/styles";
|
|
5
5
|
import { TabsRoot } from "reka-ui";
|
|
6
6
|
//#region src/components/tabs/Tabs.vue?vue&type=script&setup=true&lang.ts
|
|
@@ -18,26 +18,34 @@ var Tabs_vue_vue_type_script_setup_true_lang_default = /* @__PURE__ */ defineCom
|
|
|
18
18
|
setup(__props, { emit: __emit }) {
|
|
19
19
|
const props = __props;
|
|
20
20
|
const emit = __emit;
|
|
21
|
+
const internalValue = ref(props.modelValue ?? props.defaultValue);
|
|
22
|
+
watch(() => props.modelValue, (v) => {
|
|
23
|
+
if (v !== void 0) internalValue.value = v;
|
|
24
|
+
});
|
|
25
|
+
function changeTab(value) {
|
|
26
|
+
internalValue.value = value;
|
|
27
|
+
emit("update:modelValue", value);
|
|
28
|
+
}
|
|
21
29
|
const slotFns = computed(() => tabsVariants({ variant: props.variant }));
|
|
22
30
|
useTabsProvide({
|
|
23
31
|
slotFns,
|
|
24
|
-
orientation: toRef(props, "orientation")
|
|
32
|
+
orientation: toRef(props, "orientation"),
|
|
33
|
+
currentValue: internalValue,
|
|
34
|
+
changeTab
|
|
25
35
|
});
|
|
26
36
|
return (_ctx, _cache) => {
|
|
27
37
|
return openBlock(), createBlock(unref(TabsRoot), {
|
|
28
|
-
"model-value":
|
|
29
|
-
"default-value": props.defaultValue,
|
|
38
|
+
"model-value": internalValue.value,
|
|
30
39
|
orientation: props.orientation,
|
|
31
40
|
"activation-mode": props.activationMode,
|
|
32
41
|
class: normalizeClass(unref(composeClassName)(slotFns.value.base(), props.class)),
|
|
33
42
|
"data-orientation": props.orientation,
|
|
34
|
-
"onUpdate:modelValue":
|
|
43
|
+
"onUpdate:modelValue": changeTab
|
|
35
44
|
}, {
|
|
36
45
|
default: withCtx(() => [renderSlot(_ctx.$slots, "default")]),
|
|
37
46
|
_: 3
|
|
38
47
|
}, 8, [
|
|
39
48
|
"model-value",
|
|
40
|
-
"default-value",
|
|
41
49
|
"orientation",
|
|
42
50
|
"activation-mode",
|
|
43
51
|
"class",
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Tabs.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/Tabs.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, toRef } from 'vue'\nimport { TabsRoot } from 'reka-ui'\nimport { tabsVariants, type TabsVariants } from '@auronui/styles'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsProvide } from './tabs.context'\n\nconst props = withDefaults(defineProps<{\n modelValue?: string\n defaultValue?: string\n orientation?: 'horizontal' | 'vertical'\n variant?: TabsVariants['variant']\n activationMode?: 'automatic' | 'manual'\n class?: string\n}>(), {\n orientation: 'horizontal',\n variant: 'primary',\n activationMode: 'automatic',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst slotFns = computed(() => tabsVariants({ variant: props.variant }))\n\nuseTabsProvide({\n slotFns,\n orientation: toRef(props, 'orientation'),\n})\n</script>\n\n<template>\n <TabsRoot\n :model-value=\"
|
|
1
|
+
{"version":3,"file":"Tabs.vue_vue_type_script_setup_true_lang.js","names":[],"sources":["../../../src/components/tabs/Tabs.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, ref, toRef, watch } from 'vue'\nimport { TabsRoot } from 'reka-ui'\nimport { tabsVariants, type TabsVariants } from '@auronui/styles'\nimport { composeClassName } from '../../utils/composeClassName'\nimport { useTabsProvide } from './tabs.context'\n\nconst props = withDefaults(defineProps<{\n modelValue?: string\n defaultValue?: string\n orientation?: 'horizontal' | 'vertical'\n variant?: TabsVariants['variant']\n activationMode?: 'automatic' | 'manual'\n class?: string\n}>(), {\n orientation: 'horizontal',\n variant: 'primary',\n activationMode: 'automatic',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string]\n}>()\n\nconst internalValue = ref<string | undefined>(props.modelValue ?? props.defaultValue)\n\nwatch(() => props.modelValue, (v) => {\n if (v !== undefined) internalValue.value = v\n})\n\nfunction changeTab(value: string) {\n internalValue.value = value\n emit('update:modelValue', value)\n}\n\nconst slotFns = computed(() => tabsVariants({ variant: props.variant }))\n\nuseTabsProvide({\n slotFns,\n orientation: toRef(props, 'orientation'),\n currentValue: internalValue,\n changeTab,\n})\n</script>\n\n<template>\n <TabsRoot\n :model-value=\"internalValue\"\n :orientation=\"props.orientation\"\n :activation-mode=\"props.activationMode\"\n :class=\"composeClassName(slotFns.base(), props.class)\"\n :data-orientation=\"props.orientation\"\n @update:model-value=\"changeTab\"\n >\n <slot />\n </TabsRoot>\n</template>\n"],"mappings":";;;;;;;;;;;;;;;;;;EAOA,MAAM,QAAQ;EAad,MAAM,OAAO;EAIb,MAAM,gBAAgB,IAAwB,MAAM,cAAc,MAAM,aAAY;AAEpF,cAAY,MAAM,aAAa,MAAM;AACnC,OAAI,MAAM,KAAA,EAAW,eAAc,QAAQ;IAC5C;EAED,SAAS,UAAU,OAAe;AAChC,iBAAc,QAAQ;AACtB,QAAK,qBAAqB,MAAK;;EAGjC,MAAM,UAAU,eAAe,aAAa,EAAE,SAAS,MAAM,SAAS,CAAC,CAAA;AAEvE,iBAAe;GACb;GACA,aAAa,MAAM,OAAO,cAAc;GACxC,cAAc;GACd;GACD,CAAA;;uBAIC,YASW,MAAA,SAAA,EAAA;IARR,eAAa,cAAA;IACb,aAAa,MAAM;IACnB,mBAAiB,MAAM;IACvB,OAAK,eAAE,MAAA,iBAAgB,CAAC,QAAA,MAAQ,MAAI,EAAI,MAAM,MAAK,CAAA;IACnD,oBAAkB,MAAM;IACxB,uBAAoB;;2BAEb,CAAR,WAAQ,KAAA,QAAA,UAAA,CAAA,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tabs.context.js","names":[],"sources":["../../../src/components/tabs/tabs.context.ts"],"sourcesContent":["import { createContext } from '../../utils/context'\nimport type { Ref } from 'vue'\nimport type { tabsVariants } from '@auronui/styles'\n\n// Return shape of tabsVariants({ variant }) — each key is a slot function that returns a string\nexport type TabsSlotFns = ReturnType<typeof tabsVariants>\n\nexport interface TabsContext {\n slotFns: Ref<TabsSlotFns>\n orientation: Ref<'horizontal' | 'vertical'>\n}\n\nexport const {\n useProvide: useTabsProvide,\n useInject: useTabsInject,\n key: tabsContextKey,\n} = createContext<TabsContext>('Tabs')\n"],"mappings":";;
|
|
1
|
+
{"version":3,"file":"tabs.context.js","names":[],"sources":["../../../src/components/tabs/tabs.context.ts"],"sourcesContent":["import { createContext } from '../../utils/context'\nimport type { Ref } from 'vue'\nimport type { tabsVariants } from '@auronui/styles'\n\n// Return shape of tabsVariants({ variant }) — each key is a slot function that returns a string\nexport type TabsSlotFns = ReturnType<typeof tabsVariants>\n\nexport interface TabsContext {\n slotFns: Ref<TabsSlotFns>\n orientation: Ref<'horizontal' | 'vertical'>\n currentValue: Ref<string | undefined>\n changeTab: (value: string) => void\n}\n\nexport const {\n useProvide: useTabsProvide,\n useInject: useTabsInject,\n key: tabsContextKey,\n} = createContext<TabsContext>('Tabs')\n"],"mappings":";;AAcA,IAAa,EACX,YAAY,gBACZ,WAAW,eACX,KAAK,mBACH,cAA2B,OAAO"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@auronui/vue",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.6",
|
|
4
4
|
"description": "Vue 3 85 components with full visual and functional parity",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "MIT",
|
|
@@ -69,7 +69,7 @@
|
|
|
69
69
|
"tailwind-merge": "3.5.0",
|
|
70
70
|
"tailwind-variants": "3.2.2",
|
|
71
71
|
"vee-validate": "^4.15.1",
|
|
72
|
-
"@auronui/styles": "1.0.
|
|
72
|
+
"@auronui/styles": "1.0.6"
|
|
73
73
|
},
|
|
74
74
|
"devDependencies": {
|
|
75
75
|
"@chialab/vitest-axe": "0.19.1",
|
|
@@ -88,8 +88,8 @@
|
|
|
88
88
|
"vitest": "4.1.4",
|
|
89
89
|
"vue": "^3.5.32",
|
|
90
90
|
"vue-tsc": "^3.2.6",
|
|
91
|
-
"@auronui/
|
|
92
|
-
"@auronui/
|
|
91
|
+
"@auronui/vitest": "0.0.0",
|
|
92
|
+
"@auronui/standard": "0.0.0"
|
|
93
93
|
},
|
|
94
94
|
"scripts": {
|
|
95
95
|
"build": "vite build",
|