@salt-ds/core 1.8.0-rc.2 → 1.8.0-rc.4

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 (148) hide show
  1. package/dist-cjs/accordion/Accordion.css.js +6 -0
  2. package/dist-cjs/accordion/Accordion.css.js.map +1 -0
  3. package/dist-cjs/accordion/Accordion.js +67 -0
  4. package/dist-cjs/accordion/Accordion.js.map +1 -0
  5. package/dist-cjs/accordion/AccordionContext.js +29 -0
  6. package/dist-cjs/accordion/AccordionContext.js.map +1 -0
  7. package/dist-cjs/accordion/AccordionGroup.js +27 -0
  8. package/dist-cjs/accordion/AccordionGroup.js.map +1 -0
  9. package/dist-cjs/accordion/AccordionHeader.css.js +6 -0
  10. package/dist-cjs/accordion/AccordionHeader.css.js.map +1 -0
  11. package/dist-cjs/accordion/AccordionHeader.js +54 -0
  12. package/dist-cjs/accordion/AccordionHeader.js.map +1 -0
  13. package/dist-cjs/accordion/AccordionPanel.css.js +6 -0
  14. package/dist-cjs/accordion/AccordionPanel.css.js.map +1 -0
  15. package/dist-cjs/accordion/AccordionPanel.js +49 -0
  16. package/dist-cjs/accordion/AccordionPanel.js.map +1 -0
  17. package/dist-cjs/button/Button.css.js +1 -1
  18. package/dist-cjs/checkbox/Checkbox.css.js +1 -1
  19. package/dist-cjs/checkbox/Checkbox.js +27 -17
  20. package/dist-cjs/checkbox/Checkbox.js.map +1 -1
  21. package/dist-cjs/checkbox/CheckboxGroup.js +4 -0
  22. package/dist-cjs/checkbox/CheckboxGroup.js.map +1 -1
  23. package/dist-cjs/checkbox/CheckboxIcon.css.js +1 -1
  24. package/dist-cjs/checkbox/CheckboxIcon.js +42 -24
  25. package/dist-cjs/checkbox/CheckboxIcon.js.map +1 -1
  26. package/dist-cjs/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  27. package/dist-cjs/form-field/FormFieldLabel.css.js +1 -1
  28. package/dist-cjs/form-field/FormFieldLabel.js +8 -3
  29. package/dist-cjs/form-field/FormFieldLabel.js.map +1 -1
  30. package/dist-cjs/index.js +16 -0
  31. package/dist-cjs/index.js.map +1 -1
  32. package/dist-cjs/input/Input.js +1 -1
  33. package/dist-cjs/input/Input.js.map +1 -1
  34. package/dist-cjs/radio-button/RadioButton.css.js +1 -1
  35. package/dist-cjs/radio-button/RadioButton.js +20 -9
  36. package/dist-cjs/radio-button/RadioButton.js.map +1 -1
  37. package/dist-cjs/radio-button/RadioButtonGroup.js +4 -0
  38. package/dist-cjs/radio-button/RadioButtonGroup.js.map +1 -1
  39. package/dist-cjs/radio-button/RadioButtonIcon.css.js +1 -1
  40. package/dist-cjs/radio-button/RadioButtonIcon.js +27 -24
  41. package/dist-cjs/radio-button/RadioButtonIcon.js.map +1 -1
  42. package/dist-cjs/radio-button/internal/RadioGroupContext.js.map +1 -1
  43. package/dist-cjs/status-adornment/StatusAdornment.css.js +1 -1
  44. package/dist-cjs/toggle-button/ToggleButton.css.js +6 -0
  45. package/dist-cjs/toggle-button/ToggleButton.css.js.map +1 -0
  46. package/dist-cjs/toggle-button/ToggleButton.js +81 -0
  47. package/dist-cjs/toggle-button/ToggleButton.js.map +1 -0
  48. package/dist-cjs/toggle-button-group/ToggleButtonGroup.css.js +6 -0
  49. package/dist-cjs/toggle-button-group/ToggleButtonGroup.css.js.map +1 -0
  50. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js +117 -0
  51. package/dist-cjs/toggle-button-group/ToggleButtonGroup.js.map +1 -0
  52. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js +20 -0
  53. package/dist-cjs/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
  54. package/dist-es/accordion/Accordion.css.js +4 -0
  55. package/dist-es/accordion/Accordion.css.js.map +1 -0
  56. package/dist-es/accordion/Accordion.js +63 -0
  57. package/dist-es/accordion/Accordion.js.map +1 -0
  58. package/dist-es/accordion/AccordionContext.js +24 -0
  59. package/dist-es/accordion/AccordionContext.js.map +1 -0
  60. package/dist-es/accordion/AccordionGroup.js +23 -0
  61. package/dist-es/accordion/AccordionGroup.js.map +1 -0
  62. package/dist-es/accordion/AccordionHeader.css.js +4 -0
  63. package/dist-es/accordion/AccordionHeader.css.js.map +1 -0
  64. package/dist-es/accordion/AccordionHeader.js +50 -0
  65. package/dist-es/accordion/AccordionHeader.js.map +1 -0
  66. package/dist-es/accordion/AccordionPanel.css.js +4 -0
  67. package/dist-es/accordion/AccordionPanel.css.js.map +1 -0
  68. package/dist-es/accordion/AccordionPanel.js +45 -0
  69. package/dist-es/accordion/AccordionPanel.js.map +1 -0
  70. package/dist-es/button/Button.css.js +1 -1
  71. package/dist-es/checkbox/Checkbox.css.js +1 -1
  72. package/dist-es/checkbox/Checkbox.js +27 -17
  73. package/dist-es/checkbox/Checkbox.js.map +1 -1
  74. package/dist-es/checkbox/CheckboxGroup.js +4 -0
  75. package/dist-es/checkbox/CheckboxGroup.js.map +1 -1
  76. package/dist-es/checkbox/CheckboxIcon.css.js +1 -1
  77. package/dist-es/checkbox/CheckboxIcon.js +43 -25
  78. package/dist-es/checkbox/CheckboxIcon.js.map +1 -1
  79. package/dist-es/checkbox/internal/CheckboxGroupContext.js.map +1 -1
  80. package/dist-es/form-field/FormFieldLabel.css.js +1 -1
  81. package/dist-es/form-field/FormFieldLabel.js +8 -3
  82. package/dist-es/form-field/FormFieldLabel.js.map +1 -1
  83. package/dist-es/index.js +8 -0
  84. package/dist-es/index.js.map +1 -1
  85. package/dist-es/input/Input.js +1 -1
  86. package/dist-es/input/Input.js.map +1 -1
  87. package/dist-es/radio-button/RadioButton.css.js +1 -1
  88. package/dist-es/radio-button/RadioButton.js +20 -9
  89. package/dist-es/radio-button/RadioButton.js.map +1 -1
  90. package/dist-es/radio-button/RadioButtonGroup.js +4 -0
  91. package/dist-es/radio-button/RadioButtonGroup.js.map +1 -1
  92. package/dist-es/radio-button/RadioButtonIcon.css.js +1 -1
  93. package/dist-es/radio-button/RadioButtonIcon.js +28 -25
  94. package/dist-es/radio-button/RadioButtonIcon.js.map +1 -1
  95. package/dist-es/radio-button/internal/RadioGroupContext.js.map +1 -1
  96. package/dist-es/status-adornment/StatusAdornment.css.js +1 -1
  97. package/dist-es/toggle-button/ToggleButton.css.js +4 -0
  98. package/dist-es/toggle-button/ToggleButton.css.js.map +1 -0
  99. package/dist-es/toggle-button/ToggleButton.js +77 -0
  100. package/dist-es/toggle-button/ToggleButton.js.map +1 -0
  101. package/dist-es/toggle-button-group/ToggleButtonGroup.css.js +4 -0
  102. package/dist-es/toggle-button-group/ToggleButtonGroup.css.js.map +1 -0
  103. package/dist-es/toggle-button-group/ToggleButtonGroup.js +113 -0
  104. package/dist-es/toggle-button-group/ToggleButtonGroup.js.map +1 -0
  105. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js +15 -0
  106. package/dist-es/toggle-button-group/ToggleButtonGroupContext.js.map +1 -0
  107. package/dist-types/accordion/Accordion.d.ts +25 -0
  108. package/dist-types/accordion/AccordionContext.d.ts +10 -0
  109. package/dist-types/accordion/AccordionGroup.d.ts +3 -0
  110. package/dist-types/accordion/AccordionHeader.d.ts +3 -0
  111. package/dist-types/accordion/AccordionPanel.d.ts +3 -0
  112. package/dist-types/accordion/index.d.ts +4 -0
  113. package/dist-types/checkbox/CheckboxGroup.d.ts +4 -0
  114. package/dist-types/checkbox/CheckboxIcon.d.ts +5 -1
  115. package/dist-types/checkbox/internal/CheckboxGroupContext.d.ts +1 -0
  116. package/dist-types/form-field/FormFieldLabel.d.ts +3 -1
  117. package/dist-types/index.d.ts +4 -0
  118. package/dist-types/radio-button/RadioButton.d.ts +6 -2
  119. package/dist-types/radio-button/RadioButtonGroup.d.ts +4 -0
  120. package/dist-types/radio-button/RadioButtonIcon.d.ts +8 -4
  121. package/dist-types/radio-button/internal/RadioGroupContext.d.ts +1 -0
  122. package/dist-types/toggle-button/ToggleButton.d.ts +7 -0
  123. package/dist-types/toggle-button/index.d.ts +1 -0
  124. package/dist-types/toggle-button-group/ToggleButtonGroup.d.ts +25 -0
  125. package/dist-types/toggle-button-group/ToggleButtonGroupContext.d.ts +10 -0
  126. package/dist-types/toggle-button-group/index.d.ts +2 -0
  127. package/package.json +3 -3
  128. package/dist-cjs/checkbox/assets/CheckboxCheckedIcon.js +0 -33
  129. package/dist-cjs/checkbox/assets/CheckboxCheckedIcon.js.map +0 -1
  130. package/dist-cjs/checkbox/assets/CheckboxCheckedIconHD.js +0 -32
  131. package/dist-cjs/checkbox/assets/CheckboxCheckedIconHD.js.map +0 -1
  132. package/dist-cjs/checkbox/assets/CheckboxIndeterminateIcon.js +0 -37
  133. package/dist-cjs/checkbox/assets/CheckboxIndeterminateIcon.js.map +0 -1
  134. package/dist-cjs/checkbox/assets/CheckboxUncheckedIcon.js +0 -26
  135. package/dist-cjs/checkbox/assets/CheckboxUncheckedIcon.js.map +0 -1
  136. package/dist-es/checkbox/assets/CheckboxCheckedIcon.js +0 -29
  137. package/dist-es/checkbox/assets/CheckboxCheckedIcon.js.map +0 -1
  138. package/dist-es/checkbox/assets/CheckboxCheckedIconHD.js +0 -28
  139. package/dist-es/checkbox/assets/CheckboxCheckedIconHD.js.map +0 -1
  140. package/dist-es/checkbox/assets/CheckboxIndeterminateIcon.js +0 -33
  141. package/dist-es/checkbox/assets/CheckboxIndeterminateIcon.js.map +0 -1
  142. package/dist-es/checkbox/assets/CheckboxUncheckedIcon.js +0 -22
  143. package/dist-es/checkbox/assets/CheckboxUncheckedIcon.js.map +0 -1
  144. package/dist-types/checkbox/assets/CheckboxCheckedIcon.d.ts +0 -4
  145. package/dist-types/checkbox/assets/CheckboxCheckedIconHD.d.ts +0 -4
  146. package/dist-types/checkbox/assets/CheckboxIndeterminateIcon.d.ts +0 -4
  147. package/dist-types/checkbox/assets/CheckboxUncheckedIcon.d.ts +0 -4
  148. package/dist-types/checkbox/assets/index.d.ts +0 -4
@@ -17,9 +17,12 @@ var RadioButtonIcon$1 = require('./RadioButtonIcon.css.js');
17
17
  const withBaseName = makePrefixer.makePrefixer("saltRadioButtonIcon");
18
18
  const RadioButtonIcon = ({
19
19
  checked,
20
+ className,
20
21
  error,
21
22
  disabled,
22
- validationStatus
23
+ validationStatus,
24
+ readOnly,
25
+ ...rest
23
26
  }) => {
24
27
  const targetWindow = window.useWindow();
25
28
  styles.useComponentCssInjection({
@@ -27,30 +30,30 @@ const RadioButtonIcon = ({
27
30
  css: RadioButtonIcon$1,
28
31
  window: targetWindow
29
32
  });
30
- return /* @__PURE__ */ jsxRuntime.jsxs("svg", {
31
- className: clsx.clsx(withBaseName(), {
32
- [withBaseName("checked")]: checked,
33
- [withBaseName("error")]: error,
34
- [withBaseName("disabled")]: disabled,
35
- [withBaseName(validationStatus || "")]: validationStatus
36
- }),
37
- height: "14",
38
- viewBox: "0 0 14 14",
39
- width: "14",
40
- children: [
41
- /* @__PURE__ */ jsxRuntime.jsx("circle", {
42
- className: withBaseName("circle"),
43
- cx: "7",
44
- cy: "7",
45
- r: "6.5"
46
- }),
47
- checked && /* @__PURE__ */ jsxRuntime.jsx("circle", {
48
- className: withBaseName("checked-circle"),
49
- cx: "7",
50
- cy: "7",
51
- r: "3.2"
33
+ return /* @__PURE__ */ jsxRuntime.jsx("div", {
34
+ "aria-hidden": "true",
35
+ className: clsx.clsx(
36
+ withBaseName(),
37
+ {
38
+ [withBaseName("checked")]: checked,
39
+ [withBaseName("error")]: error,
40
+ [withBaseName("disabled")]: disabled,
41
+ [withBaseName(validationStatus || "")]: validationStatus,
42
+ [withBaseName("readOnly")]: readOnly
43
+ },
44
+ className
45
+ ),
46
+ ...rest,
47
+ children: checked && /* @__PURE__ */ jsxRuntime.jsx("svg", {
48
+ xmlns: "http://www.w3.org/2000/svg",
49
+ viewBox: "0 0 12 12",
50
+ fill: "currentColor",
51
+ children: /* @__PURE__ */ jsxRuntime.jsx("path", {
52
+ fillRule: "evenodd",
53
+ d: "M0 6a6 6 0 1 1 12 0A6 6 0 0 1 0 6Zm6 3a3 3 0 1 1 0-6 3 3 0 0 1 0 6Z",
54
+ clipRule: "evenodd"
52
55
  })
53
- ]
56
+ })
54
57
  });
55
58
  };
56
59
 
@@ -1 +1 @@
1
- {"version":3,"file":"RadioButtonIcon.js","sources":["../src/radio-button/RadioButtonIcon.tsx"],"sourcesContent":["import { makePrefixer } from \"../utils\";\nimport { clsx } from \"clsx\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { AdornmentValidationStatus } from \"../status-adornment\";\nimport radioButtonIconCss from \"./RadioButtonIcon.css\";\n\nconst withBaseName = makePrefixer(\"saltRadioButtonIcon\");\n\nexport interface RadioButtonIconProps {\n checked?: boolean;\n error?: boolean;\n disabled?: boolean;\n validationStatus?: AdornmentValidationStatus;\n}\n\n/**\n * Default radio icon\n */\nexport const RadioButtonIcon = ({\n checked,\n error,\n disabled,\n validationStatus,\n}: RadioButtonIconProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-radio-button-icon\",\n css: radioButtonIconCss,\n window: targetWindow,\n });\n return (\n <svg\n className={clsx(withBaseName(), {\n [withBaseName(\"checked\")]: checked,\n [withBaseName(\"error\")]: error,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n })}\n height=\"14\"\n viewBox=\"0 0 14 14\"\n width=\"14\"\n >\n <circle className={withBaseName(\"circle\")} cx=\"7\" cy=\"7\" r=\"6.5\" />\n {checked && (\n <circle\n className={withBaseName(\"checked-circle\")}\n cx=\"7\"\n cy=\"7\"\n r=\"3.2\"\n />\n )}\n </svg>\n );\n};\n"],"names":["makePrefixer","useWindow","useComponentCssInjection","radioButtonIconCss","jsxs","clsx","jsx"],"mappings":";;;;;;;;;;;;;;;;AAOA,MAAM,YAAA,GAAeA,0BAAa,qBAAqB,CAAA,CAAA;AAYhD,MAAM,kBAAkB,CAAC;AAAA,EAC9B,OAAA;AAAA,EACA,KAAA;AAAA,EACA,QAAA;AAAA,EACA,gBAAA;AACF,CAA4B,KAAA;AAC1B,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,iBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,uBACGC,eAAA,CAAA,KAAA,EAAA;AAAA,IACC,SAAA,EAAWC,SAAK,CAAA,YAAA,EAAgB,EAAA;AAAA,MAC9B,CAAC,YAAa,CAAA,SAAS,CAAI,GAAA,OAAA;AAAA,MAC3B,CAAC,YAAa,CAAA,OAAO,CAAI,GAAA,KAAA;AAAA,MACzB,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,MAC5B,CAAC,YAAA,CAAa,gBAAoB,IAAA,EAAE,CAAI,GAAA,gBAAA;AAAA,KACzC,CAAA;AAAA,IACD,MAAO,EAAA,IAAA;AAAA,IACP,OAAQ,EAAA,WAAA;AAAA,IACR,KAAM,EAAA,IAAA;AAAA,IAEN,QAAA,EAAA;AAAA,sBAACC,cAAA,CAAA,QAAA,EAAA;AAAA,QAAO,SAAA,EAAW,aAAa,QAAQ,CAAA;AAAA,QAAG,EAAG,EAAA,GAAA;AAAA,QAAI,EAAG,EAAA,GAAA;AAAA,QAAI,CAAE,EAAA,KAAA;AAAA,OAAM,CAAA;AAAA,MAChE,2BACEA,cAAA,CAAA,QAAA,EAAA;AAAA,QACC,SAAA,EAAW,aAAa,gBAAgB,CAAA;AAAA,QACxC,EAAG,EAAA,GAAA;AAAA,QACH,EAAG,EAAA,GAAA;AAAA,QACH,CAAE,EAAA,KAAA;AAAA,OACJ,CAAA;AAAA,KAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ;;;;"}
1
+ {"version":3,"file":"RadioButtonIcon.js","sources":["../src/radio-button/RadioButtonIcon.tsx"],"sourcesContent":["import { makePrefixer } from \"../utils\";\nimport { clsx } from \"clsx\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { AdornmentValidationStatus } from \"../status-adornment\";\nimport radioButtonIconCss from \"./RadioButtonIcon.css\";\nimport { ComponentPropsWithoutRef } from \"react\";\n\nconst withBaseName = makePrefixer(\"saltRadioButtonIcon\");\n\nexport interface RadioButtonIconProps extends ComponentPropsWithoutRef<\"div\"> {\n checked?: boolean;\n disabled?: boolean;\n /**\n * @deprecated Use validationStatus instead\n */\n error?: boolean;\n readOnly?: boolean;\n validationStatus?: AdornmentValidationStatus;\n}\n\n/**\n * Default radio icon\n */\nexport const RadioButtonIcon = ({\n checked,\n className,\n error,\n disabled,\n validationStatus,\n readOnly,\n ...rest\n}: RadioButtonIconProps) => {\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-radio-button-icon\",\n css: radioButtonIconCss,\n window: targetWindow,\n });\n return (\n <div\n aria-hidden=\"true\"\n className={clsx(\n withBaseName(),\n {\n [withBaseName(\"checked\")]: checked,\n [withBaseName(\"error\")]: error,\n [withBaseName(\"disabled\")]: disabled,\n [withBaseName(validationStatus || \"\")]: validationStatus,\n [withBaseName(\"readOnly\")]: readOnly,\n },\n className\n )}\n {...rest}\n >\n {checked && (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 12 12\"\n fill=\"currentColor\"\n >\n <path\n fillRule=\"evenodd\"\n d=\"M0 6a6 6 0 1 1 12 0A6 6 0 0 1 0 6Zm6 3a3 3 0 1 1 0-6 3 3 0 0 1 0 6Z\"\n clipRule=\"evenodd\"\n />\n </svg>\n )}\n </div>\n );\n};\n"],"names":["makePrefixer","useWindow","useComponentCssInjection","radioButtonIconCss","jsx","clsx"],"mappings":";;;;;;;;;;;;;;;;AAQA,MAAM,YAAA,GAAeA,0BAAa,qBAAqB,CAAA,CAAA;AAgBhD,MAAM,kBAAkB,CAAC;AAAA,EAC9B,OAAA;AAAA,EACA,SAAA;AAAA,EACA,KAAA;AAAA,EACA,QAAA;AAAA,EACA,gBAAA;AAAA,EACA,QAAA;AAAA,EACG,GAAA,IAAA;AACL,CAA4B,KAAA;AAC1B,EAAA,MAAM,eAAeC,gBAAU,EAAA,CAAA;AAC/B,EAAyBC,+BAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,wBAAA;AAAA,IACR,GAAK,EAAAC,iBAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AACD,EAAA,uBACGC,cAAA,CAAA,KAAA,EAAA;AAAA,IACC,aAAY,EAAA,MAAA;AAAA,IACZ,SAAW,EAAAC,SAAA;AAAA,MACT,YAAa,EAAA;AAAA,MACb;AAAA,QACE,CAAC,YAAa,CAAA,SAAS,CAAI,GAAA,OAAA;AAAA,QAC3B,CAAC,YAAa,CAAA,OAAO,CAAI,GAAA,KAAA;AAAA,QACzB,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,QAC5B,CAAC,YAAA,CAAa,gBAAoB,IAAA,EAAE,CAAI,GAAA,gBAAA;AAAA,QACxC,CAAC,YAAa,CAAA,UAAU,CAAI,GAAA,QAAA;AAAA,OAC9B;AAAA,MACA,SAAA;AAAA,KACF;AAAA,IACC,GAAG,IAAA;AAAA,IAEH,qCACED,cAAA,CAAA,KAAA,EAAA;AAAA,MACC,KAAM,EAAA,4BAAA;AAAA,MACN,OAAQ,EAAA,WAAA;AAAA,MACR,IAAK,EAAA,cAAA;AAAA,MAEL,QAAC,kBAAAA,cAAA,CAAA,MAAA,EAAA;AAAA,QACC,QAAS,EAAA,SAAA;AAAA,QACT,CAAE,EAAA,qEAAA;AAAA,QACF,QAAS,EAAA,SAAA;AAAA,OACX,CAAA;AAAA,KACF,CAAA;AAAA,GAEJ,CAAA,CAAA;AAEJ;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"RadioGroupContext.js","sources":["../src/radio-button/internal/RadioGroupContext.tsx"],"sourcesContent":["import { ChangeEventHandler } from \"react\";\nimport { a11yValueAriaProps } from \"../../form-field-context\";\nimport { AdornmentValidationStatus } from \"../../status-adornment\";\nimport { createContext } from \"../../utils\";\n\nexport interface RadioGroupContextValue {\n a11yProps?: a11yValueAriaProps;\n disabled?: boolean;\n name?: string;\n value?: string;\n onChange?: ChangeEventHandler<HTMLElement>;\n validationStatus?: AdornmentValidationStatus;\n}\n\nexport const RadioGroupContext = createContext<RadioGroupContextValue>(\n \"RadioGroupContext\",\n {}\n);\n"],"names":["createContext"],"mappings":";;;;;;;;;;;;AAcO,MAAM,iBAAoB,GAAAA,2BAAA;AAAA,EAC/B,mBAAA;AAAA,EACA,EAAC;AACH;;;;"}
1
+ {"version":3,"file":"RadioGroupContext.js","sources":["../src/radio-button/internal/RadioGroupContext.tsx"],"sourcesContent":["import { ChangeEventHandler } from \"react\";\nimport { a11yValueAriaProps } from \"../../form-field-context\";\nimport { AdornmentValidationStatus } from \"../../status-adornment\";\nimport { createContext } from \"../../utils\";\n\nexport interface RadioGroupContextValue {\n a11yProps?: a11yValueAriaProps;\n disabled?: boolean;\n name?: string;\n value?: string;\n onChange?: ChangeEventHandler<HTMLElement>;\n readOnly?: boolean;\n validationStatus?: AdornmentValidationStatus;\n}\n\nexport const RadioGroupContext = createContext<RadioGroupContextValue>(\n \"RadioGroupContext\",\n {}\n);\n"],"names":["createContext"],"mappings":";;;;;;;;;;;;AAeO,MAAM,iBAAoB,GAAAA,2BAAA;AAAA,EAC/B,mBAAA;AAAA,EACA,EAAC;AACH;;;;"}
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var css_248z = ".saltStatusAdornment {\n display: inline-block;\n fill: var(--saltStatusAdornment-color, var(--statusAdornment-color));\n height: var(--salt-icon-size-status-adornment);\n min-height: var(--salt-icon-size-status-adornment);\n padding-left: var(--salt-spacing-100);\n position: relative;\n}\n\n.saltStatusAdornment-error {\n --statusAdornment-color: var(--salt-status-error-foreground);\n}\n\n.saltStatusAdornment-warning {\n --statusAdornment-color: var(--salt-status-warning-foreground);\n}\n\n.saltStatusAdornment-success {\n --statusAdornment-color: var(--salt-status-success-foreground);\n}\n";
3
+ var css_248z = ".saltStatusAdornment {\n align-self: center;\n display: inline-block;\n fill: var(--saltStatusAdornment-color, var(--statusAdornment-color));\n height: var(--salt-icon-size-status-adornment);\n min-height: var(--salt-icon-size-status-adornment);\n padding-left: var(--salt-spacing-100);\n position: relative;\n}\n\n.saltStatusAdornment-error {\n --statusAdornment-color: var(--salt-status-error-foreground);\n}\n\n.saltStatusAdornment-warning {\n --statusAdornment-color: var(--salt-status-warning-foreground);\n}\n\n.saltStatusAdornment-success {\n --statusAdornment-color: var(--salt-status-success-foreground);\n}\n";
4
4
 
5
5
  module.exports = css_248z;
6
6
  //# sourceMappingURL=StatusAdornment.css.js.map
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltToggleButton {\n align-items: center;\n justify-content: center;\n appearance: none;\n display: inline-flex;\n background: var(--salt-actionable-secondary-background);\n border: 0 solid transparent;\n border-radius: 0;\n height: var(--salt-size-base);\n color: var(--salt-actionable-secondary-foreground);\n text-transform: var(--salt-actionable-textTransform);\n font-weight: var(--salt-actionable-secondary-fontWeight);\n font-family: var(--salt-text-fontFamily);\n text-align: var(--salt-actionable-textAlign);\n letter-spacing: var(--salt-actionable-letterSpacing);\n line-height: var(--salt-text-lineHeight);\n font-size: var(--salt-text-fontSize);\n padding-inline: var(--salt-spacing-100);\n gap: var(--salt-spacing-50);\n --saltIcon-color: var(--salt-actionable-secondary-foreground);\n}\n\n.saltToggleButton:hover {\n background: var(--salt-actionable-secondary-background-hover);\n color: var(--salt-actionable-secondary-foreground-hover);\n cursor: var(--salt-actionable-cursor-hover);\n --saltIcon-color: var(--salt-actionable-secondary-foreground-hover);\n}\n\n.saltToggleButton:focus-visible {\n outline: var(--salt-focused-outline);\n background: var(--salt-actionable-secondary-background-hover);\n color: var(--salt-actionable-secondary-foreground-hover);\n cursor: var(--salt-actionable-cursor-hover);\n --saltIcon-color: var(--salt-actionable-secondary-foreground-hover);\n}\n\n.saltToggleButton[aria-checked=\"true\"]:focus-visible {\n background: var(--salt-actionable-secondary-background-active);\n color: var(--salt-actionable-secondary-foreground-active);\n cursor: var(--salt-actionable-cursor-active);\n --saltIcon-color: var(--salt-actionable-secondary-foreground-active);\n}\n\n.saltToggleButton[aria-checked=\"true\"] {\n background: var(--salt-actionable-secondary-background-active);\n color: var(--salt-actionable-secondary-foreground-active);\n cursor: var(--salt-actionable-cursor-active);\n --saltIcon-color: var(--salt-actionable-secondary-foreground-active);\n}\n\n.saltToggleButton:disabled {\n background: var(--salt-actionable-secondary-background-disabled);\n cursor: var(--salt-actionable-cursor-disabled);\n color: var(--salt-actionable-secondary-foreground-disabled);\n --saltIcon-color: var(--salt-actionable-secondary-foreground-disabled);\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=ToggleButton.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleButton.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,81 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var clsx = require('clsx');
8
+ require('../toggle-button-group/ToggleButtonGroup.js');
9
+ var ToggleButtonGroupContext = require('../toggle-button-group/ToggleButtonGroupContext.js');
10
+ var window = require('@salt-ds/window');
11
+ var styles = require('@salt-ds/styles');
12
+ var makePrefixer = require('../utils/makePrefixer.js');
13
+ var useControlled = require('../utils/useControlled.js');
14
+ require('../utils/useFloatingUI.js');
15
+ var useForkRef = require('../utils/useForkRef.js');
16
+ require('../utils/useId.js');
17
+ require('../salt-provider/SaltProvider.js');
18
+ require('../viewport/ViewportProvider.js');
19
+ var ToggleButton$1 = require('./ToggleButton.css.js');
20
+
21
+ const withBaseName = makePrefixer.makePrefixer("saltToggleButton");
22
+ const ToggleButton = React.forwardRef(
23
+ function ToggleButton2(props, ref) {
24
+ const {
25
+ children,
26
+ className,
27
+ disabled: disabledProp,
28
+ value,
29
+ onClick,
30
+ onFocus,
31
+ onChange,
32
+ selected: selectedProp,
33
+ ...rest
34
+ } = props;
35
+ const targetWindow = window.useWindow();
36
+ styles.useComponentCssInjection({
37
+ testId: "salt-toggle-button",
38
+ css: ToggleButton$1,
39
+ window: targetWindow
40
+ });
41
+ const buttonRef = React.useRef(null);
42
+ const handleRef = useForkRef.useForkRef(ref, buttonRef);
43
+ const toggleButtonGroup = ToggleButtonGroupContext.useToggleButtonGroup();
44
+ const toggleButtonGroupSelected = toggleButtonGroup ? toggleButtonGroup.isSelected(value) : selectedProp;
45
+ const focusable = toggleButtonGroup ? toggleButtonGroup == null ? void 0 : toggleButtonGroup.isFocused(value) : true;
46
+ const disabled = (toggleButtonGroup == null ? void 0 : toggleButtonGroup.disabled) || disabledProp;
47
+ const [selected, setSelected] = useControlled.useControlled({
48
+ controlled: toggleButtonGroupSelected,
49
+ default: Boolean(selectedProp),
50
+ name: "ToggleButton",
51
+ state: "selected"
52
+ });
53
+ const handleClick = (event) => {
54
+ toggleButtonGroup == null ? void 0 : toggleButtonGroup.select(event);
55
+ setSelected(!selected);
56
+ onChange == null ? void 0 : onChange(event);
57
+ onClick == null ? void 0 : onClick(event);
58
+ };
59
+ const handleFocus = (event) => {
60
+ toggleButtonGroup == null ? void 0 : toggleButtonGroup.focus(value);
61
+ onFocus == null ? void 0 : onFocus(event);
62
+ };
63
+ const ariaChecked = selected && !disabled;
64
+ return /* @__PURE__ */ jsxRuntime.jsx("button", {
65
+ "aria-checked": ariaChecked,
66
+ className: clsx.clsx(withBaseName(), className),
67
+ disabled,
68
+ role: toggleButtonGroup ? "radio" : "checkbox",
69
+ ref: handleRef,
70
+ onClick: handleClick,
71
+ onFocus: handleFocus,
72
+ tabIndex: focusable && !disabled ? 0 : -1,
73
+ value,
74
+ ...rest,
75
+ children
76
+ });
77
+ }
78
+ );
79
+
80
+ exports.ToggleButton = ToggleButton;
81
+ //# sourceMappingURL=ToggleButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleButton.js","sources":["../src/toggle-button/ToggleButton.tsx"],"sourcesContent":["import {\n ComponentProps,\n forwardRef,\n useRef,\n MouseEvent,\n FocusEvent,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useToggleButtonGroup } from \"../toggle-button-group\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\n\nimport toggleButtonCss from \"./ToggleButton.css\";\n\nexport interface ToggleButtonProps extends ComponentProps<\"button\"> {\n selected?: boolean;\n onChange?: (event: MouseEvent<HTMLButtonElement>) => void;\n value: string | ReadonlyArray<string> | number | undefined;\n}\n\nconst withBaseName = makePrefixer(\"saltToggleButton\");\n\nexport const ToggleButton = forwardRef<HTMLButtonElement, ToggleButtonProps>(\n function ToggleButton(props, ref) {\n const {\n children,\n className,\n disabled: disabledProp,\n value,\n onClick,\n onFocus,\n onChange,\n selected: selectedProp,\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-toggle-button\",\n css: toggleButtonCss,\n window: targetWindow,\n });\n\n const buttonRef = useRef<HTMLButtonElement>(null);\n const handleRef = useForkRef(ref, buttonRef);\n\n const toggleButtonGroup = useToggleButtonGroup();\n\n const toggleButtonGroupSelected = toggleButtonGroup\n ? toggleButtonGroup.isSelected(value)\n : selectedProp;\n const focusable = toggleButtonGroup\n ? toggleButtonGroup?.isFocused(value)\n : true;\n const disabled = toggleButtonGroup?.disabled || disabledProp;\n\n const [selected, setSelected] = useControlled({\n controlled: toggleButtonGroupSelected,\n default: Boolean(selectedProp),\n name: \"ToggleButton\",\n state: \"selected\",\n });\n\n const handleClick = (event: MouseEvent<HTMLButtonElement>) => {\n toggleButtonGroup?.select(event);\n setSelected(!selected);\n onChange?.(event);\n onClick?.(event);\n };\n\n const handleFocus = (event: FocusEvent<HTMLButtonElement>) => {\n toggleButtonGroup?.focus(value);\n onFocus?.(event);\n };\n\n const ariaChecked = selected && !disabled;\n\n return (\n <button\n aria-checked={ariaChecked}\n className={clsx(withBaseName(), className)}\n disabled={disabled}\n role={toggleButtonGroup ? \"radio\" : \"checkbox\"}\n ref={handleRef}\n onClick={handleClick}\n onFocus={handleFocus}\n tabIndex={focusable && !disabled ? 0 : -1}\n value={value}\n {...rest}\n >\n {children}\n </button>\n );\n }\n);\n"],"names":["makePrefixer","forwardRef","ToggleButton","useWindow","useComponentCssInjection","toggleButtonCss","useRef","useForkRef","useToggleButtonGroup","useControlled","jsx","clsx"],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ 'use strict';
2
+
3
+ var css_248z = ".saltToggleButtonGroup {\n display: flex;\n background: var(--salt-container-primary-background);\n border: var(--salt-size-border) var(--salt-container-borderStyle) var(--salt-container-primary-borderColor);\n width: fit-content;\n gap: var(--salt-spacing-50);\n padding: calc(var(--salt-spacing-50) - var(--salt-size-border));\n flex-direction: row;\n}\n\n.saltToggleButtonGroup-horizontal .saltToggleButton {\n height: calc(var(--salt-size-base) - var(--salt-spacing-100));\n}\n\n.saltToggleButtonGroup-vertical {\n flex-direction: column;\n}\n\n.saltToggleButtonGroup-vertical .saltToggleButton {\n justify-content: start;\n}\n";
4
+
5
+ module.exports = css_248z;
6
+ //# sourceMappingURL=ToggleButtonGroup.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleButtonGroup.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
@@ -0,0 +1,117 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var jsxRuntime = require('react/jsx-runtime');
6
+ var React = require('react');
7
+ var clsx = require('clsx');
8
+ var window = require('@salt-ds/window');
9
+ var styles = require('@salt-ds/styles');
10
+ var makePrefixer = require('../utils/makePrefixer.js');
11
+ var useControlled = require('../utils/useControlled.js');
12
+ require('../utils/useFloatingUI.js');
13
+ var useForkRef = require('../utils/useForkRef.js');
14
+ require('../utils/useId.js');
15
+ require('../salt-provider/SaltProvider.js');
16
+ require('../viewport/ViewportProvider.js');
17
+ var ToggleButtonGroupContext = require('./ToggleButtonGroupContext.js');
18
+ var ToggleButtonGroup$1 = require('./ToggleButtonGroup.css.js');
19
+
20
+ const withBaseName = makePrefixer.makePrefixer("saltToggleButtonGroup");
21
+ const ToggleButtonGroup = React.forwardRef(function ToggleButtonGroup2(props, ref) {
22
+ const {
23
+ children,
24
+ className,
25
+ value: valueProp,
26
+ defaultValue,
27
+ disabled,
28
+ onChange,
29
+ onKeyDown,
30
+ orientation = "horizontal",
31
+ ...rest
32
+ } = props;
33
+ const targetWindow = window.useWindow();
34
+ styles.useComponentCssInjection({
35
+ testId: "salt-toggle-button-group",
36
+ css: ToggleButtonGroup$1,
37
+ window: targetWindow
38
+ });
39
+ const groupRef = React.useRef(null);
40
+ const handleRef = useForkRef.useForkRef(ref, groupRef);
41
+ const [value, setValue] = useControlled.useControlled({
42
+ default: defaultValue,
43
+ controlled: valueProp,
44
+ name: "ToggleButtonGroup",
45
+ state: "value"
46
+ });
47
+ const [focused, setFocused] = React.useState(value);
48
+ const select = React.useCallback(
49
+ (event) => {
50
+ const newValue = event.currentTarget.value;
51
+ setValue(newValue);
52
+ if (value !== newValue) {
53
+ onChange == null ? void 0 : onChange(event);
54
+ }
55
+ },
56
+ [onChange, value, setValue]
57
+ );
58
+ const isSelected = React.useCallback(
59
+ (id) => {
60
+ return value === id;
61
+ },
62
+ [value]
63
+ );
64
+ const focus = (id) => {
65
+ setFocused(id);
66
+ };
67
+ const isFocused = React.useCallback(
68
+ (id) => {
69
+ return focused === id || !focused;
70
+ },
71
+ [focused]
72
+ );
73
+ const contextValue = React.useMemo(
74
+ () => ({
75
+ select,
76
+ isSelected,
77
+ focus,
78
+ isFocused,
79
+ disabled
80
+ }),
81
+ [select, isSelected, isFocused, disabled]
82
+ );
83
+ const handleKeyDown = (event) => {
84
+ var _a, _b, _c, _d;
85
+ const elements = Array.from(
86
+ (_b = (_a = groupRef.current) == null ? void 0 : _a.querySelectorAll("button:not([disabled])")) != null ? _b : []
87
+ );
88
+ const currentIndex = elements.findIndex(
89
+ (element) => element === document.activeElement
90
+ );
91
+ switch (event.key) {
92
+ case "ArrowDown":
93
+ case "ArrowRight":
94
+ (_c = elements[(currentIndex + 1) % elements.length]) == null ? void 0 : _c.focus();
95
+ break;
96
+ case "ArrowUp":
97
+ case "ArrowLeft":
98
+ (_d = elements[(currentIndex - 1 + elements.length) % elements.length]) == null ? void 0 : _d.focus();
99
+ break;
100
+ }
101
+ onKeyDown == null ? void 0 : onKeyDown(event);
102
+ };
103
+ return /* @__PURE__ */ jsxRuntime.jsx(ToggleButtonGroupContext.ToggleButtonGroupContext.Provider, {
104
+ value: contextValue,
105
+ children: /* @__PURE__ */ jsxRuntime.jsx("div", {
106
+ className: clsx.clsx(withBaseName(), withBaseName(orientation), className),
107
+ role: "radiogroup",
108
+ ref: handleRef,
109
+ onKeyDown: handleKeyDown,
110
+ ...rest,
111
+ children
112
+ })
113
+ });
114
+ });
115
+
116
+ exports.ToggleButtonGroup = ToggleButtonGroup;
117
+ //# sourceMappingURL=ToggleButtonGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleButtonGroup.js","sources":["../src/toggle-button-group/ToggleButtonGroup.tsx"],"sourcesContent":["import {\n ComponentPropsWithoutRef,\n forwardRef,\n KeyboardEvent,\n SyntheticEvent,\n useCallback,\n useMemo,\n useRef,\n useState,\n} from \"react\";\nimport { clsx } from \"clsx\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { makePrefixer, useControlled, useForkRef } from \"../utils\";\nimport { ToggleButtonGroupContext } from \"./ToggleButtonGroupContext\";\nimport toggleButtonGroupCss from \"./ToggleButtonGroup.css\";\n\nexport interface ToggleButtonGroupProps\n extends Omit<ComponentPropsWithoutRef<\"div\">, \"onChange\"> {\n /**\n * The default value. Use when the component is not controlled.\n */\n defaultValue?: string | ReadonlyArray<string> | number | undefined;\n /**\n * If `true`, the Toggle Button Group will be disabled.\n */\n disabled?: boolean;\n /**\n * The value. Use when the component is controlled.\n */\n value?: string | ReadonlyArray<string> | number | undefined;\n /**\n * Callback fired when the selection changes.\n * @param event\n */\n onChange?: (event: SyntheticEvent<HTMLButtonElement>) => void;\n /**\n * The orientation of the toggle buttons.\n */\n orientation?: \"horizontal\" | \"vertical\";\n}\n\nconst withBaseName = makePrefixer(\"saltToggleButtonGroup\");\n\nexport const ToggleButtonGroup = forwardRef<\n HTMLDivElement,\n ToggleButtonGroupProps\n>(function ToggleButtonGroup(props, ref) {\n const {\n children,\n className,\n value: valueProp,\n defaultValue,\n disabled,\n onChange,\n onKeyDown,\n orientation = \"horizontal\",\n ...rest\n } = props;\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-toggle-button-group\",\n css: toggleButtonGroupCss,\n window: targetWindow,\n });\n\n const groupRef = useRef<HTMLDivElement>(null);\n const handleRef = useForkRef(ref, groupRef);\n\n const [value, setValue] = useControlled({\n default: defaultValue,\n controlled: valueProp,\n name: \"ToggleButtonGroup\",\n state: \"value\",\n });\n const [focused, setFocused] = useState<\n string | ReadonlyArray<string> | number | undefined\n >(value);\n\n const select = useCallback(\n (event: SyntheticEvent<HTMLButtonElement>) => {\n const newValue = event.currentTarget.value;\n setValue(newValue);\n if (value !== newValue) {\n onChange?.(event);\n }\n },\n [onChange, value, setValue]\n );\n\n const isSelected = useCallback(\n (id: string | ReadonlyArray<string> | number | undefined) => {\n return value === id;\n },\n [value]\n );\n\n const focus = (id: string | ReadonlyArray<string> | number | undefined) => {\n setFocused(id);\n };\n\n const isFocused = useCallback(\n (id: string | ReadonlyArray<string> | number | undefined) => {\n return focused === id || !focused;\n },\n [focused]\n );\n\n const contextValue = useMemo(\n () => ({\n select,\n isSelected,\n focus,\n isFocused,\n disabled,\n }),\n [select, isSelected, isFocused, disabled]\n );\n\n const handleKeyDown = (event: KeyboardEvent<HTMLDivElement>) => {\n const elements: HTMLElement[] = Array.from(\n groupRef.current?.querySelectorAll(\"button:not([disabled])\") ?? []\n );\n const currentIndex = elements.findIndex(\n (element) => element === document.activeElement\n );\n switch (event.key) {\n case \"ArrowDown\":\n case \"ArrowRight\":\n elements[(currentIndex + 1) % elements.length]?.focus();\n break;\n case \"ArrowUp\":\n case \"ArrowLeft\":\n elements[\n (currentIndex - 1 + elements.length) % elements.length\n ]?.focus();\n break;\n }\n\n onKeyDown?.(event);\n };\n\n return (\n <ToggleButtonGroupContext.Provider value={contextValue}>\n <div\n className={clsx(withBaseName(), withBaseName(orientation), className)}\n role=\"radiogroup\"\n ref={handleRef}\n onKeyDown={handleKeyDown}\n {...rest}\n >\n {children}\n </div>\n </ToggleButtonGroupContext.Provider>\n );\n});\n"],"names":["makePrefixer","forwardRef","ToggleButtonGroup","useWindow","useComponentCssInjection","toggleButtonGroupCss","useRef","useForkRef","useControlled","useState","useCallback","useMemo","jsx","ToggleButtonGroupContext","clsx"],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var React = require('react');
6
+ var createContext = require('../utils/createContext.js');
7
+ require('../utils/useFloatingUI.js');
8
+ require('../utils/useId.js');
9
+ require('../salt-provider/SaltProvider.js');
10
+ require('../viewport/ViewportProvider.js');
11
+ require('clsx');
12
+
13
+ const ToggleButtonGroupContext = createContext.createContext("ToggleButtonGroupContext", void 0);
14
+ function useToggleButtonGroup() {
15
+ return React.useContext(ToggleButtonGroupContext);
16
+ }
17
+
18
+ exports.ToggleButtonGroupContext = ToggleButtonGroupContext;
19
+ exports.useToggleButtonGroup = useToggleButtonGroup;
20
+ //# sourceMappingURL=ToggleButtonGroupContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ToggleButtonGroupContext.js","sources":["../src/toggle-button-group/ToggleButtonGroupContext.ts"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\nexport interface ToggleButtonGroupContextValue {\n disabled?: boolean;\n select: (event: SyntheticEvent<HTMLButtonElement>) => void;\n isSelected: (\n id: string | ReadonlyArray<string> | number | undefined\n ) => boolean;\n focus: (id: string | ReadonlyArray<string> | number | undefined) => void;\n isFocused: (\n id: string | ReadonlyArray<string> | number | undefined\n ) => boolean;\n}\n\nexport const ToggleButtonGroupContext = createContext<\n ToggleButtonGroupContextValue | undefined\n>(\"ToggleButtonGroupContext\", undefined);\n\nexport function useToggleButtonGroup() {\n return useContext(ToggleButtonGroupContext);\n}\n"],"names":["createContext","useContext"],"mappings":";;;;;;;;;;;;AAca,MAAA,wBAAA,GAA2BA,2BAEtC,CAAA,0BAAA,EAA4B,KAAS,CAAA,EAAA;AAEhC,SAAS,oBAAuB,GAAA;AACrC,EAAA,OAAOC,iBAAW,wBAAwB,CAAA,CAAA;AAC5C;;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltAccordion {\n border-bottom: var(--salt-size-border) var(--salt-separable-borderStyle) var(--salt-separable-tertiary-borderColor);\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=Accordion.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,63 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { forwardRef } from 'react';
3
+ import { clsx } from 'clsx';
4
+ import { AccordionContext } from './AccordionContext.js';
5
+ import { useWindow } from '@salt-ds/window';
6
+ import { useComponentCssInjection } from '@salt-ds/styles';
7
+ import { makePrefixer } from '../utils/makePrefixer.js';
8
+ import { useControlled } from '../utils/useControlled.js';
9
+ import '../utils/useFloatingUI.js';
10
+ import { useId } from '../utils/useId.js';
11
+ import '../salt-provider/SaltProvider.js';
12
+ import '../viewport/ViewportProvider.js';
13
+ import css_248z from './Accordion.css.js';
14
+
15
+ const withBaseName = makePrefixer("saltAccordion");
16
+ const Accordion = forwardRef(
17
+ function Accordion2(props, ref) {
18
+ const {
19
+ className,
20
+ defaultExpanded,
21
+ expanded: expandedProp,
22
+ disabled,
23
+ id: idProp,
24
+ onToggle,
25
+ value,
26
+ ...rest
27
+ } = props;
28
+ const id = useId(idProp);
29
+ const targetWindow = useWindow();
30
+ useComponentCssInjection({
31
+ testId: "salt-accordion",
32
+ css: css_248z,
33
+ window: targetWindow
34
+ });
35
+ const [expanded, setExpanded] = useControlled({
36
+ controlled: expandedProp,
37
+ default: Boolean(defaultExpanded),
38
+ name: "Accordion",
39
+ state: "expanded"
40
+ });
41
+ const toggle = (event) => {
42
+ setExpanded((prev) => !prev);
43
+ onToggle == null ? void 0 : onToggle(event);
44
+ };
45
+ return /* @__PURE__ */ jsx(AccordionContext.Provider, {
46
+ value: {
47
+ value,
48
+ toggle,
49
+ expanded,
50
+ disabled: Boolean(disabled),
51
+ id: id != null ? id : ""
52
+ },
53
+ children: /* @__PURE__ */ jsx("div", {
54
+ ref,
55
+ className: clsx(withBaseName(), className),
56
+ ...rest
57
+ })
58
+ });
59
+ }
60
+ );
61
+
62
+ export { Accordion };
63
+ //# sourceMappingURL=Accordion.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Accordion.js","sources":["../src/accordion/Accordion.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef, SyntheticEvent } from \"react\";\nimport { clsx } from \"clsx\";\nimport { AccordionContext } from \"./AccordionContext\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\nimport { makePrefixer, useControlled, useId } from \"../utils\";\nimport accordionCss from \"./Accordion.css\";\nexport interface AccordionProps extends ComponentPropsWithoutRef<\"div\"> {\n /**\n * AccordionGroup value.\n */\n value: string;\n /**\n * Whether the accordion is expanded.\n */\n expanded?: boolean;\n /**\n * Whether the accordion is expanded by default.\n */\n defaultExpanded?: boolean;\n /**\n * Callback fired when the accordion is toggled.\n * @param event\n */\n onToggle?: (event: SyntheticEvent<HTMLButtonElement>) => void;\n /**\n * Whether the accordion is disabled.\n */\n disabled?: boolean;\n}\n\nconst withBaseName = makePrefixer(\"saltAccordion\");\n\nexport const Accordion = forwardRef<HTMLDivElement, AccordionProps>(\n function Accordion(props, ref) {\n const {\n className,\n defaultExpanded,\n expanded: expandedProp,\n disabled,\n id: idProp,\n onToggle,\n value,\n ...rest\n } = props;\n\n const id = useId(idProp);\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-accordion\",\n css: accordionCss,\n window: targetWindow,\n });\n\n const [expanded, setExpanded] = useControlled({\n controlled: expandedProp,\n default: Boolean(defaultExpanded),\n name: \"Accordion\",\n state: \"expanded\",\n });\n\n const toggle = (event: SyntheticEvent<HTMLButtonElement>) => {\n setExpanded((prev) => !prev);\n onToggle?.(event);\n };\n\n return (\n <AccordionContext.Provider\n value={{\n value,\n toggle,\n expanded,\n disabled: Boolean(disabled),\n id: id ?? \"\",\n }}\n >\n <div ref={ref} className={clsx(withBaseName(), className)} {...rest} />\n </AccordionContext.Provider>\n );\n }\n);\n"],"names":["Accordion","accordionCss"],"mappings":";;;;;;;;;;;;;;AA+BA,MAAM,YAAA,GAAe,aAAa,eAAe,CAAA,CAAA;AAE1C,MAAM,SAAY,GAAA,UAAA;AAAA,EACvB,SAASA,UAAU,CAAA,KAAA,EAAO,GAAK,EAAA;AAC7B,IAAM,MAAA;AAAA,MACJ,SAAA;AAAA,MACA,eAAA;AAAA,MACA,QAAU,EAAA,YAAA;AAAA,MACV,QAAA;AAAA,MACA,EAAI,EAAA,MAAA;AAAA,MACJ,QAAA;AAAA,MACA,KAAA;AAAA,MACG,GAAA,IAAA;AAAA,KACD,GAAA,KAAA,CAAA;AAEJ,IAAM,MAAA,EAAA,GAAK,MAAM,MAAM,CAAA,CAAA;AACvB,IAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,IAAyB,wBAAA,CAAA;AAAA,MACvB,MAAQ,EAAA,gBAAA;AAAA,MACR,GAAK,EAAAC,QAAA;AAAA,MACL,MAAQ,EAAA,YAAA;AAAA,KACT,CAAA,CAAA;AAED,IAAA,MAAM,CAAC,QAAA,EAAU,WAAW,CAAA,GAAI,aAAc,CAAA;AAAA,MAC5C,UAAY,EAAA,YAAA;AAAA,MACZ,OAAA,EAAS,QAAQ,eAAe,CAAA;AAAA,MAChC,IAAM,EAAA,WAAA;AAAA,MACN,KAAO,EAAA,UAAA;AAAA,KACR,CAAA,CAAA;AAED,IAAM,MAAA,MAAA,GAAS,CAAC,KAA6C,KAAA;AAC3D,MAAY,WAAA,CAAA,CAAC,IAAS,KAAA,CAAC,IAAI,CAAA,CAAA;AAC3B,MAAW,QAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,QAAA,CAAA,KAAA,CAAA,CAAA;AAAA,KACb,CAAA;AAEA,IACE,uBAAA,GAAA,CAAC,iBAAiB,QAAjB,EAAA;AAAA,MACC,KAAO,EAAA;AAAA,QACL,KAAA;AAAA,QACA,MAAA;AAAA,QACA,QAAA;AAAA,QACA,QAAA,EAAU,QAAQ,QAAQ,CAAA;AAAA,QAC1B,IAAI,EAAM,IAAA,IAAA,GAAA,EAAA,GAAA,EAAA;AAAA,OACZ;AAAA,MAEA,QAAC,kBAAA,GAAA,CAAA,KAAA,EAAA;AAAA,QAAI,GAAA;AAAA,QAAU,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,QAAI,GAAG,IAAA;AAAA,OAAM,CAAA;AAAA,KACvE,CAAA,CAAA;AAAA,GAEJ;AACF;;;;"}
@@ -0,0 +1,24 @@
1
+ import { useContext } from 'react';
2
+ import { createContext } from '../utils/createContext.js';
3
+ import '../utils/useFloatingUI.js';
4
+ import '../utils/useId.js';
5
+ import '../salt-provider/SaltProvider.js';
6
+ import '../viewport/ViewportProvider.js';
7
+ import 'clsx';
8
+
9
+ const AccordionContext = createContext(
10
+ "AccordionContext",
11
+ {
12
+ value: "",
13
+ expanded: false,
14
+ toggle: () => void 0,
15
+ disabled: false,
16
+ id: ""
17
+ }
18
+ );
19
+ function useAccordion() {
20
+ return useContext(AccordionContext);
21
+ }
22
+
23
+ export { AccordionContext, useAccordion };
24
+ //# sourceMappingURL=AccordionContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccordionContext.js","sources":["../src/accordion/AccordionContext.ts"],"sourcesContent":["import { SyntheticEvent, useContext } from \"react\";\nimport { createContext } from \"../utils\";\n\nexport interface AccordionContextValue {\n value: string;\n expanded: boolean;\n toggle: (event: SyntheticEvent<HTMLButtonElement>) => void;\n disabled: boolean;\n id: string;\n}\n\nexport const AccordionContext = createContext<AccordionContextValue>(\n \"AccordionContext\",\n {\n value: \"\",\n expanded: false,\n toggle: () => undefined,\n disabled: false,\n id: \"\",\n }\n);\n\nexport function useAccordion() {\n return useContext(AccordionContext);\n}\n"],"names":[],"mappings":";;;;;;;;AAWO,MAAM,gBAAmB,GAAA,aAAA;AAAA,EAC9B,kBAAA;AAAA,EACA;AAAA,IACE,KAAO,EAAA,EAAA;AAAA,IACP,QAAU,EAAA,KAAA;AAAA,IACV,QAAQ,MAAM,KAAA,CAAA;AAAA,IACd,QAAU,EAAA,KAAA;AAAA,IACV,EAAI,EAAA,EAAA;AAAA,GACN;AACF,EAAA;AAEO,SAAS,YAAe,GAAA;AAC7B,EAAA,OAAO,WAAW,gBAAgB,CAAA,CAAA;AACpC;;;;"}
@@ -0,0 +1,23 @@
1
+ import { jsx } from 'react/jsx-runtime';
2
+ import { forwardRef } from 'react';
3
+ import { clsx } from 'clsx';
4
+ import { makePrefixer } from '../utils/makePrefixer.js';
5
+ import '../utils/useFloatingUI.js';
6
+ import '../utils/useId.js';
7
+ import '../salt-provider/SaltProvider.js';
8
+ import '../viewport/ViewportProvider.js';
9
+
10
+ const withBaseName = makePrefixer("saltAccordionGroup");
11
+ const AccordionGroup = forwardRef(
12
+ function AccordionGroup2(props, ref) {
13
+ const { className, ...rest } = props;
14
+ return /* @__PURE__ */ jsx("div", {
15
+ className: clsx(withBaseName(), className),
16
+ ref,
17
+ ...rest
18
+ });
19
+ }
20
+ );
21
+
22
+ export { AccordionGroup };
23
+ //# sourceMappingURL=AccordionGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccordionGroup.js","sources":["../src/accordion/AccordionGroup.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef } from \"react\";\nimport { clsx } from \"clsx\";\nimport { makePrefixer } from \"../utils\";\n\nexport type AccordionGroupProps = ComponentPropsWithoutRef<\"div\">;\n\nconst withBaseName = makePrefixer(\"saltAccordionGroup\");\n\nexport const AccordionGroup = forwardRef<HTMLDivElement, AccordionGroupProps>(\n function AccordionGroup(props, ref) {\n const { className, ...rest } = props;\n\n return (\n <div className={clsx(withBaseName(), className)} ref={ref} {...rest} />\n );\n }\n);\n"],"names":["AccordionGroup"],"mappings":";;;;;;;;;AAMA,MAAM,YAAA,GAAe,aAAa,oBAAoB,CAAA,CAAA;AAE/C,MAAM,cAAiB,GAAA,UAAA;AAAA,EAC5B,SAASA,eAAe,CAAA,KAAA,EAAO,GAAK,EAAA;AAClC,IAAM,MAAA,EAAE,SAAc,EAAA,GAAA,IAAA,EAAS,GAAA,KAAA,CAAA;AAE/B,IAAA,uBACG,GAAA,CAAA,KAAA,EAAA;AAAA,MAAI,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,MAAG,GAAA;AAAA,MAAW,GAAG,IAAA;AAAA,KAAM,CAAA,CAAA;AAAA,GAEzE;AACF;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltAccordionHeader {\n display: flex;\n gap: var(--salt-spacing-100);\n padding-block: var(--salt-spacing-50);\n padding-inline: var(--salt-spacing-100);\n align-items: center;\n border: 0;\n width: 100%;\n min-height: var(--salt-size-base);\n background: var(--salt-actionable-secondary-background);\n font-size: var(--salt-text-fontSize);\n line-height: var(--salt-text-lineHeight);\n font-family: var(--salt-text-fontFamily);\n color: var(--salt-text-primary-foreground);\n --saltIcon-color: var(--salt-text-primary-foreground);\n text-align: left;\n}\n\n.saltAccordionHeader:focus-visible {\n background: var(--salt-actionable-primary-background-hover);\n outline: var(--salt-focused-outline);\n}\n\n@media (hover: hover) and (pointer: fine) {\n .saltAccordionHeader:hover {\n background: var(--salt-actionable-primary-background-hover);\n }\n}\n\n.saltAccordionHeader:disabled {\n background: var(--salt-actionable-secondary-background);\n color: var(--salt-text-primary-foreground-disabled);\n --saltIcon-fill: var(--salt-text-primary-foreground-disabled);\n}\n\n.saltAccordionHeader-icon {\n transition: transform var(--salt-duration-instant) cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n.saltAccordionHeader[aria-expanded=\"true\"] > .saltAccordionHeader-icon {\n transform: rotate(90deg);\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=AccordionHeader.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccordionHeader.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
@@ -0,0 +1,50 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { forwardRef } from 'react';
3
+ import { clsx } from 'clsx';
4
+ import { ChevronRightIcon } from '@salt-ds/icons';
5
+ import { useWindow } from '@salt-ds/window';
6
+ import { useComponentCssInjection } from '@salt-ds/styles';
7
+ import { makePrefixer } from '../utils/makePrefixer.js';
8
+ import '../utils/useFloatingUI.js';
9
+ import '../utils/useId.js';
10
+ import '../salt-provider/SaltProvider.js';
11
+ import '../viewport/ViewportProvider.js';
12
+ import { useAccordion } from './AccordionContext.js';
13
+ import css_248z from './AccordionHeader.css.js';
14
+
15
+ const withBaseName = makePrefixer("saltAccordionHeader");
16
+ const AccordionHeader = forwardRef(function AccordionHeader2(props, ref) {
17
+ const { children, className, onClick, ...rest } = props;
18
+ const { value, expanded, toggle, disabled, id } = useAccordion();
19
+ const targetWindow = useWindow();
20
+ useComponentCssInjection({
21
+ testId: "salt-accordion-header",
22
+ css: css_248z,
23
+ window: targetWindow
24
+ });
25
+ const handleClick = (event) => {
26
+ toggle(event);
27
+ onClick == null ? void 0 : onClick(event);
28
+ };
29
+ return /* @__PURE__ */ jsxs("button", {
30
+ ref,
31
+ className: clsx(withBaseName(), className),
32
+ disabled,
33
+ onClick: handleClick,
34
+ "aria-expanded": expanded,
35
+ id: `${id}-header`,
36
+ "aria-controls": `${id}-panel`,
37
+ value,
38
+ ...rest,
39
+ children: [
40
+ /* @__PURE__ */ jsx(ChevronRightIcon, {
41
+ "aria-hidden": "true",
42
+ className: withBaseName("icon")
43
+ }),
44
+ children
45
+ ]
46
+ });
47
+ });
48
+
49
+ export { AccordionHeader };
50
+ //# sourceMappingURL=AccordionHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccordionHeader.js","sources":["../src/accordion/AccordionHeader.tsx"],"sourcesContent":["import { ComponentPropsWithoutRef, forwardRef, MouseEvent } from \"react\";\nimport { clsx } from \"clsx\";\nimport { ChevronRightIcon } from \"@salt-ds/icons\";\nimport { useWindow } from \"@salt-ds/window\";\nimport { useComponentCssInjection } from \"@salt-ds/styles\";\n\nimport { makePrefixer } from \"../utils\";\n\nimport { useAccordion } from \"./AccordionContext\";\nimport accordionHeaderCss from \"./AccordionHeader.css\";\n\nexport type AccordionHeaderProps = ComponentPropsWithoutRef<\"button\">;\n\nconst withBaseName = makePrefixer(\"saltAccordionHeader\");\n\nexport const AccordionHeader = forwardRef<\n HTMLButtonElement,\n AccordionHeaderProps\n>(function AccordionHeader(props, ref) {\n const { children, className, onClick, ...rest } = props;\n const { value, expanded, toggle, disabled, id } = useAccordion();\n\n const targetWindow = useWindow();\n useComponentCssInjection({\n testId: \"salt-accordion-header\",\n css: accordionHeaderCss,\n window: targetWindow,\n });\n\n const handleClick = (event: MouseEvent<HTMLButtonElement>) => {\n toggle(event);\n onClick?.(event);\n };\n\n return (\n <button\n ref={ref}\n className={clsx(withBaseName(), className)}\n disabled={disabled}\n onClick={handleClick}\n aria-expanded={expanded}\n id={`${id}-header`}\n aria-controls={`${id}-panel`}\n value={value}\n {...rest}\n >\n <ChevronRightIcon aria-hidden=\"true\" className={withBaseName(\"icon\")} />\n {children}\n </button>\n );\n});\n"],"names":["AccordionHeader","accordionHeaderCss"],"mappings":";;;;;;;;;;;;;;AAaA,MAAM,YAAA,GAAe,aAAa,qBAAqB,CAAA,CAAA;AAEhD,MAAM,eAAkB,GAAA,UAAA,CAG7B,SAASA,gBAAAA,CAAgB,OAAO,GAAK,EAAA;AACrC,EAAA,MAAM,EAAE,QAAA,EAAU,SAAW,EAAA,OAAA,EAAA,GAAY,MAAS,GAAA,KAAA,CAAA;AAClD,EAAA,MAAM,EAAE,KAAO,EAAA,QAAA,EAAU,QAAQ,QAAU,EAAA,EAAA,KAAO,YAAa,EAAA,CAAA;AAE/D,EAAA,MAAM,eAAe,SAAU,EAAA,CAAA;AAC/B,EAAyB,wBAAA,CAAA;AAAA,IACvB,MAAQ,EAAA,uBAAA;AAAA,IACR,GAAK,EAAAC,QAAA;AAAA,IACL,MAAQ,EAAA,YAAA;AAAA,GACT,CAAA,CAAA;AAED,EAAM,MAAA,WAAA,GAAc,CAAC,KAAyC,KAAA;AAC5D,IAAA,MAAA,CAAO,KAAK,CAAA,CAAA;AACZ,IAAU,OAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,OAAA,CAAA,KAAA,CAAA,CAAA;AAAA,GACZ,CAAA;AAEA,EAAA,uBACG,IAAA,CAAA,QAAA,EAAA;AAAA,IACC,GAAA;AAAA,IACA,SAAW,EAAA,IAAA,CAAK,YAAa,EAAA,EAAG,SAAS,CAAA;AAAA,IACzC,QAAA;AAAA,IACA,OAAS,EAAA,WAAA;AAAA,IACT,eAAe,EAAA,QAAA;AAAA,IACf,IAAI,CAAG,EAAA,EAAA,CAAA,OAAA,CAAA;AAAA,IACP,iBAAe,CAAG,EAAA,EAAA,CAAA,MAAA,CAAA;AAAA,IAClB,KAAA;AAAA,IACC,GAAG,IAAA;AAAA,IAEJ,QAAA,EAAA;AAAA,sBAAC,GAAA,CAAA,gBAAA,EAAA;AAAA,QAAiB,aAAY,EAAA,MAAA;AAAA,QAAO,SAAA,EAAW,aAAa,MAAM,CAAA;AAAA,OAAG,CAAA;AAAA,MACrE,QAAA;AAAA,KAAA;AAAA,GACH,CAAA,CAAA;AAEJ,CAAC;;;;"}
@@ -0,0 +1,4 @@
1
+ var css_248z = ".saltAccordionPanel {\n display: grid;\n grid-template-rows: 0fr;\n transition: grid-template-rows var(--salt-duration-perceptible) cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n.saltAccordionHeader[aria-expanded=\"true\"] + .saltAccordionPanel {\n grid-template-rows: 1fr;\n}\n\n.saltAccordionPanel-inner {\n overflow: hidden;\n}\n\n.saltAccordionPanel-content {\n padding: var(--salt-spacing-200);\n padding-left: calc(var(--salt-spacing-200) + var(--salt-size-icon));\n}\n";
2
+
3
+ export { css_248z as default };
4
+ //# sourceMappingURL=AccordionPanel.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccordionPanel.css.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}