@economic/taco 1.0.5 → 1.0.6

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 (614) hide show
  1. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js +35 -0
  2. package/dist/esm/_virtual/_rollupPluginBabelHelpers.js.map +1 -0
  3. package/dist/esm/components/Accordion/Accordion.js +93 -0
  4. package/dist/esm/components/Accordion/Accordion.js.map +1 -0
  5. package/dist/esm/components/Backdrop/Backdrop.js +13 -0
  6. package/dist/esm/components/Backdrop/Backdrop.js.map +1 -0
  7. package/dist/esm/components/Badge/Badge.js +32 -0
  8. package/dist/esm/components/Badge/Badge.js.map +1 -0
  9. package/dist/esm/components/Banner/Banner.js +24 -0
  10. package/dist/esm/components/Banner/Banner.js.map +1 -0
  11. package/dist/esm/components/Banner/util.js +36 -0
  12. package/dist/esm/components/Banner/util.js.map +1 -0
  13. package/dist/esm/components/Button/Button.js +36 -0
  14. package/dist/esm/components/Button/Button.js.map +1 -0
  15. package/dist/esm/components/Button/util.js +77 -0
  16. package/dist/esm/components/Button/util.js.map +1 -0
  17. package/dist/esm/components/Calendar/Calendar.js +152 -0
  18. package/dist/esm/components/Calendar/Calendar.js.map +1 -0
  19. package/dist/esm/components/Checkbox/Checkbox.js +58 -0
  20. package/dist/esm/components/Checkbox/Checkbox.js.map +1 -0
  21. package/dist/esm/components/Combobox/Combobox.js +89 -0
  22. package/dist/esm/components/Combobox/Combobox.js.map +1 -0
  23. package/dist/esm/components/Combobox/useCombobox.js +285 -0
  24. package/dist/esm/components/Combobox/useCombobox.js.map +1 -0
  25. package/dist/esm/components/Datepicker/Datepicker.js +75 -0
  26. package/dist/esm/components/Datepicker/Datepicker.js.map +1 -0
  27. package/dist/esm/components/Datepicker/useDatepicker.js +88 -0
  28. package/dist/esm/components/Datepicker/useDatepicker.js.map +1 -0
  29. package/dist/esm/components/Dialog/Context.js +26 -0
  30. package/dist/esm/components/Dialog/Context.js.map +1 -0
  31. package/dist/esm/components/Dialog/Dialog.js +98 -0
  32. package/dist/esm/components/Dialog/Dialog.js.map +1 -0
  33. package/dist/esm/components/Dialog/components/Content.js +135 -0
  34. package/dist/esm/components/Dialog/components/Content.js.map +1 -0
  35. package/dist/esm/components/Dialog/components/Drawer.js +42 -0
  36. package/dist/esm/components/Dialog/components/Drawer.js.map +1 -0
  37. package/dist/esm/components/Dialog/components/Extra.js +15 -0
  38. package/dist/esm/components/Dialog/components/Extra.js.map +1 -0
  39. package/dist/esm/components/Dialog/components/Trigger.js +15 -0
  40. package/dist/esm/components/Dialog/components/Trigger.js.map +1 -0
  41. package/dist/esm/components/Field/Field.js +33 -0
  42. package/dist/esm/components/Field/Field.js.map +1 -0
  43. package/dist/esm/components/Form/Form.js +22 -0
  44. package/dist/esm/components/Form/Form.js.map +1 -0
  45. package/dist/esm/components/Group/Group.js +20 -0
  46. package/dist/esm/components/Group/Group.js.map +1 -0
  47. package/dist/esm/components/Hanger/Hanger.js +104 -0
  48. package/dist/esm/components/Hanger/Hanger.js.map +1 -0
  49. package/dist/esm/components/HoverCard/HoverCard.js +33 -0
  50. package/dist/esm/components/HoverCard/HoverCard.js.map +1 -0
  51. package/dist/esm/components/Icon/Icon.js +30 -0
  52. package/dist/esm/components/Icon/Icon.js.map +1 -0
  53. package/dist/esm/components/Icon/components/AccountPreview.js +18 -0
  54. package/dist/esm/components/Icon/components/AccountPreview.js.map +1 -0
  55. package/dist/esm/components/Icon/components/Accounting.js +18 -0
  56. package/dist/esm/components/Icon/components/Accounting.js.map +1 -0
  57. package/dist/esm/components/Icon/components/AccountingYear.js +18 -0
  58. package/dist/esm/components/Icon/components/AccountingYear.js.map +1 -0
  59. package/dist/esm/components/Icon/components/AccountingYearCancel.js +18 -0
  60. package/dist/esm/components/Icon/components/AccountingYearCancel.js.map +1 -0
  61. package/dist/esm/components/Icon/components/ArrowBottom.js +18 -0
  62. package/dist/esm/components/Icon/components/ArrowBottom.js.map +1 -0
  63. package/dist/esm/components/Icon/components/ArrowDown.js +18 -0
  64. package/dist/esm/components/Icon/components/ArrowDown.js.map +1 -0
  65. package/dist/esm/components/Icon/components/ArrowEnd.js +18 -0
  66. package/dist/esm/components/Icon/components/ArrowEnd.js.map +1 -0
  67. package/dist/esm/components/Icon/components/ArrowLeft.js +18 -0
  68. package/dist/esm/components/Icon/components/ArrowLeft.js.map +1 -0
  69. package/dist/esm/components/Icon/components/ArrowRight.js +18 -0
  70. package/dist/esm/components/Icon/components/ArrowRight.js.map +1 -0
  71. package/dist/esm/components/Icon/components/ArrowStart.js +18 -0
  72. package/dist/esm/components/Icon/components/ArrowStart.js.map +1 -0
  73. package/dist/esm/components/Icon/components/ArrowTop.js +18 -0
  74. package/dist/esm/components/Icon/components/ArrowTop.js.map +1 -0
  75. package/dist/esm/components/Icon/components/ArrowUp.js +18 -0
  76. package/dist/esm/components/Icon/components/ArrowUp.js.map +1 -0
  77. package/dist/esm/components/Icon/components/Attach.js +18 -0
  78. package/dist/esm/components/Icon/components/Attach.js.map +1 -0
  79. package/dist/esm/components/Icon/components/AttachAuto.js +18 -0
  80. package/dist/esm/components/Icon/components/AttachAuto.js.map +1 -0
  81. package/dist/esm/components/Icon/components/AttachCancel.js +18 -0
  82. package/dist/esm/components/Icon/components/AttachCancel.js.map +1 -0
  83. package/dist/esm/components/Icon/components/Autotext.js +18 -0
  84. package/dist/esm/components/Icon/components/Autotext.js.map +1 -0
  85. package/dist/esm/components/Icon/components/AutotextInsert.js +18 -0
  86. package/dist/esm/components/Icon/components/AutotextInsert.js.map +1 -0
  87. package/dist/esm/components/Icon/components/Basic.js +18 -0
  88. package/dist/esm/components/Icon/components/Basic.js.map +1 -0
  89. package/dist/esm/components/Icon/components/BasicTabs.js +18 -0
  90. package/dist/esm/components/Icon/components/BasicTabs.js.map +1 -0
  91. package/dist/esm/components/Icon/components/BellSolid.js +18 -0
  92. package/dist/esm/components/Icon/components/BellSolid.js.map +1 -0
  93. package/dist/esm/components/Icon/components/Book.js +18 -0
  94. package/dist/esm/components/Icon/components/Book.js.map +1 -0
  95. package/dist/esm/components/Icon/components/Booking.js +18 -0
  96. package/dist/esm/components/Icon/components/Booking.js.map +1 -0
  97. package/dist/esm/components/Icon/components/Budget.js +18 -0
  98. package/dist/esm/components/Icon/components/Budget.js.map +1 -0
  99. package/dist/esm/components/Icon/components/Calendar.js +18 -0
  100. package/dist/esm/components/Icon/components/Calendar.js.map +1 -0
  101. package/dist/esm/components/Icon/components/CashAccount.js +17 -0
  102. package/dist/esm/components/Icon/components/CashAccount.js.map +1 -0
  103. package/dist/esm/components/Icon/components/CashReports.js +18 -0
  104. package/dist/esm/components/Icon/components/CashReports.js.map +1 -0
  105. package/dist/esm/components/Icon/components/Chat.js +18 -0
  106. package/dist/esm/components/Icon/components/Chat.js.map +1 -0
  107. package/dist/esm/components/Icon/components/ChatSolid.js +18 -0
  108. package/dist/esm/components/Icon/components/ChatSolid.js.map +1 -0
  109. package/dist/esm/components/Icon/components/ChevronDown.js +18 -0
  110. package/dist/esm/components/Icon/components/ChevronDown.js.map +1 -0
  111. package/dist/esm/components/Icon/components/ChevronDownDouble.js +18 -0
  112. package/dist/esm/components/Icon/components/ChevronDownDouble.js.map +1 -0
  113. package/dist/esm/components/Icon/components/ChevronDownSolid.js +18 -0
  114. package/dist/esm/components/Icon/components/ChevronDownSolid.js.map +1 -0
  115. package/dist/esm/components/Icon/components/ChevronLeft.js +18 -0
  116. package/dist/esm/components/Icon/components/ChevronLeft.js.map +1 -0
  117. package/dist/esm/components/Icon/components/ChevronLeftDouble.js +18 -0
  118. package/dist/esm/components/Icon/components/ChevronLeftDouble.js.map +1 -0
  119. package/dist/esm/components/Icon/components/ChevronRight.js +18 -0
  120. package/dist/esm/components/Icon/components/ChevronRight.js.map +1 -0
  121. package/dist/esm/components/Icon/components/ChevronRightDouble.js +18 -0
  122. package/dist/esm/components/Icon/components/ChevronRightDouble.js.map +1 -0
  123. package/dist/esm/components/Icon/components/ChevronUp.js +18 -0
  124. package/dist/esm/components/Icon/components/ChevronUp.js.map +1 -0
  125. package/dist/esm/components/Icon/components/ChevronUpDouble.js +18 -0
  126. package/dist/esm/components/Icon/components/ChevronUpDouble.js.map +1 -0
  127. package/dist/esm/components/Icon/components/ChevronUpSolid.js +18 -0
  128. package/dist/esm/components/Icon/components/ChevronUpSolid.js.map +1 -0
  129. package/dist/esm/components/Icon/components/CircleClose.js +19 -0
  130. package/dist/esm/components/Icon/components/CircleClose.js.map +1 -0
  131. package/dist/esm/components/Icon/components/CircleMinus.js +18 -0
  132. package/dist/esm/components/Icon/components/CircleMinus.js.map +1 -0
  133. package/dist/esm/components/Icon/components/CirclePlus.js +18 -0
  134. package/dist/esm/components/Icon/components/CirclePlus.js.map +1 -0
  135. package/dist/esm/components/Icon/components/CircleTick.js +18 -0
  136. package/dist/esm/components/Icon/components/CircleTick.js.map +1 -0
  137. package/dist/esm/components/Icon/components/Clamp.js +18 -0
  138. package/dist/esm/components/Icon/components/Clamp.js.map +1 -0
  139. package/dist/esm/components/Icon/components/ClampOpen.js +18 -0
  140. package/dist/esm/components/Icon/components/ClampOpen.js.map +1 -0
  141. package/dist/esm/components/Icon/components/Close.js +18 -0
  142. package/dist/esm/components/Icon/components/Close.js.map +1 -0
  143. package/dist/esm/components/Icon/components/ConnectionEnable.js +17 -0
  144. package/dist/esm/components/Icon/components/ConnectionEnable.js.map +1 -0
  145. package/dist/esm/components/Icon/components/ConnectionRevoke.js +17 -0
  146. package/dist/esm/components/Icon/components/ConnectionRevoke.js.map +1 -0
  147. package/dist/esm/components/Icon/components/Contacts.js +18 -0
  148. package/dist/esm/components/Icon/components/Contacts.js.map +1 -0
  149. package/dist/esm/components/Icon/components/Copy.js +18 -0
  150. package/dist/esm/components/Icon/components/Copy.js.map +1 -0
  151. package/dist/esm/components/Icon/components/Courses.js +17 -0
  152. package/dist/esm/components/Icon/components/Courses.js.map +1 -0
  153. package/dist/esm/components/Icon/components/Credit.js +18 -0
  154. package/dist/esm/components/Icon/components/Credit.js.map +1 -0
  155. package/dist/esm/components/Icon/components/Delete.js +18 -0
  156. package/dist/esm/components/Icon/components/Delete.js.map +1 -0
  157. package/dist/esm/components/Icon/components/DeletePermanently.js +18 -0
  158. package/dist/esm/components/Icon/components/DeletePermanently.js.map +1 -0
  159. package/dist/esm/components/Icon/components/Depecriate.js +18 -0
  160. package/dist/esm/components/Icon/components/Depecriate.js.map +1 -0
  161. package/dist/esm/components/Icon/components/Developer.js +18 -0
  162. package/dist/esm/components/Icon/components/Developer.js.map +1 -0
  163. package/dist/esm/components/Icon/components/DistributionTemplate.js +18 -0
  164. package/dist/esm/components/Icon/components/DistributionTemplate.js.map +1 -0
  165. package/dist/esm/components/Icon/components/Document.js +17 -0
  166. package/dist/esm/components/Icon/components/Document.js.map +1 -0
  167. package/dist/esm/components/Icon/components/DocumentApprove.js +18 -0
  168. package/dist/esm/components/Icon/components/DocumentApprove.js.map +1 -0
  169. package/dist/esm/components/Icon/components/DocumentCreateEntry.js +18 -0
  170. package/dist/esm/components/Icon/components/DocumentCreateEntry.js.map +1 -0
  171. package/dist/esm/components/Icon/components/DocumentCut.js +18 -0
  172. package/dist/esm/components/Icon/components/DocumentCut.js.map +1 -0
  173. package/dist/esm/components/Icon/components/DocumentError.js +18 -0
  174. package/dist/esm/components/Icon/components/DocumentError.js.map +1 -0
  175. package/dist/esm/components/Icon/components/DocumentIsolatePage.js +18 -0
  176. package/dist/esm/components/Icon/components/DocumentIsolatePage.js.map +1 -0
  177. package/dist/esm/components/Icon/components/DocumentMerge.js +18 -0
  178. package/dist/esm/components/Icon/components/DocumentMerge.js.map +1 -0
  179. package/dist/esm/components/Icon/components/DocumentMove.js +18 -0
  180. package/dist/esm/components/Icon/components/DocumentMove.js.map +1 -0
  181. package/dist/esm/components/Icon/components/DocumentPreview.js +18 -0
  182. package/dist/esm/components/Icon/components/DocumentPreview.js.map +1 -0
  183. package/dist/esm/components/Icon/components/DocumentReceived.js +17 -0
  184. package/dist/esm/components/Icon/components/DocumentReceived.js.map +1 -0
  185. package/dist/esm/components/Icon/components/DocumentRejectedRequest.js +17 -0
  186. package/dist/esm/components/Icon/components/DocumentRejectedRequest.js.map +1 -0
  187. package/dist/esm/components/Icon/components/DocumentSplit.js +18 -0
  188. package/dist/esm/components/Icon/components/DocumentSplit.js.map +1 -0
  189. package/dist/esm/components/Icon/components/DocumentTime.js +18 -0
  190. package/dist/esm/components/Icon/components/DocumentTime.js.map +1 -0
  191. package/dist/esm/components/Icon/components/Download.js +18 -0
  192. package/dist/esm/components/Icon/components/Download.js.map +1 -0
  193. package/dist/esm/components/Icon/components/Drag.js +18 -0
  194. package/dist/esm/components/Icon/components/Drag.js.map +1 -0
  195. package/dist/esm/components/Icon/components/ECopedia.js +18 -0
  196. package/dist/esm/components/Icon/components/ECopedia.js.map +1 -0
  197. package/dist/esm/components/Icon/components/ESignature.js +18 -0
  198. package/dist/esm/components/Icon/components/ESignature.js.map +1 -0
  199. package/dist/esm/components/Icon/components/Edit.js +18 -0
  200. package/dist/esm/components/Icon/components/Edit.js.map +1 -0
  201. package/dist/esm/components/Icon/components/EllipsisHorizontal.js +18 -0
  202. package/dist/esm/components/Icon/components/EllipsisHorizontal.js.map +1 -0
  203. package/dist/esm/components/Icon/components/EllipsisVertical.js +18 -0
  204. package/dist/esm/components/Icon/components/EllipsisVertical.js.map +1 -0
  205. package/dist/esm/components/Icon/components/EntriesOnAccount.js +18 -0
  206. package/dist/esm/components/Icon/components/EntriesOnAccount.js.map +1 -0
  207. package/dist/esm/components/Icon/components/EntriesOpen.js +18 -0
  208. package/dist/esm/components/Icon/components/EntriesOpen.js.map +1 -0
  209. package/dist/esm/components/Icon/components/EntriesWarning.js +18 -0
  210. package/dist/esm/components/Icon/components/EntriesWarning.js.map +1 -0
  211. package/dist/esm/components/Icon/components/EntryTypeCustomerInvoice.js +18 -0
  212. package/dist/esm/components/Icon/components/EntryTypeCustomerInvoice.js.map +1 -0
  213. package/dist/esm/components/Icon/components/EntryTypeCustomerPayment.js +18 -0
  214. package/dist/esm/components/Icon/components/EntryTypeCustomerPayment.js.map +1 -0
  215. package/dist/esm/components/Icon/components/EntryTypeJournalEntry.js +18 -0
  216. package/dist/esm/components/Icon/components/EntryTypeJournalEntry.js.map +1 -0
  217. package/dist/esm/components/Icon/components/EntryTypeManualCustomerInvoice.js +18 -0
  218. package/dist/esm/components/Icon/components/EntryTypeManualCustomerInvoice.js.map +1 -0
  219. package/dist/esm/components/Icon/components/EntryTypeSupplierInvoice.js +18 -0
  220. package/dist/esm/components/Icon/components/EntryTypeSupplierInvoice.js.map +1 -0
  221. package/dist/esm/components/Icon/components/EntryTypeSupplierPayment.js +18 -0
  222. package/dist/esm/components/Icon/components/EntryTypeSupplierPayment.js.map +1 -0
  223. package/dist/esm/components/Icon/components/Envelope.js +18 -0
  224. package/dist/esm/components/Icon/components/Envelope.js.map +1 -0
  225. package/dist/esm/components/Icon/components/EnvelopeApproved.js +18 -0
  226. package/dist/esm/components/Icon/components/EnvelopeApproved.js.map +1 -0
  227. package/dist/esm/components/Icon/components/ExpandView.js +18 -0
  228. package/dist/esm/components/Icon/components/ExpandView.js.map +1 -0
  229. package/dist/esm/components/Icon/components/Expenses.js +18 -0
  230. package/dist/esm/components/Icon/components/Expenses.js.map +1 -0
  231. package/dist/esm/components/Icon/components/Export.js +18 -0
  232. package/dist/esm/components/Icon/components/Export.js.map +1 -0
  233. package/dist/esm/components/Icon/components/ExportToExcel.js +18 -0
  234. package/dist/esm/components/Icon/components/ExportToExcel.js.map +1 -0
  235. package/dist/esm/components/Icon/components/ExportToPdf.js +18 -0
  236. package/dist/esm/components/Icon/components/ExportToPdf.js.map +1 -0
  237. package/dist/esm/components/Icon/components/Filter.js +18 -0
  238. package/dist/esm/components/Icon/components/Filter.js.map +1 -0
  239. package/dist/esm/components/Icon/components/FilterSolid.js +18 -0
  240. package/dist/esm/components/Icon/components/FilterSolid.js.map +1 -0
  241. package/dist/esm/components/Icon/components/GraphSolid.js +18 -0
  242. package/dist/esm/components/Icon/components/GraphSolid.js.map +1 -0
  243. package/dist/esm/components/Icon/components/Hash.js +18 -0
  244. package/dist/esm/components/Icon/components/Hash.js.map +1 -0
  245. package/dist/esm/components/Icon/components/Home.js +18 -0
  246. package/dist/esm/components/Icon/components/Home.js.map +1 -0
  247. package/dist/esm/components/Icon/components/Images.js +18 -0
  248. package/dist/esm/components/Icon/components/Images.js.map +1 -0
  249. package/dist/esm/components/Icon/components/Import.js +18 -0
  250. package/dist/esm/components/Icon/components/Import.js.map +1 -0
  251. package/dist/esm/components/Icon/components/Inbox.js +20 -0
  252. package/dist/esm/components/Icon/components/Inbox.js.map +1 -0
  253. package/dist/esm/components/Icon/components/InboxEinvoicing.js +20 -0
  254. package/dist/esm/components/Icon/components/InboxEinvoicing.js.map +1 -0
  255. package/dist/esm/components/Icon/components/InboxScanning.js +20 -0
  256. package/dist/esm/components/Icon/components/InboxScanning.js.map +1 -0
  257. package/dist/esm/components/Icon/components/InboxSmart.js +20 -0
  258. package/dist/esm/components/Icon/components/InboxSmart.js.map +1 -0
  259. package/dist/esm/components/Icon/components/Info.js +18 -0
  260. package/dist/esm/components/Icon/components/Info.js.map +1 -0
  261. package/dist/esm/components/Icon/components/Inventory.js +18 -0
  262. package/dist/esm/components/Icon/components/Inventory.js.map +1 -0
  263. package/dist/esm/components/Icon/components/InventoryMatrix.js +18 -0
  264. package/dist/esm/components/Icon/components/InventoryMatrix.js.map +1 -0
  265. package/dist/esm/components/Icon/components/JournalPro.js +18 -0
  266. package/dist/esm/components/Icon/components/JournalPro.js.map +1 -0
  267. package/dist/esm/components/Icon/components/Layout.js +18 -0
  268. package/dist/esm/components/Icon/components/Layout.js.map +1 -0
  269. package/dist/esm/components/Icon/components/LayoutBoth.js +18 -0
  270. package/dist/esm/components/Icon/components/LayoutBoth.js.map +1 -0
  271. package/dist/esm/components/Icon/components/LayoutFirst.js +18 -0
  272. package/dist/esm/components/Icon/components/LayoutFirst.js.map +1 -0
  273. package/dist/esm/components/Icon/components/LayoutLast.js +18 -0
  274. package/dist/esm/components/Icon/components/LayoutLast.js.map +1 -0
  275. package/dist/esm/components/Icon/components/LayoutNone.js +18 -0
  276. package/dist/esm/components/Icon/components/LayoutNone.js.map +1 -0
  277. package/dist/esm/components/Icon/components/LedgerCard.js +18 -0
  278. package/dist/esm/components/Icon/components/LedgerCard.js.map +1 -0
  279. package/dist/esm/components/Icon/components/LedgerCardCustomerReminder.js +18 -0
  280. package/dist/esm/components/Icon/components/LedgerCardCustomerReminder.js.map +1 -0
  281. package/dist/esm/components/Icon/components/LedgerCardManualCustomerInvoice.js +18 -0
  282. package/dist/esm/components/Icon/components/LedgerCardManualCustomerInvoice.js.map +1 -0
  283. package/dist/esm/components/Icon/components/LedgerCardObsoleteStock.js +18 -0
  284. package/dist/esm/components/Icon/components/LedgerCardObsoleteStock.js.map +1 -0
  285. package/dist/esm/components/Icon/components/LedgerCardOpeningEntry.js +18 -0
  286. package/dist/esm/components/Icon/components/LedgerCardOpeningEntry.js.map +1 -0
  287. package/dist/esm/components/Icon/components/LedgerCardReservedEntry.js +18 -0
  288. package/dist/esm/components/Icon/components/LedgerCardReservedEntry.js.map +1 -0
  289. package/dist/esm/components/Icon/components/LedgerCardShrinkagePilferage.js +18 -0
  290. package/dist/esm/components/Icon/components/LedgerCardShrinkagePilferage.js.map +1 -0
  291. package/dist/esm/components/Icon/components/LedgerCardStockAdjustment.js +18 -0
  292. package/dist/esm/components/Icon/components/LedgerCardStockAdjustment.js.map +1 -0
  293. package/dist/esm/components/Icon/components/LedgerCardTransferredOpeningEntry.js +18 -0
  294. package/dist/esm/components/Icon/components/LedgerCardTransferredOpeningEntry.js.map +1 -0
  295. package/dist/esm/components/Icon/components/Lightbulb.js +18 -0
  296. package/dist/esm/components/Icon/components/Lightbulb.js.map +1 -0
  297. package/dist/esm/components/Icon/components/Line.js +18 -0
  298. package/dist/esm/components/Icon/components/Line.js.map +1 -0
  299. package/dist/esm/components/Icon/components/List.js +18 -0
  300. package/dist/esm/components/Icon/components/List.js.map +1 -0
  301. package/dist/esm/components/Icon/components/ListBulleted.js +18 -0
  302. package/dist/esm/components/Icon/components/ListBulleted.js.map +1 -0
  303. package/dist/esm/components/Icon/components/ListSearch.js +18 -0
  304. package/dist/esm/components/Icon/components/ListSearch.js.map +1 -0
  305. package/dist/esm/components/Icon/components/LockOpen.js +18 -0
  306. package/dist/esm/components/Icon/components/LockOpen.js.map +1 -0
  307. package/dist/esm/components/Icon/components/Log.js +18 -0
  308. package/dist/esm/components/Icon/components/Log.js.map +1 -0
  309. package/dist/esm/components/Icon/components/Market.js +18 -0
  310. package/dist/esm/components/Icon/components/Market.js.map +1 -0
  311. package/dist/esm/components/Icon/components/MatchAmount.js +18 -0
  312. package/dist/esm/components/Icon/components/MatchAmount.js.map +1 -0
  313. package/dist/esm/components/Icon/components/MatchEntries.js +18 -0
  314. package/dist/esm/components/Icon/components/MatchEntries.js.map +1 -0
  315. package/dist/esm/components/Icon/components/Mileage.js +18 -0
  316. package/dist/esm/components/Icon/components/Mileage.js.map +1 -0
  317. package/dist/esm/components/Icon/components/ModalResize.js +18 -0
  318. package/dist/esm/components/Icon/components/ModalResize.js.map +1 -0
  319. package/dist/esm/components/Icon/components/ModalShrink.js +18 -0
  320. package/dist/esm/components/Icon/components/ModalShrink.js.map +1 -0
  321. package/dist/esm/components/Icon/components/More.js +18 -0
  322. package/dist/esm/components/Icon/components/More.js.map +1 -0
  323. package/dist/esm/components/Icon/components/MoreSolid.js +18 -0
  324. package/dist/esm/components/Icon/components/MoreSolid.js.map +1 -0
  325. package/dist/esm/components/Icon/components/Move.js +18 -0
  326. package/dist/esm/components/Icon/components/Move.js.map +1 -0
  327. package/dist/esm/components/Icon/components/NavigationList.js +18 -0
  328. package/dist/esm/components/Icon/components/NavigationList.js.map +1 -0
  329. package/dist/esm/components/Icon/components/Note.js +18 -0
  330. package/dist/esm/components/Icon/components/Note.js.map +1 -0
  331. package/dist/esm/components/Icon/components/NoteFollowUp.js +18 -0
  332. package/dist/esm/components/Icon/components/NoteFollowUp.js.map +1 -0
  333. package/dist/esm/components/Icon/components/NoteRead.js +18 -0
  334. package/dist/esm/components/Icon/components/NoteRead.js.map +1 -0
  335. package/dist/esm/components/Icon/components/PartnerApi.js +18 -0
  336. package/dist/esm/components/Icon/components/PartnerApi.js.map +1 -0
  337. package/dist/esm/components/Icon/components/Period.js +18 -0
  338. package/dist/esm/components/Icon/components/Period.js.map +1 -0
  339. package/dist/esm/components/Icon/components/PersonChange.js +18 -0
  340. package/dist/esm/components/Icon/components/PersonChange.js.map +1 -0
  341. package/dist/esm/components/Icon/components/PersonMinus.js +18 -0
  342. package/dist/esm/components/Icon/components/PersonMinus.js.map +1 -0
  343. package/dist/esm/components/Icon/components/PersonPlus.js +18 -0
  344. package/dist/esm/components/Icon/components/PersonPlus.js.map +1 -0
  345. package/dist/esm/components/Icon/components/PersonTick.js +18 -0
  346. package/dist/esm/components/Icon/components/PersonTick.js.map +1 -0
  347. package/dist/esm/components/Icon/components/Play.js +18 -0
  348. package/dist/esm/components/Icon/components/Play.js.map +1 -0
  349. package/dist/esm/components/Icon/components/PlusMinus.js +18 -0
  350. package/dist/esm/components/Icon/components/PlusMinus.js.map +1 -0
  351. package/dist/esm/components/Icon/components/Print.js +18 -0
  352. package/dist/esm/components/Icon/components/Print.js.map +1 -0
  353. package/dist/esm/components/Icon/components/ProcessPayment.js +18 -0
  354. package/dist/esm/components/Icon/components/ProcessPayment.js.map +1 -0
  355. package/dist/esm/components/Icon/components/ProductLedgerCard.js +18 -0
  356. package/dist/esm/components/Icon/components/ProductLedgerCard.js.map +1 -0
  357. package/dist/esm/components/Icon/components/ProjectCards.js +18 -0
  358. package/dist/esm/components/Icon/components/ProjectCards.js.map +1 -0
  359. package/dist/esm/components/Icon/components/Projects.js +18 -0
  360. package/dist/esm/components/Icon/components/Projects.js.map +1 -0
  361. package/dist/esm/components/Icon/components/Quicklinks.js +18 -0
  362. package/dist/esm/components/Icon/components/Quicklinks.js.map +1 -0
  363. package/dist/esm/components/Icon/components/RatingBankruptcy.js +18 -0
  364. package/dist/esm/components/Icon/components/RatingBankruptcy.js.map +1 -0
  365. package/dist/esm/components/Icon/components/RatingPaymentProblems.js +18 -0
  366. package/dist/esm/components/Icon/components/RatingPaymentProblems.js.map +1 -0
  367. package/dist/esm/components/Icon/components/Reconciled.js +18 -0
  368. package/dist/esm/components/Icon/components/Reconciled.js.map +1 -0
  369. package/dist/esm/components/Icon/components/Refresh.js +17 -0
  370. package/dist/esm/components/Icon/components/Refresh.js.map +1 -0
  371. package/dist/esm/components/Icon/components/Report.js +18 -0
  372. package/dist/esm/components/Icon/components/Report.js.map +1 -0
  373. package/dist/esm/components/Icon/components/ReportSolid.js +18 -0
  374. package/dist/esm/components/Icon/components/ReportSolid.js.map +1 -0
  375. package/dist/esm/components/Icon/components/Restore.js +18 -0
  376. package/dist/esm/components/Icon/components/Restore.js.map +1 -0
  377. package/dist/esm/components/Icon/components/RotateLeft.js +17 -0
  378. package/dist/esm/components/Icon/components/RotateLeft.js.map +1 -0
  379. package/dist/esm/components/Icon/components/RotateRight.js +17 -0
  380. package/dist/esm/components/Icon/components/RotateRight.js.map +1 -0
  381. package/dist/esm/components/Icon/components/Sales.js +18 -0
  382. package/dist/esm/components/Icon/components/Sales.js.map +1 -0
  383. package/dist/esm/components/Icon/components/Search.js +18 -0
  384. package/dist/esm/components/Icon/components/Search.js.map +1 -0
  385. package/dist/esm/components/Icon/components/SearchBold.js +18 -0
  386. package/dist/esm/components/Icon/components/SearchBold.js.map +1 -0
  387. package/dist/esm/components/Icon/components/Secure.js +18 -0
  388. package/dist/esm/components/Icon/components/Secure.js.map +1 -0
  389. package/dist/esm/components/Icon/components/SecureTick.js +18 -0
  390. package/dist/esm/components/Icon/components/SecureTick.js.map +1 -0
  391. package/dist/esm/components/Icon/components/Settings.js +18 -0
  392. package/dist/esm/components/Icon/components/Settings.js.map +1 -0
  393. package/dist/esm/components/Icon/components/SettingsSolid.js +18 -0
  394. package/dist/esm/components/Icon/components/SettingsSolid.js.map +1 -0
  395. package/dist/esm/components/Icon/components/Shortcuts.js +18 -0
  396. package/dist/esm/components/Icon/components/Shortcuts.js.map +1 -0
  397. package/dist/esm/components/Icon/components/ShowAll.js +18 -0
  398. package/dist/esm/components/Icon/components/ShowAll.js.map +1 -0
  399. package/dist/esm/components/Icon/components/ShowLess.js +18 -0
  400. package/dist/esm/components/Icon/components/ShowLess.js.map +1 -0
  401. package/dist/esm/components/Icon/components/ShowMore.js +18 -0
  402. package/dist/esm/components/Icon/components/ShowMore.js.map +1 -0
  403. package/dist/esm/components/Icon/components/ShowTemplate.js +18 -0
  404. package/dist/esm/components/Icon/components/ShowTemplate.js.map +1 -0
  405. package/dist/esm/components/Icon/components/Sliders.js +18 -0
  406. package/dist/esm/components/Icon/components/Sliders.js.map +1 -0
  407. package/dist/esm/components/Icon/components/Smartpay.js +18 -0
  408. package/dist/esm/components/Icon/components/Smartpay.js.map +1 -0
  409. package/dist/esm/components/Icon/components/SortBy.js +18 -0
  410. package/dist/esm/components/Icon/components/SortBy.js.map +1 -0
  411. package/dist/esm/components/Icon/components/Spinner.js +21 -0
  412. package/dist/esm/components/Icon/components/Spinner.js.map +1 -0
  413. package/dist/esm/components/Icon/components/Star.js +18 -0
  414. package/dist/esm/components/Icon/components/Star.js.map +1 -0
  415. package/dist/esm/components/Icon/components/StarSolid.js +18 -0
  416. package/dist/esm/components/Icon/components/StarSolid.js.map +1 -0
  417. package/dist/esm/components/Icon/components/Subscriptions.js +18 -0
  418. package/dist/esm/components/Icon/components/Subscriptions.js.map +1 -0
  419. package/dist/esm/components/Icon/components/SystemEntries.js +18 -0
  420. package/dist/esm/components/Icon/components/SystemEntries.js.map +1 -0
  421. package/dist/esm/components/Icon/components/Tag.js +18 -0
  422. package/dist/esm/components/Icon/components/Tag.js.map +1 -0
  423. package/dist/esm/components/Icon/components/TemplateOverride.js +18 -0
  424. package/dist/esm/components/Icon/components/TemplateOverride.js.map +1 -0
  425. package/dist/esm/components/Icon/components/Templates.js +18 -0
  426. package/dist/esm/components/Icon/components/Templates.js.map +1 -0
  427. package/dist/esm/components/Icon/components/ThumbBoth.js +18 -0
  428. package/dist/esm/components/Icon/components/ThumbBoth.js.map +1 -0
  429. package/dist/esm/components/Icon/components/ThumbDown.js +18 -0
  430. package/dist/esm/components/Icon/components/ThumbDown.js.map +1 -0
  431. package/dist/esm/components/Icon/components/ThumbDownSolid.js +18 -0
  432. package/dist/esm/components/Icon/components/ThumbDownSolid.js.map +1 -0
  433. package/dist/esm/components/Icon/components/ThumbUp.js +18 -0
  434. package/dist/esm/components/Icon/components/ThumbUp.js.map +1 -0
  435. package/dist/esm/components/Icon/components/ThumbUpSolid.js +18 -0
  436. package/dist/esm/components/Icon/components/ThumbUpSolid.js.map +1 -0
  437. package/dist/esm/components/Icon/components/Tick.js +18 -0
  438. package/dist/esm/components/Icon/components/Tick.js.map +1 -0
  439. package/dist/esm/components/Icon/components/Time.js +18 -0
  440. package/dist/esm/components/Icon/components/Time.js.map +1 -0
  441. package/dist/esm/components/Icon/components/Transfer.js +18 -0
  442. package/dist/esm/components/Icon/components/Transfer.js.map +1 -0
  443. package/dist/esm/components/Icon/components/TransferCancel.js +24 -0
  444. package/dist/esm/components/Icon/components/TransferCancel.js.map +1 -0
  445. package/dist/esm/components/Icon/components/TransferLocked.js +18 -0
  446. package/dist/esm/components/Icon/components/TransferLocked.js.map +1 -0
  447. package/dist/esm/components/Icon/components/Undock.js +18 -0
  448. package/dist/esm/components/Icon/components/Undock.js.map +1 -0
  449. package/dist/esm/components/Icon/components/Unreconciled.js +18 -0
  450. package/dist/esm/components/Icon/components/Unreconciled.js.map +1 -0
  451. package/dist/esm/components/Icon/components/Warning.js +17 -0
  452. package/dist/esm/components/Icon/components/Warning.js.map +1 -0
  453. package/dist/esm/components/Icon/components/Webshop.js +18 -0
  454. package/dist/esm/components/Icon/components/Webshop.js.map +1 -0
  455. package/dist/esm/components/Icon/components/Website.js +18 -0
  456. package/dist/esm/components/Icon/components/Website.js.map +1 -0
  457. package/dist/esm/components/Icon/components/Workflow.js +17 -0
  458. package/dist/esm/components/Icon/components/Workflow.js.map +1 -0
  459. package/dist/esm/components/Icon/components/Zoom.js +18 -0
  460. package/dist/esm/components/Icon/components/Zoom.js.map +1 -0
  461. package/dist/esm/components/Icon/components/index.js +414 -0
  462. package/dist/esm/components/Icon/components/index.js.map +1 -0
  463. package/dist/esm/components/IconButton/IconButton.js +35 -0
  464. package/dist/esm/components/IconButton/IconButton.js.map +1 -0
  465. package/dist/esm/components/Input/Input.js +85 -0
  466. package/dist/esm/components/Input/Input.js.map +1 -0
  467. package/dist/esm/components/Input/util.js +22 -0
  468. package/dist/esm/components/Input/util.js.map +1 -0
  469. package/dist/esm/components/Listbox/Listbox.js +58 -0
  470. package/dist/esm/components/Listbox/Listbox.js.map +1 -0
  471. package/dist/esm/components/Listbox/ScrollableList.js +174 -0
  472. package/dist/esm/components/Listbox/ScrollableList.js.map +1 -0
  473. package/dist/esm/components/Listbox/useListbox.js +145 -0
  474. package/dist/esm/components/Listbox/useListbox.js.map +1 -0
  475. package/dist/esm/components/Listbox/useMultiListbox.js +196 -0
  476. package/dist/esm/components/Listbox/useMultiListbox.js.map +1 -0
  477. package/dist/esm/components/Listbox/useTypeahead.js +28 -0
  478. package/dist/esm/components/Listbox/useTypeahead.js.map +1 -0
  479. package/dist/esm/components/Listbox/util.js +150 -0
  480. package/dist/esm/components/Listbox/util.js.map +1 -0
  481. package/dist/esm/components/Menu/Context.js +9 -0
  482. package/dist/esm/components/Menu/Context.js.map +1 -0
  483. package/dist/esm/components/Menu/Menu.js +74 -0
  484. package/dist/esm/components/Menu/Menu.js.map +1 -0
  485. package/dist/esm/components/Menu/components/Checkbox.js +31 -0
  486. package/dist/esm/components/Menu/components/Checkbox.js.map +1 -0
  487. package/dist/esm/components/Menu/components/Content.js +50 -0
  488. package/dist/esm/components/Menu/components/Content.js.map +1 -0
  489. package/dist/esm/components/Menu/components/Header.js +38 -0
  490. package/dist/esm/components/Menu/components/Header.js.map +1 -0
  491. package/dist/esm/components/Menu/components/Item.js +140 -0
  492. package/dist/esm/components/Menu/components/Item.js.map +1 -0
  493. package/dist/esm/components/Menu/components/Link.js +39 -0
  494. package/dist/esm/components/Menu/components/Link.js.map +1 -0
  495. package/dist/esm/components/Menu/components/RadioGroup.js +48 -0
  496. package/dist/esm/components/Menu/components/RadioGroup.js.map +1 -0
  497. package/dist/esm/components/Menu/components/Separator.js +35 -0
  498. package/dist/esm/components/Menu/components/Separator.js.map +1 -0
  499. package/dist/esm/components/Menu/components/Trigger.js +33 -0
  500. package/dist/esm/components/Menu/components/Trigger.js.map +1 -0
  501. package/dist/esm/components/Navigation/Navigation.js +125 -0
  502. package/dist/esm/components/Navigation/Navigation.js.map +1 -0
  503. package/dist/esm/components/Pagination/PageNumbers.js +50 -0
  504. package/dist/esm/components/Pagination/PageNumbers.js.map +1 -0
  505. package/dist/esm/components/Pagination/Pagination.js +103 -0
  506. package/dist/esm/components/Pagination/Pagination.js.map +1 -0
  507. package/dist/esm/components/Pagination/usePagination.js +15 -0
  508. package/dist/esm/components/Pagination/usePagination.js.map +1 -0
  509. package/dist/esm/components/Pagination/usePaginationShortcuts.js +50 -0
  510. package/dist/esm/components/Pagination/usePaginationShortcuts.js.map +1 -0
  511. package/dist/esm/components/Popover/Popover.js +84 -0
  512. package/dist/esm/components/Popover/Popover.js.map +1 -0
  513. package/dist/esm/components/Popover/Primitives.js +41 -0
  514. package/dist/esm/components/Popover/Primitives.js.map +1 -0
  515. package/dist/esm/components/Progress/Progress.js +32 -0
  516. package/dist/esm/components/Progress/Progress.js.map +1 -0
  517. package/dist/esm/components/Provider/Provider.js +105 -0
  518. package/dist/esm/components/Provider/Provider.js.map +1 -0
  519. package/dist/esm/components/RadioGroup/RadioGroup.js +106 -0
  520. package/dist/esm/components/RadioGroup/RadioGroup.js.map +1 -0
  521. package/dist/esm/components/SearchInput/SearchInput.js +95 -0
  522. package/dist/esm/components/SearchInput/SearchInput.js.map +1 -0
  523. package/dist/esm/components/Select/Select.js +100 -0
  524. package/dist/esm/components/Select/Select.js.map +1 -0
  525. package/dist/esm/components/Select/useSelect.js +212 -0
  526. package/dist/esm/components/Select/useSelect.js.map +1 -0
  527. package/dist/esm/components/Spinner/Spinner.js +48 -0
  528. package/dist/esm/components/Spinner/Spinner.js.map +1 -0
  529. package/dist/esm/components/Switch/Switch.js +37 -0
  530. package/dist/esm/components/Switch/Switch.js.map +1 -0
  531. package/dist/esm/components/Table/components/BaseTable.js +48 -0
  532. package/dist/esm/components/Table/components/BaseTable.js.map +1 -0
  533. package/dist/esm/components/Table/components/PaginatedTable.js +16 -0
  534. package/dist/esm/components/Table/components/PaginatedTable.js.map +1 -0
  535. package/dist/esm/components/Table/components/Table.js +56 -0
  536. package/dist/esm/components/Table/components/Table.js.map +1 -0
  537. package/dist/esm/components/Table/components/WindowedTable.js +186 -0
  538. package/dist/esm/components/Table/components/WindowedTable.js.map +1 -0
  539. package/dist/esm/components/Table/hooks/plugins/useRowActions.js +236 -0
  540. package/dist/esm/components/Table/hooks/plugins/useRowActions.js.map +1 -0
  541. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js +129 -0
  542. package/dist/esm/components/Table/hooks/plugins/useRowDraggable.js.map +1 -0
  543. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js +100 -0
  544. package/dist/esm/components/Table/hooks/plugins/useRowEditing.js.map +1 -0
  545. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js +108 -0
  546. package/dist/esm/components/Table/hooks/plugins/useRowSelect.js.map +1 -0
  547. package/dist/esm/components/Table/hooks/useRowCreation.js +106 -0
  548. package/dist/esm/components/Table/hooks/useRowCreation.js.map +1 -0
  549. package/dist/esm/components/Table/hooks/useTable.js +217 -0
  550. package/dist/esm/components/Table/hooks/useTable.js.map +1 -0
  551. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js +132 -0
  552. package/dist/esm/components/Table/hooks/useTableKeyboardNavigation.js.map +1 -0
  553. package/dist/esm/components/Table/util/renderColumn.js +40 -0
  554. package/dist/esm/components/Table/util/renderColumn.js.map +1 -0
  555. package/dist/esm/components/Table/util/renderRow.js +101 -0
  556. package/dist/esm/components/Table/util/renderRow.js.map +1 -0
  557. package/dist/esm/components/Table/util/rowIndexPath.js +57 -0
  558. package/dist/esm/components/Table/util/rowIndexPath.js.map +1 -0
  559. package/dist/esm/components/Table/util/sortTypes.js +82 -0
  560. package/dist/esm/components/Table/util/sortTypes.js.map +1 -0
  561. package/dist/esm/components/Table/util.js +99 -0
  562. package/dist/esm/components/Table/util.js.map +1 -0
  563. package/dist/esm/components/Tabs/Tabs.js +69 -0
  564. package/dist/esm/components/Tabs/Tabs.js.map +1 -0
  565. package/dist/esm/components/Textarea/Textarea.js +39 -0
  566. package/dist/esm/components/Textarea/Textarea.js.map +1 -0
  567. package/dist/esm/components/Toast/Toast.js +79 -0
  568. package/dist/esm/components/Toast/Toast.js.map +1 -0
  569. package/dist/esm/components/Toast/Toaster.js +163 -0
  570. package/dist/esm/components/Toast/Toaster.js.map +1 -0
  571. package/dist/esm/components/Toast/util.js +46 -0
  572. package/dist/esm/components/Toast/util.js.map +1 -0
  573. package/dist/esm/components/Tooltip/Tooltip.js +32 -0
  574. package/dist/esm/components/Tooltip/Tooltip.js.map +1 -0
  575. package/dist/esm/components/Tour/Tour.js +142 -0
  576. package/dist/esm/components/Tour/Tour.js.map +1 -0
  577. package/dist/esm/components/Treeview/Treeview.js +73 -0
  578. package/dist/esm/components/Treeview/Treeview.js.map +1 -0
  579. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js +11 -0
  580. package/dist/esm/components/VisuallyHidden/VisuallyHidden.js.map +1 -0
  581. package/dist/esm/index.css +661 -0
  582. package/dist/esm/index.js +50 -0
  583. package/dist/esm/index.js.map +1 -0
  584. package/dist/esm/primitives/Button.js +21 -0
  585. package/dist/esm/primitives/Button.js.map +1 -0
  586. package/dist/esm/utils/date.js +98 -0
  587. package/dist/esm/utils/date.js.map +1 -0
  588. package/dist/esm/utils/hooks/useBoundingClientRectListener.js +50 -0
  589. package/dist/esm/utils/hooks/useBoundingClientRectListener.js.map +1 -0
  590. package/dist/esm/utils/hooks/useDraggable.js +42 -0
  591. package/dist/esm/utils/hooks/useDraggable.js.map +1 -0
  592. package/dist/esm/utils/hooks/useDropTarget.js +38 -0
  593. package/dist/esm/utils/hooks/useDropTarget.js.map +1 -0
  594. package/dist/esm/utils/hooks/useListKeyboardNavigation.js +58 -0
  595. package/dist/esm/utils/hooks/useListKeyboardNavigation.js.map +1 -0
  596. package/dist/esm/utils/hooks/useListScrollTo.js +38 -0
  597. package/dist/esm/utils/hooks/useListScrollTo.js.map +1 -0
  598. package/dist/esm/utils/hooks/useOnClickOutside.js +27 -0
  599. package/dist/esm/utils/hooks/useOnClickOutside.js.map +1 -0
  600. package/dist/esm/utils/hooks/useProxiedRef.js +18 -0
  601. package/dist/esm/utils/hooks/useProxiedRef.js.map +1 -0
  602. package/dist/esm/utils/hooks/useTimer.js +50 -0
  603. package/dist/esm/utils/hooks/useTimer.js.map +1 -0
  604. package/dist/esm/utils/input.js +49 -0
  605. package/dist/esm/utils/input.js.map +1 -0
  606. package/dist/esm/utils/mergeRefs.js +14 -0
  607. package/dist/esm/utils/mergeRefs.js.map +1 -0
  608. package/dist/esm/utils/taillwind.js +41 -0
  609. package/dist/esm/utils/taillwind.js.map +1 -0
  610. package/dist/taco.cjs.development.js +458 -552
  611. package/dist/taco.cjs.development.js.map +1 -1
  612. package/dist/taco.cjs.production.min.js +2 -0
  613. package/dist/taco.cjs.production.min.js.map +1 -0
  614. package/package.json +2 -2
@@ -0,0 +1,106 @@
1
+ import { useMemo, Children, isValidElement, forwardRef, createElement, createContext, useContext } from 'react';
2
+ import cn from 'classnames';
3
+ import { Root, Item, Indicator } from '@radix-ui/react-radio-group';
4
+
5
+ const getRadioGroupItemValueAsString = value => value === null ? '' : String(value);
6
+ const findByValue = (values, valueAsString) => values.find(value => getRadioGroupItemValueAsString(value) === valueAsString);
7
+ const RadioGroupContext = /*#__PURE__*/createContext({
8
+ disabled: false,
9
+ invalid: false
10
+ });
11
+ const RadioGroupItem = /*#__PURE__*/forwardRef(function RadioGroupItem(props, ref) {
12
+ const context = useContext(RadioGroupContext);
13
+ const {
14
+ children,
15
+ value,
16
+ ...otherProps
17
+ } = props;
18
+ const isDisabled = context.disabled || props.disabled;
19
+ const className = cn('flex flex-shrink-0 self-start items-center justify-center h-4 w-4 mt-[0.2rem] rounded-full bg-white border-2 hover:border-4', {
20
+ 'border-grey-dark focus:yt-focus aria-checked:bg-blue aria-checked:border-blue hover:aria-checked:border-blue-light': !isDisabled && !context.invalid,
21
+ 'border-grey cursor-not-allowed aria-checked:bg-blue-light aria-checked:border-blue-light ': isDisabled,
22
+ 'border-red text-red focus:border-red focus:yt-focus-red aria-checked:bg-red aria-checked:border-red': context.invalid && !isDisabled
23
+ });
24
+ const labelClassName = cn('flex items-center cursor-pointer gap-2', {
25
+ 'cursor-not-allowed text-grey-dark': isDisabled
26
+ }, props.className);
27
+ return createElement("label", {
28
+ className: labelClassName
29
+ }, createElement(Item, Object.assign({}, otherProps, {
30
+ className: className,
31
+ disabled: isDisabled,
32
+ ref: ref,
33
+ value: getRadioGroupItemValueAsString(value)
34
+ }), createElement(Indicator, {
35
+ className: "h-2 w-2 rounded-full bg-white"
36
+ })), children);
37
+ });
38
+ const useRadioGroup = props => {
39
+ const {
40
+ children,
41
+ defaultValue,
42
+ disabled,
43
+ invalid,
44
+ onChange,
45
+ orientation = 'vertical',
46
+ value,
47
+ ...otherProps
48
+ } = props;
49
+ const values = useMemo(() => {
50
+ const radioGroupItemValues = [];
51
+ Children.forEach(children, child => {
52
+ if (isValidElement(child)) {
53
+ radioGroupItemValues.push(child.props.value);
54
+ }
55
+ });
56
+ return radioGroupItemValues;
57
+ }, [children]);
58
+ const context = useMemo(() => ({
59
+ disabled: disabled !== null && disabled !== void 0 ? disabled : false,
60
+ invalid: invalid !== null && invalid !== void 0 ? invalid : false
61
+ }), [disabled, invalid]);
62
+ let valueProps;
63
+
64
+ if (onChange !== undefined) {
65
+ const handleChange = value => onChange(findByValue(values, value));
66
+
67
+ valueProps = {
68
+ onValueChange: handleChange,
69
+ value: value !== undefined ? getRadioGroupItemValueAsString(value) : undefined
70
+ };
71
+ } else {
72
+ valueProps = {
73
+ defaultValue: defaultValue !== undefined ? getRadioGroupItemValueAsString(defaultValue) : undefined
74
+ };
75
+ }
76
+
77
+ return {
78
+ context,
79
+ props: { ...otherProps,
80
+ ...valueProps,
81
+ children,
82
+ orientation
83
+ }
84
+ };
85
+ };
86
+ const RadioGroup = /*#__PURE__*/forwardRef(function RadioGroup(props, ref) {
87
+ const {
88
+ context,
89
+ props: otherProps
90
+ } = useRadioGroup(props);
91
+ const className = cn('flex items-start gap-y-2', {
92
+ 'flex-wrap gap-x-4 ': otherProps.orientation === 'horizontal',
93
+ 'flex-col': otherProps.orientation === 'vertical'
94
+ }, otherProps.className);
95
+ return createElement(RadioGroupContext.Provider, {
96
+ value: context
97
+ }, createElement(Root, Object.assign({}, otherProps, {
98
+ className: className,
99
+ "data-taco": "radio-group",
100
+ ref: ref
101
+ })));
102
+ });
103
+ RadioGroup.Item = RadioGroupItem;
104
+
105
+ export { RadioGroup, findByValue, getRadioGroupItemValueAsString, useRadioGroup };
106
+ //# sourceMappingURL=RadioGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RadioGroup.js","sources":["../../../../src/components/RadioGroup/RadioGroup.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport cn from 'classnames';\r\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group';\r\nimport { Orientation } from '../../types';\r\n\r\nexport type RadioGroupItemValue = string | number | boolean | null;\r\n\r\nexport const getRadioGroupItemValueAsString = (value: RadioGroupItemValue): string => (value === null ? '' : String(value));\r\n\r\nexport const findByValue = (values: RadioGroupItemValue[], valueAsString: string): RadioGroupItemValue =>\r\n values.find(value => getRadioGroupItemValueAsString(value) === valueAsString) as RadioGroupItemValue;\r\n\r\nconst RadioGroupContext = React.createContext({ disabled: false, invalid: false });\r\n\r\nexport type RadioGroupItemProps<T = HTMLButtonElement> = Omit<\r\n React.ButtonHTMLAttributes<T>,\r\n 'children' | 'onSelect' | 'value'\r\n> & {\r\n /** Label for the radio group item */\r\n children: React.ReactNode;\r\n /* Whether the radio group item is disabled */\r\n disabled?: boolean;\r\n /** Value of the radio button */\r\n value: RadioGroupItemValue;\r\n};\r\n\r\nconst RadioGroupItem = React.forwardRef(function RadioGroupItem(props: RadioGroupItemProps, ref: React.Ref<HTMLButtonElement>) {\r\n const context = React.useContext(RadioGroupContext);\r\n const { children, value, ...otherProps } = props;\r\n\r\n const isDisabled = context.disabled || props.disabled;\r\n\r\n const className = cn(\r\n 'flex flex-shrink-0 self-start items-center justify-center h-4 w-4 mt-[0.2rem] rounded-full bg-white border-2 hover:border-4',\r\n {\r\n 'border-grey-dark focus:yt-focus aria-checked:bg-blue aria-checked:border-blue hover:aria-checked:border-blue-light':\r\n !isDisabled && !context.invalid,\r\n 'border-grey cursor-not-allowed aria-checked:bg-blue-light aria-checked:border-blue-light ': isDisabled,\r\n 'border-red text-red focus:border-red focus:yt-focus-red aria-checked:bg-red aria-checked:border-red':\r\n context.invalid && !isDisabled,\r\n }\r\n );\r\n const labelClassName = cn(\r\n 'flex items-center cursor-pointer gap-2',\r\n {\r\n 'cursor-not-allowed text-grey-dark': isDisabled,\r\n },\r\n props.className\r\n );\r\n\r\n return (\r\n <label className={labelClassName}>\r\n <RadioGroupPrimitive.Item\r\n {...otherProps}\r\n className={className}\r\n disabled={isDisabled}\r\n ref={ref}\r\n value={getRadioGroupItemValueAsString(value)}\r\n >\r\n <RadioGroupPrimitive.Indicator className=\"h-2 w-2 rounded-full bg-white\" />\r\n </RadioGroupPrimitive.Item>\r\n {children}\r\n </label>\r\n );\r\n});\r\n\r\ntype ReactGroupBaseChild = React.ReactElement<RadioGroupItemProps> | boolean | null;\r\n\r\ntype RadioGroupBaseProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\r\n children: ReactGroupBaseChild[];\r\n /* Whether the radio group is disabled */\r\n disabled?: boolean;\r\n /* Whether the radio group is in an invalid state */\r\n invalid?: boolean;\r\n /** The name of the radio group, used when submitting an HTML form */\r\n name?: string;\r\n /**\r\n * Orientation of the radio group\r\n * @defaultValue vertical\r\n */\r\n orientation?: Orientation;\r\n /* Whether the radio group requires user input */\r\n required?: boolean;\r\n};\r\n\r\ninterface UncontrolledRadioGroupProps extends RadioGroupBaseProps {\r\n /* The default value (uncontrolled) */\r\n defaultValue?: RadioGroupItemValue;\r\n onChange?: never;\r\n value?: never;\r\n}\r\n\r\ninterface ControlledRadioGroupProps extends RadioGroupBaseProps {\r\n defaultValue?: never;\r\n /** Handler called when the value changes */\r\n onChange: (value: RadioGroupItemValue) => void;\r\n /** The current value (controlled) */\r\n value?: RadioGroupItemValue;\r\n}\r\n\r\nexport type RadioGroupProps = UncontrolledRadioGroupProps | ControlledRadioGroupProps;\r\n\r\nexport type ForwardedRadioGroupWithStatics = React.ForwardRefExoticComponent<\r\n RadioGroupProps & React.RefAttributes<HTMLDivElement>\r\n> & {\r\n /** Item component rendered in a `RadioGroup` component */\r\n Item: React.ForwardRefExoticComponent<RadioGroupItemProps>;\r\n};\r\n\r\nexport const useRadioGroup = (props: RadioGroupProps) => {\r\n const { children, defaultValue, disabled, invalid, onChange, orientation = 'vertical', value, ...otherProps } = props;\r\n\r\n const values = React.useMemo<RadioGroupItemValue[]>(() => {\r\n const radioGroupItemValues: RadioGroupItemValue[] = [];\r\n\r\n React.Children.forEach(children, child => {\r\n if (React.isValidElement(child)) {\r\n radioGroupItemValues.push(child.props.value);\r\n }\r\n });\r\n\r\n return radioGroupItemValues;\r\n }, [children]);\r\n\r\n const context = React.useMemo(() => ({ disabled: disabled ?? false, invalid: invalid ?? false }), [disabled, invalid]);\r\n\r\n let valueProps;\r\n\r\n if (onChange !== undefined) {\r\n const handleChange = (value: string): void => onChange(findByValue(values, value));\r\n\r\n valueProps = {\r\n onValueChange: handleChange,\r\n value: value !== undefined ? getRadioGroupItemValueAsString(value) : undefined,\r\n };\r\n } else {\r\n valueProps = {\r\n defaultValue: defaultValue !== undefined ? getRadioGroupItemValueAsString(defaultValue) : undefined,\r\n };\r\n }\r\n\r\n return {\r\n context,\r\n props: {\r\n ...otherProps,\r\n ...valueProps,\r\n children,\r\n orientation,\r\n },\r\n };\r\n};\r\n\r\nexport const RadioGroup = React.forwardRef(function RadioGroup(props: RadioGroupProps, ref: React.Ref<HTMLDivElement>) {\r\n const { context, props: otherProps } = useRadioGroup(props);\r\n const className = cn(\r\n 'flex items-start gap-y-2',\r\n {\r\n 'flex-wrap gap-x-4 ': otherProps.orientation === 'horizontal',\r\n 'flex-col': otherProps.orientation === 'vertical',\r\n },\r\n otherProps.className\r\n );\r\n\r\n return (\r\n <RadioGroupContext.Provider value={context}>\r\n <RadioGroupPrimitive.Root {...otherProps} className={className} data-taco=\"radio-group\" ref={ref} />\r\n </RadioGroupContext.Provider>\r\n );\r\n}) as ForwardedRadioGroupWithStatics;\r\nRadioGroup.Item = RadioGroupItem;\r\n"],"names":["getRadioGroupItemValueAsString","value","String","findByValue","values","valueAsString","find","RadioGroupContext","React","disabled","invalid","RadioGroupItem","props","ref","context","children","otherProps","isDisabled","className","cn","labelClassName","RadioGroupPrimitive","useRadioGroup","defaultValue","onChange","orientation","radioGroupItemValues","forEach","child","push","valueProps","undefined","handleChange","onValueChange","RadioGroup","Provider","Item"],"mappings":";;;;MAOaA,8BAA8B,GAAIC,KAAD,IAAyCA,KAAK,KAAK,IAAV,GAAiB,EAAjB,GAAsBC,MAAM,CAACD,KAAD;MAEtGE,WAAW,GAAG,CAACC,MAAD,EAAgCC,aAAhC,KACvBD,MAAM,CAACE,IAAP,CAAYL,KAAK,IAAID,8BAA8B,CAACC,KAAD,CAA9B,KAA0CI,aAA/D;AAEJ,MAAME,iBAAiB,gBAAGC,aAAA,CAAoB;AAAEC,EAAAA,QAAQ,EAAE,KAAZ;AAAmBC,EAAAA,OAAO,EAAE;AAA5B,CAApB,CAA1B;AAcA,MAAMC,cAAc,gBAAGH,UAAA,CAAiB,SAASG,cAAT,CAAwBC,KAAxB,EAAoDC,GAApD;AACpC,QAAMC,OAAO,GAAGN,UAAA,CAAiBD,iBAAjB,CAAhB;AACA,QAAM;AAAEQ,IAAAA,QAAF;AAAYd,IAAAA,KAAZ;AAAmB,OAAGe;AAAtB,MAAqCJ,KAA3C;AAEA,QAAMK,UAAU,GAAGH,OAAO,CAACL,QAAR,IAAoBG,KAAK,CAACH,QAA7C;AAEA,QAAMS,SAAS,GAAGC,EAAE,CAChB,6HADgB,EAEhB;AACI,0HACI,CAACF,UAAD,IAAe,CAACH,OAAO,CAACJ,OAFhC;AAGI,iGAA6FO,UAHjG;AAII,2GACIH,OAAO,CAACJ,OAAR,IAAmB,CAACO;AAL5B,GAFgB,CAApB;AAUA,QAAMG,cAAc,GAAGD,EAAE,CACrB,wCADqB,EAErB;AACI,yCAAqCF;AADzC,GAFqB,EAKrBL,KAAK,CAACM,SALe,CAAzB;AAQA,SACIV,aAAA,QAAA;AAAOU,IAAAA,SAAS,EAAEE;GAAlB,EACIZ,aAAA,CAACa,IAAD,oBACQL;AACJE,IAAAA,SAAS,EAAEA;AACXT,IAAAA,QAAQ,EAAEQ;AACVJ,IAAAA,GAAG,EAAEA;AACLZ,IAAAA,KAAK,EAAED,8BAA8B,CAACC,KAAD;IALzC,EAOIO,aAAA,CAACa,SAAD;AAA+BH,IAAAA,SAAS,EAAC;GAAzC,CAPJ,CADJ,EAUKH,QAVL,CADJ;AAcH,CAtCsB,CAAvB;MAmFaO,aAAa,GAAIV,KAAD;AACzB,QAAM;AAAEG,IAAAA,QAAF;AAAYQ,IAAAA,YAAZ;AAA0Bd,IAAAA,QAA1B;AAAoCC,IAAAA,OAApC;AAA6Cc,IAAAA,QAA7C;AAAuDC,IAAAA,WAAW,GAAG,UAArE;AAAiFxB,IAAAA,KAAjF;AAAwF,OAAGe;AAA3F,MAA0GJ,KAAhH;AAEA,QAAMR,MAAM,GAAGI,OAAA,CAAqC;AAChD,UAAMkB,oBAAoB,GAA0B,EAApD;AAEAlB,IAAAA,QAAA,CAAemB,OAAf,CAAuBZ,QAAvB,EAAiCa,KAAK;AAClC,UAAIpB,cAAA,CAAqBoB,KAArB,CAAJ,EAAiC;AAC7BF,QAAAA,oBAAoB,CAACG,IAArB,CAA0BD,KAAK,CAAChB,KAAN,CAAYX,KAAtC;AACH;AACJ,KAJD;AAMA,WAAOyB,oBAAP;AACH,GAVc,EAUZ,CAACX,QAAD,CAVY,CAAf;AAYA,QAAMD,OAAO,GAAGN,OAAA,CAAc,OAAO;AAAEC,IAAAA,QAAQ,EAAEA,QAAF,aAAEA,QAAF,cAAEA,QAAF,GAAc,KAAxB;AAA+BC,IAAAA,OAAO,EAAEA,OAAF,aAAEA,OAAF,cAAEA,OAAF,GAAa;AAAnD,GAAP,CAAd,EAAkF,CAACD,QAAD,EAAWC,OAAX,CAAlF,CAAhB;AAEA,MAAIoB,UAAJ;;AAEA,MAAIN,QAAQ,KAAKO,SAAjB,EAA4B;AACxB,UAAMC,YAAY,GAAI/B,KAAD,IAAyBuB,QAAQ,CAACrB,WAAW,CAACC,MAAD,EAASH,KAAT,CAAZ,CAAtD;;AAEA6B,IAAAA,UAAU,GAAG;AACTG,MAAAA,aAAa,EAAED,YADN;AAET/B,MAAAA,KAAK,EAAEA,KAAK,KAAK8B,SAAV,GAAsB/B,8BAA8B,CAACC,KAAD,CAApD,GAA8D8B;AAF5D,KAAb;AAIH,GAPD,MAOO;AACHD,IAAAA,UAAU,GAAG;AACTP,MAAAA,YAAY,EAAEA,YAAY,KAAKQ,SAAjB,GAA6B/B,8BAA8B,CAACuB,YAAD,CAA3D,GAA4EQ;AADjF,KAAb;AAGH;;AAED,SAAO;AACHjB,IAAAA,OADG;AAEHF,IAAAA,KAAK,EAAE,EACH,GAAGI,UADA;AAEH,SAAGc,UAFA;AAGHf,MAAAA,QAHG;AAIHU,MAAAA;AAJG;AAFJ,GAAP;AASH;MAEYS,UAAU,gBAAG1B,UAAA,CAAiB,SAAS0B,UAAT,CAAoBtB,KAApB,EAA4CC,GAA5C;AACvC,QAAM;AAAEC,IAAAA,OAAF;AAAWF,IAAAA,KAAK,EAAEI;AAAlB,MAAiCM,aAAa,CAACV,KAAD,CAApD;AACA,QAAMM,SAAS,GAAGC,EAAE,CAChB,0BADgB,EAEhB;AACI,0BAAsBH,UAAU,CAACS,WAAX,KAA2B,YADrD;AAEI,gBAAYT,UAAU,CAACS,WAAX,KAA2B;AAF3C,GAFgB,EAMhBT,UAAU,CAACE,SANK,CAApB;AASA,SACIV,aAAA,CAACD,iBAAiB,CAAC4B,QAAnB;AAA4BlC,IAAAA,KAAK,EAAEa;GAAnC,EACIN,aAAA,CAACa,IAAD,oBAA8BL;AAAYE,IAAAA,SAAS,EAAEA;iBAAqB;AAAcL,IAAAA,GAAG,EAAEA;IAA7F,CADJ,CADJ;AAKH,CAhByB;AAiB1BqB,UAAU,CAACE,IAAX,GAAkBzB,cAAlB;;;;"}
@@ -0,0 +1,95 @@
1
+ import { objectWithoutPropertiesLoose as _objectWithoutPropertiesLoose } from '../../_virtual/_rollupPluginBabelHelpers.js';
2
+ import { forwardRef, createElement } from 'react';
3
+ import '../Icon/components/index.js';
4
+ import '../Icon/Icon.js';
5
+ import '../Accordion/Accordion.js';
6
+ import '../Backdrop/Backdrop.js';
7
+ import '../VisuallyHidden/VisuallyHidden.js';
8
+ import '../Badge/Badge.js';
9
+ import '../Tooltip/Tooltip.js';
10
+ import { IconButton } from '../IconButton/IconButton.js';
11
+ import '../Banner/Banner.js';
12
+ import '../Button/Button.js';
13
+ import '../Spinner/Spinner.js';
14
+ import '../Toast/Toaster.js';
15
+ import { useLocalization } from '../Provider/Provider.js';
16
+ import '../Calendar/Calendar.js';
17
+ import '../Checkbox/Checkbox.js';
18
+ import { Input } from '../Input/Input.js';
19
+ import keycode from 'keycode';
20
+ import '../../utils/hooks/useListKeyboardNavigation.js';
21
+ import '../../utils/hooks/useListScrollTo.js';
22
+ import '../../utils/hooks/useBoundingClientRectListener.js';
23
+ import '../Combobox/Combobox.js';
24
+ import '../../utils/date.js';
25
+ import '../Popover/Popover.js';
26
+ import '../Datepicker/Datepicker.js';
27
+ import '../Dialog/Dialog.js';
28
+ import '../Field/Field.js';
29
+ import '../Form/Form.js';
30
+ import '../Group/Group.js';
31
+ import '../Hanger/Hanger.js';
32
+ import '../HoverCard/HoverCard.js';
33
+ import '../Listbox/Listbox.js';
34
+ import '../RadioGroup/RadioGroup.js';
35
+ import '../Menu/Menu.js';
36
+ import '../Treeview/Treeview.js';
37
+ import '../Navigation/Navigation.js';
38
+ import '../Select/Select.js';
39
+ import '../Pagination/usePagination.js';
40
+ import '../Pagination/Pagination.js';
41
+ import '../Progress/Progress.js';
42
+ import '../Table/components/Table.js';
43
+ import '../Table/components/PaginatedTable.js';
44
+ import '../Table/components/WindowedTable.js';
45
+ import '../Table/util/rowIndexPath.js';
46
+ import '../Table/hooks/useRowCreation.js';
47
+ import '../Tabs/Tabs.js';
48
+ import '../Textarea/Textarea.js';
49
+ import '../Switch/Switch.js';
50
+ import '../Tour/Tour.js';
51
+ import '../../utils/hooks/useOnClickOutside.js';
52
+
53
+ var _excluded = ["onSearch"];
54
+ var SearchInput = /*#__PURE__*/forwardRef(function SearchInput(_ref, ref) {
55
+ var onSearch = _ref.onSearch,
56
+ props = _objectWithoutPropertiesLoose(_ref, _excluded);
57
+
58
+ var _useLocalization = useLocalization(),
59
+ texts = _useLocalization.texts;
60
+
61
+ var handleClick = function handleClick() {
62
+ if (!props.disabled) {
63
+ onSearch === null || onSearch === void 0 ? void 0 : onSearch(props.value);
64
+ }
65
+ };
66
+
67
+ var handleKeyDown = function handleKeyDown(event) {
68
+ var _props$onKeyDown;
69
+
70
+ var isEnterKeyPressed = event.keyCode === keycode('enter');
71
+
72
+ if (isEnterKeyPressed) {
73
+ handleClick();
74
+ }
75
+
76
+ (_props$onKeyDown = props.onKeyDown) === null || _props$onKeyDown === void 0 ? void 0 : _props$onKeyDown.call(props, event);
77
+ };
78
+
79
+ return createElement(Input, Object.assign({
80
+ "aria-label": texts.searchInput.inputLabel
81
+ }, props, {
82
+ button: createElement(IconButton, {
83
+ icon: "search",
84
+ className: "!border-transparent !bg-transparent focus:!border-transparent peer-focus:!border-transparent peer-focus:peer-active:!border-transparent",
85
+ disabled: props.disabled,
86
+ onClick: handleClick
87
+ }),
88
+ onKeyDown: handleKeyDown,
89
+ ref: ref,
90
+ type: "search"
91
+ }));
92
+ });
93
+
94
+ export { SearchInput };
95
+ //# sourceMappingURL=SearchInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SearchInput.js","sources":["../../../../src/components/SearchInput/SearchInput.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport keycode from 'keycode';\r\nimport { Input, InputProps, useLocalization, IconButton } from '../..';\r\n\r\nexport type SearchInputTexts = {\r\n /**\r\n * aria-label text for input\r\n */\r\n inputLabel: string;\r\n};\r\n\r\nexport type SearchInputProps = Omit<InputProps, 'icon'> & {\r\n /** Current input value will be passed to the method. In order to get the value, the component must be controlled otherwise value will always be undefined */\r\n onSearch?: (value: string | number | readonly string[] | undefined) => void;\r\n};\r\n\r\nexport const SearchInput = React.forwardRef(function SearchInput(\r\n { onSearch, ...props }: SearchInputProps,\r\n ref: React.Ref<HTMLInputElement>\r\n) {\r\n const { texts } = useLocalization();\r\n\r\n const handleClick = (): void => {\r\n if (!props.disabled) {\r\n onSearch?.(props.value);\r\n }\r\n };\r\n\r\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\r\n const isEnterKeyPressed = event.keyCode === keycode('enter');\r\n\r\n if (isEnterKeyPressed) {\r\n handleClick();\r\n }\r\n\r\n props.onKeyDown?.(event);\r\n };\r\n\r\n return (\r\n <Input\r\n aria-label={texts.searchInput.inputLabel}\r\n {...props}\r\n button={\r\n <IconButton\r\n icon=\"search\"\r\n className=\"!border-transparent !bg-transparent focus:!border-transparent peer-focus:!border-transparent peer-focus:peer-active:!border-transparent\"\r\n disabled={props.disabled}\r\n onClick={handleClick}\r\n />\r\n }\r\n onKeyDown={handleKeyDown}\r\n ref={ref}\r\n type=\"search\"\r\n />\r\n );\r\n});\r\n"],"names":["SearchInput","React","ref","onSearch","props","useLocalization","texts","handleClick","disabled","value","handleKeyDown","event","isEnterKeyPressed","keyCode","keycode","onKeyDown","Input","searchInput","inputLabel","button","IconButton","icon","className","onClick","type"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAgBaA,WAAW,gBAAGC,UAAA,CAAiB,SAASD,WAAT,OAExCE,GAFwC;MACtCC,gBAAAA;MAAaC;;AAGf,yBAAkBC,eAAe,EAAjC;AAAA,MAAQC,KAAR,oBAAQA,KAAR;;AAEA,MAAMC,WAAW,GAAG,SAAdA,WAAc;AAChB,QAAI,CAACH,KAAK,CAACI,QAAX,EAAqB;AACjBL,MAAAA,QAAQ,SAAR,IAAAA,QAAQ,WAAR,YAAAA,QAAQ,CAAGC,KAAK,CAACK,KAAT,CAAR;AACH;AACJ,GAJD;;AAMA,MAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACC,KAAD;;;AAClB,QAAMC,iBAAiB,GAAGD,KAAK,CAACE,OAAN,KAAkBC,OAAO,CAAC,OAAD,CAAnD;;AAEA,QAAIF,iBAAJ,EAAuB;AACnBL,MAAAA,WAAW;AACd;;AAED,wBAAAH,KAAK,CAACW,SAAN,2EAAAX,KAAK,EAAaO,KAAb,CAAL;AACH,GARD;;AAUA,SACIV,aAAA,CAACe,KAAD;kBACgBV,KAAK,CAACW,WAAN,CAAkBC;KAC1Bd;AACJe,IAAAA,MAAM,EACFlB,aAAA,CAACmB,UAAD;AACIC,MAAAA,IAAI,EAAC;AACLC,MAAAA,SAAS,EAAC;AACVd,MAAAA,QAAQ,EAAEJ,KAAK,CAACI;AAChBe,MAAAA,OAAO,EAAEhB;KAJb;AAOJQ,IAAAA,SAAS,EAAEL;AACXR,IAAAA,GAAG,EAAEA;AACLsB,IAAAA,IAAI,EAAC;IAbT,CADJ;AAiBH,CAvC0B;;;;"}
@@ -0,0 +1,100 @@
1
+ import { forwardRef, createElement, useRef, useEffect, Fragment } from 'react';
2
+ import cn from 'classnames';
3
+ import { Icon } from '../Icon/Icon.js';
4
+ import { Badge } from '../Badge/Badge.js';
5
+ import { Root, Trigger, Content } from '@radix-ui/react-popover';
6
+ import { getInputClasses } from '../Input/util.js';
7
+ import { useBoundingClientRectListener } from '../../utils/hooks/useBoundingClientRectListener.js';
8
+ import { Combobox } from '../Combobox/Combobox.js';
9
+ import { MultiListbox, Listbox } from '../Listbox/Listbox.js';
10
+ import { useSelect } from './useSelect.js';
11
+
12
+ const BaseSelect = /*#__PURE__*/forwardRef(function BaseSelect(props, ref) {
13
+ const {
14
+ autoFocus,
15
+ className: externalClassName,
16
+ highlighted,
17
+ style,
18
+ ...otherProps
19
+ } = props;
20
+ const {
21
+ button,
22
+ listbox,
23
+ popover,
24
+ input,
25
+ text,
26
+ more = 0
27
+ } = useSelect(otherProps, ref);
28
+ const internalRef = useRef(null);
29
+ const selectDimensions = useBoundingClientRectListener(internalRef);
30
+ const className = cn('inline-flex relative w-full', {
31
+ 'yt-select--readonly': props.readOnly
32
+ }, externalClassName);
33
+ const inputClassname = cn(getInputClasses(props), 'h-8 text-left pr-0', {
34
+ 'border-blue': popover.open
35
+ });
36
+ useEffect(() => {
37
+ if (autoFocus && internalRef.current) {
38
+ internalRef.current.focus();
39
+ }
40
+ }, []);
41
+
42
+ const renderMultiSelection = () => {
43
+ return createElement(Fragment, null, createElement("span", {
44
+ className: "flex-grow truncate text-left"
45
+ }, text), more > 0 && createElement(Badge, {
46
+ className: "ml-2"
47
+ }, `+${more}`));
48
+ };
49
+
50
+ const commonListboxProps = { ...listbox,
51
+ className: 'w-auto',
52
+ invalid: undefined,
53
+ style: {
54
+ minWidth: selectDimensions === null || selectDimensions === void 0 ? void 0 : selectDimensions.width
55
+ },
56
+ tabIndex: popover.open ? 0 : -1
57
+ };
58
+ return createElement("span", {
59
+ className: className,
60
+ "data-taco": "select",
61
+ style: style
62
+ }, createElement(Root, Object.assign({}, popover), createElement(Trigger, Object.assign({}, button, {
63
+ className: inputClassname,
64
+ ref: internalRef
65
+ }), props.multiselect ? renderMultiSelection() : createElement("span", {
66
+ className: "flex-grow truncate text-left"
67
+ }, text), createElement("span", {
68
+ className: "flex h-8 w-8 items-center justify-center"
69
+ }, createElement(Icon, {
70
+ className: "pointer-events-none",
71
+ name: popover.open ? 'chevron-up' : 'chevron-down'
72
+ }))), createElement(Content, {
73
+ align: "start",
74
+ sideOffset: 4
75
+ }, props.multiselect ? createElement(MultiListbox, Object.assign({}, commonListboxProps)) : createElement(Listbox, Object.assign({}, commonListboxProps))), createElement("input", Object.assign({}, input, {
76
+ className: "hidden",
77
+ type: "text"
78
+ }))));
79
+ });
80
+ const Select = /*#__PURE__*/forwardRef(function Select(props, ref) {
81
+ const {
82
+ editable,
83
+ ...otherProps
84
+ } = props;
85
+
86
+ if (editable) {
87
+ return createElement(Combobox, Object.assign({}, otherProps, {
88
+ dialog: undefined,
89
+ inline: true,
90
+ ref: ref
91
+ }));
92
+ }
93
+
94
+ return createElement(BaseSelect, Object.assign({}, otherProps, {
95
+ ref: ref
96
+ }));
97
+ });
98
+
99
+ export { Select };
100
+ //# sourceMappingURL=Select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Select.js","sources":["../../../../src/components/Select/Select.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport cn from 'classnames';\r\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\r\nimport { Icon } from '../Icon/Icon';\r\nimport { Listbox, MultiListbox, ListboxProps } from '../Listbox/Listbox';\r\nimport { useBoundingClientRectListener } from '../../utils/hooks/useBoundingClientRectListener';\r\nimport { useSelect } from './useSelect';\r\nimport { Combobox, ComboboxProps } from '../Combobox/Combobox';\r\nimport { Badge } from '../Badge/Badge';\r\nimport { getInputClasses } from '../Input/util';\r\n\r\nexport type SelectTexts = {\r\n /**\r\n * The text displayed when all options are selected when multiselect mode in on.\r\n */\r\n allOptionsSelected: string;\r\n};\r\n\r\nexport type BaseSelectProps = Omit<ListboxProps, 'dialog'> &\r\n Omit<ComboboxProps, 'inline'> & {\r\n /**\r\n * Allows to select multiple values.\r\n * All the selected values will be combined in a comma-seperated string as the value of the input.\r\n */\r\n multiselect?: boolean;\r\n };\r\n\r\nexport type SelectProps = BaseSelectProps & {\r\n /**\r\n * Creates an editable select.\r\n * Setting this will render a inline Combobox which will display the provided data on click/focus,\r\n * even if there is no value in the input.\r\n * After user starts typing, matching data will be displayed.\r\n */\r\n editable?: boolean;\r\n};\r\n\r\nconst BaseSelect = React.forwardRef(function BaseSelect(props: BaseSelectProps, ref: React.Ref<HTMLInputElement>) {\r\n const { autoFocus, className: externalClassName, highlighted, style, ...otherProps } = props;\r\n const { button, listbox, popover, input, text, more = 0 } = useSelect(otherProps, ref);\r\n const internalRef = React.useRef<HTMLButtonElement>(null);\r\n const selectDimensions = useBoundingClientRectListener(internalRef);\r\n const className = cn('inline-flex relative w-full', { 'yt-select--readonly': props.readOnly }, externalClassName);\r\n const inputClassname = cn(getInputClasses(props), 'h-8 text-left pr-0', {\r\n 'border-blue': popover.open,\r\n });\r\n\r\n React.useEffect(() => {\r\n if (autoFocus && internalRef.current) {\r\n internalRef.current.focus();\r\n }\r\n }, []);\r\n\r\n const renderMultiSelection = (): React.ReactNode => {\r\n return (\r\n <>\r\n <span className=\"flex-grow truncate text-left\">{text}</span>\r\n {more > 0 && <Badge className=\"ml-2\">{`+${more}`}</Badge>}\r\n </>\r\n );\r\n };\r\n\r\n const commonListboxProps: ListboxProps = {\r\n ...listbox,\r\n className: 'w-auto',\r\n invalid: undefined,\r\n style: { minWidth: selectDimensions?.width },\r\n tabIndex: popover.open ? 0 : -1,\r\n };\r\n\r\n return (\r\n <span className={className} data-taco=\"select\" style={style}>\r\n <PopoverPrimitive.Root {...popover}>\r\n <PopoverPrimitive.Trigger {...button} className={inputClassname} ref={internalRef}>\r\n {props.multiselect ? renderMultiSelection() : <span className=\"flex-grow truncate text-left\">{text}</span>}\r\n <span className=\"flex h-8 w-8 items-center justify-center\">\r\n <Icon className=\"pointer-events-none\" name={popover.open ? 'chevron-up' : 'chevron-down'} />\r\n </span>\r\n </PopoverPrimitive.Trigger>\r\n <PopoverPrimitive.Content align=\"start\" sideOffset={4}>\r\n {props.multiselect ? <MultiListbox {...commonListboxProps} /> : <Listbox {...commonListboxProps} />}\r\n </PopoverPrimitive.Content>\r\n <input {...input} className=\"hidden\" type=\"text\" />\r\n </PopoverPrimitive.Root>\r\n </span>\r\n );\r\n});\r\n\r\nexport const Select = React.forwardRef(function Select(props: SelectProps, ref: React.Ref<HTMLInputElement>) {\r\n const { editable, ...otherProps } = props;\r\n\r\n if (editable) {\r\n return <Combobox {...otherProps} dialog={undefined} inline ref={ref} />;\r\n }\r\n\r\n return <BaseSelect {...otherProps} ref={ref} />;\r\n});\r\n"],"names":["BaseSelect","React","props","ref","autoFocus","className","externalClassName","highlighted","style","otherProps","button","listbox","popover","input","text","more","useSelect","internalRef","selectDimensions","useBoundingClientRectListener","cn","readOnly","inputClassname","getInputClasses","open","current","focus","renderMultiSelection","Badge","commonListboxProps","invalid","undefined","minWidth","width","tabIndex","PopoverPrimitive","multiselect","Icon","name","align","sideOffset","MultiListbox","Listbox","type","Select","editable","Combobox","dialog","inline"],"mappings":"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"}
@@ -0,0 +1,212 @@
1
+ import { useState, useMemo, useRef, useEffect, createElement, Fragment, cloneElement } from 'react';
2
+ import cn from 'classnames';
3
+ import { v4 } from 'uuid';
4
+ import { useLocalization } from '../Provider/Provider.js';
5
+ import { useProxiedRef } from '../../utils/hooks/useProxiedRef.js';
6
+ import keycode from 'keycode';
7
+ import { createCustomEvent } from '../../utils/input.js';
8
+ import { useFlattenedData, findByValue, setInputValueByRef, sanitizeItem } from '../Listbox/util.js';
9
+
10
+ const useSelect = ({
11
+ 'aria-label': ariaLabel,
12
+ 'aria-labelledby': ariaLabelledBy,
13
+ data = [],
14
+ defaultValue,
15
+ disabled,
16
+ emptyValue,
17
+ id: nativeId,
18
+ multiselect,
19
+ onBlur,
20
+ onClick,
21
+ onChange,
22
+ readOnly,
23
+ value,
24
+ ...otherProps
25
+ }, ref) => {
26
+ const {
27
+ texts
28
+ } = useLocalization();
29
+ const flattenedData = useFlattenedData(data);
30
+ const listboxInputRef = useProxiedRef(ref);
31
+ const [open, setOpen] = useState(false);
32
+ const id = useMemo(() => nativeId || `select_${v4()}`, [nativeId]);
33
+ const inputRef = useRef(null);
34
+ const buttonId = `${id}-button`; // support 'escape' resetting to the value that was set when the listbox opened
35
+
36
+ const [lastValue, setLastValue] = useState(value);
37
+ useEffect(() => {
38
+ setLastValue(value);
39
+ }, [open]);
40
+ useEffect(() => {
41
+ if (value === undefined) {
42
+ if (defaultValue !== undefined && findByValue(flattenedData, defaultValue)) {
43
+ setInputValueByRef(inputRef.current, defaultValue);
44
+ } else {
45
+ if (emptyValue !== undefined) {
46
+ setInputValueByRef(inputRef.current, emptyValue);
47
+ } else if (data.length > 0) {
48
+ setInputValueByRef(inputRef.current, data[0].value);
49
+ }
50
+ }
51
+ } else {
52
+ if (!multiselect && !findByValue(flattenedData, value)) {
53
+ if (emptyValue !== undefined) {
54
+ setInputValueByRef(inputRef.current, emptyValue);
55
+ } else if (data.length > 0) {
56
+ setInputValueByRef(inputRef.current, data[0].value);
57
+ }
58
+ }
59
+ }
60
+ }, []); // event handlers
61
+
62
+ const handleButtonKeyDown = event => {
63
+ if (event.keyCode === keycode('up') || event.keyCode === keycode('down')) {
64
+ event.preventDefault();
65
+ setOpen(true);
66
+ }
67
+ };
68
+
69
+ const handleListboxKeyDown = event => {
70
+ switch (event.keyCode) {
71
+ case keycode('escape'):
72
+ {
73
+ event.preventDefault();
74
+
75
+ if (lastValue !== undefined) {
76
+ setInputValueByRef(listboxInputRef.current, lastValue);
77
+ }
78
+
79
+ setOpen(false);
80
+ break;
81
+ }
82
+
83
+ case keycode('tab'):
84
+ case keycode('enter'):
85
+ {
86
+ if (event.keyCode !== keycode('tab')) {
87
+ event.preventDefault();
88
+ }
89
+
90
+ setOpen(false);
91
+ break;
92
+ }
93
+ }
94
+
95
+ if (otherProps.onKeyDown) {
96
+ otherProps.onKeyDown(event);
97
+ }
98
+ };
99
+
100
+ const handleListboxClick = event => {
101
+ event.preventDefault();
102
+
103
+ if (!multiselect) {
104
+ setOpen(false);
105
+
106
+ if (onBlur) {
107
+ onBlur(createCustomEvent('blur'));
108
+ }
109
+ }
110
+ };
111
+
112
+ let text = '';
113
+ let more = 0;
114
+
115
+ if (value !== undefined) {
116
+ if (multiselect) {
117
+ const selectedValues = (value === null || value === void 0 ? void 0 : value.toString().split(',')) || [];
118
+
119
+ if (selectedValues.length === flattenedData.filter(item => !item.disabled).length) {
120
+ text = texts.select.allOptionsSelected;
121
+ } else {
122
+ var _findByValue$text, _findByValue;
123
+
124
+ text = (_findByValue$text = (_findByValue = findByValue(flattenedData, selectedValues[0])) === null || _findByValue === void 0 ? void 0 : _findByValue.text) !== null && _findByValue$text !== void 0 ? _findByValue$text : '';
125
+ more = selectedValues.length > 1 ? selectedValues.length - 1 : 0;
126
+ }
127
+ } else {
128
+ const item = findByValue(flattenedData, value);
129
+
130
+ if (item) {
131
+ text = item.icon ? createElement(Fragment, null, cloneElement(item.icon, {
132
+ className: cn(item.icon.props.className, 'mr-1 -mt-px')
133
+ }), item.text) : item.text;
134
+ }
135
+ }
136
+ }
137
+
138
+ const handleInputChange = event => {
139
+ event.persist();
140
+
141
+ if (onChange) {
142
+ var _item$path$split, _item$path;
143
+
144
+ const item = findByValue(flattenedData, event.target.value);
145
+ event.detail = sanitizeItem(item);
146
+ const indexes = (_item$path$split = item === null || item === void 0 ? void 0 : (_item$path = item.path) === null || _item$path === void 0 ? void 0 : _item$path.split('.')) !== null && _item$path$split !== void 0 ? _item$path$split : [];
147
+
148
+ if (indexes.length > 1) {
149
+ // we don't want to map the current item
150
+ indexes.pop(); // we need to rebuild the path as we map
151
+
152
+ let lastPath;
153
+ event.detail.parents = indexes.map(i => {
154
+ lastPath = lastPath ? [lastPath, i].join('.') : i;
155
+ return sanitizeItem(flattenedData.find(i => i.path === lastPath));
156
+ });
157
+ }
158
+
159
+ onChange(event);
160
+ }
161
+ };
162
+
163
+ const button = {
164
+ 'aria-haspopup': 'listbox',
165
+ 'aria-label': ariaLabel ? `${ariaLabel} ${text}` : undefined,
166
+ 'aria-labelledby': ariaLabelledBy ? `${ariaLabelledBy} ${buttonId}` : undefined,
167
+ disabled: disabled || readOnly,
168
+ id: buttonId,
169
+ onKeyDown: !disabled && !readOnly ? handleButtonKeyDown : undefined,
170
+ type: 'button'
171
+ };
172
+ const listbox = { ...otherProps,
173
+ 'aria-label': ariaLabel,
174
+ 'aria-labelledby': ariaLabelledBy,
175
+ data,
176
+ disabled,
177
+ emptyValue,
178
+ onBlur,
179
+ onClick: handleListboxClick,
180
+ onChange: event => {
181
+ setInputValueByRef(inputRef.current, event.target.value);
182
+ },
183
+ onKeyDown: handleListboxKeyDown,
184
+ ref: listboxInputRef,
185
+ value
186
+ };
187
+ const input = {
188
+ onChange: handleInputChange,
189
+ ref: inputRef,
190
+ value: String(value !== null && value !== void 0 ? value : '')
191
+ };
192
+ return {
193
+ button,
194
+ listbox,
195
+ input,
196
+ popover: {
197
+ open,
198
+ onOpenChange: open => {
199
+ if (!open && onBlur) {
200
+ onBlur(createCustomEvent('blur'));
201
+ }
202
+
203
+ setOpen(open);
204
+ }
205
+ },
206
+ text,
207
+ more
208
+ };
209
+ };
210
+
211
+ export { useSelect };
212
+ //# sourceMappingURL=useSelect.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSelect.js","sources":["../../../../src/components/Select/useSelect.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport keycode from 'keycode';\r\nimport cn from 'classnames';\r\nimport { v4 as uuid } from 'uuid';\r\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\r\nimport { useLocalization } from '../Provider/Provider';\r\nimport { SelectProps } from './Select';\r\nimport { ListboxProps } from '../Listbox/Listbox';\r\nimport { useProxiedRef } from '../../utils/hooks/useProxiedRef';\r\nimport { setInputValueByRef, findByValue, useFlattenedData, sanitizeItem } from '../Listbox/util';\r\nimport { ScrollableListItemValue } from '../Listbox/ScrollableList';\r\nimport { createCustomEvent } from '../../utils/input';\r\n\r\ntype InternalButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement>;\r\ntype InternalListboxProps = ListboxProps & { ref: React.ForwardedRef<HTMLInputElement> };\r\ntype InternalInputProps = React.InputHTMLAttributes<HTMLInputElement> & { ref: React.ForwardedRef<HTMLInputElement> };\r\n\r\ntype useSelect = React.HtmlHTMLAttributes<HTMLDivElement> & {\r\n button: InternalButtonProps;\r\n listbox: InternalListboxProps;\r\n input: InternalInputProps;\r\n popover: Pick<PopoverPrimitive.PopoverProps, 'onOpenChange' | 'open'>;\r\n text: string | JSX.Element;\r\n more?: number;\r\n};\r\n\r\nexport const useSelect = (\r\n {\r\n 'aria-label': ariaLabel,\r\n 'aria-labelledby': ariaLabelledBy,\r\n data = [],\r\n defaultValue,\r\n disabled,\r\n emptyValue,\r\n id: nativeId,\r\n multiselect,\r\n onBlur,\r\n onClick,\r\n onChange,\r\n readOnly,\r\n value,\r\n ...otherProps\r\n }: SelectProps,\r\n ref: React.Ref<HTMLInputElement>\r\n): useSelect => {\r\n const { texts } = useLocalization();\r\n const flattenedData = useFlattenedData(data);\r\n const listboxInputRef = useProxiedRef<HTMLInputElement>(ref);\r\n const [open, setOpen] = React.useState(false);\r\n const id = React.useMemo(() => nativeId || `select_${uuid()}`, [nativeId]);\r\n const inputRef = React.useRef<HTMLInputElement>(null);\r\n const buttonId = `${id}-button`;\r\n // support 'escape' resetting to the value that was set when the listbox opened\r\n const [lastValue, setLastValue] = React.useState<ScrollableListItemValue | undefined>(value);\r\n\r\n React.useEffect(() => {\r\n setLastValue(value);\r\n }, [open]);\r\n\r\n React.useEffect(() => {\r\n if (value === undefined) {\r\n if (defaultValue !== undefined && findByValue(flattenedData, defaultValue)) {\r\n setInputValueByRef(inputRef.current, defaultValue);\r\n } else {\r\n if (emptyValue !== undefined) {\r\n setInputValueByRef(inputRef.current, emptyValue);\r\n } else if (data.length > 0) {\r\n setInputValueByRef(inputRef.current, data[0].value);\r\n }\r\n }\r\n } else {\r\n if (!multiselect && !findByValue(flattenedData, value)) {\r\n if (emptyValue !== undefined) {\r\n setInputValueByRef(inputRef.current, emptyValue);\r\n } else if (data.length > 0) {\r\n setInputValueByRef(inputRef.current, data[0].value);\r\n }\r\n }\r\n }\r\n }, []);\r\n\r\n // event handlers\r\n const handleButtonKeyDown = (event: React.KeyboardEvent<HTMLButtonElement>): void => {\r\n if (event.keyCode === keycode('up') || event.keyCode === keycode('down')) {\r\n event.preventDefault();\r\n setOpen(true);\r\n }\r\n };\r\n\r\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\r\n switch (event.keyCode) {\r\n case keycode('escape'): {\r\n event.preventDefault();\r\n if (lastValue !== undefined) {\r\n setInputValueByRef(listboxInputRef.current, lastValue);\r\n }\r\n\r\n setOpen(false);\r\n break;\r\n }\r\n\r\n case keycode('tab'):\r\n case keycode('enter'): {\r\n if (event.keyCode !== keycode('tab')) {\r\n event.preventDefault();\r\n }\r\n setOpen(false);\r\n break;\r\n }\r\n\r\n default:\r\n }\r\n\r\n if (otherProps.onKeyDown) {\r\n otherProps.onKeyDown(event);\r\n }\r\n };\r\n\r\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>): void => {\r\n event.preventDefault();\r\n if (!multiselect) {\r\n setOpen(false);\r\n if (onBlur) {\r\n onBlur(createCustomEvent('blur'));\r\n }\r\n }\r\n };\r\n\r\n let text: string | JSX.Element = '';\r\n let more = 0;\r\n\r\n if (value !== undefined) {\r\n if (multiselect) {\r\n const selectedValues = value?.toString().split(',') || [];\r\n\r\n if (selectedValues.length === flattenedData.filter(item => !item.disabled).length) {\r\n text = texts.select.allOptionsSelected;\r\n } else {\r\n text = findByValue(flattenedData, selectedValues[0])?.text ?? '';\r\n more = selectedValues.length > 1 ? selectedValues.length - 1 : 0;\r\n }\r\n } else {\r\n const item = findByValue(flattenedData, value);\r\n\r\n if (item) {\r\n text = item.icon ? (\r\n <>\r\n {React.cloneElement(item.icon, {\r\n className: cn(item.icon.props.className, 'mr-1 -mt-px'),\r\n })}\r\n {item.text}\r\n </>\r\n ) : (\r\n item.text\r\n );\r\n }\r\n }\r\n }\r\n\r\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\r\n event.persist();\r\n\r\n if (onChange) {\r\n const item = findByValue(flattenedData, event.target.value);\r\n (event as any).detail = sanitizeItem(item);\r\n\r\n const indexes = item?.path?.split('.') ?? [];\r\n\r\n if (indexes.length > 1) {\r\n // we don't want to map the current item\r\n indexes.pop();\r\n // we need to rebuild the path as we map\r\n let lastPath: string;\r\n\r\n (event as any).detail.parents = indexes.map(i => {\r\n lastPath = lastPath ? [lastPath, i].join('.') : i;\r\n return sanitizeItem(flattenedData.find(i => i.path === lastPath));\r\n });\r\n }\r\n\r\n onChange(event);\r\n }\r\n };\r\n\r\n const button: InternalButtonProps = {\r\n 'aria-haspopup': 'listbox' as const,\r\n 'aria-label': ariaLabel ? `${ariaLabel} ${text}` : undefined,\r\n 'aria-labelledby': ariaLabelledBy ? `${ariaLabelledBy} ${buttonId}` : undefined,\r\n disabled: disabled || readOnly,\r\n id: buttonId,\r\n onKeyDown: !disabled && !readOnly ? handleButtonKeyDown : undefined,\r\n type: 'button',\r\n };\r\n\r\n const listbox: InternalListboxProps = {\r\n ...otherProps,\r\n 'aria-label': ariaLabel,\r\n 'aria-labelledby': ariaLabelledBy,\r\n data,\r\n disabled,\r\n emptyValue,\r\n onBlur,\r\n onClick: handleListboxClick,\r\n onChange: event => {\r\n setInputValueByRef(inputRef.current, event.target.value);\r\n },\r\n onKeyDown: handleListboxKeyDown,\r\n ref: listboxInputRef,\r\n value,\r\n };\r\n\r\n const input: InternalInputProps = {\r\n onChange: handleInputChange,\r\n ref: inputRef,\r\n value: String(value ?? ''),\r\n };\r\n\r\n return {\r\n button,\r\n listbox,\r\n input,\r\n popover: {\r\n open,\r\n onOpenChange: open => {\r\n if (!open && onBlur) {\r\n onBlur(createCustomEvent('blur'));\r\n }\r\n setOpen(open);\r\n },\r\n },\r\n text,\r\n more,\r\n };\r\n};\r\n"],"names":["useSelect","ariaLabel","ariaLabelledBy","data","defaultValue","disabled","emptyValue","id","nativeId","multiselect","onBlur","onClick","onChange","readOnly","value","otherProps","ref","texts","useLocalization","flattenedData","useFlattenedData","listboxInputRef","useProxiedRef","open","setOpen","React","uuid","inputRef","buttonId","lastValue","setLastValue","undefined","findByValue","setInputValueByRef","current","length","handleButtonKeyDown","event","keyCode","keycode","preventDefault","handleListboxKeyDown","onKeyDown","handleListboxClick","createCustomEvent","text","more","selectedValues","toString","split","filter","item","select","allOptionsSelected","icon","className","cn","props","handleInputChange","persist","target","detail","sanitizeItem","indexes","path","pop","lastPath","parents","map","i","join","find","button","type","listbox","input","String","popover","onOpenChange"],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ import React__default from 'react';
2
+ import cn from 'classnames';
3
+
4
+ const Spinner = /*#__PURE__*/React__default.forwardRef(function Spinner(props, ref) {
5
+ const {
6
+ delay = 500,
7
+ label,
8
+ ...otherProps
9
+ } = props;
10
+ const [visible, setVisibility] = React__default.useState(!delay);
11
+ React__default.useEffect(() => {
12
+ let timeout;
13
+
14
+ if (delay) {
15
+ timeout = window.setTimeout(() => setVisibility(true), delay);
16
+ }
17
+
18
+ return () => {
19
+ if (timeout) {
20
+ clearTimeout(timeout);
21
+ }
22
+ };
23
+ }, [delay]);
24
+
25
+ if (!visible) {
26
+ return null;
27
+ }
28
+
29
+ const className = cn('inline-flex flex-col relative items-center', otherProps.className);
30
+ return React__default.createElement("div", Object.assign({}, otherProps, {
31
+ className: className,
32
+ "data-taco": "spinner",
33
+ ref: ref
34
+ }), React__default.createElement("svg", {
35
+ className: "h-10 w-10 animate-[spinnerRotation_2s_linear_infinite]",
36
+ viewBox: "0 0 100 100",
37
+ xmlns: "http://www.w3.org/2000/svg"
38
+ }, React__default.createElement("circle", {
39
+ cx: "50",
40
+ cy: "50",
41
+ r: "45"
42
+ })), label && React__default.createElement("span", {
43
+ className: "mt-4"
44
+ }, label));
45
+ });
46
+
47
+ export { Spinner };
48
+ //# sourceMappingURL=Spinner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Spinner.js","sources":["../../../../src/components/Spinner/Spinner.tsx"],"sourcesContent":["import React from 'react';\r\nimport cn from 'classnames';\r\nimport './Spinner.css';\r\n\r\nexport type SpinnerProps = React.HTMLAttributes<HTMLDivElement> & {\r\n /**\r\n * Define a delay in milliseconds after which the spinner is shown.\r\n * Default value is `500`ms\r\n */\r\n delay?: number;\r\n /** Define a text that will be displayed below spinner */\r\n label?: string;\r\n};\r\n\r\nexport const Spinner = React.forwardRef(function Spinner(props: SpinnerProps, ref: React.Ref<HTMLDivElement>) {\r\n const { delay = 500, label, ...otherProps } = props;\r\n const [visible, setVisibility] = React.useState(!delay);\r\n\r\n React.useEffect(() => {\r\n let timeout: number;\r\n\r\n if (delay) {\r\n timeout = window.setTimeout(() => setVisibility(true), delay);\r\n }\r\n\r\n return () => {\r\n if (timeout) {\r\n clearTimeout(timeout);\r\n }\r\n };\r\n }, [delay]);\r\n\r\n if (!visible) {\r\n return null;\r\n }\r\n\r\n const className = cn('inline-flex flex-col relative items-center', otherProps.className);\r\n\r\n return (\r\n <div {...otherProps} className={className} data-taco=\"spinner\" ref={ref}>\r\n <svg\r\n className=\"h-10 w-10 animate-[spinnerRotation_2s_linear_infinite]\"\r\n viewBox=\"0 0 100 100\"\r\n xmlns=\"http://www.w3.org/2000/svg\"\r\n >\r\n <circle cx=\"50\" cy=\"50\" r=\"45\"></circle>\r\n </svg>\r\n {label && <span className=\"mt-4\">{label}</span>}\r\n </div>\r\n );\r\n});\r\n"],"names":["Spinner","React","forwardRef","props","ref","delay","label","otherProps","visible","setVisibility","useState","useEffect","timeout","window","setTimeout","clearTimeout","className","cn","viewBox","xmlns","cx","cy","r"],"mappings":";;;MAcaA,OAAO,gBAAGC,cAAK,CAACC,UAAN,CAAiB,SAASF,OAAT,CAAiBG,KAAjB,EAAsCC,GAAtC;AACpC,QAAM;AAAEC,IAAAA,KAAK,GAAG,GAAV;AAAeC,IAAAA,KAAf;AAAsB,OAAGC;AAAzB,MAAwCJ,KAA9C;AACA,QAAM,CAACK,OAAD,EAAUC,aAAV,IAA2BR,cAAK,CAACS,QAAN,CAAe,CAACL,KAAhB,CAAjC;AAEAJ,EAAAA,cAAK,CAACU,SAAN,CAAgB;AACZ,QAAIC,OAAJ;;AAEA,QAAIP,KAAJ,EAAW;AACPO,MAAAA,OAAO,GAAGC,MAAM,CAACC,UAAP,CAAkB,MAAML,aAAa,CAAC,IAAD,CAArC,EAA6CJ,KAA7C,CAAV;AACH;;AAED,WAAO;AACH,UAAIO,OAAJ,EAAa;AACTG,QAAAA,YAAY,CAACH,OAAD,CAAZ;AACH;AACJ,KAJD;AAKH,GAZD,EAYG,CAACP,KAAD,CAZH;;AAcA,MAAI,CAACG,OAAL,EAAc;AACV,WAAO,IAAP;AACH;;AAED,QAAMQ,SAAS,GAAGC,EAAE,CAAC,4CAAD,EAA+CV,UAAU,CAACS,SAA1D,CAApB;AAEA,SACIf,4BAAA,MAAA,oBAASM;AAAYS,IAAAA,SAAS,EAAEA;iBAAqB;AAAUZ,IAAAA,GAAG,EAAEA;IAApE,EACIH,4BAAA,MAAA;AACIe,IAAAA,SAAS,EAAC;AACVE,IAAAA,OAAO,EAAC;AACRC,IAAAA,KAAK,EAAC;GAHV,EAKIlB,4BAAA,SAAA;AAAQmB,IAAAA,EAAE,EAAC;AAAKC,IAAAA,EAAE,EAAC;AAAKC,IAAAA,CAAC,EAAC;GAA1B,CALJ,CADJ,EAQKhB,KAAK,IAAIL,4BAAA,OAAA;AAAMe,IAAAA,SAAS,EAAC;GAAhB,EAAwBV,KAAxB,CARd,CADJ;AAYH,CApCsB;;;;"}