@protonradio/proton-ui 0.11.10 → 0.11.11

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 (487) hide show
  1. package/README.md +148 -148
  2. package/dist/_virtual/jsx-runtime.cjs.js +2 -0
  3. package/dist/_virtual/jsx-runtime.cjs.js.map +1 -0
  4. package/dist/_virtual/jsx-runtime.es.js +5 -0
  5. package/dist/_virtual/jsx-runtime.es.js.map +1 -0
  6. package/dist/_virtual/react-jsx-runtime.development.cjs.js +2 -0
  7. package/dist/_virtual/react-jsx-runtime.development.cjs.js.map +1 -0
  8. package/dist/_virtual/react-jsx-runtime.development.es.js +5 -0
  9. package/dist/_virtual/react-jsx-runtime.development.es.js.map +1 -0
  10. package/dist/_virtual/react-jsx-runtime.production.min.cjs.js +2 -0
  11. package/dist/_virtual/react-jsx-runtime.production.min.cjs.js.map +1 -0
  12. package/dist/_virtual/react-jsx-runtime.production.min.es.js +5 -0
  13. package/dist/_virtual/react-jsx-runtime.production.min.es.js.map +1 -0
  14. package/dist/assets/svg/icons.svg.cjs.js +2 -0
  15. package/dist/assets/svg/icons.svg.cjs.js.map +1 -0
  16. package/dist/assets/svg/icons.svg.es.js +5 -0
  17. package/dist/assets/svg/icons.svg.es.js.map +1 -0
  18. package/dist/components/ActionMenu/ActionMenu.cjs.js +2 -0
  19. package/dist/components/ActionMenu/ActionMenu.cjs.js.map +1 -0
  20. package/dist/components/ActionMenu/ActionMenu.es.js +277 -0
  21. package/dist/components/ActionMenu/ActionMenu.es.js.map +1 -0
  22. package/dist/components/Badge/Badge.cjs.js +2 -0
  23. package/dist/components/Badge/Badge.cjs.js.map +1 -0
  24. package/dist/components/Badge/Badge.es.js +25 -0
  25. package/dist/components/Badge/Badge.es.js.map +1 -0
  26. package/dist/components/Banner/Banner.cjs.js +2 -0
  27. package/dist/components/Banner/Banner.cjs.js.map +1 -0
  28. package/dist/components/Banner/Banner.es.js +131 -0
  29. package/dist/components/Banner/Banner.es.js.map +1 -0
  30. package/dist/components/Button/Button.cjs.js +2 -0
  31. package/dist/components/Button/Button.cjs.js.map +1 -0
  32. package/dist/components/Button/Button.es.js +99 -0
  33. package/dist/components/Button/Button.es.js.map +1 -0
  34. package/dist/components/ButtonGroup/ButtonGroup.cjs.js +2 -0
  35. package/dist/components/ButtonGroup/ButtonGroup.cjs.js.map +1 -0
  36. package/dist/components/ButtonGroup/ButtonGroup.es.js +51 -0
  37. package/dist/components/ButtonGroup/ButtonGroup.es.js.map +1 -0
  38. package/dist/components/ButtonWithSelect/ButtonWithSelect.cjs.js +2 -0
  39. package/dist/components/ButtonWithSelect/ButtonWithSelect.cjs.js.map +1 -0
  40. package/dist/components/ButtonWithSelect/ButtonWithSelect.es.js +80 -0
  41. package/dist/components/ButtonWithSelect/ButtonWithSelect.es.js.map +1 -0
  42. package/dist/components/DataTable/DataTable.cjs.js +2 -0
  43. package/dist/components/DataTable/DataTable.cjs.js.map +1 -0
  44. package/dist/components/DataTable/DataTable.es.js +137 -0
  45. package/dist/components/DataTable/DataTable.es.js.map +1 -0
  46. package/dist/components/Dialog/Dialog.cjs.js +2 -0
  47. package/dist/components/Dialog/Dialog.cjs.js.map +1 -0
  48. package/dist/components/Dialog/Dialog.es.js +15 -0
  49. package/dist/components/Dialog/Dialog.es.js.map +1 -0
  50. package/dist/components/Elevation/Elevation.cjs.js +2 -0
  51. package/dist/components/Elevation/Elevation.cjs.js.map +1 -0
  52. package/dist/components/Elevation/Elevation.es.js +33 -0
  53. package/dist/components/Elevation/Elevation.es.js.map +1 -0
  54. package/dist/components/Icon/Icon.cjs.js +2 -0
  55. package/dist/components/Icon/Icon.cjs.js.map +1 -0
  56. package/dist/components/Icon/Icon.es.js +42 -0
  57. package/dist/components/Icon/Icon.es.js.map +1 -0
  58. package/dist/components/ImageBackground/ImageBackground.cjs.js +2 -0
  59. package/dist/components/ImageBackground/ImageBackground.cjs.js.map +1 -0
  60. package/dist/components/ImageBackground/ImageBackground.es.js +55 -0
  61. package/dist/components/ImageBackground/ImageBackground.es.js.map +1 -0
  62. package/dist/components/Input/BaseInput/Input.cjs.js +2 -0
  63. package/dist/components/Input/BaseInput/Input.cjs.js.map +1 -0
  64. package/dist/components/Input/BaseInput/Input.es.js +186 -0
  65. package/dist/components/Input/BaseInput/Input.es.js.map +1 -0
  66. package/dist/components/Input/CopyInput/CopyInput.cjs.js +2 -0
  67. package/dist/components/Input/CopyInput/CopyInput.cjs.js.map +1 -0
  68. package/dist/components/Input/CopyInput/CopyInput.es.js +83 -0
  69. package/dist/components/Input/CopyInput/CopyInput.es.js.map +1 -0
  70. package/dist/components/Input/SearchInput/SearchInput.cjs.js +2 -0
  71. package/dist/components/Input/SearchInput/SearchInput.cjs.js.map +1 -0
  72. package/dist/components/Input/SearchInput/SearchInput.es.js +118 -0
  73. package/dist/components/Input/SearchInput/SearchInput.es.js.map +1 -0
  74. package/dist/components/Menu/MenuTrigger.cjs.js +2 -0
  75. package/dist/components/Menu/MenuTrigger.cjs.js.map +1 -0
  76. package/dist/components/Menu/MenuTrigger.es.js +89 -0
  77. package/dist/components/Menu/MenuTrigger.es.js.map +1 -0
  78. package/dist/components/Menu/PopoverMenu.cjs.js +2 -0
  79. package/dist/components/Menu/PopoverMenu.cjs.js.map +1 -0
  80. package/dist/components/Menu/PopoverMenu.es.js +122 -0
  81. package/dist/components/Menu/PopoverMenu.es.js.map +1 -0
  82. package/dist/components/Modal/Modal.cjs.js +2 -0
  83. package/dist/components/Modal/Modal.cjs.js.map +1 -0
  84. package/dist/components/Modal/Modal.es.js +122 -0
  85. package/dist/components/Modal/Modal.es.js.map +1 -0
  86. package/dist/components/Popover/Popover.cjs.js +2 -0
  87. package/dist/components/Popover/Popover.cjs.js.map +1 -0
  88. package/dist/components/Popover/Popover.es.js +54 -0
  89. package/dist/components/Popover/Popover.es.js.map +1 -0
  90. package/dist/components/ScreenOverlay/ScreenOverlay.cjs.js +2 -0
  91. package/dist/components/ScreenOverlay/ScreenOverlay.cjs.js.map +1 -0
  92. package/dist/components/ScreenOverlay/ScreenOverlay.es.js +44 -0
  93. package/dist/components/ScreenOverlay/ScreenOverlay.es.js.map +1 -0
  94. package/dist/components/Select/Select.cjs.js +2 -0
  95. package/dist/components/Select/Select.cjs.js.map +1 -0
  96. package/dist/components/Select/Select.es.js +228 -0
  97. package/dist/components/Select/Select.es.js.map +1 -0
  98. package/dist/components/Switch/Switch.cjs.js +2 -0
  99. package/dist/components/Switch/Switch.cjs.js.map +1 -0
  100. package/dist/components/Switch/Switch.es.js +40 -0
  101. package/dist/components/Switch/Switch.es.js.map +1 -0
  102. package/dist/components/Table/Collection/CompoundComponents.cjs.js +2 -0
  103. package/dist/components/Table/Collection/CompoundComponents.cjs.js.map +1 -0
  104. package/dist/components/Table/Collection/CompoundComponents.es.js +9 -0
  105. package/dist/components/Table/Collection/CompoundComponents.es.js.map +1 -0
  106. package/dist/components/Table/Collection/collectionParser.cjs.js +2 -0
  107. package/dist/components/Table/Collection/collectionParser.cjs.js.map +1 -0
  108. package/dist/components/Table/Collection/collectionParser.es.js +54 -0
  109. package/dist/components/Table/Collection/collectionParser.es.js.map +1 -0
  110. package/dist/components/Table/Collection/useTableCollection.cjs.js +2 -0
  111. package/dist/components/Table/Collection/useTableCollection.cjs.js.map +1 -0
  112. package/dist/components/Table/Collection/useTableCollection.es.js +59 -0
  113. package/dist/components/Table/Collection/useTableCollection.es.js.map +1 -0
  114. package/dist/components/Table/Table.cjs.js +2 -0
  115. package/dist/components/Table/Table.cjs.js.map +1 -0
  116. package/dist/components/Table/Table.es.js +89 -0
  117. package/dist/components/Table/Table.es.js.map +1 -0
  118. package/dist/components/Text/TextEllipsis/TextEllipsis.cjs.js +2 -0
  119. package/dist/components/Text/TextEllipsis/TextEllipsis.cjs.js.map +1 -0
  120. package/dist/components/Text/TextEllipsis/TextEllipsis.es.js +30 -0
  121. package/dist/components/Text/TextEllipsis/TextEllipsis.es.js.map +1 -0
  122. package/dist/components/Text/TextEmphasis/TextEmphasis.cjs.js +2 -0
  123. package/dist/components/Text/TextEmphasis/TextEmphasis.cjs.js.map +1 -0
  124. package/dist/components/Text/TextEmphasis/TextEmphasis.es.js +54 -0
  125. package/dist/components/Text/TextEmphasis/TextEmphasis.es.js.map +1 -0
  126. package/dist/components/ThemeProvider.cjs.js +2 -0
  127. package/dist/components/ThemeProvider.cjs.js.map +1 -0
  128. package/dist/components/ThemeProvider.es.js +42 -0
  129. package/dist/components/ThemeProvider.es.js.map +1 -0
  130. package/dist/components/Tombstone/Tombstone.cjs.js +2 -0
  131. package/dist/components/Tombstone/Tombstone.cjs.js.map +1 -0
  132. package/dist/components/Tombstone/Tombstone.es.js +35 -0
  133. package/dist/components/Tombstone/Tombstone.es.js.map +1 -0
  134. package/dist/components/Tooltip/Tooltip.cjs.js +2 -0
  135. package/dist/components/Tooltip/Tooltip.cjs.js.map +1 -0
  136. package/dist/components/Tooltip/Tooltip.es.js +78 -0
  137. package/dist/components/Tooltip/Tooltip.es.js.map +1 -0
  138. package/dist/components/Waveform/Waveform.cjs.js +2 -0
  139. package/dist/components/Waveform/Waveform.cjs.js.map +1 -0
  140. package/dist/components/Waveform/Waveform.es.js +163 -0
  141. package/dist/components/Waveform/Waveform.es.js.map +1 -0
  142. package/dist/components/Waveform/WaveformBar.cjs.js +2 -0
  143. package/dist/components/Waveform/WaveformBar.cjs.js.map +1 -0
  144. package/dist/components/Waveform/WaveformBar.es.js +74 -0
  145. package/dist/components/Waveform/WaveformBar.es.js.map +1 -0
  146. package/dist/constants/breakpoint.cjs.js +2 -0
  147. package/dist/constants/breakpoint.cjs.js.map +1 -0
  148. package/dist/{breakpoint-9y1_8U_b.mjs → constants/breakpoint.es.js} +2 -2
  149. package/dist/constants/breakpoint.es.js.map +1 -0
  150. package/dist/constants/placement.cjs.js +2 -0
  151. package/dist/constants/placement.cjs.js.map +1 -0
  152. package/dist/constants/placement.es.js +28 -0
  153. package/dist/constants/placement.es.js.map +1 -0
  154. package/dist/constants.cjs.js +1 -1
  155. package/dist/constants.cjs.js.map +1 -1
  156. package/dist/constants.es.js +3 -26
  157. package/dist/constants.es.js.map +1 -1
  158. package/dist/dark.cjs.js +1 -1
  159. package/dist/dark.cjs.js.map +1 -1
  160. package/dist/dark.es.js +8 -55
  161. package/dist/dark.es.js.map +1 -1
  162. package/dist/design/colors.cjs.js +2 -0
  163. package/dist/design/colors.cjs.js.map +1 -0
  164. package/dist/{colors-CWaj9dFz.mjs → design/colors.es.js} +7 -7
  165. package/dist/design/colors.es.js.map +1 -0
  166. package/dist/design/darkTheme/colors.cjs.js +2 -0
  167. package/dist/design/darkTheme/colors.cjs.js.map +1 -0
  168. package/dist/{colors-Ceyo4oCJ.mjs → design/darkTheme/colors.es.js} +13 -13
  169. package/dist/design/darkTheme/colors.es.js.map +1 -0
  170. package/dist/design/darkTheme/stylesheet.cjs.js +2 -0
  171. package/dist/design/darkTheme/stylesheet.cjs.js.map +1 -0
  172. package/dist/design/darkTheme/stylesheet.es.js +52 -0
  173. package/dist/design/darkTheme/stylesheet.es.js.map +1 -0
  174. package/dist/design/generateStylesheet.cjs.js +2 -0
  175. package/dist/design/generateStylesheet.cjs.js.map +1 -0
  176. package/dist/design/generateStylesheet.es.js +26 -0
  177. package/dist/design/generateStylesheet.es.js.map +1 -0
  178. package/dist/design/lightTheme/colors.cjs.js +2 -0
  179. package/dist/design/lightTheme/colors.cjs.js.map +1 -0
  180. package/dist/{colors-DMkDnu4U.mjs → design/lightTheme/colors.es.js} +11 -11
  181. package/dist/design/lightTheme/colors.es.js.map +1 -0
  182. package/dist/design/lightTheme/stylesheet.cjs.js +2 -0
  183. package/dist/design/lightTheme/stylesheet.cjs.js.map +1 -0
  184. package/dist/design/lightTheme/stylesheet.es.js +52 -0
  185. package/dist/design/lightTheme/stylesheet.es.js.map +1 -0
  186. package/dist/design/theme.cjs.js +2 -0
  187. package/dist/design/theme.cjs.js.map +1 -0
  188. package/dist/design/theme.es.js +12 -0
  189. package/dist/design/theme.es.js.map +1 -0
  190. package/dist/hooks/useBreakpoint.cjs.js +2 -0
  191. package/dist/hooks/useBreakpoint.cjs.js.map +1 -0
  192. package/dist/hooks/useBreakpoint.es.js +17 -0
  193. package/dist/hooks/useBreakpoint.es.js.map +1 -0
  194. package/dist/hooks/useIsClosing.cjs.js +2 -0
  195. package/dist/hooks/useIsClosing.cjs.js.map +1 -0
  196. package/dist/hooks/useIsClosing.es.js +30 -0
  197. package/dist/hooks/useIsClosing.es.js.map +1 -0
  198. package/dist/hooks/useLockBodyScroll.cjs.js +2 -0
  199. package/dist/hooks/useLockBodyScroll.cjs.js.map +1 -0
  200. package/dist/hooks/useLockBodyScroll.es.js +14 -0
  201. package/dist/hooks/useLockBodyScroll.es.js.map +1 -0
  202. package/dist/hooks/usePalette.cjs.js +2 -0
  203. package/dist/hooks/usePalette.cjs.js.map +1 -0
  204. package/dist/hooks/usePalette.es.js +37 -0
  205. package/dist/hooks/usePalette.es.js.map +1 -0
  206. package/dist/hooks.cjs.js +1 -1
  207. package/dist/hooks.cjs.js.map +1 -1
  208. package/dist/hooks.es.js +8 -37
  209. package/dist/hooks.es.js.map +1 -1
  210. package/dist/icons.svg +10 -10
  211. package/dist/index.cjs.js +1 -36
  212. package/dist/index.cjs.js.map +1 -1
  213. package/dist/index.d.ts +0 -1
  214. package/dist/index.es.js +60 -5421
  215. package/dist/index.es.js.map +1 -1
  216. package/dist/light.cjs.js +1 -1
  217. package/dist/light.cjs.js.map +1 -1
  218. package/dist/light.es.js +8 -55
  219. package/dist/light.es.js.map +1 -1
  220. package/dist/node_modules/@react-aria/button/dist/useButton.cjs.js +2 -0
  221. package/dist/node_modules/@react-aria/button/dist/useButton.cjs.js.map +1 -0
  222. package/dist/node_modules/@react-aria/button/dist/useButton.es.js +55 -0
  223. package/dist/node_modules/@react-aria/button/dist/useButton.es.js.map +1 -0
  224. package/dist/node_modules/@react-aria/dialog/dist/useDialog.cjs.js +2 -0
  225. package/dist/node_modules/@react-aria/dialog/dist/useDialog.cjs.js.map +1 -0
  226. package/dist/node_modules/@react-aria/dialog/dist/useDialog.es.js +44 -0
  227. package/dist/node_modules/@react-aria/dialog/dist/useDialog.es.js.map +1 -0
  228. package/dist/node_modules/@react-aria/focus/dist/FocusScope.cjs.js +2 -0
  229. package/dist/node_modules/@react-aria/focus/dist/FocusScope.cjs.js.map +1 -0
  230. package/dist/node_modules/@react-aria/focus/dist/FocusScope.es.js +437 -0
  231. package/dist/node_modules/@react-aria/focus/dist/FocusScope.es.js.map +1 -0
  232. package/dist/node_modules/@react-aria/form/dist/useFormValidation.cjs.js +2 -0
  233. package/dist/node_modules/@react-aria/form/dist/useFormValidation.cjs.js.map +1 -0
  234. package/dist/node_modules/@react-aria/form/dist/useFormValidation.es.js +78 -0
  235. package/dist/node_modules/@react-aria/form/dist/useFormValidation.es.js.map +1 -0
  236. package/dist/node_modules/@react-aria/i18n/dist/context.cjs.js +2 -0
  237. package/dist/node_modules/@react-aria/i18n/dist/context.cjs.js.map +1 -0
  238. package/dist/node_modules/@react-aria/i18n/dist/context.es.js +11 -0
  239. package/dist/node_modules/@react-aria/i18n/dist/context.es.js.map +1 -0
  240. package/dist/node_modules/@react-aria/i18n/dist/useDefaultLocale.cjs.js +2 -0
  241. package/dist/node_modules/@react-aria/i18n/dist/useDefaultLocale.cjs.js.map +1 -0
  242. package/dist/node_modules/@react-aria/i18n/dist/useDefaultLocale.es.js +30 -0
  243. package/dist/node_modules/@react-aria/i18n/dist/useDefaultLocale.es.js.map +1 -0
  244. package/dist/node_modules/@react-aria/i18n/dist/utils.cjs.js +2 -0
  245. package/dist/node_modules/@react-aria/i18n/dist/utils.cjs.js.map +1 -0
  246. package/dist/node_modules/@react-aria/i18n/dist/utils.es.js +45 -0
  247. package/dist/node_modules/@react-aria/i18n/dist/utils.es.js.map +1 -0
  248. package/dist/node_modules/@react-aria/interactions/dist/context.cjs.js +2 -0
  249. package/dist/node_modules/@react-aria/interactions/dist/context.cjs.js.map +1 -0
  250. package/dist/node_modules/@react-aria/interactions/dist/context.es.js +10 -0
  251. package/dist/node_modules/@react-aria/interactions/dist/context.es.js.map +1 -0
  252. package/dist/node_modules/@react-aria/interactions/dist/createEventHandler.cjs.js +2 -0
  253. package/dist/node_modules/@react-aria/interactions/dist/createEventHandler.cjs.js.map +1 -0
  254. package/dist/node_modules/@react-aria/interactions/dist/createEventHandler.es.js +29 -0
  255. package/dist/node_modules/@react-aria/interactions/dist/createEventHandler.es.js.map +1 -0
  256. package/dist/node_modules/@react-aria/interactions/dist/focusSafely.cjs.js +2 -0
  257. package/dist/node_modules/@react-aria/interactions/dist/focusSafely.cjs.js.map +1 -0
  258. package/dist/node_modules/@react-aria/interactions/dist/focusSafely.es.js +15 -0
  259. package/dist/node_modules/@react-aria/interactions/dist/focusSafely.es.js.map +1 -0
  260. package/dist/node_modules/@react-aria/interactions/dist/textSelection.cjs.js +2 -0
  261. package/dist/node_modules/@react-aria/interactions/dist/textSelection.cjs.js.map +1 -0
  262. package/dist/node_modules/@react-aria/interactions/dist/textSelection.es.js +35 -0
  263. package/dist/node_modules/@react-aria/interactions/dist/textSelection.es.js.map +1 -0
  264. package/dist/node_modules/@react-aria/interactions/dist/useFocus.cjs.js +2 -0
  265. package/dist/node_modules/@react-aria/interactions/dist/useFocus.cjs.js.map +1 -0
  266. package/dist/node_modules/@react-aria/interactions/dist/useFocus.es.js +30 -0
  267. package/dist/node_modules/@react-aria/interactions/dist/useFocus.es.js.map +1 -0
  268. package/dist/node_modules/@react-aria/interactions/dist/useFocusVisible.cjs.js +2 -0
  269. package/dist/node_modules/@react-aria/interactions/dist/useFocusVisible.cjs.js.map +1 -0
  270. package/dist/node_modules/@react-aria/interactions/dist/useFocusVisible.es.js +63 -0
  271. package/dist/node_modules/@react-aria/interactions/dist/useFocusVisible.es.js.map +1 -0
  272. package/dist/node_modules/@react-aria/interactions/dist/useFocusWithin.cjs.js +2 -0
  273. package/dist/node_modules/@react-aria/interactions/dist/useFocusWithin.cjs.js.map +1 -0
  274. package/dist/node_modules/@react-aria/interactions/dist/useFocusWithin.es.js +56 -0
  275. package/dist/node_modules/@react-aria/interactions/dist/useFocusWithin.es.js.map +1 -0
  276. package/dist/node_modules/@react-aria/interactions/dist/useFocusable.cjs.js +2 -0
  277. package/dist/node_modules/@react-aria/interactions/dist/useFocusable.cjs.js.map +1 -0
  278. package/dist/node_modules/@react-aria/interactions/dist/useFocusable.es.js +42 -0
  279. package/dist/node_modules/@react-aria/interactions/dist/useFocusable.es.js.map +1 -0
  280. package/dist/node_modules/@react-aria/interactions/dist/useInteractOutside.cjs.js +2 -0
  281. package/dist/node_modules/@react-aria/interactions/dist/useInteractOutside.cjs.js.map +1 -0
  282. package/dist/node_modules/@react-aria/interactions/dist/useInteractOutside.es.js +51 -0
  283. package/dist/node_modules/@react-aria/interactions/dist/useInteractOutside.es.js.map +1 -0
  284. package/dist/node_modules/@react-aria/interactions/dist/useKeyboard.cjs.js +2 -0
  285. package/dist/node_modules/@react-aria/interactions/dist/useKeyboard.cjs.js.map +1 -0
  286. package/dist/node_modules/@react-aria/interactions/dist/useKeyboard.es.js +13 -0
  287. package/dist/node_modules/@react-aria/interactions/dist/useKeyboard.es.js.map +1 -0
  288. package/dist/node_modules/@react-aria/interactions/dist/usePress.cjs.js +8 -0
  289. package/dist/node_modules/@react-aria/interactions/dist/usePress.cjs.js.map +1 -0
  290. package/dist/node_modules/@react-aria/interactions/dist/usePress.es.js +386 -0
  291. package/dist/node_modules/@react-aria/interactions/dist/usePress.es.js.map +1 -0
  292. package/dist/node_modules/@react-aria/interactions/dist/utils.cjs.js +2 -0
  293. package/dist/node_modules/@react-aria/interactions/dist/utils.cjs.js.map +1 -0
  294. package/dist/node_modules/@react-aria/interactions/dist/utils.es.js +92 -0
  295. package/dist/node_modules/@react-aria/interactions/dist/utils.es.js.map +1 -0
  296. package/dist/node_modules/@react-aria/label/dist/useField.cjs.js +2 -0
  297. package/dist/node_modules/@react-aria/label/dist/useField.cjs.js.map +1 -0
  298. package/dist/node_modules/@react-aria/label/dist/useField.es.js +36 -0
  299. package/dist/node_modules/@react-aria/label/dist/useField.es.js.map +1 -0
  300. package/dist/node_modules/@react-aria/label/dist/useLabel.cjs.js +2 -0
  301. package/dist/node_modules/@react-aria/label/dist/useLabel.cjs.js.map +1 -0
  302. package/dist/node_modules/@react-aria/label/dist/useLabel.es.js +23 -0
  303. package/dist/node_modules/@react-aria/label/dist/useLabel.es.js.map +1 -0
  304. package/dist/node_modules/@react-aria/overlays/dist/Overlay.cjs.js +2 -0
  305. package/dist/node_modules/@react-aria/overlays/dist/Overlay.cjs.js.map +1 -0
  306. package/dist/node_modules/@react-aria/overlays/dist/Overlay.es.js +16 -0
  307. package/dist/node_modules/@react-aria/overlays/dist/Overlay.es.js.map +1 -0
  308. package/dist/node_modules/@react-aria/overlays/dist/ariaHideOutside.cjs.js +2 -0
  309. package/dist/node_modules/@react-aria/overlays/dist/ariaHideOutside.cjs.js.map +1 -0
  310. package/dist/node_modules/@react-aria/overlays/dist/ariaHideOutside.es.js +70 -0
  311. package/dist/node_modules/@react-aria/overlays/dist/ariaHideOutside.es.js.map +1 -0
  312. package/dist/node_modules/@react-aria/overlays/dist/useModalOverlay.cjs.js +2 -0
  313. package/dist/node_modules/@react-aria/overlays/dist/useModalOverlay.cjs.js.map +1 -0
  314. package/dist/node_modules/@react-aria/overlays/dist/useModalOverlay.es.js +32 -0
  315. package/dist/node_modules/@react-aria/overlays/dist/useModalOverlay.es.js.map +1 -0
  316. package/dist/node_modules/@react-aria/overlays/dist/useOverlay.cjs.js +2 -0
  317. package/dist/node_modules/@react-aria/overlays/dist/useOverlay.cjs.js.map +1 -0
  318. package/dist/node_modules/@react-aria/overlays/dist/useOverlay.es.js +53 -0
  319. package/dist/node_modules/@react-aria/overlays/dist/useOverlay.es.js.map +1 -0
  320. package/dist/node_modules/@react-aria/overlays/dist/usePreventScroll.cjs.js +2 -0
  321. package/dist/node_modules/@react-aria/overlays/dist/usePreventScroll.cjs.js.map +1 -0
  322. package/dist/node_modules/@react-aria/overlays/dist/usePreventScroll.es.js +100 -0
  323. package/dist/node_modules/@react-aria/overlays/dist/usePreventScroll.es.js.map +1 -0
  324. package/dist/node_modules/@react-aria/radio/dist/useRadio.cjs.js +2 -0
  325. package/dist/node_modules/@react-aria/radio/dist/useRadio.cjs.js.map +1 -0
  326. package/dist/node_modules/@react-aria/radio/dist/useRadio.es.js +70 -0
  327. package/dist/node_modules/@react-aria/radio/dist/useRadio.es.js.map +1 -0
  328. package/dist/node_modules/@react-aria/radio/dist/useRadioGroup.cjs.js +2 -0
  329. package/dist/node_modules/@react-aria/radio/dist/useRadioGroup.cjs.js.map +1 -0
  330. package/dist/node_modules/@react-aria/radio/dist/useRadioGroup.es.js +80 -0
  331. package/dist/node_modules/@react-aria/radio/dist/useRadioGroup.es.js.map +1 -0
  332. package/dist/node_modules/@react-aria/radio/dist/utils.cjs.js +2 -0
  333. package/dist/node_modules/@react-aria/radio/dist/utils.cjs.js.map +1 -0
  334. package/dist/node_modules/@react-aria/radio/dist/utils.es.js +5 -0
  335. package/dist/node_modules/@react-aria/radio/dist/utils.es.js.map +1 -0
  336. package/dist/node_modules/@react-aria/ssr/dist/SSRProvider.cjs.js +2 -0
  337. package/dist/node_modules/@react-aria/ssr/dist/SSRProvider.cjs.js.map +1 -0
  338. package/dist/node_modules/@react-aria/ssr/dist/SSRProvider.es.js +19 -0
  339. package/dist/node_modules/@react-aria/ssr/dist/SSRProvider.es.js.map +1 -0
  340. package/dist/node_modules/@react-aria/switch/dist/useSwitch.cjs.js +2 -0
  341. package/dist/node_modules/@react-aria/switch/dist/useSwitch.cjs.js.map +1 -0
  342. package/dist/node_modules/@react-aria/switch/dist/useSwitch.es.js +20 -0
  343. package/dist/node_modules/@react-aria/switch/dist/useSwitch.es.js.map +1 -0
  344. package/dist/node_modules/@react-aria/toggle/dist/useToggle.cjs.js +2 -0
  345. package/dist/node_modules/@react-aria/toggle/dist/useToggle.cjs.js.map +1 -0
  346. package/dist/node_modules/@react-aria/toggle/dist/useToggle.es.js +60 -0
  347. package/dist/node_modules/@react-aria/toggle/dist/useToggle.es.js.map +1 -0
  348. package/dist/node_modules/@react-aria/visually-hidden/dist/VisuallyHidden.cjs.js +2 -0
  349. package/dist/node_modules/@react-aria/visually-hidden/dist/VisuallyHidden.cjs.js.map +1 -0
  350. package/dist/node_modules/@react-aria/visually-hidden/dist/VisuallyHidden.es.js +41 -0
  351. package/dist/node_modules/@react-aria/visually-hidden/dist/VisuallyHidden.es.js.map +1 -0
  352. package/dist/node_modules/@react-stately/form/dist/useFormValidationState.cjs.js +2 -0
  353. package/dist/node_modules/@react-stately/form/dist/useFormValidationState.cjs.js.map +1 -0
  354. package/dist/node_modules/@react-stately/form/dist/useFormValidationState.es.js +110 -0
  355. package/dist/node_modules/@react-stately/form/dist/useFormValidationState.es.js.map +1 -0
  356. package/dist/node_modules/@react-stately/overlays/dist/useOverlayTriggerState.cjs.js +2 -0
  357. package/dist/node_modules/@react-stately/overlays/dist/useOverlayTriggerState.cjs.js.map +1 -0
  358. package/dist/node_modules/@react-stately/overlays/dist/useOverlayTriggerState.es.js +30 -0
  359. package/dist/node_modules/@react-stately/overlays/dist/useOverlayTriggerState.es.js.map +1 -0
  360. package/dist/node_modules/@react-stately/radio/dist/useRadioGroupState.cjs.js +2 -0
  361. package/dist/node_modules/@react-stately/radio/dist/useRadioGroupState.cjs.js.map +1 -0
  362. package/dist/node_modules/@react-stately/radio/dist/useRadioGroupState.es.js +35 -0
  363. package/dist/node_modules/@react-stately/radio/dist/useRadioGroupState.es.js.map +1 -0
  364. package/dist/node_modules/@react-stately/toggle/dist/useToggleState.cjs.js +2 -0
  365. package/dist/node_modules/@react-stately/toggle/dist/useToggleState.cjs.js.map +1 -0
  366. package/dist/node_modules/@react-stately/toggle/dist/useToggleState.es.js +22 -0
  367. package/dist/node_modules/@react-stately/toggle/dist/useToggleState.es.js.map +1 -0
  368. package/dist/node_modules/@react-stately/utils/dist/useControlledState.cjs.js +2 -0
  369. package/dist/node_modules/@react-stately/utils/dist/useControlledState.cjs.js.map +1 -0
  370. package/dist/node_modules/@react-stately/utils/dist/useControlledState.es.js +31 -0
  371. package/dist/node_modules/@react-stately/utils/dist/useControlledState.es.js.map +1 -0
  372. package/dist/node_modules/@swc/helpers/esm/_check_private_redeclaration.cjs.js +2 -0
  373. package/dist/node_modules/@swc/helpers/esm/_check_private_redeclaration.cjs.js.map +1 -0
  374. package/dist/node_modules/@swc/helpers/esm/_check_private_redeclaration.es.js +9 -0
  375. package/dist/node_modules/@swc/helpers/esm/_check_private_redeclaration.es.js.map +1 -0
  376. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.cjs.js +2 -0
  377. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.cjs.js.map +1 -0
  378. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.es.js +8 -0
  379. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_get.es.js.map +1 -0
  380. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.cjs.js +2 -0
  381. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.cjs.js.map +1 -0
  382. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.es.js +13 -0
  383. package/dist/node_modules/@swc/helpers/esm/_class_apply_descriptor_set.es.js.map +1 -0
  384. package/dist/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.cjs.js +2 -0
  385. package/dist/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.cjs.js.map +1 -0
  386. package/dist/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.es.js +9 -0
  387. package/dist/node_modules/@swc/helpers/esm/_class_extract_field_descriptor.es.js.map +1 -0
  388. package/dist/node_modules/@swc/helpers/esm/_class_private_field_get.cjs.js +2 -0
  389. package/dist/node_modules/@swc/helpers/esm/_class_private_field_get.cjs.js.map +1 -0
  390. package/dist/node_modules/@swc/helpers/esm/_class_private_field_get.es.js +11 -0
  391. package/dist/node_modules/@swc/helpers/esm/_class_private_field_get.es.js.map +1 -0
  392. package/dist/node_modules/@swc/helpers/esm/_class_private_field_init.cjs.js +2 -0
  393. package/dist/node_modules/@swc/helpers/esm/_class_private_field_init.cjs.js.map +1 -0
  394. package/dist/node_modules/@swc/helpers/esm/_class_private_field_init.es.js +9 -0
  395. package/dist/node_modules/@swc/helpers/esm/_class_private_field_init.es.js.map +1 -0
  396. package/dist/node_modules/@swc/helpers/esm/_class_private_field_set.cjs.js +2 -0
  397. package/dist/node_modules/@swc/helpers/esm/_class_private_field_set.cjs.js.map +1 -0
  398. package/dist/node_modules/@swc/helpers/esm/_class_private_field_set.es.js +11 -0
  399. package/dist/node_modules/@swc/helpers/esm/_class_private_field_set.es.js.map +1 -0
  400. package/dist/node_modules/color2k/dist/index.exports.import.es.cjs.js +2 -0
  401. package/dist/node_modules/color2k/dist/index.exports.import.es.cjs.js.map +1 -0
  402. package/dist/node_modules/color2k/dist/index.exports.import.es.es.js +171 -0
  403. package/dist/node_modules/color2k/dist/index.exports.import.es.es.js.map +1 -0
  404. package/dist/node_modules/react/cjs/react-jsx-runtime.development.cjs.js +23 -0
  405. package/dist/node_modules/react/cjs/react-jsx-runtime.development.cjs.js.map +1 -0
  406. package/dist/node_modules/react/cjs/react-jsx-runtime.development.es.js +609 -0
  407. package/dist/node_modules/react/cjs/react-jsx-runtime.development.es.js.map +1 -0
  408. package/dist/node_modules/react/cjs/react-jsx-runtime.production.min.cjs.js +10 -0
  409. package/dist/node_modules/react/cjs/react-jsx-runtime.production.min.cjs.js.map +1 -0
  410. package/dist/node_modules/react/cjs/react-jsx-runtime.production.min.es.js +29 -0
  411. package/dist/node_modules/react/cjs/react-jsx-runtime.production.min.es.js.map +1 -0
  412. package/dist/node_modules/react/jsx-runtime.cjs.js +2 -0
  413. package/dist/node_modules/react/jsx-runtime.cjs.js.map +1 -0
  414. package/dist/node_modules/react/jsx-runtime.es.js +9 -0
  415. package/dist/node_modules/react/jsx-runtime.es.js.map +1 -0
  416. package/dist/node_modules/react-aria-components/dist/OverlayArrow.cjs.js +2 -0
  417. package/dist/node_modules/react-aria-components/dist/OverlayArrow.cjs.js.map +1 -0
  418. package/dist/node_modules/react-aria-components/dist/OverlayArrow.es.js +37 -0
  419. package/dist/node_modules/react-aria-components/dist/OverlayArrow.es.js.map +1 -0
  420. package/dist/node_modules/react-aria-components/dist/Tooltip.cjs.js +2 -0
  421. package/dist/node_modules/react-aria-components/dist/Tooltip.cjs.js.map +1 -0
  422. package/dist/node_modules/react-aria-components/dist/Tooltip.es.js +98 -0
  423. package/dist/node_modules/react-aria-components/dist/Tooltip.es.js.map +1 -0
  424. package/dist/node_modules/react-aria-components/dist/utils.cjs.js +2 -0
  425. package/dist/node_modules/react-aria-components/dist/utils.cjs.js.map +1 -0
  426. package/dist/node_modules/react-aria-components/dist/utils.es.js +89 -0
  427. package/dist/node_modules/react-aria-components/dist/utils.es.js.map +1 -0
  428. package/dist/theme.cjs.js +1 -1
  429. package/dist/theme.cjs.js.map +1 -1
  430. package/dist/theme.es.js +9 -15
  431. package/dist/theme.es.js.map +1 -1
  432. package/dist/utils/color2k.cjs.js +2 -0
  433. package/dist/utils/color2k.cjs.js.map +1 -0
  434. package/dist/utils/color2k.es.js +14 -0
  435. package/dist/utils/color2k.es.js.map +1 -0
  436. package/dist/utils/copy.cjs.js +2 -0
  437. package/dist/utils/copy.cjs.js.map +1 -0
  438. package/dist/utils/copy.es.js +31 -0
  439. package/dist/utils/copy.es.js.map +1 -0
  440. package/dist/utils/image.cjs.js +2 -0
  441. package/dist/utils/image.cjs.js.map +1 -0
  442. package/dist/utils/image.es.js +28 -0
  443. package/dist/utils/image.es.js.map +1 -0
  444. package/dist/utils/navigation.cjs.js +2 -0
  445. package/dist/utils/navigation.cjs.js.map +1 -0
  446. package/dist/utils/navigation.es.js +12 -0
  447. package/dist/utils/navigation.es.js.map +1 -0
  448. package/dist/utils/palette.cjs.js +2 -0
  449. package/dist/utils/palette.cjs.js.map +1 -0
  450. package/dist/utils/palette.es.js +183 -0
  451. package/dist/utils/palette.es.js.map +1 -0
  452. package/dist/utils/string.cjs.js +2 -0
  453. package/dist/utils/string.cjs.js.map +1 -0
  454. package/dist/utils/string.es.js +8 -0
  455. package/dist/utils/string.es.js.map +1 -0
  456. package/dist/utils.cjs.js +1 -1
  457. package/dist/utils.es.js +19 -15
  458. package/dist/utils.es.js.map +1 -1
  459. package/package.json +140 -140
  460. package/dist/breakpoint-9y1_8U_b.mjs.map +0 -1
  461. package/dist/breakpoint-DtqbboOa.js +0 -2
  462. package/dist/breakpoint-DtqbboOa.js.map +0 -1
  463. package/dist/color2k-CpDB_dpw.mjs +0 -168
  464. package/dist/color2k-CpDB_dpw.mjs.map +0 -1
  465. package/dist/color2k-DCgwXUem.js +0 -2
  466. package/dist/color2k-DCgwXUem.js.map +0 -1
  467. package/dist/colors-CWaj9dFz.mjs.map +0 -1
  468. package/dist/colors-CebzFjpe.js +0 -2
  469. package/dist/colors-CebzFjpe.js.map +0 -1
  470. package/dist/colors-Ceyo4oCJ.mjs.map +0 -1
  471. package/dist/colors-CmSJBHaf.js +0 -2
  472. package/dist/colors-CmSJBHaf.js.map +0 -1
  473. package/dist/colors-DL1dYffC.js +0 -2
  474. package/dist/colors-DL1dYffC.js.map +0 -1
  475. package/dist/colors-DMkDnu4U.mjs.map +0 -1
  476. package/dist/image-CUSfY1_T.js +0 -2
  477. package/dist/image-CUSfY1_T.js.map +0 -1
  478. package/dist/image-DFyN0Kd9.mjs +0 -207
  479. package/dist/image-DFyN0Kd9.mjs.map +0 -1
  480. package/dist/navigation-BB0MBIiR.js +0 -2
  481. package/dist/navigation-BB0MBIiR.js.map +0 -1
  482. package/dist/navigation-Bj7Pex9j.mjs +0 -43
  483. package/dist/navigation-Bj7Pex9j.mjs.map +0 -1
  484. package/dist/useBreakpoint-CjRyGKN-.mjs +0 -53
  485. package/dist/useBreakpoint-CjRyGKN-.mjs.map +0 -1
  486. package/dist/useBreakpoint-DA-JqOu3.js +0 -2
  487. package/dist/useBreakpoint-DA-JqOu3.js.map +0 -1
package/README.md CHANGED
@@ -1,148 +1,148 @@
1
- # ProtonUI
2
-
3
- ![](./.readme.gif)
4
-
5
- ```
6
- npm run storybook
7
- ```
8
-
9
- ## Installation
10
-
11
- ### Prerequisites
12
-
13
- 1. Ensure you have access to `@protonradio/proton-ui` [npm package](https://www.npmjs.com/package/@protonradio/proton-ui)
14
- 2. Login using `npm login`
15
-
16
- ### Install
17
-
18
- ```bash
19
- npm install @protonradio/proton-ui --save
20
- ```
21
-
22
- ### Project Structure
23
-
24
- TODO: Explain project structure after treeshaking efforts have concluded
25
-
26
- ### Setup ThemeProvider
27
-
28
- Wrap your application with the `ThemeProvider` to enable theming:
29
-
30
- ```jsx
31
- import { ThemeProvider, THEMES } from "@protonradio/proton-ui";
32
-
33
- function MyApp({ Component, pageProps }) {
34
- return (
35
- <ThemeProvider theme={THEMES.DARK}>
36
- <Component {...pageProps} />
37
- </ThemeProvider>
38
- );
39
- }
40
- ```
41
-
42
- ### Custom Color Palettes
43
-
44
- Each theme has a `ProtonPalette` with colors tailored for UI design. Palettes are made up of `ProtonColorScale`s that have shades from super_light to super_dark:
45
-
46
- - **Primary Scale**
47
- - **Secondary Scale**
48
- - **Brand Colors** [Partial ProtonColorScale]
49
- - **Gray Scale**
50
- - **Semantic Colors**
51
- - Success
52
- - Warning
53
- - Error
54
-
55
- When you pass a custom palette to the ThemeProvider, these five scales are updated with colors based on the background image you gave it. This is useful for designing UIs around individual releases, labels and artists. All generated scales are designed with accessibility in mind, ensuring proper contrast ratios and visual hierarchy.
56
-
57
- To generate a new palette, use the `usePalette` hook:
58
-
59
- ```jsx
60
- import { ThemeProvider, usePalette, THEMES } from "@protonradio/proton-ui";
61
-
62
- function AppWithCustomPalette(props) {
63
- const customPalette = usePalette(
64
- `https://example.com/${props.imgUrl}.jpg`,
65
- THEMES.DARK
66
- );
67
-
68
- return (
69
- <ThemeProvider theme={THEMES.DARK} palette={customPalette}>
70
- <YourApp />
71
- </ThemeProvider>
72
- );
73
- }
74
- ```
75
-
76
- ## Best Styling Practices
77
-
78
- Components use standardized _control_ variables defined in the theme config stylesheets for consistent styling across the design system:
79
-
80
- ```typescript
81
- export interface ProtonStyleSheet {
82
- "--proton-control__background-color": string;
83
- "--proton-control__background-color-light": string;
84
- "--proton-control__text-color": string;
85
- "--proton-control__title-color": string;
86
- "--proton-control__border-color": string;
87
- "--proton-control__shadow-color": string;
88
- // ... etc
89
- ```
90
-
91
- These control variables unify the styling system while powering theme-specific CSS customization, and follow the pattern `--proton-control__{style}-{property}`:
92
-
93
- ```css
94
- .myComponent {
95
- background-color: var(--proton-control__background-color);
96
- }
97
- ```
98
-
99
- For more advanced theme overrides we utilize the theme class names. The `ThemeProvider` applies the appropriate theme class to its container, making it available to all child components. Theme class names follow the pattern `proton-ui__theme--{themeName}`:
100
-
101
- ```css
102
- .proton-ui__theme--dark .myComponent[active] {
103
- background-color: var(--proton-control__interactive-color);
104
- }
105
- ```
106
-
107
- Palettes can also be accessed in JSX via the `useTheme` hook for more advanced use cases:
108
-
109
- ```jsx
110
- import { useTheme } from "@protonradio/proton-ui";
111
-
112
- function MyComponent() {
113
- const { palette } = useTheme();
114
-
115
- // Prefer CSS selectors over programmatic styling
116
- return <Icon color={palette.BRAND.PRIMARY} />;
117
- }
118
- ```
119
-
120
- ## Publishing Updates to NPM
121
-
122
- We follow semantic versioning and use automated CI/CD for releases:
123
-
124
- **For Beta Releases (Testing):**
125
-
126
- ```bash
127
- npm run build
128
- npm run publish-beta # Automated versioning with beta tag
129
- ```
130
-
131
- **For Production Releases:**
132
-
133
- ```bash
134
- npm run build
135
- npm version <patch|minor|major> # Semantic versioning
136
- npm publish
137
- ```
138
-
139
- **Best Practices:**
140
-
141
- - Always publish beta releases first for testing across platforms
142
- - Test on all supported environments before production release
143
- - Use semantic versioning (patch for bug fixes, minor for features, major for breaking changes)
144
- - Our GitHub Actions [NPM Version](https://github.com/protonradio/proton-ui/actions/workflows/npm_release.yml) tool automatically handles versioning and deployment workflows
145
-
146
- ## Recommended Reading
147
-
148
- - https://www.gabe.pizza/notes-on-component-libraries/
1
+ # ProtonUI
2
+
3
+ ![](./.readme.gif)
4
+
5
+ ```
6
+ npm run storybook
7
+ ```
8
+
9
+ ## Installation
10
+
11
+ ### Prerequisites
12
+
13
+ 1. Ensure you have access to `@protonradio/proton-ui` [npm package](https://www.npmjs.com/package/@protonradio/proton-ui)
14
+ 2. Login using `npm login`
15
+
16
+ ### Install
17
+
18
+ ```bash
19
+ npm install @protonradio/proton-ui --save
20
+ ```
21
+
22
+ ### Project Structure
23
+
24
+ TODO: Explain project structure after treeshaking efforts have concluded
25
+
26
+ ### Setup ThemeProvider
27
+
28
+ Wrap your application with the `ThemeProvider` to enable theming:
29
+
30
+ ```jsx
31
+ import { ThemeProvider, THEMES } from "@protonradio/proton-ui";
32
+
33
+ function MyApp({ Component, pageProps }) {
34
+ return (
35
+ <ThemeProvider theme={THEMES.DARK}>
36
+ <Component {...pageProps} />
37
+ </ThemeProvider>
38
+ );
39
+ }
40
+ ```
41
+
42
+ ### Custom Color Palettes
43
+
44
+ Each theme has a `ProtonPalette` with colors tailored for UI design. Palettes are made up of `ProtonColorScale`s that have shades from super_light to super_dark:
45
+
46
+ - **Primary Scale**
47
+ - **Secondary Scale**
48
+ - **Brand Colors** [Partial ProtonColorScale]
49
+ - **Gray Scale**
50
+ - **Semantic Colors**
51
+ - Success
52
+ - Warning
53
+ - Error
54
+
55
+ When you pass a custom palette to the ThemeProvider, these five scales are updated with colors based on the background image you gave it. This is useful for designing UIs around individual releases, labels and artists. All generated scales are designed with accessibility in mind, ensuring proper contrast ratios and visual hierarchy.
56
+
57
+ To generate a new palette, use the `usePalette` hook:
58
+
59
+ ```jsx
60
+ import { ThemeProvider, usePalette, THEMES } from "@protonradio/proton-ui";
61
+
62
+ function AppWithCustomPalette(props) {
63
+ const customPalette = usePalette(
64
+ `https://example.com/${props.imgUrl}.jpg`,
65
+ THEMES.DARK
66
+ );
67
+
68
+ return (
69
+ <ThemeProvider theme={THEMES.DARK} palette={customPalette}>
70
+ <YourApp />
71
+ </ThemeProvider>
72
+ );
73
+ }
74
+ ```
75
+
76
+ ## Best Styling Practices
77
+
78
+ Components use standardized _control_ variables defined in the theme config stylesheets for consistent styling across the design system:
79
+
80
+ ```typescript
81
+ export interface ProtonStyleSheet {
82
+ "--proton-control__background-color": string;
83
+ "--proton-control__background-color-light": string;
84
+ "--proton-control__text-color": string;
85
+ "--proton-control__title-color": string;
86
+ "--proton-control__border-color": string;
87
+ "--proton-control__shadow-color": string;
88
+ // ... etc
89
+ ```
90
+
91
+ These control variables unify the styling system while powering theme-specific CSS customization, and follow the pattern `--proton-control__{style}-{property}`:
92
+
93
+ ```css
94
+ .myComponent {
95
+ background-color: var(--proton-control__background-color);
96
+ }
97
+ ```
98
+
99
+ For more advanced theme overrides we utilize the theme class names. The `ThemeProvider` applies the appropriate theme class to its container, making it available to all child components. Theme class names follow the pattern `proton-ui__theme--{themeName}`:
100
+
101
+ ```css
102
+ .proton-ui__theme--dark .myComponent[active] {
103
+ background-color: var(--proton-control__interactive-color);
104
+ }
105
+ ```
106
+
107
+ Palettes can also be accessed in JSX via the `useTheme` hook for more advanced use cases:
108
+
109
+ ```jsx
110
+ import { useTheme } from "@protonradio/proton-ui";
111
+
112
+ function MyComponent() {
113
+ const { palette } = useTheme();
114
+
115
+ // Prefer CSS selectors over programmatic styling
116
+ return <Icon color={palette.BRAND.PRIMARY} />;
117
+ }
118
+ ```
119
+
120
+ ## Publishing Updates to NPM
121
+
122
+ We follow semantic versioning and use automated CI/CD for releases:
123
+
124
+ **For Beta Releases (Testing):**
125
+
126
+ ```bash
127
+ npm run build
128
+ npm run publish-beta # Automated versioning with beta tag
129
+ ```
130
+
131
+ **For Production Releases:**
132
+
133
+ ```bash
134
+ npm run build
135
+ npm version <patch|minor|major> # Semantic versioning
136
+ npm publish
137
+ ```
138
+
139
+ **Best Practices:**
140
+
141
+ - Always publish beta releases first for testing across platforms
142
+ - Test on all supported environments before production release
143
+ - Use semantic versioning (patch for bug fixes, minor for features, major for breaking changes)
144
+ - Our GitHub Actions [NPM Version](https://github.com/protonradio/proton-ui/actions/workflows/npm_release.yml) tool automatically handles versioning and deployment workflows
145
+
146
+ ## Recommended Reading
147
+
148
+ - https://www.gabe.pizza/notes-on-component-libraries/
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={exports:{}};exports.__module=e;
2
+ //# sourceMappingURL=jsx-runtime.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsx-runtime.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ var e = { exports: {} };
2
+ export {
3
+ e as __module
4
+ };
5
+ //# sourceMappingURL=jsx-runtime.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jsx-runtime.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
2
+ //# sourceMappingURL=react-jsx-runtime.development.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-jsx-runtime.development.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ var e = {};
2
+ export {
3
+ e as __exports
4
+ };
5
+ //# sourceMappingURL=react-jsx-runtime.development.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-jsx-runtime.development.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});var e={};exports.__exports=e;
2
+ //# sourceMappingURL=react-jsx-runtime.production.min.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-jsx-runtime.production.min.cjs.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ var r = {};
2
+ export {
3
+ r as __exports
4
+ };
5
+ //# sourceMappingURL=react-jsx-runtime.production.min.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"react-jsx-runtime.production.min.es.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3cdefs%3e%3csymbol%20id='external-link'%20viewBox='0%200%20512%20512'%3e%3cpath%20d='M384%20224v184a40%2040%200%2001-40%2040H104a40%2040%200%2001-40-40V168a40%2040%200%200140-40h167.48M336%2064h112v112M224%20288L440%2072'%20fill='none'%20stroke='currentColor'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-width='32'/%3e%3c/symbol%3e%3csymbol%20id='caret-down'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M233.4%20406.6c12.5%2012.5%2032.8%2012.5%2045.3%200l192-192c12.5-12.5%2012.5-32.8%200-45.3s-32.8-12.5-45.3%200L256%20338.7L86.6%20169.4c-12.5-12.5-32.8-12.5-45.3%200s-12.5%2032.8%200%2045.3l192%20192z'/%3e%3c/symbol%3e%3csymbol%20id='caret-right'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M216.5%20374.8c-11.3%2011.3-30%2011.3-41.3%200L74.8%20256c-11.3-11.3-11.3-30%200-41.3l128.5-128.5c11.3-11.3%2030-11.3%2041.3%200s11.3%2030%200%2041.3L145.7%20256l119.8%20119.8c11.3%2011.3%2011.3%2030%200%2041.3z'/%3e%3c/symbol%3e%3csymbol%20id='chevron-right'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M5.74%203.2a.75.75%200%200%200-.04%201.06L9.227%208L5.7%2011.74a.75.75%200%201%200%201.1%201.02l4-4.25a.75.75%200%200%200%200-1.02l-4-4.25a.75.75%200%200%200-1.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-left'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M10.26%203.2a.75.75%200%200%201%20.04%201.06L6.773%208l3.527%203.74a.75.75%200%201%201-1.1%201.02l-4-4.25a.75.75%200%200%201%200-1.02l4-4.25a.75.75%200%200%201%201.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-down'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M3.2%205.74a.75.75%200%200%201%201.06-.04L8%209.227L11.74%205.7a.75.75%200%201%201%201.02%201.1l-4.25%204a.75.75%200%200%201-1.02%200l-4.25-4a.75.75%200%200%201-.04-1.06'/%3e%3c/symbol%3e%3c/defs%3e%3c/svg%3e";exports.default=e;
2
+ //# sourceMappingURL=icons.svg.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.svg.cjs.js","sources":["../../../assets/svg/icons.svg"],"sourcesContent":["export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3cdefs%3e%3csymbol%20id='external-link'%20viewBox='0%200%20512%20512'%3e%3cpath%20d='M384%20224v184a40%2040%200%2001-40%2040H104a40%2040%200%2001-40-40V168a40%2040%200%200140-40h167.48M336%2064h112v112M224%20288L440%2072'%20fill='none'%20stroke='currentColor'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-width='32'/%3e%3c/symbol%3e%3csymbol%20id='caret-down'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M233.4%20406.6c12.5%2012.5%2032.8%2012.5%2045.3%200l192-192c12.5-12.5%2012.5-32.8%200-45.3s-32.8-12.5-45.3%200L256%20338.7L86.6%20169.4c-12.5-12.5-32.8-12.5-45.3%200s-12.5%2032.8%200%2045.3l192%20192z'/%3e%3c/symbol%3e%3csymbol%20id='caret-right'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M216.5%20374.8c-11.3%2011.3-30%2011.3-41.3%200L74.8%20256c-11.3-11.3-11.3-30%200-41.3l128.5-128.5c11.3-11.3%2030-11.3%2041.3%200s11.3%2030%200%2041.3L145.7%20256l119.8%20119.8c11.3%2011.3%2011.3%2030%200%2041.3z'/%3e%3c/symbol%3e%3csymbol%20id='chevron-right'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M5.74%203.2a.75.75%200%200%200-.04%201.06L9.227%208L5.7%2011.74a.75.75%200%201%200%201.1%201.02l4-4.25a.75.75%200%200%200%200-1.02l-4-4.25a.75.75%200%200%200-1.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-left'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M10.26%203.2a.75.75%200%200%201%20.04%201.06L6.773%208l3.527%203.74a.75.75%200%201%201-1.1%201.02l-4-4.25a.75.75%200%200%201%200-1.02l4-4.25a.75.75%200%200%201%201.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-down'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M3.2%205.74a.75.75%200%200%201%201.06-.04L8%209.227L11.74%205.7a.75.75%200%201%201%201.02%201.1l-4.25%204a.75.75%200%200%201-1.02%200l-4.25-4a.75.75%200%200%201-.04-1.06'/%3e%3c/symbol%3e%3c/defs%3e%3c/svg%3e\""],"names":["iconURL"],"mappings":"4GAAA,MAAeA,EAAA"}
@@ -0,0 +1,5 @@
1
+ const e = "data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3cdefs%3e%3csymbol%20id='external-link'%20viewBox='0%200%20512%20512'%3e%3cpath%20d='M384%20224v184a40%2040%200%2001-40%2040H104a40%2040%200%2001-40-40V168a40%2040%200%200140-40h167.48M336%2064h112v112M224%20288L440%2072'%20fill='none'%20stroke='currentColor'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-width='32'/%3e%3c/symbol%3e%3csymbol%20id='caret-down'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M233.4%20406.6c12.5%2012.5%2032.8%2012.5%2045.3%200l192-192c12.5-12.5%2012.5-32.8%200-45.3s-32.8-12.5-45.3%200L256%20338.7L86.6%20169.4c-12.5-12.5-32.8-12.5-45.3%200s-12.5%2032.8%200%2045.3l192%20192z'/%3e%3c/symbol%3e%3csymbol%20id='caret-right'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M216.5%20374.8c-11.3%2011.3-30%2011.3-41.3%200L74.8%20256c-11.3-11.3-11.3-30%200-41.3l128.5-128.5c11.3-11.3%2030-11.3%2041.3%200s11.3%2030%200%2041.3L145.7%20256l119.8%20119.8c11.3%2011.3%2011.3%2030%200%2041.3z'/%3e%3c/symbol%3e%3csymbol%20id='chevron-right'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M5.74%203.2a.75.75%200%200%200-.04%201.06L9.227%208L5.7%2011.74a.75.75%200%201%200%201.1%201.02l4-4.25a.75.75%200%200%200%200-1.02l-4-4.25a.75.75%200%200%200-1.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-left'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M10.26%203.2a.75.75%200%200%201%20.04%201.06L6.773%208l3.527%203.74a.75.75%200%201%201-1.1%201.02l-4-4.25a.75.75%200%200%201%200-1.02l4-4.25a.75.75%200%200%201%201.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-down'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M3.2%205.74a.75.75%200%200%201%201.06-.04L8%209.227L11.74%205.7a.75.75%200%201%201%201.02%201.1l-4.25%204a.75.75%200%200%201-1.02%200l-4.25-4a.75.75%200%200%201-.04-1.06'/%3e%3c/symbol%3e%3c/defs%3e%3c/svg%3e";
2
+ export {
3
+ e as default
4
+ };
5
+ //# sourceMappingURL=icons.svg.es.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.svg.es.js","sources":["../../../assets/svg/icons.svg"],"sourcesContent":["export default \"data:image/svg+xml,%3csvg%20xmlns='http://www.w3.org/2000/svg'%20xmlns:xlink='http://www.w3.org/1999/xlink'%3e%3cdefs%3e%3csymbol%20id='external-link'%20viewBox='0%200%20512%20512'%3e%3cpath%20d='M384%20224v184a40%2040%200%2001-40%2040H104a40%2040%200%2001-40-40V168a40%2040%200%200140-40h167.48M336%2064h112v112M224%20288L440%2072'%20fill='none'%20stroke='currentColor'%20stroke-linecap='round'%20stroke-linejoin='round'%20stroke-width='32'/%3e%3c/symbol%3e%3csymbol%20id='caret-down'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M233.4%20406.6c12.5%2012.5%2032.8%2012.5%2045.3%200l192-192c12.5-12.5%2012.5-32.8%200-45.3s-32.8-12.5-45.3%200L256%20338.7L86.6%20169.4c-12.5-12.5-32.8-12.5-45.3%200s-12.5%2032.8%200%2045.3l192%20192z'/%3e%3c/symbol%3e%3csymbol%20id='caret-right'%20viewBox='0%200%20512%20512'%3e%3cpath%20fill='currentColor'%20d='M216.5%20374.8c-11.3%2011.3-30%2011.3-41.3%200L74.8%20256c-11.3-11.3-11.3-30%200-41.3l128.5-128.5c11.3-11.3%2030-11.3%2041.3%200s11.3%2030%200%2041.3L145.7%20256l119.8%20119.8c11.3%2011.3%2011.3%2030%200%2041.3z'/%3e%3c/symbol%3e%3csymbol%20id='chevron-right'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M5.74%203.2a.75.75%200%200%200-.04%201.06L9.227%208L5.7%2011.74a.75.75%200%201%200%201.1%201.02l4-4.25a.75.75%200%200%200%200-1.02l-4-4.25a.75.75%200%200%200-1.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-left'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M10.26%203.2a.75.75%200%200%201%20.04%201.06L6.773%208l3.527%203.74a.75.75%200%201%201-1.1%201.02l-4-4.25a.75.75%200%200%201%200-1.02l4-4.25a.75.75%200%200%201%201.06-.04'/%3e%3c/symbol%3e%3csymbol%20id='chevron-down'%20viewBox='0%200%2016%2016'%3e%3cpath%20fill='currentColor'%20d='M3.2%205.74a.75.75%200%200%201%201.06-.04L8%209.227L11.74%205.7a.75.75%200%201%201%201.02%201.1l-4.25%204a.75.75%200%200%201-1.02%200l-4.25-4a.75.75%200%200%201-.04-1.06'/%3e%3c/symbol%3e%3c/defs%3e%3c/svg%3e\""],"names":["iconURL"],"mappings":"AAAA,MAAeA,IAAA;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const n=require("../../node_modules/react/jsx-runtime.cjs.js"),s=require("react"),H=require("../../hooks/useIsClosing.cjs.js"),P=require("../../hooks/useLockBodyScroll.cjs.js"),G=require("../Button/Button.cjs.js"),L=require("../ScreenOverlay/ScreenOverlay.cjs.js"),i=require("radix-ui"),N=require("../Icon/Icon.cjs.js");;/* empty css */const D=require("../../utils/navigation.cjs.js"),T=({isOpen:e,actions:a=[],children:o,showCancel:l=!0,cancelButtonText:m="Cancel",selectionMode:E="single",selectedKeys:x,disabledKeys:h=[],onSelectionChange:p,onClose:f,title:j,"data-testid":r})=>{var $;P.useLockBodyScroll(e);const[u,c]=s.useState(0),[t,d]=s.useState([]),[A,_]=s.useState({title:j,actions:a,key:null,previousKey:null}),b=s.useRef(null),C=s.useRef(null),S=s.useRef(null),{isClosing:M,handleClose:g}=H.useIsClosing({onClose:f,overlayRef:S}),v=A.actions||[],w=v&&v.length>0,I=o||w||l,q=t.length>0;function B(R){const y=v.find(k=>k.key===R);if(!y){console.error(`Action with key ${R} not found`);return}d(k=>[...k,A]),_(k=>({title:y.label,actions:y.children,key:y.key,previousKey:k.key}))}function F(){if(t.length>0){const R=t[t.length-1];_(R),d(t.slice(0,-1))}}return s.useEffect(()=>{e&&requestAnimationFrame(()=>{b.current&&c(b.current.scrollHeight+12)})},[e,t,I]),s.useEffect(()=>{(!e||M)&&c(0)},[e,M]),!e&&!M?null:n.jsxRuntimeExports.jsx(L.ScreenOverlay,{fadeIn:!0,ref:S,children:n.jsxRuntimeExports.jsxs(i.DropdownMenu.Root,{modal:!0,open:e,onOpenChange:R=>{R||g()},children:[n.jsxRuntimeExports.jsx(i.DropdownMenu.Trigger,{asChild:!0,children:n.jsxRuntimeExports.jsx("div",{children:""})}),n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__background-wrapper",style:{opacity:M?0:1},children:n.jsxRuntimeExports.jsx("div",{"data-testid":r||"ActionMenu-wrapper",className:"proton-ActionMenu__wrapper",children:n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__card","data-testid":"ActionMenu-content",style:{height:`${u}px`},children:n.jsxRuntimeExports.jsx("div",{ref:C,className:"proton-ActionMenu__menu",children:n.jsxRuntimeExports.jsx(i.DropdownMenu.Content,{loop:!0,sideOffset:8,ref:b,children:I&&n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[o&&n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__content",children:typeof o=="function"?o({close:g}):o}),w&&n.jsxRuntimeExports.jsx(z,{actions:v,selectionMode:E,selectedKeys:x,onSelectionChange:p,disabledKeys:h,handleSubmenuOpen:B,title:A.title,isInSubmenu:q,handleBack:F,previousMenuTitle:($=t[t.length-1])==null?void 0:$.title}),l&&n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[n.jsxRuntimeExports.jsx(i.DropdownMenu.Separator,{}),n.jsxRuntimeExports.jsx(i.DropdownMenu.Item,{className:"proton-ActionMenu__cancel-button",children:n.jsxRuntimeExports.jsx(G.Button,{"data-testid":"ActionMenuItem-cancel",onPress:g,fullWidth:!0,variant:"secondary",children:m})})]})]})})})})})})]})})},z=({actions:e,selectionMode:a,selectedKeys:o=[],onSelectionChange:l,disabledKeys:m=[],handleSubmenuOpen:E,title:x,isInSubmenu:h=!1,handleBack:p,previousMenuTitle:f})=>{const j=()=>n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[h&&p&&n.jsxRuntimeExports.jsxs("div",{className:"proton-ActionMenu__back-button-container",children:[n.jsxRuntimeExports.jsx(i.DropdownMenu.Item,{className:"proton-ActionMenu__back-button",onSelect:r=>{r.preventDefault(),p()},"aria-label":`Go back to ${f||"previous menu"}`,children:n.jsxRuntimeExports.jsx(N.Icon,{id:"chevron-left",size:16,"aria-hidden":"true"})}),n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__title",role:"banner","aria-label":h?`Submenu: ${x}`:`Menu: ${x}`,children:n.jsxRuntimeExports.jsx("span",{children:x})}),n.jsxRuntimeExports.jsx(i.DropdownMenu.Separator,{})]}),e.map((r,u)=>{var t;const c=e[u];return n.jsxRuntimeExports.jsx(U,{item:r,isSubmenu:!!((t=c.children)!=null&&t.length),selectionMode:a,onSelectionChange:l,selectedKeys:o,disabledKeys:m,handleSubmenuOpen:E},r.key)})]});return n.jsxRuntimeExports.jsx("div",{"aria-disabled":a==="none",className:"proton-ActionMenu__list",role:"menu","aria-label":x?`${h?"Submenu":"Menu"}: ${x}`:"Action menu","aria-orientation":"vertical",children:a==="single"?n.jsxRuntimeExports.jsx(i.DropdownMenu.RadioGroup,{value:(o==null?void 0:o[0])||"",onValueChange:r=>{var c;const u=e.find(t=>t.key===r);(c=u==null?void 0:u.children)!=null&&c.length||l&&l(new Set([r]))},children:n.jsxRuntimeExports.jsx(j,{})}):n.jsxRuntimeExports.jsx(i.DropdownMenu.Group,{children:n.jsxRuntimeExports.jsx(j,{})})})},U=({item:e,isSubmenu:a,selectionMode:o,onSelectionChange:l,selectedKeys:m=[],disabledKeys:E=[],handleSubmenuOpen:x})=>{const h=s.useRef(null),p=e.to&&D.isUrlExternal(e.to),f=E.includes(e.key),j=m.includes(e.key),r={className:"proton-ActionMenu__item","aria-label":e.label?`${e.label}${e.description?`, ${e.description}`:""}`:`ActionMenu-Item-${e.key}`,role:"menuitem",disabled:f,ref:h},u=t=>{var d;if((d=e==null?void 0:e.children)!=null&&d.length){t.preventDefault(),x(e.key);return}e.onAction&&e.onAction(e.key)},c=n.jsxRuntimeExports.jsxs(n.jsxRuntimeExports.Fragment,{children:[n.jsxRuntimeExports.jsxs("div",{className:"proton-ActionMenu__item-content",children:[n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__item-label",children:e.label}),e.description&&n.jsxRuntimeExports.jsx("div",{className:"proton-ActionMenu__description",children:e.description})]}),a&&n.jsxRuntimeExports.jsx(N.Icon,{id:"chevron-right",size:16,"aria-hidden":"true"})]});return e.to?s.createElement(i.DropdownMenu.Item,{...r,key:e.key,asChild:!0},n.jsxRuntimeExports.jsx("a",{"aria-label":e.label?`${e.label}${e.description?`, ${e.description}`:""}`:`ActionMenu-Item-${e.key}`,"aria-disabled":f,"aria-checked":j,"aria-expanded":a?!1:void 0,href:e.to,target:p?"_blank":void 0,rel:p?"noopener noreferrer":void 0,onClick:t=>{p||!e.to||D.handleInternalNavigation(t,e.to)},children:c})):o==="multiple"?s.createElement(i.DropdownMenu.CheckboxItem,{...r,key:e.key,checked:j,onSelect:u,onCheckedChange:t=>{if(!l)return;const d=new Set(m);t?d.add(e.key):d.delete(e.key),l(d)}},c):s.createElement(i.DropdownMenu.RadioItem,{...r,value:e.key,key:e.key,"aria-checked":j,"aria-expanded":a?!1:void 0,onSelect:u},c)};exports.ActionMenu=T;
2
+ //# sourceMappingURL=ActionMenu.cjs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ActionMenu.cjs.js","sources":["../../../src/components/ActionMenu/ActionMenu.tsx"],"sourcesContent":["\"use client\";\r\n\r\nimport { ReactNode, useEffect, useRef, useState } from \"react\";\r\nimport type { Selection } from \"@react-types/shared\";\r\n\r\nimport { useIsClosing } from \"../../hooks/useIsClosing\";\r\nimport { useLockBodyScroll } from \"../../hooks/useLockBodyScroll\";\r\nimport { handleInternalNavigation, isUrlExternal } from \"../../utils\";\r\n\r\nimport { Button } from \"../Button/Button\";\r\nimport { ScreenOverlay } from \"../ScreenOverlay/ScreenOverlay\";\r\nimport { DropdownMenu } from \"radix-ui\";\r\nimport { Icon } from \"../Icon/Icon\";\r\n\r\nimport \"./ActionMenu.css\";\r\n\r\nexport interface ActionMenuAction {\r\n key: string;\r\n label?: ReactNode;\r\n description?: ReactNode;\r\n to?: string;\r\n onAction?: (key: string) => void;\r\n children?: ActionMenuAction[];\r\n}\r\n\r\nexport type ActionMenuSelectionMode = \"single\" | \"multiple\" | \"none\";\r\n\r\nexport interface ActionMenuProps {\r\n /** The actions of the menu\r\n * - type {@link ActionMenuAction}[]\r\n */\r\n actions?: ActionMenuAction[];\r\n\r\n /** The text of the cancel button */\r\n cancelButtonText?: string;\r\n\r\n /** The children of the menu */\r\n children?: ReactNode | ((props: { close: () => void }) => ReactNode);\r\n\r\n /** The test id of the menu */\r\n \"data-testid\"?: string;\r\n\r\n /** The keys of the disabled items\r\n * @default []\r\n */\r\n disabledKeys?: string[];\r\n\r\n /** Whether the menu is open\r\n * @default false\r\n */\r\n isOpen: boolean;\r\n\r\n /** The callback function to close the menu */\r\n onClose?: () => void;\r\n\r\n /** The callback function to change the selection\r\n * - type {@link Selection}\r\n */\r\n onSelectionChange?: (keys: Selection) => void;\r\n\r\n /** The selection mode of the menu\r\n * @default \"single\"\r\n */\r\n selectionMode?: ActionMenuSelectionMode;\r\n\r\n /** The keys of the selected items */\r\n selectedKeys?: string[];\r\n\r\n /** Whether to show the cancel button */\r\n showCancel?: boolean;\r\n\r\n /** The title of the menu */\r\n title?: string;\r\n}\r\n\r\ntype ActionStack = {\r\n title: ReactNode | null;\r\n actions: ActionMenuAction[];\r\n key: string | null;\r\n previousKey: string | null;\r\n};\r\n\r\n/**\r\n * A controlled ActionMenu to display a menu of actions.\r\n * Renders a list of actions as a focusable menu, or non-focusable children.\r\n *\r\n * API:\r\n * - {@link ActionMenuProps}\r\n */\r\nexport const ActionMenu = ({\r\n isOpen,\r\n actions = [],\r\n children,\r\n showCancel = true,\r\n cancelButtonText = \"Cancel\",\r\n selectionMode = \"single\",\r\n selectedKeys,\r\n disabledKeys = [],\r\n onSelectionChange,\r\n onClose,\r\n title,\r\n \"data-testid\": testId,\r\n}: ActionMenuProps) => {\r\n useLockBodyScroll(isOpen);\r\n const [contentHeight, setContentHeight] = useState<number>(0);\r\n const [stackHistory, setStackHistory] = useState<ActionStack[]>([]);\r\n const [currentActionStack, setCurrentActionStack] = useState<ActionStack>({\r\n title,\r\n actions,\r\n key: null,\r\n previousKey: null,\r\n });\r\n const contentRef = useRef<HTMLDivElement>(null);\r\n const menuRef = useRef<HTMLDivElement>(null);\r\n const overlayRef = useRef<HTMLDivElement>(null);\r\n const { isClosing, handleClose } = useIsClosing({ onClose, overlayRef });\r\n\r\n const currentActions = currentActionStack.actions || [];\r\n const hasActions = currentActions && currentActions.length > 0;\r\n const hasContent = children || hasActions || showCancel;\r\n const isInSubmenu = stackHistory.length > 0;\r\n\r\n function handleSubmenuOpen(key: string) {\r\n const action = currentActions.find((action) => action.key === key);\r\n if (!action) {\r\n console.error(`Action with key ${key} not found`);\r\n return;\r\n }\r\n\r\n setStackHistory((prevStackHistory) => [\r\n ...prevStackHistory,\r\n currentActionStack,\r\n ]);\r\n setCurrentActionStack((prevStack) => ({\r\n title: action.label,\r\n actions: action.children,\r\n key: action.key,\r\n previousKey: prevStack.key,\r\n }));\r\n }\r\n\r\n function handleBack() {\r\n if (stackHistory.length > 0) {\r\n const previousStack = stackHistory[stackHistory.length - 1];\r\n setCurrentActionStack(previousStack);\r\n setStackHistory(stackHistory.slice(0, -1));\r\n }\r\n }\r\n\r\n // Re-measure the open menu's content height when stack history changes\r\n useEffect(() => {\r\n if (!isOpen) return;\r\n\r\n requestAnimationFrame(() => {\r\n if (contentRef.current) {\r\n setContentHeight(contentRef.current.scrollHeight + 12);\r\n }\r\n });\r\n }, [isOpen, stackHistory, hasContent]);\r\n\r\n // Reset content height when menu closes or is closing\r\n useEffect(() => {\r\n if (!isOpen || isClosing) {\r\n setContentHeight(0);\r\n }\r\n }, [isOpen, isClosing]);\r\n\r\n if (!isOpen && !isClosing) return null;\r\n\r\n return (\r\n <ScreenOverlay fadeIn ref={overlayRef}>\r\n <DropdownMenu.Root\r\n modal\r\n open={isOpen}\r\n onOpenChange={(open) => {\r\n if (!open) handleClose();\r\n }}\r\n >\r\n <DropdownMenu.Trigger asChild>\r\n {/* No visible trigger, menu is controlled by isOpen */}\r\n <div>{\"\"}</div>\r\n </DropdownMenu.Trigger>\r\n\r\n <div\r\n className=\"proton-ActionMenu__background-wrapper\"\r\n style={{ opacity: isClosing ? 0 : 1 }}\r\n >\r\n <div\r\n data-testid={testId || \"ActionMenu-wrapper\"}\r\n className=\"proton-ActionMenu__wrapper\"\r\n >\r\n <div\r\n className=\"proton-ActionMenu__card\"\r\n data-testid=\"ActionMenu-content\"\r\n style={{ height: `${contentHeight}px` }}\r\n >\r\n <div ref={menuRef} className=\"proton-ActionMenu__menu\">\r\n <DropdownMenu.Content loop sideOffset={8} ref={contentRef}>\r\n {hasContent && (\r\n <>\r\n {children && (\r\n <div className=\"proton-ActionMenu__content\">\r\n {typeof children === \"function\"\r\n ? children({ close: handleClose })\r\n : children}\r\n </div>\r\n )}\r\n\r\n {hasActions && (\r\n <ActionMenuList\r\n actions={currentActions}\r\n selectionMode={selectionMode}\r\n selectedKeys={selectedKeys}\r\n onSelectionChange={onSelectionChange}\r\n disabledKeys={disabledKeys}\r\n handleSubmenuOpen={handleSubmenuOpen}\r\n title={currentActionStack.title}\r\n isInSubmenu={isInSubmenu}\r\n handleBack={handleBack}\r\n previousMenuTitle={\r\n stackHistory[stackHistory.length - 1]?.title\r\n }\r\n />\r\n )}\r\n\r\n {showCancel && (\r\n <>\r\n <DropdownMenu.Separator />\r\n <DropdownMenu.Item className=\"proton-ActionMenu__cancel-button\">\r\n <Button\r\n data-testid=\"ActionMenuItem-cancel\"\r\n onPress={handleClose}\r\n fullWidth\r\n variant=\"secondary\"\r\n >\r\n {cancelButtonText}\r\n </Button>\r\n </DropdownMenu.Item>\r\n </>\r\n )}\r\n </>\r\n )}\r\n </DropdownMenu.Content>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </DropdownMenu.Root>\r\n </ScreenOverlay>\r\n );\r\n};\r\n\r\ninterface ActionMenuListProps {\r\n actions: ActionMenuAction[];\r\n selectionMode: ActionMenuSelectionMode;\r\n selectedKeys?: string[];\r\n onSelectionChange?: (keys: Selection) => void;\r\n disabledKeys?: string[];\r\n handleSubmenuOpen: (key: string) => void;\r\n title?: ReactNode;\r\n isInSubmenu?: boolean;\r\n handleBack?: () => void;\r\n previousMenuTitle?: ReactNode;\r\n}\r\n\r\nconst ActionMenuList = ({\r\n actions,\r\n selectionMode,\r\n selectedKeys = [],\r\n onSelectionChange,\r\n disabledKeys = [],\r\n handleSubmenuOpen,\r\n title,\r\n isInSubmenu = false,\r\n handleBack,\r\n previousMenuTitle,\r\n}: ActionMenuListProps) => {\r\n const ActionMenuItemMap = () => (\r\n <>\r\n {isInSubmenu && handleBack && (\r\n <div className=\"proton-ActionMenu__back-button-container\">\r\n <DropdownMenu.Item\r\n className=\"proton-ActionMenu__back-button\"\r\n onSelect={(event) => {\r\n event.preventDefault();\r\n handleBack();\r\n }}\r\n aria-label={`Go back to ${previousMenuTitle || \"previous menu\"}`}\r\n >\r\n <Icon id=\"chevron-left\" size={16} aria-hidden=\"true\" />\r\n </DropdownMenu.Item>\r\n <div\r\n className=\"proton-ActionMenu__title\"\r\n role=\"banner\"\r\n aria-label={isInSubmenu ? `Submenu: ${title}` : `Menu: ${title}`}\r\n >\r\n <span>{title}</span>\r\n </div>\r\n <DropdownMenu.Separator />\r\n </div>\r\n )}\r\n\r\n {actions.map((action, i) => {\r\n const itemProps = actions[i];\r\n return (\r\n <ActionMenuItem\r\n key={action.key}\r\n item={action}\r\n isSubmenu={Boolean(itemProps.children?.length)}\r\n selectionMode={selectionMode}\r\n onSelectionChange={onSelectionChange}\r\n selectedKeys={selectedKeys}\r\n disabledKeys={disabledKeys}\r\n handleSubmenuOpen={handleSubmenuOpen}\r\n />\r\n );\r\n })}\r\n </>\r\n );\r\n\r\n return (\r\n <div\r\n aria-disabled={selectionMode === \"none\"}\r\n className=\"proton-ActionMenu__list\"\r\n role=\"menu\"\r\n aria-label={\r\n title ? `${isInSubmenu ? \"Submenu\" : \"Menu\"}: ${title}` : \"Action menu\"\r\n }\r\n aria-orientation=\"vertical\"\r\n >\r\n {selectionMode === \"single\" ? (\r\n <DropdownMenu.RadioGroup\r\n value={selectedKeys?.[0] || \"\"}\r\n onValueChange={(value) => {\r\n // Check if this is a submenu item - if so, don't trigger selection change\r\n const action = actions.find((action) => action.key === value);\r\n if (action?.children?.length) {\r\n return;\r\n }\r\n\r\n if (onSelectionChange) {\r\n onSelectionChange(new Set([value]));\r\n }\r\n }}\r\n >\r\n <ActionMenuItemMap />\r\n </DropdownMenu.RadioGroup>\r\n ) : (\r\n <DropdownMenu.Group>\r\n <ActionMenuItemMap />\r\n </DropdownMenu.Group>\r\n )}\r\n </div>\r\n );\r\n};\r\n\r\ninterface ActionMenuItemProps {\r\n to?: string;\r\n item: ActionMenuAction;\r\n isSubmenu?: boolean;\r\n selectionMode: ActionMenuSelectionMode;\r\n onSelectionChange?: (keys: Selection) => void;\r\n selectedKeys?: string[];\r\n disabledKeys?: string[];\r\n handleSubmenuOpen: (key: string) => void;\r\n}\r\n\r\nconst ActionMenuItem = ({\r\n item,\r\n isSubmenu,\r\n selectionMode,\r\n onSelectionChange,\r\n selectedKeys = [],\r\n disabledKeys = [],\r\n handleSubmenuOpen,\r\n}: ActionMenuItemProps) => {\r\n const ref = useRef(null);\r\n const isExternal = item.to && isUrlExternal(item.to);\r\n const isDisabled = disabledKeys.includes(item.key);\r\n const isSelected = selectedKeys.includes(item.key);\r\n\r\n const radixItemProps = {\r\n className: \"proton-ActionMenu__item\",\r\n \"aria-label\": item.label\r\n ? `${item.label}${item.description ? `, ${item.description}` : \"\"}`\r\n : `ActionMenu-Item-${item.key}`,\r\n role: \"menuitem\",\r\n disabled: isDisabled,\r\n ref,\r\n };\r\n\r\n const onSelect = (event: Event) => {\r\n if (item?.children?.length) {\r\n event.preventDefault();\r\n handleSubmenuOpen(item.key);\r\n return;\r\n }\r\n if (item.onAction) {\r\n item.onAction(item.key);\r\n }\r\n };\r\n\r\n const content = (\r\n <>\r\n <div className=\"proton-ActionMenu__item-content\">\r\n <div className=\"proton-ActionMenu__item-label\">{item.label}</div>\r\n {item.description && (\r\n <div className=\"proton-ActionMenu__description\">\r\n {item.description}\r\n </div>\r\n )}\r\n </div>\r\n {isSubmenu && <Icon id=\"chevron-right\" size={16} aria-hidden=\"true\" />}\r\n </>\r\n );\r\n\r\n if (item.to) {\r\n return (\r\n <DropdownMenu.Item {...radixItemProps} key={item.key} asChild>\r\n <a\r\n aria-label={\r\n item.label\r\n ? `${item.label}${item.description ? `, ${item.description}` : \"\"}`\r\n : `ActionMenu-Item-${item.key}`\r\n }\r\n aria-disabled={isDisabled}\r\n aria-checked={isSelected}\r\n aria-expanded={isSubmenu ? false : undefined}\r\n href={item.to}\r\n target={isExternal ? \"_blank\" : undefined}\r\n rel={isExternal ? \"noopener noreferrer\" : undefined}\r\n onClick={(e: React.MouseEvent<HTMLAnchorElement>) => {\r\n if (isExternal || !item.to) {\r\n return;\r\n }\r\n handleInternalNavigation(e, item.to);\r\n }}\r\n >\r\n {content}\r\n </a>\r\n </DropdownMenu.Item>\r\n );\r\n }\r\n\r\n if (selectionMode === \"multiple\") {\r\n return (\r\n <DropdownMenu.CheckboxItem\r\n {...radixItemProps}\r\n key={item.key}\r\n checked={isSelected}\r\n onSelect={onSelect}\r\n onCheckedChange={(checked: boolean) => {\r\n if (!onSelectionChange) return;\r\n\r\n const currentKeys = new Set(selectedKeys);\r\n if (checked) {\r\n currentKeys.add(item.key);\r\n } else {\r\n currentKeys.delete(item.key);\r\n }\r\n onSelectionChange(currentKeys);\r\n }}\r\n >\r\n {content}\r\n </DropdownMenu.CheckboxItem>\r\n );\r\n }\r\n\r\n return (\r\n <DropdownMenu.RadioItem\r\n {...radixItemProps}\r\n value={item.key}\r\n key={item.key}\r\n aria-checked={isSelected}\r\n aria-expanded={isSubmenu ? false : undefined}\r\n onSelect={onSelect}\r\n >\r\n {content}\r\n </DropdownMenu.RadioItem>\r\n );\r\n};\r\n"],"names":["ActionMenu","isOpen","actions","children","showCancel","cancelButtonText","selectionMode","selectedKeys","disabledKeys","onSelectionChange","onClose","title","testId","useLockBodyScroll","contentHeight","setContentHeight","useState","stackHistory","setStackHistory","currentActionStack","setCurrentActionStack","contentRef","useRef","menuRef","overlayRef","isClosing","handleClose","useIsClosing","currentActions","hasActions","hasContent","isInSubmenu","handleSubmenuOpen","key","action","prevStackHistory","prevStack","handleBack","previousStack","useEffect","jsx","ScreenOverlay","jsxs","DropdownMenu","open","Fragment","ActionMenuList","_a","Button","previousMenuTitle","ActionMenuItemMap","event","Icon","i","itemProps","ActionMenuItem","value","item","isSubmenu","ref","isExternal","isUrlExternal","isDisabled","isSelected","radixItemProps","onSelect","content","createElement","e","handleInternalNavigation","checked","currentKeys"],"mappings":"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"}