@tcn/ui 0.7.0 → 0.8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (137) hide show
  1. package/dist/{Color-6BZIO3FS-CWWwv-fq.js → Color-6BZIO3FS-C9xkPWgz.js} +2 -2
  2. package/dist/{Color-6BZIO3FS-CWWwv-fq.js.map → Color-6BZIO3FS-C9xkPWgz.js.map} +1 -1
  3. package/dist/{WithTooltip-65CFNBJE-DvcUZizH.js → WithTooltip-65CFNBJE-DEnh547F.js} +2 -2
  4. package/dist/{WithTooltip-65CFNBJE-DvcUZizH.js.map → WithTooltip-65CFNBJE-DEnh547F.js.map} +1 -1
  5. package/dist/actions/__docs__/components/showcase.js +1 -1
  6. package/dist/actions/index.d.ts +1 -0
  7. package/dist/actions/index.d.ts.map +1 -1
  8. package/dist/actions/index.js +8 -6
  9. package/dist/actions/index.js.map +1 -1
  10. package/dist/body.css +1 -0
  11. package/dist/form/field_presenters/field_presenter.d.ts +2 -2
  12. package/dist/form/field_presenters/field_presenter.d.ts.map +1 -1
  13. package/dist/form/field_presenters/field_presenter.js.map +1 -1
  14. package/dist/formatter-EIJCOSYU-DWmgEY3b.js +6 -0
  15. package/dist/{formatter-EIJCOSYU-D6nmx63h.js.map → formatter-EIJCOSYU-DWmgEY3b.js.map} +1 -1
  16. package/dist/inputs/color_input/color_input.js +10 -9
  17. package/dist/inputs/color_input/color_input.js.map +1 -1
  18. package/dist/inputs/date_picker/date_picker_header.js +7 -6
  19. package/dist/inputs/date_picker/date_picker_header.js.map +1 -1
  20. package/dist/inputs/date_picker/date_picker_input.js +3 -2
  21. package/dist/inputs/date_picker/date_picker_input.js.map +1 -1
  22. package/dist/inputs/date_picker/date_picker_time_selector.js +3 -2
  23. package/dist/inputs/date_picker/date_picker_time_selector.js.map +1 -1
  24. package/dist/inputs/date_picker/date_picker_year_input.js +6 -5
  25. package/dist/inputs/date_picker/date_picker_year_input.js.map +1 -1
  26. package/dist/inputs/date_picker/date_picker_year_selector.js +3 -2
  27. package/dist/inputs/date_picker/date_picker_year_selector.js.map +1 -1
  28. package/dist/inputs/multiselect/multiselect_inline_values.js +8 -7
  29. package/dist/inputs/multiselect/multiselect_inline_values.js.map +1 -1
  30. package/dist/inputs/multiselect/multiselect_values.js +3 -2
  31. package/dist/inputs/multiselect/multiselect_values.js.map +1 -1
  32. package/dist/inputs/phone_number_input/phone_number_input.js +44 -43
  33. package/dist/inputs/phone_number_input/phone_number_input.js.map +1 -1
  34. package/dist/inputs/select/select.js +3 -2
  35. package/dist/inputs/select/select.js.map +1 -1
  36. package/dist/inputs/suggestions/suggestion_list.js +3 -2
  37. package/dist/inputs/suggestions/suggestion_list.js.map +1 -1
  38. package/dist/layouts/body/body.d.ts +6 -0
  39. package/dist/layouts/body/body.d.ts.map +1 -0
  40. package/dist/layouts/body/body.js +21 -0
  41. package/dist/layouts/body/body.js.map +1 -0
  42. package/dist/layouts/index.d.ts +5 -0
  43. package/dist/layouts/index.d.ts.map +1 -1
  44. package/dist/layouts/index.js +38 -22
  45. package/dist/layouts/index.js.map +1 -1
  46. package/dist/layouts/rail/main/main.d.ts +6 -0
  47. package/dist/layouts/rail/main/main.d.ts.map +1 -0
  48. package/dist/layouts/rail/main/main.js +21 -0
  49. package/dist/layouts/rail/main/main.js.map +1 -0
  50. package/dist/layouts/rail/rail.d.ts +9 -0
  51. package/dist/layouts/rail/rail.d.ts.map +1 -0
  52. package/dist/layouts/rail/rail.js +55 -0
  53. package/dist/layouts/rail/rail.js.map +1 -0
  54. package/dist/layouts/rail/side/side.d.ts +6 -0
  55. package/dist/layouts/rail/side/side.d.ts.map +1 -0
  56. package/dist/layouts/rail/side/side.js +21 -0
  57. package/dist/layouts/rail/side/side.js.map +1 -0
  58. package/dist/layouts/rail/utility_strip/utility_strip.d.ts +9 -0
  59. package/dist/layouts/rail/utility_strip/utility_strip.d.ts.map +1 -0
  60. package/dist/layouts/rail/utility_strip/utility_strip.js +32 -0
  61. package/dist/layouts/rail/utility_strip/utility_strip.js.map +1 -0
  62. package/dist/layouts/scaffold/scaffold.js +31 -31
  63. package/dist/layouts/scaffold/scaffold.js.map +1 -1
  64. package/dist/layouts/table/table.d.ts +27 -0
  65. package/dist/layouts/table/table.d.ts.map +1 -0
  66. package/dist/layouts/table/table.js +70 -0
  67. package/dist/layouts/table/table.js.map +1 -0
  68. package/dist/main.css +1 -0
  69. package/dist/navigation/tabs/primitives/tabs_list.d.ts.map +1 -1
  70. package/dist/navigation/tabs/primitives/tabs_list.js +61 -21
  71. package/dist/navigation/tabs/primitives/tabs_list.js.map +1 -1
  72. package/dist/navigation/tabs/state/link/tab_link.d.ts.map +1 -1
  73. package/dist/navigation/tabs/state/link/tab_link.js +20 -17
  74. package/dist/navigation/tabs/state/link/tab_link.js.map +1 -1
  75. package/dist/navigation/tabs/state/tab.d.ts.map +1 -1
  76. package/dist/navigation/tabs/state/tab.js +8 -3
  77. package/dist/navigation/tabs/state/tab.js.map +1 -1
  78. package/dist/rail.css +1 -0
  79. package/dist/scaffold.css +1 -1
  80. package/dist/{showcase-DK557szS.js → showcase-y9D3_Y8T.js} +3413 -3396
  81. package/dist/showcase-y9D3_Y8T.js.map +1 -0
  82. package/dist/side.css +1 -0
  83. package/dist/stacks/box/box.d.ts +2 -2
  84. package/dist/stacks/box/box.d.ts.map +1 -1
  85. package/dist/stacks/box/box.js.map +1 -1
  86. package/dist/stacks/story_components/style_box.d.ts +1 -1
  87. package/dist/stacks/story_components/style_box.d.ts.map +1 -1
  88. package/dist/surfaces/alert/alert.js +3 -2
  89. package/dist/surfaces/alert/alert.js.map +1 -1
  90. package/dist/surfaces/pop_confirm/pop_confirm.js +13 -2
  91. package/dist/surfaces/pop_confirm/pop_confirm.js.map +1 -1
  92. package/dist/{syntaxhighlighter-ED5Y7EFY-DaMS-2cF.js → syntaxhighlighter-ED5Y7EFY-CqInEOwQ.js} +2 -2
  93. package/dist/{syntaxhighlighter-ED5Y7EFY-DaMS-2cF.js.map → syntaxhighlighter-ED5Y7EFY-CqInEOwQ.js.map} +1 -1
  94. package/dist/table.css +1 -0
  95. package/dist/table.module-BtSxOntS.js +5 -0
  96. package/dist/table.module-BtSxOntS.js.map +1 -0
  97. package/dist/themes/themes/ergo/ergo_theme.css +1 -1
  98. package/dist/themes/themes/ergo/ergo_theme.js +179 -44
  99. package/dist/themes/themes/ergo/ergo_theme.js.map +1 -1
  100. package/dist/utility_strip.css +1 -0
  101. package/package.json +2 -2
  102. package/src/actions/index.ts +1 -0
  103. package/src/form/field_presenters/field_presenter.ts +3 -3
  104. package/src/layouts/__stories__/composed.stories.tsx +113 -0
  105. package/src/layouts/__stories__/composed_stories.module.css +142 -0
  106. package/src/layouts/__stories__/utils.tsx +174 -0
  107. package/src/layouts/body/body.module.css +11 -0
  108. package/src/layouts/body/body.tsx +23 -0
  109. package/src/layouts/index.ts +10 -0
  110. package/src/layouts/rail/__stories__/rail.stories.tsx +64 -0
  111. package/src/layouts/rail/__stories__/rail_stories.module.css +25 -0
  112. package/src/layouts/rail/main/main.module.css +7 -0
  113. package/src/layouts/rail/main/main.tsx +26 -0
  114. package/src/layouts/rail/rail.module.css +10 -0
  115. package/src/layouts/rail/rail.tsx +62 -0
  116. package/src/layouts/rail/side/side.module.css +8 -0
  117. package/src/layouts/rail/side/side.tsx +25 -0
  118. package/src/layouts/rail/utility_strip/utility_strip.module.css +6 -0
  119. package/src/layouts/rail/utility_strip/utility_strip.tsx +40 -0
  120. package/src/layouts/scaffold/__stories__/scaffold.stories.tsx +53 -0
  121. package/src/layouts/scaffold/__stories__/scaffold_stories.module.css +31 -0
  122. package/src/layouts/scaffold/scaffold.module.css +4 -0
  123. package/src/layouts/table/__stories__/mock_data.ts +420 -0
  124. package/src/layouts/table/__stories__/table.stories.tsx +326 -0
  125. package/src/layouts/table/__stories__/table_stories.module.css +30 -0
  126. package/src/layouts/table/table.module.css +37 -0
  127. package/src/layouts/table/table.tsx +132 -0
  128. package/src/navigation/tabs/primitives/tabs_list.tsx +46 -2
  129. package/src/navigation/tabs/state/link/tab_link.tsx +4 -1
  130. package/src/navigation/tabs/state/tab.tsx +10 -0
  131. package/src/stacks/box/box.tsx +1 -1
  132. package/src/surfaces/modal/__stories__/modal.stories.tsx +5 -5
  133. package/src/surfaces/panel/__stories__/panel.stories.tsx +114 -1
  134. package/src/surfaces/pop_confirm/pop_confirm.stories.tsx +4 -2
  135. package/src/themes/themes/ergo/ergo_theme.css +178 -43
  136. package/dist/formatter-EIJCOSYU-D6nmx63h.js +0 -6
  137. package/dist/showcase-DK557szS.js.map +0 -1
@@ -1,29 +1,69 @@
1
- import { jsx as s } from "react/jsx-runtime";
2
- import { forwardRef as c } from "react";
3
- import { HStack as n } from "../../../stacks/h_stack.js";
4
- import e from "clsx";
5
- import { Toggle as f } from "../../../actions/toggle/toggle.js";
6
- const T = ({
7
- children: t,
1
+ import { jsx as n } from "react/jsx-runtime";
2
+ import { forwardRef as m, useCallback as f } from "react";
3
+ import { HStack as u } from "../../../stacks/h_stack.js";
4
+ import l from "clsx";
5
+ import { Toggle as b } from "../../../actions/toggle/toggle.js";
6
+ const g = (e) => {
7
+ const r = Array.from(e.currentTarget.querySelectorAll(':scope > [role="tab"]')), o = e.currentTarget.querySelector(":focus"), a = o ? r.indexOf(o) : -1;
8
+ if (a === -1) return;
9
+ let t = 0;
10
+ switch (e.key) {
11
+ case "ArrowRight":
12
+ t = (a + 1) % r.length;
13
+ break;
14
+ case "ArrowLeft":
15
+ t = (a - 1 + r.length) % r.length;
16
+ break;
17
+ case "Home":
18
+ t = 0;
19
+ break;
20
+ case "End":
21
+ t = r.length - 1;
22
+ break;
23
+ default:
24
+ return;
25
+ }
26
+ e.preventDefault(), e.stopPropagation(), r[t].focus();
27
+ }, x = ({
28
+ children: e,
8
29
  className: r,
9
- role: m = "tablist",
10
- as: o = "menu",
11
- ...a
12
- }) => /* @__PURE__ */ s(n, { as: o, role: m, className: e("tcn-tabs-list", r), ...a, children: t }), g = c(
13
- ({ children: t, className: r, role: m = "tab", selected: o = !1, ...a }, i) => /* @__PURE__ */ s(
14
- f,
30
+ role: o = "tablist",
31
+ as: a = "menu",
32
+ onKeyDown: t,
33
+ ...s
34
+ }) => {
35
+ const i = f(
36
+ (c) => {
37
+ g(c), t && t(c);
38
+ },
39
+ [t]
40
+ );
41
+ return /* @__PURE__ */ n(
42
+ u,
15
43
  {
16
- ref: i,
17
- role: m,
18
- className: e(r, "tcn-interactive", "tcn-tab-item"),
19
- selected: o,
20
- ...a,
21
- children: t
44
+ onKeyDown: i,
45
+ as: a,
46
+ role: o,
47
+ className: l("tcn-tabs-list", r),
48
+ ...s,
49
+ children: e
50
+ }
51
+ );
52
+ }, w = m(
53
+ ({ children: e, className: r, role: o = "tab", selected: a = !1, ...t }, s) => /* @__PURE__ */ n(
54
+ b,
55
+ {
56
+ ref: s,
57
+ role: o,
58
+ className: l(r, "tcn-interactive", "tcn-tab-item"),
59
+ selected: a,
60
+ ...t,
61
+ children: e
22
62
  }
23
63
  )
24
64
  );
25
65
  export {
26
- g as TabItem,
27
- T as TabsList
66
+ w as TabItem,
67
+ x as TabsList
28
68
  };
29
69
  //# sourceMappingURL=tabs_list.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tabs_list.js","sources":["../../../../src/navigation/tabs/primitives/tabs_list.tsx"],"sourcesContent":["import { forwardRef, type FC, type PropsWithChildren } from 'react';\nimport { type BaseButtonProps } from '../../../actions/index.js';\nimport { HStack, type HStackProps } from '../../../stacks/h_stack.js';\nimport clsx from 'clsx';\nimport { Toggle } from '../../../actions/toggle/toggle.js';\n\nexport type TabsListProps = HStackProps;\n\nexport const TabsList: FC<PropsWithChildren<TabsListProps>> = ({\n children,\n className,\n role = 'tablist',\n as = 'menu',\n ...props\n}) => {\n return (\n <HStack as={as} role={role} className={clsx('tcn-tabs-list', className)} {...props}>\n {children}\n </HStack>\n );\n};\n\nexport interface TabItemProps extends Omit<BaseButtonProps, 'hierarchy'> {\n selected?: boolean;\n}\n\nexport const TabItem = forwardRef<HTMLButtonElement, PropsWithChildren<TabItemProps>>(\n ({ children, className, role = 'tab', selected = false, ...props }, ref) => {\n return (\n <Toggle\n ref={ref}\n role={role}\n className={clsx(className, 'tcn-interactive', 'tcn-tab-item')}\n selected={selected}\n {...props}\n >\n {children}\n </Toggle>\n );\n }\n);\n"],"names":["TabsList","children","className","role","as","props","jsx","HStack","clsx","TabItem","forwardRef","selected","ref","Toggle"],"mappings":";;;;;AAQO,MAAMA,IAAiD,CAAC;AAAA,EAC7D,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,IAAAC,IAAK;AAAA,EACL,GAAGC;AACL,MAEI,gBAAAC,EAACC,GAAA,EAAO,IAAAH,GAAQ,MAAAD,GAAY,WAAWK,EAAK,iBAAiBN,CAAS,GAAI,GAAGG,GAC1E,UAAAJ,EAAA,CACH,GAQSQ,IAAUC;AAAA,EACrB,CAAC,EAAE,UAAAT,GAAU,WAAAC,GAAW,MAAAC,IAAO,OAAO,UAAAQ,IAAW,IAAO,GAAGN,EAAA,GAASO,MAEhE,gBAAAN;AAAA,IAACO;AAAA,IAAA;AAAA,MACC,KAAAD;AAAA,MACA,MAAAT;AAAA,MACA,WAAWK,EAAKN,GAAW,mBAAmB,cAAc;AAAA,MAC5D,UAAAS;AAAA,MACC,GAAGN;AAAA,MAEH,UAAAJ;AAAA,IAAA;AAAA,EAAA;AAIT;"}
1
+ {"version":3,"file":"tabs_list.js","sources":["../../../../src/navigation/tabs/primitives/tabs_list.tsx"],"sourcesContent":["import { forwardRef, useCallback, type FC, type PropsWithChildren } from 'react';\nimport { type BaseButtonProps } from '../../../actions/index.js';\nimport { HStack, type HStackProps } from '../../../stacks/h_stack.js';\nimport clsx from 'clsx';\nimport { Toggle } from '../../../actions/toggle/toggle.js';\n\nexport type TabsListProps = HStackProps;\n\nconst navigateTabs = (event: React.KeyboardEvent<HTMLDivElement>) => {\n const tabs = Array.from(event.currentTarget.querySelectorAll(':scope > [role=\"tab\"]'));\n const currentTab = event.currentTarget.querySelector(':focus');\n const currentIndex = currentTab ? tabs.indexOf(currentTab) : -1;\n if (currentIndex === -1) return; // Exit if the focused element is not a tab\n let newIndex = 0;\n\n switch (event.key) {\n case 'ArrowRight':\n newIndex = (currentIndex + 1) % tabs.length;\n break;\n case 'ArrowLeft':\n newIndex = (currentIndex - 1 + tabs.length) % tabs.length;\n break;\n case 'Home':\n newIndex = 0;\n break;\n case 'End':\n newIndex = tabs.length - 1;\n break;\n default:\n return; // Exit if the key is not recognized\n }\n\n event.preventDefault();\n event.stopPropagation();\n tabs[newIndex]['focus']();\n};\n\nexport const TabsList: FC<PropsWithChildren<TabsListProps>> = ({\n children,\n className,\n role = 'tablist',\n as = 'menu',\n onKeyDown,\n ...props\n}) => {\n const handleKeyDown = useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n navigateTabs(event);\n onKeyDown && onKeyDown(event);\n },\n [onKeyDown]\n );\n\n return (\n <HStack\n onKeyDown={handleKeyDown}\n as={as}\n role={role}\n className={clsx('tcn-tabs-list', className)}\n {...props}\n >\n {children}\n </HStack>\n );\n};\n\nexport interface TabItemProps extends Omit<BaseButtonProps, 'hierarchy'> {\n selected?: boolean;\n}\n\nexport const TabItem = forwardRef<HTMLButtonElement, PropsWithChildren<TabItemProps>>(\n ({ children, className, role = 'tab', selected = false, ...props }, ref) => {\n return (\n <Toggle\n ref={ref}\n role={role}\n className={clsx(className, 'tcn-interactive', 'tcn-tab-item')}\n selected={selected}\n {...props}\n >\n {children}\n </Toggle>\n );\n }\n);\n"],"names":["navigateTabs","event","tabs","currentTab","currentIndex","newIndex","TabsList","children","className","role","as","onKeyDown","props","handleKeyDown","useCallback","jsx","HStack","clsx","TabItem","forwardRef","selected","ref","Toggle"],"mappings":";;;;;AAQA,MAAMA,IAAe,CAACC,MAA+C;AACnE,QAAMC,IAAO,MAAM,KAAKD,EAAM,cAAc,iBAAiB,uBAAuB,CAAC,GAC/EE,IAAaF,EAAM,cAAc,cAAc,QAAQ,GACvDG,IAAeD,IAAaD,EAAK,QAAQC,CAAU,IAAI;AAC7D,MAAIC,MAAiB,GAAI;AACzB,MAAIC,IAAW;AAEf,UAAQJ,EAAM,KAAA;AAAA,IACZ,KAAK;AACH,MAAAI,KAAYD,IAAe,KAAKF,EAAK;AACrC;AAAA,IACF,KAAK;AACH,MAAAG,KAAYD,IAAe,IAAIF,EAAK,UAAUA,EAAK;AACnD;AAAA,IACF,KAAK;AACH,MAAAG,IAAW;AACX;AAAA,IACF,KAAK;AACH,MAAAA,IAAWH,EAAK,SAAS;AACzB;AAAA,IACF;AACE;AAAA,EAAA;AAGJ,EAAAD,EAAM,eAAA,GACNA,EAAM,gBAAA,GACNC,EAAKG,CAAQ,EAAE,MAAO;AACxB,GAEaC,IAAiD,CAAC;AAAA,EAC7D,UAAAC;AAAA,EACA,WAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,IAAAC,IAAK;AAAA,EACL,WAAAC;AAAA,EACA,GAAGC;AACL,MAAM;AACJ,QAAMC,IAAgBC;AAAA,IACpB,CAACb,MAA+C;AAC9C,MAAAD,EAAaC,CAAK,GAClBU,KAAaA,EAAUV,CAAK;AAAA,IAC9B;AAAA,IACA,CAACU,CAAS;AAAA,EAAA;AAGZ,SACE,gBAAAI;AAAA,IAACC;AAAA,IAAA;AAAA,MACC,WAAWH;AAAA,MACX,IAAAH;AAAA,MACA,MAAAD;AAAA,MACA,WAAWQ,EAAK,iBAAiBT,CAAS;AAAA,MACzC,GAAGI;AAAA,MAEH,UAAAL;AAAA,IAAA;AAAA,EAAA;AAGP,GAMaW,IAAUC;AAAA,EACrB,CAAC,EAAE,UAAAZ,GAAU,WAAAC,GAAW,MAAAC,IAAO,OAAO,UAAAW,IAAW,IAAO,GAAGR,EAAA,GAASS,MAEhE,gBAAAN;AAAA,IAACO;AAAA,IAAA;AAAA,MACC,KAAAD;AAAA,MACA,MAAAZ;AAAA,MACA,WAAWQ,EAAKT,GAAW,mBAAmB,cAAc;AAAA,MAC5D,UAAAY;AAAA,MACC,GAAGR;AAAA,MAEH,UAAAL;AAAA,IAAA;AAAA,EAAA;AAIT;"}
@@ -1 +1 @@
1
- {"version":3,"file":"tab_link.d.ts","sourceRoot":"","sources":["../../../../../src/navigation/tabs/state/link/tab_link.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACxE,OAAO,EAAW,KAAK,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAK3E,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,YACf,SAAQ,IAAI,CAAC,YAAY,EAAE,UAAU,GAAG,OAAO,CAAC,EAC9C,eAAe;CAAG;AAEtB,eAAO,MAAM,OAAO,4IA8BnB,CAAC"}
1
+ {"version":3,"file":"tab_link.d.ts","sourceRoot":"","sources":["../../../../../src/navigation/tabs/state/link/tab_link.tsx"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACxE,OAAO,EAAW,KAAK,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAK3E,MAAM,WAAW,eAAe;IAC9B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,YACf,SAAQ,IAAI,CAAC,YAAY,EAAE,UAAU,GAAG,OAAO,CAAC,EAC9C,eAAe;CAAG;AAEtB,eAAO,MAAM,OAAO,4IAiCnB,CAAC"}
@@ -1,34 +1,37 @@
1
- import { jsx as W } from "react/jsx-runtime";
2
- import { forwardRef as b, useCallback as x } from "react";
1
+ import { jsx as k } from "react/jsx-runtime";
2
+ import { forwardRef as x, useCallback as W } from "react";
3
3
  import { TabItem as l } from "../../primitives/tabs_list.js";
4
4
  import "../../../../utils/click_away_listener.js";
5
5
  import "../../../../utils/focus_redirect.js";
6
6
  import "../../../../utils/scroll_away_listener.js";
7
- import { useForkRef as T } from "../../../../utils/hooks/use_fork_ref.js";
7
+ import { useForkRef as I } from "../../../../utils/hooks/use_fork_ref.js";
8
8
  import "../../../../utils/hooks/use_resize_observer.js";
9
9
  import "../../../../utils/dnd/context.js";
10
10
  import "clsx";
11
11
  import "../../../../draggable.module-BgelQsuJ.js";
12
- import { useTabs as u } from "../context.js";
12
+ import { useTabs as T } from "../context.js";
13
13
  import { useTabLink as C } from "./use_tab_link.js";
14
- const D = b(
15
- ({ children: r, value: o, onClick: i, minWidth: m, maxWidth: e, ...n }, p) => {
16
- const { ref: s, isMatch: a } = C(o), t = u(), c = T(s, p), f = x(
17
- (k) => {
18
- t.onChange?.(o), i?.(k);
14
+ const D = x(
15
+ ({ children: m, value: t, onClick: o, minWidth: n, maxWidth: e, id: M, ...a }, p) => {
16
+ const { ref: s, isMatch: r } = C(t), i = T(), c = I(s, p), d = W(
17
+ (b) => {
18
+ i.onChange?.(t), o?.(b);
19
19
  },
20
- [t, o, i]
21
- ), d = t.minItemWidth ?? m, h = t.maxItemWidth ?? e;
22
- return /* @__PURE__ */ W(
20
+ [i, t, o]
21
+ ), f = i.minItemWidth ?? n, h = i.maxItemWidth ?? e;
22
+ return /* @__PURE__ */ k(
23
23
  l,
24
24
  {
25
25
  ref: c,
26
- selected: a,
27
- onClick: f,
28
- minWidth: d,
26
+ selected: r,
27
+ onClick: d,
28
+ minWidth: f,
29
29
  maxWidth: h,
30
- ...n,
31
- children: r
30
+ id: `tab-${t}`,
31
+ "aria-controls": `tabpanel-${t}`,
32
+ tabIndex: r ? 0 : -1,
33
+ ...a,
34
+ children: m
32
35
  }
33
36
  );
34
37
  }
@@ -1 +1 @@
1
- {"version":3,"file":"tab_link.js","sources":["../../../../../src/navigation/tabs/state/link/tab_link.tsx"],"sourcesContent":["import { forwardRef, useCallback, type PropsWithChildren } from 'react';\nimport { TabItem, type TabItemProps } from '../../primitives/tabs_list.js';\nimport { useForkRef } from '../../../../utils/index.js';\nimport { useTabs } from '../context.js';\nimport { useTabLink } from './use_tab_link.js';\n\nexport interface TabLinkOwnProps {\n value: string;\n}\n\nexport interface TabLinkProps\n extends Omit<TabItemProps, 'selected' | 'value'>,\n TabLinkOwnProps {}\n\nexport const TabLink = forwardRef<HTMLButtonElement, PropsWithChildren<TabLinkProps>>(\n ({ children, value, onClick, minWidth, maxWidth, ...props }, forwardedRef) => {\n const { ref: internalRef, isMatch } = useTabLink(value);\n const state = useTabs();\n const ref = useForkRef(internalRef, forwardedRef);\n\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n state.onChange?.(value);\n onClick?.(event);\n },\n [state, value, onClick]\n );\n\n const pickMinWidth = state.minItemWidth ?? minWidth;\n const pickMaxWidth = state.maxItemWidth ?? maxWidth;\n\n return (\n <TabItem\n ref={ref}\n selected={isMatch}\n onClick={handleClick}\n minWidth={pickMinWidth}\n maxWidth={pickMaxWidth}\n {...props}\n >\n {children}\n </TabItem>\n );\n }\n);\n"],"names":["TabLink","forwardRef","children","value","onClick","minWidth","maxWidth","props","forwardedRef","internalRef","isMatch","useTabLink","state","useTabs","ref","useForkRef","handleClick","useCallback","event","pickMinWidth","pickMaxWidth","jsx","TabItem"],"mappings":";;;;;;;;;;;;;AAcO,MAAMA,IAAUC;AAAA,EACrB,CAAC,EAAE,UAAAC,GAAU,OAAAC,GAAO,SAAAC,GAAS,UAAAC,GAAU,UAAAC,GAAU,GAAGC,EAAA,GAASC,MAAiB;AAC5E,UAAM,EAAE,KAAKC,GAAa,SAAAC,EAAA,IAAYC,EAAWR,CAAK,GAChDS,IAAQC,EAAA,GACRC,IAAMC,EAAWN,GAAaD,CAAY,GAE1CQ,IAAcC;AAAA,MAClB,CAACC,MAA+C;AAC9C,QAAAN,EAAM,WAAWT,CAAK,GACtBC,IAAUc,CAAK;AAAA,MACjB;AAAA,MACA,CAACN,GAAOT,GAAOC,CAAO;AAAA,IAAA,GAGlBe,IAAeP,EAAM,gBAAgBP,GACrCe,IAAeR,EAAM,gBAAgBN;AAE3C,WACE,gBAAAe;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,KAAAR;AAAA,QACA,UAAUJ;AAAA,QACV,SAASM;AAAA,QACT,UAAUG;AAAA,QACV,UAAUC;AAAA,QACT,GAAGb;AAAA,QAEH,UAAAL;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;"}
1
+ {"version":3,"file":"tab_link.js","sources":["../../../../../src/navigation/tabs/state/link/tab_link.tsx"],"sourcesContent":["import { forwardRef, useCallback, type PropsWithChildren } from 'react';\nimport { TabItem, type TabItemProps } from '../../primitives/tabs_list.js';\nimport { useForkRef } from '../../../../utils/index.js';\nimport { useTabs } from '../context.js';\nimport { useTabLink } from './use_tab_link.js';\n\nexport interface TabLinkOwnProps {\n value: string;\n}\n\nexport interface TabLinkProps\n extends Omit<TabItemProps, 'selected' | 'value'>,\n TabLinkOwnProps {}\n\nexport const TabLink = forwardRef<HTMLButtonElement, PropsWithChildren<TabLinkProps>>(\n ({ children, value, onClick, minWidth, maxWidth, id, ...props }, forwardedRef) => {\n const { ref: internalRef, isMatch } = useTabLink(value);\n const state = useTabs();\n const ref = useForkRef(internalRef, forwardedRef);\n\n const handleClick = useCallback(\n (event: React.MouseEvent<HTMLButtonElement>) => {\n state.onChange?.(value);\n onClick?.(event);\n },\n [state, value, onClick]\n );\n\n const pickMinWidth = state.minItemWidth ?? minWidth;\n const pickMaxWidth = state.maxItemWidth ?? maxWidth;\n\n return (\n <TabItem\n ref={ref}\n selected={isMatch}\n onClick={handleClick}\n minWidth={pickMinWidth}\n maxWidth={pickMaxWidth}\n id={`tab-${value}`}\n aria-controls={`tabpanel-${value}`}\n tabIndex={isMatch ? 0 : -1}\n {...props}\n >\n {children}\n </TabItem>\n );\n }\n);\n"],"names":["TabLink","forwardRef","children","value","onClick","minWidth","maxWidth","id","props","forwardedRef","internalRef","isMatch","useTabLink","state","useTabs","ref","useForkRef","handleClick","useCallback","event","pickMinWidth","pickMaxWidth","jsx","TabItem"],"mappings":";;;;;;;;;;;;;AAcO,MAAMA,IAAUC;AAAA,EACrB,CAAC,EAAE,UAAAC,GAAU,OAAAC,GAAO,SAAAC,GAAS,UAAAC,GAAU,UAAAC,GAAU,IAAAC,GAAI,GAAGC,EAAA,GAASC,MAAiB;AAChF,UAAM,EAAE,KAAKC,GAAa,SAAAC,EAAA,IAAYC,EAAWT,CAAK,GAChDU,IAAQC,EAAA,GACRC,IAAMC,EAAWN,GAAaD,CAAY,GAE1CQ,IAAcC;AAAA,MAClB,CAACC,MAA+C;AAC9C,QAAAN,EAAM,WAAWV,CAAK,GACtBC,IAAUe,CAAK;AAAA,MACjB;AAAA,MACA,CAACN,GAAOV,GAAOC,CAAO;AAAA,IAAA,GAGlBgB,IAAeP,EAAM,gBAAgBR,GACrCgB,IAAeR,EAAM,gBAAgBP;AAE3C,WACE,gBAAAgB;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,KAAAR;AAAA,QACA,UAAUJ;AAAA,QACV,SAASM;AAAA,QACT,UAAUG;AAAA,QACV,UAAUC;AAAA,QACV,IAAI,OAAOlB,CAAK;AAAA,QAChB,iBAAe,YAAYA,CAAK;AAAA,QAChC,UAAUQ,IAAU,IAAI;AAAA,QACvB,GAAGH;AAAA,QAEH,UAAAN;AAAA,MAAA;AAAA,IAAA;AAAA,EAGP;AACF;"}
@@ -1 +1 @@
1
- {"version":3,"file":"tab.d.ts","sourceRoot":"","sources":["../../../../src/navigation/tabs/state/tab.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAGnD,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,GAAG,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAI/C,CAAC"}
1
+ {"version":3,"file":"tab.d.ts","sourceRoot":"","sources":["../../../../src/navigation/tabs/state/tab.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAGnD,MAAM,WAAW,QAAQ;IACvB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,eAAO,MAAM,GAAG,EAAE,EAAE,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAa/C,CAAC"}
@@ -1,6 +1,11 @@
1
- import { useTabs as r } from "./context.js";
2
- const n = ({ value: t, children: e }) => r().value !== t ? null : e;
1
+ import e from "react";
2
+ import { useTabs as a } from "./context.js";
3
+ const m = ({ value: o, children: t }) => a().value !== o ? null : t && e.isValidElement(t) ? e.cloneElement(t, {
4
+ ...t.props,
5
+ id: t.props.id ?? `tabpanel-${o}`,
6
+ role: t.props.role ?? "tabpanel"
7
+ }) : t;
3
8
  export {
4
- n as Tab
9
+ m as Tab
5
10
  };
6
11
  //# sourceMappingURL=tab.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tab.js","sources":["../../../../src/navigation/tabs/state/tab.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from 'react';\nimport { useTabs } from './context.js';\n\nexport interface TabProps {\n value: string;\n}\n\nexport const Tab: FC<PropsWithChildren<TabProps>> = ({ value, children }) => {\n const state = useTabs();\n if (state.value !== value) return null;\n return children;\n};\n"],"names":["Tab","value","children","useTabs"],"mappings":";AAOO,MAAMA,IAAuC,CAAC,EAAE,OAAAC,GAAO,UAAAC,QAC9CC,EAAA,EACJ,UAAUF,IAAc,OAC3BC;"}
1
+ {"version":3,"file":"tab.js","sources":["../../../../src/navigation/tabs/state/tab.tsx"],"sourcesContent":["import React from 'react';\nimport type { FC, PropsWithChildren } from 'react';\nimport { useTabs } from './context.js';\n\nexport interface TabProps {\n value: string;\n}\n\nexport const Tab: FC<PropsWithChildren<TabProps>> = ({ value, children }) => {\n const state = useTabs();\n if (state.value !== value) return null;\n\n if (children && React.isValidElement(children)) {\n return React.cloneElement(children, {\n ...children.props,\n id: children.props.id ?? `tabpanel-${value}`,\n role: children.props.role ?? 'tabpanel',\n });\n }\n\n return children;\n};\n"],"names":["Tab","value","children","useTabs","React"],"mappings":";;AAQO,MAAMA,IAAuC,CAAC,EAAE,OAAAC,GAAO,UAAAC,QAC9CC,EAAA,EACJ,UAAUF,IAAc,OAE9BC,KAAYE,EAAM,eAAeF,CAAQ,IACpCE,EAAM,aAAaF,GAAU;AAAA,EAClC,GAAGA,EAAS;AAAA,EACZ,IAAIA,EAAS,MAAM,MAAM,YAAYD,CAAK;AAAA,EAC1C,MAAMC,EAAS,MAAM,QAAQ;AAAA,CAC9B,IAGIA;"}
package/dist/rail.css ADDED
@@ -0,0 +1 @@
1
+ @layer tcn-system{:where(._rail-stack_76bc40f){width:100%;height:100%;overflow:auto}:where(._rail-stack_76bc40f) :where(._tcn-body_a4d9cc2){height:100%}}
package/dist/scaffold.css CHANGED
@@ -1 +1 @@
1
- @layer tcn-system{:where(._scaffold-stack_8f97a6a){width:100%;height:100%;overflow:auto}}
1
+ @layer tcn-system{:where(._scaffold-stack_8f97a6a){width:100%;height:100%;overflow:auto}:where(._scaffold-stack_8f97a6a) :where(._tcn-main_8a04212){height:auto;background:#000!important}}