@intlayer/design-system 5.7.8 → 5.8.1-canary.0

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 (413) hide show
  1. package/dist/.vite/manifest.json +127 -91
  2. package/dist/{better-auth.8zoxzg-F-D8e0X4ys.js → better-auth.CMQ3rA-I-7umXOENE.js} +1 -7
  3. package/dist/better-auth.CMQ3rA-I-7umXOENE.js.map +1 -0
  4. package/dist/{better-auth.8zoxzg-F-BEBqzpjz.cjs → better-auth.CMQ3rA-I-C2nBKRMa.cjs} +1 -7
  5. package/dist/better-auth.CMQ3rA-I-C2nBKRMa.cjs.map +1 -0
  6. package/dist/components/Accordion/Accordion.cjs +2 -2
  7. package/dist/components/Accordion/Accordion.cjs.map +1 -1
  8. package/dist/components/Accordion/Accordion.d.ts.map +1 -1
  9. package/dist/components/Accordion/Accordion.mjs +3 -3
  10. package/dist/components/Accordion/Accordion.mjs.map +1 -1
  11. package/dist/components/Badge/index.cjs +69 -12
  12. package/dist/components/Badge/index.cjs.map +1 -1
  13. package/dist/components/Badge/index.d.ts +18 -2
  14. package/dist/components/Badge/index.d.ts.map +1 -1
  15. package/dist/components/Badge/index.mjs +69 -12
  16. package/dist/components/Badge/index.mjs.map +1 -1
  17. package/dist/components/Breadcrumb/index.cjs +4 -5
  18. package/dist/components/Breadcrumb/index.cjs.map +1 -1
  19. package/dist/components/Breadcrumb/index.d.ts +2 -1
  20. package/dist/components/Breadcrumb/index.d.ts.map +1 -1
  21. package/dist/components/Breadcrumb/index.mjs +7 -8
  22. package/dist/components/Breadcrumb/index.mjs.map +1 -1
  23. package/dist/components/Button/Button.cjs +95 -40
  24. package/dist/components/Button/Button.cjs.map +1 -1
  25. package/dist/components/Button/Button.d.ts +42 -1
  26. package/dist/components/Button/Button.d.ts.map +1 -1
  27. package/dist/components/Button/Button.mjs +96 -41
  28. package/dist/components/Button/Button.mjs.map +1 -1
  29. package/dist/components/Button/index.cjs +5 -0
  30. package/dist/components/Button/index.cjs.map +1 -1
  31. package/dist/components/Button/index.mjs +7 -2
  32. package/dist/components/Container/index.cjs +67 -0
  33. package/dist/components/Container/index.cjs.map +1 -1
  34. package/dist/components/Container/index.d.ts +53 -0
  35. package/dist/components/Container/index.d.ts.map +1 -1
  36. package/dist/components/Container/index.mjs +67 -0
  37. package/dist/components/Container/index.mjs.map +1 -1
  38. package/dist/components/ContentEditor/ContentEditor.cjs +3 -1
  39. package/dist/components/ContentEditor/ContentEditor.cjs.map +1 -1
  40. package/dist/components/ContentEditor/ContentEditor.d.ts.map +1 -1
  41. package/dist/components/ContentEditor/ContentEditor.mjs +3 -1
  42. package/dist/components/ContentEditor/ContentEditor.mjs.map +1 -1
  43. package/dist/components/ContentEditor/ContentEditorInput.cjs +7 -7
  44. package/dist/components/ContentEditor/ContentEditorInput.cjs.map +1 -1
  45. package/dist/components/ContentEditor/ContentEditorInput.d.ts +1 -1
  46. package/dist/components/ContentEditor/ContentEditorInput.d.ts.map +1 -1
  47. package/dist/components/ContentEditor/ContentEditorInput.mjs +9 -9
  48. package/dist/components/ContentEditor/ContentEditorInput.mjs.map +1 -1
  49. package/dist/components/CopyButton/CopyButton.content.cjs.map +1 -0
  50. package/dist/components/CopyButton/CopyButton.content.d.ts.map +1 -0
  51. package/dist/components/CopyButton/CopyButton.content.mjs.map +1 -0
  52. package/dist/components/CopyButton/index.cjs +4 -5
  53. package/dist/components/CopyButton/index.cjs.map +1 -1
  54. package/dist/components/CopyButton/index.d.ts.map +1 -1
  55. package/dist/components/CopyButton/index.mjs +6 -7
  56. package/dist/components/CopyButton/index.mjs.map +1 -1
  57. package/dist/components/DictionaryFieldEditor/ContentEditorView/TextEditor.cjs +29 -33
  58. package/dist/components/DictionaryFieldEditor/ContentEditorView/TextEditor.cjs.map +1 -1
  59. package/dist/components/DictionaryFieldEditor/ContentEditorView/TextEditor.d.ts.map +1 -1
  60. package/dist/components/DictionaryFieldEditor/ContentEditorView/TextEditor.mjs +32 -36
  61. package/dist/components/DictionaryFieldEditor/ContentEditorView/TextEditor.mjs.map +1 -1
  62. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/DictionaryCreationForm.cjs +4 -6
  63. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/DictionaryCreationForm.cjs.map +1 -1
  64. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/DictionaryCreationForm.d.ts.map +1 -1
  65. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/DictionaryCreationForm.mjs +5 -7
  66. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/DictionaryCreationForm.mjs.map +1 -1
  67. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.cjs +2 -1
  68. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.cjs.map +1 -1
  69. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.d.ts +1 -0
  70. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.d.ts.map +1 -1
  71. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.mjs +1 -0
  72. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/dictionaryCreationForm.content.mjs.map +1 -1
  73. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/useDictionaryFormSchema.cjs +2 -3
  74. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/useDictionaryFormSchema.cjs.map +1 -1
  75. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/useDictionaryFormSchema.d.ts.map +1 -1
  76. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/useDictionaryFormSchema.mjs +3 -4
  77. package/dist/components/DictionaryFieldEditor/DictionaryCreationForm/useDictionaryFormSchema.mjs.map +1 -1
  78. package/dist/components/DictionaryFieldEditor/DictionaryDetails/DictionaryDetailsForm.cjs +5 -5
  79. package/dist/components/DictionaryFieldEditor/DictionaryDetails/DictionaryDetailsForm.cjs.map +1 -1
  80. package/dist/components/DictionaryFieldEditor/DictionaryDetails/DictionaryDetailsForm.mjs +6 -6
  81. package/dist/components/DictionaryFieldEditor/DictionaryDetails/DictionaryDetailsForm.mjs.map +1 -1
  82. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.cjs +2 -1
  83. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.cjs.map +1 -1
  84. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.d.ts +3 -24
  85. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.d.ts.map +1 -1
  86. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.mjs +1 -0
  87. package/dist/components/DictionaryFieldEditor/DictionaryDetails/dictionaryDetails.content.mjs.map +1 -1
  88. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.cjs +2 -3
  89. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.cjs.map +1 -1
  90. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.cjs +2 -1
  91. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.cjs.map +1 -1
  92. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.d.ts +1 -0
  93. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.d.ts.map +1 -1
  94. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.mjs +1 -0
  95. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.content.mjs.map +1 -1
  96. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.d.ts.map +1 -1
  97. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.mjs +3 -4
  98. package/dist/components/DictionaryFieldEditor/DictionaryDetails/useDictionaryDetailsSchema.mjs.map +1 -1
  99. package/dist/components/DictionaryFieldEditor/DictionaryFieldEditor.cjs +6 -10
  100. package/dist/components/DictionaryFieldEditor/DictionaryFieldEditor.cjs.map +1 -1
  101. package/dist/components/DictionaryFieldEditor/DictionaryFieldEditor.d.ts.map +1 -1
  102. package/dist/components/DictionaryFieldEditor/DictionaryFieldEditor.mjs +9 -13
  103. package/dist/components/DictionaryFieldEditor/DictionaryFieldEditor.mjs.map +1 -1
  104. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.cjs +8 -9
  105. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.cjs.map +1 -1
  106. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.d.ts +1 -1
  107. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.d.ts.map +1 -1
  108. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.mjs +10 -11
  109. package/dist/components/DictionaryFieldEditor/NavigationView/NavigationViewNode.mjs.map +1 -1
  110. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.cjs +2 -1
  111. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.cjs.map +1 -1
  112. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.d.ts +1 -0
  113. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.d.ts.map +1 -1
  114. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.mjs +1 -0
  115. package/dist/components/DictionaryFieldEditor/NavigationView/navigationViewNode.content.mjs.map +1 -1
  116. package/dist/components/DictionaryFieldEditor/NodeTypeSelector.cjs +1 -2
  117. package/dist/components/DictionaryFieldEditor/NodeTypeSelector.cjs.map +1 -1
  118. package/dist/components/DictionaryFieldEditor/NodeTypeSelector.d.ts.map +1 -1
  119. package/dist/components/DictionaryFieldEditor/NodeTypeSelector.mjs +2 -3
  120. package/dist/components/DictionaryFieldEditor/NodeTypeSelector.mjs.map +1 -1
  121. package/dist/components/DictionaryFieldEditor/SaveForm/SaveForm.cjs +14 -14
  122. package/dist/components/DictionaryFieldEditor/SaveForm/SaveForm.cjs.map +1 -1
  123. package/dist/components/DictionaryFieldEditor/SaveForm/SaveForm.d.ts.map +1 -1
  124. package/dist/components/DictionaryFieldEditor/SaveForm/SaveForm.mjs +16 -16
  125. package/dist/components/DictionaryFieldEditor/SaveForm/SaveForm.mjs.map +1 -1
  126. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.cjs +2 -1
  127. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.cjs.map +1 -1
  128. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.d.ts +3 -24
  129. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.d.ts.map +1 -1
  130. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.mjs +1 -0
  131. package/dist/components/DictionaryFieldEditor/SaveForm/saveForm.content.mjs.map +1 -1
  132. package/dist/components/DictionaryFieldEditor/StructureView/StructureView.cjs +11 -12
  133. package/dist/components/DictionaryFieldEditor/StructureView/StructureView.cjs.map +1 -1
  134. package/dist/components/DictionaryFieldEditor/StructureView/StructureView.mjs +13 -14
  135. package/dist/components/DictionaryFieldEditor/StructureView/StructureView.mjs.map +1 -1
  136. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.cjs +3 -2
  137. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.cjs.map +1 -1
  138. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.d.ts +1 -0
  139. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.d.ts.map +1 -1
  140. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.mjs +2 -1
  141. package/dist/components/DictionaryFieldEditor/StructureView/structureView.content.mjs.map +1 -1
  142. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcher.cjs +5 -8
  143. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcher.cjs.map +1 -1
  144. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcher.d.ts.map +1 -1
  145. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcher.mjs +7 -10
  146. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcher.mjs.map +1 -1
  147. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcherContext.cjs +1 -1
  148. package/dist/components/DictionaryFieldEditor/VersionSwitcherDropDown/VersionSwitcherContext.mjs +1 -1
  149. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.cjs +2 -1
  150. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.cjs.map +1 -1
  151. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.d.ts +1 -0
  152. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.d.ts.map +1 -1
  153. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.mjs +1 -0
  154. package/dist/components/DictionaryFieldEditor/dictionaryFieldEditor.content.mjs.map +1 -1
  155. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.cjs +2 -1
  156. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.cjs.map +1 -1
  157. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.d.ts +1 -0
  158. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.d.ts.map +1 -1
  159. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.mjs +1 -0
  160. package/dist/components/DictionaryFieldEditor/nodeTypeSelector.content.mjs.map +1 -1
  161. package/dist/components/DropDown/index.cjs +11 -2
  162. package/dist/components/DropDown/index.cjs.map +1 -1
  163. package/dist/components/DropDown/index.d.ts +7 -2
  164. package/dist/components/DropDown/index.d.ts.map +1 -1
  165. package/dist/components/DropDown/index.mjs +12 -3
  166. package/dist/components/DropDown/index.mjs.map +1 -1
  167. package/dist/components/EditableField/EditableFieldLayout.cjs +9 -9
  168. package/dist/components/EditableField/EditableFieldLayout.cjs.map +1 -1
  169. package/dist/components/EditableField/EditableFieldLayout.d.ts +1 -1
  170. package/dist/components/EditableField/EditableFieldLayout.d.ts.map +1 -1
  171. package/dist/components/EditableField/EditableFieldLayout.mjs +10 -10
  172. package/dist/components/EditableField/EditableFieldLayout.mjs.map +1 -1
  173. package/dist/components/EditableField/EditableFieldTextArea.cjs +1 -1
  174. package/dist/components/EditableField/EditableFieldTextArea.mjs +1 -1
  175. package/dist/components/ExpandCollapse/ExpandCollapse.cjs +56 -0
  176. package/dist/components/ExpandCollapse/ExpandCollapse.cjs.map +1 -0
  177. package/dist/components/ExpandCollapse/ExpandCollapse.d.ts +9 -0
  178. package/dist/components/ExpandCollapse/ExpandCollapse.d.ts.map +1 -0
  179. package/dist/components/ExpandCollapse/ExpandCollapse.mjs +56 -0
  180. package/dist/components/ExpandCollapse/ExpandCollapse.mjs.map +1 -0
  181. package/dist/components/ExpandCollapse/expandCollapse.content.cjs +41 -0
  182. package/dist/components/ExpandCollapse/expandCollapse.content.cjs.map +1 -0
  183. package/dist/components/ExpandCollapse/expandCollapse.content.d.ts +40 -0
  184. package/dist/components/ExpandCollapse/expandCollapse.content.d.ts.map +1 -0
  185. package/dist/components/ExpandCollapse/expandCollapse.content.mjs +42 -0
  186. package/dist/components/ExpandCollapse/expandCollapse.content.mjs.map +1 -0
  187. package/dist/components/ExpandCollapse/index.cjs +5 -0
  188. package/dist/components/ExpandCollapse/index.cjs.map +1 -0
  189. package/dist/components/ExpandCollapse/index.d.ts +2 -0
  190. package/dist/components/ExpandCollapse/index.d.ts.map +1 -0
  191. package/dist/components/ExpandCollapse/index.mjs +5 -0
  192. package/dist/components/ExpandCollapse/index.mjs.map +1 -0
  193. package/dist/components/Form/FormBase.cjs +1 -1
  194. package/dist/components/Form/FormBase.mjs +1 -1
  195. package/dist/components/Form/elements/FormElementWrapper.cjs +2 -2
  196. package/dist/components/Form/elements/FormElementWrapper.mjs +2 -2
  197. package/dist/components/IDE/Code.cjs +12 -1
  198. package/dist/components/IDE/Code.cjs.map +1 -1
  199. package/dist/components/IDE/Code.d.ts +1 -0
  200. package/dist/components/IDE/Code.d.ts.map +1 -1
  201. package/dist/components/IDE/Code.mjs +12 -1
  202. package/dist/components/IDE/Code.mjs.map +1 -1
  203. package/dist/components/IDE/CodeBlockClient.cjs +2 -2
  204. package/dist/components/IDE/CodeBlockClient.cjs.map +1 -1
  205. package/dist/components/IDE/CodeBlockClient.mjs +2 -2
  206. package/dist/components/IDE/CodeBlockClient.mjs.map +1 -1
  207. package/dist/components/IDE/CodeBlockServer.cjs +2 -2
  208. package/dist/components/IDE/CodeBlockServer.cjs.map +1 -1
  209. package/dist/components/IDE/CodeBlockServer.mjs +2 -2
  210. package/dist/components/IDE/CodeBlockServer.mjs.map +1 -1
  211. package/dist/components/IDE/CodeContext.cjs +1 -1
  212. package/dist/components/IDE/CodeContext.mjs +1 -1
  213. package/dist/components/IDE/CopyCode.cjs +2 -3
  214. package/dist/components/IDE/CopyCode.cjs.map +1 -1
  215. package/dist/components/IDE/CopyCode.d.ts.map +1 -1
  216. package/dist/components/IDE/CopyCode.mjs +4 -5
  217. package/dist/components/IDE/CopyCode.mjs.map +1 -1
  218. package/dist/components/Input/Checkbox.cjs +21 -0
  219. package/dist/components/Input/Checkbox.cjs.map +1 -1
  220. package/dist/components/Input/Checkbox.d.ts +21 -1
  221. package/dist/components/Input/Checkbox.d.ts.map +1 -1
  222. package/dist/components/Input/Checkbox.mjs +21 -0
  223. package/dist/components/Input/Checkbox.mjs.map +1 -1
  224. package/dist/components/Input/Input.cjs +12 -0
  225. package/dist/components/Input/Input.cjs.map +1 -1
  226. package/dist/components/Input/Input.d.ts +13 -2
  227. package/dist/components/Input/Input.d.ts.map +1 -1
  228. package/dist/components/Input/Input.mjs +12 -0
  229. package/dist/components/Input/Input.mjs.map +1 -1
  230. package/dist/components/Input/index.cjs +4 -0
  231. package/dist/components/Input/index.cjs.map +1 -1
  232. package/dist/components/Input/index.mjs +6 -2
  233. package/dist/components/Link/Link.cjs +60 -19
  234. package/dist/components/Link/Link.cjs.map +1 -1
  235. package/dist/components/Link/Link.d.ts +27 -2
  236. package/dist/components/Link/Link.d.ts.map +1 -1
  237. package/dist/components/Link/Link.mjs +60 -19
  238. package/dist/components/Link/Link.mjs.map +1 -1
  239. package/dist/components/Link/index.cjs +3 -0
  240. package/dist/components/Link/index.cjs.map +1 -1
  241. package/dist/components/Link/index.mjs +4 -1
  242. package/dist/components/Loader/index.content.d.ts +2 -24
  243. package/dist/components/Loader/index.content.d.ts.map +1 -1
  244. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.cjs +8 -9
  245. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.cjs.map +1 -1
  246. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.d.ts.map +1 -1
  247. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.mjs +11 -12
  248. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.mjs.map +1 -1
  249. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContentContext.cjs +1 -1
  250. package/dist/components/LocaleSwitcherContentDropDown/LocaleSwitcherContentContext.mjs +1 -1
  251. package/dist/components/LocaleSwitcherDropDown/LocaleSwitcher.cjs +4 -5
  252. package/dist/components/LocaleSwitcherDropDown/LocaleSwitcher.cjs.map +1 -1
  253. package/dist/components/LocaleSwitcherDropDown/LocaleSwitcher.d.ts.map +1 -1
  254. package/dist/components/LocaleSwitcherDropDown/LocaleSwitcher.mjs +6 -7
  255. package/dist/components/LocaleSwitcherDropDown/LocaleSwitcher.mjs.map +1 -1
  256. package/dist/components/MarkDownRender/index.cjs +17 -23
  257. package/dist/components/MarkDownRender/index.cjs.map +1 -1
  258. package/dist/components/MarkDownRender/index.d.ts.map +1 -1
  259. package/dist/components/MarkDownRender/index.mjs +18 -24
  260. package/dist/components/MarkDownRender/index.mjs.map +1 -1
  261. package/dist/components/Modal/Modal.cjs +14 -5
  262. package/dist/components/Modal/Modal.cjs.map +1 -1
  263. package/dist/components/Modal/Modal.d.ts +10 -4
  264. package/dist/components/Modal/Modal.d.ts.map +1 -1
  265. package/dist/components/Modal/Modal.mjs +16 -7
  266. package/dist/components/Modal/Modal.mjs.map +1 -1
  267. package/dist/components/Modal/index.cjs +1 -0
  268. package/dist/components/Modal/index.cjs.map +1 -1
  269. package/dist/components/Modal/index.mjs +3 -2
  270. package/dist/components/Navbar/DesktopNavbar.cjs +2 -2
  271. package/dist/components/Navbar/DesktopNavbar.cjs.map +1 -1
  272. package/dist/components/Navbar/DesktopNavbar.d.ts.map +1 -1
  273. package/dist/components/Navbar/DesktopNavbar.mjs +3 -3
  274. package/dist/components/Navbar/DesktopNavbar.mjs.map +1 -1
  275. package/dist/components/Navbar/MobileNavbar.cjs +1 -1
  276. package/dist/components/Navbar/MobileNavbar.mjs +1 -1
  277. package/dist/components/Navbar/index.cjs +2 -2
  278. package/dist/components/Navbar/index.cjs.map +1 -1
  279. package/dist/components/Navbar/index.mjs +2 -2
  280. package/dist/components/Navbar/index.mjs.map +1 -1
  281. package/dist/components/Popover/index.cjs +12 -0
  282. package/dist/components/Popover/index.cjs.map +1 -1
  283. package/dist/components/Popover/index.d.ts +10 -2
  284. package/dist/components/Popover/index.d.ts.map +1 -1
  285. package/dist/components/Popover/index.mjs +13 -1
  286. package/dist/components/Popover/index.mjs.map +1 -1
  287. package/dist/components/RightDrawer/RightDrawer.cjs +5 -5
  288. package/dist/components/RightDrawer/RightDrawer.cjs.map +1 -1
  289. package/dist/components/RightDrawer/RightDrawer.mjs +6 -6
  290. package/dist/components/RightDrawer/RightDrawer.mjs.map +1 -1
  291. package/dist/components/Select/Multiselect.cjs +1 -1
  292. package/dist/components/Select/Multiselect.cjs.map +1 -1
  293. package/dist/components/Select/Multiselect.mjs +2 -2
  294. package/dist/components/Select/Multiselect.mjs.map +1 -1
  295. package/dist/components/Select/Select.cjs +12 -1
  296. package/dist/components/Select/Select.cjs.map +1 -1
  297. package/dist/components/Select/Select.d.ts +5 -1
  298. package/dist/components/Select/Select.d.ts.map +1 -1
  299. package/dist/components/Select/Select.mjs +12 -1
  300. package/dist/components/Select/Select.mjs.map +1 -1
  301. package/dist/components/Select/index.cjs +1 -0
  302. package/dist/components/Select/index.cjs.map +1 -1
  303. package/dist/components/Select/index.mjs +2 -1
  304. package/dist/components/SocialNetworks/index.cjs +1 -1
  305. package/dist/components/SocialNetworks/index.cjs.map +1 -1
  306. package/dist/components/SocialNetworks/index.mjs +1 -1
  307. package/dist/components/SocialNetworks/index.mjs.map +1 -1
  308. package/dist/components/SwitchSelector/index.cjs +89 -18
  309. package/dist/components/SwitchSelector/index.cjs.map +1 -1
  310. package/dist/components/SwitchSelector/index.d.ts +16 -2
  311. package/dist/components/SwitchSelector/index.d.ts.map +1 -1
  312. package/dist/components/SwitchSelector/index.mjs +90 -19
  313. package/dist/components/SwitchSelector/index.mjs.map +1 -1
  314. package/dist/components/TabSelector/TabSelector.cjs +12 -1
  315. package/dist/components/TabSelector/TabSelector.cjs.map +1 -1
  316. package/dist/components/TabSelector/TabSelector.d.ts +12 -1
  317. package/dist/components/TabSelector/TabSelector.d.ts.map +1 -1
  318. package/dist/components/TabSelector/TabSelector.mjs +13 -2
  319. package/dist/components/TabSelector/TabSelector.mjs.map +1 -1
  320. package/dist/components/TabSelector/index.cjs +1 -0
  321. package/dist/components/TabSelector/index.cjs.map +1 -1
  322. package/dist/components/TabSelector/index.d.ts +1 -0
  323. package/dist/components/TabSelector/index.d.ts.map +1 -1
  324. package/dist/components/TabSelector/index.mjs +3 -2
  325. package/dist/components/Table/Table.cjs +58 -0
  326. package/dist/components/Table/Table.cjs.map +1 -0
  327. package/dist/components/Table/Table.d.ts +7 -0
  328. package/dist/components/Table/Table.d.ts.map +1 -0
  329. package/dist/components/Table/Table.mjs +58 -0
  330. package/dist/components/Table/Table.mjs.map +1 -0
  331. package/dist/components/Table/index.cjs +5 -0
  332. package/dist/components/Table/index.cjs.map +1 -0
  333. package/dist/components/Table/index.d.ts +2 -0
  334. package/dist/components/Table/index.d.ts.map +1 -0
  335. package/dist/components/Table/index.mjs +5 -0
  336. package/dist/components/Table/index.mjs.map +1 -0
  337. package/dist/components/Table/table.content.cjs +24 -0
  338. package/dist/components/Table/table.content.cjs.map +1 -0
  339. package/dist/components/Table/table.content.d.ts +40 -0
  340. package/dist/components/Table/table.content.d.ts.map +1 -0
  341. package/dist/components/Table/table.content.mjs +25 -0
  342. package/dist/components/Table/table.content.mjs.map +1 -0
  343. package/dist/components/Tag/index.cjs +131 -22
  344. package/dist/components/Tag/index.cjs.map +1 -1
  345. package/dist/components/Tag/index.d.ts +37 -5
  346. package/dist/components/Tag/index.d.ts.map +1 -1
  347. package/dist/components/Tag/index.mjs +132 -23
  348. package/dist/components/Tag/index.mjs.map +1 -1
  349. package/dist/components/TextArea/AutocompleteTextArea.cjs +1 -1
  350. package/dist/components/TextArea/AutocompleteTextArea.mjs +1 -1
  351. package/dist/components/TextArea/TextArea.cjs.map +1 -1
  352. package/dist/components/TextArea/TextArea.d.ts +5 -3
  353. package/dist/components/TextArea/TextArea.d.ts.map +1 -1
  354. package/dist/components/TextArea/TextArea.mjs.map +1 -1
  355. package/dist/components/ThemeSwitcherDropDown/DesktopThemeSwitcher.cjs +1 -1
  356. package/dist/components/ThemeSwitcherDropDown/DesktopThemeSwitcher.cjs.map +1 -1
  357. package/dist/components/ThemeSwitcherDropDown/DesktopThemeSwitcher.mjs +2 -2
  358. package/dist/components/ThemeSwitcherDropDown/DesktopThemeSwitcher.mjs.map +1 -1
  359. package/dist/components/index.cjs +36 -0
  360. package/dist/components/index.cjs.map +1 -1
  361. package/dist/components/index.d.ts +1 -0
  362. package/dist/components/index.d.ts.map +1 -1
  363. package/dist/components/index.mjs +49 -13
  364. package/dist/components/index.mjs.map +1 -1
  365. package/dist/hooks/auth.cjs +2 -2
  366. package/dist/hooks/auth.cjs.map +1 -1
  367. package/dist/hooks/auth.mjs +1 -1
  368. package/dist/hooks/auth.mjs.map +1 -1
  369. package/dist/hooks/intlayerAPIHooks.cjs +1 -1
  370. package/dist/hooks/intlayerAPIHooks.d.ts +1 -1
  371. package/dist/hooks/intlayerAPIHooks.d.ts.map +1 -1
  372. package/dist/hooks/intlayerAPIHooks.mjs +1 -1
  373. package/dist/hooks/useAsync/useAsync.cjs +6 -6
  374. package/dist/hooks/useAsync/useAsync.cjs.map +1 -1
  375. package/dist/hooks/useAsync/useAsync.mjs +6 -6
  376. package/dist/hooks/useAsync/useAsync.mjs.map +1 -1
  377. package/dist/hooks/useUser/index.cjs +1 -1
  378. package/dist/hooks/useUser/index.mjs +1 -1
  379. package/dist/index-BCuMWKyy.js.map +1 -1
  380. package/dist/index-BYzBot7l.cjs.map +1 -1
  381. package/dist/{parse-BJVwmz92.cjs → parse-Ltyyb1op.cjs} +9 -11
  382. package/dist/parse-Ltyyb1op.cjs.map +1 -0
  383. package/dist/{parse-pnJgclyf.js → parse-Vrm0h1r9.js} +30 -32
  384. package/dist/parse-Vrm0h1r9.js.map +1 -0
  385. package/dist/{schemas-BIuxHDyZ.js → schemas-DEXdAbCK.js} +75 -46
  386. package/dist/schemas-DEXdAbCK.js.map +1 -0
  387. package/dist/{schemas-Q6C7ZNs3.cjs → schemas-lh5OFOvX.cjs} +75 -46
  388. package/dist/schemas-lh5OFOvX.cjs.map +1 -0
  389. package/dist/{zod-K7y5gPX4.cjs → zod-BvUVjPTw.cjs} +11 -11
  390. package/dist/zod-BvUVjPTw.cjs.map +1 -0
  391. package/dist/{zod-D4WapgbL.js → zod-CJrbzxwg.js} +11 -11
  392. package/dist/zod-CJrbzxwg.js.map +1 -0
  393. package/package.json +42 -35
  394. package/dist/better-auth.8zoxzg-F-BEBqzpjz.cjs.map +0 -1
  395. package/dist/better-auth.8zoxzg-F-D8e0X4ys.js.map +0 -1
  396. package/dist/components/Headers/SectionScroller.cjs +0 -29
  397. package/dist/components/Headers/SectionScroller.cjs.map +0 -1
  398. package/dist/components/Headers/SectionScroller.d.ts +0 -2
  399. package/dist/components/Headers/SectionScroller.d.ts.map +0 -1
  400. package/dist/components/Headers/SectionScroller.mjs +0 -29
  401. package/dist/components/Headers/SectionScroller.mjs.map +0 -1
  402. package/dist/components/IDE/CopyButton.content.cjs.map +0 -1
  403. package/dist/components/IDE/CopyButton.content.d.ts.map +0 -1
  404. package/dist/components/IDE/CopyButton.content.mjs.map +0 -1
  405. package/dist/parse-BJVwmz92.cjs.map +0 -1
  406. package/dist/parse-pnJgclyf.js.map +0 -1
  407. package/dist/schemas-BIuxHDyZ.js.map +0 -1
  408. package/dist/schemas-Q6C7ZNs3.cjs.map +0 -1
  409. package/dist/zod-D4WapgbL.js.map +0 -1
  410. package/dist/zod-K7y5gPX4.cjs.map +0 -1
  411. /package/dist/components/{IDE → CopyButton}/CopyButton.content.cjs +0 -0
  412. /package/dist/components/{IDE → CopyButton}/CopyButton.content.d.ts +0 -0
  413. /package/dist/components/{IDE → CopyButton}/CopyButton.content.mjs +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"Link.mjs","sources":["../../../src/components/Link/Link.tsx"],"sourcesContent":["import configuration from '@intlayer/config/built';\nimport type { LocalesValues } from '@intlayer/config/client';\nimport { getLocalizedUrl } from '@intlayer/core';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { ExternalLink } from 'lucide-react';\nimport {\n type AnchorHTMLAttributes,\n type DetailedHTMLProps,\n type FC,\n} from 'react';\nimport { cn } from '../../utils/cn';\n\nexport const linkVariants = cva(\n 'gap-3 transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n {\n variants: {\n variant: {\n default:\n 'h-auto justify-start border-inherit bg-current/0 px-1 underline-offset-4 hover:bg-current/0 hover:underline',\n 'invisible-link':\n 'h-auto justify-start border-inherit bg-current/0 px-1 underline-offset-4 hover:bg-current/0',\n button:\n 'rounded-lg bg-current *:text-text-opposite min-h-8 px-6 max-md:py-2 text-sm flex items-center justify-center gap-2 whitespace-nowrap font-medium transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n 'button-outlined':\n 'rounded-lg border-[1.5px] hover:bg-current/30 min-h-8 px-6 max-md:py-2 text-sm flex items-center justify-center gap-2 whitespace-nowrap font-medium transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n hoverable:\n 'block rounded-lg border-none bg-current/0 transition hover:bg-current/20 aria-[current]:bg-current/5',\n },\n color: {\n primary: 'text-primary',\n secondary: 'text-secondary',\n destructive: 'text-destructive',\n neutral: 'text-neutral',\n light: 'text-white',\n dark: 'text-neutral-800',\n text: 'text-text',\n 'text-inverse': 'text-text-opposite',\n error: 'text-error',\n success: 'text-success',\n custom: '',\n },\n underlined: {\n default: '',\n true: 'underline',\n false: 'no-underline',\n },\n },\n\n defaultVariants: {\n variant: 'default',\n color: 'primary',\n underlined: 'default',\n },\n }\n);\n\nexport type LinkProps = DetailedHTMLProps<\n AnchorHTMLAttributes<HTMLAnchorElement>,\n HTMLAnchorElement\n> &\n VariantProps<typeof linkVariants> & {\n label: string;\n isExternalLink?: boolean;\n isActive?: boolean;\n locale?: LocalesValues;\n };\n\nexport const checkIsExternalLink = ({\n href,\n isExternalLink: isExternalLinkProp,\n}: LinkProps): boolean => {\n const isValidHref = typeof href === 'string' && href.trim() !== '';\n const isExternalLink =\n isExternalLinkProp === true ||\n (typeof isExternalLinkProp === 'undefined' &&\n isValidHref &&\n /^https?:\\/\\//.test(href));\n\n return isExternalLink;\n};\n\nexport const Link: FC<LinkProps> = (props) => {\n const {\n variant = 'default',\n color = 'primary',\n children,\n label,\n className,\n isActive,\n underlined,\n locale,\n isExternalLink: isExternalLinkProp,\n href: hrefProp,\n ...otherProps\n } = props;\n const { internationalization } = configuration;\n\n const isExternalLink = checkIsExternalLink(props);\n const isChildrenString = typeof children === 'string';\n\n const rel = isExternalLink ? 'noopener noreferrer nofollow' : undefined;\n\n const target = isExternalLink ? '_blank' : '_self';\n\n const hrefLang = locale\n ? locale === internationalization.defaultLocale\n ? 'x-default'\n : locale\n : undefined;\n\n const href =\n locale && hrefProp && !isExternalLink\n ? getLocalizedUrl(hrefProp, locale)\n : hrefProp;\n\n return (\n <a\n href={href}\n hrefLang={hrefLang}\n aria-label={label}\n rel={rel}\n target={target}\n aria-current={isActive ? 'page' : undefined}\n className={cn(\n linkVariants({\n variant,\n color,\n underlined,\n className,\n })\n )}\n {...otherProps}\n >\n {variant === 'button' ? <span>{children}</span> : children}\n {isExternalLink && isChildrenString && (\n <ExternalLink className=\"ml-2 inline-block size-4\" />\n )}\n </a>\n );\n};\n"],"names":[],"mappings":";;;;;;AAYO,MAAM,eAAe;AAAA,EAC1B;AAAA,EACA;AAAA,IACE,UAAU;AAAA,MACR,SAAS;AAAA,QACP,SACE;AAAA,QACF,kBACE;AAAA,QACF,QACE;AAAA,QACF,mBACE;AAAA,QACF,WACE;AAAA,MAAA;AAAA,MAEJ,OAAO;AAAA,QACL,SAAS;AAAA,QACT,WAAW;AAAA,QACX,aAAa;AAAA,QACb,SAAS;AAAA,QACT,OAAO;AAAA,QACP,MAAM;AAAA,QACN,MAAM;AAAA,QACN,gBAAgB;AAAA,QAChB,OAAO;AAAA,QACP,SAAS;AAAA,QACT,QAAQ;AAAA,MAAA;AAAA,MAEV,YAAY;AAAA,QACV,SAAS;AAAA,QACT,MAAM;AAAA,QACN,OAAO;AAAA,MAAA;AAAA,IACT;AAAA,IAGF,iBAAiB;AAAA,MACf,SAAS;AAAA,MACT,OAAO;AAAA,MACP,YAAY;AAAA,IAAA;AAAA,EACd;AAEJ;AAaO,MAAM,sBAAsB,CAAC;AAAA,EAClC;AAAA,EACA,gBAAgB;AAClB,MAA0B;AACxB,QAAM,cAAc,OAAO,SAAS,YAAY,KAAK,WAAW;AAChE,QAAM,iBACJ,uBAAuB,QACtB,OAAO,uBAAuB,eAC7B,eACA,eAAe,KAAK,IAAI;AAE5B,SAAO;AACT;AAEO,MAAM,OAAsB,CAAC,UAAU;AAC5C,QAAM;AAAA,IACJ,UAAU;AAAA,IACV,QAAQ;AAAA,IACR;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA,gBAAgB;AAAA,IAChB,MAAM;AAAA,IACN,GAAG;AAAA,EAAA,IACD;AACJ,QAAM,EAAE,yBAAyB;AAEjC,QAAM,iBAAiB,oBAAoB,KAAK;AAChD,QAAM,mBAAmB,OAAO,aAAa;AAE7C,QAAM,MAAM,iBAAiB,iCAAiC;AAE9D,QAAM,SAAS,iBAAiB,WAAW;AAE3C,QAAM,WAAW,SACb,WAAW,qBAAqB,gBAC9B,cACA,SACF;AAEJ,QAAM,OACJ,UAAU,YAAY,CAAC,iBACnB,gBAAgB,UAAU,MAAM,IAChC;AAEN,SACE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,cAAY;AAAA,MACZ;AAAA,MACA;AAAA,MACA,gBAAc,WAAW,SAAS;AAAA,MAClC,WAAW;AAAA,QACT,aAAa;AAAA,UACX;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QAAA,CACD;AAAA,MAAA;AAAA,MAEF,GAAG;AAAA,MAEH,UAAA;AAAA,QAAA,YAAY,WAAW,oBAAC,QAAA,EAAM,SAAA,CAAS,IAAU;AAAA,QACjD,kBAAkB,oBACjB,oBAAC,cAAA,EAAa,WAAU,2BAAA,CAA2B;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAI3D;"}
1
+ {"version":3,"file":"Link.mjs","sources":["../../../src/components/Link/Link.tsx"],"sourcesContent":["import configuration from '@intlayer/config/built';\nimport type { LocalesValues } from '@intlayer/config/client';\nimport { getLocalizedUrl } from '@intlayer/core';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { ExternalLink } from 'lucide-react';\nimport {\n type AnchorHTMLAttributes,\n type DetailedHTMLProps,\n type FC,\n} from 'react';\nimport { cn } from '../../utils/cn';\n\nexport enum LinkVariant {\n DEFAULT = 'default',\n INVISIBLE_LINK = 'invisible-link',\n BUTTON = 'button',\n BUTTON_OUTLINED = 'button-outlined',\n HOVERABLE = 'hoverable',\n}\n\nexport enum LinkColor {\n PRIMARY = 'primary',\n SECONDARY = 'secondary',\n DESTRUCTIVE = 'destructive',\n NEUTRAL = 'neutral',\n LIGHT = 'light',\n DARK = 'dark',\n TEXT = 'text',\n TEXT_INVERSE = 'text-inverse',\n ERROR = 'error',\n SUCCESS = 'success',\n CUSTOM = 'custom',\n}\n\nexport enum LinkUnderlined {\n DEFAULT = 'default',\n TRUE = 'true',\n FALSE = 'false',\n}\n\nexport const linkVariants = cva(\n 'gap-3 transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n {\n variants: {\n variant: {\n [`${LinkVariant.DEFAULT}`]:\n 'h-auto justify-start border-inherit bg-current/0 px-1 underline-offset-4 hover:bg-current/0 hover:underline',\n [`${LinkVariant.INVISIBLE_LINK}`]:\n 'h-auto justify-start border-inherit bg-current/0 px-1 underline-offset-4 hover:bg-current/0',\n [`${LinkVariant.BUTTON}`]:\n 'rounded-lg bg-current *:text-text-opposite min-h-8 px-6 max-md:py-2 text-sm flex items-center justify-center gap-2 whitespace-nowrap font-medium transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n [`${LinkVariant.BUTTON_OUTLINED}`]:\n 'rounded-lg border-[1.5px] hover:bg-current/30 min-h-8 px-6 max-md:py-2 text-sm flex items-center justify-center gap-2 whitespace-nowrap font-medium transition focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50',\n [`${LinkVariant.HOVERABLE}`]:\n 'block rounded-lg border-none bg-current/0 transition hover:bg-current/20 aria-[current]:bg-current/5',\n },\n color: {\n [`${LinkColor.PRIMARY}`]: 'text-primary',\n [`${LinkColor.SECONDARY}`]: 'text-secondary',\n [`${LinkColor.DESTRUCTIVE}`]: 'text-destructive',\n [`${LinkColor.NEUTRAL}`]: 'text-neutral',\n [`${LinkColor.LIGHT}`]: 'text-white',\n [`${LinkColor.DARK}`]: 'text-neutral-800',\n [`${LinkColor.TEXT}`]: 'text-text',\n [`${LinkColor.TEXT_INVERSE}`]: 'text-text-opposite',\n [`${LinkColor.ERROR}`]: 'text-error',\n [`${LinkColor.SUCCESS}`]: 'text-success',\n [`${LinkColor.CUSTOM}`]: '',\n },\n underlined: {\n [LinkUnderlined.DEFAULT]: '',\n [LinkUnderlined.TRUE]: 'underline',\n [LinkUnderlined.FALSE]: 'no-underline',\n },\n },\n\n defaultVariants: {\n variant: LinkVariant.DEFAULT,\n color: LinkColor.PRIMARY,\n underlined: LinkUnderlined.DEFAULT,\n },\n }\n);\n\nexport type LinkProps = DetailedHTMLProps<\n AnchorHTMLAttributes<HTMLAnchorElement>,\n HTMLAnchorElement\n> &\n VariantProps<typeof linkVariants> & {\n label: string;\n isExternalLink?: boolean;\n isActive?: boolean;\n locale?: LocalesValues;\n };\n\nexport const checkIsExternalLink = ({\n href,\n isExternalLink: isExternalLinkProp,\n}: LinkProps): boolean => {\n const isValidHref = typeof href === 'string' && href.trim() !== '';\n const isExternalLink =\n isExternalLinkProp === true ||\n (typeof isExternalLinkProp === 'undefined' &&\n isValidHref &&\n /^https?:\\/\\//.test(href));\n\n return isExternalLink;\n};\n\nexport const Link: FC<LinkProps> = (props) => {\n const {\n variant = LinkVariant.DEFAULT,\n color = LinkColor.PRIMARY,\n children,\n label,\n className,\n isActive,\n underlined,\n locale,\n isExternalLink: isExternalLinkProp,\n href: hrefProp,\n ...otherProps\n } = props;\n const { internationalization } = configuration;\n\n const isExternalLink = checkIsExternalLink(props);\n const isChildrenString = typeof children === 'string';\n\n const rel = isExternalLink ? 'noopener noreferrer nofollow' : undefined;\n\n const target = isExternalLink ? '_blank' : '_self';\n\n const hrefLang = locale\n ? locale === internationalization.defaultLocale\n ? 'x-default'\n : locale\n : undefined;\n\n const href =\n locale && hrefProp && !isExternalLink\n ? getLocalizedUrl(hrefProp, locale)\n : hrefProp;\n\n return (\n <a\n href={href}\n hrefLang={hrefLang}\n aria-label={label}\n rel={rel}\n target={target}\n aria-current={isActive ? 'page' : undefined}\n className={cn(\n linkVariants({\n variant,\n color,\n underlined,\n className,\n })\n )}\n {...otherProps}\n >\n {variant === 'button' ? <span>{children}</span> : children}\n {isExternalLink && isChildrenString && (\n <ExternalLink className=\"ml-2 inline-block size-4\" />\n )}\n </a>\n );\n};\n"],"names":["LinkVariant","LinkColor","LinkUnderlined"],"mappings":"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"}
@@ -2,6 +2,9 @@
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
3
  const components_Link_Link = require("./Link.cjs");
4
4
  exports.Link = components_Link_Link.Link;
5
+ exports.LinkColor = components_Link_Link.LinkColor;
6
+ exports.LinkUnderlined = components_Link_Link.LinkUnderlined;
7
+ exports.LinkVariant = components_Link_Link.LinkVariant;
5
8
  exports.checkIsExternalLink = components_Link_Link.checkIsExternalLink;
6
9
  exports.linkVariants = components_Link_Link.linkVariants;
7
10
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
1
+ {"version":3,"file":"index.cjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;"}
@@ -1,6 +1,9 @@
1
- import { Link, checkIsExternalLink, linkVariants } from "./Link.mjs";
1
+ import { Link, LinkColor, LinkUnderlined, LinkVariant, checkIsExternalLink, linkVariants } from "./Link.mjs";
2
2
  export {
3
3
  Link,
4
+ LinkColor,
5
+ LinkUnderlined,
6
+ LinkVariant,
4
7
  checkIsExternalLink,
5
8
  linkVariants
6
9
  };
@@ -1,32 +1,10 @@
1
1
  export declare const loaderContent: {
2
2
  key: string;
3
3
  content: {
4
- label: import('@intlayer/core').TypedNodeModel<import("@intlayer/core").NodeType.Translation, {
5
- en: string;
6
- 'en-GB': string;
7
- fr: string;
8
- es: string;
9
- de: string;
10
- ja: string;
11
- ko: string;
12
- zh: string;
13
- it: string;
14
- pt: string;
15
- }, {
4
+ label: import('@intlayer/core').TypedNodeModel<import("@intlayer/core").NodeType.Translation, import('intlayer').IConfigLocales<unknown>, {
16
5
  nodeType: import("@intlayer/core").NodeType.Translation | "translation";
17
6
  } & {
18
- translation: {
19
- en: string;
20
- 'en-GB': string;
21
- fr: string;
22
- es: string;
23
- de: string;
24
- ja: string;
25
- ko: string;
26
- zh: string;
27
- it: string;
28
- pt: string;
29
- };
7
+ translation: import('intlayer').IConfigLocales<unknown>;
30
8
  }>;
31
9
  };
32
10
  };
@@ -1 +1 @@
1
- {"version":3,"file":"index.content.d.ts","sourceRoot":"","sources":["../../../src/components/Loader/index.content.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,aAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAgBJ,CAAC;AAEvB,eAAe,aAAa,CAAC"}
1
+ {"version":3,"file":"index.content.d.ts","sourceRoot":"","sources":["../../../src/components/Loader/index.content.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,aAAa;;;;;;;;;CAgBJ,CAAC;AAEvB,eAAe,aAAa,CAAC"}
@@ -9,7 +9,7 @@ const lucideReact = require("lucide-react");
9
9
  const ReactExports = require("react");
10
10
  const reactIntlayer = require("react-intlayer");
11
11
  require("@intlayer/config/built");
12
- require("../../better-auth.8zoxzg-F-BEBqzpjz.cjs");
12
+ require("../../better-auth.CMQ3rA-I-C2nBKRMa.cjs");
13
13
  require("@intlayer/editor-react");
14
14
  require("../Toaster/Toast.cjs");
15
15
  require("../../hooks/useAsync/useAsyncStateStore.cjs");
@@ -23,7 +23,6 @@ const components_DropDown_index = require("../DropDown/index.cjs");
23
23
  const components_Input_Input = require("../Input/Input.cjs");
24
24
  require("../Input/Checkbox.cjs");
25
25
  const components_SwitchSelector_index = require("../SwitchSelector/index.cjs");
26
- const components_LocaleSwitcherContentDropDown_localeSwitcher_content = require("./localeSwitcher.content.cjs");
27
26
  const components_LocaleSwitcherContentDropDown_LocaleSwitcherContentContext = require("./LocaleSwitcherContentContext.cjs");
28
27
  const DROPDOWN_IDENTIFIER = "locale-switcher-content";
29
28
  const LocaleSwitcherContent = ({
@@ -36,7 +35,7 @@ const LocaleSwitcherContent = ({
36
35
  localeSwitcherLabel,
37
36
  languageListLabel,
38
37
  seeAllLocalesSwitch
39
- } = reactIntlayer.useDictionary(components_LocaleSwitcherContentDropDown_localeSwitcher_content);
38
+ } = reactIntlayer.useIntlayer("locale-switcher-content");
40
39
  const inputRef = ReactExports.useRef(null);
41
40
  const { locale } = reactIntlayer.useLocale();
42
41
  const { availableLocales, selectedLocales, setSelectedLocales } = components_LocaleSwitcherContentDropDown_LocaleSwitcherContentContext.useLocaleSwitcherContent();
@@ -141,8 +140,8 @@ const LocaleSwitcherContent = ({
141
140
  {
142
141
  defaultValue: false,
143
142
  onChange: handleSeeAllLocales,
144
- color: "text",
145
- size: "sm",
143
+ color: components_SwitchSelector_index.SwitchSelectorColor.TEXT,
144
+ size: components_SwitchSelector_index.SwitchSelectorSize.SM,
146
145
  className: "!w-60",
147
146
  choices: [
148
147
  {
@@ -181,11 +180,11 @@ const LocaleSwitcherContent = ({
181
180
  localeItem
182
181
  ),
183
182
  isActive: selectedLocales.includes(localeItem),
184
- variant: "hoverable",
185
- color: "text",
183
+ variant: components_Button_Button.ButtonVariant.HOVERABLE,
184
+ color: components_Button_Button.ButtonColor.TEXT,
186
185
  isFullWidth: true,
187
- textAlign: "left",
188
- size: "sm",
186
+ textAlign: components_Button_Button.ButtonTextAlign.LEFT,
187
+ size: components_Button_Button.ButtonSize.SM,
189
188
  children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-row items-center justify-between gap-3 px-2 py-1", children: [
190
189
  isMultilingual && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "w-4", children: selectedLocales.includes(localeItem) && /* @__PURE__ */ jsxRuntime.jsx(lucideReact.Check, { className: "size-full" }) }),
191
190
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1", children: [
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcherContent.cjs","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"sourcesContent":["'use client';\n\nimport { Locales, type LocalesValues } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { Check, Globe, MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useDictionary, useLocale } from 'react-intlayer';\nimport { usePersistedStore } from '../../hooks';\nimport { Button } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport { SwitchSelector } from '../SwitchSelector';\nimport localeSwitcherContent from './localeSwitcher.content';\nimport { useLocaleSwitcherContent } from './LocaleSwitcherContentContext';\n\nexport type LocaleSwitcherContentProps = {\n panelProps?: Omit<PanelProps, 'identifier'>;\n isMultilingual?: boolean;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher-content';\n\ntype MultilingualAvailableLocales = {\n locale: LocalesValues;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcherContent: FC<LocaleSwitcherContentProps> = ({\n panelProps,\n isMultilingual = true,\n}) => {\n const {\n switchTo,\n searchInput,\n localeSwitcherLabel,\n languageListLabel,\n seeAllLocalesSwitch,\n } = useDictionary(localeSwitcherContent);\n const inputRef = useRef<HTMLInputElement>(null);\n const { locale } = useLocale();\n const { availableLocales, selectedLocales, setSelectedLocales } =\n useLocaleSwitcherContent();\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n availableLocales.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [availableLocales, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n const [seeAllLocales, setSeeAllLocales] = usePersistedStore(\n 'locale-content-selector-see-all-locales',\n false\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n const handleClickLocale = (localeItem: LocalesValues) => {\n if (isMultilingual) {\n if (selectedLocales.includes(localeItem)) {\n if (selectedLocales.length > 1) {\n setSelectedLocales((prev) => prev.filter((el) => el !== localeItem));\n }\n } else {\n setSelectedLocales((prev) => [...prev, localeItem]);\n }\n } else {\n setSelectedLocales([localeItem]);\n }\n };\n\n const handleSeeAllLocales = (value: boolean) => {\n setSeeAllLocales(value);\n if (value) {\n setSelectedLocales(availableLocales);\n } else {\n setSelectedLocales([locale]);\n }\n };\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"px-2 py-1\">\n <Globe size={18} />\n </div>\n <MoveVertical className=\"self-center\" size={18} />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n className=\"left-auto right-0\"\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n border\n roundedSize=\"2xl\"\n borderColor=\"text\"\n aria-label={languageListLabel.value}\n >\n {isMultilingual && (\n <div className=\"m-auto p-2\">\n <SwitchSelector\n defaultValue={false}\n onChange={handleSeeAllLocales}\n color=\"text\"\n size=\"sm\"\n className=\"!w-60\"\n choices={[\n {\n content: seeAllLocalesSwitch.true.value,\n value: true,\n },\n {\n content: seeAllLocalesSwitch.false.value,\n value: false,\n },\n ]}\n />\n </div>\n )}\n\n {!(isMultilingual && seeAllLocales) && (\n <>\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({\n locale: localeItem,\n currentLocaleName,\n ownLocaleName,\n }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => handleClickLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? availableLocales).includes(\n localeItem\n )\n }\n isActive={selectedLocales.includes(localeItem)}\n variant=\"hoverable\"\n color=\"text\"\n isFullWidth\n textAlign=\"left\"\n size=\"sm\"\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n {isMultilingual && (\n <div className=\"w-4\">\n {selectedLocales.includes(localeItem) && (\n <Check className=\"size-full\" />\n )}\n </div>\n )}\n <div className=\"flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </>\n )}\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":["useDictionary","localeSwitcherContent","useRef","useLocale","useLocaleSwitcherContent","useMemo","getLocaleName","Locales","useState","usePersistedStore","useCallback","jsx","jsxs","DropDown","Globe","MoveVertical","Container","SwitchSelector","Fragment","Input","Button","Check","getHTMLTextDir"],"mappings":"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"}
1
+ {"version":3,"file":"LocaleSwitcherContent.cjs","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"sourcesContent":["'use client';\n\nimport { Locales, type LocalesValues } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { Check, Globe, MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useIntlayer, useLocale } from 'react-intlayer';\nimport { usePersistedStore } from '../../hooks';\nimport {\n Button,\n ButtonColor,\n ButtonSize,\n ButtonTextAlign,\n ButtonVariant,\n} from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport {\n SwitchSelector,\n SwitchSelectorColor,\n SwitchSelectorSize,\n} from '../SwitchSelector';\nimport { useLocaleSwitcherContent } from './LocaleSwitcherContentContext';\n\nexport type LocaleSwitcherContentProps = {\n panelProps?: Omit<PanelProps, 'identifier'>;\n isMultilingual?: boolean;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher-content';\n\ntype MultilingualAvailableLocales = {\n locale: LocalesValues;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcherContent: FC<LocaleSwitcherContentProps> = ({\n panelProps,\n isMultilingual = true,\n}) => {\n const {\n switchTo,\n searchInput,\n localeSwitcherLabel,\n languageListLabel,\n seeAllLocalesSwitch,\n } = useIntlayer('locale-switcher-content');\n const inputRef = useRef<HTMLInputElement>(null);\n const { locale } = useLocale();\n const { availableLocales, selectedLocales, setSelectedLocales } =\n useLocaleSwitcherContent();\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n availableLocales.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [availableLocales, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n const [seeAllLocales, setSeeAllLocales] = usePersistedStore(\n 'locale-content-selector-see-all-locales',\n false\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n const handleClickLocale = (localeItem: LocalesValues) => {\n if (isMultilingual) {\n if (selectedLocales.includes(localeItem)) {\n if (selectedLocales.length > 1) {\n setSelectedLocales((prev) => prev.filter((el) => el !== localeItem));\n }\n } else {\n setSelectedLocales((prev) => [...prev, localeItem]);\n }\n } else {\n setSelectedLocales([localeItem]);\n }\n };\n\n const handleSeeAllLocales = (value: boolean) => {\n setSeeAllLocales(value);\n if (value) {\n setSelectedLocales(availableLocales);\n } else {\n setSelectedLocales([locale]);\n }\n };\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"px-2 py-1\">\n <Globe size={18} />\n </div>\n <MoveVertical className=\"self-center\" size={18} />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n className=\"left-auto right-0\"\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n border\n roundedSize=\"2xl\"\n borderColor=\"text\"\n aria-label={languageListLabel.value}\n >\n {isMultilingual && (\n <div className=\"m-auto p-2\">\n <SwitchSelector\n defaultValue={false}\n onChange={handleSeeAllLocales}\n color={SwitchSelectorColor.TEXT}\n size={SwitchSelectorSize.SM}\n className=\"!w-60\"\n choices={[\n {\n content: seeAllLocalesSwitch.true.value,\n value: true,\n },\n {\n content: seeAllLocalesSwitch.false.value,\n value: false,\n },\n ]}\n />\n </div>\n )}\n\n {!(isMultilingual && seeAllLocales) && (\n <>\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({\n locale: localeItem,\n currentLocaleName,\n ownLocaleName,\n }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => handleClickLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? availableLocales).includes(\n localeItem\n )\n }\n isActive={selectedLocales.includes(localeItem)}\n variant={ButtonVariant.HOVERABLE}\n color={ButtonColor.TEXT}\n isFullWidth\n textAlign={ButtonTextAlign.LEFT}\n size={ButtonSize.SM}\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n {isMultilingual && (\n <div className=\"w-4\">\n {selectedLocales.includes(localeItem) && (\n <Check className=\"size-full\" />\n )}\n </div>\n )}\n <div className=\"flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </>\n )}\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":["useIntlayer","useRef","useLocale","useLocaleSwitcherContent","useMemo","getLocaleName","Locales","useState","usePersistedStore","useCallback","jsx","jsxs","DropDown","Globe","MoveVertical","Container","SwitchSelector","SwitchSelectorColor","SwitchSelectorSize","Fragment","Input","Button","ButtonVariant","ButtonColor","ButtonTextAlign","ButtonSize","Check","getHTMLTextDir"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcherContent.d.ts","sourceRoot":"","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"names":[],"mappings":"AAMA,OAAO,EAA0C,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAKxE,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AAMxD,MAAM,MAAM,0BAA0B,GAAG;IACvC,UAAU,CAAC,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;IAC5C,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B,CAAC;AAWF,eAAO,MAAM,qBAAqB,EAAE,EAAE,CAAC,0BAA0B,CA0NhE,CAAC"}
1
+ {"version":3,"file":"LocaleSwitcherContent.d.ts","sourceRoot":"","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"names":[],"mappings":"AAMA,OAAO,EAA0C,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAWxE,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AASxD,MAAM,MAAM,0BAA0B,GAAG;IACvC,UAAU,CAAC,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;IAC5C,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B,CAAC;AAWF,eAAO,MAAM,qBAAqB,EAAE,EAAE,CAAC,0BAA0B,CA0NhE,CAAC"}
@@ -5,9 +5,9 @@ import { getLocaleName, getHTMLTextDir } from "@intlayer/core";
5
5
  import Fuse from "fuse.js";
6
6
  import { Globe, MoveVertical, Check } from "lucide-react";
7
7
  import { useRef, useMemo, useState, useCallback } from "react";
8
- import { useDictionary, useLocale } from "react-intlayer";
8
+ import { useIntlayer, useLocale } from "react-intlayer";
9
9
  import "@intlayer/config/built";
10
- import "../../better-auth.8zoxzg-F-D8e0X4ys.js";
10
+ import "../../better-auth.CMQ3rA-I-7umXOENE.js";
11
11
  import "@intlayer/editor-react";
12
12
  import "../Toaster/Toast.mjs";
13
13
  import "../../hooks/useAsync/useAsyncStateStore.mjs";
@@ -15,13 +15,12 @@ import "@intlayer/api";
15
15
  import "deepmerge";
16
16
  import { usePersistedStore } from "../../hooks/usePersistedStore.mjs";
17
17
  import "../../hooks/useScrollBlockage/useScrollBlockageStore.mjs";
18
- import { Button } from "../Button/Button.mjs";
18
+ import { Button, ButtonSize, ButtonTextAlign, ButtonColor, ButtonVariant } from "../Button/Button.mjs";
19
19
  import { Container } from "../Container/index.mjs";
20
20
  import { DropDown } from "../DropDown/index.mjs";
21
21
  import { Input } from "../Input/Input.mjs";
22
22
  import "../Input/Checkbox.mjs";
23
- import { SwitchSelector } from "../SwitchSelector/index.mjs";
24
- import localeSwitcherContent from "./localeSwitcher.content.mjs";
23
+ import { SwitchSelector, SwitchSelectorSize, SwitchSelectorColor } from "../SwitchSelector/index.mjs";
25
24
  import { useLocaleSwitcherContent } from "./LocaleSwitcherContentContext.mjs";
26
25
  const DROPDOWN_IDENTIFIER = "locale-switcher-content";
27
26
  const LocaleSwitcherContent = ({
@@ -34,7 +33,7 @@ const LocaleSwitcherContent = ({
34
33
  localeSwitcherLabel,
35
34
  languageListLabel,
36
35
  seeAllLocalesSwitch
37
- } = useDictionary(localeSwitcherContent);
36
+ } = useIntlayer("locale-switcher-content");
38
37
  const inputRef = useRef(null);
39
38
  const { locale } = useLocale();
40
39
  const { availableLocales, selectedLocales, setSelectedLocales } = useLocaleSwitcherContent();
@@ -139,8 +138,8 @@ const LocaleSwitcherContent = ({
139
138
  {
140
139
  defaultValue: false,
141
140
  onChange: handleSeeAllLocales,
142
- color: "text",
143
- size: "sm",
141
+ color: SwitchSelectorColor.TEXT,
142
+ size: SwitchSelectorSize.SM,
144
143
  className: "!w-60",
145
144
  choices: [
146
145
  {
@@ -179,11 +178,11 @@ const LocaleSwitcherContent = ({
179
178
  localeItem
180
179
  ),
181
180
  isActive: selectedLocales.includes(localeItem),
182
- variant: "hoverable",
183
- color: "text",
181
+ variant: ButtonVariant.HOVERABLE,
182
+ color: ButtonColor.TEXT,
184
183
  isFullWidth: true,
185
- textAlign: "left",
186
- size: "sm",
184
+ textAlign: ButtonTextAlign.LEFT,
185
+ size: ButtonSize.SM,
187
186
  children: /* @__PURE__ */ jsxs("div", { className: "flex flex-row items-center justify-between gap-3 px-2 py-1", children: [
188
187
  isMultilingual && /* @__PURE__ */ jsx("div", { className: "w-4", children: selectedLocales.includes(localeItem) && /* @__PURE__ */ jsx(Check, { className: "size-full" }) }),
189
188
  /* @__PURE__ */ jsxs("div", { className: "flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1", children: [
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcherContent.mjs","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"sourcesContent":["'use client';\n\nimport { Locales, type LocalesValues } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { Check, Globe, MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useDictionary, useLocale } from 'react-intlayer';\nimport { usePersistedStore } from '../../hooks';\nimport { Button } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport { SwitchSelector } from '../SwitchSelector';\nimport localeSwitcherContent from './localeSwitcher.content';\nimport { useLocaleSwitcherContent } from './LocaleSwitcherContentContext';\n\nexport type LocaleSwitcherContentProps = {\n panelProps?: Omit<PanelProps, 'identifier'>;\n isMultilingual?: boolean;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher-content';\n\ntype MultilingualAvailableLocales = {\n locale: LocalesValues;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcherContent: FC<LocaleSwitcherContentProps> = ({\n panelProps,\n isMultilingual = true,\n}) => {\n const {\n switchTo,\n searchInput,\n localeSwitcherLabel,\n languageListLabel,\n seeAllLocalesSwitch,\n } = useDictionary(localeSwitcherContent);\n const inputRef = useRef<HTMLInputElement>(null);\n const { locale } = useLocale();\n const { availableLocales, selectedLocales, setSelectedLocales } =\n useLocaleSwitcherContent();\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n availableLocales.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [availableLocales, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n const [seeAllLocales, setSeeAllLocales] = usePersistedStore(\n 'locale-content-selector-see-all-locales',\n false\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n const handleClickLocale = (localeItem: LocalesValues) => {\n if (isMultilingual) {\n if (selectedLocales.includes(localeItem)) {\n if (selectedLocales.length > 1) {\n setSelectedLocales((prev) => prev.filter((el) => el !== localeItem));\n }\n } else {\n setSelectedLocales((prev) => [...prev, localeItem]);\n }\n } else {\n setSelectedLocales([localeItem]);\n }\n };\n\n const handleSeeAllLocales = (value: boolean) => {\n setSeeAllLocales(value);\n if (value) {\n setSelectedLocales(availableLocales);\n } else {\n setSelectedLocales([locale]);\n }\n };\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"px-2 py-1\">\n <Globe size={18} />\n </div>\n <MoveVertical className=\"self-center\" size={18} />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n className=\"left-auto right-0\"\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n border\n roundedSize=\"2xl\"\n borderColor=\"text\"\n aria-label={languageListLabel.value}\n >\n {isMultilingual && (\n <div className=\"m-auto p-2\">\n <SwitchSelector\n defaultValue={false}\n onChange={handleSeeAllLocales}\n color=\"text\"\n size=\"sm\"\n className=\"!w-60\"\n choices={[\n {\n content: seeAllLocalesSwitch.true.value,\n value: true,\n },\n {\n content: seeAllLocalesSwitch.false.value,\n value: false,\n },\n ]}\n />\n </div>\n )}\n\n {!(isMultilingual && seeAllLocales) && (\n <>\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({\n locale: localeItem,\n currentLocaleName,\n ownLocaleName,\n }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => handleClickLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? availableLocales).includes(\n localeItem\n )\n }\n isActive={selectedLocales.includes(localeItem)}\n variant=\"hoverable\"\n color=\"text\"\n isFullWidth\n textAlign=\"left\"\n size=\"sm\"\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n {isMultilingual && (\n <div className=\"w-4\">\n {selectedLocales.includes(localeItem) && (\n <Check className=\"size-full\" />\n )}\n </div>\n )}\n <div className=\"flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </>\n )}\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"LocaleSwitcherContent.mjs","sources":["../../../src/components/LocaleSwitcherContentDropDown/LocaleSwitcherContent.tsx"],"sourcesContent":["'use client';\n\nimport { Locales, type LocalesValues } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { Check, Globe, MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useIntlayer, useLocale } from 'react-intlayer';\nimport { usePersistedStore } from '../../hooks';\nimport {\n Button,\n ButtonColor,\n ButtonSize,\n ButtonTextAlign,\n ButtonVariant,\n} from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport {\n SwitchSelector,\n SwitchSelectorColor,\n SwitchSelectorSize,\n} from '../SwitchSelector';\nimport { useLocaleSwitcherContent } from './LocaleSwitcherContentContext';\n\nexport type LocaleSwitcherContentProps = {\n panelProps?: Omit<PanelProps, 'identifier'>;\n isMultilingual?: boolean;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher-content';\n\ntype MultilingualAvailableLocales = {\n locale: LocalesValues;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcherContent: FC<LocaleSwitcherContentProps> = ({\n panelProps,\n isMultilingual = true,\n}) => {\n const {\n switchTo,\n searchInput,\n localeSwitcherLabel,\n languageListLabel,\n seeAllLocalesSwitch,\n } = useIntlayer('locale-switcher-content');\n const inputRef = useRef<HTMLInputElement>(null);\n const { locale } = useLocale();\n const { availableLocales, selectedLocales, setSelectedLocales } =\n useLocaleSwitcherContent();\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n availableLocales.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [availableLocales, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n const [seeAllLocales, setSeeAllLocales] = usePersistedStore(\n 'locale-content-selector-see-all-locales',\n false\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n const handleClickLocale = (localeItem: LocalesValues) => {\n if (isMultilingual) {\n if (selectedLocales.includes(localeItem)) {\n if (selectedLocales.length > 1) {\n setSelectedLocales((prev) => prev.filter((el) => el !== localeItem));\n }\n } else {\n setSelectedLocales((prev) => [...prev, localeItem]);\n }\n } else {\n setSelectedLocales([localeItem]);\n }\n };\n\n const handleSeeAllLocales = (value: boolean) => {\n setSeeAllLocales(value);\n if (value) {\n setSelectedLocales(availableLocales);\n } else {\n setSelectedLocales([locale]);\n }\n };\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"px-2 py-1\">\n <Globe size={18} />\n </div>\n <MoveVertical className=\"self-center\" size={18} />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n className=\"left-auto right-0\"\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n border\n roundedSize=\"2xl\"\n borderColor=\"text\"\n aria-label={languageListLabel.value}\n >\n {isMultilingual && (\n <div className=\"m-auto p-2\">\n <SwitchSelector\n defaultValue={false}\n onChange={handleSeeAllLocales}\n color={SwitchSelectorColor.TEXT}\n size={SwitchSelectorSize.SM}\n className=\"!w-60\"\n choices={[\n {\n content: seeAllLocalesSwitch.true.value,\n value: true,\n },\n {\n content: seeAllLocalesSwitch.false.value,\n value: false,\n },\n ]}\n />\n </div>\n )}\n\n {!(isMultilingual && seeAllLocales) && (\n <>\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({\n locale: localeItem,\n currentLocaleName,\n ownLocaleName,\n }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => handleClickLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? availableLocales).includes(\n localeItem\n )\n }\n isActive={selectedLocales.includes(localeItem)}\n variant={ButtonVariant.HOVERABLE}\n color={ButtonColor.TEXT}\n isFullWidth\n textAlign={ButtonTextAlign.LEFT}\n size={ButtonSize.SM}\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n {isMultilingual && (\n <div className=\"w-4\">\n {selectedLocales.includes(localeItem) && (\n <Check className=\"size-full\" />\n )}\n </div>\n )}\n <div className=\"flex flex-1 flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </>\n )}\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
@@ -5,7 +5,7 @@ const jsxRuntime = require("react/jsx-runtime");
5
5
  const ReactExports = require("react");
6
6
  const reactIntlayer = require("react-intlayer");
7
7
  require("@intlayer/config/built");
8
- require("../../better-auth.8zoxzg-F-BEBqzpjz.cjs");
8
+ require("../../better-auth.CMQ3rA-I-C2nBKRMa.cjs");
9
9
  require("@intlayer/editor-react");
10
10
  require("../Toaster/Toast.cjs");
11
11
  require("../../hooks/useAsync/useAsyncStateStore.cjs");
@@ -3,7 +3,7 @@ import { jsx } from "react/jsx-runtime";
3
3
  import { createContext, useContext } from "react";
4
4
  import { useLocale } from "react-intlayer";
5
5
  import "@intlayer/config/built";
6
- import "../../better-auth.8zoxzg-F-D8e0X4ys.js";
6
+ import "../../better-auth.CMQ3rA-I-7umXOENE.js";
7
7
  import "@intlayer/editor-react";
8
8
  import "../Toaster/Toast.mjs";
9
9
  import "../../hooks/useAsync/useAsyncStateStore.mjs";
@@ -13,7 +13,6 @@ const components_Container_index = require("../Container/index.cjs");
13
13
  const components_DropDown_index = require("../DropDown/index.cjs");
14
14
  const components_Input_Input = require("../Input/Input.cjs");
15
15
  require("../Input/Checkbox.cjs");
16
- const components_LocaleSwitcherDropDown_localeSwitcher_content = require("./localeSwitcher.content.cjs");
17
16
  const DROPDOWN_IDENTIFIER = "locale-switcher";
18
17
  const LocaleSwitcher = ({
19
18
  locale,
@@ -24,7 +23,7 @@ const LocaleSwitcher = ({
24
23
  panelProps
25
24
  }) => {
26
25
  let localeName = "Select a locale";
27
- const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } = reactIntlayer.useDictionary(components_LocaleSwitcherDropDown_localeSwitcher_content);
26
+ const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } = reactIntlayer.useIntlayer("locale-switcher");
28
27
  const inputRef = ReactExports.useRef(null);
29
28
  const multilingualAvailableLocales = ReactExports.useMemo(
30
29
  () => localeList.map((localeEl) => {
@@ -114,10 +113,10 @@ const LocaleSwitcher = ({
114
113
  label: `${switchTo} ${currentLocaleName}`,
115
114
  disabled: !(availableLocales ?? localeList).includes(localeItem),
116
115
  isActive: locale === localeItem,
117
- variant: "hoverable",
118
- color: "text",
116
+ variant: components_Button_Button.ButtonVariant.HOVERABLE,
117
+ color: components_Button_Button.ButtonColor.TEXT,
119
118
  isFullWidth: true,
120
- textAlign: "left",
119
+ textAlign: components_Button_Button.ButtonTextAlign.LEFT,
121
120
  children: /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-row items-center justify-between gap-3 px-2 py-1", children: [
122
121
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-col text-nowrap", children: [
123
122
  /* @__PURE__ */ jsxRuntime.jsx(
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcher.cjs","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"sourcesContent":["'use client';\n\nimport { Locales } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useDictionary } from 'react-intlayer';\nimport { Button } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport localeSwitcherContent from './localeSwitcher.content';\n\nexport type LocaleSwitcherProps = {\n locale?: Locales;\n localeList: Locales[];\n availableLocales?: Locales[];\n fullLocaleName?: boolean;\n setLocale: (locale: Locales) => void;\n panelProps?: Omit<PanelProps, 'identifier'>;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher';\n\ntype MultilingualAvailableLocales = {\n locale: Locales;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcher: FC<LocaleSwitcherProps> = ({\n locale,\n localeList,\n availableLocales,\n fullLocaleName = true,\n setLocale,\n panelProps,\n}) => {\n let localeName = 'Select a locale';\n const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } =\n useDictionary(localeSwitcherContent);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n localeList.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [localeList, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n if (locale) {\n localeName = fullLocaleName ? getLocaleName(locale) : locale.toUpperCase();\n }\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"text-nowrap px-2\">{localeName}</div>\n <MoveVertical className=\"w-5 self-center\" />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n aria-label={languageListLabel.value}\n >\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({ locale: localeItem, currentLocaleName, ownLocaleName }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => setLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? localeList).includes(localeItem)\n }\n isActive={locale === localeItem}\n variant=\"hoverable\"\n color=\"text\"\n isFullWidth\n textAlign=\"left\"\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":["useDictionary","localeSwitcherContent","useRef","useMemo","getLocaleName","Locales","useState","useCallback","jsx","jsxs","DropDown","MoveVertical","Container","Input","Button","getHTMLTextDir"],"mappings":";;;;;;;;;;;;;;;;AAuBA,MAAM,sBAAsB;AASrB,MAAM,iBAA0C,CAAC;AAAA,EACtD;AAAA,EACA;AAAA,EACA;AAAA,EACA,iBAAiB;AAAA,EACjB;AAAA,EACA;AACF,MAAM;AACJ,MAAI,aAAa;AACjB,QAAM,EAAE,UAAU,aAAa,qBAAqB,kBAAA,IAClDA,cAAAA,cAAcC,wDAAqB;AACrC,QAAM,WAAWC,aAAAA,OAAyB,IAAI;AAE9C,QAAM,+BAA+DC,aAAAA;AAAAA,IACnE,MACE,WAAW,IAAI,CAAC,aAAa;AAC3B,YAAM,cAAcC,KAAAA,cAAc,UAAUC,OAAAA,QAAQ,OAAO;AAC3D,YAAM,oBAAoBD,KAAAA,cAAc,UAAU,MAAM;AACxD,YAAM,gBAAgBA,KAAAA,cAAc,QAAQ;AAC5C,aAAO;AAAA,QACL,QAAQ;AAAA,QACR;AAAA,QACA;AAAA,QACA;AAAA,MAAA;AAAA,IAEJ,CAAC;AAAA,IACH,CAAC,YAAY,MAAM;AAAA,EAAA;AAGrB,QAAM,CAAC,SAAS,UAAU,IAAIE,aAAAA;AAAAA,IAC5B;AAAA,EAAA;AAIF,QAAM,OAAOH,aAAAA,QAAQ,MAAM;AACzB,UAAM,cAA0D;AAAA,MAC9D,MAAM;AAAA,QACJ,EAAE,MAAM,iBAAiB,QAAQ,IAAA;AAAA,QACjC,EAAE,MAAM,eAAe,QAAQ,IAAA;AAAA,QAC/B,EAAE,MAAM,qBAAqB,QAAQ,IAAA;AAAA,QACrC,EAAE,MAAM,UAAU,QAAQ,IAAA;AAAA,MAAI;AAAA,MAEhC,WAAW;AAAA;AAAA,IAAA;AAGb,WAAO,IAAI,KAAK,8BAA8B,WAAW;AAAA,EAC3D,GAAG,CAAC,4BAA4B,CAAC;AAEjC,QAAM,eAAeI,aAAAA;AAAAA,IACnB,CAAC,gBAAwB;AACvB,UAAI,aAAa;AAEf,cAAM,gBAAgB,KACnB,OAAO,WAAW,EAClB,IAAI,CAAC,WAAW,OAAO,IAAI;AAC9B,mBAAW,aAAa;AAAA,MAC1B,OAAO;AACL,mBAAW,4BAA4B;AAAA,MACzC;AAAA,IACF;AAAA,IACA,CAAC,MAAM,4BAA4B;AAAA,EAAA;AAGrC,MAAI,QAAQ;AACV,iBAAa,iBAAiBH,KAAAA,cAAc,MAAM,IAAI,OAAO,YAAA;AAAA,EAC/D;AAEA,SACEI,2BAAAA;AAAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAU;AAAA,MACV,cAAY,oBAAoB;AAAA,MAEhC,UAAAC,2BAAAA,KAACC,0BAAAA,UAAA,EAAS,YAAY,qBACpB,UAAA;AAAA,QAAAF,2BAAAA,IAACE,0BAAAA,SAAS,SAAT,EAAiB,YAAY,qBAC5B,UAAAD,2BAAAA,KAAC,OAAA,EAAI,WAAU,4CACb,UAAA;AAAA,UAAAD,2BAAAA,IAAC,OAAA,EAAI,WAAU,oBAAoB,UAAA,YAAW;AAAA,UAC9CA,2BAAAA,IAACG,YAAAA,cAAA,EAAa,WAAU,kBAAA,CAAkB;AAAA,QAAA,EAAA,CAC5C,EAAA,CACF;AAAA,QAEAH,2BAAAA;AAAAA,UAACE,0BAAAA,SAAS;AAAA,UAAT;AAAA,YACC,YAAY;AAAA,YACZ,YAAU;AAAA,YACV,aAAW;AAAA,YACV,GAAG;AAAA,YAEJ,UAAAD,2BAAAA;AAAAA,cAACG,2BAAAA;AAAAA,cAAA;AAAA,gBACC,WAAU;AAAA,gBACV,WAAU;AAAA,gBACV,MAAK;AAAA,gBACL,cAAa;AAAA,gBACb,cAAY,kBAAkB;AAAA,gBAE9B,UAAA;AAAA,kBAAAJ,2BAAAA,IAAC,OAAA,EAAI,WAAU,OACb,UAAAA,2BAAAA;AAAAA,oBAACK,uBAAAA;AAAAA,oBAAA;AAAA,sBACC,MAAK;AAAA,sBACL,cAAY,YAAY,UAAU;AAAA,sBAClC,aAAa,YAAY,YAAY;AAAA,sBACrC,UAAU,CAAC,MAAM,aAAa,EAAE,OAAO,KAAK;AAAA,sBAC5C,KAAK;AAAA,oBAAA;AAAA,kBAAA,GAET;AAAA,kBACAL,2BAAAA,IAAC,MAAA,EAAG,WAAU,6DACX,UAAA,QAAQ;AAAA,oBACP,CAAC,EAAE,QAAQ,YAAY,mBAAmB,oBACxCA,+BAAC,MAAA,EAAG,WAAU,eACZ,UAAAA,2BAAAA;AAAAA,sBAACM,yBAAAA;AAAAA,sBAAA;AAAA,wBACC,SAAS,MAAM,UAAU,UAAU;AAAA,wBACnC,OAAO,GAAG,QAAQ,IAAI,iBAAiB;AAAA,wBACvC,UACE,EAAE,oBAAoB,YAAY,SAAS,UAAU;AAAA,wBAEvD,UAAU,WAAW;AAAA,wBACrB,SAAQ;AAAA,wBACR,OAAM;AAAA,wBACN,aAAW;AAAA,wBACX,WAAU;AAAA,wBAEV,UAAAL,2BAAAA,KAAC,OAAA,EAAI,WAAU,8DACb,UAAA;AAAA,0BAAAA,2BAAAA,KAAC,OAAA,EAAI,WAAU,6BACb,UAAA;AAAA,4BAAAD,2BAAAA;AAAAA,8BAAC;AAAA,8BAAA;AAAA,gCACC,KAAKO,KAAAA,eAAe,UAAU;AAAA,gCAC9B,MAAM;AAAA,gCAEL,UAAA;AAAA,8BAAA;AAAA,4BAAA;AAAA,4BAEHP,2BAAAA,IAAC,QAAA,EAAK,WAAU,wBACb,UAAA,kBAAA,CACH;AAAA,0BAAA,GACF;AAAA,yDACC,QAAA,EAAK,WAAU,wBACb,UAAA,WAAW,cAAY,CAC1B;AAAA,wBAAA,EAAA,CACF;AAAA,sBAAA;AAAA,oBAAA,KA5B6B,UA8BjC;AAAA,kBAAA,EAEJ,CACF;AAAA,gBAAA;AAAA,cAAA;AAAA,YAAA;AAAA,UACF;AAAA,QAAA;AAAA,MACF,EAAA,CACF;AAAA,IAAA;AAAA,EAAA;AAGN;;"}
1
+ {"version":3,"file":"LocaleSwitcher.cjs","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"sourcesContent":["'use client';\n\nimport { Locales } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useIntlayer } from 'react-intlayer';\nimport { Button, ButtonColor, ButtonTextAlign, ButtonVariant } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\n\nexport type LocaleSwitcherProps = {\n locale?: Locales;\n localeList: Locales[];\n availableLocales?: Locales[];\n fullLocaleName?: boolean;\n setLocale: (locale: Locales) => void;\n panelProps?: Omit<PanelProps, 'identifier'>;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher';\n\ntype MultilingualAvailableLocales = {\n locale: Locales;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcher: FC<LocaleSwitcherProps> = ({\n locale,\n localeList,\n availableLocales,\n fullLocaleName = true,\n setLocale,\n panelProps,\n}) => {\n let localeName = 'Select a locale';\n const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } =\n useIntlayer('locale-switcher');\n const inputRef = useRef<HTMLInputElement>(null);\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n localeList.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [localeList, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n if (locale) {\n localeName = fullLocaleName ? getLocaleName(locale) : locale.toUpperCase();\n }\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"text-nowrap px-2\">{localeName}</div>\n <MoveVertical className=\"w-5 self-center\" />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n aria-label={languageListLabel.value}\n >\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({ locale: localeItem, currentLocaleName, ownLocaleName }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => setLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? localeList).includes(localeItem)\n }\n isActive={locale === localeItem}\n variant={ButtonVariant.HOVERABLE}\n color={ButtonColor.TEXT}\n isFullWidth\n textAlign={ButtonTextAlign.LEFT}\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":["useIntlayer","useRef","useMemo","getLocaleName","Locales","useState","useCallback","jsx","jsxs","DropDown","MoveVertical","Container","Input","Button","ButtonVariant","ButtonColor","ButtonTextAlign","getHTMLTextDir"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcher.d.ts","sourceRoot":"","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAIlD,OAAO,EAA0C,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAIxE,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AAIxD,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,OAAO,EAAE,CAAC;IAC7B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,UAAU,CAAC,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;CAC7C,CAAC;AAWF,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CAgJlD,CAAC"}
1
+ {"version":3,"file":"LocaleSwitcher.d.ts","sourceRoot":"","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,yBAAyB,CAAC;AAIlD,OAAO,EAA0C,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAIxE,OAAO,EAAY,KAAK,UAAU,EAAE,MAAM,aAAa,CAAC;AAGxD,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,OAAO,EAAE,CAAC;IACtB,gBAAgB,CAAC,EAAE,OAAO,EAAE,CAAC;IAC7B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;IACrC,UAAU,CAAC,EAAE,IAAI,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;CAC7C,CAAC;AAWF,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,mBAAmB,CAgJlD,CAAC"}
@@ -5,13 +5,12 @@ import { getLocaleName, getHTMLTextDir } from "@intlayer/core";
5
5
  import Fuse from "fuse.js";
6
6
  import { MoveVertical } from "lucide-react";
7
7
  import { useRef, useMemo, useState, useCallback } from "react";
8
- import { useDictionary } from "react-intlayer";
9
- import { Button } from "../Button/Button.mjs";
8
+ import { useIntlayer } from "react-intlayer";
9
+ import { Button, ButtonTextAlign, ButtonColor, ButtonVariant } from "../Button/Button.mjs";
10
10
  import { Container } from "../Container/index.mjs";
11
11
  import { DropDown } from "../DropDown/index.mjs";
12
12
  import { Input } from "../Input/Input.mjs";
13
13
  import "../Input/Checkbox.mjs";
14
- import localeSwitcherContent from "./localeSwitcher.content.mjs";
15
14
  const DROPDOWN_IDENTIFIER = "locale-switcher";
16
15
  const LocaleSwitcher = ({
17
16
  locale,
@@ -22,7 +21,7 @@ const LocaleSwitcher = ({
22
21
  panelProps
23
22
  }) => {
24
23
  let localeName = "Select a locale";
25
- const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } = useDictionary(localeSwitcherContent);
24
+ const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } = useIntlayer("locale-switcher");
26
25
  const inputRef = useRef(null);
27
26
  const multilingualAvailableLocales = useMemo(
28
27
  () => localeList.map((localeEl) => {
@@ -112,10 +111,10 @@ const LocaleSwitcher = ({
112
111
  label: `${switchTo} ${currentLocaleName}`,
113
112
  disabled: !(availableLocales ?? localeList).includes(localeItem),
114
113
  isActive: locale === localeItem,
115
- variant: "hoverable",
116
- color: "text",
114
+ variant: ButtonVariant.HOVERABLE,
115
+ color: ButtonColor.TEXT,
117
116
  isFullWidth: true,
118
- textAlign: "left",
117
+ textAlign: ButtonTextAlign.LEFT,
119
118
  children: /* @__PURE__ */ jsxs("div", { className: "flex flex-row items-center justify-between gap-3 px-2 py-1", children: [
120
119
  /* @__PURE__ */ jsxs("div", { className: "flex flex-col text-nowrap", children: [
121
120
  /* @__PURE__ */ jsx(
@@ -1 +1 @@
1
- {"version":3,"file":"LocaleSwitcher.mjs","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"sourcesContent":["'use client';\n\nimport { Locales } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useDictionary } from 'react-intlayer';\nimport { Button } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\nimport localeSwitcherContent from './localeSwitcher.content';\n\nexport type LocaleSwitcherProps = {\n locale?: Locales;\n localeList: Locales[];\n availableLocales?: Locales[];\n fullLocaleName?: boolean;\n setLocale: (locale: Locales) => void;\n panelProps?: Omit<PanelProps, 'identifier'>;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher';\n\ntype MultilingualAvailableLocales = {\n locale: Locales;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcher: FC<LocaleSwitcherProps> = ({\n locale,\n localeList,\n availableLocales,\n fullLocaleName = true,\n setLocale,\n panelProps,\n}) => {\n let localeName = 'Select a locale';\n const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } =\n useDictionary(localeSwitcherContent);\n const inputRef = useRef<HTMLInputElement>(null);\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n localeList.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [localeList, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n if (locale) {\n localeName = fullLocaleName ? getLocaleName(locale) : locale.toUpperCase();\n }\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"text-nowrap px-2\">{localeName}</div>\n <MoveVertical className=\"w-5 self-center\" />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n aria-label={languageListLabel.value}\n >\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({ locale: localeItem, currentLocaleName, ownLocaleName }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => setLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? localeList).includes(localeItem)\n }\n isActive={locale === localeItem}\n variant=\"hoverable\"\n color=\"text\"\n isFullWidth\n textAlign=\"left\"\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"LocaleSwitcher.mjs","sources":["../../../src/components/LocaleSwitcherDropDown/LocaleSwitcher.tsx"],"sourcesContent":["'use client';\n\nimport { Locales } from '@intlayer/config/client';\nimport { getHTMLTextDir, getLocaleName } from '@intlayer/core';\nimport Fuse, { type IFuseOptions } from 'fuse.js';\nimport { MoveVertical } from 'lucide-react';\nimport { useCallback, useMemo, useRef, useState, type FC } from 'react';\nimport { useIntlayer } from 'react-intlayer';\nimport { Button, ButtonColor, ButtonTextAlign, ButtonVariant } from '../Button';\nimport { Container } from '../Container';\nimport { DropDown, type PanelProps } from '../DropDown';\nimport { Input } from '../Input';\n\nexport type LocaleSwitcherProps = {\n locale?: Locales;\n localeList: Locales[];\n availableLocales?: Locales[];\n fullLocaleName?: boolean;\n setLocale: (locale: Locales) => void;\n panelProps?: Omit<PanelProps, 'identifier'>;\n};\n\nconst DROPDOWN_IDENTIFIER = 'locale-switcher';\n\ntype MultilingualAvailableLocales = {\n locale: Locales;\n englishName: string;\n currentLocaleName: string;\n ownLocaleName: string;\n};\n\nexport const LocaleSwitcher: FC<LocaleSwitcherProps> = ({\n locale,\n localeList,\n availableLocales,\n fullLocaleName = true,\n setLocale,\n panelProps,\n}) => {\n let localeName = 'Select a locale';\n const { switchTo, searchInput, localeSwitcherLabel, languageListLabel } =\n useIntlayer('locale-switcher');\n const inputRef = useRef<HTMLInputElement>(null);\n\n const multilingualAvailableLocales: MultilingualAvailableLocales[] = useMemo(\n () =>\n localeList.map((localeEl) => {\n const englishName = getLocaleName(localeEl, Locales.ENGLISH);\n const currentLocaleName = getLocaleName(localeEl, locale);\n const ownLocaleName = getLocaleName(localeEl);\n return {\n locale: localeEl,\n englishName,\n currentLocaleName,\n ownLocaleName,\n };\n }),\n [localeList, locale]\n );\n\n const [results, setResults] = useState<MultilingualAvailableLocales[]>(\n multilingualAvailableLocales\n );\n\n // Create a new Fuse instance with the options and documentation data\n const fuse = useMemo(() => {\n const fuseOptions: IFuseOptions<MultilingualAvailableLocales> = {\n keys: [\n { name: 'ownLocaleName', weight: 0.4 },\n { name: 'englishName', weight: 0.2 },\n { name: 'currentLocaleName', weight: 0.2 },\n { name: 'locale', weight: 0.2 },\n ],\n threshold: 0.02, // Defines how fuzzy the matching should be (lower is more strict)\n };\n\n return new Fuse(multilingualAvailableLocales, fuseOptions);\n }, [multilingualAvailableLocales]);\n\n const handleSearch = useCallback(\n (searchQuery: string) => {\n if (searchQuery) {\n // Perform search on every input change\n const searchResults = fuse\n .search(searchQuery)\n .map((result) => result.item);\n setResults(searchResults);\n } else {\n setResults(multilingualAvailableLocales);\n }\n },\n [fuse, multilingualAvailableLocales]\n );\n\n if (locale) {\n localeName = fullLocaleName ? getLocaleName(locale) : locale.toUpperCase();\n }\n\n return (\n <div\n className=\"border-text text-text rounded-xl border transition-colors\"\n aria-label={localeSwitcherLabel.value}\n >\n <DropDown identifier={DROPDOWN_IDENTIFIER}>\n <DropDown.Trigger identifier={DROPDOWN_IDENTIFIER}>\n <div className=\"flex w-full items-center justify-between\">\n <div className=\"text-nowrap px-2\">{localeName}</div>\n <MoveVertical className=\"w-5 self-center\" />\n </div>\n </DropDown.Trigger>\n\n <DropDown.Panel\n identifier={DROPDOWN_IDENTIFIER}\n isOverable\n isFocusable\n {...panelProps}\n >\n <Container\n className=\"max-h-[80vh] min-w-28\"\n separator=\"y\"\n role=\"listbox\"\n transparency=\"sm\"\n aria-label={languageListLabel.value}\n >\n <div className=\"p-3\">\n <Input\n type=\"search\"\n aria-label={searchInput.ariaLabel.value}\n placeholder={searchInput.placeholder.value}\n onChange={(e) => handleSearch(e.target.value)}\n ref={inputRef}\n />\n </div>\n <ol className=\"divide-text/20 divide-y divide-dashed overflow-y-auto p-1\">\n {results.map(\n ({ locale: localeItem, currentLocaleName, ownLocaleName }) => (\n <li className=\"px-1.5 py-1\" key={localeItem}>\n <Button\n onClick={() => setLocale(localeItem)}\n label={`${switchTo} ${currentLocaleName}`}\n disabled={\n !(availableLocales ?? localeList).includes(localeItem)\n }\n isActive={locale === localeItem}\n variant={ButtonVariant.HOVERABLE}\n color={ButtonColor.TEXT}\n isFullWidth\n textAlign={ButtonTextAlign.LEFT}\n >\n <div className=\"flex flex-row items-center justify-between gap-3 px-2 py-1\">\n <div className=\"flex flex-col text-nowrap\">\n <span\n dir={getHTMLTextDir(localeItem)}\n lang={localeItem}\n >\n {ownLocaleName}\n </span>\n <span className=\"text-neutral text-xs\">\n {currentLocaleName}\n </span>\n </div>\n <span className=\"text-neutral text-sm\">\n {localeItem.toUpperCase()}\n </span>\n </div>\n </Button>\n </li>\n )\n )}\n </ol>\n </Container>\n </DropDown.Panel>\n </DropDown>\n </div>\n );\n};\n"],"names":[],"mappings":"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"}