@data-slot/tabs 0.2.10 → 0.2.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -223,6 +223,8 @@ The component automatically handles:
223
223
 
224
224
  ## Events
225
225
 
226
+ ### Outbound Events
227
+
226
228
  Listen for changes via custom events:
227
229
 
228
230
  ```javascript
@@ -231,6 +233,39 @@ element.addEventListener("tabs:change", (e) => {
231
233
  });
232
234
  ```
233
235
 
236
+ ### Inbound Events
237
+
238
+ Control the tabs via events:
239
+
240
+ | Event | Detail | Description |
241
+ |-------|--------|-------------|
242
+ | `tabs:set` | `{ value: string }` | Select a tab programmatically |
243
+
244
+ ```javascript
245
+ // Select a tab
246
+ element.dispatchEvent(
247
+ new CustomEvent("tabs:set", { detail: { value: "two" } })
248
+ );
249
+ ```
250
+
251
+ ### Deprecated Events
252
+
253
+ The following event is deprecated and will be removed in v1.0:
254
+
255
+ ```javascript
256
+ // Deprecated: tabs:select event
257
+ element.dispatchEvent(
258
+ new CustomEvent("tabs:select", { detail: { value: "two" } })
259
+ );
260
+
261
+ // Deprecated: string detail
262
+ element.dispatchEvent(
263
+ new CustomEvent("tabs:select", { detail: "two" })
264
+ );
265
+ ```
266
+
267
+ Use `tabs:set` with `{ value: string }` instead.
268
+
234
269
  ## License
235
270
 
236
271
  MIT
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- const e=(e,t)=>e.querySelector(`[data-slot="${t}"]`),t=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],n=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],r=new WeakMap;function i(e,t,n){if(typeof process<`u`&&process.env?.NODE_ENV===`production`)return;let i=r.get(e);i||(i=new Set,r.set(e,i)),!i.has(t)&&(i.add(t),console.warn(`[@data-slot] ${n}`))}function a(e){let t=`data-${e.replace(/([A-Z])/g,`-$1`).toLowerCase()}`,n=`data-${e}`;return t===n?[t]:[t,n]}function o(e,t){for(let n of a(t))if(e.hasAttribute(n))return e.getAttribute(n);return null}function s(e,t){return a(t).some(t=>e.hasAttribute(t))}function c(e,t){if(s(e,t))return o(e,t)??void 0}function l(e,t,n){let r=o(e,t);if(r!==null){if(n.includes(r))return r;i(e,t,`Invalid value "${r}" for data-${t}. Expected one of: ${n.join(`, `)}.`)}}let u=0;const d=(e,t)=>e.id||=`${t}-${++u}`,f=(e,t,n)=>{n===null?e.removeAttribute(`aria-${t}`):e.setAttribute(`aria-${t}`,String(n))};function p(e,t,n,r){return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r)}const m=(e,t,n)=>e.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:n})),h=[`horizontal`,`vertical`],g=[`auto`,`manual`],_=`a[href],button:not([disabled]),input:not([disabled]),select:not([disabled]),textarea:not([disabled]),[tabindex]:not([tabindex="-1"])`;function v(n,r={}){let i=e(n,`tabs-list`),a=t(n,`tabs-trigger`),o=t(n,`tabs-content`),s=e(n,`tabs-indicator`);if(!i||a.length===0)throw Error(`Tabs requires tabs-list and at least one tabs-trigger`);let u=r.onValueChange,v=r.orientation??l(n,`orientation`,h)??`horizontal`,b=r.activationMode??l(n,`activationMode`,g)??`auto`,x=new Map;for(let e of o){let t=(e.dataset.value||``).trim();t&&x.set(t,e)}let S=[],C=new Map,w=new Map;for(let e of a){let t=(e.dataset.value||``).trim();if(!t)continue;let n=e.hasAttribute(`disabled`)||e.dataset.disabled!==void 0||e.getAttribute(`aria-disabled`)===`true`,r=x.get(t),i={el:e,value:t,disabled:n,panel:r};S.push(i),C.set(t,i),w.set(e,i)}let T=S.filter(e=>!e.disabled),E=new Map;T.forEach((e,t)=>E.set(e.value,t));let D=T[0]?.value||``,O=(r.defaultValue??c(n,`defaultValue`)??``).trim(),k=C.get(O),A=k&&!k.disabled?O:D,j=[];i.setAttribute(`role`,`tablist`),v===`vertical`&&f(i,`orientation`,`vertical`);for(let e of S){let{el:t,disabled:n,panel:r}=e;t.setAttribute(`role`,`tab`);let i=d(t,`tab`);if(t.tagName===`BUTTON`&&!t.hasAttribute(`type`)&&(t.type=`button`),n&&(t.setAttribute(`aria-disabled`,`true`),t.tagName===`BUTTON`&&(t.disabled=!0)),r){r.setAttribute(`role`,`tabpanel`),r.tabIndex=-1;let e=d(r,`tabpanel`);t.setAttribute(`aria-controls`,e),r.setAttribute(`aria-labelledby`,i)}}let M=()=>{if(!s)return;let e=C.get(A);if(!e)return;let t=i.getBoundingClientRect(),n=e.el.getBoundingClientRect(),r=i.scrollLeft,a=i.scrollTop;s.style.setProperty(`--active-tab-left`,`${n.left-t.left-i.clientLeft+r}px`),s.style.setProperty(`--active-tab-width`,`${n.width}px`),s.style.setProperty(`--active-tab-top`,`${n.top-t.top-i.clientTop+a}px`),s.style.setProperty(`--active-tab-height`,`${n.height}px`)},N=(e,t=!1)=>{if(e=e.trim(),A===e&&!t)return;let r=C.get(e);if(!r||r.disabled)if(t){if(e=D,!e)return}else return;let i=A!==e;A=e;for(let t of S){let n=t.value===e;f(t.el,`selected`,n),t.el.tabIndex=n&&!t.disabled?0:-1,t.el.dataset.state=n?`active`:`inactive`}for(let t of o){let n=(t.dataset.value||``).trim();if(!n)continue;let r=n===e;t.hidden=!r,t.dataset.state=r?`active`:`inactive`}n.setAttribute(`data-value`,e),s&&M(),i&&!t&&(m(n,`tabs:change`,{value:e}),u?.(e))};if(N(A,!0),s){let e=()=>requestAnimationFrame(M);j.push(p(window,`resize`,e)),j.push(p(i,`scroll`,e));let t=new ResizeObserver(e);t.observe(i),j.push(()=>t.disconnect())}j.push(p(i,`click`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);n&&!n.disabled&&N(n.value)}));let P=v===`horizontal`,F=P?`ArrowLeft`:`ArrowUp`,I=P?`ArrowRight`:`ArrowDown`;j.push(p(i,`keydown`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);if(!n||T.length===0)return;if(e.key===`Enter`||e.key===` `){e.preventDefault(),n.disabled||N(n.value);return}if(P&&e.key===`ArrowDown`&&n.value===A){let t=n.panel;if(t){e.preventDefault();let n=t.querySelector(_);(n||t).focus();return}}let r=E.get(n.value)??-1;r===-1&&(r=E.get(A)??0);let i=r;switch(e.key){case F:i=r-1,i<0&&(i=T.length-1);break;case I:i=r+1,i>=T.length&&(i=0);break;case`Home`:i=0;break;case`End`:i=T.length-1;break;default:return}e.preventDefault();let a=T[i];a&&(a.el.focus(),b===`auto`&&N(a.value))}));let L=e=>{let t=e,n=e.currentTarget,r=t.detail,i=typeof r==`string`?r:r?.value??n?.dataset?.value,a=i?.trim();a&&N(a)};j.push(p(n,`tabs:select`,L));let R={select:e=>N(e),get value(){return A},updateIndicator:M,destroy:()=>{j.forEach(e=>e()),j.length=0,y.delete(n)}};return R}const y=new WeakSet;function b(e=document){let t=[];for(let r of n(e,`tabs`)){if(y.has(r))continue;y.add(r),t.push(v(r))}return t}exports.create=b,exports.createTabs=v;
1
+ const e=(e,t)=>e.querySelector(`[data-slot="${t}"]`),t=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],n=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],r=new WeakMap;function i(e,t,n){if(typeof process<`u`&&process.env?.NODE_ENV===`production`)return;let i=r.get(e);i||(i=new Set,r.set(e,i)),!i.has(t)&&(i.add(t),console.warn(`[@data-slot] ${n}`))}function a(e){let t=`data-${e.replace(/([A-Z])/g,`-$1`).toLowerCase()}`,n=`data-${e}`;return t===n?[t]:[t,n]}function o(e,t){for(let n of a(t))if(e.hasAttribute(n))return e.getAttribute(n);return null}function s(e,t){return a(t).some(t=>e.hasAttribute(t))}function c(e,t){if(s(e,t))return o(e,t)??void 0}function l(e,t,n){let r=o(e,t);if(r!==null){if(n.includes(r))return r;i(e,t,`Invalid value "${r}" for data-${t}. Expected one of: ${n.join(`, `)}.`)}}let u=0;const d=(e,t)=>e.id||=`${t}-${++u}`,f=(e,t,n)=>{n===null?e.removeAttribute(`aria-${t}`):e.setAttribute(`aria-${t}`,String(n))};function p(e,t,n,r){return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r)}const m=(e,t,n)=>e.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:n})),h=[`horizontal`,`vertical`],g=[`auto`,`manual`],_=`a[href],button:not([disabled]),input:not([disabled]),select:not([disabled]),textarea:not([disabled]),[tabindex]:not([tabindex="-1"])`;function v(n,r={}){let i=e(n,`tabs-list`),a=t(n,`tabs-trigger`),o=t(n,`tabs-content`),s=e(n,`tabs-indicator`);if(!i||a.length===0)throw Error(`Tabs requires tabs-list and at least one tabs-trigger`);let u=r.onValueChange,v=r.orientation??l(n,`orientation`,h)??`horizontal`,b=r.activationMode??l(n,`activationMode`,g)??`auto`,x=new Map;for(let e of o){let t=(e.dataset.value||``).trim();t&&x.set(t,e)}let S=[],C=new Map,w=new Map;for(let e of a){let t=(e.dataset.value||``).trim();if(!t)continue;let n=e.hasAttribute(`disabled`)||e.dataset.disabled!==void 0||e.getAttribute(`aria-disabled`)===`true`,r=x.get(t),i={el:e,value:t,disabled:n,panel:r};S.push(i),C.set(t,i),w.set(e,i)}let T=S.filter(e=>!e.disabled),E=new Map;T.forEach((e,t)=>E.set(e.value,t));let D=T[0]?.value||``,O=(r.defaultValue??c(n,`defaultValue`)??``).trim(),k=C.get(O),A=k&&!k.disabled?O:D,j=[];i.setAttribute(`role`,`tablist`),v===`vertical`&&f(i,`orientation`,`vertical`);for(let e of S){let{el:t,disabled:n,panel:r}=e;t.setAttribute(`role`,`tab`);let i=d(t,`tab`);if(t.tagName===`BUTTON`&&!t.hasAttribute(`type`)&&(t.type=`button`),n&&(t.setAttribute(`aria-disabled`,`true`),t.tagName===`BUTTON`&&(t.disabled=!0)),r){r.setAttribute(`role`,`tabpanel`),r.tabIndex=-1;let e=d(r,`tabpanel`);t.setAttribute(`aria-controls`,e),r.setAttribute(`aria-labelledby`,i)}}let M=()=>{if(!s)return;let e=C.get(A);if(!e)return;let t=i.getBoundingClientRect(),n=e.el.getBoundingClientRect(),r=i.scrollLeft,a=i.scrollTop;s.style.setProperty(`--active-tab-left`,`${n.left-t.left-i.clientLeft+r}px`),s.style.setProperty(`--active-tab-width`,`${n.width}px`),s.style.setProperty(`--active-tab-top`,`${n.top-t.top-i.clientTop+a}px`),s.style.setProperty(`--active-tab-height`,`${n.height}px`)},N=(e,t=!1)=>{if(e=e.trim(),A===e&&!t)return;let r=C.get(e);if(!r||r.disabled)if(t){if(e=D,!e)return}else return;let i=A!==e;A=e;for(let t of S){let n=t.value===e;f(t.el,`selected`,n),t.el.tabIndex=n&&!t.disabled?0:-1,t.el.dataset.state=n?`active`:`inactive`}for(let t of o){let n=(t.dataset.value||``).trim();if(!n)continue;let r=n===e;t.hidden=!r,t.dataset.state=r?`active`:`inactive`}n.setAttribute(`data-value`,e),s&&M(),i&&!t&&(m(n,`tabs:change`,{value:e}),u?.(e))};if(N(A,!0),s){let e=()=>requestAnimationFrame(M);j.push(p(window,`resize`,e)),j.push(p(i,`scroll`,e));let t=new ResizeObserver(e);t.observe(i),j.push(()=>t.disconnect())}j.push(p(i,`click`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);n&&!n.disabled&&N(n.value)}));let P=v===`horizontal`,F=P?`ArrowLeft`:`ArrowUp`,I=P?`ArrowRight`:`ArrowDown`;j.push(p(i,`keydown`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);if(!n||T.length===0)return;if(e.key===`Enter`||e.key===` `){e.preventDefault(),n.disabled||N(n.value);return}if(P&&e.key===`ArrowDown`&&n.value===A){let t=n.panel;if(t){e.preventDefault();let n=t.querySelector(_);(n||t).focus();return}}let r=E.get(n.value)??-1;r===-1&&(r=E.get(A)??0);let i=r;switch(e.key){case F:i=r-1,i<0&&(i=T.length-1);break;case I:i=r+1,i>=T.length&&(i=0);break;case`Home`:i=0;break;case`End`:i=T.length-1;break;default:return}e.preventDefault();let a=T[i];a&&(a.el.focus(),b===`auto`&&N(a.value))}));let L=e=>{let t=e,n=e.currentTarget,r=t.detail,i=typeof r==`string`?r:r?.value??n?.dataset?.value,a=i?.trim();a&&N(a)};j.push(p(n,`tabs:set`,L)),j.push(p(n,`tabs:select`,L));let R={select:e=>N(e),get value(){return A},updateIndicator:M,destroy:()=>{j.forEach(e=>e()),j.length=0,y.delete(n)}};return R}const y=new WeakSet;function b(e=document){let t=[];for(let r of n(e,`tabs`)){if(y.has(r))continue;y.add(r),t.push(v(r))}return t}exports.create=b,exports.createTabs=v;
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- const e=(e,t)=>e.querySelector(`[data-slot="${t}"]`),t=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],n=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],r=new WeakMap;function i(e,t,n){if(typeof process<`u`&&process.env?.NODE_ENV===`production`)return;let i=r.get(e);i||(i=new Set,r.set(e,i)),!i.has(t)&&(i.add(t),console.warn(`[@data-slot] ${n}`))}function a(e){let t=`data-${e.replace(/([A-Z])/g,`-$1`).toLowerCase()}`,n=`data-${e}`;return t===n?[t]:[t,n]}function o(e,t){for(let n of a(t))if(e.hasAttribute(n))return e.getAttribute(n);return null}function s(e,t){return a(t).some(t=>e.hasAttribute(t))}function c(e,t){if(s(e,t))return o(e,t)??void 0}function l(e,t,n){let r=o(e,t);if(r!==null){if(n.includes(r))return r;i(e,t,`Invalid value "${r}" for data-${t}. Expected one of: ${n.join(`, `)}.`)}}let u=0;const d=(e,t)=>e.id||=`${t}-${++u}`,f=(e,t,n)=>{n===null?e.removeAttribute(`aria-${t}`):e.setAttribute(`aria-${t}`,String(n))};function p(e,t,n,r){return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r)}const m=(e,t,n)=>e.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:n})),h=[`horizontal`,`vertical`],g=[`auto`,`manual`],_=`a[href],button:not([disabled]),input:not([disabled]),select:not([disabled]),textarea:not([disabled]),[tabindex]:not([tabindex="-1"])`;function v(n,r={}){let i=e(n,`tabs-list`),a=t(n,`tabs-trigger`),o=t(n,`tabs-content`),s=e(n,`tabs-indicator`);if(!i||a.length===0)throw Error(`Tabs requires tabs-list and at least one tabs-trigger`);let u=r.onValueChange,v=r.orientation??l(n,`orientation`,h)??`horizontal`,b=r.activationMode??l(n,`activationMode`,g)??`auto`,x=new Map;for(let e of o){let t=(e.dataset.value||``).trim();t&&x.set(t,e)}let S=[],C=new Map,w=new Map;for(let e of a){let t=(e.dataset.value||``).trim();if(!t)continue;let n=e.hasAttribute(`disabled`)||e.dataset.disabled!==void 0||e.getAttribute(`aria-disabled`)===`true`,r=x.get(t),i={el:e,value:t,disabled:n,panel:r};S.push(i),C.set(t,i),w.set(e,i)}let T=S.filter(e=>!e.disabled),E=new Map;T.forEach((e,t)=>E.set(e.value,t));let D=T[0]?.value||``,O=(r.defaultValue??c(n,`defaultValue`)??``).trim(),k=C.get(O),A=k&&!k.disabled?O:D,j=[];i.setAttribute(`role`,`tablist`),v===`vertical`&&f(i,`orientation`,`vertical`);for(let e of S){let{el:t,disabled:n,panel:r}=e;t.setAttribute(`role`,`tab`);let i=d(t,`tab`);if(t.tagName===`BUTTON`&&!t.hasAttribute(`type`)&&(t.type=`button`),n&&(t.setAttribute(`aria-disabled`,`true`),t.tagName===`BUTTON`&&(t.disabled=!0)),r){r.setAttribute(`role`,`tabpanel`),r.tabIndex=-1;let e=d(r,`tabpanel`);t.setAttribute(`aria-controls`,e),r.setAttribute(`aria-labelledby`,i)}}let M=()=>{if(!s)return;let e=C.get(A);if(!e)return;let t=i.getBoundingClientRect(),n=e.el.getBoundingClientRect(),r=i.scrollLeft,a=i.scrollTop;s.style.setProperty(`--active-tab-left`,`${n.left-t.left-i.clientLeft+r}px`),s.style.setProperty(`--active-tab-width`,`${n.width}px`),s.style.setProperty(`--active-tab-top`,`${n.top-t.top-i.clientTop+a}px`),s.style.setProperty(`--active-tab-height`,`${n.height}px`)},N=(e,t=!1)=>{if(e=e.trim(),A===e&&!t)return;let r=C.get(e);if(!r||r.disabled)if(t){if(e=D,!e)return}else return;let i=A!==e;A=e;for(let t of S){let n=t.value===e;f(t.el,`selected`,n),t.el.tabIndex=n&&!t.disabled?0:-1,t.el.dataset.state=n?`active`:`inactive`}for(let t of o){let n=(t.dataset.value||``).trim();if(!n)continue;let r=n===e;t.hidden=!r,t.dataset.state=r?`active`:`inactive`}n.setAttribute(`data-value`,e),s&&M(),i&&!t&&(m(n,`tabs:change`,{value:e}),u?.(e))};if(N(A,!0),s){let e=()=>requestAnimationFrame(M);j.push(p(window,`resize`,e)),j.push(p(i,`scroll`,e));let t=new ResizeObserver(e);t.observe(i),j.push(()=>t.disconnect())}j.push(p(i,`click`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);n&&!n.disabled&&N(n.value)}));let P=v===`horizontal`,F=P?`ArrowLeft`:`ArrowUp`,I=P?`ArrowRight`:`ArrowDown`;j.push(p(i,`keydown`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);if(!n||T.length===0)return;if(e.key===`Enter`||e.key===` `){e.preventDefault(),n.disabled||N(n.value);return}if(P&&e.key===`ArrowDown`&&n.value===A){let t=n.panel;if(t){e.preventDefault();let n=t.querySelector(_);(n||t).focus();return}}let r=E.get(n.value)??-1;r===-1&&(r=E.get(A)??0);let i=r;switch(e.key){case F:i=r-1,i<0&&(i=T.length-1);break;case I:i=r+1,i>=T.length&&(i=0);break;case`Home`:i=0;break;case`End`:i=T.length-1;break;default:return}e.preventDefault();let a=T[i];a&&(a.el.focus(),b===`auto`&&N(a.value))}));let L=e=>{let t=e,n=e.currentTarget,r=t.detail,i=typeof r==`string`?r:r?.value??n?.dataset?.value,a=i?.trim();a&&N(a)};j.push(p(n,`tabs:select`,L));let R={select:e=>N(e),get value(){return A},updateIndicator:M,destroy:()=>{j.forEach(e=>e()),j.length=0,y.delete(n)}};return R}const y=new WeakSet;function b(e=document){let t=[];for(let r of n(e,`tabs`)){if(y.has(r))continue;y.add(r),t.push(v(r))}return t}export{b as create,v as createTabs};
1
+ const e=(e,t)=>e.querySelector(`[data-slot="${t}"]`),t=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],n=(e,t)=>[...e.querySelectorAll(`[data-slot="${t}"]`)],r=new WeakMap;function i(e,t,n){if(typeof process<`u`&&process.env?.NODE_ENV===`production`)return;let i=r.get(e);i||(i=new Set,r.set(e,i)),!i.has(t)&&(i.add(t),console.warn(`[@data-slot] ${n}`))}function a(e){let t=`data-${e.replace(/([A-Z])/g,`-$1`).toLowerCase()}`,n=`data-${e}`;return t===n?[t]:[t,n]}function o(e,t){for(let n of a(t))if(e.hasAttribute(n))return e.getAttribute(n);return null}function s(e,t){return a(t).some(t=>e.hasAttribute(t))}function c(e,t){if(s(e,t))return o(e,t)??void 0}function l(e,t,n){let r=o(e,t);if(r!==null){if(n.includes(r))return r;i(e,t,`Invalid value "${r}" for data-${t}. Expected one of: ${n.join(`, `)}.`)}}let u=0;const d=(e,t)=>e.id||=`${t}-${++u}`,f=(e,t,n)=>{n===null?e.removeAttribute(`aria-${t}`):e.setAttribute(`aria-${t}`,String(n))};function p(e,t,n,r){return e.addEventListener(t,n,r),()=>e.removeEventListener(t,n,r)}const m=(e,t,n)=>e.dispatchEvent(new CustomEvent(t,{bubbles:!0,detail:n})),h=[`horizontal`,`vertical`],g=[`auto`,`manual`],_=`a[href],button:not([disabled]),input:not([disabled]),select:not([disabled]),textarea:not([disabled]),[tabindex]:not([tabindex="-1"])`;function v(n,r={}){let i=e(n,`tabs-list`),a=t(n,`tabs-trigger`),o=t(n,`tabs-content`),s=e(n,`tabs-indicator`);if(!i||a.length===0)throw Error(`Tabs requires tabs-list and at least one tabs-trigger`);let u=r.onValueChange,v=r.orientation??l(n,`orientation`,h)??`horizontal`,b=r.activationMode??l(n,`activationMode`,g)??`auto`,x=new Map;for(let e of o){let t=(e.dataset.value||``).trim();t&&x.set(t,e)}let S=[],C=new Map,w=new Map;for(let e of a){let t=(e.dataset.value||``).trim();if(!t)continue;let n=e.hasAttribute(`disabled`)||e.dataset.disabled!==void 0||e.getAttribute(`aria-disabled`)===`true`,r=x.get(t),i={el:e,value:t,disabled:n,panel:r};S.push(i),C.set(t,i),w.set(e,i)}let T=S.filter(e=>!e.disabled),E=new Map;T.forEach((e,t)=>E.set(e.value,t));let D=T[0]?.value||``,O=(r.defaultValue??c(n,`defaultValue`)??``).trim(),k=C.get(O),A=k&&!k.disabled?O:D,j=[];i.setAttribute(`role`,`tablist`),v===`vertical`&&f(i,`orientation`,`vertical`);for(let e of S){let{el:t,disabled:n,panel:r}=e;t.setAttribute(`role`,`tab`);let i=d(t,`tab`);if(t.tagName===`BUTTON`&&!t.hasAttribute(`type`)&&(t.type=`button`),n&&(t.setAttribute(`aria-disabled`,`true`),t.tagName===`BUTTON`&&(t.disabled=!0)),r){r.setAttribute(`role`,`tabpanel`),r.tabIndex=-1;let e=d(r,`tabpanel`);t.setAttribute(`aria-controls`,e),r.setAttribute(`aria-labelledby`,i)}}let M=()=>{if(!s)return;let e=C.get(A);if(!e)return;let t=i.getBoundingClientRect(),n=e.el.getBoundingClientRect(),r=i.scrollLeft,a=i.scrollTop;s.style.setProperty(`--active-tab-left`,`${n.left-t.left-i.clientLeft+r}px`),s.style.setProperty(`--active-tab-width`,`${n.width}px`),s.style.setProperty(`--active-tab-top`,`${n.top-t.top-i.clientTop+a}px`),s.style.setProperty(`--active-tab-height`,`${n.height}px`)},N=(e,t=!1)=>{if(e=e.trim(),A===e&&!t)return;let r=C.get(e);if(!r||r.disabled)if(t){if(e=D,!e)return}else return;let i=A!==e;A=e;for(let t of S){let n=t.value===e;f(t.el,`selected`,n),t.el.tabIndex=n&&!t.disabled?0:-1,t.el.dataset.state=n?`active`:`inactive`}for(let t of o){let n=(t.dataset.value||``).trim();if(!n)continue;let r=n===e;t.hidden=!r,t.dataset.state=r?`active`:`inactive`}n.setAttribute(`data-value`,e),s&&M(),i&&!t&&(m(n,`tabs:change`,{value:e}),u?.(e))};if(N(A,!0),s){let e=()=>requestAnimationFrame(M);j.push(p(window,`resize`,e)),j.push(p(i,`scroll`,e));let t=new ResizeObserver(e);t.observe(i),j.push(()=>t.disconnect())}j.push(p(i,`click`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);n&&!n.disabled&&N(n.value)}));let P=v===`horizontal`,F=P?`ArrowLeft`:`ArrowUp`,I=P?`ArrowRight`:`ArrowDown`;j.push(p(i,`keydown`,e=>{let t=e.target.closest?.(`[data-slot="tabs-trigger"]`);if(!t)return;let n=w.get(t);if(!n||T.length===0)return;if(e.key===`Enter`||e.key===` `){e.preventDefault(),n.disabled||N(n.value);return}if(P&&e.key===`ArrowDown`&&n.value===A){let t=n.panel;if(t){e.preventDefault();let n=t.querySelector(_);(n||t).focus();return}}let r=E.get(n.value)??-1;r===-1&&(r=E.get(A)??0);let i=r;switch(e.key){case F:i=r-1,i<0&&(i=T.length-1);break;case I:i=r+1,i>=T.length&&(i=0);break;case`Home`:i=0;break;case`End`:i=T.length-1;break;default:return}e.preventDefault();let a=T[i];a&&(a.el.focus(),b===`auto`&&N(a.value))}));let L=e=>{let t=e,n=e.currentTarget,r=t.detail,i=typeof r==`string`?r:r?.value??n?.dataset?.value,a=i?.trim();a&&N(a)};j.push(p(n,`tabs:set`,L)),j.push(p(n,`tabs:select`,L));let R={select:e=>N(e),get value(){return A},updateIndicator:M,destroy:()=>{j.forEach(e=>e()),j.length=0,y.delete(n)}};return R}const y=new WeakSet;function b(e=document){let t=[];for(let r of n(e,`tabs`)){if(y.has(r))continue;y.add(r),t.push(v(r))}return t}export{b as create,v as createTabs};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@data-slot/tabs",
3
- "version": "0.2.10",
3
+ "version": "0.2.12",
4
4
  "type": "module",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.cjs",