@onesy/ui-react 1.0.130 → 1.0.131

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 (444) hide show
  1. package/Accordion/Accordion.js +342 -242
  2. package/Accordion/index.js +12 -7
  3. package/AdvancedTextField/AdvancedTextField.js +165 -157
  4. package/AdvancedTextField/index.js +12 -7
  5. package/Append/Append.js +502 -519
  6. package/Append/index.js +12 -7
  7. package/AreaChart/AreaChart.js +53 -40
  8. package/AreaChart/index.js +12 -7
  9. package/AreaChartItem/AreaChartItem.js +325 -237
  10. package/AreaChartItem/index.js +12 -7
  11. package/AudioPlayer/AudioPlayer.js +683 -466
  12. package/AudioPlayer/index.js +12 -7
  13. package/AudioRecorder/AudioRecorder.js +359 -259
  14. package/AudioRecorder/index.js +12 -7
  15. package/AutoComplete/AutoComplete.js +693 -568
  16. package/AutoComplete/index.js +12 -7
  17. package/AutoCompleteCountry/AutoCompleteCountry.js +99 -62
  18. package/AutoCompleteCountry/index.js +12 -7
  19. package/AutoCompleteCurrency/AutoCompleteCurrency.js +73 -61
  20. package/AutoCompleteCurrency/index.js +12 -7
  21. package/Avatar/Avatar.js +113 -86
  22. package/Avatar/index.js +12 -7
  23. package/AvatarGroup/AvatarGroup.js +104 -87
  24. package/AvatarGroup/index.js +12 -7
  25. package/Backdrop/Backdrop.js +160 -139
  26. package/Backdrop/index.js +12 -7
  27. package/Badge/Badge.js +116 -96
  28. package/Badge/index.js +12 -7
  29. package/Banner/Banner.js +126 -85
  30. package/Banner/index.js +12 -7
  31. package/BottomAppBar/BottomAppBar.js +89 -60
  32. package/BottomAppBar/index.js +12 -7
  33. package/BottomSheet/BottomSheet.js +66 -59
  34. package/BottomSheet/index.js +12 -7
  35. package/Box/Box.js +43 -35
  36. package/Box/index.js +12 -7
  37. package/Breadcrumbs/Breadcrumbs.js +168 -144
  38. package/Breadcrumbs/index.js +12 -7
  39. package/BubbleChart/BubbleChart.js +261 -132
  40. package/BubbleChart/index.js +12 -7
  41. package/BubbleChartItem/BubbleChartItem.js +228 -161
  42. package/BubbleChartItem/index.js +12 -7
  43. package/Button/Button.js +488 -467
  44. package/Button/index.js +12 -7
  45. package/Buttons/Buttons.js +366 -293
  46. package/Buttons/index.js +12 -7
  47. package/Calendar/Calendar.js +715 -452
  48. package/Calendar/index.js +12 -7
  49. package/CalendarAvailability/CalendarAvailability.js +709 -388
  50. package/CalendarAvailability/index.js +12 -7
  51. package/CalendarMenu/CalendarMenu.js +430 -303
  52. package/CalendarMenu/index.js +12 -7
  53. package/CalendarMonth/CalendarMonth.js +537 -498
  54. package/CalendarMonth/index.js +12 -7
  55. package/CalendarViews/CalendarViews.js +403 -254
  56. package/CalendarViews/index.js +12 -7
  57. package/CalendarWeek/CalendarWeek.js +536 -395
  58. package/CalendarWeek/index.js +12 -7
  59. package/Card/Card.js +133 -101
  60. package/Card/index.js +12 -7
  61. package/CardButton/CardButton.js +78 -58
  62. package/CardButton/index.js +12 -7
  63. package/CardFooter/CardFooter.js +58 -39
  64. package/CardFooter/index.js +12 -7
  65. package/CardHeader/CardHeader.js +61 -44
  66. package/CardHeader/index.js +12 -7
  67. package/CardImage/CardImage.js +80 -67
  68. package/CardImage/index.js +12 -7
  69. package/CardMain/CardMain.js +53 -39
  70. package/CardMain/index.js +12 -7
  71. package/Carousel/Carousel.js +1025 -913
  72. package/Carousel/index.js +12 -7
  73. package/Chart/Chart.js +1325 -1174
  74. package/Chart/index.js +12 -7
  75. package/Checkbox/Checkbox.js +339 -325
  76. package/Checkbox/index.js +12 -7
  77. package/Chip/Chip.js +131 -102
  78. package/Chip/index.js +12 -7
  79. package/Chips/Chips.js +121 -94
  80. package/Chips/index.js +12 -7
  81. package/ClickListener/ClickListener.js +86 -89
  82. package/ClickListener/index.js +12 -7
  83. package/Clock/Clock.js +470 -417
  84. package/Clock/index.js +12 -7
  85. package/ColorTextField/ColorTextField.js +234 -171
  86. package/ColorTextField/index.js +12 -7
  87. package/ColumnChart/ColumnChart.js +63 -46
  88. package/ColumnChart/index.js +12 -7
  89. package/ColumnChartItem/ColumnChartItem.js +208 -149
  90. package/ColumnChartItem/index.js +12 -7
  91. package/Confirm/Confirm.js +184 -129
  92. package/Confirm/Context.js +9 -7
  93. package/Confirm/index.js +32 -13
  94. package/Confirm/useConfirm.js +11 -10
  95. package/Container/Container.js +154 -133
  96. package/Container/index.js +12 -7
  97. package/CookieBanner/CookieBanner.js +142 -76
  98. package/CookieBanner/index.js +12 -7
  99. package/Countdown/Countdown.js +403 -255
  100. package/Countdown/index.js +12 -7
  101. package/DatePicker/DatePicker.js +802 -547
  102. package/DatePicker/index.js +12 -7
  103. package/DateRangePicker/DateRangePicker.js +44 -37
  104. package/DateRangePicker/index.js +12 -7
  105. package/DateTimePicker/DateTimePicker.js +672 -459
  106. package/DateTimePicker/index.js +12 -7
  107. package/DateTimeRangePicker/DateTimeRangePicker.js +44 -37
  108. package/DateTimeRangePicker/index.js +12 -7
  109. package/Divider/Divider.js +198 -185
  110. package/Divider/index.js +12 -7
  111. package/DonutChart/DonutChart.js +49 -42
  112. package/DonutChart/index.js +12 -7
  113. package/DragAndDropList/DragAndDropList.js +160 -156
  114. package/DragAndDropList/index.js +12 -7
  115. package/Drawing/Drawing.js +850 -523
  116. package/Drawing/index.js +12 -7
  117. package/DropZone/DropZone.js +239 -201
  118. package/DropZone/index.js +12 -7
  119. package/Emojis/Emojis.js +409 -317
  120. package/Emojis/emojis_list.js +7279 -9250
  121. package/Emojis/index.js +19 -9
  122. package/Expand/Expand.js +201 -149
  123. package/Expand/index.js +12 -7
  124. package/Fab/Fab.js +46 -26
  125. package/Fab/index.js +12 -7
  126. package/Fade/Fade.js +131 -101
  127. package/Fade/index.js +12 -7
  128. package/FileChoose/FileChoose.js +218 -150
  129. package/FileChoose/index.js +12 -7
  130. package/Focus/Focus.js +87 -88
  131. package/Focus/index.js +12 -7
  132. package/Form/Form.js +194 -120
  133. package/Form/index.js +12 -7
  134. package/FormRow/FormRow.js +123 -78
  135. package/FormRow/index.js +12 -7
  136. package/Forms/Forms.js +55 -41
  137. package/Forms/index.js +12 -7
  138. package/Frame/Frame.js +212 -150
  139. package/Frame/index.js +12 -7
  140. package/Grid/Grid.js +231 -166
  141. package/Grid/index.js +12 -7
  142. package/Grow/Grow.js +137 -109
  143. package/Grow/index.js +12 -7
  144. package/HTMLCanvas/HTMLCanvas.js +752 -542
  145. package/HTMLCanvas/index.js +24 -21
  146. package/IFrame/IFrame.js +122 -104
  147. package/IFrame/index.js +12 -7
  148. package/Icon/Icon.js +112 -95
  149. package/Icon/index.js +24 -21
  150. package/IconButton/IconButton.js +49 -37
  151. package/IconButton/index.js +12 -7
  152. package/Image/Image.js +285 -252
  153. package/Image/index.js +12 -7
  154. package/ImageCrop/ImageCrop.js +1073 -1048
  155. package/ImageCrop/index.js +12 -7
  156. package/ImageEdit/ImageEdit.js +1088 -783
  157. package/ImageEdit/index.js +12 -7
  158. package/ImageGallery/ImageGallery.js +518 -473
  159. package/ImageGallery/index.js +12 -7
  160. package/ImageList/ImageList.js +136 -129
  161. package/ImageList/index.js +12 -7
  162. package/ImageListItem/ImageListItem.js +101 -87
  163. package/ImageListItem/index.js +12 -7
  164. package/ImageListItemBox/ImageListItemBox.js +61 -50
  165. package/ImageListItemBox/index.js +12 -7
  166. package/Info/Info.js +99 -63
  167. package/Info/index.js +12 -7
  168. package/Interaction/Interaction.js +405 -345
  169. package/Interaction/index.js +12 -7
  170. package/Keyframes/Context.js +9 -7
  171. package/Keyframes/Keyframes.js +189 -174
  172. package/Keyframes/index.js +42 -25
  173. package/Keyframes/useKeyframes.js +11 -10
  174. package/Label/Label.js +177 -151
  175. package/Label/index.js +12 -7
  176. package/Labels/Labels.js +126 -98
  177. package/Labels/index.js +12 -7
  178. package/Line/Line.js +296 -174
  179. package/Line/index.js +12 -7
  180. package/LineChart/LineChart.js +57 -40
  181. package/LineChart/index.js +12 -7
  182. package/LineChartItem/LineChartItem.js +239 -177
  183. package/LineChartItem/index.js +12 -7
  184. package/LinearMeter/LinearMeter.js +453 -377
  185. package/LinearMeter/index.js +12 -7
  186. package/LinearProgress/LinearProgress.js +324 -255
  187. package/LinearProgress/index.js +12 -7
  188. package/Link/Link.js +182 -127
  189. package/Link/index.js +12 -7
  190. package/Links/Links.js +277 -156
  191. package/Links/index.js +12 -7
  192. package/List/List.js +148 -113
  193. package/List/index.js +12 -7
  194. package/ListItem/ListItem.js +388 -362
  195. package/ListItem/index.js +12 -7
  196. package/ListSubheader/ListSubheader.js +52 -44
  197. package/ListSubheader/index.js +12 -7
  198. package/MainProgress/Context.js +9 -7
  199. package/MainProgress/MainProgress.js +193 -161
  200. package/MainProgress/index.js +32 -13
  201. package/MainProgress/useMainProgress.js +11 -10
  202. package/Markdown/Markdown.js +676 -704
  203. package/Markdown/index.js +12 -7
  204. package/Masonry/Masonry.js +207 -181
  205. package/Masonry/index.js +12 -7
  206. package/Medias/Medias.js +436 -398
  207. package/Medias/index.js +12 -7
  208. package/Menu/Menu.js +278 -243
  209. package/Menu/index.js +12 -7
  210. package/MenuDesktop/MenuDesktop.js +496 -419
  211. package/MenuDesktop/index.js +12 -7
  212. package/MenuItem/MenuItem.js +286 -231
  213. package/MenuItem/index.js +12 -7
  214. package/Meta/Meta.js +78 -54
  215. package/Meta/index.js +12 -7
  216. package/Modal/Modal.js +333 -272
  217. package/Modal/index.js +12 -7
  218. package/ModalFooter/ModalFooter.js +50 -39
  219. package/ModalFooter/index.js +12 -7
  220. package/ModalHeader/ModalHeader.js +51 -39
  221. package/ModalHeader/index.js +12 -7
  222. package/ModalIcon/ModalIcon.js +29 -23
  223. package/ModalIcon/index.js +12 -7
  224. package/ModalMain/ModalMain.js +50 -41
  225. package/ModalMain/index.js +12 -7
  226. package/ModalText/ModalText.js +47 -37
  227. package/ModalText/index.js +12 -7
  228. package/ModalTitle/ModalTitle.js +47 -37
  229. package/ModalTitle/index.js +12 -7
  230. package/MoreOptions/MoreOptions.js +72 -52
  231. package/MoreOptions/index.js +12 -7
  232. package/Move/Move.js +166 -141
  233. package/Move/index.js +12 -7
  234. package/NavigationBar/NavigationBar.js +133 -109
  235. package/NavigationBar/index.js +12 -7
  236. package/NavigationDrawer/NavigationDrawer.js +241 -211
  237. package/NavigationDrawer/index.js +12 -7
  238. package/NavigationItem/NavigationItem.js +293 -262
  239. package/NavigationItem/index.js +12 -7
  240. package/NavigationRail/NavigationRail.js +187 -150
  241. package/NavigationRail/index.js +12 -7
  242. package/NotFound/NotFound.js +89 -66
  243. package/NotFound/index.js +12 -7
  244. package/NumericTextField/NumericTextField.js +217 -212
  245. package/NumericTextField/index.js +12 -7
  246. package/Page/Page.js +131 -67
  247. package/Page/index.js +12 -7
  248. package/PageTransition/PageTransition.js +112 -102
  249. package/PageTransition/index.js +12 -7
  250. package/Pagination/Pagination.js +153 -98
  251. package/Pagination/index.js +12 -7
  252. package/PaginationItem/PaginationItem.js +85 -65
  253. package/PaginationItem/index.js +12 -7
  254. package/Parallax/Parallax.js +138 -145
  255. package/Parallax/index.js +12 -7
  256. package/Path/Path.js +40 -35
  257. package/Path/index.js +12 -7
  258. package/PieChart/PieChart.js +382 -267
  259. package/PieChart/index.js +12 -7
  260. package/Placeholder/Placeholder.js +125 -117
  261. package/Placeholder/index.js +12 -7
  262. package/Portal/Portal.js +37 -38
  263. package/Portal/index.js +12 -7
  264. package/Properties/Properties.js +85 -64
  265. package/Properties/index.js +12 -7
  266. package/Property/Property.js +120 -108
  267. package/Property/index.js +12 -7
  268. package/Radio/Radio.js +211 -181
  269. package/Radio/index.js +12 -7
  270. package/Radios/Radios.js +124 -92
  271. package/Radios/index.js +12 -7
  272. package/Rating/Rating.js +353 -360
  273. package/Rating/index.js +12 -7
  274. package/Reset/Reset.js +19 -24
  275. package/Reset/index.js +12 -7
  276. package/Reveal/Reveal.js +98 -89
  277. package/Reveal/index.js +12 -7
  278. package/RichTextEditor/RichTextEditor.js +1764 -972
  279. package/RichTextEditor/index.js +12 -7
  280. package/RoundMeter/RoundMeter.js +629 -537
  281. package/RoundMeter/index.js +12 -7
  282. package/RoundProgress/RoundProgress.js +233 -174
  283. package/RoundProgress/index.js +12 -7
  284. package/ScatterChart/ScatterChart.js +53 -40
  285. package/ScatterChart/index.js +12 -7
  286. package/ScatterChartItem/ScatterChartItem.js +214 -153
  287. package/ScatterChartItem/index.js +12 -7
  288. package/ScreenCapture/ScreenCapture.js +427 -335
  289. package/ScreenCapture/index.js +12 -7
  290. package/Section/Section.js +380 -319
  291. package/Section/index.js +12 -7
  292. package/SectionAction/SectionAction.js +72 -61
  293. package/SectionAction/index.js +12 -7
  294. package/SectionBoxes/SectionBoxes.js +240 -208
  295. package/SectionBoxes/index.js +12 -7
  296. package/SectionCards/SectionCards.js +256 -217
  297. package/SectionCards/index.js +12 -7
  298. package/SectionCarousel/SectionCarousel.js +284 -242
  299. package/SectionCarousel/index.js +12 -7
  300. package/SectionContact/SectionContact.js +174 -116
  301. package/SectionContact/index.js +12 -7
  302. package/SectionImageGallery/SectionImageGallery.js +64 -51
  303. package/SectionImageGallery/index.js +12 -7
  304. package/SectionLogos/SectionLogos.js +123 -109
  305. package/SectionLogos/index.js +12 -7
  306. package/SectionMedia/SectionMedia.js +170 -152
  307. package/SectionMedia/index.js +12 -7
  308. package/SectionReviews/SectionReviews.js +170 -129
  309. package/SectionReviews/index.js +12 -7
  310. package/SectionTextMedia/SectionTextMedia.js +187 -142
  311. package/SectionTextMedia/index.js +12 -7
  312. package/SectionTimeline/SectionTimeline.js +126 -95
  313. package/SectionTimeline/index.js +12 -7
  314. package/SectionWatch/SectionWatch.js +65 -53
  315. package/SectionWatch/index.js +12 -7
  316. package/Select/Select.js +517 -406
  317. package/Select/index.js +12 -7
  318. package/Share/Share.js +458 -319
  319. package/Share/index.js +12 -7
  320. package/Slide/Slide.js +184 -140
  321. package/Slide/index.js +12 -7
  322. package/Slider/Slider.js +927 -837
  323. package/Slider/index.js +12 -7
  324. package/SmartTextField/SmartTextField.js +1406 -1014
  325. package/SmartTextField/index.js +12 -7
  326. package/Snackbar/Snackbar.js +227 -185
  327. package/Snackbar/index.js +12 -7
  328. package/Snackbars/Context.js +9 -7
  329. package/Snackbars/Snackbars.js +234 -210
  330. package/Snackbars/index.js +32 -13
  331. package/Snackbars/useSnackbars.js +11 -10
  332. package/Space/Space.js +1683 -968
  333. package/Space/index.js +24 -21
  334. package/SpeechToText/SpeechToText.js +207 -172
  335. package/SpeechToText/index.js +12 -7
  336. package/SpeedDial/SpeedDial.js +434 -398
  337. package/SpeedDial/index.js +12 -7
  338. package/SpeedDialItem/SpeedDialItem.js +89 -63
  339. package/SpeedDialItem/index.js +12 -7
  340. package/SpyScroll/SpyScroll.js +154 -142
  341. package/SpyScroll/index.js +12 -7
  342. package/Step/Step.js +181 -127
  343. package/Step/index.js +12 -7
  344. package/Stepper/Stepper.js +159 -139
  345. package/Stepper/index.js +12 -7
  346. package/Surface/Surface.js +760 -798
  347. package/Surface/index.js +12 -7
  348. package/Switch/Switch.js +688 -532
  349. package/Switch/index.js +12 -7
  350. package/Tab/Tab.js +185 -150
  351. package/Tab/index.js +12 -7
  352. package/Table/Table.js +100 -77
  353. package/Table/index.js +12 -7
  354. package/TableBody/TableBody.js +76 -63
  355. package/TableBody/index.js +12 -7
  356. package/TableCell/TableCell.js +258 -220
  357. package/TableCell/index.js +12 -7
  358. package/TableFooter/TableFooter.js +60 -48
  359. package/TableFooter/index.js +12 -7
  360. package/TableHead/TableHead.js +139 -120
  361. package/TableHead/index.js +12 -7
  362. package/TableHeader/TableHeader.js +65 -50
  363. package/TableHeader/index.js +12 -7
  364. package/TablePagination/TablePagination.js +171 -98
  365. package/TablePagination/index.js +12 -7
  366. package/TableRow/TableRow.js +77 -64
  367. package/TableRow/index.js +12 -7
  368. package/Tabs/Tabs.js +425 -377
  369. package/Tabs/index.js +12 -7
  370. package/Text/Text.js +131 -113
  371. package/Text/index.js +12 -7
  372. package/TextField/TextField.js +940 -879
  373. package/TextField/index.js +12 -7
  374. package/TextToSpeech/TextToSpeech.js +176 -153
  375. package/TextToSpeech/index.js +12 -7
  376. package/TimePicker/TimePicker.js +985 -718
  377. package/TimePicker/index.js +12 -7
  378. package/TimeRangePicker/TimeRangePicker.js +44 -37
  379. package/TimeRangePicker/index.js +12 -7
  380. package/Timeline/Timeline.js +54 -42
  381. package/Timeline/index.js +12 -7
  382. package/TimelineItem/TimelineItem.js +144 -147
  383. package/TimelineItem/index.js +12 -7
  384. package/Timer/Timer.js +321 -204
  385. package/Timer/index.js +12 -7
  386. package/ToggleButton/ToggleButton.js +67 -58
  387. package/ToggleButton/index.js +12 -7
  388. package/ToggleButtons/ToggleButtons.js +46 -37
  389. package/ToggleButtons/index.js +12 -7
  390. package/Tooltip/Tooltip.js +489 -454
  391. package/Tooltip/index.js +12 -7
  392. package/TopAppBar/TopAppBar.js +237 -197
  393. package/TopAppBar/index.js +12 -7
  394. package/Transition/Context.js +9 -7
  395. package/Transition/Transition.js +321 -339
  396. package/Transition/index.js +42 -25
  397. package/Transition/useTransition.js +11 -10
  398. package/Transitions/Transitions.js +215 -179
  399. package/Transitions/index.js +12 -7
  400. package/Tree/Tree.js +375 -312
  401. package/Tree/index.js +12 -7
  402. package/Type/Type.js +251 -152
  403. package/Type/index.js +12 -7
  404. package/VideoPlayer/VideoPlayer.js +866 -656
  405. package/VideoPlayer/index.js +12 -7
  406. package/ViewSplit/ViewSplit.js +413 -387
  407. package/ViewSplit/index.js +12 -7
  408. package/Watch/Watch.js +436 -290
  409. package/Watch/index.js +12 -7
  410. package/Weather/Weather.js +294 -247
  411. package/Weather/index.js +12 -7
  412. package/Whiteboard/Whiteboard.js +1392 -1292
  413. package/Whiteboard/index.js +12 -7
  414. package/Widgets/Context.js +9 -7
  415. package/Widgets/Widgets.js +220 -168
  416. package/Widgets/index.js +32 -13
  417. package/Widgets/useWidgets.js +11 -10
  418. package/WindowSplit/WindowSplit.js +381 -336
  419. package/WindowSplit/index.js +12 -7
  420. package/Zoom/Zoom.js +126 -99
  421. package/Zoom/index.js +12 -7
  422. package/esm/Buttons/Buttons.js +1 -1
  423. package/esm/index.js +1 -1
  424. package/index.js +4053 -660
  425. package/package.json +1 -1
  426. package/types.js +4 -1
  427. package/useForm/index.js +25 -11
  428. package/useForm/useForm.js +203 -174
  429. package/useForm/validate.js +215 -203
  430. package/useLocation/index.js +12 -7
  431. package/useLocation/useLocation.js +54 -49
  432. package/useMediaQuery/index.js +12 -7
  433. package/useMediaQuery/useMediaQuery.js +44 -43
  434. package/useQuery/index.js +12 -7
  435. package/useQuery/useQuery.js +14 -10
  436. package/useScroll/index.js +12 -7
  437. package/useScroll/useScroll.js +61 -56
  438. package/useSubscription/index.js +12 -7
  439. package/useSubscription/useSubscription.js +35 -35
  440. package/useSwipe/index.js +12 -7
  441. package/useSwipe/useSwipe.js +157 -131
  442. package/useVisible/index.js +12 -7
  443. package/useVisible/useVisible.js +86 -76
  444. package/utils.js +1224 -1362
package/Tabs/Tabs.js CHANGED
@@ -1,387 +1,435 @@
1
1
  "use strict";
2
- var __rest = (this && this.__rest) || function (s, e) {
3
- var t = {};
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
- t[p] = s[p];
6
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
- t[p[i]] = s[p[i]];
10
- }
11
- return t;
12
- };
13
- var __importDefault = (this && this.__importDefault) || function (mod) {
14
- return (mod && mod.__esModule) ? mod : { "default": mod };
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- const jsx_runtime_1 = require("react/jsx-runtime");
18
- const react_1 = __importDefault(require("react"));
19
- const utils_1 = require("@onesy/utils");
20
- const style_react_1 = require("@onesy/style-react");
21
- const IconMaterialExpandLessW100_1 = __importDefault(require("@onesy/icons-material-rounded-react/IconMaterialExpandLessW100"));
22
- const IconMaterialExpandMoreW100_1 = __importDefault(require("@onesy/icons-material-rounded-react/IconMaterialExpandMoreW100"));
23
- const IconMaterialNavigateNextW100_1 = __importDefault(require("@onesy/icons-material-rounded-react/IconMaterialNavigateNextW100"));
24
- const IconMaterialNavigateBeforeW100_1 = __importDefault(require("@onesy/icons-material-rounded-react/IconMaterialNavigateBeforeW100"));
25
- const Surface_1 = __importDefault(require("../Surface"));
26
- const Line_1 = __importDefault(require("../Line"));
27
- const IconButton_1 = __importDefault(require("../IconButton"));
28
- const Divider_1 = __importDefault(require("../Divider"));
29
- const useMediaQuery_1 = __importDefault(require("../useMediaQuery"));
30
- const utils_2 = require("../utils");
31
- const useStyle = (0, style_react_1.style)(theme => ({
32
- root: {
33
- position: 'relative',
34
- overflow: 'hidden',
35
- flex: '0 0 auto'
36
- },
37
- size_small: {
38
- minHeight: '39px'
39
- },
40
- size_regular: {
41
- minHeight: '44px'
42
- },
43
- size_large: {
44
- minHeight: '62px'
45
- },
46
- tabs: {
47
- position: 'relative'
48
- },
49
- orientation_horizontal: {
50
- width: '100%'
51
- },
52
- tabs_orientation_horizontal: {
53
- height: '100%',
54
- overflowX: 'auto'
55
- },
56
- tabs_orientation_vertical: {
57
- width: '100%',
58
- overflowY: 'auto'
59
- },
60
- arrow: {
61
- flex: '0 0 auto',
62
- alignSelf: 'center',
63
- justifySelf: 'center',
64
- transition: theme.methods.transitions.make(['opacity'], { duration: 'xxs' }),
65
- '&[disabled]': {
66
- opacity: '0'
67
- }
68
- },
69
- line: {
70
- display: 'inline-block',
71
- position: 'absolute',
72
- background: 'currentColor',
73
- transition: theme.methods.transitions.make(['top', 'left', 'width']),
74
- zIndex: '1'
75
- },
76
- line_version_primary_size_small_orientation_horizontal: {
77
- height: '2px',
78
- bottom: '0',
79
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
80
- },
81
- line_version_primary_size_regular_orientation_horizontal: {
82
- height: '3px',
83
- bottom: '0',
84
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
85
- },
86
- line_version_primary_size_large_orientation_horizontal: {
87
- height: '4px',
88
- bottom: '0',
89
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
90
- },
91
- line_version_primary_size_small_orientation_vertical: {
92
- width: '2px',
93
- insetInlineEnd: '0',
94
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
95
- },
96
- line_version_primary_size_regular_orientation_vertical: {
97
- width: '3px',
98
- insetInlineEnd: '0',
99
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
100
- },
101
- line_version_primary_size_large_orientation_vertical: {
102
- width: '4px',
103
- insetInlineEnd: '0',
104
- borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
105
- },
106
- line_version_secondary_size_small_orientation_horizontal: {
107
- height: '1px',
108
- bottom: '0'
109
- },
110
- line_version_secondary_size_regular_orientation_horizontal: {
111
- height: '2px',
112
- bottom: '0'
113
- },
114
- line_version_secondary_size_large_orientation_horizontal: {
115
- height: '3px',
116
- bottom: '0'
117
- },
118
- line_version_secondary_size_small_orientation_vertical: {
119
- width: '1px',
120
- insetInlineEnd: '0'
121
- },
122
- line_version_secondary_size_regular_orientation_vertical: {
123
- width: '2px',
124
- insetInlineEnd: '0'
125
- },
126
- line_version_secondary_size_large_orientation_vertical: {
127
- width: '3px',
128
- insetInlineEnd: '0'
129
- },
130
- divider: {
131
- position: 'absolute',
132
- '&.onesy-Divider-root': {
133
- margin: '0px',
134
- background: 'currentColor',
135
- opacity: '0.14',
136
- zIndex: '1'
137
- }
138
- },
139
- divider_orientation_horizontal: {
140
- '&.onesy-Divider-root': {
141
- left: '0',
142
- right: '0',
143
- bottom: '0'
144
- }
145
- },
146
- divider_orientation_vertical: {
147
- '&.onesy-Divider-root': {
148
- top: '0',
149
- bottom: '0',
150
- insetInlineEnd: '0'
151
- }
152
- },
153
- fixed: {
154
- position: 'fixed',
155
- top: '0',
156
- insetInline: '0'
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
10
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _utils = require("@onesy/utils");
13
+ var _styleReact = require("@onesy/style-react");
14
+ var _IconMaterialExpandLessW = _interopRequireDefault(require("@onesy/icons-material-rounded-react/IconMaterialExpandLessW100"));
15
+ var _IconMaterialExpandMoreW = _interopRequireDefault(require("@onesy/icons-material-rounded-react/IconMaterialExpandMoreW100"));
16
+ var _IconMaterialNavigateNextW = _interopRequireDefault(require("@onesy/icons-material-rounded-react/IconMaterialNavigateNextW100"));
17
+ var _IconMaterialNavigateBeforeW = _interopRequireDefault(require("@onesy/icons-material-rounded-react/IconMaterialNavigateBeforeW100"));
18
+ var _Surface = _interopRequireDefault(require("../Surface"));
19
+ var _Line = _interopRequireDefault(require("../Line"));
20
+ var _IconButton = _interopRequireDefault(require("../IconButton"));
21
+ var _Divider = _interopRequireDefault(require("../Divider"));
22
+ var _useMediaQuery = _interopRequireDefault(require("../useMediaQuery"));
23
+ var _utils2 = require("../utils");
24
+ const _excluded = ["tonal", "color", "version", "value", "valueDefault", "onChange", "isActive", "activateOnFocus", "align", "justify", "orientation", "size", "initialLineUpdateTimeout", "arrows", "arrowsMobile", "fixed", "noDivider", "IconStart", "IconEnd", "IconTop", "IconBottom", "SurfaceProps", "Component", "className", "children"];
25
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
26
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
27
+ const useStyle = (0, _styleReact.style)(theme => ({
28
+ root: {
29
+ position: 'relative',
30
+ overflow: 'hidden',
31
+ flex: '0 0 auto'
32
+ },
33
+ size_small: {
34
+ minHeight: '39px'
35
+ },
36
+ size_regular: {
37
+ minHeight: '44px'
38
+ },
39
+ size_large: {
40
+ minHeight: '62px'
41
+ },
42
+ tabs: {
43
+ position: 'relative'
44
+ },
45
+ orientation_horizontal: {
46
+ width: '100%'
47
+ },
48
+ tabs_orientation_horizontal: {
49
+ height: '100%',
50
+ overflowX: 'auto'
51
+ },
52
+ tabs_orientation_vertical: {
53
+ width: '100%',
54
+ overflowY: 'auto'
55
+ },
56
+ arrow: {
57
+ flex: '0 0 auto',
58
+ alignSelf: 'center',
59
+ justifySelf: 'center',
60
+ transition: theme.methods.transitions.make(['opacity'], {
61
+ duration: 'xxs'
62
+ }),
63
+ '&[disabled]': {
64
+ opacity: '0'
65
+ }
66
+ },
67
+ line: {
68
+ display: 'inline-block',
69
+ position: 'absolute',
70
+ background: 'currentColor',
71
+ transition: theme.methods.transitions.make(['top', 'left', 'width']),
72
+ zIndex: '1'
73
+ },
74
+ line_version_primary_size_small_orientation_horizontal: {
75
+ height: '2px',
76
+ bottom: '0',
77
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
78
+ },
79
+ line_version_primary_size_regular_orientation_horizontal: {
80
+ height: '3px',
81
+ bottom: '0',
82
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
83
+ },
84
+ line_version_primary_size_large_orientation_horizontal: {
85
+ height: '4px',
86
+ bottom: '0',
87
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} ${theme.methods.shape.radius.value(40, 'px')} 0 0`
88
+ },
89
+ line_version_primary_size_small_orientation_vertical: {
90
+ width: '2px',
91
+ insetInlineEnd: '0',
92
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
93
+ },
94
+ line_version_primary_size_regular_orientation_vertical: {
95
+ width: '3px',
96
+ insetInlineEnd: '0',
97
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
98
+ },
99
+ line_version_primary_size_large_orientation_vertical: {
100
+ width: '4px',
101
+ insetInlineEnd: '0',
102
+ borderRadius: `${theme.methods.shape.radius.value(40, 'px')} 0 0 ${theme.methods.shape.radius.value(40, 'px')}`
103
+ },
104
+ line_version_secondary_size_small_orientation_horizontal: {
105
+ height: '1px',
106
+ bottom: '0'
107
+ },
108
+ line_version_secondary_size_regular_orientation_horizontal: {
109
+ height: '2px',
110
+ bottom: '0'
111
+ },
112
+ line_version_secondary_size_large_orientation_horizontal: {
113
+ height: '3px',
114
+ bottom: '0'
115
+ },
116
+ line_version_secondary_size_small_orientation_vertical: {
117
+ width: '1px',
118
+ insetInlineEnd: '0'
119
+ },
120
+ line_version_secondary_size_regular_orientation_vertical: {
121
+ width: '2px',
122
+ insetInlineEnd: '0'
123
+ },
124
+ line_version_secondary_size_large_orientation_vertical: {
125
+ width: '3px',
126
+ insetInlineEnd: '0'
127
+ },
128
+ divider: {
129
+ position: 'absolute',
130
+ '&.onesy-Divider-root': {
131
+ margin: '0px',
132
+ background: 'currentColor',
133
+ opacity: '0.14',
134
+ zIndex: '1'
135
+ }
136
+ },
137
+ divider_orientation_horizontal: {
138
+ '&.onesy-Divider-root': {
139
+ left: '0',
140
+ right: '0',
141
+ bottom: '0'
157
142
  }
158
- }), { name: 'onesy-Tabs' });
159
- const Tabs = react_1.default.forwardRef((props_, ref) => {
160
- var _a, _b, _c, _d, _e, _f, _g;
161
- const theme = (0, style_react_1.useOnesyTheme)();
162
- const props = react_1.default.useMemo(() => { var _a, _b, _c, _d, _e, _f, _g, _h; return (Object.assign(Object.assign(Object.assign({}, (_d = (_c = (_b = (_a = theme === null || theme === void 0 ? void 0 : theme.ui) === null || _a === void 0 ? void 0 : _a.elements) === null || _b === void 0 ? void 0 : _b.all) === null || _c === void 0 ? void 0 : _c.props) === null || _d === void 0 ? void 0 : _d.default), (_h = (_g = (_f = (_e = theme === null || theme === void 0 ? void 0 : theme.ui) === null || _e === void 0 ? void 0 : _e.elements) === null || _f === void 0 ? void 0 : _f.onesyTabs) === null || _g === void 0 ? void 0 : _g.props) === null || _h === void 0 ? void 0 : _h.default), props_)); }, [props_]);
163
- const Line = react_1.default.useMemo(() => { var _a; return ((_a = theme === null || theme === void 0 ? void 0 : theme.elements) === null || _a === void 0 ? void 0 : _a.Line) || Line_1.default; }, [theme]);
164
- const Surface = react_1.default.useMemo(() => { var _a; return ((_a = theme === null || theme === void 0 ? void 0 : theme.elements) === null || _a === void 0 ? void 0 : _a.Surface) || Surface_1.default; }, [theme]);
165
- const IconButton = react_1.default.useMemo(() => { var _a; return ((_a = theme === null || theme === void 0 ? void 0 : theme.elements) === null || _a === void 0 ? void 0 : _a.IconButton) || IconButton_1.default; }, [theme]);
166
- const Divider = react_1.default.useMemo(() => { var _a; return ((_a = theme === null || theme === void 0 ? void 0 : theme.elements) === null || _a === void 0 ? void 0 : _a.Divider) || Divider_1.default; }, [theme]);
167
- const { tonal = true, color = 'primary', version = 'primary', value: value_ = 0, valueDefault, onChange: onChange_, isActive, activateOnFocus, align = 'flex-start', justify = 'flex-start', orientation = 'horizontal', size = 'regular', initialLineUpdateTimeout = 0, arrows, arrowsMobile, fixed, noDivider, IconStart = IconMaterialNavigateBeforeW100_1.default, IconEnd = IconMaterialNavigateNextW100_1.default, IconTop = IconMaterialExpandLessW100_1.default, IconBottom = IconMaterialExpandMoreW100_1.default, SurfaceProps, Component = 'div', className, children } = props, other = __rest(props, ["tonal", "color", "version", "value", "valueDefault", "onChange", "isActive", "activateOnFocus", "align", "justify", "orientation", "size", "initialLineUpdateTimeout", "arrows", "arrowsMobile", "fixed", "noDivider", "IconStart", "IconEnd", "IconTop", "IconBottom", "SurfaceProps", "Component", "className", "children"]);
168
- const { classes } = useStyle();
169
- const setMoveValue = react_1.default.useState({})[1];
170
- const [init, setInit] = react_1.default.useState(false);
171
- const [lineValues, setLineValues] = react_1.default.useState({});
172
- const [value, setValue] = react_1.default.useState(valueDefault !== undefined ? valueDefault : value_);
173
- const refs = {
174
- root: react_1.default.useRef(undefined),
175
- tabsRoot: react_1.default.useRef(undefined),
176
- value: react_1.default.useRef(undefined),
177
- props: react_1.default.useRef(undefined),
178
- mobile: react_1.default.useRef(undefined),
179
- version: react_1.default.useRef(undefined),
180
- isActive: react_1.default.useRef(undefined),
181
- initialLineUpdateTimeout: react_1.default.useRef(undefined)
143
+ },
144
+ divider_orientation_vertical: {
145
+ '&.onesy-Divider-root': {
146
+ top: '0',
147
+ bottom: '0',
148
+ insetInlineEnd: '0'
149
+ }
150
+ },
151
+ fixed: {
152
+ position: 'fixed',
153
+ top: '0',
154
+ insetInline: '0'
155
+ }
156
+ }), {
157
+ name: 'onesy-Tabs'
158
+ });
159
+ const Tabs = /*#__PURE__*/_react.default.forwardRef((props_, ref) => {
160
+ var _refs$tabsRoot$curren3, _refs$tabsRoot$curren4, _refs$tabsRoot$curren5, _refs$tabsRoot$curren6, _refs$tabsRoot$curren7, _refs$tabsRoot$curren8, _refs$tabsRoot$curren9;
161
+ const theme = (0, _styleReact.useOnesyTheme)();
162
+ const props = _react.default.useMemo(() => {
163
+ var _theme$ui, _theme$ui2;
164
+ return _objectSpread(_objectSpread(_objectSpread({}, theme === null || theme === void 0 || (_theme$ui = theme.ui) === null || _theme$ui === void 0 || (_theme$ui = _theme$ui.elements) === null || _theme$ui === void 0 || (_theme$ui = _theme$ui.all) === null || _theme$ui === void 0 || (_theme$ui = _theme$ui.props) === null || _theme$ui === void 0 ? void 0 : _theme$ui.default), theme === null || theme === void 0 || (_theme$ui2 = theme.ui) === null || _theme$ui2 === void 0 || (_theme$ui2 = _theme$ui2.elements) === null || _theme$ui2 === void 0 || (_theme$ui2 = _theme$ui2.onesyTabs) === null || _theme$ui2 === void 0 || (_theme$ui2 = _theme$ui2.props) === null || _theme$ui2 === void 0 ? void 0 : _theme$ui2.default), props_);
165
+ }, [props_]);
166
+ const Line = _react.default.useMemo(() => {
167
+ var _theme$elements;
168
+ return (theme === null || theme === void 0 || (_theme$elements = theme.elements) === null || _theme$elements === void 0 ? void 0 : _theme$elements.Line) || _Line.default;
169
+ }, [theme]);
170
+ const Surface = _react.default.useMemo(() => {
171
+ var _theme$elements2;
172
+ return (theme === null || theme === void 0 || (_theme$elements2 = theme.elements) === null || _theme$elements2 === void 0 ? void 0 : _theme$elements2.Surface) || _Surface.default;
173
+ }, [theme]);
174
+ const IconButton = _react.default.useMemo(() => {
175
+ var _theme$elements3;
176
+ return (theme === null || theme === void 0 || (_theme$elements3 = theme.elements) === null || _theme$elements3 === void 0 ? void 0 : _theme$elements3.IconButton) || _IconButton.default;
177
+ }, [theme]);
178
+ const Divider = _react.default.useMemo(() => {
179
+ var _theme$elements4;
180
+ return (theme === null || theme === void 0 || (_theme$elements4 = theme.elements) === null || _theme$elements4 === void 0 ? void 0 : _theme$elements4.Divider) || _Divider.default;
181
+ }, [theme]);
182
+ const {
183
+ tonal = true,
184
+ color = 'primary',
185
+ version = 'primary',
186
+ value: value_ = 0,
187
+ valueDefault,
188
+ onChange: onChange_,
189
+ isActive,
190
+ activateOnFocus,
191
+ align = 'flex-start',
192
+ justify = 'flex-start',
193
+ orientation = 'horizontal',
194
+ size = 'regular',
195
+ initialLineUpdateTimeout = 0,
196
+ arrows,
197
+ arrowsMobile,
198
+ fixed,
199
+ noDivider,
200
+ IconStart = _IconMaterialNavigateBeforeW.default,
201
+ IconEnd = _IconMaterialNavigateNextW.default,
202
+ IconTop = _IconMaterialExpandLessW.default,
203
+ IconBottom = _IconMaterialExpandMoreW.default,
204
+ SurfaceProps,
205
+ Component = 'div',
206
+ className,
207
+ children
208
+ } = props,
209
+ other = (0, _objectWithoutProperties2.default)(props, _excluded);
210
+ const {
211
+ classes
212
+ } = useStyle();
213
+ const setMoveValue = _react.default.useState({})[1];
214
+ const [init, setInit] = _react.default.useState(false);
215
+ const [lineValues, setLineValues] = _react.default.useState({});
216
+ const [value, setValue] = _react.default.useState(valueDefault !== undefined ? valueDefault : value_);
217
+ const refs = {
218
+ root: _react.default.useRef(undefined),
219
+ tabsRoot: _react.default.useRef(undefined),
220
+ value: _react.default.useRef(undefined),
221
+ props: _react.default.useRef(undefined),
222
+ mobile: _react.default.useRef(undefined),
223
+ version: _react.default.useRef(undefined),
224
+ isActive: _react.default.useRef(undefined),
225
+ initialLineUpdateTimeout: _react.default.useRef(undefined)
226
+ };
227
+ const mobile = (0, _useMediaQuery.default)('(pointer: coarse)', {
228
+ element: refs.root.current
229
+ });
230
+ refs.value.current = value;
231
+ refs.props.current = props;
232
+ refs.mobile.current = mobile;
233
+ refs.version.current = version;
234
+ refs.isActive.current = isActive;
235
+ refs.initialLineUpdateTimeout.current = initialLineUpdateTimeout;
236
+ _react.default.useEffect(() => {
237
+ // Update lineValues value
238
+ // with the first tab
239
+ // For elements within a modal
240
+ // being transitioned, minor bug fix
241
+ setTimeout(updateLine, refs.initialLineUpdateTimeout.current);
242
+ const observerMethod = () => updateLine();
243
+
244
+ // Mutation observer
245
+ const observerMutation = new ResizeObserver(observerMethod);
246
+ observerMutation.observe(refs.tabsRoot.current);
247
+
248
+ // Update theme subscription method
249
+ const method = () => updateLine();
250
+ theme.subscriptions.update.subscribe(method);
251
+ setInit(true);
252
+ return () => {
253
+ // Unsubscribe
254
+ theme.subscriptions.update.unsubscribe(method);
255
+ observerMutation.disconnect();
182
256
  };
183
- const mobile = (0, useMediaQuery_1.default)('(pointer: coarse)', { element: refs.root.current });
184
- refs.value.current = value;
185
- refs.props.current = props;
186
- refs.mobile.current = mobile;
187
- refs.version.current = version;
188
- refs.isActive.current = isActive;
189
- refs.initialLineUpdateTimeout.current = initialLineUpdateTimeout;
190
- react_1.default.useEffect(() => {
257
+ }, []);
258
+ const onScroll = _react.default.useCallback(event => {
259
+ const useArrows_ = refs.props.current.arrows && (!refs.mobile.current || refs.props.current.arrowsMobile);
260
+ if (useArrows_) {
261
+ setMoveValue({
262
+ left: refs.tabsRoot.current.scrollLeft,
263
+ top: refs.tabsRoot.current.scrollTop
264
+ });
265
+ }
266
+ }, []);
267
+ _react.default.useEffect(() => {
268
+ if (init) {
269
+ if (value_ !== refs.value.current) {
270
+ setValue(value_);
271
+
191
272
  // Update lineValues value
192
- // with the first tab
193
- // For elements within a modal
194
- // being transitioned, minor bug fix
195
- setTimeout(updateLine, refs.initialLineUpdateTimeout.current);
196
- const observerMethod = () => updateLine();
197
- // Mutation observer
198
- const observerMutation = new ResizeObserver(observerMethod);
199
- observerMutation.observe(refs.tabsRoot.current);
200
- // Update theme subscription method
201
- const method = () => updateLine();
202
- theme.subscriptions.update.subscribe(method);
203
- setInit(true);
204
- return () => {
205
- // Unsubscribe
206
- theme.subscriptions.update.unsubscribe(method);
207
- observerMutation.disconnect();
208
- };
209
- }, []);
210
- const onScroll = react_1.default.useCallback((event) => {
211
- const useArrows_ = refs.props.current.arrows && (!refs.mobile.current || refs.props.current.arrowsMobile);
212
- if (useArrows_) {
213
- setMoveValue({
214
- left: refs.tabsRoot.current.scrollLeft,
215
- top: refs.tabsRoot.current.scrollTop,
216
- });
217
- }
218
- }, []);
219
- react_1.default.useEffect(() => {
220
- if (init) {
221
- if (value_ !== refs.value.current) {
222
- setValue(value_);
223
- // Update lineValues value
224
- updateLine();
225
- }
226
- }
227
- }, [value_]);
228
- const onChange = (valueItem, index) => {
229
- // Update inner or controlled
230
- if (!props.hasOwnProperty('value')) {
231
- setValue(valueItem);
232
- // Update line
233
- updateLine();
234
- }
235
- if ((0, utils_1.is)('function', onChange_))
236
- onChange_(valueItem);
237
- };
238
- const move = (forward_ = true) => {
239
- const forward = theme.direction === 'ltr' || orientation === 'vertical' ? forward_ : !forward_;
240
- const rect = refs.tabsRoot.current.getBoundingClientRect();
241
- let moveValue_;
242
- if (orientation === 'horizontal')
243
- moveValue_ = {
244
- left: refs.tabsRoot.current.scrollLeft + (forward ? 1 : -1) * rect.width,
245
- behavior: 'smooth'
246
- };
247
- else
248
- moveValue_ = {
249
- top: refs.tabsRoot.current.scrollTop + (forward ? 1 : -1) * rect.height,
250
- behavior: 'smooth'
251
- };
252
- refs.tabsRoot.current.scrollTo(moveValue_);
273
+ updateLine();
274
+ }
275
+ }
276
+ }, [value_]);
277
+ const onChange = (valueItem, index) => {
278
+ // Update inner or controlled
279
+ if (!props.hasOwnProperty('value')) {
280
+ setValue(valueItem);
281
+
282
+ // Update line
283
+ updateLine();
284
+ }
285
+ if ((0, _utils.is)('function', onChange_)) onChange_(valueItem);
286
+ };
287
+ const move = (forward_ = true) => {
288
+ const forward = theme.direction === 'ltr' || orientation === 'vertical' ? forward_ : !forward_;
289
+ const rect = refs.tabsRoot.current.getBoundingClientRect();
290
+ let moveValue_;
291
+ if (orientation === 'horizontal') moveValue_ = {
292
+ left: refs.tabsRoot.current.scrollLeft + (forward ? 1 : -1) * rect.width,
293
+ behavior: 'smooth'
294
+ };else moveValue_ = {
295
+ top: refs.tabsRoot.current.scrollTop + (forward ? 1 : -1) * rect.height,
296
+ behavior: 'smooth'
253
297
  };
254
- const updateLine = async () => {
255
- var _a, _b, _c;
256
- await (0, utils_1.wait)(40);
257
- const valueProp = refs.value.current;
258
- const tabs = Array.from(((_a = refs.tabsRoot.current) === null || _a === void 0 ? void 0 : _a.querySelectorAll(`[data-onesy-tab-value]`)) || []);
259
- const tab = tabs.find(item => (0, utils_1.is)('function', refs.isActive.current) ? refs.isActive.current(valueProp, item.dataset.onesyTabValue) : String(item.dataset.onesyTabValue) === String(valueProp));
260
- if (tab) {
261
- const rect = {
262
- parent: (_b = refs.tabsRoot.current) === null || _b === void 0 ? void 0 : _b.getBoundingClientRect(),
263
- tab: tab.getBoundingClientRect(),
264
- line: (_c = (refs.version.current === 'primary' ? tab.children[1] : tab)) === null || _c === void 0 ? void 0 : _c.getBoundingClientRect()
265
- };
298
+ refs.tabsRoot.current.scrollTo(moveValue_);
299
+ };
300
+ const updateLine = async () => {
301
+ var _refs$tabsRoot$curren;
302
+ await (0, _utils.wait)(40);
303
+ const valueProp = refs.value.current;
304
+ const tabs = Array.from(((_refs$tabsRoot$curren = refs.tabsRoot.current) === null || _refs$tabsRoot$curren === void 0 ? void 0 : _refs$tabsRoot$curren.querySelectorAll(`[data-onesy-tab-value]`)) || []);
305
+ const tab = tabs.find(item => (0, _utils.is)('function', refs.isActive.current) ? refs.isActive.current(valueProp, item.dataset.onesyTabValue) : String(item.dataset.onesyTabValue) === String(valueProp));
306
+ if (tab) {
307
+ var _refs$tabsRoot$curren2, _ref;
308
+ const rect = {
309
+ parent: (_refs$tabsRoot$curren2 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren2 === void 0 ? void 0 : _refs$tabsRoot$curren2.getBoundingClientRect(),
310
+ tab: tab.getBoundingClientRect(),
311
+ line: (_ref = refs.version.current === 'primary' ? tab.children[1] : tab) === null || _ref === void 0 ? void 0 : _ref.getBoundingClientRect()
312
+ };
313
+
314
+ // Update
315
+ if (rect.parent && rect.line && rect.tab) {
316
+ // Update left scroll
317
+ if (orientation === 'horizontal') {
318
+ if (rect.tab.x < rect.parent.x || rect.parent.x + rect.parent.width < rect.tab.x + rect.tab.width) {
319
+ let left = refs.tabsRoot.current.scrollLeft;
320
+ if (rect.tab.x < rect.parent.x) left += rect.tab.x - rect.parent.x;else left += rect.tab.x + rect.tab.width - (rect.parent.x + rect.parent.width);
321
+
266
322
  // Update
267
- if (rect.parent && rect.line && rect.tab) {
268
- // Update left scroll
269
- if (orientation === 'horizontal') {
270
- if ((rect.tab.x < rect.parent.x) || (rect.parent.x + rect.parent.width < rect.tab.x + rect.tab.width)) {
271
- let left = refs.tabsRoot.current.scrollLeft;
272
- if (rect.tab.x < rect.parent.x)
273
- left += rect.tab.x - rect.parent.x;
274
- else
275
- left += (rect.tab.x + rect.tab.width) - (rect.parent.x + rect.parent.width);
276
- // Update
277
- refs.tabsRoot.current.scrollTo({ left, behavior: 'smooth' });
278
- }
279
- }
280
- else {
281
- if ((rect.tab.y < rect.parent.y) || (rect.parent.y + rect.parent.height < rect.tab.y + rect.tab.height)) {
282
- let top = refs.tabsRoot.current.scrollTop;
283
- if (rect.tab.y < rect.parent.y)
284
- top += rect.tab.y - rect.parent.y;
285
- else
286
- top += (rect.tab.y + rect.tab.height) - (rect.parent.y + rect.parent.height);
287
- // Update
288
- refs.tabsRoot.current.scrollTo({ top, behavior: 'smooth' });
289
- }
290
- }
291
- // Update lineValues value
292
- setLineValues({
293
- x: rect.line.x - rect.parent.x + refs.tabsRoot.current.scrollLeft,
294
- y: rect.line.y - rect.parent.y + refs.tabsRoot.current.scrollTop,
295
- width: rect.line.width,
296
- height: rect.line.height
297
- });
298
- }
323
+ refs.tabsRoot.current.scrollTo({
324
+ left,
325
+ behavior: 'smooth'
326
+ });
327
+ }
328
+ } else {
329
+ if (rect.tab.y < rect.parent.y || rect.parent.y + rect.parent.height < rect.tab.y + rect.tab.height) {
330
+ let top = refs.tabsRoot.current.scrollTop;
331
+ if (rect.tab.y < rect.parent.y) top += rect.tab.y - rect.parent.y;else top += rect.tab.y + rect.tab.height - (rect.parent.y + rect.parent.height);
332
+
333
+ // Update
334
+ refs.tabsRoot.current.scrollTo({
335
+ top,
336
+ behavior: 'smooth'
337
+ });
338
+ }
299
339
  }
300
- };
301
- const direction = orientation === 'horizontal' ? 'row' : 'column';
302
- const propPosition = orientation === 'horizontal' ? 'left' : 'top';
303
- const propMain = orientation === 'horizontal' ? 'width' : 'height';
304
- const useArrows = arrows && (!mobile || arrowsMobile);
305
- const ArrowPre = ((0, jsx_runtime_1.jsx)(IconButton, Object.assign({ color: 'inherit', onClick: () => move(false), className: (0, style_react_1.classNames)([
306
- (0, utils_2.staticClassName)('Tabs', theme) && [
307
- 'onesy-Tabs-arrow'
308
- ],
309
- classes.arrow
310
- ]), disabled: ((_a = refs.tabsRoot.current) === null || _a === void 0 ? void 0 : _a[orientation === 'horizontal' ? 'scrollLeft' : 'scrollTop']) === 0 }, { children: orientation === 'horizontal' ? (0, jsx_runtime_1.jsx)(IconStart, {}) : (0, jsx_runtime_1.jsx)(IconTop, {}) })));
311
- const ArrowPost = ((0, jsx_runtime_1.jsx)(IconButton, Object.assign({ color: 'inherit', onClick: () => move(), className: (0, style_react_1.classNames)([
312
- (0, utils_2.staticClassName)('Tabs', theme) && [
313
- 'onesy-Tabs-arrow'
314
- ],
315
- classes.arrow
316
- ]), disabled: orientation === 'horizontal' ? Math.ceil(((_b = refs.tabsRoot.current) === null || _b === void 0 ? void 0 : _b.clientWidth) + ((_c = refs.tabsRoot.current) === null || _c === void 0 ? void 0 : _c.scrollLeft)) === ((_d = refs.tabsRoot.current) === null || _d === void 0 ? void 0 : _d.scrollWidth) : Math.ceil(((_e = refs.tabsRoot.current) === null || _e === void 0 ? void 0 : _e.clientHeight) + ((_f = refs.tabsRoot.current) === null || _f === void 0 ? void 0 : _f.scrollTop)) === ((_g = refs.tabsRoot.current) === null || _g === void 0 ? void 0 : _g.scrollHeight) }, { children: orientation === 'horizontal' ? (0, jsx_runtime_1.jsx)(IconEnd, {}) : (0, jsx_runtime_1.jsx)(IconBottom, {}) })));
317
- const TabElements = react_1.default.Children.toArray(children).filter((item) => { var _a, _b; return (_b = (_a = item === null || item === void 0 ? void 0 : item.type) === null || _a === void 0 ? void 0 : _a.displayName) === null || _b === void 0 ? void 0 : _b.endsWith('Tab'); });
318
- const tabActive = TabElements.find((item, index) => {
319
- const valueItem = item.props.value !== undefined ? item.props.value : index;
320
- return (0, utils_1.is)('function', refs.isActive.current) ? refs.isActive.current(value, valueItem) : value === valueItem;
340
+
341
+ // Update lineValues value
342
+ setLineValues({
343
+ x: rect.line.x - rect.parent.x + refs.tabsRoot.current.scrollLeft,
344
+ y: rect.line.y - rect.parent.y + refs.tabsRoot.current.scrollTop,
345
+ width: rect.line.width,
346
+ height: rect.line.height
347
+ });
348
+ }
349
+ }
350
+ };
351
+ const direction = orientation === 'horizontal' ? 'row' : 'column';
352
+ const propPosition = orientation === 'horizontal' ? 'left' : 'top';
353
+ const propMain = orientation === 'horizontal' ? 'width' : 'height';
354
+ const useArrows = arrows && (!mobile || arrowsMobile);
355
+ const ArrowPre = /*#__PURE__*/_react.default.createElement(IconButton, {
356
+ color: "inherit",
357
+ onClick: () => move(false),
358
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-arrow'], classes.arrow]),
359
+ disabled: ((_refs$tabsRoot$curren3 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren3 === void 0 ? void 0 : _refs$tabsRoot$curren3[orientation === 'horizontal' ? 'scrollLeft' : 'scrollTop']) === 0
360
+ }, orientation === 'horizontal' ? /*#__PURE__*/_react.default.createElement(IconStart, null) : /*#__PURE__*/_react.default.createElement(IconTop, null));
361
+ const ArrowPost = /*#__PURE__*/_react.default.createElement(IconButton, {
362
+ color: "inherit",
363
+ onClick: () => move(),
364
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-arrow'], classes.arrow]),
365
+ disabled: orientation === 'horizontal' ? Math.ceil(((_refs$tabsRoot$curren4 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren4 === void 0 ? void 0 : _refs$tabsRoot$curren4.clientWidth) + ((_refs$tabsRoot$curren5 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren5 === void 0 ? void 0 : _refs$tabsRoot$curren5.scrollLeft)) === ((_refs$tabsRoot$curren6 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren6 === void 0 ? void 0 : _refs$tabsRoot$curren6.scrollWidth) : Math.ceil(((_refs$tabsRoot$curren7 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren7 === void 0 ? void 0 : _refs$tabsRoot$curren7.clientHeight) + ((_refs$tabsRoot$curren8 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren8 === void 0 ? void 0 : _refs$tabsRoot$curren8.scrollTop)) === ((_refs$tabsRoot$curren9 = refs.tabsRoot.current) === null || _refs$tabsRoot$curren9 === void 0 ? void 0 : _refs$tabsRoot$curren9.scrollHeight)
366
+ }, orientation === 'horizontal' ? /*#__PURE__*/_react.default.createElement(IconEnd, null) : /*#__PURE__*/_react.default.createElement(IconBottom, null));
367
+ const TabElements = _react.default.Children.toArray(children).filter(item => {
368
+ var _item$type;
369
+ return item === null || item === void 0 || (_item$type = item.type) === null || _item$type === void 0 || (_item$type = _item$type.displayName) === null || _item$type === void 0 ? void 0 : _item$type.endsWith('Tab');
370
+ });
371
+ const tabActive = TabElements.find((item, index) => {
372
+ const valueItem = item.props.value !== undefined ? item.props.value : index;
373
+ return (0, _utils.is)('function', refs.isActive.current) ? refs.isActive.current(value, valueItem) : value === valueItem;
374
+ });
375
+ return /*#__PURE__*/_react.default.createElement(Surface, (0, _extends2.default)({
376
+ ref: item => {
377
+ if (ref) {
378
+ if ((0, _utils.is)('function', ref)) ref(item);else ref.current = item;
379
+ }
380
+ refs.root.current = item;
381
+ },
382
+ tonal: tonal,
383
+ color: color,
384
+ gap: 0,
385
+ direction: direction,
386
+ align: align,
387
+ justify: justify,
388
+ role: "tablist",
389
+ "aria-orientation": orientation,
390
+ Component: Line,
391
+ AdditionalProps: {
392
+ Component
393
+ }
394
+ }, SurfaceProps, {
395
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-root', `onesy-Tabs-version-${version}`, `onesy-Tabs-size-${size}`], SurfaceProps === null || SurfaceProps === void 0 ? void 0 : SurfaceProps.className, className, classes.root, classes[`size_${size}`], classes[`orientation_${orientation}`], fixed && classes.fixed])
396
+ }, other), useArrows && ArrowPre, !noDivider && /*#__PURE__*/_react.default.createElement(Divider, {
397
+ tonal: tonal,
398
+ color: color,
399
+ orientation: orientation,
400
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-divider'], classes.divider, classes[`divider_orientation_${orientation}`]])
401
+ }), /*#__PURE__*/_react.default.createElement(Line, {
402
+ ref: refs.tabsRoot,
403
+ gap: 0,
404
+ direction: direction,
405
+ align: "flex-start",
406
+ justify: "flex-start",
407
+ onScroll: onScroll,
408
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-tabs'], classes.tabs, classes[`tabs_orientation_${orientation}`]])
409
+ }, tabActive && /*#__PURE__*/_react.default.createElement("span", {
410
+ className: (0, _styleReact.classNames)([(0, _utils2.staticClassName)('Tabs', theme) && ['onesy-Tabs-line'], classes.line, classes[`line_version_${version}_size_${size}_orientation_${orientation}`], orientation === 'vertical' && theme.direction === 'rtl' && classes[`line_version_${version}_orientation_vertical_rtl`]]),
411
+ style: {
412
+ [propPosition]: orientation === 'horizontal' ? lineValues.x : lineValues.y,
413
+ [propMain]: lineValues[propMain]
414
+ }
415
+ }), TabElements.map((item, index) => {
416
+ const valueItem = item.props.value !== undefined ? item.props.value : index;
417
+ return /*#__PURE__*/_react.default.cloneElement(item, {
418
+ tonal: item.props.tonal !== undefined ? item.props.tonal : tonal,
419
+ color: item.props.color !== undefined ? item.props.color : color,
420
+ version: item.props.version !== undefined ? item.props.version : version,
421
+ value: item.props.value !== undefined ? item.props.value : index,
422
+ size: item.props.size !== undefined ? item.props.size : size,
423
+ index,
424
+ onChange,
425
+ activateOnFocus: item.props.activateOnFocus !== undefined ? item.props.activateOnFocus : activateOnFocus,
426
+ active: (0, _utils.is)('function', refs.isActive.current) ? refs.isActive.current(value, valueItem) : value === valueItem,
427
+ onClick: event => {
428
+ onChange(valueItem, index);
429
+ if ((0, _utils.is)('function', item.props.onClick)) item.props.onClick(event);
430
+ }
321
431
  });
322
- return ((0, jsx_runtime_1.jsxs)(Surface, Object.assign({ ref: item => {
323
- if (ref) {
324
- if ((0, utils_1.is)('function', ref))
325
- ref(item);
326
- else
327
- ref.current = item;
328
- }
329
- refs.root.current = item;
330
- }, tonal: tonal, color: color, gap: 0, direction: direction, align: align, justify: justify, role: 'tablist', "aria-orientation": orientation, Component: Line, AdditionalProps: {
331
- Component
332
- } }, SurfaceProps, { className: (0, style_react_1.classNames)([
333
- (0, utils_2.staticClassName)('Tabs', theme) && [
334
- 'onesy-Tabs-root',
335
- `onesy-Tabs-version-${version}`,
336
- `onesy-Tabs-size-${size}`
337
- ],
338
- SurfaceProps === null || SurfaceProps === void 0 ? void 0 : SurfaceProps.className,
339
- className,
340
- classes.root,
341
- classes[`size_${size}`],
342
- classes[`orientation_${orientation}`],
343
- fixed && classes.fixed
344
- ]) }, other, { children: [useArrows && ArrowPre, !noDivider && ((0, jsx_runtime_1.jsx)(Divider, { tonal: tonal, color: color, orientation: orientation, className: (0, style_react_1.classNames)([
345
- (0, utils_2.staticClassName)('Tabs', theme) && [
346
- 'onesy-Tabs-divider'
347
- ],
348
- classes.divider,
349
- classes[`divider_orientation_${orientation}`]
350
- ]) })), (0, jsx_runtime_1.jsxs)(Line, Object.assign({ ref: refs.tabsRoot, gap: 0, direction: direction, align: 'flex-start', justify: 'flex-start', onScroll: onScroll, className: (0, style_react_1.classNames)([
351
- (0, utils_2.staticClassName)('Tabs', theme) && [
352
- 'onesy-Tabs-tabs'
353
- ],
354
- classes.tabs,
355
- classes[`tabs_orientation_${orientation}`]
356
- ]) }, { children: [tabActive && ((0, jsx_runtime_1.jsx)("span", { className: (0, style_react_1.classNames)([
357
- (0, utils_2.staticClassName)('Tabs', theme) && [
358
- 'onesy-Tabs-line'
359
- ],
360
- classes.line,
361
- classes[`line_version_${version}_size_${size}_orientation_${orientation}`],
362
- orientation === 'vertical' && theme.direction === 'rtl' && classes[`line_version_${version}_orientation_vertical_rtl`]
363
- ]), style: {
364
- [propPosition]: orientation === 'horizontal' ? lineValues.x : lineValues.y,
365
- [propMain]: lineValues[propMain]
366
- } })), TabElements.map((item, index) => {
367
- const valueItem = item.props.value !== undefined ? item.props.value : index;
368
- return (react_1.default.cloneElement(item, {
369
- tonal: item.props.tonal !== undefined ? item.props.tonal : tonal,
370
- color: item.props.color !== undefined ? item.props.color : color,
371
- version: item.props.version !== undefined ? item.props.version : version,
372
- value: item.props.value !== undefined ? item.props.value : index,
373
- size: item.props.size !== undefined ? item.props.size : size,
374
- index,
375
- onChange,
376
- activateOnFocus: item.props.activateOnFocus !== undefined ? item.props.activateOnFocus : activateOnFocus,
377
- active: (0, utils_1.is)('function', refs.isActive.current) ? refs.isActive.current(value, valueItem) : value === valueItem,
378
- onClick: (event) => {
379
- onChange(valueItem, index);
380
- if ((0, utils_1.is)('function', item.props.onClick))
381
- item.props.onClick(event);
382
- }
383
- }));
384
- })] })), useArrows && ArrowPost] })));
432
+ })), useArrows && ArrowPost);
385
433
  });
386
434
  Tabs.displayName = 'onesy-Tabs';
387
- exports.default = Tabs;
435
+ var _default = exports.default = Tabs;