@openorgus/react 0.0.6 → 0.0.7

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 (195) hide show
  1. package/dist/components/AIChatbot.d.ts +12 -0
  2. package/dist/components/AIChatbot.d.ts.map +1 -0
  3. package/dist/components/ActionSheet.d.ts +12 -0
  4. package/dist/components/ActionSheet.d.ts.map +1 -0
  5. package/dist/components/Alert.d.ts +11 -0
  6. package/dist/components/Alert.d.ts.map +1 -0
  7. package/dist/components/AnimationPreview.d.ts +10 -0
  8. package/dist/components/AnimationPreview.d.ts.map +1 -0
  9. package/dist/components/AppBar.d.ts +12 -0
  10. package/dist/components/AppBar.d.ts.map +1 -0
  11. package/dist/components/Autocomplete.d.ts +12 -0
  12. package/dist/components/Autocomplete.d.ts.map +1 -0
  13. package/dist/components/Avatar.d.ts +11 -0
  14. package/dist/components/Avatar.d.ts.map +1 -0
  15. package/dist/components/Backdrop.d.ts +12 -0
  16. package/dist/components/Backdrop.d.ts.map +1 -0
  17. package/dist/components/Badge.d.ts +11 -0
  18. package/dist/components/Badge.d.ts.map +1 -0
  19. package/dist/components/BottomNavigation.d.ts +12 -0
  20. package/dist/components/BottomNavigation.d.ts.map +1 -0
  21. package/dist/components/Box.d.ts +12 -0
  22. package/dist/components/Box.d.ts.map +1 -0
  23. package/dist/components/Breadcrumbs.d.ts +12 -0
  24. package/dist/components/Breadcrumbs.d.ts.map +1 -0
  25. package/dist/components/Button.d.ts +8 -7
  26. package/dist/components/Button.d.ts.map +1 -0
  27. package/dist/components/ButtonGroup.d.ts +12 -0
  28. package/dist/components/ButtonGroup.d.ts.map +1 -0
  29. package/dist/components/CalendarBookings.d.ts +38 -0
  30. package/dist/components/CalendarBookings.d.ts.map +1 -0
  31. package/dist/components/Camera.d.ts +12 -0
  32. package/dist/components/Camera.d.ts.map +1 -0
  33. package/dist/components/Card.d.ts +12 -0
  34. package/dist/components/Card.d.ts.map +1 -0
  35. package/dist/components/Charts.d.ts +12 -0
  36. package/dist/components/Charts.d.ts.map +1 -0
  37. package/dist/components/Checkbox.d.ts +12 -0
  38. package/dist/components/Checkbox.d.ts.map +1 -0
  39. package/dist/components/Chip.d.ts +12 -0
  40. package/dist/components/Chip.d.ts.map +1 -0
  41. package/dist/components/CodeGenerator.d.ts +12 -0
  42. package/dist/components/CodeGenerator.d.ts.map +1 -0
  43. package/dist/components/ColorPicker.d.ts +12 -0
  44. package/dist/components/ColorPicker.d.ts.map +1 -0
  45. package/dist/components/Container.d.ts +12 -0
  46. package/dist/components/Container.d.ts.map +1 -0
  47. package/dist/components/CreditCard.d.ts +12 -0
  48. package/dist/components/CreditCard.d.ts.map +1 -0
  49. package/dist/components/DataQuery.d.ts +12 -0
  50. package/dist/components/DataQuery.d.ts.map +1 -0
  51. package/dist/components/DatePicker.d.ts +12 -0
  52. package/dist/components/DatePicker.d.ts.map +1 -0
  53. package/dist/components/DecayCard.d.ts +12 -0
  54. package/dist/components/DecayCard.d.ts.map +1 -0
  55. package/dist/components/Dialog.d.ts +12 -0
  56. package/dist/components/Dialog.d.ts.map +1 -0
  57. package/dist/components/Divider.d.ts +12 -0
  58. package/dist/components/Divider.d.ts.map +1 -0
  59. package/dist/components/Drawer.d.ts +12 -0
  60. package/dist/components/Drawer.d.ts.map +1 -0
  61. package/dist/components/EmojisPreview.d.ts +10 -0
  62. package/dist/components/EmojisPreview.d.ts.map +1 -0
  63. package/dist/components/FloatingActionButton.d.ts +12 -0
  64. package/dist/components/FloatingActionButton.d.ts.map +1 -0
  65. package/dist/components/FontAwesomeWrapper.d.ts +12 -0
  66. package/dist/components/FontAwesomeWrapper.d.ts.map +1 -0
  67. package/dist/components/IconsPreview.d.ts +17 -0
  68. package/dist/components/IconsPreview.d.ts.map +1 -0
  69. package/dist/components/IllustrationsPreview.d.ts +17 -0
  70. package/dist/components/IllustrationsPreview.d.ts.map +1 -0
  71. package/dist/components/ImageGenerator.d.ts +12 -0
  72. package/dist/components/ImageGenerator.d.ts.map +1 -0
  73. package/dist/components/ImageList.d.ts +12 -0
  74. package/dist/components/ImageList.d.ts.map +1 -0
  75. package/dist/components/InteractiveCursor.d.ts +12 -0
  76. package/dist/components/InteractiveCursor.d.ts.map +1 -0
  77. package/dist/components/Link.d.ts +12 -0
  78. package/dist/components/Link.d.ts.map +1 -0
  79. package/dist/components/List.d.ts +12 -0
  80. package/dist/components/List.d.ts.map +1 -0
  81. package/dist/components/MagnetLines.d.ts +12 -0
  82. package/dist/components/MagnetLines.d.ts.map +1 -0
  83. package/dist/components/Map.d.ts +12 -0
  84. package/dist/components/Map.d.ts.map +1 -0
  85. package/dist/components/Menu.d.ts +12 -0
  86. package/dist/components/Menu.d.ts.map +1 -0
  87. package/dist/components/Modal.d.ts +12 -0
  88. package/dist/components/Modal.d.ts.map +1 -0
  89. package/dist/components/NumberField.d.ts +12 -0
  90. package/dist/components/NumberField.d.ts.map +1 -0
  91. package/dist/components/OrderSummary.d.ts +12 -0
  92. package/dist/components/OrderSummary.d.ts.map +1 -0
  93. package/dist/components/Pagination.d.ts +12 -0
  94. package/dist/components/Pagination.d.ts.map +1 -0
  95. package/dist/components/Paper.d.ts +12 -0
  96. package/dist/components/Paper.d.ts.map +1 -0
  97. package/dist/components/PixelTrail.d.ts +12 -0
  98. package/dist/components/PixelTrail.d.ts.map +1 -0
  99. package/dist/components/Progress.d.ts +12 -0
  100. package/dist/components/Progress.d.ts.map +1 -0
  101. package/dist/components/QRCode.d.ts +12 -0
  102. package/dist/components/QRCode.d.ts.map +1 -0
  103. package/dist/components/Radio.d.ts +12 -0
  104. package/dist/components/Radio.d.ts.map +1 -0
  105. package/dist/components/Rating.d.ts +12 -0
  106. package/dist/components/Rating.d.ts.map +1 -0
  107. package/dist/components/ReactBitsPlaceholder.d.ts +13 -0
  108. package/dist/components/ReactBitsPlaceholder.d.ts.map +1 -0
  109. package/dist/components/Select.d.ts +12 -0
  110. package/dist/components/Select.d.ts.map +1 -0
  111. package/dist/components/ShoppingCart.d.ts +12 -0
  112. package/dist/components/ShoppingCart.d.ts.map +1 -0
  113. package/dist/components/Signature.d.ts +12 -0
  114. package/dist/components/Signature.d.ts.map +1 -0
  115. package/dist/components/Skeleton.d.ts +12 -0
  116. package/dist/components/Skeleton.d.ts.map +1 -0
  117. package/dist/components/Slider.d.ts +12 -0
  118. package/dist/components/Slider.d.ts.map +1 -0
  119. package/dist/components/Snackbar.d.ts +12 -0
  120. package/dist/components/Snackbar.d.ts.map +1 -0
  121. package/dist/components/SpeedDial.d.ts +12 -0
  122. package/dist/components/SpeedDial.d.ts.map +1 -0
  123. package/dist/components/Stack.d.ts +12 -0
  124. package/dist/components/Stack.d.ts.map +1 -0
  125. package/dist/components/Stepper.d.ts +12 -0
  126. package/dist/components/Stepper.d.ts.map +1 -0
  127. package/dist/components/Switch.d.ts +12 -0
  128. package/dist/components/Switch.d.ts.map +1 -0
  129. package/dist/components/Table.d.ts +12 -0
  130. package/dist/components/Table.d.ts.map +1 -0
  131. package/dist/components/Tabs.d.ts +12 -0
  132. package/dist/components/Tabs.d.ts.map +1 -0
  133. package/dist/components/TextArea.d.ts +12 -0
  134. package/dist/components/TextArea.d.ts.map +1 -0
  135. package/dist/components/TextField.d.ts +12 -0
  136. package/dist/components/TextField.d.ts.map +1 -0
  137. package/dist/components/TextGenerator.d.ts +12 -0
  138. package/dist/components/TextGenerator.d.ts.map +1 -0
  139. package/dist/components/ToggleButton.d.ts +12 -0
  140. package/dist/components/ToggleButton.d.ts.map +1 -0
  141. package/dist/components/Tooltip.d.ts +12 -0
  142. package/dist/components/Tooltip.d.ts.map +1 -0
  143. package/dist/components/TransferList.d.ts +12 -0
  144. package/dist/components/TransferList.d.ts.map +1 -0
  145. package/dist/components/TreeView.d.ts +12 -0
  146. package/dist/components/TreeView.d.ts.map +1 -0
  147. package/dist/components/TypographyPreview.d.ts +11 -0
  148. package/dist/components/TypographyPreview.d.ts.map +1 -0
  149. package/dist/components/Upload.d.ts +12 -0
  150. package/dist/components/Upload.d.ts.map +1 -0
  151. package/dist/components/VerificationCode.d.ts +12 -0
  152. package/dist/components/VerificationCode.d.ts.map +1 -0
  153. package/dist/components/VerificationProgress.d.ts +36 -0
  154. package/dist/components/VerificationProgress.d.ts.map +1 -0
  155. package/dist/components/VideoGenerator.d.ts +12 -0
  156. package/dist/components/VideoGenerator.d.ts.map +1 -0
  157. package/dist/components/VideoPlayer.d.ts +12 -0
  158. package/dist/components/VideoPlayer.d.ts.map +1 -0
  159. package/dist/components/VirtualKeyboard.d.ts +13 -0
  160. package/dist/components/VirtualKeyboard.d.ts.map +1 -0
  161. package/dist/components/VoiceChatbot.d.ts +12 -0
  162. package/dist/components/VoiceChatbot.d.ts.map +1 -0
  163. package/dist/components/VoiceUI.d.ts +12 -0
  164. package/dist/components/VoiceUI.d.ts.map +1 -0
  165. package/dist/components/Whiteboard.d.ts +12 -0
  166. package/dist/components/Whiteboard.d.ts.map +1 -0
  167. package/dist/constants.d.ts +4 -0
  168. package/dist/constants.d.ts.map +1 -0
  169. package/dist/index.d.ts +83 -1
  170. package/dist/index.d.ts.map +1 -0
  171. package/dist/openorgus-react.es.js +15198 -0
  172. package/dist/openorgus-react.es.js.map +1 -0
  173. package/dist/types.d.ts +12 -0
  174. package/dist/types.d.ts.map +1 -0
  175. package/dist/utils/animationUtils.d.ts +6 -0
  176. package/dist/utils/animationUtils.d.ts.map +1 -0
  177. package/dist/utils/autolayout.d.ts +27 -0
  178. package/dist/utils/autolayout.d.ts.map +1 -0
  179. package/dist/utils/componentDocumentation.d.ts +61 -0
  180. package/dist/utils/componentDocumentation.d.ts.map +1 -0
  181. package/dist/utils/cursorEffects.d.ts +37 -0
  182. package/dist/utils/cursorEffects.d.ts.map +1 -0
  183. package/dist/utils/iconData.d.ts +5 -0
  184. package/dist/utils/iconData.d.ts.map +1 -0
  185. package/dist/utils/mockData.d.ts +91 -0
  186. package/dist/utils/mockData.d.ts.map +1 -0
  187. package/dist/utils/mockStorage.d.ts +69 -0
  188. package/dist/utils/mockStorage.d.ts.map +1 -0
  189. package/dist/utils/styleUtils.d.ts +10 -9
  190. package/dist/utils/styleUtils.d.ts.map +1 -0
  191. package/dist/utils/urduTranslator.d.ts +22 -0
  192. package/dist/utils/urduTranslator.d.ts.map +1 -0
  193. package/package.json +1 -1
  194. package/dist/opengrid-react.es.js +0 -420
  195. package/dist/opengrid-react.umd.js +0 -56
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openorgus-react.es.js","sources":["../src/utils/styleUtils.ts","../src/components/Button.tsx","../src/components/Alert.tsx","../src/components/Avatar.tsx","../src/components/Badge.tsx","../src/components/Box.tsx","../src/components/Breadcrumbs.tsx","../src/components/Card.tsx","../src/components/Chip.tsx","../src/components/Container.tsx","../src/components/Divider.tsx","../src/components/Link.tsx","../src/components/List.tsx","../src/components/Paper.tsx","../src/components/Skeleton.tsx","../src/components/Stack.tsx","../src/components/Tooltip.tsx","../src/components/Autocomplete.tsx","../src/components/Checkbox.tsx","../src/components/ColorPicker.tsx","../src/components/DatePicker.tsx","../src/components/NumberField.tsx","../src/components/Radio.tsx","../src/components/Select.tsx","../src/components/Signature.tsx","../src/components/Slider.tsx","../src/components/Switch.tsx","../src/components/TextArea.tsx","../src/components/TextField.tsx","../src/components/Upload.tsx","../src/components/VerificationCode.tsx","../src/components/AppBar.tsx","../src/components/BottomNavigation.tsx","../src/components/Menu.tsx","../src/components/Pagination.tsx","../src/components/SpeedDial.tsx","../src/components/Stepper.tsx","../src/components/Tabs.tsx","../src/components/Backdrop.tsx","../src/components/Dialog.tsx","../src/components/Modal.tsx","../src/components/Progress.tsx","../src/components/Snackbar.tsx","../src/components/Charts.tsx","../src/components/ImageList.tsx","../src/components/Rating.tsx","../src/components/Table.tsx","../src/components/TransferList.tsx","../src/components/TreeView.tsx","../src/components/OrderSummary.tsx","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/common.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/red.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/purple.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/blue.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/lightBlue.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/green.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/orange.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/colors/grey.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/formatMuiErrorMessage/formatMuiErrorMessage.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/identifier.js","../../../node_modules/.pnpm/@babel+runtime@7.28.4/node_modules/@babel/runtime/helpers/esm/extends.js","../../../node_modules/.pnpm/@emotion+sheet@1.4.0/node_modules/@emotion/sheet/dist/emotion-sheet.esm.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Enum.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Utility.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Tokenizer.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Parser.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Serializer.js","../../../node_modules/.pnpm/stylis@4.2.0/node_modules/stylis/src/Middleware.js","../../../node_modules/.pnpm/@emotion+memoize@0.9.0/node_modules/@emotion/memoize/dist/emotion-memoize.esm.js","../../../node_modules/.pnpm/@emotion+cache@11.14.0/node_modules/@emotion/cache/dist/emotion-cache.browser.esm.js","../../../node_modules/.pnpm/react-is@16.13.1/node_modules/react-is/cjs/react-is.production.min.js","../../../node_modules/.pnpm/react-is@16.13.1/node_modules/react-is/cjs/react-is.development.js","../../../node_modules/.pnpm/react-is@16.13.1/node_modules/react-is/index.js","../../../node_modules/.pnpm/hoist-non-react-statics@3.3.2/node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js","../../../node_modules/.pnpm/@emotion+utils@1.4.2/node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../../../node_modules/.pnpm/@emotion+hash@0.9.2/node_modules/@emotion/hash/dist/emotion-hash.esm.js","../../../node_modules/.pnpm/@emotion+unitless@0.10.0/node_modules/@emotion/unitless/dist/emotion-unitless.esm.js","../../../node_modules/.pnpm/@emotion+serialize@1.3.3/node_modules/@emotion/serialize/dist/emotion-serialize.esm.js","../../../node_modules/.pnpm/@emotion+use-insertion-effe_11ba0692a8a0877d191ec06c2da029e2/node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.browser.esm.js","../../../node_modules/.pnpm/@emotion+react@11.14.0_@types+react@19.2.7_react@19.2.1/node_modules/@emotion/react/dist/emotion-element-f0de968e.browser.esm.js","../../../node_modules/.pnpm/@emotion+react@11.14.0_@types+react@19.2.7_react@19.2.1/node_modules/@emotion/react/dist/emotion-react.browser.esm.js","../../../node_modules/.pnpm/@emotion+is-prop-valid@1.4.0/node_modules/@emotion/is-prop-valid/dist/emotion-is-prop-valid.esm.js","../../../node_modules/.pnpm/@emotion+styled@11.14.1_@em_947fd12070a91eb77107ced8b4064729/node_modules/@emotion/styled/base/dist/emotion-styled-base.browser.esm.js","../../../node_modules/.pnpm/@emotion+styled@11.14.1_@em_947fd12070a91eb77107ced8b4064729/node_modules/@emotion/styled/dist/emotion-styled.browser.esm.js","../../../node_modules/.pnpm/object-assign@4.1.1/node_modules/object-assign/index.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/lib/ReactPropTypesSecret.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/lib/has.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/checkPropTypes.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/factoryWithTypeCheckers.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/factoryWithThrowingShims.js","../../../node_modules/.pnpm/prop-types@15.8.1/node_modules/prop-types/index.js","../../../node_modules/.pnpm/@mui+styled-engine@7.3.6_@e_2b2db6ebd3c5097a2fed6cb8231098f1/node_modules/@mui/styled-engine/esm/index.js","../../../node_modules/.pnpm/react-is@19.2.3/node_modules/react-is/cjs/react-is.production.js","../../../node_modules/.pnpm/react-is@19.2.3/node_modules/react-is/cjs/react-is.development.js","../../../node_modules/.pnpm/react-is@19.2.3/node_modules/react-is/index.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/deepmerge/deepmerge.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createBreakpoints/createBreakpoints.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssContainerQueries/cssContainerQueries.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createTheme/shape.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/responsivePropType/responsivePropType.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/merge/merge.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/breakpoints/breakpoints.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/capitalize/capitalize.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/style/style.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/memoize/memoize.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/spacing/spacing.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createTheme/createSpacing.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/compose/compose.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/borders/borders.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssGrid/cssGrid.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/palette/palette.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/sizing/sizing.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/styleFunctionSx/defaultSxConfig.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/styleFunctionSx/styleFunctionSx.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createTheme/applyStyles.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createTheme/createTheme.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/useThemeWithoutDefault/useThemeWithoutDefault.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/useTheme/useTheme.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/styleFunctionSx/extendSxProp.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/ClassNameGenerator/ClassNameGenerator.js","../../../node_modules/.pnpm/clsx@2.1.1/node_modules/clsx/dist/clsx.mjs","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createBox/createBox.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/generateUtilityClass/generateUtilityClass.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/generateUtilityClasses/generateUtilityClasses.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/getDisplayName/getDisplayName.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/preprocessStyles.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/createStyled/createStyled.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/resolveProps/resolveProps.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useEnhancedEffect/useEnhancedEffect.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/clamp/clamp.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/colorManipulator/colorManipulator.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/DefaultPropsProvider/DefaultPropsProvider.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useId/useId.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/memoTheme.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssVars/createGetCssVar.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssVars/cssVarsParser.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssVars/prepareCssVars.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssVars/getColorSchemeSelector.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/composeClasses/composeClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createPalette.js","../../../node_modules/.pnpm/@mui+system@7.3.6_@emotion+_2d56dd2619673c18a1edd264899eea71/node_modules/@mui/system/esm/cssVars/prepareTypographyVars.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createMixins.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createTypography.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/shadows.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createTransitions.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/zIndex.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/stringifyTheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createThemeNoVars.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/getOverlayAlpha.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createColorScheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/shouldSkipGeneratingVar.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/excludeVariablesFromRoot.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createGetSelector.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createThemeWithVars.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/createTheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/defaultTheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/useTheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/slotShouldForwardProp.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/rootShouldForwardProp.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/styles/styled.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/zero-styled/index.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/utils/memoTheme.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/DefaultPropsProvider/DefaultPropsProvider.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/SvgIcon/svgIconClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/SvgIcon/SvgIcon.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/utils/createSvgIcon.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useEventCallback/useEventCallback.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useForkRef/useForkRef.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/chainPropTypes/chainPropTypes.js","../../../node_modules/.pnpm/@babel+runtime@7.28.4/node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../../../node_modules/.pnpm/@babel+runtime@7.28.4/node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js","../../../node_modules/.pnpm/@babel+runtime@7.28.4/node_modules/@babel/runtime/helpers/esm/inheritsLoose.js","../../../node_modules/.pnpm/react-transition-group@4.4._b722a0dfdf5dc5276a7a399cc52a7769/node_modules/react-transition-group/esm/TransitionGroupContext.js","../../../node_modules/.pnpm/@babel+runtime@7.28.4/node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js","../../../node_modules/.pnpm/react-transition-group@4.4._b722a0dfdf5dc5276a7a399cc52a7769/node_modules/react-transition-group/esm/utils/ChildMapping.js","../../../node_modules/.pnpm/react-transition-group@4.4._b722a0dfdf5dc5276a7a399cc52a7769/node_modules/react-transition-group/esm/TransitionGroup.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useLazyRef/useLazyRef.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useOnMount/useOnMount.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/useTimeout/useTimeout.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/elementTypeAcceptingRef/elementTypeAcceptingRef.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/isHostComponent/isHostComponent.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/appendOwnerState/appendOwnerState.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/resolveComponentProps/resolveComponentProps.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/extractEventHandlers/extractEventHandlers.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/omitEventHandlers/omitEventHandlers.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/mergeSlotProps/mergeSlotProps.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/utils/useSlot.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/integerPropType/integerPropType.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Paper/paperClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Paper/Paper.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/refType/refType.js","../../../node_modules/.pnpm/@mui+utils@7.3.6_@types+react@19.2.7_react@19.2.1/node_modules/@mui/utils/esm/isFocusVisible/isFocusVisible.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/useLazyRipple/useLazyRipple.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/ButtonBase/Ripple.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/ButtonBase/touchRippleClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/ButtonBase/TouchRipple.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/ButtonBase/buttonBaseClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/ButtonBase/ButtonBase.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/utils/createSimplePaletteValueFilter.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Alert/alertClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/CircularProgress/circularProgressClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/CircularProgress/CircularProgress.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/IconButton/iconButtonClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/IconButton/IconButton.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/internal/svg-icons/SuccessOutlined.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/internal/svg-icons/ReportProblemOutlined.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/internal/svg-icons/ErrorOutline.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/internal/svg-icons/InfoOutlined.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/internal/svg-icons/Close.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Alert/Alert.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Typography/typographyClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Typography/Typography.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Box/boxClasses.js","../../../node_modules/.pnpm/@mui+material@7.3.6_@emotio_44fdc03b9dadf5e68d14a54f194d8420/node_modules/@mui/material/esm/Box/Box.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/AccessTime.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/ArrowForward.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/CalendarToday.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/CheckCircle.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/LocationOn.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/Schedule.js","../../../node_modules/.pnpm/@mui+icons-material@7.3.6_@_7c9dbbd27a0043003ea11932a8cfc4a4/node_modules/@mui/icons-material/esm/VideoCall.js","../src/components/CalendarBookings.tsx","../src/components/VerificationProgress.tsx","../src/components/ButtonGroup.tsx","../src/components/FloatingActionButton.tsx","../src/components/ToggleButton.tsx","../src/components/Drawer.tsx","../src/components/ActionSheet.tsx","../src/components/Camera.tsx","../src/components/Map.tsx","../src/components/AIChatbot.tsx","../src/components/CodeGenerator.tsx","../src/components/ImageGenerator.tsx","../src/components/TextGenerator.tsx","../src/components/VideoGenerator.tsx","../src/components/VoiceChatbot.tsx","../src/components/VoiceUI.tsx","../src/components/DataQuery.tsx","../src/components/Whiteboard.tsx","../src/components/QRCode.tsx","../src/components/CreditCard.tsx","../src/components/AnimationPreview.tsx","../src/components/EmojisPreview.tsx","../src/utils/animationUtils.ts","../src/components/FontAwesomeWrapper.tsx","../src/components/IconsPreview.tsx","../src/components/IllustrationsPreview.tsx","../src/components/VideoPlayer.tsx","../src/components/TypographyPreview.tsx","../src/components/ShoppingCart.tsx","../src/components/VirtualKeyboard.tsx","../src/utils/cursorEffects.ts","../src/components/InteractiveCursor.tsx","../src/components/MagnetLines.tsx","../src/components/PixelTrail.tsx","../src/components/DecayCard.tsx"],"sourcesContent":["\r\nimport { GlobalConfig, GranularStyles, ComponentProps, DesignSystem } from '../types';\r\nimport React from 'react';\r\n\r\n// === THEME ENGINE ===\r\n\r\nexport const getRadiusClass = (globalConfig: Partial<GlobalConfig> = {}) => {\r\n const baseRadius = globalConfig?.baseRadius ?? 4;\r\n\r\n // Default Slider Logic\r\n if (baseRadius === 0) return 'rounded-none';\r\n if (baseRadius <= 4) return 'rounded-sm';\r\n if (baseRadius <= 8) return 'rounded-md';\r\n if (baseRadius <= 12) return 'rounded-lg';\r\n if (baseRadius <= 16) return 'rounded-xl';\r\n return 'rounded-2xl';\r\n};\r\n\r\nexport const getColorClass = (\r\n globalConfig: Partial<GlobalConfig> = {},\r\n type: 'bg' | 'text' | 'border' | 'ring',\r\n role: 'primary' | 'secondary' | 'tertiary' | 'success' | 'danger' | 'warning' | 'info' = 'primary'\r\n) => {\r\n const primaryColor = globalConfig?.primaryColor || 'blue';\r\n const secondaryColor = globalConfig?.secondaryColor;\r\n const tertiaryColor = globalConfig?.tertiaryColor;\r\n\r\n // Determine which color to use based on role\r\n let c = primaryColor;\r\n if (role === 'secondary' && secondaryColor) {\r\n c = secondaryColor;\r\n } else if (role === 'tertiary' && tertiaryColor) {\r\n c = tertiaryColor;\r\n }\r\n\r\n // Map semantic roles to color shades\r\n const colorMap = {\r\n primary: { bg: 600, hover: 700, text: 600, border: 600, ring: 500 },\r\n secondary: { bg: 500, hover: 600, text: 500, border: 500, ring: 400 },\r\n tertiary: { bg: 400, hover: 500, text: 400, border: 400, ring: 300 },\r\n success: { bg: 600, hover: 700, text: 600, border: 600, ring: 500 }, // Use primary color for success\r\n danger: { bg: 600, hover: 700, text: 600, border: 600, ring: 500 }, // Use primary color for danger\r\n warning: { bg: 500, hover: 600, text: 500, border: 500, ring: 400 }, // Use primary color for warning\r\n info: { bg: 500, hover: 600, text: 500, border: 500, ring: 400 }, // Use primary color for info\r\n };\r\n\r\n const shades = colorMap[role] || colorMap.primary;\r\n\r\n // Standard Tailwind Map\r\n if (type === 'bg') return `bg-${c}-${shades.bg} hover:bg-${c}-${shades.hover}`;\r\n if (type === 'text') return `text-${c}-${shades.text}`;\r\n if (type === 'border') return `border-${c}-${shades.border}`;\r\n if (type === 'ring') return `focus:ring-${c}-${shades.ring}`;\r\n return '';\r\n};\r\n\r\n// Get color class with specific shade\r\nexport const getColorShade = (\r\n globalConfig: Partial<GlobalConfig> = {},\r\n type: 'bg' | 'text' | 'border' | 'ring',\r\n shade: 50 | 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900 = 600,\r\n role: 'primary' | 'secondary' | 'tertiary' = 'primary'\r\n): string => {\r\n const primaryColor = globalConfig?.primaryColor || 'blue';\r\n const secondaryColor = globalConfig?.secondaryColor;\r\n const tertiaryColor = globalConfig?.tertiaryColor;\r\n\r\n // Determine which color to use based on role\r\n let c = primaryColor;\r\n if (role === 'secondary' && secondaryColor) {\r\n c = secondaryColor;\r\n } else if (role === 'tertiary' && tertiaryColor) {\r\n c = tertiaryColor;\r\n }\r\n\r\n if (type === 'ring') return `ring-${c}-${shade}`;\r\n return `${type}-${c}-${shade}`;\r\n};\r\n\r\n// Get color value as hex/rgb for inline styles\r\nexport const getColorValue = (\r\n globalConfig: Partial<GlobalConfig> = {},\r\n role: 'primary' | 'secondary' | 'tertiary' = 'primary',\r\n shade: number = 600\r\n): string => {\r\n const primaryColor = globalConfig?.primaryColor || 'blue';\r\n const secondaryColor = globalConfig?.secondaryColor;\r\n const tertiaryColor = globalConfig?.tertiaryColor;\r\n\r\n // Determine which color to use based on role\r\n let colorName = primaryColor;\r\n if (role === 'secondary' && secondaryColor) {\r\n colorName = secondaryColor;\r\n } else if (role === 'tertiary' && tertiaryColor) {\r\n colorName = tertiaryColor;\r\n }\r\n\r\n // Map Tailwind color names to hex values\r\n const colorMap: Record<string, Record<number, string>> = {\r\n blue: { 50: '#eff6ff', 100: '#dbeafe', 400: '#60a5fa', 500: '#3b82f6', 600: '#2563eb', 700: '#1d4ed8', 800: '#1e40af' },\r\n green: { 50: '#f0fdf4', 100: '#dcfce7', 400: '#4ade80', 500: '#22c55e', 600: '#16a34a', 700: '#15803d', 800: '#166534' },\r\n red: { 50: '#fef2f2', 100: '#fee2e2', 400: '#f87171', 500: '#ef4444', 600: '#dc2626', 700: '#b91c1c', 800: '#991b1b' },\r\n yellow: { 50: '#fefce8', 100: '#fef9c3', 400: '#facc15', 500: '#eab308', 600: '#ca8a04', 700: '#a16207', 800: '#854d0e' },\r\n purple: { 50: '#faf5ff', 100: '#f3e8ff', 400: '#a78bfa', 500: '#9333ea', 600: '#7e22ce', 700: '#6b21a8', 800: '#581c87' },\r\n pink: { 50: '#fdf2f8', 100: '#fce7f3', 400: '#f472b6', 500: '#ec4899', 600: '#db2777', 700: '#be185d', 800: '#9d174d' },\r\n indigo: { 50: '#eef2ff', 100: '#e0e7ff', 400: '#818cf8', 500: '#6366f1', 600: '#4f46e5', 700: '#4338ca', 800: '#3730a3' },\r\n cyan: { 50: '#ecfeff', 100: '#cffafe', 400: '#22d3ee', 500: '#06b6d4', 600: '#0891b2', 700: '#0e7490', 800: '#155e75' },\r\n orange: { 50: '#fff7ed', 100: '#ffedd5', 400: '#fb923c', 500: '#f97316', 600: '#ea580c', 700: '#c2410c', 800: '#9a3412' },\r\n teal: { 50: '#f0fdf4', 100: '#ccfbf1', 400: '#2dd4bf', 500: '#14b8a6', 600: '#0d9488', 700: '#0f766e', 800: '#115e59' },\r\n rose: { 50: '#fff1f2', 100: '#ffe4e6', 400: '#fb7185', 500: '#f43f5e', 600: '#e11d48', 700: '#be123c', 800: '#9f1239' },\r\n fuchsia: { 50: '#fdf4ff', 100: '#fae8ff', 400: '#e879f9', 500: '#d946ef', 600: '#c026d3', 700: '#a21caf', 800: '#86198f' },\r\n violet: { 50: '#f5f3ff', 100: '#ede9fe', 400: '#a78bfa', 500: '#8b5cf6', 600: '#7c3aed', 700: '#6d28d9', 800: '#5b21b6' },\r\n sky: { 50: '#f0f9ff', 100: '#e0f2fe', 400: '#38bdf8', 500: '#0ea5e9', 600: '#0284c7', 700: '#0369a1', 800: '#075985' },\r\n emerald: { 50: '#ecfdf5', 100: '#d1fae5', 400: '#34d399', 500: '#10b981', 600: '#059669', 700: '#047857', 800: '#065f46' },\r\n lime: { 50: '#f7fee7', 100: '#ecfccb', 400: '#a3e635', 500: '#84cc16', 600: '#65a30d', 700: '#4d7c0f', 800: '#365314' },\r\n amber: { 50: '#fffbeb', 100: '#fef3c7', 400: '#fbbf24', 500: '#f59e0b', 600: '#d97706', 700: '#b45309', 800: '#92400e' },\r\n };\r\n\r\n const roleShades: Record<string, number> = {\r\n primary: 600,\r\n secondary: 500,\r\n tertiary: 400,\r\n };\r\n\r\n const targetShade = roleShades[role] || shade;\r\n return colorMap[colorName]?.[targetShade] || colorMap.blue[600];\r\n};\r\n\r\n// === COMPONENT GENERATORS ===\r\n\r\n/**\r\n * Generates the specific tailwind classes for the combination of Variant + State + Design System\r\n */\r\nexport const getComponentVariantClasses = (\r\n designSystem: DesignSystem = 'Custom',\r\n componentProps: Partial<ComponentProps> = {},\r\n globalConfig: Partial<GlobalConfig> = {},\r\n baseType: 'button' | 'input' | 'surface' = 'button'\r\n) => {\r\n const variant = componentProps?.variant || 'primary';\r\n const isHovered = componentProps?.isHovered;\r\n const isFocused = componentProps?.isFocused;\r\n const isActive = componentProps?.isActive;\r\n const isTouched = componentProps?.isTouched;\r\n const isError = componentProps?.isError;\r\n const isDisabled = componentProps?.isDisabled;\r\n\r\n const c = globalConfig?.primaryColor || 'blue';\r\n\r\n let classes = '';\r\n\r\n // --- BASE STATE MODIFIERS ---\r\n if (isHovered) classes += ' brightness-95 transform -translate-y-0.5 shadow-md ';\r\n if (isFocused) classes += ` ring-2 ring-offset-2 ring-${c}-500 dark:ring-${c}-400 z-10 `;\r\n if (isActive) classes += ' transform scale-95 brightness-90 shadow-inner ';\r\n if (isTouched) classes += ' opacity-70 ';\r\n if (isDisabled) classes += ' opacity-50 cursor-not-allowed grayscale pointer-events-none ';\r\n\r\n // --- VARIANT LOGIC ---\r\n if (variant === 'primary') {\r\n if (baseType === 'button' || baseType === 'surface') {\r\n classes += ` bg-${c}-600 text-white border border-transparent shadow-sm`;\r\n if (designSystem === 'MUI') classes += ' shadow-md hover:shadow-lg uppercase tracking-wider font-medium';\r\n if (designSystem === 'Apple') classes += ' shadow-sm bg-gradient-to-b from-blue-500 to-blue-600 border-blue-400';\r\n }\r\n if (baseType === 'input') {\r\n classes += ` bg-gray-100 dark:bg-gray-800 border-b-2 border-${c}-600 rounded-t-md px-4 py-2`;\r\n }\r\n } else if (variant === 'secondary') {\r\n if (baseType === 'button') {\r\n classes += ` bg-white dark:bg-gray-800 text-${c}-700 dark:text-${c}-300 border border-gray-200 dark:border-gray-700`;\r\n if (designSystem === 'MUI') classes += ` border-2 border-${c}-600 text-${c}-600 font-medium uppercase`;\r\n }\r\n } else if (variant === 'tertiary') {\r\n classes += ` text-gray-600 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-800`;\r\n } else if (variant === 'outline') {\r\n classes += ` bg-transparent border-2 border-${c}-500 text-${c}-600 dark:text-${c}-400`;\r\n } else if (variant === 'ghost') {\r\n classes += ` bg-transparent text-${c}-600 dark:text-${c}-400 hover:bg-${c}-50 dark:hover:bg-${c}-900/20`;\r\n } else if (variant === 'soft') {\r\n classes += ` bg-${c}-100 dark:bg-${c}-900/40 text-${c}-800 dark:text-${c}-200 border border-${c}-200 dark:border-${c}-800`;\r\n } else if (variant === 'link') {\r\n classes += ` bg-transparent text-${c}-600 dark:text-${c}-400 underline underline-offset-4 hover:text-${c}-800 p-0 shadow-none border-none h-auto`;\r\n } else if (variant === 'danger') {\r\n classes += ` bg-${c}-700 text-white hover:bg-${c}-800 border border-${c}-700`;\r\n } else if (variant === 'success') {\r\n classes += ` bg-${c}-600 text-white hover:bg-${c}-700 border border-${c}-600`;\r\n } else if (variant === 'warning') {\r\n classes += ` bg-${c}-500 text-white hover:bg-${c}-600 border border-${c}-500`;\r\n }\r\n\r\n // --- ERROR STATE OVERRIDES ---\r\n if (isError) {\r\n if (baseType === 'input') classes += ` border-${c}-600 focus:ring-${c}-500 text-${c}-900 dark:text-${c}-100`;\r\n else classes += ` ring-2 ring-${c}-500 ring-offset-1`;\r\n }\r\n\r\n return classes;\r\n};\r\n\r\nexport const getThemeClasses = (globalConfig: Partial<GlobalConfig> = {}, variant: 'container' | 'input' | 'panel' = 'container') => {\r\n return '';\r\n};\r\n\r\n// === GRANULAR CONTROL ===\r\n\r\n/**\r\n * Get border radius value - uses granularStyles if explicitly set, otherwise falls back to globalConfig.baseRadius\r\n */\r\nexport const getBorderRadius = (granularStyles: Partial<GranularStyles> = {}, globalConfig: Partial<GlobalConfig> = {}): string => {\r\n const baseRadius = globalConfig?.baseRadius ?? 4;\r\n if (granularStyles?.borderRadius && granularStyles.borderRadius !== baseRadius) {\r\n return `${granularStyles.borderRadius}px`;\r\n }\r\n return `${baseRadius}px`;\r\n};\r\n\r\nexport const getAppliedStyles = (granularStyles: Partial<GranularStyles> = {}, globalConfig: Partial<GlobalConfig> = {}): React.CSSProperties => {\r\n return {\r\n width: granularStyles?.width === 'auto' ? undefined : granularStyles?.width,\r\n height: granularStyles?.height === 'auto' ? undefined : granularStyles?.height,\r\n\r\n paddingTop: granularStyles?.paddingY ? `${granularStyles.paddingY}px` : undefined,\r\n paddingBottom: granularStyles?.paddingY ? `${granularStyles.paddingY}px` : undefined,\r\n paddingLeft: granularStyles?.paddingX ? `${granularStyles.paddingX}px` : undefined,\r\n paddingRight: granularStyles?.paddingX ? `${granularStyles.paddingX}px` : undefined,\r\n\r\n marginTop: granularStyles?.marginTop ? `${granularStyles.marginTop}px` : undefined,\r\n marginBottom: granularStyles?.marginBottom ? `${granularStyles.marginBottom}px` : undefined,\r\n\r\n borderTopWidth: granularStyles?.borderTopWidth ? `${granularStyles.borderTopWidth}px` : undefined,\r\n borderRightWidth: granularStyles?.borderRightWidth ? `${granularStyles.borderRightWidth}px` : undefined,\r\n borderBottomWidth: granularStyles?.borderBottomWidth ? `${granularStyles.borderBottomWidth}px` : undefined,\r\n borderLeftWidth: granularStyles?.borderLeftWidth ? `${granularStyles.borderLeftWidth}px` : undefined,\r\n\r\n borderColor: granularStyles?.borderColor !== 'transparent' ? granularStyles?.borderColor : undefined,\r\n borderRadius: getBorderRadius(granularStyles, globalConfig),\r\n\r\n opacity: granularStyles?.opacity !== undefined ? granularStyles.opacity / 100 : undefined,\r\n boxShadow: granularStyles?.boxShadow !== 'none' ? granularStyles?.boxShadow : undefined,\r\n animation: granularStyles?.animation !== 'none' ? granularStyles?.animation : undefined,\r\n\r\n fontWeight: granularStyles?.fontWeight !== 'normal' ? granularStyles?.fontWeight : undefined,\r\n letterSpacing: granularStyles?.letterSpacing !== 'normal' ? granularStyles?.letterSpacing : undefined,\r\n };\r\n};\r\n","import React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, MousePointer2 } from 'lucide-react';\r\nimport { getAppliedStyles, getComponentVariantClasses } from '../utils/styleUtils';\r\n\r\nconst defaultComponentProps: ComponentProps = {\r\n variant: 'primary',\r\n size: 'MD',\r\n orientation: 'horizontal',\r\n textAlign: 'center',\r\n iconStyle: 'filled',\r\n isDisabled: false,\r\n isLoading: false,\r\n isError: false,\r\n isChecked: false,\r\n isIndeterminate: false,\r\n isHovered: false,\r\n isFocused: false,\r\n isActive: false,\r\n isTouched: false,\r\n text: '',\r\n};\r\n\r\nconst defaultGlobalConfig: GlobalConfig = {\r\n primaryColor: 'blue',\r\n baseRadius: 4,\r\n};\r\n\r\nconst defaultGranularStyles: GranularStyles = {\r\n width: 'auto',\r\n height: 'auto',\r\n paddingX: 0,\r\n paddingY: 0,\r\n marginTop: 0,\r\n marginBottom: 0,\r\n borderTopWidth: 0,\r\n borderRightWidth: 0,\r\n borderBottomWidth: 0,\r\n borderLeftWidth: 0,\r\n borderColor: 'transparent',\r\n borderRadius: 4,\r\n opacity: 100,\r\n boxShadow: 'none',\r\n animation: 'none',\r\n fontWeight: 'normal',\r\n letterSpacing: 'normal',\r\n};\r\n\r\nexport interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\r\n designSystem?: DesignSystem;\r\n componentProps?: Partial<ComponentProps>;\r\n globalConfig?: GlobalConfig;\r\n granularStyles?: GranularStyles;\r\n}\r\n\r\nexport const Button: React.FC<ButtonProps> = ({\r\n designSystem = 'Custom',\r\n componentProps = {},\r\n globalConfig = defaultGlobalConfig,\r\n granularStyles = defaultGranularStyles,\r\n children,\r\n className,\r\n disabled,\r\n style,\r\n ...rest\r\n}) => {\r\n // Merge provided componentProps with defaults\r\n const mergedComponentProps: ComponentProps = { ...defaultComponentProps, ...componentProps };\r\n\r\n // Update disabled state if prop is passed directly\r\n if (disabled !== undefined) {\r\n mergedComponentProps.isDisabled = disabled;\r\n }\r\n\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const variantClasses = getComponentVariantClasses(designSystem, mergedComponentProps, globalConfig, 'button');\r\n\r\n return (\r\n <button\r\n {...rest}\r\n style={{ ...appliedStyles, ...style }}\r\n disabled={mergedComponentProps.isDisabled || mergedComponentProps.isLoading}\r\n className={`\r\n flex items-center gap-2 transition-all duration-200 font-medium select-none\r\n ${mergedComponentProps.size === 'SM' ? 'px-4 py-2 text-xs' : mergedComponentProps.size === 'LG' ? 'px-8 py-4 text-lg' : 'px-6 py-2 text-sm'}\r\n ${variantClasses}\r\n ${className || ''}\r\n `}\r\n >\r\n {mergedComponentProps.isLoading ? <Loader2 className=\"animate-spin\" size={16} /> : null}\r\n {!mergedComponentProps.isLoading && children ? children : (mergedComponentProps.text || 'Button')}\r\n </button>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { AlertTriangle, Info, CheckCircle, XCircle } from 'lucide-react';\r\nimport { getAppliedStyles, getComponentVariantClasses, getRadiusClass } from '../utils/styleUtils';\r\n\r\nexport interface AlertProps extends React.HTMLAttributes<HTMLDivElement> {\r\n designSystem?: DesignSystem;\r\n componentProps?: Partial<ComponentProps>;\r\n globalConfig?: Partial<GlobalConfig>;\r\n granularStyles?: Partial<GranularStyles>;\r\n}\r\n\r\nexport const Alert: React.FC<AlertProps> = ({\r\n designSystem = 'Custom',\r\n componentProps = {},\r\n globalConfig = {},\r\n granularStyles = {},\r\n children,\r\n className,\r\n style,\r\n ...rest\r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n // Map component props to a variant if not explicitly set\r\n let variant = componentProps?.variant || 'primary';\r\n if (componentProps?.isError) variant = 'danger';\r\n if (variant === 'primary') variant = 'soft'; // Default to soft for alerts usually\r\n\r\n const variantClasses = getComponentVariantClasses(designSystem, { ...componentProps, variant }, globalConfig, 'surface');\r\n\r\n return (\r\n <div\r\n {...rest}\r\n style={{ ...appliedStyles, ...style }}\r\n className={`\r\n w-full max-w-md p-4 flex gap-3\r\n ${getRadiusClass(globalConfig)}\r\n ${variantClasses}\r\n ${className || ''}\r\n `}\r\n >\r\n {variant === 'danger' && <XCircle size={20} />}\r\n {variant === 'warning' && <AlertTriangle size={20} />}\r\n {variant === 'success' && <CheckCircle size={20} />}\r\n {(variant === 'info' || variant === 'soft' || variant === 'primary') && <Info size={20} />}\r\n\r\n <div className=\"flex-1\">\r\n <h4 className=\"text-sm font-bold capitalize\">{variant === 'soft' ? 'Information' : variant}</h4>\r\n <div className=\"text-sm opacity-90 mt-1\">\r\n {children || componentProps?.text || 'This alert component adapts to the selected variant and global state.'}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\nexport interface AvatarProps extends React.HTMLAttributes<HTMLDivElement> {\r\n designSystem?: DesignSystem;\r\n componentProps?: Partial<ComponentProps>;\r\n globalConfig?: Partial<GlobalConfig>;\r\n granularStyles?: Partial<GranularStyles>;\r\n}\r\n\r\nexport const Avatar: React.FC<AvatarProps> = ({\r\n designSystem = 'Custom',\r\n componentProps = {},\r\n globalConfig = {},\r\n granularStyles = {},\r\n children,\r\n className,\r\n style,\r\n ...rest\r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const bgClass = getColorClass(globalConfig, 'bg');\r\n\r\n return (\r\n <div\r\n {...rest}\r\n style={{ ...appliedStyles, ...style }}\r\n className={`h-12 w-12 rounded-full flex items-center justify-center text-white font-bold text-lg shadow-sm ${bgClass} ${className || ''}`}\r\n >\r\n {children || componentProps?.text?.charAt(0) || 'A'}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Bell, Mail } from 'lucide-react';\r\nimport { getAppliedStyles, getComponentVariantClasses } from '../utils/styleUtils';\r\n\r\nexport interface BadgeProps extends React.HTMLAttributes<HTMLDivElement> {\r\n designSystem?: DesignSystem;\r\n componentProps?: Partial<ComponentProps>;\r\n globalConfig?: Partial<GlobalConfig>;\r\n granularStyles?: Partial<GranularStyles>;\r\n}\r\n\r\nexport const Badge: React.FC<BadgeProps> = ({\r\n designSystem = 'Custom',\r\n componentProps = {},\r\n globalConfig = {},\r\n granularStyles = {},\r\n children,\r\n className,\r\n style,\r\n ...rest\r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n // Use the engine to get classes for the badge indicator itself\r\n const badgeClasses = getComponentVariantClasses(\r\n designSystem,\r\n { ...componentProps, variant: componentProps?.variant === 'ghost' ? 'primary' : componentProps?.variant || 'primary' },\r\n globalConfig,\r\n 'button'\r\n );\r\n\r\n return (\r\n <div {...rest} style={{ ...appliedStyles, ...style }} className={`flex gap-8 items-center ${className || ''}`}>\r\n {/* Number Badge */}\r\n <div className=\"relative group\">\r\n <div className={`p-3 bg-gray-100 dark:bg-gray-800 rounded-xl transition-transform ${componentProps?.isHovered ? 'scale-110' : ''}`}>\r\n <Bell size={24} className=\"text-gray-600 dark:text-gray-300\" />\r\n </div>\r\n <span className={`\r\n absolute -top-2 -right-2 flex h-6 w-6 items-center justify-center rounded-full text-[10px] font-bold ring-2 ring-white dark:ring-gray-950\r\n ${badgeClasses}\r\n `}>\r\n {children || '3'}\r\n </span>\r\n </div>\r\n\r\n {/* Dot Badge */}\r\n <div className=\"relative group\">\r\n <div className={`p-3 bg-gray-100 dark:bg-gray-800 rounded-xl transition-transform ${componentProps?.isHovered ? 'scale-110' : ''}`}>\r\n <Mail size={24} className=\"text-gray-600 dark:text-gray-300\" />\r\n </div>\r\n <span className={`\r\n absolute top-0 right-0 flex h-3.5 w-3.5 rounded-full ring-2 ring-white dark:ring-gray-950\r\n ${badgeClasses}\r\n `}></span>\r\n </div>\r\n\r\n {/* Text/Label Badge (using same engine) */}\r\n <div className={`\r\n px-2.5 py-0.5 rounded text-xs font-bold uppercase tracking-wider\r\n ${badgeClasses}\r\n `}>\r\n {componentProps?.text || 'New'}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface BoxProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Box: React.FC<BoxProps> = ({ \r\n designSystem, \r\n componentProps, \r\n globalConfig, \r\n granularStyles \r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Default dimensions if not specified - fill container by default\r\n const width = granularStyles.width === 'auto' || !granularStyles.width ? '100%' : granularStyles.width;\r\n const height = granularStyles.height === 'auto' || !granularStyles.height ? '100%' : granularStyles.height;\r\n\r\n // Calculate opacity safely\r\n const opacityValue = typeof appliedStyles.opacity === 'number' \r\n ? appliedStyles.opacity / 100 \r\n : 1;\r\n\r\n // Base styles - Box component acts as a generic container\r\n const baseStyles: React.CSSProperties = {\r\n width: width,\r\n height: height,\r\n paddingTop: appliedStyles.paddingTop || '16px',\r\n paddingBottom: appliedStyles.paddingBottom || '16px',\r\n paddingLeft: appliedStyles.paddingLeft || '16px',\r\n paddingRight: appliedStyles.paddingRight || '16px',\r\n marginTop: appliedStyles.marginTop || 0,\r\n marginBottom: appliedStyles.marginBottom || 0,\r\n borderTopWidth: appliedStyles.borderTopWidth || '1px',\r\n borderRightWidth: appliedStyles.borderRightWidth || '1px',\r\n borderBottomWidth: appliedStyles.borderBottomWidth || '1px',\r\n borderLeftWidth: appliedStyles.borderLeftWidth || '1px',\r\n borderStyle: 'dashed',\r\n borderColor: appliedStyles.borderColor && appliedStyles.borderColor !== 'transparent' \r\n ? appliedStyles.borderColor \r\n : '#3b82f6',\r\n borderRadius: appliedStyles.borderRadius || `${globalConfig.baseRadius || 8}px`,\r\n opacity: opacityValue,\r\n boxShadow: appliedStyles.boxShadow || 'none',\r\n backgroundColor: 'rgba(59, 130, 246, 0.1)',\r\n display: 'flex',\r\n alignItems: 'flex-start',\r\n justifyContent: 'center',\r\n color: '#3b82f6',\r\n fontWeight: 500\r\n };\r\n\r\n return (\r\n <div style={baseStyles}>\r\n <div className=\"text-center w-full h-full flex items-start justify-center pt-4\">\r\n <div>\r\n {componentProps.text ? (\r\n <div className=\"text-sm text-gray-700 dark:text-gray-300\">\r\n {componentProps.text}\r\n </div>\r\n ) : (\r\n <>\r\n <div className=\"text-sm font-medium text-gray-700 dark:text-gray-300 mb-1\">\r\n Box Component\r\n </div>\r\n <div className=\"text-xs text-gray-500 dark:text-gray-400\">\r\n {width} × {height}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronRight, Home } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface BreadcrumbsProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Breadcrumbs: React.FC<BreadcrumbsProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const items = ['Home', 'Catalog', 'Accessories', 'Belts'];\r\n\r\n return (\r\n <nav style={appliedStyles} className=\"w-full flex items-center text-sm flex-wrap gap-x-2\">\r\n {items.map((item, i) => {\r\n const isLast = i === items.length - 1;\r\n return (\r\n <div key={item} className=\"flex items-center\">\r\n {i === 0 && designSystem === 'MUI' ? (\r\n <Home size={16} className=\"mr-2 text-gray-500\" />\r\n ) : null}\r\n\r\n <span className={`\r\n ${isLast ? 'font-medium' : 'cursor-pointer hover:underline'}\r\n ${designSystem === 'MUI' ? (isLast ? `${getColorShade(globalConfig, 'text', 900)} dark:${getColorShade(globalConfig, 'text', 100)}` : 'text-gray-500') : ''}\r\n ${designSystem === 'Apple' ? (isLast ? 'text-gray-900 dark:text-white' : `${getColorShade(globalConfig, 'text', 500)}`) : ''}\r\n ${designSystem === 'Custom' ? (isLast ? `${getColorShade(globalConfig, 'text', 900)} dark:${getColorShade(globalConfig, 'text', 100)}` : 'text-gray-500 hover:text-gray-900') : ''}\r\n `}>\r\n {item}\r\n </span>\r\n\r\n {!isLast && (\r\n <span className=\"mx-2 text-gray-400\">\r\n {designSystem === 'MUI' ? '/' : <ChevronRight size={14} />}\r\n </span>\r\n )}\r\n </div>\r\n );\r\n })}\r\n </nav>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getRadiusClass, getComponentVariantClasses } from '../utils/styleUtils';\r\n\r\ninterface CardProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Card: React.FC<CardProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Treat card as a 'surface' for variant generation (e.g. outline card, soft card)\r\n // We override variant to 'secondary' if it's default to get a nice border/bg, or use the prop if set to outline/soft\r\n const effectiveVariant = componentProps.variant === 'primary' ? 'secondary' : componentProps.variant;\r\n const variantClasses = getComponentVariantClasses(designSystem, { ...componentProps, variant: effectiveVariant }, globalConfig, 'surface');\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n w-full h-full min-h-[200px] overflow-hidden transition-all flex flex-col\r\n ${variantClasses}\r\n ${!componentProps.variant || componentProps.variant === 'primary' ? 'bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 shadow-sm' : ''}\r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <div className=\"p-6 space-y-4 animate-pulse flex-1 flex flex-col justify-center\">\r\n <div className=\"h-6 bg-gray-200 dark:bg-gray-800 rounded w-3/4\"></div>\r\n <div className=\"h-4 bg-gray-200 dark:bg-gray-800 rounded w-full\"></div>\r\n <div className=\"h-4 bg-gray-200 dark:bg-gray-800 rounded w-5/6\"></div>\r\n </div>\r\n ) : (\r\n <div className=\"p-6 flex-1 flex flex-col justify-between min-h-0\">\r\n <div className=\"flex-1 min-h-0 flex flex-col\">\r\n <h3 className=\"text-xl font-semibold mb-2 flex-shrink-0\">{componentProps.text || 'Card Title'}</h3>\r\n <p className=\"text-sm opacity-80 leading-relaxed flex-1 min-h-0 overflow-y-auto\">\r\n This card now responds to global states like hover elevation, focus rings, and active scaling if those states are toggled in the inspector.\r\n </p>\r\n </div>\r\n <div className=\"mt-6 flex gap-4 flex-shrink-0\">\r\n <button className=\"text-sm font-bold hover:underline\">Action</button>\r\n <button className=\"text-sm font-medium opacity-60 hover:opacity-100\">Cancel</button>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { X, User } from 'lucide-react';\r\nimport { getAppliedStyles, getComponentVariantClasses, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface ChipProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Chip: React.FC<ChipProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [isVisible, setIsVisible] = useState(true);\r\n\r\n if (!isVisible) return null;\r\n\r\n // Chips usually map variants slightly differently, but we can reuse the engine for consistent state classes\r\n // If variant is 'primary', it's filled. If 'secondary', it's outlined/gray.\r\n const variantClasses = getComponentVariantClasses(designSystem, componentProps, globalConfig, 'button');\r\n\r\n return (\r\n <div className=\"flex gap-2 items-center\">\r\n <div\r\n style={appliedStyles}\r\n className={`\r\n inline-flex items-center gap-2 transition-all cursor-default select-none\r\n ${componentProps.size === 'SM' ? 'px-2 py-0.5 text-xs' : componentProps.size === 'LG' ? 'px-4 py-1.5 text-base' : 'px-3 py-1 text-sm'}\r\n ${designSystem === 'MUI' ? 'rounded-full uppercase tracking-wider text-[10px]' : getRadiusClass(globalConfig)}\r\n ${variantClasses}\r\n `}\r\n >\r\n {/* Avatar simulation */}\r\n {componentProps.variant === 'soft' && (\r\n <div className={`\r\n rounded-full flex items-center justify-center overflow-hidden bg-white/20 text-current\r\n ${componentProps.size === 'SM' ? 'w-4 h-4 -ml-1 text-[8px]' : componentProps.size === 'LG' ? 'w-6 h-6 -ml-1.5' : 'w-5 h-5 -ml-1 text-[10px]'}\r\n `}>\r\n <User size={componentProps.size === 'SM' ? 10 : 14} />\r\n </div>\r\n )}\r\n \r\n <span className=\"font-medium\">{componentProps.text || 'Chip Label'}</span>\r\n \r\n {!componentProps.isDisabled && (\r\n <button \r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setIsVisible(false);\r\n }}\r\n className={`\r\n rounded-full p-0.5 hover:bg-black/10 dark:hover:bg-white/20 transition-colors\r\n ${componentProps.size === 'SM' ? 'w-3 h-3' : 'w-4 h-4'} flex items-center justify-center\r\n -mr-0.5\r\n `}\r\n >\r\n <X size={componentProps.size === 'SM' ? 10 : 12} />\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface ContainerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\n// MUI Container maxWidth breakpoints (in pixels)\r\nconst MAX_WIDTH_MAP: Record<string, string> = {\r\n 'xs': '444px', // ~444px\r\n 'sm': '600px', // 600px\r\n 'md': '900px', // 900px\r\n 'lg': '1200px', // 1200px\r\n 'xl': '1536px', // 1536px\r\n '2xl': '1536px', // 1536px\r\n};\r\n\r\nexport const Container: React.FC<ContainerProps> = ({ \r\n designSystem, \r\n componentProps, \r\n globalConfig, \r\n granularStyles \r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Determine maxWidth based on componentProps.size\r\n // XS = xs, SM = sm, MD = md, LG = lg, XL = xl\r\n const sizeToMaxWidth: Record<string, string> = {\r\n 'XS': 'xs',\r\n 'SM': 'sm',\r\n 'MD': 'md',\r\n 'LG': 'lg',\r\n 'XL': 'xl',\r\n };\r\n \r\n const maxWidthKey = sizeToMaxWidth[componentProps.size] || 'md';\r\n const maxWidth = MAX_WIDTH_MAP[maxWidthKey] || MAX_WIDTH_MAP['md'];\r\n \r\n // Container styles - centers content horizontally with max-width constraint\r\n const containerStyles: React.CSSProperties = {\r\n maxWidth: maxWidth,\r\n marginLeft: 'auto',\r\n marginRight: 'auto',\r\n paddingLeft: appliedStyles.paddingLeft || '16px',\r\n paddingRight: appliedStyles.paddingRight || '16px',\r\n paddingTop: appliedStyles.paddingTop || '16px',\r\n paddingBottom: appliedStyles.paddingBottom || '16px',\r\n marginTop: appliedStyles.marginTop || 0,\r\n marginBottom: appliedStyles.marginBottom || 0,\r\n borderRadius: appliedStyles.borderRadius || `${globalConfig.baseRadius || 8}px`,\r\n opacity: typeof appliedStyles.opacity === 'number' ? appliedStyles.opacity / 100 : 1,\r\n boxShadow: appliedStyles.boxShadow || 'none',\r\n backgroundColor: 'rgba(59, 130, 246, 0.05)',\r\n border: '1px dashed rgba(59, 130, 246, 0.3)',\r\n };\r\n\r\n return (\r\n <div className=\"w-full h-full bg-gray-100 dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-lg relative overflow-hidden flex flex-col\">\r\n <div className=\"absolute inset-x-0 top-0 h-4 bg-gray-200/50 dark:bg-gray-800/50 flex items-center justify-center text-[10px] text-gray-500 z-10 flex-shrink-0\">Viewport</div>\r\n \r\n <div className=\"flex-1 min-h-0 p-4 pt-6 flex items-start justify-center\">\r\n <div style={containerStyles} className=\"w-full flex items-start justify-center\">\r\n <div className=\"text-center w-full\">\r\n <div className=\"px-4 py-3 bg-white dark:bg-gray-800 rounded border border-gray-200 dark:border-gray-700 inline-block\">\r\n <div className=\"text-sm font-medium text-gray-700 dark:text-gray-300\">\r\n {componentProps.text || 'Centered Content'}\r\n </div>\r\n <div className=\"text-xs text-gray-500 dark:text-gray-400 mt-1 font-mono\">\r\n max-width: {maxWidth}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\ninterface DividerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Divider: React.FC<DividerProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n const isVertical = componentProps.orientation === 'vertical';\r\n const hasText = !isVertical && componentProps.text && componentProps.text.length > 0;\r\n \r\n // Line Styles\r\n const isSolid = componentProps.variant === 'primary';\r\n const isDashed = componentProps.variant === 'secondary';\r\n const isDotted = componentProps.variant === 'ghost';\r\n \r\n const borderStyle = isDashed ? 'dashed' : isDotted ? 'dotted' : 'solid';\r\n \r\n const getThickness = () => {\r\n switch(componentProps.size) {\r\n case 'SM': return '1px';\r\n case 'MD': return '2px';\r\n case 'LG': return '4px';\r\n case 'XL': return '8px';\r\n default: return '1px';\r\n }\r\n };\r\n\r\n const thickness = getThickness();\r\n \r\n // Container Sizing for Demo\r\n const containerStyle = isVertical \r\n ? { height: '200px', display: 'flex', alignItems: 'center', justifyContent: 'center' } \r\n : { width: '100%', display: 'flex', alignItems: 'center' };\r\n\r\n // Alignment Logic for Text\r\n const textAlign = componentProps.textAlign;\r\n\r\n return (\r\n <div style={containerStyle} className=\"relative\">\r\n {/* The Component Wrapper / Preview Context */}\r\n \r\n {hasText ? (\r\n <div className=\"flex items-center w-full\" style={appliedStyles}>\r\n <div \r\n className={`flex-1 ${textAlign === 'left' ? 'flex-grow-0 w-8 mr-4' : ''} ${textAlign === 'right' ? 'flex-grow' : ''}`}\r\n style={{ \r\n borderTopWidth: thickness, \r\n borderTopStyle: borderStyle,\r\n borderColor: designSystem === 'MUI' ? '#e0e0e0' : designSystem === 'Apple' ? 'rgba(0,0,0,0.1)' : 'currentColor',\r\n opacity: designSystem === 'Apple' ? 0.5 : 1\r\n }} \r\n />\r\n \r\n <span className={`\r\n px-3 text-sm font-medium text-gray-500 dark:text-gray-400 whitespace-nowrap\r\n ${designSystem === 'MUI' ? 'uppercase tracking-wider text-xs' : ''}\r\n ${designSystem === 'Apple' ? 'text-gray-400 font-normal' : ''}\r\n `}>\r\n {componentProps.text}\r\n </span>\r\n\r\n <div \r\n className={`flex-1 ${textAlign === 'right' ? 'flex-grow-0 w-8 ml-4' : ''} ${textAlign === 'left' ? 'flex-grow' : ''}`}\r\n style={{ \r\n borderTopWidth: thickness, \r\n borderTopStyle: borderStyle,\r\n borderColor: designSystem === 'MUI' ? '#e0e0e0' : designSystem === 'Apple' ? 'rgba(0,0,0,0.1)' : 'currentColor',\r\n opacity: designSystem === 'Apple' ? 0.5 : 1\r\n }} \r\n />\r\n </div>\r\n ) : (\r\n <div \r\n style={{\r\n ...appliedStyles,\r\n width: isVertical ? thickness : '100%',\r\n height: isVertical ? '100%' : thickness,\r\n backgroundColor: isSolid ? (designSystem === 'Custom' ? getColorClass(globalConfig, 'bg').split(' ')[0].replace('bg-', 'text-').replace('text-', '') : 'currentColor') : 'transparent',\r\n borderTopWidth: !isVertical && !isSolid ? thickness : 0,\r\n borderLeftWidth: isVertical && !isSolid ? thickness : 0,\r\n borderStyle: borderStyle,\r\n borderColor: 'currentColor',\r\n color: designSystem === 'MUI' ? '#e5e7eb' : designSystem === 'Apple' ? 'rgba(0,0,0,0.1)' : 'gray',\r\n opacity: designSystem === 'Apple' ? 0.8 : 1\r\n }}\r\n className={`\r\n ${designSystem === 'Custom' && isSolid ? `bg-gray-200 dark:bg-gray-700` : ''}\r\n `}\r\n />\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getComponentVariantClasses } from '../utils/styleUtils';\r\n\r\ninterface LinkProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Link: React.FC<LinkProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Default to 'link' variant if none specified, but allow buttons to look like links via variants\r\n const effectiveVariant = componentProps.variant === 'primary' ? 'link' : componentProps.variant;\r\n const variantClasses = getComponentVariantClasses(designSystem, { ...componentProps, variant: effectiveVariant }, globalConfig, 'button');\r\n\r\n return (\r\n <a \r\n href=\"#\" \r\n onClick={(e) => e.preventDefault()}\r\n style={appliedStyles}\r\n className={`\r\n font-medium transition-all inline-flex items-center gap-1\r\n ${variantClasses}\r\n ${componentProps.isHovered ? 'underline' : ''}\r\n `}\r\n >\r\n {componentProps.text || 'Learn more about this feature'}\r\n </a>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronRight } from 'lucide-react';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface ListProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const List: React.FC<ListProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full max-w-sm bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-lg overflow-hidden\">\r\n {[1, 2, 3].map((i) => (\r\n <div key={i} className=\"flex items-center gap-3 p-3 border-b border-gray-100 dark:border-gray-800 last:border-0 hover:bg-gray-50 dark:hover:bg-gray-800 cursor-pointer\">\r\n <div className=\"w-8 h-8 rounded-full bg-gray-200 dark:bg-gray-700 flex items-center justify-center text-xs font-bold text-gray-500\">\r\n {i}\r\n </div>\r\n <div className=\"flex-1\">\r\n <div className=\"text-sm font-medium text-gray-900 dark:text-white\">List Item {i}</div>\r\n <div className=\"text-xs text-gray-500\">Supporting text here</div>\r\n </div>\r\n <ChevronRight size={16} className=\"text-gray-400\"/>\r\n </div>\r\n ))}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface PaperProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Paper: React.FC<PaperProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const getElevation = () => {\r\n switch(componentProps.size) {\r\n case 'SM': return 'shadow-sm';\r\n case 'MD': return 'shadow-md';\r\n case 'LG': return 'shadow-lg';\r\n case 'XL': return 'shadow-2xl';\r\n default: return 'shadow';\r\n }\r\n };\r\n\r\n const isOutlined = componentProps.variant === 'secondary';\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n w-full h-full min-h-[200px] flex items-center justify-center p-6 text-center\r\n ${designSystem === 'MUI' ? `bg-white dark:bg-gray-800 rounded-sm ${isOutlined ? 'border border-gray-200' : getElevation()}` : ''}\r\n \r\n ${designSystem === 'Apple' ? `bg-white/60 dark:bg-gray-800/60 backdrop-blur-xl rounded-2xl border border-white/20 shadow-sm` : ''}\r\n\r\n ${designSystem === 'Custom' ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)} ${getElevation()}` : ''}\r\n `}\r\n >\r\n <p className=\"text-gray-500 dark:text-gray-400 text-sm\">\r\n Paper Surface\r\n <br/>\r\n <span className=\"text-xs opacity-70\">Elevation: {componentProps.size}</span>\r\n </p>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface SkeletonProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Skeleton: React.FC<SkeletonProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const baseClass = `\r\n animate-pulse bg-gray-200 dark:bg-gray-800\r\n ${designSystem === 'MUI' ? 'rounded-sm' : ''}\r\n ${designSystem === 'Apple' ? 'rounded-lg' : ''}\r\n ${designSystem === 'Custom' ? getRadiusClass(globalConfig) : ''}\r\n `;\r\n\r\n return (\r\n <div className=\"w-full max-w-sm p-4 space-y-4 border border-dashed border-gray-200 dark:border-gray-800 rounded-xl\" style={appliedStyles}>\r\n {/* Header Skeleton */}\r\n <div className=\"flex items-center gap-4\">\r\n <div className={`w-12 h-12 rounded-full ${baseClass}`} />\r\n <div className=\"space-y-2 flex-1\">\r\n <div className={`h-4 w-3/4 ${baseClass}`} />\r\n <div className={`h-3 w-1/2 ${baseClass}`} />\r\n </div>\r\n </div>\r\n\r\n {/* Content Skeleton */}\r\n <div className=\"space-y-2\">\r\n <div className={`h-32 w-full ${baseClass}`} />\r\n <div className={`h-4 w-full ${baseClass}`} />\r\n <div className={`h-4 w-5/6 ${baseClass}`} />\r\n <div className={`h-4 w-4/6 ${baseClass}`} />\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface StackProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Stack: React.FC<StackProps> = ({ \r\n designSystem, \r\n componentProps, \r\n globalConfig, \r\n granularStyles \r\n}) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Determine direction (row or column)\r\n const isVertical = componentProps.orientation === 'vertical';\r\n const direction = isVertical ? 'column' : 'row';\r\n \r\n // Determine spacing based on componentProps.size (MUI Stack spacing prop)\r\n // MUI uses theme.spacing() which multiplies by 8px by default\r\n const spacingMap: Record<string, number> = {\r\n 'SM': 1, // 8px\r\n 'MD': 2, // 16px\r\n 'LG': 4, // 32px\r\n 'XL': 6, // 48px\r\n };\r\n \r\n const spacing = spacingMap[componentProps.size] || 2;\r\n const spacingPx = spacing * 8; // MUI spacing: 1 = 8px, 2 = 16px, etc.\r\n \r\n // Stack styles - flexbox container\r\n const stackStyles: React.CSSProperties = {\r\n display: 'flex',\r\n flexDirection: direction as 'row' | 'column',\r\n gap: `${spacingPx}px`, // Use CSS gap for spacing\r\n paddingTop: appliedStyles.paddingTop || '16px',\r\n paddingBottom: appliedStyles.paddingBottom || '16px',\r\n paddingLeft: appliedStyles.paddingLeft || '16px',\r\n paddingRight: appliedStyles.paddingRight || '16px',\r\n marginTop: appliedStyles.marginTop || 0,\r\n marginBottom: appliedStyles.marginBottom || 0,\r\n borderRadius: appliedStyles.borderRadius || `${globalConfig.baseRadius || 8}px`,\r\n opacity: typeof appliedStyles.opacity === 'number' ? appliedStyles.opacity / 100 : 1,\r\n boxShadow: appliedStyles.boxShadow || 'none',\r\n height: '100%',\r\n backgroundColor: 'transparent',\r\n alignItems: 'flex-start',\r\n justifyContent: 'flex-start',\r\n width: '100%',\r\n };\r\n\r\n // Demo items to show stack behavior - styled like MUI Item component\r\n const items = [1, 2, 3];\r\n\r\n return (\r\n <div style={stackStyles}>\r\n {items.map((item) => (\r\n <div\r\n key={item}\r\n className=\"px-4 py-3 bg-white dark:bg-gray-800 rounded-lg border border-gray-200 dark:border-gray-700 text-gray-700 dark:text-gray-300 text-sm font-medium text-center shadow-md hover:shadow-lg transition-shadow\"\r\n style={{ \r\n minWidth: isVertical ? '100%' : '80px',\r\n width: isVertical ? '100%' : 'auto'\r\n }}\r\n >\r\n Item {item}\r\n </div>\r\n ))}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface TooltipProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Tooltip: React.FC<TooltipProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isVisible, setIsVisible] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const placement = 'top'; // Could be made dynamic prop\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div className=\"relative inline-block\" style={appliedStyles}>\r\n <button\r\n onMouseEnter={() => setIsVisible(true)}\r\n onMouseLeave={() => setIsVisible(false)}\r\n disabled={componentProps.isDisabled}\r\n className={`\r\n px-4 py-2 rounded-md font-medium transition-colors border\r\n ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\r\n bg-white dark:bg-gray-900 border-gray-300 dark:border-gray-700 hover:bg-gray-50 dark:hover:bg-gray-800\r\n `}\r\n >\r\n Hover Me\r\n </button>\r\n\r\n <div className={`\r\n absolute z-50 whitespace-nowrap transition-all duration-200 pointer-events-none\r\n left-1/2 -translate-x-1/2\r\n ${isVisible ? 'opacity-100 translate-y-0' : 'opacity-0 translate-y-2'}\r\n ${placement === 'top' ? 'bottom-full mb-2' : 'top-full mt-2'}\r\n \r\n ${isMUI ? 'bg-gray-700 text-white text-[10px] rounded px-2 py-1 shadow-sm opacity-90' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 backdrop-blur-md text-gray-900 dark:text-white text-xs px-3 py-1.5 rounded-lg shadow-lg border border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? `bg-gray-900 dark:bg-white text-white dark:text-black text-xs px-3 py-1.5 shadow-md ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {componentProps.text || 'Tooltip Text'}\r\n {/* Arrow for Apple/Custom */}\r\n {(isApple || isCustom) && (\r\n <div className={`\r\n absolute left-1/2 -translate-x-1/2 w-2 h-2 rotate-45\r\n ${placement === 'top' ? 'top-full -mt-1' : 'bottom-full -mb-1'}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 border-r border-b border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? 'bg-gray-900 dark:bg-white' : ''}\r\n `} />\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronDown } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface AutocompleteProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Autocomplete: React.FC<AutocompleteProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div className=\"w-full max-w-sm relative\">\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n flex items-center justify-between px-3 py-2 bg-white dark:bg-gray-900 border rounded-md cursor-text\r\n ${componentProps.isError ? getColorShade(globalConfig, 'border', 600) : 'border-gray-300 dark:border-gray-700'}\r\n ${designSystem === 'MUI' ? 'shadow-sm' : ''}\r\n `}\r\n >\r\n <span className=\"text-gray-500 dark:text-gray-400 text-sm\">Select Option...</span>\r\n <ChevronDown size={16} className=\"text-gray-400\" />\r\n </div>\r\n {/* Dropdown simulation */}\r\n <div className=\"absolute top-full left-0 right-0 mt-1 bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-md shadow-lg z-10 overflow-hidden\">\r\n {['Option 1', 'Option 2', 'Option 3'].map((opt, i) => (\r\n <div key={i} className=\"px-3 py-2 text-sm text-gray-700 dark:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800 cursor-pointer\">\r\n {opt}\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Check, Minus } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface CheckboxProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Checkbox: React.FC<CheckboxProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [internalChecked, setInternalChecked] = useState(componentProps.isChecked);\r\n \r\n useEffect(() => setInternalChecked(componentProps.isChecked), [componentProps.isChecked]);\r\n\r\n return (\r\n <label className={`flex items-center gap-3 cursor-pointer ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}`}>\r\n <div \r\n style={appliedStyles}\r\n onClick={() => !componentProps.isDisabled && setInternalChecked(!internalChecked)}\r\n className={`\r\n flex items-center justify-center transition-all duration-200\r\n ${componentProps.size === 'SM' ? 'w-4 h-4' : componentProps.size === 'LG' ? 'w-6 h-6' : 'w-5 h-5'}\r\n ${designSystem === 'MUI' ? 'rounded-[2px]' : 'rounded-md'}\r\n ${\r\n internalChecked || componentProps.isIndeterminate \r\n ? (designSystem === 'Apple' ? `${getColorShade(globalConfig, 'bg', 500)} ${getColorShade(globalConfig, 'border', 500)}` : `${getColorClass(globalConfig, 'bg')} border-transparent`) \r\n : `bg-transparent border-2 ${componentProps.isError ? getColorShade(globalConfig, 'border', 600) : 'border-gray-400 dark:border-gray-600'}`\r\n }\r\n ${designSystem === 'MUI' && !internalChecked ? 'hover:bg-gray-100 rounded-full p-2 -m-2' : ''} \r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <Loader2 size={12} className=\"animate-spin text-current\" />\r\n ) : componentProps.isIndeterminate ? (\r\n <Minus size={14} className=\"text-white\" strokeWidth={3} />\r\n ) : internalChecked && (\r\n <Check size={14} className=\"text-white\" strokeWidth={3} />\r\n )}\r\n </div>\r\n <span className={`text-gray-700 dark:text-gray-200 ${componentProps.size === 'SM' ? 'text-xs' : componentProps.size === 'LG' ? 'text-lg' : 'text-sm'}`}>\r\n {componentProps.text || 'Accept terms and conditions'}\r\n </span>\r\n </label>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface ColorPickerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const ColorPicker: React.FC<ColorPickerProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [hue, setHue] = useState(200);\r\n const [color, setColor] = useState('#3b82f6');\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"flex flex-col gap-4\">\r\n {/* Input Trigger */}\r\n <div className=\"flex items-center gap-2\">\r\n <div className={`w-10 h-10 rounded-md shadow-sm border border-gray-200`} style={{ backgroundColor: color }} />\r\n <input \r\n type=\"text\" \r\n value={color} \r\n className=\"border border-gray-300 dark:border-gray-700 rounded-md px-3 py-2 text-sm w-32 bg-transparent\"\r\n readOnly\r\n />\r\n </div>\r\n\r\n {/* Popover Content */}\r\n <div className={`\r\n p-3 w-64\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-xl rounded-sm' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 backdrop-blur-xl shadow-2xl rounded-xl border border-gray-200/50' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 shadow-lg ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {/* Saturation Area */}\r\n <div \r\n className=\"w-full h-32 rounded mb-3 relative\"\r\n style={{ \r\n background: `linear-gradient(to top, black, transparent), linear-gradient(to right, white, hsl(${hue}, 100%, 50%))` \r\n }}\r\n >\r\n <div className=\"absolute top-1/3 left-1/2 w-3 h-3 border-2 border-white rounded-full shadow-sm -ml-1.5 -mt-1.5\"></div>\r\n </div>\r\n\r\n {/* Hue Slider */}\r\n <div className=\"w-full h-3 rounded-full mb-3 relative\" style={{ background: 'linear-gradient(to right, #f00, #ff0, #0f0, #0ff, #00f, #f0f, #f00)' }}>\r\n <input \r\n type=\"range\" \r\n min=\"0\" max=\"360\" \r\n value={hue} \r\n onChange={(e) => setHue(Number(e.target.value))}\r\n className=\"absolute inset-0 w-full opacity-0 cursor-pointer\" \r\n />\r\n <div \r\n className=\"absolute top-0 h-full w-3 bg-white border border-gray-300 rounded-full shadow-sm pointer-events-none\"\r\n style={{ left: `${(hue/360)*100}%`, transform: 'translateX(-50%)' }}\r\n />\r\n </div>\r\n\r\n {/* Actions */}\r\n <div className=\"flex justify-between items-center mt-2\">\r\n <span className=\"text-xs text-gray-500\">HEX</span>\r\n <div className=\"flex gap-2\">\r\n <div className=\"w-4 h-4 rounded bg-red-500 cursor-pointer\" onClick={() => setColor('#ef4444')} />\r\n <div className=\"w-4 h-4 rounded bg-green-500 cursor-pointer\" onClick={() => setColor('#22c55e')} />\r\n <div className=\"w-4 h-4 rounded bg-blue-500 cursor-pointer\" onClick={() => setColor('#3b82f6')} />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Calendar, ChevronLeft, ChevronRight } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface DatePickerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const DatePicker: React.FC<DatePickerProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const [selectedDate, setSelectedDate] = useState<number | null>(15); // Mock selection\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const toggleCalendar = () => setIsOpen(!isOpen);\r\n\r\n const days = Array.from({ length: 30 }, (_, i) => i + 1);\r\n const weekDays = ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa'];\r\n\r\n // Design System Styles\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n const primaryBg = getColorClass(globalConfig, 'bg');\r\n const primaryText = getColorClass(globalConfig, 'text');\r\n\r\n return (\r\n <div className=\"relative w-full max-w-xs overflow-visible\" style={appliedStyles}>\r\n {/* Input Trigger */}\r\n <div \r\n onClick={toggleCalendar}\r\n className={`\r\n flex items-center justify-between cursor-pointer transition-all duration-200 relative z-50\r\n ${isMUI \r\n ? 'border border-gray-400 rounded px-3 py-2 hover:border-black dark:border-gray-600 dark:hover:border-gray-400' \r\n : ''}\r\n ${isApple \r\n ? 'bg-gray-100 dark:bg-gray-800 rounded-lg px-3 py-2 text-blue-600 dark:text-blue-400 font-medium' \r\n : ''}\r\n ${isCustom \r\n ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 px-4 py-2 shadow-sm ${getRadiusClass(globalConfig)}` \r\n : ''}\r\n ${isOpen && isMUI ? 'border-blue-600 ring-1 ring-blue-600' : ''}\r\n ${componentProps.isDisabled ? 'opacity-50 pointer-events-none' : ''}\r\n `}\r\n >\r\n <span className={`${!selectedDate ? 'text-gray-500' : 'text-gray-900 dark:text-white'}`}>\r\n {selectedDate ? `Oct ${selectedDate}, 2023` : 'MM/DD/YYYY'}\r\n </span>\r\n <Calendar size={18} className={`${isMUI ? 'text-gray-500' : isApple ? 'text-blue-500' : 'text-gray-400'}`} />\r\n </div>\r\n\r\n {/* Calendar Popover */}\r\n {isOpen && (\r\n <>\r\n {/* Backdrop */}\r\n <div \r\n className=\"absolute inset-0 bg-black/40 z-40\"\r\n onClick={() => setIsOpen(false)}\r\n />\r\n \r\n {/* Calendar */}\r\n <div \r\n className={`\r\n absolute top-full left-0 mt-1 z-50 p-3 w-full max-w-[320px] sm:min-w-[280px]\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-xl rounded-md animate-in fade-in zoom-in-95 duration-100' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 backdrop-blur-xl shadow-2xl rounded-2xl border border-white/20' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 shadow-lg ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n onClick={(e) => e.stopPropagation()}\r\n >\r\n {/* Header */}\r\n <div className=\"flex items-center justify-between mb-3\">\r\n <span className=\"font-semibold text-gray-900 dark:text-white text-sm\">October 2023</span>\r\n <div className=\"flex gap-1\">\r\n <button className=\"p-1 hover:bg-gray-100 dark:hover:bg-gray-700 rounded-full\"><ChevronLeft size={16}/></button>\r\n <button className=\"p-1 hover:bg-gray-100 dark:hover:bg-gray-700 rounded-full\"><ChevronRight size={16}/></button>\r\n </div>\r\n </div>\r\n\r\n {/* Week Days */}\r\n <div className=\"grid grid-cols-7 gap-1 mb-2 text-center\">\r\n {weekDays.map(d => (\r\n <span key={d} className=\"text-[10px] font-medium text-gray-500 uppercase\">{d}</span>\r\n ))}\r\n </div>\r\n\r\n {/* Days Grid */}\r\n <div className=\"grid grid-cols-7 gap-1\">\r\n {/* Empty slots for start of month */}\r\n <div /> <div /> \r\n {days.map(day => {\r\n const isSelected = selectedDate === day;\r\n return (\r\n <button\r\n key={day}\r\n onClick={() => { setSelectedDate(day); setIsOpen(false); }}\r\n className={`\r\n h-7 w-7 text-xs rounded-full flex items-center justify-center transition-colors\r\n ${isSelected \r\n ? (isMUI \r\n ? 'bg-blue-600 text-white hover:bg-blue-700' \r\n : isApple \r\n ? 'bg-blue-500 text-white' \r\n : `${primaryBg} text-white`) \r\n : 'text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700'}\r\n `}\r\n >\r\n {day}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n \r\n {isMUI && (\r\n <div className=\"mt-3 flex justify-end gap-2\">\r\n <button className=\"text-xs font-bold text-blue-600 uppercase px-2 py-1 hover:bg-blue-50 rounded\" onClick={() => setIsOpen(false)}>Cancel</button>\r\n <button className=\"text-xs font-bold text-blue-600 uppercase px-2 py-1 hover:bg-blue-50 rounded\" onClick={() => setIsOpen(false)}>OK</button>\r\n </div>\r\n )}\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Plus, Minus } from 'lucide-react';\r\nimport { getAppliedStyles, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface NumberFieldProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const NumberField: React.FC<NumberFieldProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [value, setValue] = useState<number>(0);\r\n const min = 0;\r\n const max = 100;\r\n \r\n const handleIncrement = () => {\r\n if (value < max) setValue(v => v + 1);\r\n };\r\n const handleDecrement = () => {\r\n if (value > min) setValue(v => v - 1);\r\n };\r\n\r\n const isGrouped = componentProps.variant === 'secondary';\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n flex items-center transition-all\r\n ${designSystem === 'Apple' ? (isGrouped ? 'gap-0 bg-white dark:bg-gray-800 rounded-lg shadow-sm border border-gray-200 dark:border-gray-700 p-0.5' : 'gap-4') : ''}\r\n ${designSystem === 'MUI' ? 'relative' : ''}\r\n ${componentProps.isDisabled ? 'opacity-50 pointer-events-none' : ''}\r\n `}>\r\n {designSystem === 'Apple' && !isGrouped && (\r\n <button onClick={handleDecrement} className={`w-8 h-8 rounded-full bg-white dark:bg-gray-800 shadow-sm border border-gray-200 dark:border-gray-700 flex items-center justify-center ${getColorShade(globalConfig, 'text', 600)} active:scale-95 transition-transform`}><Minus size={16}/></button>\r\n )}\r\n \r\n <div className={`\r\n flex items-center\r\n ${designSystem === 'MUI' ? `border border-gray-300 dark:border-gray-600 hover:border-black dark:hover:border-white rounded px-2 bg-white dark:bg-gray-900 focus-within:ring-2 focus-within:${getColorShade(globalConfig, 'ring', 500)} focus-within:${getColorShade(globalConfig, 'border', 500)}` : ''}\r\n ${designSystem === 'Custom' ? `bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 ${getRadiusClass(globalConfig)} overflow-hidden` : ''}\r\n `}>\r\n {(designSystem === 'MUI' || designSystem === 'Custom' || (designSystem === 'Apple' && isGrouped)) && (\r\n <button onClick={handleDecrement} className={`p-2 text-gray-500 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white transition-colors ${designSystem === 'Apple' && isGrouped ? 'border-r border-gray-200 dark:border-gray-700 px-3' : ''} ${designSystem === 'Custom' ? 'hover:bg-gray-50 dark:hover:bg-gray-700' : ''}`}><Minus size={14}/></button>\r\n )}\r\n \r\n <div className=\"relative\">\r\n {componentProps.isLoading && <div className=\"absolute inset-0 flex items-center justify-center bg-white/80 dark:bg-gray-900/80 z-10\"><Loader2 size={14} className={`animate-spin ${getColorShade(globalConfig, 'text', 600)}`}/></div>}\r\n <input \r\n type=\"text\" \r\n value={value} \r\n readOnly \r\n className={`\r\n w-12 text-center bg-transparent border-none focus:ring-0 p-2 font-mono text-sm\r\n ${designSystem === 'Apple' && !isGrouped ? 'bg-gray-100 dark:bg-gray-800 rounded-md mx-2' : ''}\r\n `}\r\n />\r\n </div>\r\n\r\n {(designSystem === 'MUI' || designSystem === 'Custom' || (designSystem === 'Apple' && isGrouped)) && (\r\n <button onClick={handleIncrement} className={`p-2 text-gray-500 hover:text-gray-900 dark:text-gray-400 dark:hover:text-white transition-colors ${designSystem === 'Apple' && isGrouped ? 'border-l border-gray-200 dark:border-gray-700 px-3' : ''} ${designSystem === 'Custom' ? 'hover:bg-gray-50 dark:hover:bg-gray-700' : ''}`}><Plus size={14}/></button>\r\n )}\r\n </div>\r\n\r\n {designSystem === 'Apple' && !isGrouped && (\r\n <button onClick={handleIncrement} className={`w-8 h-8 rounded-full bg-white dark:bg-gray-800 shadow-sm border border-gray-200 dark:border-gray-700 flex items-center justify-center ${getColorShade(globalConfig, 'text', 600)} active:scale-95 transition-transform`}><Plus size={16}/></button>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface RadioProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Radio: React.FC<RadioProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <label className={`flex items-center gap-3 cursor-pointer ${componentProps.isDisabled ? 'opacity-50' : ''}`}>\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n rounded-full border flex items-center justify-center transition-all\r\n ${componentProps.size === 'SM' ? 'w-4 h-4' : componentProps.size === 'LG' ? 'w-6 h-6' : 'w-5 h-5'}\r\n ${componentProps.isChecked ? getColorShade(globalConfig, 'border', 600) : 'border-gray-400 dark:border-gray-600'}\r\n ${componentProps.isError ? getColorShade(globalConfig, 'border', 600) : ''}\r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <Loader2 size={10} className={`animate-spin ${getColorShade(globalConfig, 'text', 600)}`} />\r\n ) : componentProps.isChecked && (\r\n <div className={`rounded-full ${getColorShade(globalConfig, 'bg', 600)} ${componentProps.size === 'SM' ? 'w-2 h-2' : componentProps.size === 'LG' ? 'w-3 h-3' : 'w-2.5 h-2.5'}`} />\r\n )}\r\n </div>\r\n <span className=\"text-gray-700 dark:text-gray-200 font-medium\">{componentProps.text || 'Radio Option'}</span>\r\n </label>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, ChevronDown } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface SelectProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Select: React.FC<SelectProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div className=\"w-full max-w-sm\">\r\n <label className=\"text-sm font-medium text-gray-700 dark:text-gray-300 mb-1 block\">\r\n {componentProps.text || 'Choose item'}\r\n </label>\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n flex items-center justify-between px-3 py-2 bg-white dark:bg-gray-900 border rounded-md cursor-pointer\r\n ${componentProps.isError ? getColorShade(globalConfig, 'border', 600) : 'border-gray-300 dark:border-gray-700'}\r\n ${designSystem === 'MUI' ? 'border-b-2 border-x-0 border-t-0 rounded-t bg-gray-100 dark:bg-gray-800' : ''}\r\n ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\r\n `}\r\n >\r\n <span className=\"text-gray-900 dark:text-white text-sm\">Selected Value</span>\r\n {componentProps.isLoading ? <Loader2 size={16} className=\"animate-spin text-gray-500\"/> : <ChevronDown size={16} className=\"text-gray-500\" />}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Eraser, PenTool } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface SignatureProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Signature: React.FC<SignatureProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [cleared, setCleared] = useState(false);\r\n\r\n // Mock path for signature\r\n const signaturePath = \"M 50 100 Q 80 50 150 80 T 250 100 T 350 50\";\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col\">\r\n <label className=\"text-sm font-medium mb-2 block text-gray-700 dark:text-gray-300 flex-shrink-0\">Signature</label>\r\n <div className={`\r\n relative flex-1 w-full min-h-0 border-2 border-dashed rounded-lg bg-white dark:bg-gray-900 overflow-hidden\r\n ${designSystem === 'MUI' ? 'border-gray-300 dark:border-gray-700 rounded-sm' : ''}\r\n ${designSystem === 'Apple' ? 'border-gray-200 dark:border-gray-800 rounded-xl' : ''}\r\n ${designSystem === 'Custom' ? `border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {/* Background Lines */}\r\n <div className=\"absolute inset-0 flex flex-col justify-end pb-8 px-8\">\r\n <div className=\"border-b border-gray-200 dark:border-gray-800 w-full\"></div>\r\n </div>\r\n\r\n {/* Signature SVG */}\r\n {!cleared && (\r\n <svg className=\"absolute inset-0 w-full h-full pointer-events-none\" viewBox=\"0 0 400 200\">\r\n <path \r\n d={signaturePath} \r\n fill=\"none\" \r\n stroke=\"currentColor\" \r\n strokeWidth=\"3\" \r\n strokeLinecap=\"round\"\r\n className={`${getColorShade(globalConfig, 'text', 900)} dark:${getColorShade(globalConfig, 'text', 400)}`}\r\n />\r\n </svg>\r\n )}\r\n\r\n {/* Tools */}\r\n <div className=\"absolute top-2 right-2 flex gap-2\">\r\n <button \r\n onClick={() => setCleared(!cleared)} \r\n className=\"p-2 bg-gray-100 dark:bg-gray-800 rounded-full hover:bg-gray-200 dark:hover:bg-gray-700 text-gray-600 dark:text-gray-300\"\r\n title={cleared ? \"Sign\" : \"Clear\"}\r\n >\r\n {cleared ? <PenTool size={16} /> : <Eraser size={16} />}\r\n </button>\r\n </div>\r\n </div>\r\n <p className=\"text-xs text-gray-500 mt-2 flex-shrink-0\">Draw your signature above</p>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Minus, Plus } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\ninterface SliderProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Slider: React.FC<SliderProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [value, setValue] = useState(50);\r\n const trackRef = useRef<HTMLDivElement>(null);\r\n const [isDragging, setIsDragging] = useState(false);\r\n\r\n const handleInteract = (e: React.MouseEvent | MouseEvent) => {\r\n if (componentProps.isDisabled || !trackRef.current) return;\r\n \r\n const rect = trackRef.current.getBoundingClientRect();\r\n const clientX = e.clientX;\r\n \r\n // Calculate percentage\r\n let newValue = ((clientX - rect.left) / rect.width) * 100;\r\n newValue = Math.max(0, Math.min(100, newValue));\r\n \r\n setValue(newValue);\r\n };\r\n\r\n const handleMouseDown = (e: React.MouseEvent) => {\r\n if (componentProps.isDisabled) return;\r\n setIsDragging(true);\r\n handleInteract(e);\r\n };\r\n\r\n useEffect(() => {\r\n const handleGlobalMouseMove = (e: MouseEvent) => {\r\n if (isDragging) handleInteract(e);\r\n };\r\n const handleGlobalMouseUp = () => setIsDragging(false);\r\n\r\n if (isDragging) {\r\n window.addEventListener('mousemove', handleGlobalMouseMove);\r\n window.addEventListener('mouseup', handleGlobalMouseUp);\r\n }\r\n return () => {\r\n window.removeEventListener('mousemove', handleGlobalMouseMove);\r\n window.removeEventListener('mouseup', handleGlobalMouseUp);\r\n };\r\n }, [isDragging]);\r\n\r\n return (\r\n <div className={`w-full max-w-sm flex items-center gap-4 ${componentProps.isDisabled ? 'opacity-50 pointer-events-none' : ''}`}>\r\n <button onClick={() => setValue(Math.max(0, value - 10))} className=\"text-gray-400 hover:text-gray-600 dark:hover:text-gray-200\">\r\n <Minus size={16} />\r\n </button>\r\n \r\n <div \r\n ref={trackRef}\r\n className=\"flex-1 h-1.5 bg-gray-200 dark:bg-gray-700 rounded-full relative cursor-pointer group\" \r\n style={appliedStyles}\r\n onMouseDown={handleMouseDown}\r\n >\r\n {/* Fill Track */}\r\n <div \r\n className={`absolute top-0 left-0 h-full rounded-full ${getColorClass(globalConfig, 'bg')}`}\r\n style={{ width: `${value}%` }}\r\n />\r\n \r\n {/* Thumb */}\r\n <div \r\n className={`\r\n absolute top-1/2 -translate-y-1/2 w-4 h-4 bg-white rounded-full shadow-md border border-gray-200 cursor-grab active:cursor-grabbing transition-transform\r\n ${isDragging ? 'scale-125' : 'group-hover:scale-110'}\r\n ${designSystem === 'MUI' ? 'w-5 h-5 bg-blue-600 border-none' : ''}\r\n `}\r\n style={{ left: `${value}%`, transform: `translate(-50%, -50%) ${isDragging ? 'scale(1.2)' : ''}` }}\r\n />\r\n </div>\r\n \r\n <button onClick={() => setValue(Math.min(100, value + 10))} className=\"text-gray-400 hover:text-gray-600 dark:hover:text-gray-200\">\r\n <Plus size={16} />\r\n </button>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Check, X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface SwitchProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Switch: React.FC<SwitchProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [internalChecked, setInternalChecked] = useState(componentProps.isChecked);\r\n useEffect(() => setInternalChecked(componentProps.isChecked), [componentProps.isChecked]);\r\n \r\n const isOn = internalChecked;\r\n\r\n // Using arbitrary values [px] to ensure exact positioning regardless of tailwind config spacing scale\r\n const getSwitchDimensions = (sz: string) => {\r\n switch(sz) {\r\n case 'SM': return { w: 'w-8', h: 'h-5', thumb: 'w-3 h-3', trans: 'translate-x-[12px]', px: '12px' };\r\n case 'LG': return { w: 'w-14', h: 'h-8', thumb: 'w-6 h-6', trans: 'translate-x-[24px]', px: '24px' };\r\n default: return { w: 'w-11', h: 'h-6', thumb: 'w-4 h-4', trans: 'translate-x-[20px]', px: '20px' };\r\n }\r\n };\r\n\r\n const dims = getSwitchDimensions(componentProps.size);\r\n\r\n return (\r\n <label className=\"flex items-center gap-3 cursor-pointer\">\r\n <div\r\n style={appliedStyles}\r\n onClick={() => !componentProps.isDisabled && setInternalChecked(!isOn)}\r\n className={`\r\n relative inline-flex items-center transition-colors duration-300 ease-in-out flex-shrink-0 cursor-pointer\r\n ${dims.w} ${dims.h}\r\n ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\r\n \r\n ${designSystem === 'MUI' \r\n ? `rounded-full ${isOn ? (getColorClass(globalConfig, 'bg').split(' ')[0] + ' opacity-100') : 'bg-gray-300 dark:bg-gray-600'}`\r\n : ''\r\n }\r\n \r\n ${designSystem === 'Apple'\r\n ? `rounded-full ${isOn ? 'bg-[#34C759]' : 'bg-gray-200 dark:bg-gray-600'} shadow-inner`\r\n : ''\r\n }\r\n\r\n ${designSystem === 'Custom'\r\n ? `rounded-full border-2 ${isOn ? (getColorClass(globalConfig, 'bg').split(' ')[0] + ' border-transparent') : 'bg-transparent border-gray-300 dark:border-gray-600'}`\r\n : ''\r\n }\r\n `}\r\n >\r\n <span\r\n className={`\r\n absolute left-1 inline-block transform rounded-full transition-transform duration-300 shadow-sm flex items-center justify-center\r\n ${dims.thumb}\r\n ${isOn ? dims.trans : 'translate-x-0'}\r\n \r\n ${designSystem === 'MUI' ? `bg-white shadow-md ${isOn ? '' : ''}` : ''}\r\n \r\n ${designSystem === 'Apple' ? 'bg-white shadow-md' : ''}\r\n\r\n ${designSystem === 'Custom' ? `bg-white shadow-sm ${isOn ? '' : 'bg-gray-400'}` : ''}\r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <Loader2 size={12} className={`animate-spin ${isOn ? getColorShade(globalConfig, 'text', 600) : 'text-gray-400'}`} />\r\n ) : (\r\n designSystem === 'Custom' && (\r\n isOn ? <Check size={10} className={getColorShade(globalConfig, 'text', 600)} strokeWidth={3}/> : <X size={10} className=\"text-gray-400\" strokeWidth={3}/>\r\n )\r\n )}\r\n </span>\r\n </div>\r\n <span className={`text-gray-700 dark:text-gray-200 ${componentProps.size === 'SM' ? 'text-xs' : componentProps.size === 'LG' ? 'text-lg' : 'text-sm'}`}>\r\n {componentProps.text || 'Toggle Setting'}\r\n </span>\r\n </label>\r\n );\r\n};\r\n","\r\nimport React, { useState, useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\nimport { Delete, ArrowUp, Globe, Smile } from 'lucide-react';\r\n\r\ninterface TextAreaProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\ntype KeyboardType = 'letters' | 'numbers' | 'emoji';\r\ntype KeyboardStyle = 'ios' | 'android';\r\ntype Language = 'english' | 'urdu' | 'arabic';\r\n\r\nexport const TextArea: React.FC<TextAreaProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [value, setValue] = useState('');\r\n const [isFocused, setIsFocused] = useState(false);\r\n const [keyboardType, setKeyboardType] = useState<KeyboardType>('letters');\r\n const [keyboardStyle, setKeyboardStyle] = useState<KeyboardStyle>('ios');\r\n const [language, setLanguage] = useState<Language>('english');\r\n const [isShift, setIsShift] = useState(false);\r\n const textareaRef = useRef<HTMLTextAreaElement>(null);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n // Keyboard layouts\r\n const englishKeys = [\r\n ['q','w','e','r','t','y','u','i','o','p'],\r\n ['a','s','d','f','g','h','j','k','l'],\r\n ['shift','z','x','c','v','b','n','m','backspace'],\r\n ];\r\n\r\n const urduKeys = [\r\n ['ق','و','ع','ر','ت','ے','ٹ','پ','ا','ل'],\r\n ['ذ','د','ڈ','گ','ھ','ج','ح','ک','خ'],\r\n ['shift','ط','ظ','ز','ر','ب','ن','م','backspace'],\r\n ];\r\n\r\n const arabicKeys = [\r\n ['ض','ص','ث','ق','ف','غ','ع','ه','خ','ح'],\r\n ['ش','س','ي','ب','ل','ا','ت','ن','م'],\r\n ['shift','ك','ط','ئ','ء','ؤ','ر','لا','backspace'],\r\n ];\r\n\r\n const numericKeys = [\r\n ['1','2','3'],\r\n ['4','5','6'],\r\n ['7','8','9'],\r\n ['#+=' ,'0','backspace'],\r\n ];\r\n\r\n const emojiKeys = [\r\n ['😀','😃','😄','😁','😆','😅','😂','🤣','😊','😇'],\r\n ['🙂','🙃','😉','😌','😍','🥰','😘','😗','😙','😚'],\r\n ['😋','😛','😝','😜','🤪','🤨','🧐','🤓','😎','🤩'],\r\n ['🥳','😏','😒','😞','😔','😟','😕','🙁','☹️','😣'],\r\n ];\r\n\r\n const getCurrentKeys = () => {\r\n if (keyboardType === 'numbers') return numericKeys;\r\n if (keyboardType === 'emoji') return emojiKeys;\r\n \r\n switch (language) {\r\n case 'urdu': return urduKeys;\r\n case 'arabic': return arabicKeys;\r\n default: return englishKeys;\r\n }\r\n };\r\n\r\n const keys = getCurrentKeys();\r\n const effectiveStyle = isApple ? 'ios' : keyboardStyle;\r\n\r\n const getKeyStyle = (key: string) => {\r\n const baseStyle = effectiveStyle === 'ios' \r\n ? 'bg-white dark:bg-gray-700 shadow-sm' \r\n : 'bg-gray-100 dark:bg-gray-700 shadow-md';\r\n \r\n const specialKeyStyle = effectiveStyle === 'ios'\r\n ? 'bg-gray-300 dark:bg-gray-600'\r\n : 'bg-gray-200 dark:bg-gray-600';\r\n\r\n if (['shift', 'backspace', '123', '#+='].includes(key)) return specialKeyStyle;\r\n if (key === 'return' || key === 'Go') return 'bg-blue-500 dark:bg-blue-600 text-white';\r\n if (key === 'space') return baseStyle;\r\n return baseStyle;\r\n };\r\n\r\n const handleKeyPress = (key: string) => {\r\n if (!textareaRef.current) return;\r\n \r\n const textarea = textareaRef.current;\r\n const start = textarea.selectionStart;\r\n const end = textarea.selectionEnd;\r\n const text = value;\r\n\r\n if (key === 'backspace') {\r\n if (start === end && start > 0) {\r\n setValue(text.slice(0, start - 1) + text.slice(start));\r\n setTimeout(() => {\r\n textarea.selectionStart = textarea.selectionEnd = start - 1;\r\n }, 0);\r\n } else if (start !== end) {\r\n setValue(text.slice(0, start) + text.slice(end));\r\n setTimeout(() => {\r\n textarea.selectionStart = textarea.selectionEnd = start;\r\n }, 0);\r\n }\r\n } else if (key === 'shift') {\r\n setIsShift(!isShift);\r\n } else if (key === '123') {\r\n setKeyboardType('numbers');\r\n } else if (key === '#+=') {\r\n setKeyboardType('letters');\r\n } else if (key === 'space') {\r\n const newText = text.slice(0, start) + ' ' + text.slice(end);\r\n setValue(newText);\r\n setTimeout(() => {\r\n textarea.selectionStart = textarea.selectionEnd = start + 1;\r\n }, 0);\r\n } else if (key.length === 1) {\r\n const char = isShift && keyboardType === 'letters' ? key.toUpperCase() : key;\r\n const newText = text.slice(0, start) + char + text.slice(end);\r\n setValue(newText);\r\n setTimeout(() => {\r\n textarea.selectionStart = textarea.selectionEnd = start + 1;\r\n }, 0);\r\n }\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col\">\r\n <label className=\"text-sm font-medium text-gray-700 dark:text-gray-300 flex-shrink-0 mb-2\">\r\n {componentProps.text || 'Description'}\r\n </label>\r\n <div className=\"relative flex-1 min-h-0 flex flex-col\">\r\n <textarea \r\n ref={textareaRef}\r\n value={value}\r\n onChange={(e) => setValue(e.target.value)}\r\n onFocus={() => setIsFocused(true)}\r\n onBlur={() => setIsFocused(false)}\r\n className={`\r\n w-full flex-1 p-3 text-sm transition-all focus:outline-none focus:ring-2 resize-none\r\n ${isMUI ? `bg-gray-50 dark:bg-gray-800 border-b-2 border-t-0 border-x-0 border-gray-400 focus:${getColorShade(globalConfig, 'border', 600)} rounded-t-sm focus:ring-0` : ''}\r\n ${isApple ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-xl focus:ring-${globalConfig.primaryColor}-500/50 focus:${getColorShade(globalConfig, 'border', 500)}` : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)} focus:ring-${globalConfig.primaryColor}-500/20 focus:border-${globalConfig.primaryColor}-500` : ''}\r\n ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\r\n `}\r\n placeholder=\"Enter your comments here...\"\r\n disabled={componentProps.isDisabled}\r\n />\r\n <div className=\"absolute bottom-2 right-2 text-xs text-gray-400 pointer-events-none\">\r\n {value.length}/500\r\n </div>\r\n </div>\r\n\r\n {/* On-Screen Keyboard */}\r\n <div className={`\r\n flex-shrink-0 mt-2 border-t border-gray-200 dark:border-gray-700\r\n ${effectiveStyle === 'ios' ? 'bg-gray-200 dark:bg-gray-800' : 'bg-gray-100 dark:bg-gray-900'}\r\n `}>\r\n {/* Keyboard Controls */}\r\n <div className=\"flex items-center justify-between p-2 border-b border-gray-200 dark:border-gray-700\">\r\n <div className=\"flex gap-1\">\r\n <button\r\n onClick={() => setLanguage('english')}\r\n className={`px-2 py-1 text-xs rounded ${language === 'english' ? 'bg-blue-500 text-white' : 'bg-gray-200 dark:bg-gray-700'}`}\r\n >\r\n EN\r\n </button>\r\n <button\r\n onClick={() => setLanguage('urdu')}\r\n className={`px-2 py-1 text-xs rounded ${language === 'urdu' ? 'bg-blue-500 text-white' : 'bg-gray-200 dark:bg-gray-700'}`}\r\n >\r\n اردو\r\n </button>\r\n <button\r\n onClick={() => setLanguage('arabic')}\r\n className={`px-2 py-1 text-xs rounded ${language === 'arabic' ? 'bg-blue-500 text-white' : 'bg-gray-200 dark:bg-gray-700'}`}\r\n >\r\n عربي\r\n </button>\r\n </div>\r\n <div className=\"flex gap-1\">\r\n <button\r\n onClick={() => setKeyboardStyle('ios')}\r\n className={`px-2 py-1 text-xs rounded ${keyboardStyle === 'ios' ? 'bg-blue-500 text-white' : 'bg-gray-200 dark:bg-gray-700'}`}\r\n >\r\n iOS\r\n </button>\r\n <button\r\n onClick={() => setKeyboardStyle('android')}\r\n className={`px-2 py-1 text-xs rounded ${keyboardStyle === 'android' ? 'bg-blue-500 text-white' : 'bg-gray-200 dark:bg-gray-700'}`}\r\n >\r\n Android\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Keyboard Rows */}\r\n <div className=\"p-2 space-y-1\">\r\n {keys.map((row, rowIndex) => (\r\n <div key={rowIndex} className=\"flex gap-1 justify-center\">\r\n {row.map((key, keyIndex) => {\r\n if (key === 'shift') {\r\n return (\r\n <button\r\n key={keyIndex}\r\n onClick={() => handleKeyPress('shift')}\r\n className={`\r\n px-3 py-2 rounded text-xs font-medium transition-colors\r\n ${getKeyStyle(key)} ${isShift ? 'bg-blue-500 text-white' : ''}\r\n `}\r\n >\r\n <ArrowUp size={14} />\r\n </button>\r\n );\r\n }\r\n if (key === 'backspace') {\r\n return (\r\n <button\r\n key={keyIndex}\r\n onClick={() => handleKeyPress('backspace')}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle(key)}`}\r\n >\r\n <Delete size={14} />\r\n </button>\r\n );\r\n }\r\n if (key === '123' || key === '#+=') {\r\n return (\r\n <button\r\n key={keyIndex}\r\n onClick={() => handleKeyPress(key)}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle(key)}`}\r\n >\r\n {key === '123' ? '123' : 'ABC'}\r\n </button>\r\n );\r\n }\r\n return (\r\n <button\r\n key={keyIndex}\r\n onClick={() => handleKeyPress(key)}\r\n className={`\r\n px-2 py-2 rounded text-xs font-medium transition-colors min-w-[32px]\r\n ${getKeyStyle(key)}\r\n ${effectiveStyle === 'ios' ? 'active:bg-gray-300 dark:active:bg-gray-600' : 'active:bg-gray-200 dark:active:bg-gray-600'}\r\n `}\r\n >\r\n {key}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n ))}\r\n \r\n {/* Bottom Row */}\r\n <div className=\"flex gap-1 justify-center\">\r\n {keyboardType === 'letters' && (\r\n <>\r\n <button\r\n onClick={() => setKeyboardType('numbers')}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle('123')}`}\r\n >\r\n 123\r\n </button>\r\n <button\r\n onClick={() => setKeyboardType('emoji')}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle('space')}`}\r\n >\r\n <Smile size={14} />\r\n </button>\r\n </>\r\n )}\r\n {keyboardType === 'numbers' && (\r\n <button\r\n onClick={() => setKeyboardType('letters')}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle('#+=')}`}\r\n >\r\n ABC\r\n </button>\r\n )}\r\n {keyboardType === 'emoji' && (\r\n <button\r\n onClick={() => setKeyboardType('letters')}\r\n className={`px-3 py-2 rounded text-xs font-medium transition-colors ${getKeyStyle('#+=')}`}\r\n >\r\n ABC\r\n </button>\r\n )}\r\n <button\r\n onClick={() => handleKeyPress('space')}\r\n className={`flex-1 max-w-[200px] py-2 rounded text-xs font-medium transition-colors ${getKeyStyle('space')}`}\r\n >\r\n Space\r\n </button>\r\n <button\r\n onClick={() => setIsFocused(false)}\r\n className={`px-4 py-2 rounded text-xs font-medium transition-colors ${effectiveStyle === 'ios' ? 'bg-blue-500 text-white' : 'bg-blue-600 text-white'}`}\r\n >\r\n Done\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Mail, AlertCircle } from 'lucide-react';\r\nimport { getAppliedStyles, getBorderRadius, getComponentVariantClasses, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface TextFieldProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const TextField: React.FC<TextFieldProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [textValue, setTextValue] = useState('');\r\n const [internalFocused, setInternalFocused] = useState(false);\r\n \r\n // Combine internal focus with inspector prop override\r\n const isFocused = internalFocused || componentProps.isFocused;\r\n \r\n // Map variants: 'primary' -> Filled/Soft, 'secondary' -> Outlined, 'ghost' -> Standard (border bottom only)\r\n let effectiveVariant = componentProps.variant;\r\n if (effectiveVariant === 'primary') effectiveVariant = 'soft'; // Filled look\r\n if (effectiveVariant === 'secondary') effectiveVariant = 'outline'; // Standard border\r\n \r\n // Use 'input' base type for special styling in engine\r\n const variantClasses = getComponentVariantClasses(\r\n designSystem, \r\n { ...componentProps, variant: effectiveVariant, isFocused }, \r\n globalConfig, \r\n 'input'\r\n );\r\n\r\n // Get border radius for input (use global baseRadius unless ghost variant)\r\n const inputBorderRadius = componentProps.variant === 'ghost' \r\n ? { borderRadius: '0px' } \r\n : { borderRadius: getBorderRadius(granularStyles, globalConfig) };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"relative group w-full max-w-sm\">\r\n <label className={`block text-sm font-medium mb-1.5 ml-1 ${componentProps.isError ? getColorShade(globalConfig, 'text', 600) : 'text-gray-700 dark:text-gray-300'}`}>\r\n {componentProps.text || 'Email Address'}\r\n </label>\r\n \r\n <div className=\"relative\">\r\n <input \r\n type=\"text\"\r\n value={textValue}\r\n onChange={(e) => setTextValue(e.target.value)}\r\n onFocus={() => setInternalFocused(true)}\r\n onBlur={() => setInternalFocused(false)}\r\n disabled={componentProps.isDisabled}\r\n placeholder=\"name@example.com\"\r\n style={inputBorderRadius}\r\n className={`\r\n w-full px-4 py-3 transition-all outline-none\r\n ${variantClasses}\r\n ${componentProps.variant === 'secondary' || componentProps.variant === 'outline' ? 'bg-transparent border-2' : ''}\r\n ${componentProps.variant === 'ghost' ? 'bg-transparent border-x-0 border-t-0 border-b-2 px-0' : ''}\r\n `}\r\n />\r\n \r\n <div className=\"absolute right-3 top-1/2 -translate-y-1/2 text-gray-400 pointer-events-none\">\r\n {componentProps.isLoading ? (\r\n <Loader2 className={`animate-spin ${getColorShade(globalConfig, 'text', 500)}`} size={18} />\r\n ) : componentProps.isError ? (\r\n <AlertCircle className={getColorShade(globalConfig, 'text', 600)} size={18} />\r\n ) : (\r\n <Mail size={18} />\r\n )}\r\n </div>\r\n </div>\r\n \r\n {componentProps.isError && <p className={`mt-1 text-xs ${getColorShade(globalConfig, 'text', 600)} ml-1`}>Invalid input value.</p>}\r\n {componentProps.variant === 'ghost' && <div className={`h-0.5 w-full ${getColorShade(globalConfig, 'bg', 500)} transform transition-transform ${isFocused ? 'scale-x-100' : 'scale-x-0'}`} />}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { UploadCloud, File, X, CheckCircle2, Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface UploadProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Upload: React.FC<UploadProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [files, setFiles] = useState<{name: string, size: string, status: 'uploading' | 'complete' | 'error', progress: number}[]>([\r\n { name: 'document.pdf', size: '2.4 MB', status: 'complete', progress: 100 },\r\n ]);\r\n\r\n const handleDrop = () => {\r\n // Simulation of a drop\r\n setFiles(prev => [...prev, { name: 'image.png', size: '4.1 MB', status: 'uploading', progress: 0 }]);\r\n setTimeout(() => {\r\n setFiles(prev => prev.map(f => f.status === 'uploading' ? { ...f, progress: 45 } : f));\r\n }, 500);\r\n setTimeout(() => {\r\n setFiles(prev => prev.map(f => f.status === 'uploading' ? { ...f, progress: 100, status: 'complete' } : f));\r\n }, 1500);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col\">\r\n {/* Drop Zone */}\r\n <div \r\n onClick={handleDrop}\r\n className={`\r\n border-2 border-dashed rounded-xl p-16 flex-1 flex flex-col items-center justify-start text-center cursor-pointer transition-colors min-h-0\r\n ${isMUI ? 'border-gray-300 bg-gray-50 hover:bg-gray-100 dark:border-gray-700 dark:bg-gray-800' : ''}\r\n ${isApple ? `${getColorShade(globalConfig, 'border', 200)} ${getColorShade(globalConfig, 'bg', 50)}/50 ${getColorShade(globalConfig, 'bg', 50).replace('bg-', 'hover:bg-')} dark:${getColorShade(globalConfig, 'border', 800)} dark:${getColorShade(globalConfig, 'bg', 900)}/20` : ''}\r\n ${isCustom ? `border-gray-200 ${getColorShade(globalConfig, 'border', 400).replace('border-', 'hover:border-')} bg-white dark:bg-gray-900 ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n <div className={`p-6 rounded-full mb-4 ${isApple ? `bg-white shadow-sm ${getColorShade(globalConfig, 'text', 500)}` : 'bg-gray-200 dark:bg-gray-700 text-gray-500'}`}>\r\n <UploadCloud size={48} />\r\n </div>\r\n <h4 className=\"text-lg font-medium text-gray-900 dark:text-white mb-2\">Click to upload or drag and drop</h4>\r\n <p className=\"text-sm text-gray-500\">SVG, PNG, JPG or GIF (max. 800x400px)</p>\r\n </div>\r\n\r\n {/* File List */}\r\n {files.length > 0 && (\r\n <div className=\"mt-4 space-y-2 flex-shrink-0\">\r\n {files.map((file, i) => (\r\n <div \r\n key={i} \r\n className={`\r\n flex items-center gap-3 p-3 rounded-lg border\r\n ${isMUI ? 'bg-white dark:bg-gray-800 border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 backdrop-blur border-gray-200/50 shadow-sm' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border-gray-100 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n <div className=\"p-2 bg-gray-100 dark:bg-gray-700 rounded text-gray-500\">\r\n <File size={20} />\r\n </div>\r\n <div className=\"flex-1 min-w-0\">\r\n <div className=\"flex justify-between mb-1\">\r\n <span className=\"text-sm font-medium truncate text-gray-900 dark:text-white\">{file.name}</span>\r\n <span className=\"text-xs text-gray-500\">{file.size}</span>\r\n </div>\r\n {/* Progress Bar */}\r\n <div className=\"w-full h-1.5 bg-gray-100 dark:bg-gray-700 rounded-full overflow-hidden\">\r\n <div \r\n className={`h-full transition-all duration-300 ${file.status === 'complete' ? 'bg-green-500' : getColorShade(globalConfig, 'bg', 500)}`} \r\n style={{ width: `${file.progress}%` }} \r\n />\r\n </div>\r\n </div>\r\n <button className=\"text-gray-400 hover:text-red-500\">\r\n {file.status === 'uploading' ? <Loader2 size={18} className={`animate-spin ${getColorShade(globalConfig, 'text', 500)}`} /> : \r\n file.status === 'complete' ? <CheckCircle2 size={18} className=\"text-green-500\" /> : <X size={18} />}\r\n </button>\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useRef } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface VerificationCodeProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const VerificationCode: React.FC<VerificationCodeProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const length = 4;\r\n const [values, setValues] = useState<string[]>(Array(length).fill(''));\r\n const inputs = useRef<(HTMLInputElement | null)[]>([]);\r\n\r\n const handleChange = (index: number, val: string) => {\r\n if (!/^\\d*$/.test(val)) return;\r\n \r\n const newValues = [...values];\r\n newValues[index] = val;\r\n setValues(newValues);\r\n\r\n // Auto-focus next\r\n if (val && index < length - 1) {\r\n inputs.current[index + 1]?.focus();\r\n }\r\n };\r\n\r\n const handleKeyDown = (index: number, e: React.KeyboardEvent) => {\r\n if (e.key === 'Backspace' && !values[index] && index > 0) {\r\n inputs.current[index - 1]?.focus();\r\n }\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"flex flex-col items-center gap-6\">\r\n <div className=\"text-center\">\r\n <h3 className=\"font-bold text-lg text-gray-900 dark:text-white\">Verify Account</h3>\r\n <p className=\"text-sm text-gray-500 mt-1\">Enter the 4-digit code sent to your email.</p>\r\n </div>\r\n\r\n <div className=\"flex gap-3\">\r\n {values.map((v, i) => (\r\n <input\r\n key={i}\r\n ref={(el) => { inputs.current[i] = el; }}\r\n type=\"text\"\r\n maxLength={1}\r\n value={v}\r\n onChange={(e) => handleChange(i, e.target.value)}\r\n onKeyDown={(e) => handleKeyDown(i, e)}\r\n className={`\r\n w-12 h-14 text-center text-xl font-bold outline-none transition-all\r\n ${isMUI ? 'bg-transparent border-b-2 border-gray-300 focus:border-blue-600 rounded-none' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-xl border border-transparent focus:bg-white dark:focus:bg-black focus:border-blue-500 focus:ring-2 focus:ring-blue-500/20' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)} focus:border-${globalConfig.primaryColor}-500` : ''}\r\n `}\r\n />\r\n ))}\r\n </div>\r\n\r\n <button className=\"text-sm text-blue-600 hover:underline font-medium\">\r\n Resend Code\r\n </button>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Menu, Search, Bell, MoreVertical, ChevronLeft } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface AppBarProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const AppBar: React.FC<AppBarProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full min-h-[400px] flex flex-col relative overflow-hidden rounded-lg border border-gray-200 dark:border-gray-800 bg-gray-50 dark:bg-gray-900\">\r\n \r\n {/* App Bar */}\r\n <header className={`\r\n w-full flex items-center justify-between px-4 flex-shrink-0 transition-all\r\n ${designSystem === 'MUI' ? `h-14 ${getColorShade(globalConfig, 'bg', 600)} text-white shadow-md` : ''}\r\n ${designSystem === 'Apple' ? 'h-12 bg-white/80 dark:bg-gray-900/80 backdrop-blur-md border-b border-gray-200 dark:border-gray-800' : ''}\r\n ${designSystem === 'Custom' ? `h-16 bg-white dark:bg-gray-950 border-b border-gray-100 dark:border-gray-800` : ''}\r\n `}>\r\n \r\n {/* Left Action */}\r\n <div className=\"flex items-center gap-4\">\r\n {designSystem === 'MUI' && <button><Menu size={24} /></button>}\r\n {designSystem === 'Apple' && <button className={`flex items-center ${getColorShade(globalConfig, 'text', 500)} gap-1`}><ChevronLeft size={20} /> <span className=\"text-base\">Back</span></button>}\r\n {designSystem === 'Custom' && <div className={`w-8 h-8 rounded-lg ${getColorClass(globalConfig, 'bg')}`}></div>}\r\n \r\n <h1 className={`\r\n ${designSystem === 'MUI' ? 'text-lg font-medium tracking-wide' : ''}\r\n ${designSystem === 'Apple' ? 'absolute left-1/2 -translate-x-1/2 text-base font-semibold text-gray-900 dark:text-white' : ''}\r\n ${designSystem === 'Custom' ? 'text-xl font-bold text-gray-900 dark:text-white' : ''}\r\n `}>\r\n {componentProps.text || 'Page Title'}\r\n </h1>\r\n </div>\r\n\r\n {/* Right Actions */}\r\n <div className=\"flex items-center gap-3\">\r\n {designSystem === 'MUI' && (\r\n <>\r\n <button><Search size={24} /></button>\r\n <button><Bell size={24} /></button>\r\n <button><MoreVertical size={24} /></button>\r\n </>\r\n )}\r\n {designSystem === 'Apple' && <button className={`${getColorShade(globalConfig, 'text', 500)} text-base font-normal`}>Edit</button>}\r\n {designSystem === 'Custom' && (\r\n <button className=\"p-2 rounded-full hover:bg-gray-100 dark:hover:bg-gray-800 text-gray-500\">\r\n <SettingsIcon />\r\n </button>\r\n )}\r\n </div>\r\n </header>\r\n\r\n <div className=\"flex-1 overflow-y-auto p-4 text-sm text-gray-500 dark:text-gray-400\">\r\n Content scrolls beneath the app bar.\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nconst SettingsIcon = () => (\r\n <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\">\r\n <circle cx=\"12\" cy=\"12\" r=\"3\"></circle>\r\n <path d=\"M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z\"></path>\r\n </svg>\r\n);\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Home, Heart, User, MapPin } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface BottomNavProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const BottomNavigation: React.FC<BottomNavProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [active, setActive] = useState(0);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const items = [\r\n { label: 'Home', icon: Home },\r\n { label: 'Favorites', icon: Heart },\r\n { label: 'Nearby', icon: MapPin },\r\n { label: 'Profile', icon: User },\r\n ];\r\n\r\n return (\r\n <div className=\"w-full h-full min-h-[400px] flex flex-col border border-gray-200 dark:border-gray-800 rounded-lg overflow-hidden relative bg-gray-50 dark:bg-gray-900\" style={appliedStyles}>\r\n <div className=\"flex-1 flex items-center justify-center text-gray-400 text-sm overflow-y-auto\">App Content</div>\r\n \r\n <div className={`\r\n w-full flex items-center justify-around flex-shrink-0\r\n ${designSystem === 'MUI' ? 'bg-white dark:bg-gray-800 h-14 shadow-[0_-2px_6px_rgba(0,0,0,0.05)]' : ''}\r\n ${designSystem === 'Apple' ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-md h-20 pb-4 border-t border-gray-200/50 dark:border-gray-800/50' : ''}\r\n ${designSystem === 'Custom' ? 'bg-white dark:bg-gray-950 h-16 border-t border-gray-100 dark:border-gray-800' : ''}\r\n `}>\r\n {items.map((item, i) => {\r\n const isActive = active === i;\r\n return (\r\n <button \r\n key={item.label}\r\n onClick={() => setActive(i)}\r\n className={`\r\n flex flex-col items-center justify-center w-full h-full transition-colors\r\n ${designSystem === 'MUI' \r\n ? (isActive ? `${getColorShade(globalConfig, 'text', 600)} scale-110` : 'text-gray-500 hover:text-gray-700') \r\n : ''}\r\n \r\n ${designSystem === 'Apple' \r\n ? (isActive ? `${getColorShade(globalConfig, 'text', 500)}` : 'text-gray-400') \r\n : ''}\r\n\r\n ${designSystem === 'Custom' \r\n ? (isActive ? getColorClass(globalConfig, 'text') : 'text-gray-400 hover:text-gray-600') \r\n : ''}\r\n `}\r\n >\r\n <item.icon \r\n size={designSystem === 'MUI' ? 24 : 20} \r\n fill={isActive && (designSystem === 'Apple' || designSystem === 'MUI') ? \"currentColor\" : \"none\"} \r\n strokeWidth={isActive && (designSystem === 'Apple' || designSystem === 'MUI') ? 0 : 2}\r\n />\r\n <span className={`text-[10px] mt-1 ${!isActive && designSystem === 'MUI' ? 'hidden' : 'block'}`}>\r\n {item.label}\r\n </span>\r\n </button>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { User, Settings, LogOut, ChevronRight, MoreVertical } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface MenuProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Menu: React.FC<MenuProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(true); // Default open for demo\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const toggleMenu = () => setIsOpen(!isOpen);\r\n\r\n // Design System Specific Styles\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div className={`relative text-left ${isOpen ? 'w-full h-full' : 'inline-block'}`} style={appliedStyles}>\r\n {isOpen && (\r\n <div \r\n className=\"absolute inset-0 bg-black/50 z-30 backdrop-blur-sm\"\r\n onClick={toggleMenu}\r\n />\r\n )}\r\n <div className=\"relative z-40\">\r\n <button \r\n type=\"button\" \r\n onClick={toggleMenu}\r\n className={`\r\n flex items-center gap-2 px-4 py-2 transition-colors\r\n ${isMUI ? 'uppercase font-medium text-sm text-gray-700 hover:bg-gray-100 rounded' : ''}\r\n ${isApple ? `${getColorShade(globalConfig, 'text', 500)} font-normal text-base ${getColorShade(globalConfig, 'bg', 50).replace('bg-', 'hover:bg-')} rounded-lg` : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 shadow-sm text-sm font-medium ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n {isMUI ? 'Options' : isApple ? 'Actions' : 'Menu'}\r\n {!isMUI && <MoreVertical size={16} />}\r\n </button>\r\n </div>\r\n\r\n {isOpen && (\r\n <div \r\n className={`\r\n absolute left-0 mt-2 w-56 origin-top-left z-50 focus:outline-none\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded shadow-lg ring-1 ring-black ring-opacity-5 py-2' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 backdrop-blur-xl rounded-xl shadow-xl border border-gray-200/50 dark:border-gray-700/50 p-1.5' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 shadow-lg ${getRadiusClass(globalConfig)} p-1` : ''}\r\n `}\r\n >\r\n <div className={`${isApple ? 'space-y-0.5' : ''}`}>\r\n {[\r\n { label: 'Profile', icon: User, shortcut: '⌘P' },\r\n { label: 'Settings', icon: Settings, shortcut: '⌘S' },\r\n { label: 'Logout', icon: LogOut, shortcut: '', danger: true }\r\n ].map((item, i) => (\r\n <button\r\n key={item.label}\r\n className={`\r\n group flex w-full items-center justify-between px-4 py-2 text-sm transition-colors\r\n ${isMUI ? 'hover:bg-gray-100 dark:hover:bg-gray-700 text-gray-700 dark:text-gray-200' : ''}\r\n \r\n ${isApple ? `\r\n rounded-lg\r\n ${item.danger ? 'text-red-500 hover:bg-red-50 dark:hover:bg-red-900/20' : `text-gray-900 dark:text-white ${getColorShade(globalConfig, 'bg', 50).replace('bg-', 'hover:bg-')} dark:${getColorShade(globalConfig, 'bg', 900).replace('bg-', 'hover:bg-')}/30 ${getColorShade(globalConfig, 'text', 600).replace('text-', 'hover:text-')} dark:${getColorShade(globalConfig, 'text', 400).replace('text-', 'hover:text-')}`}\r\n ` : ''}\r\n\r\n ${isCustom ? `\r\n rounded-md hover:bg-gray-50 dark:hover:bg-gray-800\r\n ${item.danger ? 'text-red-600 hover:bg-red-50' : 'text-gray-700 dark:text-gray-200'}\r\n ` : ''}\r\n `}\r\n >\r\n <div className=\"flex items-center gap-3\">\r\n <item.icon size={16} className={`\r\n ${isMUI ? 'text-gray-400 group-hover:text-gray-500' : ''}\r\n ${isApple ? 'opacity-70' : ''}\r\n ${isCustom ? 'opacity-50 group-hover:opacity-100' : ''}\r\n `} />\r\n {item.label}\r\n </div>\r\n {item.shortcut && (\r\n <span className=\"text-xs text-gray-400\">{item.shortcut}</span>\r\n )}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronLeft, ChevronRight, MoreHorizontal } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface PaginationProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Pagination: React.FC<PaginationProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [page, setPage] = useState(1);\r\n const count = 10;\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n const isOutlined = componentProps.variant === 'secondary';\r\n \r\n const renderPageButton = (p: number | string) => {\r\n const isSelected = p === page;\r\n if (p === '...') return <span key={Math.random()} className=\"px-2 text-gray-400 self-end mb-1\">...</span>;\r\n\r\n return (\r\n <button\r\n key={p}\r\n onClick={() => typeof p === 'number' && setPage(p)}\r\n className={`\r\n min-w-[32px] h-8 flex items-center justify-center text-sm transition-colors\r\n ${isMUI ? `\r\n rounded-full\r\n ${isSelected ? `${getColorShade(globalConfig, 'bg', 600)} text-white` : 'text-gray-700 hover:bg-gray-100 dark:text-gray-300 dark:hover:bg-gray-800'}\r\n ${isOutlined ? 'border border-gray-300 dark:border-gray-700' : ''}\r\n ` : ''}\r\n\r\n ${isApple ? `\r\n ${isSelected ? 'font-bold text-black dark:text-white' : 'text-gray-500 hover:text-gray-800'}\r\n ` : ''}\r\n\r\n ${isCustom ? `\r\n ${getRadiusClass(globalConfig)}\r\n ${isSelected ? `${getColorClass(globalConfig, 'bg')} text-white` : 'bg-gray-100 dark:bg-gray-800 hover:bg-gray-200'}\r\n ` : ''}\r\n `}\r\n >\r\n {p}\r\n </button>\r\n );\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full flex items-center justify-center gap-2 flex-wrap\">\r\n <button \r\n onClick={() => setPage(p => Math.max(1, p - 1))}\r\n disabled={page === 1}\r\n className={`p-1 disabled:opacity-30 ${isMUI ? 'hover:bg-gray-100 rounded-full' : ''}`}\r\n >\r\n <ChevronLeft size={20} />\r\n </button>\r\n\r\n {/* Simple logic for demo */}\r\n {renderPageButton(1)}\r\n {page > 3 && renderPageButton('...')}\r\n {page > 1 && page < count && renderPageButton(page)}\r\n {page < count - 2 && renderPageButton('...')}\r\n {count > 1 && renderPageButton(count)}\r\n\r\n <button \r\n onClick={() => setPage(p => Math.min(count, p + 1))}\r\n disabled={page === count}\r\n className={`p-1 disabled:opacity-30 ${isMUI ? 'hover:bg-gray-100 rounded-full' : ''}`}\r\n >\r\n <ChevronRight size={20} />\r\n </button>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Plus, Copy, Save, Share2, Printer, X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\ninterface SpeedDialProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const SpeedDial: React.FC<SpeedDialProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [open, setOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const actions = [\r\n { icon: Copy, name: 'Copy' },\r\n { icon: Save, name: 'Save' },\r\n { icon: Printer, name: 'Print' },\r\n { icon: Share2, name: 'Share' },\r\n ];\r\n\r\n return (\r\n <div className=\"absolute bottom-6 right-6 flex flex-col items-center gap-3\" style={appliedStyles}>\r\n {/* Actions Stack */}\r\n <div className={`flex flex-col gap-3 transition-all duration-200 ${open ? 'opacity-100 translate-y-0' : 'opacity-0 translate-y-4 pointer-events-none'}`}>\r\n {actions.map((action) => (\r\n <button \r\n key={action.name}\r\n className={`\r\n w-10 h-10 rounded-full flex items-center justify-center shadow-md bg-white dark:bg-gray-800 text-gray-600 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700\r\n ${designSystem === 'MUI' ? 'shadow-lg' : ''}\r\n `}\r\n title={action.name}\r\n >\r\n <action.icon size={18} />\r\n </button>\r\n ))}\r\n </div>\r\n\r\n {/* FAB Trigger */}\r\n <button\r\n onClick={() => setOpen(!open)}\r\n className={`\r\n w-14 h-14 rounded-full flex items-center justify-center shadow-lg text-white transition-transform duration-300\r\n ${designSystem === 'MUI' ? 'bg-blue-600 hover:bg-blue-700' : ''}\r\n ${designSystem === 'Apple' ? 'bg-blue-500' : ''}\r\n ${designSystem === 'Custom' ? getColorClass(globalConfig, 'bg') : ''}\r\n ${open ? 'rotate-45' : 'rotate-0'}\r\n `}\r\n >\r\n <Plus size={28} />\r\n </button>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Check, ChevronRight, ChevronLeft } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface StepperProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Stepper: React.FC<StepperProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [activeStep, setActiveStep] = useState(1);\r\n const steps = ['Select campaign', 'Create ad group', 'Create ad'];\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const handleNext = () => setActiveStep((prev) => Math.min(prev + 1, steps.length));\r\n const handleBack = () => setActiveStep((prev) => Math.max(prev - 1, 0));\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col\">\r\n <div className={`\r\n flex items-start justify-between gap-1 overflow-x-auto\r\n ${isMUI ? 'mb-8' : 'mb-6'}\r\n `}>\r\n {steps.map((label, index) => {\r\n const stepNum = index + 1;\r\n const isActive = activeStep === index;\r\n const isCompleted = activeStep > index;\r\n const isLast = index === steps.length - 1;\r\n\r\n return (\r\n <React.Fragment key={label}>\r\n <div className=\"flex flex-col items-center relative z-10 flex-shrink-0 min-w-0\">\r\n {/* Step Circle/Indicator */}\r\n <div \r\n className={`\r\n flex items-center justify-center transition-all duration-300 flex-shrink-0\r\n ${isMUI ? `\r\n w-6 h-6 sm:w-8 sm:h-8 rounded-full text-xs sm:text-sm font-medium\r\n ${isActive || isCompleted \r\n ? `${getColorShade(globalConfig, 'bg', 600)} text-white` \r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-500 dark:text-gray-400'}\r\n ` : ''}\r\n \r\n ${isApple ? `\r\n w-3 h-3 rounded-full\r\n ${isActive \r\n ? `${getColorShade(globalConfig, 'bg', 500)} scale-125` \r\n : isCompleted \r\n ? `${getColorShade(globalConfig, 'bg', 500)}` \r\n : 'bg-gray-300 dark:bg-gray-600'}\r\n ` : ''}\r\n\r\n ${isCustom ? `\r\n w-6 h-6 sm:w-8 sm:h-8 ${getRadiusClass(globalConfig)} border-2 text-xs sm:text-sm font-bold\r\n ${isActive || isCompleted \r\n ? `${getColorClass(globalConfig, 'bg')} border-transparent text-white` \r\n : `bg-transparent border-gray-300 dark:border-gray-600 text-gray-400`}\r\n ` : ''}\r\n `}\r\n >\r\n {isMUI && (isCompleted ? <Check size={14} className=\"sm:w-4 sm:h-4\" /> : stepNum)}\r\n {isCustom && (isCompleted ? <Check size={14} className=\"sm:w-4 sm:h-4\" /> : stepNum)}\r\n </div>\r\n\r\n {/* Label */}\r\n <span className={`\r\n mt-1.5 sm:mt-2 text-[10px] sm:text-xs text-center font-medium transition-colors max-w-[60px] sm:max-w-[80px] truncate px-0.5\r\n ${isActive ? 'text-gray-900 dark:text-white' : 'text-gray-500 dark:text-gray-400'}\r\n ${isApple && !isActive ? 'hidden' : ''} \r\n `}>\r\n {label}\r\n </span>\r\n </div>\r\n\r\n {/* Connector Line */}\r\n {!isLast && (\r\n <div className={`\r\n flex-1 min-w-[20px] h-[1px] mx-1 sm:mx-2 self-start mt-3 sm:mt-4 flex-shrink\r\n ${isMUI ? `\r\n bg-gray-300 dark:bg-gray-700\r\n ${isCompleted ? `${getColorShade(globalConfig, 'bg', 600)}` : ''}\r\n ` : ''}\r\n \r\n ${isApple ? `\r\n h-[2px] rounded-full mt-1.5\r\n ${isCompleted ? `${getColorShade(globalConfig, 'bg', 500)}` : 'bg-gray-200 dark:bg-gray-700'}\r\n ` : ''}\r\n\r\n ${isCustom ? `\r\n h-1 rounded-full\r\n ${isCompleted ? getColorClass(globalConfig, 'bg') : 'bg-gray-100 dark:bg-gray-800'}\r\n ` : ''}\r\n `} />\r\n )}\r\n </React.Fragment>\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Content Placeholder */}\r\n <div className={`\r\n w-full p-6 mb-6 mt-12 text-center border rounded-lg flex-1\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-800 border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/50 dark:bg-gray-800/50 backdrop-blur-md border-gray-200/50 dark:border-gray-700/50 rounded-xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border-gray-100 dark:border-gray-800 shadow-sm ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {activeStep === steps.length ? (\r\n <div className=\"space-y-2\">\r\n <p className=\"text-lg font-medium text-gray-900 dark:text-white\">All steps completed</p>\r\n <p className=\"text-sm text-gray-500\">Your campaign has been successfully launched.</p>\r\n <button onClick={() => setActiveStep(0)} className={`${getColorShade(globalConfig, 'text', 600)} hover:underline text-sm mt-2`}>Reset</button>\r\n </div>\r\n ) : (\r\n <div className=\"space-y-2\">\r\n <p className=\"text-sm text-gray-500 uppercase tracking-wider\">Step {activeStep + 1}</p>\r\n <p className=\"text-lg font-medium text-gray-900 dark:text-white\">{steps[activeStep]}</p>\r\n </div>\r\n )}\r\n </div>\r\n\r\n {/* Actions */}\r\n <div className=\"flex justify-between mt-auto\">\r\n <button\r\n onClick={handleBack}\r\n disabled={activeStep === 0}\r\n className={`\r\n flex items-center gap-1 px-4 py-2 rounded font-medium text-sm transition-colors\r\n ${activeStep === 0 ? 'opacity-50 cursor-not-allowed text-gray-400' : 'hover:bg-gray-100 dark:hover:bg-gray-800 text-gray-700 dark:text-gray-300'}\r\n `}\r\n >\r\n {isApple || isCustom ? <ChevronLeft size={16} /> : null}\r\n Back\r\n </button>\r\n <button\r\n onClick={handleNext}\r\n className={`\r\n flex items-center gap-1 px-4 py-2 rounded font-medium text-sm transition-colors text-white\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} shadow-sm uppercase` : ''}\r\n ${isApple ? `${getColorShade(globalConfig, 'bg', 500)} ${getColorShade(globalConfig, 'bg', 600).replace('bg-', 'hover:bg-')} rounded-full px-6` : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} rounded-lg` : ''}\r\n `}\r\n >\r\n {activeStep === steps.length - 1 ? 'Finish' : 'Next'}\r\n {isApple || isCustom ? <ChevronRight size={16} /> : null}\r\n </button>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface TabsProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Tabs: React.FC<TabsProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full\">\r\n <div className={`flex ${designSystem === 'Apple' ? 'bg-gray-100 dark:bg-gray-800 p-1 rounded-lg' : 'border-b border-gray-200 dark:border-gray-700'}`}>\r\n {['Account', 'Security', 'Preferences'].map((tab, i) => (\r\n <button \r\n key={tab}\r\n className={`\r\n px-4 py-2 text-sm font-medium transition-all\r\n ${designSystem === 'Apple' \r\n ? (i === 0 ? 'bg-white dark:bg-gray-700 shadow-sm rounded-md text-black dark:text-white' : 'text-gray-500')\r\n : (i === 0 ? `border-b-2 ${getColorShade(globalConfig, 'border', 600)} ${getColorShade(globalConfig, 'text', 600)}` : 'text-gray-500 hover:text-gray-700')\r\n }\r\n `}\r\n >\r\n {tab}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface BackdropProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Backdrop: React.FC<BackdropProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [open, setOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const handleToggle = () => setOpen(!open);\r\n\r\n return (\r\n <div style={appliedStyles} className=\"relative w-full h-full overflow-hidden\">\r\n <button \r\n onClick={handleToggle}\r\n className={`px-4 py-2 ${getColorShade(globalConfig, 'bg', 600)} text-white rounded-md ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} transition-colors z-10 relative`}\r\n >\r\n Show Backdrop\r\n </button>\r\n\r\n {open && (\r\n <div \r\n className={`\r\n absolute inset-0 z-50 flex items-center justify-center transition-opacity cursor-pointer\r\n ${designSystem === 'MUI' ? 'bg-black/70' : ''}\r\n ${designSystem === 'Apple' ? 'bg-black/50 dark:bg-black/60 backdrop-blur-md' : ''}\r\n ${designSystem === 'Custom' ? 'bg-gray-900/70 backdrop-blur-sm' : ''}\r\n `}\r\n onClick={() => setOpen(false)}\r\n >\r\n <div className=\"text-center\">\r\n <Loader2 size={48} className={`animate-spin ${designSystem === 'Custom' ? 'text-white' : getColorShade(globalConfig, 'text', 500)}`} />\r\n <p className={`mt-4 font-medium ${designSystem === 'Custom' ? 'text-white' : 'text-white drop-shadow-md'}`}>Loading...</p>\r\n <p className=\"text-xs text-white/80 mt-2\">Click anywhere to close</p>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface DialogProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Dialog: React.FC<DialogProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const toggleDialog = () => setIsOpen(!isOpen);\r\n\r\n // Design System Specific Styles\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div className=\"relative w-full h-full flex flex-col items-center justify-center overflow-hidden\">\r\n <button \r\n onClick={toggleDialog}\r\n className={`\r\n px-4 py-2 rounded-md font-medium transition-colors z-10\r\n ${isMUI ? `${getColorClass(globalConfig, 'bg')} text-white shadow-md uppercase tracking-wide` : ''}\r\n ${isApple ? `${getColorClass(globalConfig, 'text').replace('-600', '-500')} font-normal ${getColorClass(globalConfig, 'bg').replace('-600', '-50').replace('hover:bg-700', '')} dark:${getColorClass(globalConfig, 'bg').replace('-600', '-900/20').replace('hover:bg-700', '')}` : ''}\r\n ${isCustom ? `${getRadiusClass(globalConfig)}` : ''}\r\n style={isCustom ? { backgroundColor: getColorValue(globalConfig, 'primary', 600), color: 'white' } : undefined}\r\n `}\r\n >\r\n Open Dialog\r\n </button>\r\n\r\n {/* Backdrop */}\r\n {isOpen && (\r\n <div className=\"absolute inset-0 z-50 flex items-center justify-center p-4\">\r\n <div \r\n className={`\r\n absolute inset-0 transition-opacity duration-300\r\n ${isMUI ? 'bg-black/70' : ''}\r\n ${isApple ? 'bg-black/50 dark:bg-black/60 backdrop-blur-md' : ''}\r\n ${isCustom ? 'bg-gray-900/70 backdrop-blur-sm' : ''}\r\n `} \r\n onClick={toggleDialog}\r\n />\r\n\r\n {/* Dialog Content */}\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n relative z-10 w-full max-w-sm transition-all duration-300 transform scale-100 animate-in zoom-in-95\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded shadow-xl' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-800/80 backdrop-blur-xl rounded-2xl shadow-lg border border-gray-200/50 dark:border-gray-700/50 text-center' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-100 dark:border-gray-800 shadow-2xl ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n {/* Header / Title */}\r\n <div className={`\r\n ${isMUI ? 'px-6 pt-5 pb-3' : ''}\r\n ${isApple ? 'pt-6 px-4 pb-2' : ''}\r\n ${isCustom ? 'p-6 border-b border-gray-100 dark:border-gray-800' : ''}\r\n `}>\r\n <h3 className={`\r\n ${isMUI ? 'text-xl font-medium text-gray-900 dark:text-white' : ''}\r\n ${isApple ? 'text-lg font-semibold text-gray-900 dark:text-white' : ''}\r\n ${isCustom ? 'text-lg font-bold tracking-tight text-gray-900 dark:text-white' : ''}\r\n `}>\r\n {componentProps.text || \"Use Google's location service?\"}\r\n </h3>\r\n \r\n {(isApple || isCustom) && (\r\n <p className={`mt-2 text-sm ${isApple ? 'text-gray-500 dark:text-gray-400' : 'text-gray-500'}`}>\r\n This allows apps to determine your location. This is a description text to elaborate on the title.\r\n </p>\r\n )}\r\n </div>\r\n\r\n {/* Content (MUI keeps content separate) */}\r\n {isMUI && (\r\n <div className=\"px-6 pb-4\">\r\n <p className=\"text-gray-600 dark:text-gray-300 text-sm leading-relaxed\">\r\n Let Google help apps determine location. This means sending anonymous location data to Google, even when no apps are running.\r\n </p>\r\n </div>\r\n )}\r\n\r\n {/* Actions */}\r\n <div className={`\r\n ${isMUI ? 'px-2 pb-2 flex justify-end gap-1' : ''}\r\n ${isApple ? 'mt-4 grid grid-cols-2 border-t border-gray-200/50 dark:border-gray-700/50 divide-x divide-gray-200/50 dark:divide-gray-700/50' : ''}\r\n ${isCustom ? 'p-4 flex flex-col sm:flex-row gap-3 justify-end bg-gray-50 dark:bg-gray-900/50' : ''}\r\n `}>\r\n {isMUI && (\r\n <>\r\n <button onClick={toggleDialog} className={`px-4 py-2 ${getColorClass(globalConfig, 'text')} dark:${getColorClass(globalConfig, 'text').replace('-600', '-400')} font-medium text-sm ${getColorClass(globalConfig, 'bg').replace('-600', '-50').replace('hover:bg-700', '')} dark:${getColorClass(globalConfig, 'bg').replace('-600', '-900/20').replace('hover:bg-700', '')} rounded uppercase transition-colors`}>Disagree</button>\r\n <button onClick={toggleDialog} className={`px-4 py-2 ${getColorClass(globalConfig, 'text')} dark:${getColorClass(globalConfig, 'text').replace('-600', '-400')} font-medium text-sm ${getColorClass(globalConfig, 'bg').replace('-600', '-50').replace('hover:bg-700', '')} dark:${getColorClass(globalConfig, 'bg').replace('-600', '-900/20').replace('hover:bg-700', '')} rounded uppercase transition-colors`}>Agree</button>\r\n </>\r\n )}\r\n\r\n {isApple && (\r\n <>\r\n <button onClick={toggleDialog} className={`py-3 ${getColorClass(globalConfig, 'text').replace('-600', '-500')} font-normal text-base hover:bg-gray-100 dark:hover:bg-gray-700/50 transition-colors rounded-bl-2xl`}>Cancel</button>\r\n <button onClick={toggleDialog} className={`py-3 ${getColorClass(globalConfig, 'text').replace('-600', '-500')} font-semibold text-base hover:bg-gray-100 dark:hover:bg-gray-700/50 transition-colors rounded-br-2xl`}>Allow</button>\r\n </>\r\n )}\r\n\r\n {isCustom && (\r\n <>\r\n <button onClick={toggleDialog} className=\"px-4 py-2 text-sm font-medium text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-800 rounded-lg transition-colors\">Cancel</button>\r\n <button onClick={toggleDialog} className={`px-4 py-2 text-sm font-medium text-white ${getColorClass(globalConfig, 'bg')} rounded-lg shadow-sm transition-transform active:scale-95`}>Confirm</button>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface ModalProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Modal: React.FC<ModalProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const toggleModal = () => setIsOpen(!isOpen);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div className=\"relative w-full h-full flex flex-col items-center justify-center overflow-hidden\">\r\n <button \r\n onClick={toggleModal}\r\n className={`\r\n px-6 py-2.5 rounded-md font-medium transition-colors z-10\r\n ${isMUI ? `${getColorClass(globalConfig, 'bg')} text-white shadow-md uppercase tracking-wide text-sm` : ''}\r\n ${isApple ? `bg-white dark:bg-gray-800 ${getColorShade(globalConfig, 'text', 500)} font-normal hover:bg-gray-50 dark:hover:bg-gray-700 shadow-sm border border-gray-200 dark:border-gray-700 rounded-xl` : ''}\r\n ${isCustom ? `hover:opacity-90 ${getRadiusClass(globalConfig)}` : ''}\r\n style={isCustom ? { backgroundColor: getColorValue(globalConfig, 'primary', 600), color: 'white' } : undefined}\r\n `}\r\n >\r\n Open Modal\r\n </button>\r\n\r\n {/* Modal Overlay */}\r\n {isOpen && (\r\n <div className=\"absolute inset-0 z-50 flex items-center justify-center p-4\">\r\n <div \r\n className={`\r\n absolute inset-0 transition-opacity duration-300\r\n ${isMUI ? 'bg-black/70' : ''}\r\n ${isApple ? 'bg-black/50 dark:bg-black/60 backdrop-blur-md' : ''}\r\n ${isCustom ? 'bg-gray-900/70 backdrop-blur-sm' : ''}\r\n `} \r\n onClick={toggleModal}\r\n />\r\n\r\n {/* Modal Content */}\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n relative z-10 w-full max-w-lg transition-all duration-300 transform scale-100 animate-in zoom-in-95 max-h-[80vh] overflow-y-auto\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded shadow-2xl' : ''}\r\n ${isApple ? 'bg-white/90 dark:bg-gray-800/90 backdrop-blur-xl rounded-2xl shadow-xl border border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 shadow-2xl ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n {/* Header */}\r\n <div className={`\r\n flex items-center justify-between\r\n ${isMUI ? 'p-6 pb-4' : ''}\r\n ${isApple ? 'p-4 border-b border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? 'p-5 border-b border-gray-100 dark:border-gray-800' : ''}\r\n `}>\r\n <h3 className={`\r\n ${isMUI ? 'text-xl font-medium text-gray-900 dark:text-white' : ''}\r\n ${isApple ? 'text-lg font-semibold text-gray-900 dark:text-white mx-auto' : ''}\r\n ${isCustom ? 'text-lg font-bold text-gray-900 dark:text-white' : ''}\r\n `}>\r\n {componentProps.text || 'Modal Title'}\r\n </h3>\r\n \r\n {/* Close Button */}\r\n <button \r\n onClick={toggleModal}\r\n className={`\r\n p-1 transition-colors\r\n ${isMUI ? 'absolute top-4 right-4 text-gray-400 hover:text-gray-600' : ''}\r\n ${isApple ? 'absolute top-4 right-4 text-gray-400 hover:text-gray-600 bg-gray-200/50 dark:bg-gray-700/50 rounded-full p-1.5' : ''}\r\n ${isCustom ? 'text-gray-400 hover:text-gray-600 dark:hover:text-gray-200' : ''}\r\n `}\r\n >\r\n <X size={isMUI ? 24 : 18} />\r\n </button>\r\n </div>\r\n\r\n {/* Body */}\r\n <div className={`\r\n ${isMUI ? 'px-6 pb-6 pt-0' : ''}\r\n ${isApple ? 'p-6' : ''}\r\n ${isCustom ? 'p-5' : ''}\r\n `}>\r\n <p className=\"text-gray-600 dark:text-gray-300 leading-relaxed\">\r\n This is a modal window. It sits on top of the main application content and requires user interaction to close. It renders content based on the selected design system tokens.\r\n </p>\r\n <div className=\"mt-4 p-4 bg-gray-50 dark:bg-gray-900/50 rounded-lg border border-gray-100 dark:border-gray-800\">\r\n <p className=\"text-xs font-mono text-gray-500\">\r\n Granular styles like border radius and padding are applied to this container.\r\n </p>\r\n </div>\r\n </div>\r\n\r\n {/* Footer */}\r\n {(isMUI || isCustom) && (\r\n <div className={`\r\n flex justify-end gap-2\r\n ${isMUI ? 'p-4 pt-0' : ''}\r\n ${isCustom ? 'p-5 pt-0' : ''}\r\n `}>\r\n <button \r\n onClick={toggleModal}\r\n className={`\r\n px-4 py-2 font-medium transition-colors text-sm\r\n ${isMUI ? `${getColorShade(globalConfig, 'text', 600)} ${getColorShade(globalConfig, 'bg', 50)} dark:${getColorShade(globalConfig, 'bg', 900)}/20 rounded uppercase` : ''}\r\n ${isCustom ? 'text-gray-600 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-800 rounded-md' : ''}\r\n `}\r\n >\r\n Close\r\n </button>\r\n <button \r\n onClick={toggleModal}\r\n className={`\r\n px-4 py-2 font-medium transition-colors text-sm\r\n ${isMUI ? `${getColorShade(globalConfig, 'text', 600)} ${getColorShade(globalConfig, 'bg', 50)} dark:${getColorShade(globalConfig, 'bg', 900)}/20 rounded uppercase` : ''}\r\n ${isCustom ? `text-white ${getColorClass(globalConfig, 'bg')} rounded-md shadow-sm` : ''}\r\n `}\r\n >\r\n Save Changes\r\n </button>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface ProgressProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Progress: React.FC<ProgressProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const isLoading = componentProps.isLoading;\r\n const [animatedValue, setAnimatedValue] = useState(0);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n // Animate from 0 to 100 when loading\r\n useEffect(() => {\r\n if (isLoading) {\r\n setAnimatedValue(0);\r\n const interval = setInterval(() => {\r\n setAnimatedValue((prev) => {\r\n if (prev >= 100) {\r\n clearInterval(interval);\r\n return 100;\r\n }\r\n return prev + 1; // Increment by 1% for smooth animation\r\n });\r\n }, 30); // Update every 30ms for smooth animation (~3 seconds total)\r\n \r\n return () => clearInterval(interval);\r\n } else {\r\n setAnimatedValue(60); // Default 60% when not loading\r\n }\r\n }, [isLoading]);\r\n\r\n const getTrackClass = (height: string = 'h-1.5') => {\r\n if (isMUI) return `bg-blue-100 dark:bg-blue-900/30 ${height}`;\r\n if (isApple) return `bg-gray-200 dark:bg-gray-700 rounded-full ${height}`;\r\n return `bg-gray-100 dark:bg-gray-800 rounded ${height}`;\r\n };\r\n\r\n const getBarClass = () => {\r\n if (isMUI) return getColorClass(globalConfig, 'bg');\r\n if (isApple) return getColorClass(globalConfig, 'bg') + ' rounded-full';\r\n return getColorClass(globalConfig, 'bg');\r\n };\r\n\r\n const progressValue = isLoading ? animatedValue : 60;\r\n const primaryColor = getColorValue(globalConfig, 'primary', 600);\r\n\r\n return (\r\n <div className=\"w-full max-w-3xl flex flex-col gap-8\" style={appliedStyles}>\r\n \r\n {/* Line Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Line</label>\r\n <div className=\"space-y-2\">\r\n <div className=\"flex justify-between text-xs text-gray-600 dark:text-gray-400\">\r\n <span>Linear Progress</span>\r\n <span>{Math.round(progressValue)}%</span>\r\n </div>\r\n <div className={`w-full ${getTrackClass()} overflow-hidden`}>\r\n <div \r\n className={`h-full transition-all duration-75 ${getBarClass()}`} \r\n style={{ width: `${progressValue}%` }} \r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Circle Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Circle</label>\r\n <div className=\"flex items-center gap-6\">\r\n {[60, 80, 100].map((size) => {\r\n const radius = (size - 8) / 2;\r\n const circumference = 2 * Math.PI * radius;\r\n const offset = circumference - (progressValue / 100) * circumference;\r\n \r\n return (\r\n <div key={size} className=\"flex flex-col items-center gap-2\">\r\n <div className=\"relative\" style={{ width: size, height: size }}>\r\n {isMUI && (\r\n <svg className=\"w-full h-full transform -rotate-90\" viewBox={`0 0 ${size} ${size}`}>\r\n <circle \r\n cx={size/2} \r\n cy={size/2} \r\n r={radius} \r\n fill=\"none\" \r\n strokeWidth=\"6\" \r\n className=\"text-blue-100 dark:text-blue-900/30\" \r\n stroke=\"currentColor\"\r\n />\r\n <circle \r\n cx={size/2} \r\n cy={size/2} \r\n r={radius} \r\n fill=\"none\" \r\n strokeWidth=\"6\" \r\n className={getColorClass(globalConfig, 'text')} \r\n strokeDasharray={circumference} \r\n strokeDashoffset={offset} \r\n strokeLinecap=\"round\"\r\n stroke=\"currentColor\"\r\n style={{ transition: 'stroke-dashoffset 0.075s ease-out' }}\r\n />\r\n </svg>\r\n )}\r\n {isApple && (\r\n <Loader2 size={size} className={`text-gray-400 ${isLoading && progressValue >= 100 ? 'animate-spin' : ''}`} />\r\n )}\r\n {isCustom && (\r\n <div className={`\r\n w-full h-full rounded-full border-4 border-gray-100 dark:border-gray-800 border-t-transparent\r\n ${getColorClass(globalConfig, 'border').replace('border-', 'border-t-')}\r\n ${isLoading && progressValue >= 100 ? 'animate-spin' : ''}\r\n `} />\r\n )}\r\n </div>\r\n <span className=\"text-xs text-gray-500\">{Math.round(progressValue)}%</span>\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n\r\n {/* Dots Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Dots</label>\r\n <div className=\"flex items-center gap-2\">\r\n {Array.from({ length: 10 }).map((_, index) => {\r\n const isActive = (index + 1) <= Math.round(progressValue / 10);\r\n return (\r\n <div\r\n key={index}\r\n className={`w-3 h-3 rounded-full transition-all duration-200 ${\r\n isActive \r\n ? `${getBarClass()} shadow-sm` \r\n : 'bg-gray-200 dark:bg-gray-700'\r\n }`}\r\n />\r\n );\r\n })}\r\n <span className=\"ml-4 text-xs text-gray-500\">{Math.round(progressValue)}%</span>\r\n </div>\r\n </div>\r\n\r\n {/* Square Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Square</label>\r\n <div className=\"flex items-center gap-2\">\r\n {Array.from({ length: 10 }).map((_, index) => {\r\n const isActive = (index + 1) <= Math.round(progressValue / 10);\r\n return (\r\n <div\r\n key={index}\r\n className={`w-3 h-3 transition-all duration-200 ${\r\n isActive \r\n ? `${getBarClass()} shadow-sm` \r\n : 'bg-gray-200 dark:bg-gray-700'\r\n }`}\r\n style={{ borderRadius: isMUI ? '2px' : isApple ? '4px' : '4px' }}\r\n />\r\n );\r\n })}\r\n <span className=\"ml-4 text-xs text-gray-500\">{Math.round(progressValue)}%</span>\r\n </div>\r\n </div>\r\n\r\n {/* Stepped Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Stepped</label>\r\n <div className=\"flex items-center gap-1\">\r\n {Array.from({ length: 5 }).map((_, index) => {\r\n const stepValue = (index + 1) * 20;\r\n const isActive = progressValue >= stepValue;\r\n const isPartial = progressValue > (index * 20) && progressValue < stepValue;\r\n return (\r\n <div\r\n key={index}\r\n className={`flex-1 h-8 transition-all duration-200 ${\r\n isActive \r\n ? `${getBarClass()}` \r\n : isPartial\r\n ? `${getBarClass()} opacity-50`\r\n : 'bg-gray-200 dark:bg-gray-700'\r\n }`}\r\n style={{ borderRadius: isMUI ? '2px' : isApple ? '6px' : '4px' }}\r\n />\r\n );\r\n })}\r\n <span className=\"ml-4 text-xs text-gray-500\">{Math.round(progressValue)}%</span>\r\n </div>\r\n </div>\r\n\r\n {/* Gradient Progress */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Gradient</label>\r\n <div className=\"space-y-2\">\r\n <div className=\"flex justify-between text-xs text-gray-600 dark:text-gray-400\">\r\n <span>Gradient Fill</span>\r\n <span>{Math.round(progressValue)}%</span>\r\n </div>\r\n <div className={`w-full ${getTrackClass()} overflow-hidden`}>\r\n <div \r\n className=\"h-full rounded-full transition-all duration-75\"\r\n style={{ \r\n width: `${progressValue}%`,\r\n background: `linear-gradient(90deg, ${primaryColor}, ${getColorValue(globalConfig, 'primary', 400)})`\r\n }}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Loading State - Animated from 0-100% */}\r\n <div className=\"w-full space-y-3\">\r\n <label className=\"text-sm font-semibold text-gray-900 dark:text-white\">Loading State (0-100%)</label>\r\n <div className=\"space-y-2\">\r\n <div className=\"flex justify-between text-xs text-gray-600 dark:text-gray-400\">\r\n <span>{isLoading ? 'Loading...' : 'Completed'}</span>\r\n <span>{Math.round(animatedValue)}%</span>\r\n </div>\r\n <div className={`w-full ${getTrackClass()} overflow-hidden`}>\r\n <div \r\n className={`h-full transition-all duration-75 ${getBarClass()}`} \r\n style={{ width: `${animatedValue}%` }} \r\n />\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface SnackbarProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Snackbar: React.FC<SnackbarProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const showSnackbar = () => {\r\n setIsOpen(true);\r\n setTimeout(() => setIsOpen(false), 3000);\r\n };\r\n\r\n return (\r\n <div className=\"relative flex flex-col items-center justify-center h-48 w-full\" style={appliedStyles}>\r\n <button \r\n onClick={showSnackbar}\r\n className={`px-4 py-2 ${getColorShade(globalConfig, 'bg', 600)} text-white rounded-md text-sm font-medium hover:${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'bg-')}`}\r\n >\r\n Trigger Notification\r\n </button>\r\n\r\n <div className={`\r\n absolute bottom-4 transition-all duration-300 transform\r\n ${isOpen ? 'translate-y-0 opacity-100' : 'translate-y-4 opacity-0 pointer-events-none'}\r\n \r\n ${designSystem === 'MUI' ? 'bg-gray-900 text-white px-4 py-3 rounded shadow-lg min-w-[300px] flex items-center justify-between' : ''}\r\n \r\n ${designSystem === 'Apple' ? 'top-0 bottom-auto mt-4 bg-white/80 dark:bg-gray-800/80 backdrop-blur-xl border border-gray-200/50 dark:border-gray-700/50 shadow-xl rounded-full px-4 py-3 min-w-[320px] flex items-center gap-3' : ''}\r\n\r\n ${designSystem === 'Custom' ? `bg-white dark:bg-gray-900 border-l-4 ${getColorClass(globalConfig, 'border').replace('border-', 'border-l-')} shadow-md p-4 rounded-r-md min-w-[300px] border-y border-r border-gray-100 dark:border-gray-800` : ''}\r\n `}>\r\n \r\n <span className={`text-sm ${designSystem === 'Custom' ? 'font-medium text-gray-900 dark:text-white' : ''}`}>\r\n {componentProps.text || 'Operation successful'}\r\n </span>\r\n\r\n {designSystem === 'MUI' && (\r\n <button className={`${getColorClass(globalConfig, 'text').replace('-600', '-400')} text-sm font-bold uppercase ${getColorClass(globalConfig, 'text').replace('-600', '-300').replace('text-', 'hover:text-')} ml-4`}>Undo</button>\r\n )}\r\n\r\n {designSystem === 'Apple' && (\r\n <div className=\"ml-auto w-px h-4 bg-gray-300 dark:bg-gray-600 mx-2\" />\r\n )}\r\n \r\n {/* Custom or Apple Close */}\r\n {(designSystem === 'Apple' || designSystem === 'Custom') && (\r\n <button className=\"text-gray-400 hover:text-gray-600 dark:hover:text-gray-200\">\r\n <X size={16} />\r\n </button>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { BarChart3, PieChart, LineChart, Activity, AreaChart, TrendingUp } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade, getColorValue, getRadiusClass } from '../utils/styleUtils';\r\nimport {\r\n AreaChart as RechartsAreaChart,\r\n Area,\r\n BarChart,\r\n Bar,\r\n LineChart as RechartsLineChart,\r\n Line,\r\n PieChart as RechartsPieChart,\r\n Pie,\r\n Cell,\r\n XAxis,\r\n YAxis,\r\n CartesianGrid,\r\n Tooltip,\r\n ResponsiveContainer,\r\n Legend,\r\n ReferenceLine\r\n} from 'recharts';\r\n\r\ninterface ChartsProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\n// Modern fintech data\r\nconst STOCK_DATA = [\r\n { date: 'Mon', open: 245.20, high: 248.50, low: 244.10, close: 247.80, volume: 1250000 },\r\n { date: 'Tue', open: 247.80, high: 250.30, low: 246.50, close: 249.20, volume: 1450000 },\r\n { date: 'Wed', open: 249.20, high: 251.80, low: 248.20, close: 250.50, volume: 1320000 },\r\n { date: 'Thu', open: 250.50, high: 252.40, low: 249.10, close: 251.90, volume: 1180000 },\r\n { date: 'Fri', open: 251.90, high: 253.20, low: 250.30, close: 252.60, volume: 1560000 },\r\n { date: 'Sat', open: 252.60, high: 254.10, low: 251.20, close: 253.40, volume: 1420000 },\r\n { date: 'Sun', open: 253.40, high: 255.80, low: 252.80, close: 254.90, volume: 1380000 },\r\n];\r\n\r\nconst PORTFOLIO_DATA = [\r\n { date: 'Mon', value: 125000, benchmark: 120000 },\r\n { date: 'Tue', value: 128500, benchmark: 121500 },\r\n { date: 'Wed', value: 131200, benchmark: 123000 },\r\n { date: 'Thu', value: 129800, benchmark: 122200 },\r\n { date: 'Fri', value: 133500, benchmark: 124500 },\r\n { date: 'Sat', value: 135200, benchmark: 125800 },\r\n { date: 'Sun', value: 137800, benchmark: 127200 },\r\n];\r\n\r\n// Asset allocation will use dynamic colors from globalConfig\r\nconst ASSET_ALLOCATION_DATA = [\r\n { name: 'Stocks', value: 45 },\r\n { name: 'Bonds', value: 25 },\r\n { name: 'Crypto', value: 15 },\r\n { name: 'Real Estate', value: 10 },\r\n { name: 'Cash', value: 5 },\r\n];\r\n\r\nconst VOLUME_DATA = STOCK_DATA.map(d => ({\r\n date: d.date,\r\n volume: d.volume,\r\n buyVolume: d.volume * 0.6,\r\n sellVolume: d.volume * 0.4,\r\n}));\r\n\r\nexport const Charts: React.FC<ChartsProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [activeTab, setActiveTab] = useState<'candlestick' | 'area' | 'line' | 'bar' | 'pie'>('area');\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n // Get colors from global palette\r\n const primaryColor = getColorValue(globalConfig, 'primary', 600);\r\n const secondaryColor = getColorValue(globalConfig, 'secondary', 500);\r\n const tertiaryColor = getColorValue(globalConfig, 'tertiary', 400);\r\n\r\n // Get success and danger colors for fintech charts (green/red)\r\n const successColor = getColorValue(globalConfig, 'primary', 500); // Use primary for success, or could be green\r\n const dangerColor = '#ef4444'; // Keep red for losses, or use danger color if available\r\n\r\n // Generate color palette for pie chart based on global colors\r\n const getPieChartColors = () => {\r\n const baseColors = [\r\n primaryColor,\r\n secondaryColor,\r\n tertiaryColor || getColorValue(globalConfig, 'primary', 400),\r\n getColorValue(globalConfig, 'primary', 300),\r\n getColorValue(globalConfig, 'secondary', 300),\r\n ];\r\n return baseColors;\r\n };\r\n\r\n // Custom tooltip for fintech charts\r\n const CustomTooltip = ({ active, payload, label }: any) => {\r\n if (active && payload && payload.length) {\r\n return (\r\n <div className=\"bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-700 rounded-lg shadow-xl p-3\">\r\n <p className=\"text-xs font-semibold text-gray-900 dark:text-white mb-2\">{label}</p>\r\n {payload.map((entry: any, index: number) => (\r\n <p key={index} className=\"text-xs\" style={{ color: entry.color }}>\r\n {entry.name}: <span className=\"font-semibold\">{typeof entry.value === 'number' ? entry.value.toLocaleString() : entry.value}</span>\r\n </p>\r\n ))}\r\n </div>\r\n );\r\n }\r\n return null;\r\n };\r\n\r\n const renderCandlestickChart = () => {\r\n const data = STOCK_DATA.map(d => ({\r\n ...d,\r\n isPositive: d.close >= d.open,\r\n }));\r\n\r\n return (\r\n <ResponsiveContainer width=\"100%\" height={400}>\r\n <RechartsAreaChart data={data} margin={{ top: 20, right: 30, left: 20, bottom: 20 }}>\r\n <defs>\r\n <linearGradient id={`colorUp-${primaryColor}`} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\r\n <stop offset=\"5%\" stopColor={successColor} stopOpacity={0.8} />\r\n <stop offset=\"95%\" stopColor={successColor} stopOpacity={0} />\r\n </linearGradient>\r\n <linearGradient id={`colorDown-${dangerColor}`} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\r\n <stop offset=\"5%\" stopColor={dangerColor} stopOpacity={0.8} />\r\n <stop offset=\"95%\" stopColor={dangerColor} stopOpacity={0} />\r\n </linearGradient>\r\n </defs>\r\n <CartesianGrid strokeDasharray=\"3 3\" stroke=\"#e5e7eb\" opacity={0.3} />\r\n <XAxis\r\n dataKey=\"date\"\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n />\r\n <YAxis\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n domain={['dataMin - 2', 'dataMax + 2']}\r\n />\r\n <Tooltip content={<CustomTooltip />} />\r\n <Area\r\n type=\"monotone\"\r\n dataKey=\"high\"\r\n stroke={successColor}\r\n fill={`url(#colorUp-${primaryColor})`}\r\n strokeWidth={2}\r\n fillOpacity={0.3}\r\n />\r\n <Area\r\n type=\"monotone\"\r\n dataKey=\"low\"\r\n stroke={dangerColor}\r\n fill={`url(#colorDown-${dangerColor})`}\r\n strokeWidth={2}\r\n fillOpacity={0.3}\r\n />\r\n <Line\r\n type=\"monotone\"\r\n dataKey=\"close\"\r\n stroke={primaryColor}\r\n strokeWidth={3}\r\n dot={{ fill: primaryColor, r: 4 }}\r\n activeDot={{ r: 6 }}\r\n />\r\n </RechartsAreaChart>\r\n </ResponsiveContainer>\r\n );\r\n };\r\n\r\n const renderAreaChart = () => {\r\n return (\r\n <ResponsiveContainer width=\"100%\" height={400}>\r\n <RechartsAreaChart data={PORTFOLIO_DATA} margin={{ top: 20, right: 30, left: 20, bottom: 20 }}>\r\n <defs>\r\n <linearGradient id={`colorPortfolio-${primaryColor}`} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\r\n <stop offset=\"5%\" stopColor={primaryColor} stopOpacity={0.4} />\r\n <stop offset=\"95%\" stopColor={primaryColor} stopOpacity={0} />\r\n </linearGradient>\r\n <linearGradient id={`colorBenchmark-${secondaryColor}`} x1=\"0\" y1=\"0\" x2=\"0\" y2=\"1\">\r\n <stop offset=\"5%\" stopColor={secondaryColor} stopOpacity={0.3} />\r\n <stop offset=\"95%\" stopColor={secondaryColor} stopOpacity={0} />\r\n </linearGradient>\r\n </defs>\r\n <CartesianGrid strokeDasharray=\"3 3\" stroke=\"#e5e7eb\" opacity={0.3} />\r\n <XAxis\r\n dataKey=\"date\"\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n />\r\n <YAxis\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n tickFormatter={(value) => `$${(value / 1000).toFixed(0)}k`}\r\n />\r\n <Tooltip\r\n content={<CustomTooltip />}\r\n formatter={(value: any) => `$${Number(value || 0).toLocaleString()}`}\r\n />\r\n <Area\r\n type=\"monotone\"\r\n dataKey=\"value\"\r\n stroke={primaryColor}\r\n fill={`url(#colorPortfolio-${primaryColor})`}\r\n strokeWidth={2}\r\n name=\"Portfolio\"\r\n />\r\n <Area\r\n type=\"monotone\"\r\n dataKey=\"benchmark\"\r\n stroke={secondaryColor}\r\n fill={`url(#colorBenchmark-${secondaryColor})`}\r\n strokeWidth={2}\r\n strokeDasharray=\"5 5\"\r\n name=\"Benchmark\"\r\n />\r\n <ReferenceLine y={PORTFOLIO_DATA[0].value} stroke=\"#6b7280\" strokeDasharray=\"3 3\" opacity={0.5} />\r\n </RechartsAreaChart>\r\n </ResponsiveContainer>\r\n );\r\n };\r\n\r\n const renderLineChart = () => {\r\n return (\r\n <ResponsiveContainer width=\"100%\" height={400}>\r\n <RechartsLineChart data={STOCK_DATA} margin={{ top: 20, right: 30, left: 20, bottom: 20 }}>\r\n <CartesianGrid strokeDasharray=\"3 3\" stroke=\"#e5e7eb\" opacity={0.3} />\r\n <XAxis\r\n dataKey=\"date\"\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n />\r\n <YAxis\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n domain={['dataMin - 1', 'dataMax + 1']}\r\n />\r\n <Tooltip content={<CustomTooltip />} />\r\n <Line\r\n type=\"monotone\"\r\n dataKey=\"close\"\r\n stroke={primaryColor}\r\n strokeWidth={3}\r\n dot={{ fill: primaryColor, r: 4 }}\r\n activeDot={{ r: 6 }}\r\n name=\"Close Price\"\r\n />\r\n <Line\r\n type=\"monotone\"\r\n dataKey=\"high\"\r\n stroke={secondaryColor}\r\n strokeWidth={2}\r\n strokeDasharray=\"5 5\"\r\n dot={false}\r\n name=\"High\"\r\n />\r\n <Line\r\n type=\"monotone\"\r\n dataKey=\"low\"\r\n stroke={tertiaryColor}\r\n strokeWidth={2}\r\n strokeDasharray=\"5 5\"\r\n dot={false}\r\n name=\"Low\"\r\n />\r\n </RechartsLineChart>\r\n </ResponsiveContainer>\r\n );\r\n };\r\n\r\n const renderBarChart = () => {\r\n return (\r\n <ResponsiveContainer width=\"100%\" height={400}>\r\n <BarChart data={VOLUME_DATA} margin={{ top: 20, right: 30, left: 20, bottom: 20 }}>\r\n <CartesianGrid strokeDasharray=\"3 3\" stroke=\"#e5e7eb\" opacity={0.3} />\r\n <XAxis\r\n dataKey=\"date\"\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n />\r\n <YAxis\r\n stroke=\"#6b7280\"\r\n tick={{ fill: '#6b7280', fontSize: 12 }}\r\n axisLine={{ stroke: '#e5e7eb' }}\r\n tickFormatter={(value) => `${(value / 1000).toFixed(0)}k`}\r\n />\r\n <Tooltip content={<CustomTooltip />} />\r\n <Bar dataKey=\"buyVolume\" stackId=\"a\" fill={successColor} name=\"Buy Volume\" radius={[4, 4, 0, 0]} />\r\n <Bar dataKey=\"sellVolume\" stackId=\"a\" fill={dangerColor} name=\"Sell Volume\" radius={[4, 4, 0, 0]} />\r\n </BarChart>\r\n </ResponsiveContainer>\r\n );\r\n };\r\n\r\n const renderPieChart = () => {\r\n const pieColors = getPieChartColors();\r\n const assetAllocation = ASSET_ALLOCATION_DATA.map((asset, index) => ({\r\n ...asset,\r\n color: pieColors[index % pieColors.length]\r\n }));\r\n\r\n return (\r\n <div className=\"flex flex-col md:flex-row items-center justify-center gap-8 w-full h-[400px]\">\r\n <ResponsiveContainer width=\"100%\" height=\"100%\" maxHeight={300}>\r\n <RechartsPieChart>\r\n <Pie\r\n data={assetAllocation}\r\n cx=\"50%\"\r\n cy=\"50%\"\r\n labelLine={false}\r\n label={({ name, percent }) => `${name}: ${((percent || 0) * 100).toFixed(0)}%`}\r\n outerRadius={100}\r\n fill=\"#8884d8\"\r\n dataKey=\"value\"\r\n >\r\n {assetAllocation.map((entry, index) => (\r\n <Cell key={`cell-${index}`} fill={entry.color} />\r\n ))}\r\n </Pie>\r\n <Tooltip\r\n formatter={(value: any) => `${value}%`}\r\n contentStyle={{\r\n backgroundColor: 'white',\r\n border: '1px solid #e5e7eb',\r\n borderRadius: '8px'\r\n }}\r\n />\r\n </RechartsPieChart>\r\n </ResponsiveContainer>\r\n <div className=\"space-y-3 min-w-[180px]\">\r\n {assetAllocation.map((asset, index) => (\r\n <div key={asset.name} className=\"flex items-center gap-3\">\r\n <div\r\n className=\"w-4 h-4 rounded-full\"\r\n style={{ backgroundColor: asset.color }}\r\n />\r\n <div className=\"flex-1\">\r\n <div className=\"text-sm font-semibold text-gray-900 dark:text-white\">{asset.name}</div>\r\n <div className=\"text-xs text-gray-500 dark:text-gray-400\">{asset.value}%</div>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n );\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col gap-4\">\r\n {/* Chart Selector Controls */}\r\n <div className={`\r\n flex p-1 rounded-lg w-full overflow-x-auto overflow-y-visible flex-shrink-0\r\n ${isMUI ? 'bg-transparent border border-gray-300 dark:border-gray-700' : 'bg-gray-100 dark:bg-gray-800/50'}\r\n `}>\r\n <div className=\"flex gap-1 min-w-max\">\r\n {[\r\n { id: 'area', icon: AreaChart, label: 'Portfolio' },\r\n { id: 'candlestick', icon: TrendingUp, label: 'Candlestick' },\r\n { id: 'line', icon: LineChart, label: 'Price' },\r\n { id: 'bar', icon: BarChart3, label: 'Volume' },\r\n { id: 'pie', icon: PieChart, label: 'Allocation' },\r\n ].map(type => (\r\n <button\r\n key={type.id}\r\n onClick={() => setActiveTab(type.id as any)}\r\n className={`\r\n flex items-center gap-2 px-4 py-2 text-xs font-medium rounded-md transition-all whitespace-nowrap flex-shrink-0\r\n ${activeTab === type.id\r\n ? (isMUI ? `${getColorShade(globalConfig, 'bg', 50)} ${getColorShade(globalConfig, 'text', 600)}` : 'bg-white dark:bg-gray-700 shadow-sm text-gray-900 dark:text-white')\r\n : 'text-gray-500 hover:text-gray-900 dark:hover:text-gray-200'}\r\n `}\r\n >\r\n <type.icon size={14} />\r\n {type.label}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Chart Container */}\r\n <div className={`\r\n p-6 flex-1 flex flex-col min-h-0 overflow-hidden\r\n ${isMUI ? 'bg-white dark:bg-gray-900 shadow rounded border border-gray-200 dark:border-gray-800' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl border border-gray-200/50 dark:border-gray-700/50 shadow-sm rounded-3xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-100 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"mb-4 flex justify-between items-start flex-shrink-0\">\r\n <div>\r\n <h3 className=\"text-lg font-bold text-gray-900 dark:text-white tracking-tight\">\r\n {activeTab === 'area' && 'Portfolio Performance'}\r\n {activeTab === 'candlestick' && 'Stock Price Analysis'}\r\n {activeTab === 'line' && 'Price Trends'}\r\n {activeTab === 'bar' && 'Trading Volume'}\r\n {activeTab === 'pie' && 'Asset Allocation'}\r\n </h3>\r\n <p className=\"text-sm text-gray-500 mt-1\">\r\n {activeTab === 'area' && 'Portfolio value vs benchmark index'}\r\n {activeTab === 'candlestick' && 'Daily OHLC price movements'}\r\n {activeTab === 'line' && 'Close, high, and low prices over time'}\r\n {activeTab === 'bar' && 'Buy vs sell volume breakdown'}\r\n {activeTab === 'pie' && 'Current portfolio distribution'}\r\n </p>\r\n </div>\r\n {/* Time Range Selector */}\r\n <select className=\"text-xs bg-transparent border border-gray-200 dark:border-gray-800 rounded px-3 py-1.5 text-gray-500 dark:text-gray-400 outline-none focus:ring-2 focus:ring-blue-500 flex-shrink-0\">\r\n <option>Last 7 Days</option>\r\n <option>Last 30 Days</option>\r\n <option>Last 3 Months</option>\r\n <option>This Year</option>\r\n </select>\r\n </div>\r\n\r\n <div className=\"flex-1 flex items-center justify-center w-full min-h-0 overflow-hidden\">\r\n {activeTab === 'candlestick' && renderCandlestickChart()}\r\n {activeTab === 'area' && renderAreaChart()}\r\n {activeTab === 'line' && renderLineChart()}\r\n {activeTab === 'bar' && renderBarChart()}\r\n {activeTab === 'pie' && renderPieChart()}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Info } from 'lucide-react';\r\nimport { getAppliedStyles, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface ImageListProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\n// Mock Data\r\nconst itemData = [\r\n { img: 'https://images.unsplash.com/photo-1551963831-b3b1ca40c98e', title: 'Breakfast', author: '@bkristastucchio', rows: 2, cols: 2 },\r\n { img: 'https://images.unsplash.com/photo-1551782450-a2132b4ba21d', title: 'Burger', author: '@rollelflex_graphy' },\r\n { img: 'https://images.unsplash.com/photo-1522770179533-24471fcdba45', title: 'Camera', author: '@helloimnik' },\r\n { img: 'https://images.unsplash.com/photo-1444418776041-9c7e33cc5a9c', title: 'Coffee', author: '@nolanissac', cols: 2 },\r\n { img: 'https://images.unsplash.com/photo-1533827432537-70133748f5c8', title: 'Hats', author: '@hjrc33', cols: 2 },\r\n { img: 'https://images.unsplash.com/photo-1558642452-9d2a7deb7f62', title: 'Honey', author: '@arwinneil', rows: 2, cols: 2 },\r\n { img: 'https://images.unsplash.com/photo-1516802273409-68526ee1bdd6', title: 'Basketball', author: '@tjdragotta' },\r\n { img: 'https://images.unsplash.com/photo-1518756131217-31eb79b20e8f', title: 'Fern', author: '@katie_wasserman' },\r\n { img: 'https://images.unsplash.com/photo-1597645587822-e99fa5d45d25', title: 'Mushrooms', author: '@silverdalex', rows: 2, cols: 2 },\r\n { img: 'https://images.unsplash.com/photo-1567306301408-9b74779a11af', title: 'Tomato basil', author: '@shelleypauls' },\r\n { img: 'https://images.unsplash.com/photo-1471357674240-e1a485acb3e1', title: 'Sea star', author: '@peterlaster' },\r\n { img: 'https://images.unsplash.com/photo-1589118949245-7d38baf380d6', title: 'Bike', author: '@southside_customs', cols: 2 },\r\n];\r\n\r\nexport const ImageList: React.FC<ImageListProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isQuilted = componentProps.variant === 'secondary';\r\n const isMasonry = componentProps.variant === 'ghost';\r\n const isStandard = !isQuilted && !isMasonry;\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full overflow-y-auto p-2\">\r\n \r\n {/* Standard Grid */}\r\n {isStandard && (\r\n <div className={`grid grid-cols-2 md:grid-cols-3 gap-1 ${isMUI ? 'gap-1' : isApple ? 'gap-0.5' : 'gap-4'}`}>\r\n {itemData.map((item) => (\r\n <div key={item.img} className={`relative group aspect-square overflow-hidden ${isCustom ? getRadiusClass(globalConfig) : ''}`}>\r\n <img\r\n src={`${item.img}?w=164&h=164&fit=crop&auto=format`}\r\n alt={item.title}\r\n loading=\"lazy\"\r\n className=\"w-full h-full object-cover transition-transform duration-300 group-hover:scale-105\"\r\n />\r\n {isMUI && (\r\n <div className=\"absolute bottom-0 left-0 right-0 bg-black/60 p-2 flex justify-between items-center text-white\">\r\n <div className=\"truncate text-sm font-medium\">{item.title}</div>\r\n <Info size={16} className=\"text-gray-300\" />\r\n </div>\r\n )}\r\n {isCustom && (\r\n <div className=\"absolute inset-0 bg-black/0 group-hover:bg-black/20 transition-colors flex items-end p-4\">\r\n <span className=\"text-white font-medium opacity-0 group-hover:opacity-100 transition-opacity translate-y-2 group-hover:translate-y-0\">{item.title}</span>\r\n </div>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n\r\n {/* Quilted Grid */}\r\n {isQuilted && (\r\n <div \r\n className={`grid grid-cols-4 auto-rows-[100px] sm:auto-rows-[150px] gap-1 ${isMUI ? 'gap-1' : 'gap-4'}`}\r\n >\r\n {itemData.map((item, index) => (\r\n <div \r\n key={item.img} \r\n className={`\r\n relative overflow-hidden group\r\n ${item.cols === 2 ? 'col-span-2' : 'col-span-1'}\r\n ${item.rows === 2 ? 'row-span-2' : 'row-span-1'}\r\n ${isCustom || isApple ? getRadiusClass(globalConfig) : ''}\r\n `}\r\n >\r\n <img\r\n src={`${item.img}?w=${164 * (item.cols || 1)}&h=${164 * (item.rows || 1)}&fit=crop&auto=format`}\r\n alt={item.title}\r\n loading=\"lazy\"\r\n className=\"w-full h-full object-cover\"\r\n />\r\n {isMUI && (\r\n <div className=\"absolute bottom-0 left-0 right-0 bg-gradient-to-t from-black/80 to-transparent p-2 pt-8 text-white\">\r\n <div className=\"text-xs font-medium\">{item.title}</div>\r\n </div>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n\r\n {/* Masonry (Simulated with Columns) */}\r\n {isMasonry && (\r\n <div className={`columns-2 md:columns-3 ${isMUI ? 'gap-1' : 'gap-4'} space-y-4`}>\r\n {itemData.map((item) => (\r\n <div key={item.img} className={`relative break-inside-avoid mb-4 ${isCustom ? getRadiusClass(globalConfig) : ''} overflow-hidden`}>\r\n <img\r\n src={`${item.img}?w=248&fit=crop&auto=format`}\r\n alt={item.title}\r\n loading=\"lazy\"\r\n className=\"w-full h-auto block\"\r\n />\r\n {isMUI && (\r\n <div className=\"bg-white dark:bg-gray-800 p-2 shadow-sm border border-t-0 border-gray-200 dark:border-gray-700\">\r\n <div className=\"text-sm font-medium text-gray-900 dark:text-white\">{item.title}</div>\r\n <div className=\"text-xs text-gray-500\">{item.author}</div>\r\n </div>\r\n )}\r\n </div>\r\n ))}\r\n </div>\r\n )}\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Star } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\ninterface RatingProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Rating: React.FC<RatingProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [ratingValue, setRatingValue] = useState<number>(3);\r\n const [hoverValue, setHoverValue] = useState<number | null>(null);\r\n\r\n const stars = Array.from({ length: 5 }, (_, i) => i + 1);\r\n\r\n const getStarColor = (index: number) => {\r\n if (componentProps.isDisabled) return 'text-gray-300 dark:text-gray-600';\r\n \r\n const active = hoverValue !== null ? index <= hoverValue : index <= ratingValue;\r\n\r\n if (designSystem === 'MUI') {\r\n return active ? 'text-yellow-400' : 'text-gray-300 dark:text-gray-600';\r\n }\r\n if (designSystem === 'Apple') {\r\n return active ? 'text-orange-400' : 'text-gray-300 dark:text-gray-600';\r\n }\r\n return active ? getColorClass(globalConfig, 'text') : 'text-gray-300 dark:text-gray-600';\r\n };\r\n\r\n const getStarSize = () => {\r\n switch (componentProps.size) {\r\n case 'SM': return 16;\r\n case 'LG': return 32;\r\n default: return 24;\r\n }\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"flex items-center gap-1\">\r\n {stars.map(s => (\r\n <button\r\n key={s}\r\n disabled={componentProps.isDisabled}\r\n onMouseEnter={() => setHoverValue(s)}\r\n onMouseLeave={() => setHoverValue(null)}\r\n onClick={() => setRatingValue(s)}\r\n className={`transition-transform duration-100 ${hoverValue === s ? 'scale-110' : ''}`}\r\n >\r\n <Star \r\n size={getStarSize()} \r\n fill=\"currentColor\" \r\n className={getStarColor(s)} \r\n />\r\n </button>\r\n ))}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { \r\n MoreHorizontal, ArrowUpDown, ArrowUp, ArrowDown, \r\n Check, Download, Trash2, Edit2, Plus, Filter, Search,\r\n ChevronLeft, ChevronRight, ChevronsLeft, ChevronsRight\r\n} from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface TableProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\n// Mock Data Types\r\ninterface Transaction {\r\n id: string;\r\n customer: { name: string; email: string; initials: string; color: string };\r\n date: string;\r\n amount: string;\r\n status: 'Paid' | 'Pending' | 'Failed';\r\n method: string;\r\n}\r\n\r\nconst MOCK_DATA: Transaction[] = [\r\n { id: 'INV-001', customer: { name: 'Olivia Martin', email: 'olivia.martin@email.com', initials: 'OM', color: 'bg-red-100 text-red-600' }, date: 'Feb 20, 2024', amount: '$1,999.00', status: 'Paid', method: 'Credit Card' },\r\n { id: 'INV-002', customer: { name: 'Isabella Nguyen', email: 'isabella.ng@email.com', initials: 'IN', color: 'bg-blue-100 text-blue-600' }, date: 'Feb 19, 2024', amount: '$39.00', status: 'Pending', method: 'PayPal' },\r\n { id: 'INV-003', customer: { name: 'Emma Wilson', email: 'emma@wilson.com', initials: 'EW', color: 'bg-green-100 text-green-600' }, date: 'Feb 18, 2024', amount: '$299.00', status: 'Paid', method: 'Bank Transfer' },\r\n { id: 'INV-004', customer: { name: 'Jackson Lee', email: 'jackson.lee@email.com', initials: 'JL', color: 'bg-amber-100 text-amber-600' }, date: 'Feb 16, 2024', amount: '$899.00', status: 'Failed', method: 'Credit Card' },\r\n { id: 'INV-005', customer: { name: 'William Kim', email: 'will@kim.com', initials: 'WK', color: 'bg-purple-100 text-purple-600' }, date: 'Feb 14, 2024', amount: '$49.00', status: 'Paid', method: 'PayPal' },\r\n { id: 'INV-006', customer: { name: 'Sofia Davis', email: 'sofia.davis@email.com', initials: 'SD', color: 'bg-pink-100 text-pink-600' }, date: 'Feb 10, 2024', amount: '$1,299.00', status: 'Pending', method: 'Bank Transfer' },\r\n];\r\n\r\nexport const Table: React.FC<TableProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // State\r\n const [selectedRows, setSelectedRows] = useState<Set<string>>(new Set());\r\n const [sortConfig, setSortConfig] = useState<{ key: keyof Transaction; direction: 'asc' | 'desc' } | null>(null);\r\n const [page, setPage] = useState(1);\r\n \r\n // Selection Logic\r\n const toggleSelectAll = () => {\r\n if (selectedRows.size === MOCK_DATA.length) {\r\n setSelectedRows(new Set());\r\n } else {\r\n setSelectedRows(new Set(MOCK_DATA.map(d => d.id)));\r\n }\r\n };\r\n\r\n const toggleSelectRow = (id: string) => {\r\n const newSelected = new Set(selectedRows);\r\n if (newSelected.has(id)) {\r\n newSelected.delete(id);\r\n } else {\r\n newSelected.add(id);\r\n }\r\n setSelectedRows(newSelected);\r\n };\r\n\r\n // Sorting Logic (Visual only for mock)\r\n const handleSort = (key: keyof Transaction) => {\r\n let direction: 'asc' | 'desc' = 'asc';\r\n if (sortConfig && sortConfig.key === key && sortConfig.direction === 'asc') {\r\n direction = 'desc';\r\n }\r\n setSortConfig({ key, direction });\r\n };\r\n\r\n // Helpers\r\n const getStatusBadge = (status: string) => {\r\n const base = `px-2.5 py-1 rounded-full text-xs font-semibold flex items-center gap-1.5 w-fit transition-all`;\r\n if (status === 'Paid') return <span className={`${base} bg-green-50 text-green-700 dark:bg-green-900/30 dark:text-green-400 border border-green-200 dark:border-green-800`}><Check size={12} strokeWidth={3}/> Paid</span>;\r\n if (status === 'Pending') return <span className={`${base} bg-amber-50 text-amber-700 dark:bg-amber-900/30 dark:text-amber-400 border border-amber-200 dark:border-amber-800`}>Pending</span>;\r\n return <span className={`${base} bg-red-50 text-red-700 dark:bg-red-900/30 dark:text-red-400 border border-red-200 dark:border-red-800`}>Failed</span>;\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n const densityClass = componentProps.size === 'SM' ? 'py-2' : componentProps.size === 'LG' ? 'py-5' : 'py-3.5';\r\n \r\n // Dynamic Styles\r\n const primaryColorText = getColorClass(globalConfig, 'text');\r\n const primaryColorBg = getColorClass(globalConfig, 'bg');\r\n const primaryColorBorder = getColorClass(globalConfig, 'border');\r\n\r\n return (\r\n <div className=\"w-full h-full min-h-[400px] flex flex-col gap-4\">\r\n {/* Toolbar / Actions */}\r\n <div className=\"flex flex-col sm:flex-row justify-between items-start sm:items-center gap-3 sm:gap-4 pb-2\">\r\n <div className=\"flex items-center gap-2 sm:gap-3 flex-1 w-full sm:w-auto min-w-0\">\r\n <button className={`p-2 sm:p-2.5 rounded-lg transition-all hover:scale-105 flex-shrink-0 ${isMUI ? 'bg-white shadow-sm border border-gray-200 dark:border-gray-700 hover:shadow-md' : 'bg-gray-100 dark:bg-gray-800 hover:bg-gray-200 dark:hover:bg-gray-700'}`}>\r\n <Filter size={16} className=\"sm:w-[18px] sm:h-[18px] text-gray-600 dark:text-gray-300\" />\r\n </button>\r\n <div className=\"relative flex-1 min-w-0 sm:flex-initial sm:min-w-[200px] sm:max-w-[280px]\">\r\n <Search size={16} className=\"absolute left-2.5 sm:left-3.5 top-1/2 -translate-y-1/2 text-gray-400 dark:text-gray-500 sm:w-[18px] sm:h-[18px]\" />\r\n <input \r\n type=\"text\" \r\n placeholder=\"Filter transactions...\" \r\n className={`\r\n w-full pl-8 sm:pl-10 pr-3 sm:pr-4 py-2 sm:py-2.5 text-xs sm:text-sm bg-white dark:bg-gray-900 border rounded-lg \r\n focus:outline-none focus:ring-2 focus:ring-blue-500/20 focus:border-blue-300 dark:focus:border-blue-600\r\n transition-all placeholder:text-gray-400 dark:placeholder:text-gray-500\r\n ${isMUI ? 'border-gray-200 dark:border-gray-700' : 'border-gray-200 dark:border-gray-700 shadow-sm'}\r\n `}\r\n />\r\n </div>\r\n </div>\r\n \r\n <div className=\"flex gap-2 sm:gap-2.5 w-full sm:w-auto flex-shrink-0\">\r\n {selectedRows.size > 0 && (\r\n <button className=\"flex items-center gap-1.5 sm:gap-2 px-2.5 sm:px-4 py-2 sm:py-2.5 bg-red-50 dark:bg-red-900/20 text-red-600 dark:text-red-400 rounded-lg text-xs sm:text-sm font-semibold hover:bg-red-100 dark:hover:bg-red-900/30 transition-all border border-red-200 dark:border-red-800 flex-shrink-0\">\r\n <Trash2 size={14} className=\"sm:w-4 sm:h-4\" /> <span className=\"hidden sm:inline\">Delete ({selectedRows.size})</span><span className=\"sm:hidden\">{selectedRows.size}</span>\r\n </button>\r\n )}\r\n <button className={`flex items-center gap-1.5 sm:gap-2 px-3 sm:px-5 py-2 sm:py-2.5 text-white rounded-lg text-xs sm:text-sm font-semibold shadow-md hover:shadow-lg hover:scale-[1.02] active:scale-[0.98] transition-all ${primaryColorBg} flex-shrink-0 whitespace-nowrap`}>\r\n <Plus size={16} className=\"sm:w-[18px] sm:h-[18px]\" /> <span className=\"hidden sm:inline\">New Invoice</span><span className=\"sm:hidden\">New</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Table Container */}\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n w-full overflow-x-auto overflow-y-auto flex-1 min-h-0\r\n ${isMUI ? 'bg-white dark:bg-gray-900 shadow-md rounded-lg border border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl rounded-xl border border-gray-200/50 dark:border-gray-700/50 shadow-sm' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n <table className=\"w-full text-left text-sm border-collapse\">\r\n {/* Header */}\r\n <thead className={`\r\n sticky top-0 z-10\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-800 border-b-2 border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-gray-50/80 dark:bg-gray-800/80 backdrop-blur-sm border-b-2 border-gray-200 dark:border-gray-700' : ''}\r\n ${isCustom ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-200 dark:border-gray-800' : ''}\r\n `}>\r\n <tr>\r\n <th className=\"px-4 py-3.5 w-12\">\r\n <input \r\n type=\"checkbox\" \r\n className=\"w-4 h-4 rounded border-gray-300 text-blue-600 focus:ring-2 focus:ring-blue-500 focus:ring-offset-0 cursor-pointer transition-all\"\r\n checked={selectedRows.size === MOCK_DATA.length}\r\n onChange={toggleSelectAll}\r\n />\r\n </th>\r\n {[\r\n { key: 'id', label: 'Invoice' },\r\n { key: 'status', label: 'Status' },\r\n { key: 'method', label: 'Method' },\r\n { key: 'amount', label: 'Amount', align: 'right' },\r\n ].map((h) => (\r\n <th \r\n key={h.key} \r\n onClick={() => handleSort(h.key as keyof Transaction)}\r\n className={`\r\n px-4 py-3.5 font-semibold text-gray-700 dark:text-gray-300 cursor-pointer group \r\n hover:text-gray-900 dark:hover:text-gray-100 hover:bg-gray-100 dark:hover:bg-gray-800/50\r\n transition-all select-none\r\n ${h.align === 'right' ? 'text-right' : ''}\r\n ${isMUI ? 'uppercase text-xs tracking-wider' : 'text-sm'}\r\n `}\r\n >\r\n <div className={`flex items-center gap-2 ${h.align === 'right' ? 'justify-end' : ''}`}>\r\n <span>{h.label}</span>\r\n {sortConfig?.key === h.key ? (\r\n <span className=\"text-blue-600 dark:text-blue-400\">\r\n {sortConfig.direction === 'asc' ? <ArrowUp size={16} /> : <ArrowDown size={16} />}\r\n </span>\r\n ) : (\r\n <ArrowUpDown size={16} className=\"opacity-0 group-hover:opacity-40 text-gray-400 dark:text-gray-500 transition-opacity\" />\r\n )}\r\n </div>\r\n </th>\r\n ))}\r\n <th className=\"px-4 py-3.5 w-12\"></th>\r\n </tr>\r\n </thead>\r\n\r\n {/* Body */}\r\n <tbody className=\"divide-y divide-gray-100 dark:divide-gray-800\">\r\n {MOCK_DATA.map((row) => {\r\n const isSelected = selectedRows.has(row.id);\r\n return (\r\n <tr \r\n key={row.id}\r\n className={`\r\n group transition-all duration-150\r\n ${isSelected \r\n ? 'bg-blue-50 dark:bg-blue-900/20 border-l-2 border-blue-500 dark:border-blue-400' \r\n : 'hover:bg-gray-50 dark:hover:bg-gray-800/30 border-l-2 border-transparent'\r\n }\r\n `}\r\n >\r\n <td className=\"px-4 py-3\">\r\n <input \r\n type=\"checkbox\" \r\n className=\"w-4 h-4 rounded border-gray-300 text-blue-600 focus:ring-2 focus:ring-blue-500 focus:ring-offset-0 cursor-pointer transition-all\"\r\n checked={isSelected}\r\n onChange={() => toggleSelectRow(row.id)}\r\n />\r\n </td>\r\n \r\n {/* Invoice / Customer Cell */}\r\n <td className={`px-4 ${densityClass}`}>\r\n <div className=\"flex items-center gap-3\">\r\n <div className={`w-10 h-10 rounded-full flex items-center justify-center text-xs font-bold shadow-sm transition-transform group-hover:scale-110 ${row.customer.color}`}>\r\n {row.customer.initials}\r\n </div>\r\n <div className=\"min-w-0\">\r\n <div className=\"font-semibold text-gray-900 dark:text-white text-sm\">{row.id}</div>\r\n <div className=\"text-xs text-gray-500 dark:text-gray-400 truncate\">{row.customer.name}</div>\r\n </div>\r\n </div>\r\n </td>\r\n\r\n {/* Status */}\r\n <td className={`px-4 ${densityClass}`}>\r\n {getStatusBadge(row.status)}\r\n </td>\r\n\r\n {/* Method */}\r\n <td className={`px-4 ${densityClass}`}>\r\n <div className=\"flex items-center gap-2 text-sm text-gray-600 dark:text-gray-300\">\r\n <CreditCard size={16} className=\"opacity-60 dark:opacity-70\" />\r\n <span className=\"font-medium\">{row.method}</span>\r\n </div>\r\n </td>\r\n\r\n {/* Amount */}\r\n <td className={`px-4 ${densityClass} text-right`}>\r\n <span className=\"font-semibold text-gray-900 dark:text-white text-sm\">{row.amount}</span>\r\n </td>\r\n\r\n {/* Actions */}\r\n <td className={`px-4 ${densityClass}`}>\r\n <button className=\"p-1.5 rounded-md text-gray-400 hover:text-gray-700 dark:hover:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800 transition-all opacity-0 group-hover:opacity-100\">\r\n <MoreHorizontal size={18} />\r\n </button>\r\n </td>\r\n </tr>\r\n );\r\n })}\r\n </tbody>\r\n </table>\r\n \r\n {/* Loading Overlay */}\r\n {componentProps.isLoading && (\r\n <div className=\"absolute inset-0 bg-white/50 dark:bg-gray-900/50 backdrop-blur-sm flex items-center justify-center z-10\">\r\n <div className=\"flex flex-col items-center gap-2\">\r\n <div className={`w-8 h-8 border-4 border-t-transparent rounded-full animate-spin ${primaryColorBorder.replace('border-', 'border-t-transparent border-')}`}></div>\r\n <span className=\"text-sm font-medium text-gray-600 dark:text-gray-300\">Loading Data...</span>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n\r\n {/* Footer / Pagination */}\r\n <div className=\"px-4 py-3 border-t border-gray-200 dark:border-gray-800 bg-gray-50/50 dark:bg-gray-900/50 space-y-3\">\r\n {/* Row 1: Labels */}\r\n <div className=\"flex items-center justify-between\">\r\n <div className=\"text-xs text-gray-500 dark:text-gray-400\">\r\n {selectedRows.size > 0 ? (\r\n <span>{selectedRows.size} of {MOCK_DATA.length} row(s) selected.</span>\r\n ) : (\r\n <span>0 of {MOCK_DATA.length} row(s) selected.</span>\r\n )}\r\n </div>\r\n \r\n <div className=\"text-xs text-gray-500 dark:text-gray-400\">\r\n Page <span className=\"font-semibold text-gray-900 dark:text-white\">1</span> of <span className=\"font-semibold text-gray-900 dark:text-white\">10</span>\r\n </div>\r\n </div>\r\n \r\n {/* Row 2: Actions */}\r\n <div className=\"flex items-center justify-between\">\r\n <div className=\"flex items-center gap-2\">\r\n <span className=\"text-xs text-gray-500 dark:text-gray-400\">Rows per page</span>\r\n <select className=\"bg-white dark:bg-gray-900 text-xs border border-gray-200 dark:border-gray-700 rounded px-2 py-1 focus:outline-none focus:ring-1 focus:ring-blue-500/20 cursor-pointer\">\r\n <option>10</option>\r\n <option>20</option>\r\n <option>50</option>\r\n </select>\r\n </div>\r\n \r\n <div className=\"flex gap-0.5\">\r\n <button className=\"p-1.5 rounded border border-gray-200 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 disabled:opacity-40 disabled:cursor-not-allowed transition-colors\" disabled>\r\n <ChevronsLeft size={14} className=\"text-gray-400 dark:text-gray-500\" />\r\n </button>\r\n <button className=\"p-1.5 rounded border border-gray-200 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 disabled:opacity-40 disabled:cursor-not-allowed transition-colors\" disabled>\r\n <ChevronLeft size={14} className=\"text-gray-400 dark:text-gray-500\" />\r\n </button>\r\n <button className=\"p-1.5 rounded border border-gray-200 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 transition-colors\">\r\n <ChevronRight size={14} className=\"text-gray-600 dark:text-gray-300\" />\r\n </button>\r\n <button className=\"p-1.5 rounded border border-gray-200 dark:border-gray-700 hover:bg-gray-100 dark:hover:bg-gray-800 transition-colors\">\r\n <ChevronsRight size={14} className=\"text-gray-600 dark:text-gray-300\" />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\n// Simple Credit Card Icon for convenience in this file\r\nconst CreditCard = ({ size, className }: { size: number, className?: string }) => (\r\n <svg width={size} height={size} viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" className={className}>\r\n <rect width=\"20\" height=\"14\" x=\"2\" y=\"5\" rx=\"2\" />\r\n <line x1=\"2\" x2=\"22\" y1=\"10\" y2=\"10\" />\r\n </svg>\r\n);\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronRight, ChevronLeft } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface TransferListProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const TransferList: React.FC<TransferListProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div className=\"flex gap-4 items-center\">\r\n <div className=\"w-40 h-48 border border-gray-200 dark:border-gray-700 rounded bg-white dark:bg-gray-900 overflow-hidden\" style={appliedStyles}>\r\n <div className=\"p-2 border-b border-gray-100 dark:border-gray-800 bg-gray-50 dark:bg-gray-800/50 text-xs font-semibold\">Available</div>\r\n <div className=\"p-2 space-y-1\">\r\n {['Item 1', 'Item 2', 'Item 3'].map(i => (\r\n <div key={i} className=\"flex items-center gap-2 p-1 hover:bg-gray-100 dark:hover:bg-gray-800 rounded cursor-pointer\">\r\n <div className=\"w-3 h-3 border rounded\"></div>\r\n <span className=\"text-xs\">{i}</span>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n <div className=\"flex flex-col gap-2\">\r\n <button className=\"p-1 border rounded bg-white dark:bg-gray-800 hover:bg-gray-50\"><ChevronRight size={16}/></button>\r\n <button className=\"p-1 border rounded bg-white dark:bg-gray-800 hover:bg-gray-50\"><ChevronLeft size={16}/></button>\r\n </div>\r\n <div className=\"w-40 h-48 border border-gray-200 dark:border-gray-700 rounded bg-white dark:bg-gray-900 overflow-hidden\" style={appliedStyles}>\r\n <div className=\"p-2 border-b border-gray-100 dark:border-gray-800 bg-gray-50 dark:bg-gray-800/50 text-xs font-semibold\">Selected</div>\r\n <div className=\"p-2 space-y-1\">\r\n {['Item 4'].map(i => (\r\n <div key={i} className=\"flex items-center gap-2 p-1 hover:bg-gray-100 dark:hover:bg-gray-800 rounded cursor-pointer\">\r\n <div className={`w-3 h-3 border rounded ${getColorShade(globalConfig, 'bg', 500)} ${getColorShade(globalConfig, 'border', 500)}`}></div>\r\n <span className=\"text-xs\">{i}</span>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ChevronRight, ChevronDown, Folder, FolderOpen, File, Image, Film } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass } from '../utils/styleUtils';\r\n\r\ninterface TreeViewProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\n// Mock Data Structure\r\ntype TreeNode = {\r\n id: string;\r\n label: string;\r\n type: 'folder' | 'file' | 'image' | 'video';\r\n children?: TreeNode[];\r\n};\r\n\r\nconst TREE_DATA: TreeNode[] = [\r\n {\r\n id: 'root',\r\n label: 'Applications',\r\n type: 'folder',\r\n children: [\r\n { id: 'calendar', label: 'Calendar', type: 'file' },\r\n { id: 'chrome', label: 'Chrome', type: 'file' },\r\n { id: 'webstorm', label: 'WebStorm', type: 'file' },\r\n ],\r\n },\r\n {\r\n id: 'documents',\r\n label: 'Documents',\r\n type: 'folder',\r\n children: [\r\n {\r\n id: 'work',\r\n label: 'Work',\r\n type: 'folder',\r\n children: [\r\n { id: 'report', label: 'Expenses.xls', type: 'file' },\r\n { id: 'resume', label: 'Resume.docx', type: 'file' },\r\n ],\r\n },\r\n {\r\n id: 'media',\r\n label: 'Media',\r\n type: 'folder',\r\n children: [\r\n { id: 'pic1', label: 'Vacation.jpg', type: 'image' },\r\n { id: 'mov1', label: 'Demo.mp4', type: 'video' },\r\n ],\r\n },\r\n ],\r\n },\r\n {\r\n id: 'downloads',\r\n label: 'Downloads',\r\n type: 'folder',\r\n children: [],\r\n }\r\n];\r\n\r\nexport const TreeView: React.FC<TreeViewProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [expanded, setExpanded] = useState<Set<string>>(new Set(['root', 'documents']));\r\n const [selected, setSelected] = useState<string | null>('calendar');\r\n\r\n const toggleExpand = (id: string) => {\r\n const newExpanded = new Set(expanded);\r\n if (newExpanded.has(id)) {\r\n newExpanded.delete(id);\r\n } else {\r\n newExpanded.add(id);\r\n }\r\n setExpanded(newExpanded);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n const renderNode = (node: TreeNode, depth: number = 0) => {\r\n const isExpanded = expanded.has(node.id);\r\n const isSelected = selected === node.id;\r\n const hasChildren = node.children && node.children.length > 0;\r\n \r\n // Icon Logic\r\n let Icon = File;\r\n if (node.type === 'folder') Icon = isExpanded ? FolderOpen : Folder;\r\n if (node.type === 'image') Icon = Image;\r\n if (node.type === 'video') Icon = Film;\r\n\r\n const paddingLeft = depth * (isApple ? 20 : 16) + 12;\r\n\r\n return (\r\n <div key={node.id}>\r\n <div\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n setSelected(node.id);\r\n if (hasChildren || node.type === 'folder') toggleExpand(node.id);\r\n }}\r\n className={`\r\n flex items-center py-1.5 cursor-pointer select-none transition-colors relative\r\n ${isMUI ? `hover:bg-gray-100 dark:hover:bg-gray-800 ${isSelected ? 'bg-blue-50 dark:bg-blue-900/20 text-blue-700' : 'text-gray-700 dark:text-gray-200'}` : ''}\r\n ${isApple ? `mx-2 rounded-md ${isSelected ? 'bg-blue-500 text-white' : 'text-gray-700 dark:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800'}` : ''}\r\n ${isCustom ? `border-l-2 ${isSelected ? `bg-gray-50 dark:bg-gray-800/50 ${getColorClass(globalConfig, 'border')}` : 'border-transparent hover:border-gray-300 dark:hover:border-gray-700'}` : ''}\r\n `}\r\n style={{ paddingLeft }}\r\n >\r\n {/* Expander Icon */}\r\n <div className={`mr-2 w-4 h-4 flex items-center justify-center ${!hasChildren && node.type !== 'folder' ? 'opacity-0' : ''}`}>\r\n {isMUI && (isExpanded ? <ChevronDown size={16} /> : <ChevronRight size={16} />)}\r\n {isApple && (isExpanded ? <ChevronDown size={14} strokeWidth={3} /> : <ChevronRight size={14} strokeWidth={3} />)}\r\n {isCustom && (isExpanded ? <span className=\"text-xs font-mono\">-</span> : <span className=\"text-xs font-mono\">+</span>)}\r\n </div>\r\n\r\n {/* Node Icon */}\r\n <Icon \r\n size={18} \r\n className={`\r\n mr-2 \r\n ${isApple && node.type === 'folder' ? (isSelected ? 'text-white' : 'text-blue-400') : ''}\r\n ${isMUI ? 'text-gray-500' : ''}\r\n `} \r\n fill={isApple && node.type === 'folder' ? \"currentColor\" : \"none\"}\r\n />\r\n\r\n <span className=\"text-sm truncate\">{node.label}</span>\r\n </div>\r\n\r\n {/* Children */}\r\n {hasChildren && isExpanded && (\r\n <div className=\"relative\">\r\n {/* Guide Line for Custom */}\r\n {isCustom && <div className=\"absolute left-4 top-0 bottom-0 w-px bg-gray-200 dark:bg-gray-800\" style={{ left: paddingLeft + 7 }}></div>}\r\n {node.children!.map((child) => renderNode(child, depth + 1))}\r\n </div>\r\n )}\r\n </div>\r\n );\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-lg shadow-sm overflow-hidden\">\r\n <div className=\"flex-1 overflow-y-auto p-2 min-h-0\">\r\n {TREE_DATA.map(node => renderNode(node))}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { ShoppingBag, ArrowRight, CreditCard, ShieldCheck } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface OrderSummaryProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const OrderSummary: React.FC<OrderSummaryProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n w-full h-full min-h-[300px] p-6 flex flex-col gap-6 justify-between\r\n ${isMUI ? `bg-white dark:bg-gray-800 rounded shadow-md border-t-4 ${getColorShade(globalConfig, 'border', 600)}` : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl rounded-2xl shadow-xl border border-gray-200/50' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n <div className=\"flex items-center gap-3 pb-4 border-b border-gray-100 dark:border-gray-800 flex-shrink-0\">\r\n <div className={`p-2 rounded-lg ${isCustom ? 'bg-gray-100 dark:bg-gray-800' : `${getColorShade(globalConfig, 'bg', 50)} ${getColorShade(globalConfig, 'text', 600)}`}`}>\r\n <ShoppingBag size={20} />\r\n </div>\r\n <h3 className=\"font-bold text-gray-900 dark:text-white\">Order Summary</h3>\r\n </div>\r\n\r\n <div className=\"space-y-4 flex-1 min-h-0 overflow-y-auto\">\r\n {[\r\n { label: 'Subtotal', val: '$240.00' },\r\n { label: 'Shipping Estimate', val: '$15.00' },\r\n { label: 'Tax Estimate', val: '$24.50' }\r\n ].map((item) => (\r\n <div key={item.label} className=\"flex justify-between text-sm text-gray-600 dark:text-gray-400\">\r\n <span>{item.label}</span>\r\n <span className=\"font-medium text-gray-900 dark:text-white\">{item.val}</span>\r\n </div>\r\n ))}\r\n \r\n <div className=\"pt-4 border-t border-gray-100 dark:border-gray-800 flex justify-between items-center\">\r\n <div>\r\n <span className=\"block text-sm text-gray-500\">Order Total</span>\r\n <span className=\"text-xl font-bold text-gray-900 dark:text-white\">$279.50</span>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div className=\"flex flex-col gap-4 flex-shrink-0\">\r\n <button \r\n className={`\r\n w-full py-3 flex items-center justify-center gap-2 font-semibold text-white transition-all\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} shadow uppercase text-sm rounded` : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black rounded-xl hover:opacity-90' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} ${getRadiusClass(globalConfig)} hover:opacity-90` : ''}\r\n `}\r\n >\r\n Checkout <ArrowRight size={18} />\r\n </button>\r\n\r\n <div className=\"flex items-center justify-center gap-2 text-xs text-gray-500\">\r\n <ShieldCheck size={14} />\r\n Secure Encrypted Checkout\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","const common = {\n black: '#000',\n white: '#fff'\n};\nexport default common;","const red = {\n 50: '#ffebee',\n 100: '#ffcdd2',\n 200: '#ef9a9a',\n 300: '#e57373',\n 400: '#ef5350',\n 500: '#f44336',\n 600: '#e53935',\n 700: '#d32f2f',\n 800: '#c62828',\n 900: '#b71c1c',\n A100: '#ff8a80',\n A200: '#ff5252',\n A400: '#ff1744',\n A700: '#d50000'\n};\nexport default red;","const purple = {\n 50: '#f3e5f5',\n 100: '#e1bee7',\n 200: '#ce93d8',\n 300: '#ba68c8',\n 400: '#ab47bc',\n 500: '#9c27b0',\n 600: '#8e24aa',\n 700: '#7b1fa2',\n 800: '#6a1b9a',\n 900: '#4a148c',\n A100: '#ea80fc',\n A200: '#e040fb',\n A400: '#d500f9',\n A700: '#aa00ff'\n};\nexport default purple;","const blue = {\n 50: '#e3f2fd',\n 100: '#bbdefb',\n 200: '#90caf9',\n 300: '#64b5f6',\n 400: '#42a5f5',\n 500: '#2196f3',\n 600: '#1e88e5',\n 700: '#1976d2',\n 800: '#1565c0',\n 900: '#0d47a1',\n A100: '#82b1ff',\n A200: '#448aff',\n A400: '#2979ff',\n A700: '#2962ff'\n};\nexport default blue;","const lightBlue = {\n 50: '#e1f5fe',\n 100: '#b3e5fc',\n 200: '#81d4fa',\n 300: '#4fc3f7',\n 400: '#29b6f6',\n 500: '#03a9f4',\n 600: '#039be5',\n 700: '#0288d1',\n 800: '#0277bd',\n 900: '#01579b',\n A100: '#80d8ff',\n A200: '#40c4ff',\n A400: '#00b0ff',\n A700: '#0091ea'\n};\nexport default lightBlue;","const green = {\n 50: '#e8f5e9',\n 100: '#c8e6c9',\n 200: '#a5d6a7',\n 300: '#81c784',\n 400: '#66bb6a',\n 500: '#4caf50',\n 600: '#43a047',\n 700: '#388e3c',\n 800: '#2e7d32',\n 900: '#1b5e20',\n A100: '#b9f6ca',\n A200: '#69f0ae',\n A400: '#00e676',\n A700: '#00c853'\n};\nexport default green;","const orange = {\n 50: '#fff3e0',\n 100: '#ffe0b2',\n 200: '#ffcc80',\n 300: '#ffb74d',\n 400: '#ffa726',\n 500: '#ff9800',\n 600: '#fb8c00',\n 700: '#f57c00',\n 800: '#ef6c00',\n 900: '#e65100',\n A100: '#ffd180',\n A200: '#ffab40',\n A400: '#ff9100',\n A700: '#ff6d00'\n};\nexport default orange;","const grey = {\n 50: '#fafafa',\n 100: '#f5f5f5',\n 200: '#eeeeee',\n 300: '#e0e0e0',\n 400: '#bdbdbd',\n 500: '#9e9e9e',\n 600: '#757575',\n 700: '#616161',\n 800: '#424242',\n 900: '#212121',\n A100: '#f5f5f5',\n A200: '#eeeeee',\n A400: '#bdbdbd',\n A700: '#616161'\n};\nexport default grey;","/**\n * WARNING: Don't import this directly. It's imported by the code generated by\n * `@mui/interal-babel-plugin-minify-errors`. Make sure to always use string literals in `Error`\n * constructors to ensure the plugin works as expected. Supported patterns include:\n * throw new Error('My message');\n * throw new Error(`My message: ${foo}`);\n * throw new Error(`My message: ${foo}` + 'another string');\n * ...\n * @param {number} code\n */\nexport default function formatMuiErrorMessage(code, ...args) {\n const url = new URL(`https://mui.com/production-error/?code=${code}`);\n args.forEach(arg => url.searchParams.append('args[]', arg));\n return `Minified MUI error #${code}; visit ${url} for the full message.`;\n}","export default '$$material';","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","var isDevelopment = false;\n\n/*\n\nBased off glamor's StyleSheet, thanks Sunil ❤️\n\nhigh performance StyleSheet for css-in-js systems\n\n- uses multiple style tags behind the scenes for millions of rules\n- uses `insertRule` for appending in production for *much* faster performance\n\n// usage\n\nimport { StyleSheet } from '@emotion/sheet'\n\nlet styleSheet = new StyleSheet({ key: '', container: document.head })\n\nstyleSheet.insert('#box { border: 1px solid red; }')\n- appends a css rule into the stylesheet\n\nstyleSheet.flush()\n- empties the stylesheet of all its contents\n\n*/\n\nfunction sheetForTag(tag) {\n if (tag.sheet) {\n return tag.sheet;\n } // this weirdness brought to you by firefox\n\n /* istanbul ignore next */\n\n\n for (var i = 0; i < document.styleSheets.length; i++) {\n if (document.styleSheets[i].ownerNode === tag) {\n return document.styleSheets[i];\n }\n } // this function should always return with a value\n // TS can't understand it though so we make it stop complaining here\n\n\n return undefined;\n}\n\nfunction createStyleElement(options) {\n var tag = document.createElement('style');\n tag.setAttribute('data-emotion', options.key);\n\n if (options.nonce !== undefined) {\n tag.setAttribute('nonce', options.nonce);\n }\n\n tag.appendChild(document.createTextNode(''));\n tag.setAttribute('data-s', '');\n return tag;\n}\n\nvar StyleSheet = /*#__PURE__*/function () {\n // Using Node instead of HTMLElement since container may be a ShadowRoot\n function StyleSheet(options) {\n var _this = this;\n\n this._insertTag = function (tag) {\n var before;\n\n if (_this.tags.length === 0) {\n if (_this.insertionPoint) {\n before = _this.insertionPoint.nextSibling;\n } else if (_this.prepend) {\n before = _this.container.firstChild;\n } else {\n before = _this.before;\n }\n } else {\n before = _this.tags[_this.tags.length - 1].nextSibling;\n }\n\n _this.container.insertBefore(tag, before);\n\n _this.tags.push(tag);\n };\n\n this.isSpeedy = options.speedy === undefined ? !isDevelopment : options.speedy;\n this.tags = [];\n this.ctr = 0;\n this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets\n\n this.key = options.key;\n this.container = options.container;\n this.prepend = options.prepend;\n this.insertionPoint = options.insertionPoint;\n this.before = null;\n }\n\n var _proto = StyleSheet.prototype;\n\n _proto.hydrate = function hydrate(nodes) {\n nodes.forEach(this._insertTag);\n };\n\n _proto.insert = function insert(rule) {\n // the max length is how many rules we have per style tag, it's 65000 in speedy mode\n // it's 1 in dev because we insert source maps that map a single rule to a location\n // and you can only have one source map per style tag\n if (this.ctr % (this.isSpeedy ? 65000 : 1) === 0) {\n this._insertTag(createStyleElement(this));\n }\n\n var tag = this.tags[this.tags.length - 1];\n\n if (this.isSpeedy) {\n var sheet = sheetForTag(tag);\n\n try {\n // this is the ultrafast version, works across browsers\n // the big drawback is that the css won't be editable in devtools\n sheet.insertRule(rule, sheet.cssRules.length);\n } catch (e) {\n }\n } else {\n tag.appendChild(document.createTextNode(rule));\n }\n\n this.ctr++;\n };\n\n _proto.flush = function flush() {\n this.tags.forEach(function (tag) {\n var _tag$parentNode;\n\n return (_tag$parentNode = tag.parentNode) == null ? void 0 : _tag$parentNode.removeChild(tag);\n });\n this.tags = [];\n this.ctr = 0;\n };\n\n return StyleSheet;\n}();\n\nexport { StyleSheet };\n","export var MS = '-ms-'\nexport var MOZ = '-moz-'\nexport var WEBKIT = '-webkit-'\n\nexport var COMMENT = 'comm'\nexport var RULESET = 'rule'\nexport var DECLARATION = 'decl'\n\nexport var PAGE = '@page'\nexport var MEDIA = '@media'\nexport var IMPORT = '@import'\nexport var CHARSET = '@charset'\nexport var VIEWPORT = '@viewport'\nexport var SUPPORTS = '@supports'\nexport var DOCUMENT = '@document'\nexport var NAMESPACE = '@namespace'\nexport var KEYFRAMES = '@keyframes'\nexport var FONT_FACE = '@font-face'\nexport var COUNTER_STYLE = '@counter-style'\nexport var FONT_FEATURE_VALUES = '@font-feature-values'\nexport var LAYER = '@layer'\n","/**\n * @param {number}\n * @return {number}\n */\nexport var abs = Math.abs\n\n/**\n * @param {number}\n * @return {string}\n */\nexport var from = String.fromCharCode\n\n/**\n * @param {object}\n * @return {object}\n */\nexport var assign = Object.assign\n\n/**\n * @param {string} value\n * @param {number} length\n * @return {number}\n */\nexport function hash (value, length) {\n\treturn charat(value, 0) ^ 45 ? (((((((length << 2) ^ charat(value, 0)) << 2) ^ charat(value, 1)) << 2) ^ charat(value, 2)) << 2) ^ charat(value, 3) : 0\n}\n\n/**\n * @param {string} value\n * @return {string}\n */\nexport function trim (value) {\n\treturn value.trim()\n}\n\n/**\n * @param {string} value\n * @param {RegExp} pattern\n * @return {string?}\n */\nexport function match (value, pattern) {\n\treturn (value = pattern.exec(value)) ? value[0] : value\n}\n\n/**\n * @param {string} value\n * @param {(string|RegExp)} pattern\n * @param {string} replacement\n * @return {string}\n */\nexport function replace (value, pattern, replacement) {\n\treturn value.replace(pattern, replacement)\n}\n\n/**\n * @param {string} value\n * @param {string} search\n * @return {number}\n */\nexport function indexof (value, search) {\n\treturn value.indexOf(search)\n}\n\n/**\n * @param {string} value\n * @param {number} index\n * @return {number}\n */\nexport function charat (value, index) {\n\treturn value.charCodeAt(index) | 0\n}\n\n/**\n * @param {string} value\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function substr (value, begin, end) {\n\treturn value.slice(begin, end)\n}\n\n/**\n * @param {string} value\n * @return {number}\n */\nexport function strlen (value) {\n\treturn value.length\n}\n\n/**\n * @param {any[]} value\n * @return {number}\n */\nexport function sizeof (value) {\n\treturn value.length\n}\n\n/**\n * @param {any} value\n * @param {any[]} array\n * @return {any}\n */\nexport function append (value, array) {\n\treturn array.push(value), value\n}\n\n/**\n * @param {string[]} array\n * @param {function} callback\n * @return {string}\n */\nexport function combine (array, callback) {\n\treturn array.map(callback).join('')\n}\n","import {from, trim, charat, strlen, substr, append, assign} from './Utility.js'\n\nexport var line = 1\nexport var column = 1\nexport var length = 0\nexport var position = 0\nexport var character = 0\nexport var characters = ''\n\n/**\n * @param {string} value\n * @param {object | null} root\n * @param {object | null} parent\n * @param {string} type\n * @param {string[] | string} props\n * @param {object[] | string} children\n * @param {number} length\n */\nexport function node (value, root, parent, type, props, children, length) {\n\treturn {value: value, root: root, parent: parent, type: type, props: props, children: children, line: line, column: column, length: length, return: ''}\n}\n\n/**\n * @param {object} root\n * @param {object} props\n * @return {object}\n */\nexport function copy (root, props) {\n\treturn assign(node('', null, null, '', null, null, 0), root, {length: -root.length}, props)\n}\n\n/**\n * @return {number}\n */\nexport function char () {\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function prev () {\n\tcharacter = position > 0 ? charat(characters, --position) : 0\n\n\tif (column--, character === 10)\n\t\tcolumn = 1, line--\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function next () {\n\tcharacter = position < length ? charat(characters, position++) : 0\n\n\tif (column++, character === 10)\n\t\tcolumn = 1, line++\n\n\treturn character\n}\n\n/**\n * @return {number}\n */\nexport function peek () {\n\treturn charat(characters, position)\n}\n\n/**\n * @return {number}\n */\nexport function caret () {\n\treturn position\n}\n\n/**\n * @param {number} begin\n * @param {number} end\n * @return {string}\n */\nexport function slice (begin, end) {\n\treturn substr(characters, begin, end)\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function token (type) {\n\tswitch (type) {\n\t\t// \\0 \\t \\n \\r \\s whitespace token\n\t\tcase 0: case 9: case 10: case 13: case 32:\n\t\t\treturn 5\n\t\t// ! + , / > @ ~ isolate token\n\t\tcase 33: case 43: case 44: case 47: case 62: case 64: case 126:\n\t\t// ; { } breakpoint token\n\t\tcase 59: case 123: case 125:\n\t\t\treturn 4\n\t\t// : accompanied token\n\t\tcase 58:\n\t\t\treturn 3\n\t\t// \" ' ( [ opening delimit token\n\t\tcase 34: case 39: case 40: case 91:\n\t\t\treturn 2\n\t\t// ) ] closing delimit token\n\t\tcase 41: case 93:\n\t\t\treturn 1\n\t}\n\n\treturn 0\n}\n\n/**\n * @param {string} value\n * @return {any[]}\n */\nexport function alloc (value) {\n\treturn line = column = 1, length = strlen(characters = value), position = 0, []\n}\n\n/**\n * @param {any} value\n * @return {any}\n */\nexport function dealloc (value) {\n\treturn characters = '', value\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function delimit (type) {\n\treturn trim(slice(position - 1, delimiter(type === 91 ? type + 2 : type === 40 ? type + 1 : type)))\n}\n\n/**\n * @param {string} value\n * @return {string[]}\n */\nexport function tokenize (value) {\n\treturn dealloc(tokenizer(alloc(value)))\n}\n\n/**\n * @param {number} type\n * @return {string}\n */\nexport function whitespace (type) {\n\twhile (character = peek())\n\t\tif (character < 33)\n\t\t\tnext()\n\t\telse\n\t\t\tbreak\n\n\treturn token(type) > 2 || token(character) > 3 ? '' : ' '\n}\n\n/**\n * @param {string[]} children\n * @return {string[]}\n */\nexport function tokenizer (children) {\n\twhile (next())\n\t\tswitch (token(character)) {\n\t\t\tcase 0: append(identifier(position - 1), children)\n\t\t\t\tbreak\n\t\t\tcase 2: append(delimit(character), children)\n\t\t\t\tbreak\n\t\t\tdefault: append(from(character), children)\n\t\t}\n\n\treturn children\n}\n\n/**\n * @param {number} index\n * @param {number} count\n * @return {string}\n */\nexport function escaping (index, count) {\n\twhile (--count && next())\n\t\t// not 0-9 A-F a-f\n\t\tif (character < 48 || character > 102 || (character > 57 && character < 65) || (character > 70 && character < 97))\n\t\t\tbreak\n\n\treturn slice(index, caret() + (count < 6 && peek() == 32 && next() == 32))\n}\n\n/**\n * @param {number} type\n * @return {number}\n */\nexport function delimiter (type) {\n\twhile (next())\n\t\tswitch (character) {\n\t\t\t// ] ) \" '\n\t\t\tcase type:\n\t\t\t\treturn position\n\t\t\t// \" '\n\t\t\tcase 34: case 39:\n\t\t\t\tif (type !== 34 && type !== 39)\n\t\t\t\t\tdelimiter(character)\n\t\t\t\tbreak\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (type === 41)\n\t\t\t\t\tdelimiter(type)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tnext()\n\t\t\t\tbreak\n\t\t}\n\n\treturn position\n}\n\n/**\n * @param {number} type\n * @param {number} index\n * @return {number}\n */\nexport function commenter (type, index) {\n\twhile (next())\n\t\t// //\n\t\tif (type + character === 47 + 10)\n\t\t\tbreak\n\t\t// /*\n\t\telse if (type + character === 42 + 42 && peek() === 47)\n\t\t\tbreak\n\n\treturn '/*' + slice(index, position - 1) + '*' + from(type === 47 ? type : next())\n}\n\n/**\n * @param {number} index\n * @return {string}\n */\nexport function identifier (index) {\n\twhile (!token(peek()))\n\t\tnext()\n\n\treturn slice(index, position)\n}\n","import {COMMENT, RULESET, DECLARATION} from './Enum.js'\nimport {abs, charat, trim, from, sizeof, strlen, substr, append, replace, indexof} from './Utility.js'\nimport {node, char, prev, next, peek, caret, alloc, dealloc, delimit, whitespace, escaping, identifier, commenter} from './Tokenizer.js'\n\n/**\n * @param {string} value\n * @return {object[]}\n */\nexport function compile (value) {\n\treturn dealloc(parse('', null, null, null, [''], value = alloc(value), 0, [0], value))\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {string[]} rule\n * @param {string[]} rules\n * @param {string[]} rulesets\n * @param {number[]} pseudo\n * @param {number[]} points\n * @param {string[]} declarations\n * @return {object}\n */\nexport function parse (value, root, parent, rule, rules, rulesets, pseudo, points, declarations) {\n\tvar index = 0\n\tvar offset = 0\n\tvar length = pseudo\n\tvar atrule = 0\n\tvar property = 0\n\tvar previous = 0\n\tvar variable = 1\n\tvar scanning = 1\n\tvar ampersand = 1\n\tvar character = 0\n\tvar type = ''\n\tvar props = rules\n\tvar children = rulesets\n\tvar reference = rule\n\tvar characters = type\n\n\twhile (scanning)\n\t\tswitch (previous = character, character = next()) {\n\t\t\t// (\n\t\t\tcase 40:\n\t\t\t\tif (previous != 108 && charat(characters, length - 1) == 58) {\n\t\t\t\t\tif (indexof(characters += replace(delimit(character), '&', '&\\f'), '&\\f') != -1)\n\t\t\t\t\t\tampersand = -1\n\t\t\t\t\tbreak\n\t\t\t\t}\n\t\t\t// \" ' [\n\t\t\tcase 34: case 39: case 91:\n\t\t\t\tcharacters += delimit(character)\n\t\t\t\tbreak\n\t\t\t// \\t \\n \\r \\s\n\t\t\tcase 9: case 10: case 13: case 32:\n\t\t\t\tcharacters += whitespace(previous)\n\t\t\t\tbreak\n\t\t\t// \\\n\t\t\tcase 92:\n\t\t\t\tcharacters += escaping(caret() - 1, 7)\n\t\t\t\tcontinue\n\t\t\t// /\n\t\t\tcase 47:\n\t\t\t\tswitch (peek()) {\n\t\t\t\t\tcase 42: case 47:\n\t\t\t\t\t\tappend(comment(commenter(next(), caret()), root, parent), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tcharacters += '/'\n\t\t\t\t}\n\t\t\t\tbreak\n\t\t\t// {\n\t\t\tcase 123 * variable:\n\t\t\t\tpoints[index++] = strlen(characters) * ampersand\n\t\t\t// } ; \\0\n\t\t\tcase 125 * variable: case 59: case 0:\n\t\t\t\tswitch (character) {\n\t\t\t\t\t// \\0 }\n\t\t\t\t\tcase 0: case 125: scanning = 0\n\t\t\t\t\t// ;\n\t\t\t\t\tcase 59 + offset: if (ampersand == -1) characters = replace(characters, /\\f/g, '')\n\t\t\t\t\t\tif (property > 0 && (strlen(characters) - length))\n\t\t\t\t\t\t\tappend(property > 32 ? declaration(characters + ';', rule, parent, length - 1) : declaration(replace(characters, ' ', '') + ';', rule, parent, length - 2), declarations)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @ ;\n\t\t\t\t\tcase 59: characters += ';'\n\t\t\t\t\t// { rule/at-rule\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tappend(reference = ruleset(characters, root, parent, index, offset, rules, points, type, props = [], children = [], length), rulesets)\n\n\t\t\t\t\t\tif (character === 123)\n\t\t\t\t\t\t\tif (offset === 0)\n\t\t\t\t\t\t\t\tparse(characters, root, reference, reference, props, rulesets, length, points, children)\n\t\t\t\t\t\t\telse\n\t\t\t\t\t\t\t\tswitch (atrule === 99 && charat(characters, 3) === 110 ? 100 : atrule) {\n\t\t\t\t\t\t\t\t\t// d l m s\n\t\t\t\t\t\t\t\t\tcase 100: case 108: case 109: case 115:\n\t\t\t\t\t\t\t\t\t\tparse(value, reference, reference, rule && append(ruleset(value, reference, reference, 0, 0, rules, points, type, rules, props = [], length), children), rules, children, length, points, rule ? props : children)\n\t\t\t\t\t\t\t\t\t\tbreak\n\t\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\t\tparse(characters, reference, reference, reference, [''], children, 0, points, children)\n\t\t\t\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tindex = offset = property = 0, variable = ampersand = 1, type = characters = '', length = pseudo\n\t\t\t\tbreak\n\t\t\t// :\n\t\t\tcase 58:\n\t\t\t\tlength = 1 + strlen(characters), property = previous\n\t\t\tdefault:\n\t\t\t\tif (variable < 1)\n\t\t\t\t\tif (character == 123)\n\t\t\t\t\t\t--variable\n\t\t\t\t\telse if (character == 125 && variable++ == 0 && prev() == 125)\n\t\t\t\t\t\tcontinue\n\n\t\t\t\tswitch (characters += from(character), character * variable) {\n\t\t\t\t\t// &\n\t\t\t\t\tcase 38:\n\t\t\t\t\t\tampersand = offset > 0 ? 1 : (characters += '\\f', -1)\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// ,\n\t\t\t\t\tcase 44:\n\t\t\t\t\t\tpoints[index++] = (strlen(characters) - 1) * ampersand, ampersand = 1\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// @\n\t\t\t\t\tcase 64:\n\t\t\t\t\t\t// -\n\t\t\t\t\t\tif (peek() === 45)\n\t\t\t\t\t\t\tcharacters += delimit(next())\n\n\t\t\t\t\t\tatrule = peek(), offset = length = strlen(type = characters += identifier(caret())), character++\n\t\t\t\t\t\tbreak\n\t\t\t\t\t// -\n\t\t\t\t\tcase 45:\n\t\t\t\t\t\tif (previous === 45 && strlen(characters) == 2)\n\t\t\t\t\t\t\tvariable = 0\n\t\t\t\t}\n\t\t}\n\n\treturn rulesets\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} index\n * @param {number} offset\n * @param {string[]} rules\n * @param {number[]} points\n * @param {string} type\n * @param {string[]} props\n * @param {string[]} children\n * @param {number} length\n * @return {object}\n */\nexport function ruleset (value, root, parent, index, offset, rules, points, type, props, children, length) {\n\tvar post = offset - 1\n\tvar rule = offset === 0 ? rules : ['']\n\tvar size = sizeof(rule)\n\n\tfor (var i = 0, j = 0, k = 0; i < index; ++i)\n\t\tfor (var x = 0, y = substr(value, post + 1, post = abs(j = points[i])), z = value; x < size; ++x)\n\t\t\tif (z = trim(j > 0 ? rule[x] + ' ' + y : replace(y, /&\\f/g, rule[x])))\n\t\t\t\tprops[k++] = z\n\n\treturn node(value, root, parent, offset === 0 ? RULESET : type, props, children, length)\n}\n\n/**\n * @param {number} value\n * @param {object} root\n * @param {object?} parent\n * @return {object}\n */\nexport function comment (value, root, parent) {\n\treturn node(value, root, parent, COMMENT, from(char()), substr(value, 2, -2), 0)\n}\n\n/**\n * @param {string} value\n * @param {object} root\n * @param {object?} parent\n * @param {number} length\n * @return {object}\n */\nexport function declaration (value, root, parent, length) {\n\treturn node(value, root, parent, DECLARATION, substr(value, 0, length), substr(value, length + 1, -1), length)\n}\n","import {IMPORT, LAYER, COMMENT, RULESET, DECLARATION, KEYFRAMES} from './Enum.js'\nimport {strlen, sizeof} from './Utility.js'\n\n/**\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function serialize (children, callback) {\n\tvar output = ''\n\tvar length = sizeof(children)\n\n\tfor (var i = 0; i < length; i++)\n\t\toutput += callback(children[i], i, children, callback) || ''\n\n\treturn output\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n * @return {string}\n */\nexport function stringify (element, index, children, callback) {\n\tswitch (element.type) {\n\t\tcase LAYER: if (element.children.length) break\n\t\tcase IMPORT: case DECLARATION: return element.return = element.return || element.value\n\t\tcase COMMENT: return ''\n\t\tcase KEYFRAMES: return element.return = element.value + '{' + serialize(element.children, callback) + '}'\n\t\tcase RULESET: element.value = element.props.join(',')\n\t}\n\n\treturn strlen(children = serialize(element.children, callback)) ? element.return = element.value + '{' + children + '}' : ''\n}\n","import {MS, MOZ, WEBKIT, RULESET, KEYFRAMES, DECLARATION} from './Enum.js'\nimport {match, charat, substr, strlen, sizeof, replace, combine} from './Utility.js'\nimport {copy, tokenize} from './Tokenizer.js'\nimport {serialize} from './Serializer.js'\nimport {prefix} from './Prefixer.js'\n\n/**\n * @param {function[]} collection\n * @return {function}\n */\nexport function middleware (collection) {\n\tvar length = sizeof(collection)\n\n\treturn function (element, index, children, callback) {\n\t\tvar output = ''\n\n\t\tfor (var i = 0; i < length; i++)\n\t\t\toutput += collection[i](element, index, children, callback) || ''\n\n\t\treturn output\n\t}\n}\n\n/**\n * @param {function} callback\n * @return {function}\n */\nexport function rulesheet (callback) {\n\treturn function (element) {\n\t\tif (!element.root)\n\t\t\tif (element = element.return)\n\t\t\t\tcallback(element)\n\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n * @param {function} callback\n */\nexport function prefixer (element, index, children, callback) {\n\tif (element.length > -1)\n\t\tif (!element.return)\n\t\t\tswitch (element.type) {\n\t\t\t\tcase DECLARATION: element.return = prefix(element.value, element.length, children)\n\t\t\t\t\treturn\n\t\t\t\tcase KEYFRAMES:\n\t\t\t\t\treturn serialize([copy(element, {value: replace(element.value, '@', '@' + WEBKIT)})], callback)\n\t\t\t\tcase RULESET:\n\t\t\t\t\tif (element.length)\n\t\t\t\t\t\treturn combine(element.props, function (value) {\n\t\t\t\t\t\t\tswitch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n\t\t\t\t\t\t\t\t// :read-(only|write)\n\t\t\t\t\t\t\t\tcase ':read-only': case ':read-write':\n\t\t\t\t\t\t\t\t\treturn serialize([copy(element, {props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]})], callback)\n\t\t\t\t\t\t\t\t// :placeholder\n\t\t\t\t\t\t\t\tcase '::placeholder':\n\t\t\t\t\t\t\t\t\treturn serialize([\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]}),\n\t\t\t\t\t\t\t\t\t\tcopy(element, {props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]})\n\t\t\t\t\t\t\t\t\t], callback)\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\treturn ''\n\t\t\t\t\t\t})\n\t\t\t}\n}\n\n/**\n * @param {object} element\n * @param {number} index\n * @param {object[]} children\n */\nexport function namespace (element) {\n\tswitch (element.type) {\n\t\tcase RULESET:\n\t\t\telement.props = element.props.map(function (value) {\n\t\t\t\treturn combine(tokenize(value), function (value, index, children) {\n\t\t\t\t\tswitch (charat(value, 0)) {\n\t\t\t\t\t\t// \\f\n\t\t\t\t\t\tcase 12:\n\t\t\t\t\t\t\treturn substr(value, 1, strlen(value))\n\t\t\t\t\t\t// \\0 ( + > ~\n\t\t\t\t\t\tcase 0: case 40: case 43: case 62: case 126:\n\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t// :\n\t\t\t\t\t\tcase 58:\n\t\t\t\t\t\t\tif (children[++index] === 'global')\n\t\t\t\t\t\t\t\tchildren[index] = '', children[++index] = '\\f' + substr(children[index], index = 1, -1)\n\t\t\t\t\t\t// \\s\n\t\t\t\t\t\tcase 32:\n\t\t\t\t\t\t\treturn index === 1 ? '' : value\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tswitch (index) {\n\t\t\t\t\t\t\t\tcase 0: element = value\n\t\t\t\t\t\t\t\t\treturn sizeof(children) > 1 ? '' : value\n\t\t\t\t\t\t\t\tcase index = sizeof(children) - 1: case 2:\n\t\t\t\t\t\t\t\t\treturn index === 2 ? value + element + element : value + element\n\t\t\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t\t\treturn value\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t\t})\n\t}\n}\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport { memoize as default };\n","import { StyleSheet } from '@emotion/sheet';\nimport { dealloc, alloc, next, token, from, peek, delimit, slice, position, RULESET, combine, match, serialize, copy, replace, WEBKIT, MOZ, MS, KEYFRAMES, DECLARATION, hash, charat, strlen, indexof, stringify, rulesheet, middleware, compile } from 'stylis';\nimport '@emotion/weak-memoize';\nimport '@emotion/memoize';\n\nvar identifierWithPointTracking = function identifierWithPointTracking(begin, points, index) {\n var previous = 0;\n var character = 0;\n\n while (true) {\n previous = character;\n character = peek(); // &\\f\n\n if (previous === 38 && character === 12) {\n points[index] = 1;\n }\n\n if (token(character)) {\n break;\n }\n\n next();\n }\n\n return slice(begin, position);\n};\n\nvar toRules = function toRules(parsed, points) {\n // pretend we've started with a comma\n var index = -1;\n var character = 44;\n\n do {\n switch (token(character)) {\n case 0:\n // &\\f\n if (character === 38 && peek() === 12) {\n // this is not 100% correct, we don't account for literal sequences here - like for example quoted strings\n // stylis inserts \\f after & to know when & where it should replace this sequence with the context selector\n // and when it should just concatenate the outer and inner selectors\n // it's very unlikely for this sequence to actually appear in a different context, so we just leverage this fact here\n points[index] = 1;\n }\n\n parsed[index] += identifierWithPointTracking(position - 1, points, index);\n break;\n\n case 2:\n parsed[index] += delimit(character);\n break;\n\n case 4:\n // comma\n if (character === 44) {\n // colon\n parsed[++index] = peek() === 58 ? '&\\f' : '';\n points[index] = parsed[index].length;\n break;\n }\n\n // fallthrough\n\n default:\n parsed[index] += from(character);\n }\n } while (character = next());\n\n return parsed;\n};\n\nvar getRules = function getRules(value, points) {\n return dealloc(toRules(alloc(value), points));\n}; // WeakSet would be more appropriate, but only WeakMap is supported in IE11\n\n\nvar fixedElements = /* #__PURE__ */new WeakMap();\nvar compat = function compat(element) {\n if (element.type !== 'rule' || !element.parent || // positive .length indicates that this rule contains pseudo\n // negative .length indicates that this rule has been already prefixed\n element.length < 1) {\n return;\n }\n\n var value = element.value;\n var parent = element.parent;\n var isImplicitRule = element.column === parent.column && element.line === parent.line;\n\n while (parent.type !== 'rule') {\n parent = parent.parent;\n if (!parent) return;\n } // short-circuit for the simplest case\n\n\n if (element.props.length === 1 && value.charCodeAt(0) !== 58\n /* colon */\n && !fixedElements.get(parent)) {\n return;\n } // if this is an implicitly inserted rule (the one eagerly inserted at the each new nested level)\n // then the props has already been manipulated beforehand as they that array is shared between it and its \"rule parent\"\n\n\n if (isImplicitRule) {\n return;\n }\n\n fixedElements.set(element, true);\n var points = [];\n var rules = getRules(value, points);\n var parentRules = parent.props;\n\n for (var i = 0, k = 0; i < rules.length; i++) {\n for (var j = 0; j < parentRules.length; j++, k++) {\n element.props[k] = points[i] ? rules[i].replace(/&\\f/g, parentRules[j]) : parentRules[j] + \" \" + rules[i];\n }\n }\n};\nvar removeLabel = function removeLabel(element) {\n if (element.type === 'decl') {\n var value = element.value;\n\n if ( // charcode for l\n value.charCodeAt(0) === 108 && // charcode for b\n value.charCodeAt(2) === 98) {\n // this ignores label\n element[\"return\"] = '';\n element.value = '';\n }\n }\n};\n\n/* eslint-disable no-fallthrough */\n\nfunction prefix(value, length) {\n switch (hash(value, length)) {\n // color-adjust\n case 5103:\n return WEBKIT + 'print-' + value + value;\n // animation, animation-(delay|direction|duration|fill-mode|iteration-count|name|play-state|timing-function)\n\n case 5737:\n case 4201:\n case 3177:\n case 3433:\n case 1641:\n case 4457:\n case 2921: // text-decoration, filter, clip-path, backface-visibility, column, box-decoration-break\n\n case 5572:\n case 6356:\n case 5844:\n case 3191:\n case 6645:\n case 3005: // mask, mask-image, mask-(mode|clip|size), mask-(repeat|origin), mask-position, mask-composite,\n\n case 6391:\n case 5879:\n case 5623:\n case 6135:\n case 4599:\n case 4855: // background-clip, columns, column-(count|fill|gap|rule|rule-color|rule-style|rule-width|span|width)\n\n case 4215:\n case 6389:\n case 5109:\n case 5365:\n case 5621:\n case 3829:\n return WEBKIT + value + value;\n // appearance, user-select, transform, hyphens, text-size-adjust\n\n case 5349:\n case 4246:\n case 4810:\n case 6968:\n case 2756:\n return WEBKIT + value + MOZ + value + MS + value + value;\n // flex, flex-direction\n\n case 6828:\n case 4268:\n return WEBKIT + value + MS + value + value;\n // order\n\n case 6165:\n return WEBKIT + value + MS + 'flex-' + value + value;\n // align-items\n\n case 5187:\n return WEBKIT + value + replace(value, /(\\w+).+(:[^]+)/, WEBKIT + 'box-$1$2' + MS + 'flex-$1$2') + value;\n // align-self\n\n case 5443:\n return WEBKIT + value + MS + 'flex-item-' + replace(value, /flex-|-self/, '') + value;\n // align-content\n\n case 4675:\n return WEBKIT + value + MS + 'flex-line-pack' + replace(value, /align-content|flex-|-self/, '') + value;\n // flex-shrink\n\n case 5548:\n return WEBKIT + value + MS + replace(value, 'shrink', 'negative') + value;\n // flex-basis\n\n case 5292:\n return WEBKIT + value + MS + replace(value, 'basis', 'preferred-size') + value;\n // flex-grow\n\n case 6060:\n return WEBKIT + 'box-' + replace(value, '-grow', '') + WEBKIT + value + MS + replace(value, 'grow', 'positive') + value;\n // transition\n\n case 4554:\n return WEBKIT + replace(value, /([^-])(transform)/g, '$1' + WEBKIT + '$2') + value;\n // cursor\n\n case 6187:\n return replace(replace(replace(value, /(zoom-|grab)/, WEBKIT + '$1'), /(image-set)/, WEBKIT + '$1'), value, '') + value;\n // background, background-image\n\n case 5495:\n case 3959:\n return replace(value, /(image-set\\([^]*)/, WEBKIT + '$1' + '$`$1');\n // justify-content\n\n case 4968:\n return replace(replace(value, /(.+:)(flex-)?(.*)/, WEBKIT + 'box-pack:$3' + MS + 'flex-pack:$3'), /s.+-b[^;]+/, 'justify') + WEBKIT + value + value;\n // (margin|padding)-inline-(start|end)\n\n case 4095:\n case 3583:\n case 4068:\n case 2532:\n return replace(value, /(.+)-inline(.+)/, WEBKIT + '$1$2') + value;\n // (min|max)?(width|height|inline-size|block-size)\n\n case 8116:\n case 7059:\n case 5753:\n case 5535:\n case 5445:\n case 5701:\n case 4933:\n case 4677:\n case 5533:\n case 5789:\n case 5021:\n case 4765:\n // stretch, max-content, min-content, fill-available\n if (strlen(value) - 1 - length > 6) switch (charat(value, length + 1)) {\n // (m)ax-content, (m)in-content\n case 109:\n // -\n if (charat(value, length + 4) !== 45) break;\n // (f)ill-available, (f)it-content\n\n case 102:\n return replace(value, /(.+:)(.+)-([^]+)/, '$1' + WEBKIT + '$2-$3' + '$1' + MOZ + (charat(value, length + 3) == 108 ? '$3' : '$2-$3')) + value;\n // (s)tretch\n\n case 115:\n return ~indexof(value, 'stretch') ? prefix(replace(value, 'stretch', 'fill-available'), length) + value : value;\n }\n break;\n // position: sticky\n\n case 4949:\n // (s)ticky?\n if (charat(value, length + 1) !== 115) break;\n // display: (flex|inline-flex)\n\n case 6444:\n switch (charat(value, strlen(value) - 3 - (~indexof(value, '!important') && 10))) {\n // stic(k)y\n case 107:\n return replace(value, ':', ':' + WEBKIT) + value;\n // (inline-)?fl(e)x\n\n case 101:\n return replace(value, /(.+:)([^;!]+)(;|!.+)?/, '$1' + WEBKIT + (charat(value, 14) === 45 ? 'inline-' : '') + 'box$3' + '$1' + WEBKIT + '$2$3' + '$1' + MS + '$2box$3') + value;\n }\n\n break;\n // writing-mode\n\n case 5936:\n switch (charat(value, length + 11)) {\n // vertical-l(r)\n case 114:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb') + value;\n // vertical-r(l)\n\n case 108:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'tb-rl') + value;\n // horizontal(-)tb\n\n case 45:\n return WEBKIT + value + MS + replace(value, /[svh]\\w+-[tblr]{2}/, 'lr') + value;\n }\n\n return WEBKIT + value + MS + value + value;\n }\n\n return value;\n}\n\nvar prefixer = function prefixer(element, index, children, callback) {\n if (element.length > -1) if (!element[\"return\"]) switch (element.type) {\n case DECLARATION:\n element[\"return\"] = prefix(element.value, element.length);\n break;\n\n case KEYFRAMES:\n return serialize([copy(element, {\n value: replace(element.value, '@', '@' + WEBKIT)\n })], callback);\n\n case RULESET:\n if (element.length) return combine(element.props, function (value) {\n switch (match(value, /(::plac\\w+|:read-\\w+)/)) {\n // :read-(only|write)\n case ':read-only':\n case ':read-write':\n return serialize([copy(element, {\n props: [replace(value, /:(read-\\w+)/, ':' + MOZ + '$1')]\n })], callback);\n // :placeholder\n\n case '::placeholder':\n return serialize([copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + WEBKIT + 'input-$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, ':' + MOZ + '$1')]\n }), copy(element, {\n props: [replace(value, /:(plac\\w+)/, MS + 'input-$1')]\n })], callback);\n }\n\n return '';\n });\n }\n};\n\nvar defaultStylisPlugins = [prefixer];\n\nvar createCache = function createCache(options) {\n var key = options.key;\n\n if (key === 'css') {\n var ssrStyles = document.querySelectorAll(\"style[data-emotion]:not([data-s])\"); // get SSRed styles out of the way of React's hydration\n // document.head is a safe place to move them to(though note document.head is not necessarily the last place they will be)\n // note this very very intentionally targets all style elements regardless of the key to ensure\n // that creating a cache works inside of render of a React component\n\n Array.prototype.forEach.call(ssrStyles, function (node) {\n // we want to only move elements which have a space in the data-emotion attribute value\n // because that indicates that it is an Emotion 11 server-side rendered style elements\n // while we will already ignore Emotion 11 client-side inserted styles because of the :not([data-s]) part in the selector\n // Emotion 10 client-side inserted styles did not have data-s (but importantly did not have a space in their data-emotion attributes)\n // so checking for the space ensures that loading Emotion 11 after Emotion 10 has inserted some styles\n // will not result in the Emotion 10 styles being destroyed\n var dataEmotionAttribute = node.getAttribute('data-emotion');\n\n if (dataEmotionAttribute.indexOf(' ') === -1) {\n return;\n }\n\n document.head.appendChild(node);\n node.setAttribute('data-s', '');\n });\n }\n\n var stylisPlugins = options.stylisPlugins || defaultStylisPlugins;\n\n var inserted = {};\n var container;\n var nodesToHydrate = [];\n\n {\n container = options.container || document.head;\n Array.prototype.forEach.call( // this means we will ignore elements which don't have a space in them which\n // means that the style elements we're looking at are only Emotion 11 server-rendered style elements\n document.querySelectorAll(\"style[data-emotion^=\\\"\" + key + \" \\\"]\"), function (node) {\n var attrib = node.getAttribute(\"data-emotion\").split(' ');\n\n for (var i = 1; i < attrib.length; i++) {\n inserted[attrib[i]] = true;\n }\n\n nodesToHydrate.push(node);\n });\n }\n\n var _insert;\n\n var omnipresentPlugins = [compat, removeLabel];\n\n {\n var currentSheet;\n var finalizingPlugins = [stringify, rulesheet(function (rule) {\n currentSheet.insert(rule);\n })];\n var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins));\n\n var stylis = function stylis(styles) {\n return serialize(compile(styles), serializer);\n };\n\n _insert = function insert(selector, serialized, sheet, shouldCache) {\n currentSheet = sheet;\n\n stylis(selector ? selector + \"{\" + serialized.styles + \"}\" : serialized.styles);\n\n if (shouldCache) {\n cache.inserted[serialized.name] = true;\n }\n };\n }\n\n var cache = {\n key: key,\n sheet: new StyleSheet({\n key: key,\n container: container,\n nonce: options.nonce,\n speedy: options.speedy,\n prepend: options.prepend,\n insertionPoint: options.insertionPoint\n }),\n nonce: options.nonce,\n inserted: inserted,\n registered: {},\n insert: _insert\n };\n cache.sheet.hydrate(nodesToHydrate);\n return cache;\n};\n\nexport { createCache as default };\n","/** @license React v16.13.1\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';var b=\"function\"===typeof Symbol&&Symbol.for,c=b?Symbol.for(\"react.element\"):60103,d=b?Symbol.for(\"react.portal\"):60106,e=b?Symbol.for(\"react.fragment\"):60107,f=b?Symbol.for(\"react.strict_mode\"):60108,g=b?Symbol.for(\"react.profiler\"):60114,h=b?Symbol.for(\"react.provider\"):60109,k=b?Symbol.for(\"react.context\"):60110,l=b?Symbol.for(\"react.async_mode\"):60111,m=b?Symbol.for(\"react.concurrent_mode\"):60111,n=b?Symbol.for(\"react.forward_ref\"):60112,p=b?Symbol.for(\"react.suspense\"):60113,q=b?\nSymbol.for(\"react.suspense_list\"):60120,r=b?Symbol.for(\"react.memo\"):60115,t=b?Symbol.for(\"react.lazy\"):60116,v=b?Symbol.for(\"react.block\"):60121,w=b?Symbol.for(\"react.fundamental\"):60117,x=b?Symbol.for(\"react.responder\"):60118,y=b?Symbol.for(\"react.scope\"):60119;\nfunction z(a){if(\"object\"===typeof a&&null!==a){var u=a.$$typeof;switch(u){case c:switch(a=a.type,a){case l:case m:case e:case g:case f:case p:return a;default:switch(a=a&&a.$$typeof,a){case k:case n:case t:case r:case h:return a;default:return u}}case d:return u}}}function A(a){return z(a)===m}exports.AsyncMode=l;exports.ConcurrentMode=m;exports.ContextConsumer=k;exports.ContextProvider=h;exports.Element=c;exports.ForwardRef=n;exports.Fragment=e;exports.Lazy=t;exports.Memo=r;exports.Portal=d;\nexports.Profiler=g;exports.StrictMode=f;exports.Suspense=p;exports.isAsyncMode=function(a){return A(a)||z(a)===l};exports.isConcurrentMode=A;exports.isContextConsumer=function(a){return z(a)===k};exports.isContextProvider=function(a){return z(a)===h};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===c};exports.isForwardRef=function(a){return z(a)===n};exports.isFragment=function(a){return z(a)===e};exports.isLazy=function(a){return z(a)===t};\nexports.isMemo=function(a){return z(a)===r};exports.isPortal=function(a){return z(a)===d};exports.isProfiler=function(a){return z(a)===g};exports.isStrictMode=function(a){return z(a)===f};exports.isSuspense=function(a){return z(a)===p};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===e||a===m||a===g||a===f||a===p||a===q||\"object\"===typeof a&&null!==a&&(a.$$typeof===t||a.$$typeof===r||a.$$typeof===h||a.$$typeof===k||a.$$typeof===n||a.$$typeof===w||a.$$typeof===x||a.$$typeof===y||a.$$typeof===v)};exports.typeOf=z;\n","/** @license React v16.13.1\n * react-is.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\n\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n'use strict';\n\n// The Symbol used to tag the ReactElement-like types. If there is no native Symbol\n// nor polyfill, then a plain number is used for performance.\nvar hasSymbol = typeof Symbol === 'function' && Symbol.for;\nvar REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for('react.element') : 0xeac7;\nvar REACT_PORTAL_TYPE = hasSymbol ? Symbol.for('react.portal') : 0xeaca;\nvar REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for('react.fragment') : 0xeacb;\nvar REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for('react.strict_mode') : 0xeacc;\nvar REACT_PROFILER_TYPE = hasSymbol ? Symbol.for('react.profiler') : 0xead2;\nvar REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for('react.provider') : 0xeacd;\nvar REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for('react.context') : 0xeace; // TODO: We don't use AsyncMode or ConcurrentMode anymore. They were temporary\n// (unstable) APIs that have been removed. Can we remove the symbols?\n\nvar REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for('react.async_mode') : 0xeacf;\nvar REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for('react.concurrent_mode') : 0xeacf;\nvar REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for('react.forward_ref') : 0xead0;\nvar REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for('react.suspense') : 0xead1;\nvar REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for('react.suspense_list') : 0xead8;\nvar REACT_MEMO_TYPE = hasSymbol ? Symbol.for('react.memo') : 0xead3;\nvar REACT_LAZY_TYPE = hasSymbol ? Symbol.for('react.lazy') : 0xead4;\nvar REACT_BLOCK_TYPE = hasSymbol ? Symbol.for('react.block') : 0xead9;\nvar REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for('react.fundamental') : 0xead5;\nvar REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for('react.responder') : 0xead6;\nvar REACT_SCOPE_TYPE = hasSymbol ? Symbol.for('react.scope') : 0xead7;\n\nfunction isValidElementType(type) {\n return typeof type === 'string' || typeof type === 'function' || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.\n type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === 'object' && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);\n}\n\nfunction typeOf(object) {\n if (typeof object === 'object' && object !== null) {\n var $$typeof = object.$$typeof;\n\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n var type = object.type;\n\n switch (type) {\n case REACT_ASYNC_MODE_TYPE:\n case REACT_CONCURRENT_MODE_TYPE:\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n return type;\n\n default:\n var $$typeofType = type && type.$$typeof;\n\n switch ($$typeofType) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n case REACT_PROVIDER_TYPE:\n return $$typeofType;\n\n default:\n return $$typeof;\n }\n\n }\n\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n\n return undefined;\n} // AsyncMode is deprecated along with isAsyncMode\n\nvar AsyncMode = REACT_ASYNC_MODE_TYPE;\nvar ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;\nvar ContextConsumer = REACT_CONTEXT_TYPE;\nvar ContextProvider = REACT_PROVIDER_TYPE;\nvar Element = REACT_ELEMENT_TYPE;\nvar ForwardRef = REACT_FORWARD_REF_TYPE;\nvar Fragment = REACT_FRAGMENT_TYPE;\nvar Lazy = REACT_LAZY_TYPE;\nvar Memo = REACT_MEMO_TYPE;\nvar Portal = REACT_PORTAL_TYPE;\nvar Profiler = REACT_PROFILER_TYPE;\nvar StrictMode = REACT_STRICT_MODE_TYPE;\nvar Suspense = REACT_SUSPENSE_TYPE;\nvar hasWarnedAboutDeprecatedIsAsyncMode = false; // AsyncMode should be deprecated\n\nfunction isAsyncMode(object) {\n {\n if (!hasWarnedAboutDeprecatedIsAsyncMode) {\n hasWarnedAboutDeprecatedIsAsyncMode = true; // Using console['warn'] to evade Babel and ESLint\n\n console['warn']('The ReactIs.isAsyncMode() alias has been deprecated, ' + 'and will be removed in React 17+. Update your code to use ' + 'ReactIs.isConcurrentMode() instead. It has the exact same API.');\n }\n }\n\n return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;\n}\nfunction isConcurrentMode(object) {\n return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;\n}\nfunction isContextConsumer(object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n}\nfunction isContextProvider(object) {\n return typeOf(object) === REACT_PROVIDER_TYPE;\n}\nfunction isElement(object) {\n return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;\n}\nfunction isForwardRef(object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n}\nfunction isFragment(object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n}\nfunction isLazy(object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n}\nfunction isMemo(object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n}\nfunction isPortal(object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n}\nfunction isProfiler(object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n}\nfunction isStrictMode(object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n}\nfunction isSuspense(object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n}\n\nexports.AsyncMode = AsyncMode;\nexports.ConcurrentMode = ConcurrentMode;\nexports.ContextConsumer = ContextConsumer;\nexports.ContextProvider = ContextProvider;\nexports.Element = Element;\nexports.ForwardRef = ForwardRef;\nexports.Fragment = Fragment;\nexports.Lazy = Lazy;\nexports.Memo = Memo;\nexports.Portal = Portal;\nexports.Profiler = Profiler;\nexports.StrictMode = StrictMode;\nexports.Suspense = Suspense;\nexports.isAsyncMode = isAsyncMode;\nexports.isConcurrentMode = isConcurrentMode;\nexports.isContextConsumer = isContextConsumer;\nexports.isContextProvider = isContextProvider;\nexports.isElement = isElement;\nexports.isForwardRef = isForwardRef;\nexports.isFragment = isFragment;\nexports.isLazy = isLazy;\nexports.isMemo = isMemo;\nexports.isPortal = isPortal;\nexports.isProfiler = isProfiler;\nexports.isStrictMode = isStrictMode;\nexports.isSuspense = isSuspense;\nexports.isValidElementType = isValidElementType;\nexports.typeOf = typeOf;\n })();\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","'use strict';\n\nvar reactIs = require('react-is');\n\n/**\n * Copyright 2015, Yahoo! Inc.\n * Copyrights licensed under the New BSD License. See the accompanying LICENSE file for terms.\n */\nvar REACT_STATICS = {\n childContextTypes: true,\n contextType: true,\n contextTypes: true,\n defaultProps: true,\n displayName: true,\n getDefaultProps: true,\n getDerivedStateFromError: true,\n getDerivedStateFromProps: true,\n mixins: true,\n propTypes: true,\n type: true\n};\nvar KNOWN_STATICS = {\n name: true,\n length: true,\n prototype: true,\n caller: true,\n callee: true,\n arguments: true,\n arity: true\n};\nvar FORWARD_REF_STATICS = {\n '$$typeof': true,\n render: true,\n defaultProps: true,\n displayName: true,\n propTypes: true\n};\nvar MEMO_STATICS = {\n '$$typeof': true,\n compare: true,\n defaultProps: true,\n displayName: true,\n propTypes: true,\n type: true\n};\nvar TYPE_STATICS = {};\nTYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;\nTYPE_STATICS[reactIs.Memo] = MEMO_STATICS;\n\nfunction getStatics(component) {\n // React v16.11 and below\n if (reactIs.isMemo(component)) {\n return MEMO_STATICS;\n } // React v16.12 and above\n\n\n return TYPE_STATICS[component['$$typeof']] || REACT_STATICS;\n}\n\nvar defineProperty = Object.defineProperty;\nvar getOwnPropertyNames = Object.getOwnPropertyNames;\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor;\nvar getPrototypeOf = Object.getPrototypeOf;\nvar objectPrototype = Object.prototype;\nfunction hoistNonReactStatics(targetComponent, sourceComponent, blacklist) {\n if (typeof sourceComponent !== 'string') {\n // don't hoist over string (html) components\n if (objectPrototype) {\n var inheritedComponent = getPrototypeOf(sourceComponent);\n\n if (inheritedComponent && inheritedComponent !== objectPrototype) {\n hoistNonReactStatics(targetComponent, inheritedComponent, blacklist);\n }\n }\n\n var keys = getOwnPropertyNames(sourceComponent);\n\n if (getOwnPropertySymbols) {\n keys = keys.concat(getOwnPropertySymbols(sourceComponent));\n }\n\n var targetStatics = getStatics(targetComponent);\n var sourceStatics = getStatics(sourceComponent);\n\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n\n if (!KNOWN_STATICS[key] && !(blacklist && blacklist[key]) && !(sourceStatics && sourceStatics[key]) && !(targetStatics && targetStatics[key])) {\n var descriptor = getOwnPropertyDescriptor(sourceComponent, key);\n\n try {\n // Avoid failures from read-only properties\n defineProperty(targetComponent, key, descriptor);\n } catch (e) {}\n }\n }\n }\n\n return targetComponent;\n}\n\nmodule.exports = hoistNonReactStatics;\n","var isBrowser = true;\n\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else if (className) {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport { murmur2 as default };\n","var unitlessKeys = {\n animationIterationCount: 1,\n aspectRatio: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n scale: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport { unitlessKeys as default };\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar isDevelopment = false;\n\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nvar noComponentSelectorMessage = 'Component selectors can only be used in conjunction with ' + '@emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware ' + 'compiler transform.';\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n var componentSelector = interpolation;\n\n if (componentSelector.__emotion_styles !== undefined) {\n\n return componentSelector;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n var keyframes = interpolation;\n\n if (keyframes.anim === 1) {\n cursor = {\n name: keyframes.name,\n styles: keyframes.styles,\n next: cursor\n };\n return keyframes.name;\n }\n\n var serializedStyles = interpolation;\n\n if (serializedStyles.styles !== undefined) {\n var next = serializedStyles.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = serializedStyles.styles + \";\";\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n }\n\n break;\n }\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n var asString = interpolation;\n\n if (registered == null) {\n return asString;\n }\n\n var cached = registered[asString];\n return cached !== undefined ? cached : asString;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var key in obj) {\n var value = obj[key];\n\n if (typeof value !== 'object') {\n var asString = value;\n\n if (registered != null && registered[asString] !== undefined) {\n string += key + \"{\" + registered[asString] + \"}\";\n } else if (isProcessableValue(asString)) {\n string += processStyleName(key) + \":\" + processStyleValue(key, asString) + \";\";\n }\n } else {\n if (key === 'NO_COMPONENT_SELECTOR' && isDevelopment) {\n throw new Error(noComponentSelectorMessage);\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(key) + \":\" + processStyleValue(key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n\n string += key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;{]+)\\s*(;|$)/g; // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\nvar cursor;\nfunction serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n var asTemplateStringsArr = strings;\n\n styles += asTemplateStringsArr[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n var templateStringsArr = strings;\n\n styles += templateStringsArr[i];\n }\n } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n}\n\nexport { serializeStyles };\n","import * as React from 'react';\n\nvar syncFallback = function syncFallback(create) {\n return create();\n};\n\nvar useInsertionEffect = React['useInsertion' + 'Effect'] ? React['useInsertion' + 'Effect'] : false;\nvar useInsertionEffectAlwaysWithSyncFallback = useInsertionEffect || syncFallback;\nvar useInsertionEffectWithLayoutFallback = useInsertionEffect || React.useLayoutEffect;\n\nexport { useInsertionEffectAlwaysWithSyncFallback, useInsertionEffectWithLayoutFallback };\n","import * as React from 'react';\nimport { useContext, forwardRef } from 'react';\nimport createCache from '@emotion/cache';\nimport _extends from '@babel/runtime/helpers/esm/extends';\nimport weakMemoize from '@emotion/weak-memoize';\nimport hoistNonReactStatics from '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\n\nvar isDevelopment = false;\n\nvar EmotionCacheContext = /* #__PURE__ */React.createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case\n// because this module is primarily intended for the browser and node\n// but it's also required in react native and similar environments sometimes\n// and we could have a special build just for that\n// but this is much easier and the native packages\n// might use a different theme context in the future anyway\ntypeof HTMLElement !== 'undefined' ? /* #__PURE__ */createCache({\n key: 'css'\n}) : null);\n\nvar CacheProvider = EmotionCacheContext.Provider;\nvar __unsafe_useEmotionCache = function useEmotionCache() {\n return useContext(EmotionCacheContext);\n};\n\nvar withEmotionCache = function withEmotionCache(func) {\n return /*#__PURE__*/forwardRef(function (props, ref) {\n // the cache will never be null in the browser\n var cache = useContext(EmotionCacheContext);\n return func(props, cache, ref);\n });\n};\n\nvar ThemeContext = /* #__PURE__ */React.createContext({});\n\nvar useTheme = function useTheme() {\n return React.useContext(ThemeContext);\n};\n\nvar getTheme = function getTheme(outerTheme, theme) {\n if (typeof theme === 'function') {\n var mergedTheme = theme(outerTheme);\n\n return mergedTheme;\n }\n\n return _extends({}, outerTheme, theme);\n};\n\nvar createCacheWithTheme = /* #__PURE__ */weakMemoize(function (outerTheme) {\n return weakMemoize(function (theme) {\n return getTheme(outerTheme, theme);\n });\n});\nvar ThemeProvider = function ThemeProvider(props) {\n var theme = React.useContext(ThemeContext);\n\n if (props.theme !== theme) {\n theme = createCacheWithTheme(theme)(props.theme);\n }\n\n return /*#__PURE__*/React.createElement(ThemeContext.Provider, {\n value: theme\n }, props.children);\n};\nfunction withTheme(Component) {\n var componentName = Component.displayName || Component.name || 'Component';\n var WithTheme = /*#__PURE__*/React.forwardRef(function render(props, ref) {\n var theme = React.useContext(ThemeContext);\n return /*#__PURE__*/React.createElement(Component, _extends({\n theme: theme,\n ref: ref\n }, props));\n });\n WithTheme.displayName = \"WithTheme(\" + componentName + \")\";\n return hoistNonReactStatics(WithTheme, Component);\n}\n\nvar hasOwn = {}.hasOwnProperty;\n\nvar typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';\nvar createEmotionProps = function createEmotionProps(type, props) {\n\n var newProps = {};\n\n for (var _key in props) {\n if (hasOwn.call(props, _key)) {\n newProps[_key] = props[_key];\n }\n }\n\n newProps[typePropName] = type; // Runtime labeling is an opt-in feature because:\n\n return newProps;\n};\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar Emotion = /* #__PURE__ */withEmotionCache(function (props, cache, ref) {\n var cssProp = props.css; // so that using `css` from `emotion` and passing the result to the css prop works\n // not passing the registered cache to serializeStyles because it would\n // make certain babel optimisations not possible\n\n if (typeof cssProp === 'string' && cache.registered[cssProp] !== undefined) {\n cssProp = cache.registered[cssProp];\n }\n\n var WrappedComponent = props[typePropName];\n var registeredStyles = [cssProp];\n var className = '';\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, registeredStyles, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(registeredStyles, undefined, React.useContext(ThemeContext));\n\n className += cache.key + \"-\" + serialized.name;\n var newProps = {};\n\n for (var _key2 in props) {\n if (hasOwn.call(props, _key2) && _key2 !== 'css' && _key2 !== typePropName && (!isDevelopment )) {\n newProps[_key2] = props[_key2];\n }\n }\n\n newProps.className = className;\n\n if (ref) {\n newProps.ref = ref;\n }\n\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof WrappedComponent === 'string'\n }), /*#__PURE__*/React.createElement(WrappedComponent, newProps));\n});\n\nvar Emotion$1 = Emotion;\n\nexport { CacheProvider as C, Emotion$1 as E, ThemeContext as T, __unsafe_useEmotionCache as _, ThemeProvider as a, withTheme as b, createEmotionProps as c, hasOwn as h, isDevelopment as i, useTheme as u, withEmotionCache as w };\n","import { h as hasOwn, E as Emotion, c as createEmotionProps, w as withEmotionCache, T as ThemeContext, i as isDevelopment } from './emotion-element-f0de968e.browser.esm.js';\nexport { C as CacheProvider, T as ThemeContext, a as ThemeProvider, _ as __unsafe_useEmotionCache, u as useTheme, w as withEmotionCache, b as withTheme } from './emotion-element-f0de968e.browser.esm.js';\nimport * as React from 'react';\nimport { insertStyles, registerStyles, getRegisteredStyles } from '@emotion/utils';\nimport { useInsertionEffectWithLayoutFallback, useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\nimport { serializeStyles } from '@emotion/serialize';\nimport '@emotion/cache';\nimport '@babel/runtime/helpers/extends';\nimport '@emotion/weak-memoize';\nimport '../_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js';\nimport 'hoist-non-react-statics';\n\nvar jsx = function jsx(type, props) {\n // eslint-disable-next-line prefer-rest-params\n var args = arguments;\n\n if (props == null || !hasOwn.call(props, 'css')) {\n return React.createElement.apply(undefined, args);\n }\n\n var argsLength = args.length;\n var createElementArgArray = new Array(argsLength);\n createElementArgArray[0] = Emotion;\n createElementArgArray[1] = createEmotionProps(type, props);\n\n for (var i = 2; i < argsLength; i++) {\n createElementArgArray[i] = args[i];\n }\n\n return React.createElement.apply(null, createElementArgArray);\n};\n\n(function (_jsx) {\n var JSX;\n\n (function (_JSX) {})(JSX || (JSX = _jsx.JSX || (_jsx.JSX = {})));\n})(jsx || (jsx = {}));\n\n// initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild\n// initial client-side render from SSR, use place of hydrating tag\n\nvar Global = /* #__PURE__ */withEmotionCache(function (props, cache) {\n\n var styles = props.styles;\n var serialized = serializeStyles([styles], undefined, React.useContext(ThemeContext));\n // but it is based on a constant that will never change at runtime\n // it's effectively like having two implementations and switching them out\n // so it's not actually breaking anything\n\n\n var sheetRef = React.useRef();\n useInsertionEffectWithLayoutFallback(function () {\n var key = cache.key + \"-global\"; // use case of https://github.com/emotion-js/emotion/issues/2675\n\n var sheet = new cache.sheet.constructor({\n key: key,\n nonce: cache.sheet.nonce,\n container: cache.sheet.container,\n speedy: cache.sheet.isSpeedy\n });\n var rehydrating = false;\n var node = document.querySelector(\"style[data-emotion=\\\"\" + key + \" \" + serialized.name + \"\\\"]\");\n\n if (cache.sheet.tags.length) {\n sheet.before = cache.sheet.tags[0];\n }\n\n if (node !== null) {\n rehydrating = true; // clear the hash so this node won't be recognizable as rehydratable by other <Global/>s\n\n node.setAttribute('data-emotion', key);\n sheet.hydrate([node]);\n }\n\n sheetRef.current = [sheet, rehydrating];\n return function () {\n sheet.flush();\n };\n }, [cache]);\n useInsertionEffectWithLayoutFallback(function () {\n var sheetRefCurrent = sheetRef.current;\n var sheet = sheetRefCurrent[0],\n rehydrating = sheetRefCurrent[1];\n\n if (rehydrating) {\n sheetRefCurrent[1] = false;\n return;\n }\n\n if (serialized.next !== undefined) {\n // insert keyframes\n insertStyles(cache, serialized.next, true);\n }\n\n if (sheet.tags.length) {\n // if this doesn't exist then it will be null so the style element will be appended\n var element = sheet.tags[sheet.tags.length - 1].nextElementSibling;\n sheet.before = element;\n sheet.flush();\n }\n\n cache.insert(\"\", serialized, sheet, false);\n }, [cache, serialized.name]);\n return null;\n});\n\nfunction css() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return serializeStyles(args);\n}\n\nfunction keyframes() {\n var insertable = css.apply(void 0, arguments);\n var name = \"animation-\" + insertable.name;\n return {\n name: name,\n styles: \"@keyframes \" + name + \"{\" + insertable.styles + \"}\",\n anim: 1,\n toString: function toString() {\n return \"_EMO_\" + this.name + \"_\" + this.styles + \"_EMO_\";\n }\n };\n}\n\nvar classnames = function classnames(args) {\n var len = args.length;\n var i = 0;\n var cls = '';\n\n for (; i < len; i++) {\n var arg = args[i];\n if (arg == null) continue;\n var toAdd = void 0;\n\n switch (typeof arg) {\n case 'boolean':\n break;\n\n case 'object':\n {\n if (Array.isArray(arg)) {\n toAdd = classnames(arg);\n } else {\n\n toAdd = '';\n\n for (var k in arg) {\n if (arg[k] && k) {\n toAdd && (toAdd += ' ');\n toAdd += k;\n }\n }\n }\n\n break;\n }\n\n default:\n {\n toAdd = arg;\n }\n }\n\n if (toAdd) {\n cls && (cls += ' ');\n cls += toAdd;\n }\n }\n\n return cls;\n};\n\nfunction merge(registered, css, className) {\n var registeredStyles = [];\n var rawClassName = getRegisteredStyles(registered, registeredStyles, className);\n\n if (registeredStyles.length < 2) {\n return className;\n }\n\n return rawClassName + css(registeredStyles);\n}\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serializedArr = _ref.serializedArr;\n useInsertionEffectAlwaysWithSyncFallback(function () {\n\n for (var i = 0; i < serializedArr.length; i++) {\n insertStyles(cache, serializedArr[i], false);\n }\n });\n\n return null;\n};\n\nvar ClassNames = /* #__PURE__ */withEmotionCache(function (props, cache) {\n var hasRendered = false;\n var serializedArr = [];\n\n var css = function css() {\n if (hasRendered && isDevelopment) {\n throw new Error('css can only be used during render');\n }\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n var serialized = serializeStyles(args, cache.registered);\n serializedArr.push(serialized); // registration has to happen here as the result of this might get consumed by `cx`\n\n registerStyles(cache, serialized, false);\n return cache.key + \"-\" + serialized.name;\n };\n\n var cx = function cx() {\n if (hasRendered && isDevelopment) {\n throw new Error('cx can only be used during render');\n }\n\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return merge(cache.registered, css, classnames(args));\n };\n\n var content = {\n css: css,\n cx: cx,\n theme: React.useContext(ThemeContext)\n };\n var ele = props.children(content);\n hasRendered = true;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serializedArr: serializedArr\n }), ele);\n});\n\nexport { ClassNames, Global, jsx as createElement, css, jsx, keyframes };\n","import memoize from '@emotion/memoize';\n\n// eslint-disable-next-line no-undef\nvar reactPropsRegex = /^((children|dangerouslySetInnerHTML|key|ref|autoFocus|defaultValue|defaultChecked|innerHTML|suppressContentEditableWarning|suppressHydrationWarning|valueLink|abbr|accept|acceptCharset|accessKey|action|allow|allowUserMedia|allowPaymentRequest|allowFullScreen|allowTransparency|alt|async|autoComplete|autoPlay|capture|cellPadding|cellSpacing|challenge|charSet|checked|cite|classID|className|cols|colSpan|content|contentEditable|contextMenu|controls|controlsList|coords|crossOrigin|data|dateTime|decoding|default|defer|dir|disabled|disablePictureInPicture|disableRemotePlayback|download|draggable|encType|enterKeyHint|fetchpriority|fetchPriority|form|formAction|formEncType|formMethod|formNoValidate|formTarget|frameBorder|headers|height|hidden|high|href|hrefLang|htmlFor|httpEquiv|id|inputMode|integrity|is|keyParams|keyType|kind|label|lang|list|loading|loop|low|marginHeight|marginWidth|max|maxLength|media|mediaGroup|method|min|minLength|multiple|muted|name|nonce|noValidate|open|optimum|pattern|placeholder|playsInline|popover|popoverTarget|popoverTargetAction|poster|preload|profile|radioGroup|readOnly|referrerPolicy|rel|required|reversed|role|rows|rowSpan|sandbox|scope|scoped|scrolling|seamless|selected|shape|size|sizes|slot|span|spellCheck|src|srcDoc|srcLang|srcSet|start|step|style|summary|tabIndex|target|title|translate|type|useMap|value|width|wmode|wrap|about|datatype|inlist|prefix|property|resource|typeof|vocab|autoCapitalize|autoCorrect|autoSave|color|incremental|fallback|inert|itemProp|itemScope|itemType|itemID|itemRef|on|option|results|security|unselectable|accentHeight|accumulate|additive|alignmentBaseline|allowReorder|alphabetic|amplitude|arabicForm|ascent|attributeName|attributeType|autoReverse|azimuth|baseFrequency|baselineShift|baseProfile|bbox|begin|bias|by|calcMode|capHeight|clip|clipPathUnits|clipPath|clipRule|colorInterpolation|colorInterpolationFilters|colorProfile|colorRendering|contentScriptType|contentStyleType|cursor|cx|cy|d|decelerate|descent|diffuseConstant|direction|display|divisor|dominantBaseline|dur|dx|dy|edgeMode|elevation|enableBackground|end|exponent|externalResourcesRequired|fill|fillOpacity|fillRule|filter|filterRes|filterUnits|floodColor|floodOpacity|focusable|fontFamily|fontSize|fontSizeAdjust|fontStretch|fontStyle|fontVariant|fontWeight|format|from|fr|fx|fy|g1|g2|glyphName|glyphOrientationHorizontal|glyphOrientationVertical|glyphRef|gradientTransform|gradientUnits|hanging|horizAdvX|horizOriginX|ideographic|imageRendering|in|in2|intercept|k|k1|k2|k3|k4|kernelMatrix|kernelUnitLength|kerning|keyPoints|keySplines|keyTimes|lengthAdjust|letterSpacing|lightingColor|limitingConeAngle|local|markerEnd|markerMid|markerStart|markerHeight|markerUnits|markerWidth|mask|maskContentUnits|maskUnits|mathematical|mode|numOctaves|offset|opacity|operator|order|orient|orientation|origin|overflow|overlinePosition|overlineThickness|panose1|paintOrder|pathLength|patternContentUnits|patternTransform|patternUnits|pointerEvents|points|pointsAtX|pointsAtY|pointsAtZ|preserveAlpha|preserveAspectRatio|primitiveUnits|r|radius|refX|refY|renderingIntent|repeatCount|repeatDur|requiredExtensions|requiredFeatures|restart|result|rotate|rx|ry|scale|seed|shapeRendering|slope|spacing|specularConstant|specularExponent|speed|spreadMethod|startOffset|stdDeviation|stemh|stemv|stitchTiles|stopColor|stopOpacity|strikethroughPosition|strikethroughThickness|string|stroke|strokeDasharray|strokeDashoffset|strokeLinecap|strokeLinejoin|strokeMiterlimit|strokeOpacity|strokeWidth|surfaceScale|systemLanguage|tableValues|targetX|targetY|textAnchor|textDecoration|textRendering|textLength|to|transform|u1|u2|underlinePosition|underlineThickness|unicode|unicodeBidi|unicodeRange|unitsPerEm|vAlphabetic|vHanging|vIdeographic|vMathematical|values|vectorEffect|version|vertAdvY|vertOriginX|vertOriginY|viewBox|viewTarget|visibility|widths|wordSpacing|writingMode|x|xHeight|x1|x2|xChannelSelector|xlinkActuate|xlinkArcrole|xlinkHref|xlinkRole|xlinkShow|xlinkTitle|xlinkType|xmlBase|xmlns|xmlnsXlink|xmlLang|xmlSpace|y|y1|y2|yChannelSelector|z|zoomAndPan|for|class|autofocus)|(([Dd][Aa][Tt][Aa]|[Aa][Rr][Ii][Aa]|x)-.*))$/; // https://esbench.com/bench/5bfee68a4cd7e6009ef61d23\n\nvar isPropValid = /* #__PURE__ */memoize(function (prop) {\n return reactPropsRegex.test(prop) || prop.charCodeAt(0) === 111\n /* o */\n && prop.charCodeAt(1) === 110\n /* n */\n && prop.charCodeAt(2) < 91;\n}\n/* Z+1 */\n);\n\nexport { isPropValid as default };\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport { withEmotionCache, ThemeContext } from '@emotion/react';\nimport { serializeStyles } from '@emotion/serialize';\nimport { useInsertionEffectAlwaysWithSyncFallback } from '@emotion/use-insertion-effect-with-fallbacks';\nimport { getRegisteredStyles, registerStyles, insertStyles } from '@emotion/utils';\nimport * as React from 'react';\nimport isPropValid from '@emotion/is-prop-valid';\n\nvar isDevelopment = false;\n\nvar testOmitPropsOnStringTag = isPropValid;\n\nvar testOmitPropsOnComponent = function testOmitPropsOnComponent(key) {\n return key !== 'theme';\n};\n\nvar getDefaultShouldForwardProp = function getDefaultShouldForwardProp(tag) {\n return typeof tag === 'string' && // 96 is one less than the char code\n // for \"a\" so this is checking that\n // it's a lowercase character\n tag.charCodeAt(0) > 96 ? testOmitPropsOnStringTag : testOmitPropsOnComponent;\n};\nvar composeShouldForwardProps = function composeShouldForwardProps(tag, options, isReal) {\n var shouldForwardProp;\n\n if (options) {\n var optionsShouldForwardProp = options.shouldForwardProp;\n shouldForwardProp = tag.__emotion_forwardProp && optionsShouldForwardProp ? function (propName) {\n return tag.__emotion_forwardProp(propName) && optionsShouldForwardProp(propName);\n } : optionsShouldForwardProp;\n }\n\n if (typeof shouldForwardProp !== 'function' && isReal) {\n shouldForwardProp = tag.__emotion_forwardProp;\n }\n\n return shouldForwardProp;\n};\n\nvar Insertion = function Insertion(_ref) {\n var cache = _ref.cache,\n serialized = _ref.serialized,\n isStringTag = _ref.isStringTag;\n registerStyles(cache, serialized, isStringTag);\n useInsertionEffectAlwaysWithSyncFallback(function () {\n return insertStyles(cache, serialized, isStringTag);\n });\n\n return null;\n};\n\nvar createStyled = function createStyled(tag, options) {\n\n var isReal = tag.__emotion_real === tag;\n var baseTag = isReal && tag.__emotion_base || tag;\n var identifierName;\n var targetClassName;\n\n if (options !== undefined) {\n identifierName = options.label;\n targetClassName = options.target;\n }\n\n var shouldForwardProp = composeShouldForwardProps(tag, options, isReal);\n var defaultShouldForwardProp = shouldForwardProp || getDefaultShouldForwardProp(baseTag);\n var shouldUseAs = !defaultShouldForwardProp('as');\n return function () {\n // eslint-disable-next-line prefer-rest-params\n var args = arguments;\n var styles = isReal && tag.__emotion_styles !== undefined ? tag.__emotion_styles.slice(0) : [];\n\n if (identifierName !== undefined) {\n styles.push(\"label:\" + identifierName + \";\");\n }\n\n if (args[0] == null || args[0].raw === undefined) {\n // eslint-disable-next-line prefer-spread\n styles.push.apply(styles, args);\n } else {\n var templateStringsArr = args[0];\n\n styles.push(templateStringsArr[0]);\n var len = args.length;\n var i = 1;\n\n for (; i < len; i++) {\n\n styles.push(args[i], templateStringsArr[i]);\n }\n }\n\n var Styled = withEmotionCache(function (props, cache, ref) {\n var FinalTag = shouldUseAs && props.as || baseTag;\n var className = '';\n var classInterpolations = [];\n var mergedProps = props;\n\n if (props.theme == null) {\n mergedProps = {};\n\n for (var key in props) {\n mergedProps[key] = props[key];\n }\n\n mergedProps.theme = React.useContext(ThemeContext);\n }\n\n if (typeof props.className === 'string') {\n className = getRegisteredStyles(cache.registered, classInterpolations, props.className);\n } else if (props.className != null) {\n className = props.className + \" \";\n }\n\n var serialized = serializeStyles(styles.concat(classInterpolations), cache.registered, mergedProps);\n className += cache.key + \"-\" + serialized.name;\n\n if (targetClassName !== undefined) {\n className += \" \" + targetClassName;\n }\n\n var finalShouldForwardProp = shouldUseAs && shouldForwardProp === undefined ? getDefaultShouldForwardProp(FinalTag) : defaultShouldForwardProp;\n var newProps = {};\n\n for (var _key in props) {\n if (shouldUseAs && _key === 'as') continue;\n\n if (finalShouldForwardProp(_key)) {\n newProps[_key] = props[_key];\n }\n }\n\n newProps.className = className;\n\n if (ref) {\n newProps.ref = ref;\n }\n\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(Insertion, {\n cache: cache,\n serialized: serialized,\n isStringTag: typeof FinalTag === 'string'\n }), /*#__PURE__*/React.createElement(FinalTag, newProps));\n });\n Styled.displayName = identifierName !== undefined ? identifierName : \"Styled(\" + (typeof baseTag === 'string' ? baseTag : baseTag.displayName || baseTag.name || 'Component') + \")\";\n Styled.defaultProps = tag.defaultProps;\n Styled.__emotion_real = Styled;\n Styled.__emotion_base = baseTag;\n Styled.__emotion_styles = styles;\n Styled.__emotion_forwardProp = shouldForwardProp;\n Object.defineProperty(Styled, 'toString', {\n value: function value() {\n if (targetClassName === undefined && isDevelopment) {\n return 'NO_COMPONENT_SELECTOR';\n }\n\n return \".\" + targetClassName;\n }\n });\n\n Styled.withComponent = function (nextTag, nextOptions) {\n var newStyled = createStyled(nextTag, _extends({}, options, nextOptions, {\n shouldForwardProp: composeShouldForwardProps(Styled, nextOptions, true)\n }));\n return newStyled.apply(void 0, styles);\n };\n\n return Styled;\n };\n};\n\nexport { createStyled as default };\n","import createStyled from '../base/dist/emotion-styled-base.browser.esm.js';\nimport '@babel/runtime/helpers/extends';\nimport '@emotion/react';\nimport '@emotion/serialize';\nimport '@emotion/use-insertion-effect-with-fallbacks';\nimport '@emotion/utils';\nimport 'react';\nimport '@emotion/is-prop-valid';\n\nvar tags = ['a', 'abbr', 'address', 'area', 'article', 'aside', 'audio', 'b', 'base', 'bdi', 'bdo', 'big', 'blockquote', 'body', 'br', 'button', 'canvas', 'caption', 'cite', 'code', 'col', 'colgroup', 'data', 'datalist', 'dd', 'del', 'details', 'dfn', 'dialog', 'div', 'dl', 'dt', 'em', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'i', 'iframe', 'img', 'input', 'ins', 'kbd', 'keygen', 'label', 'legend', 'li', 'link', 'main', 'map', 'mark', 'marquee', 'menu', 'menuitem', 'meta', 'meter', 'nav', 'noscript', 'object', 'ol', 'optgroup', 'option', 'output', 'p', 'param', 'picture', 'pre', 'progress', 'q', 'rp', 'rt', 'ruby', 's', 'samp', 'script', 'section', 'select', 'small', 'source', 'span', 'strong', 'style', 'sub', 'summary', 'sup', 'table', 'tbody', 'td', 'textarea', 'tfoot', 'th', 'thead', 'time', 'title', 'tr', 'track', 'u', 'ul', 'var', 'video', 'wbr', // SVG\n'circle', 'clipPath', 'defs', 'ellipse', 'foreignObject', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'svg', 'text', 'tspan'];\n\n// bind it to avoid mutating the original function\nvar styled = createStyled.bind(null);\ntags.forEach(function (tagName) {\n styled[tagName] = styled(tagName);\n});\n\nexport { styled as default };\n","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc'); // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","module.exports = Function.call.bind(Object.prototype.hasOwnProperty);\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n var loggedTypeFailures = {};\n var has = require('./lib/has');\n\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) { /**/ }\n };\n}\n\n/**\n * Assert that the values match with the type specs.\n * Error messages are memorized and will only be shown once.\n *\n * @param {object} typeSpecs Map of name to a ReactPropType\n * @param {object} values Runtime values that need to be type-checked\n * @param {string} location e.g. \"prop\", \"context\", \"child context\"\n * @param {string} componentName Name of the component for error messages.\n * @param {?Function} getStack Returns the component stack.\n * @private\n */\nfunction checkPropTypes(typeSpecs, values, location, componentName, getStack) {\n if (process.env.NODE_ENV !== 'production') {\n for (var typeSpecName in typeSpecs) {\n if (has(typeSpecs, typeSpecName)) {\n var error;\n // Prop type validation may throw. In case they do, we don't want to\n // fail the render phase where it didn't fail before. So we log it.\n // After these have been cleaned up, we'll let them throw.\n try {\n // This is intentionally an invariant that gets caught. It's the same\n // behavior as without this statement except with a better message.\n if (typeof typeSpecs[typeSpecName] !== 'function') {\n var err = Error(\n (componentName || 'React class') + ': ' + location + ' type `' + typeSpecName + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + typeof typeSpecs[typeSpecName] + '`.' +\n 'This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`.'\n );\n err.name = 'Invariant Violation';\n throw err;\n }\n error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);\n } catch (ex) {\n error = ex;\n }\n if (error && !(error instanceof Error)) {\n printWarning(\n (componentName || 'React class') + ': type specification of ' +\n location + ' `' + typeSpecName + '` is invalid; the type checker ' +\n 'function must return `null` or an `Error` but returned a ' + typeof error + '. ' +\n 'You may have forgotten to pass an argument to the type checker ' +\n 'creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and ' +\n 'shape all require an argument).'\n );\n }\n if (error instanceof Error && !(error.message in loggedTypeFailures)) {\n // Only monitor this failure once because there tends to be a lot of the\n // same error.\n loggedTypeFailures[error.message] = true;\n\n var stack = getStack ? getStack() : '';\n\n printWarning(\n 'Failed ' + location + ' type: ' + error.message + (stack != null ? stack : '')\n );\n }\n }\n }\n }\n}\n\n/**\n * Resets warning cache when testing.\n *\n * @private\n */\ncheckPropTypes.resetWarningCache = function() {\n if (process.env.NODE_ENV !== 'production') {\n loggedTypeFailures = {};\n }\n}\n\nmodule.exports = checkPropTypes;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactIs = require('react-is');\nvar assign = require('object-assign');\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\nvar has = require('./lib/has');\nvar checkPropTypes = require('./checkPropTypes');\n\nvar printWarning = function() {};\n\nif (process.env.NODE_ENV !== 'production') {\n printWarning = function(text) {\n var message = 'Warning: ' + text;\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n };\n}\n\nfunction emptyFunctionThatReturnsNull() {\n return null;\n}\n\nmodule.exports = function(isValidElement, throwOnDirectAccess) {\n /* global Symbol */\n var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator;\n var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec.\n\n /**\n * Returns the iterator method function contained on the iterable object.\n *\n * Be sure to invoke the function with the iterable as context:\n *\n * var iteratorFn = getIteratorFn(myIterable);\n * if (iteratorFn) {\n * var iterator = iteratorFn.call(myIterable);\n * ...\n * }\n *\n * @param {?object} maybeIterable\n * @return {?function}\n */\n function getIteratorFn(maybeIterable) {\n var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);\n if (typeof iteratorFn === 'function') {\n return iteratorFn;\n }\n }\n\n /**\n * Collection of methods that allow declaration and validation of props that are\n * supplied to React components. Example usage:\n *\n * var Props = require('ReactPropTypes');\n * var MyArticle = React.createClass({\n * propTypes: {\n * // An optional string prop named \"description\".\n * description: Props.string,\n *\n * // A required enum prop named \"category\".\n * category: Props.oneOf(['News','Photos']).isRequired,\n *\n * // A prop named \"dialog\" that requires an instance of Dialog.\n * dialog: Props.instanceOf(Dialog).isRequired\n * },\n * render: function() { ... }\n * });\n *\n * A more formal specification of how these methods are used:\n *\n * type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...)\n * decl := ReactPropTypes.{type}(.isRequired)?\n *\n * Each and every declaration produces a function with the same signature. This\n * allows the creation of custom validation functions. For example:\n *\n * var MyLink = React.createClass({\n * propTypes: {\n * // An optional string or URI prop named \"href\".\n * href: function(props, propName, componentName) {\n * var propValue = props[propName];\n * if (propValue != null && typeof propValue !== 'string' &&\n * !(propValue instanceof URI)) {\n * return new Error(\n * 'Expected a string or an URI for ' + propName + ' in ' +\n * componentName\n * );\n * }\n * }\n * },\n * render: function() {...}\n * });\n *\n * @internal\n */\n\n var ANONYMOUS = '<<anonymous>>';\n\n // Important!\n // Keep this list in sync with production version in `./factoryWithThrowingShims.js`.\n var ReactPropTypes = {\n array: createPrimitiveTypeChecker('array'),\n bigint: createPrimitiveTypeChecker('bigint'),\n bool: createPrimitiveTypeChecker('boolean'),\n func: createPrimitiveTypeChecker('function'),\n number: createPrimitiveTypeChecker('number'),\n object: createPrimitiveTypeChecker('object'),\n string: createPrimitiveTypeChecker('string'),\n symbol: createPrimitiveTypeChecker('symbol'),\n\n any: createAnyTypeChecker(),\n arrayOf: createArrayOfTypeChecker,\n element: createElementTypeChecker(),\n elementType: createElementTypeTypeChecker(),\n instanceOf: createInstanceTypeChecker,\n node: createNodeChecker(),\n objectOf: createObjectOfTypeChecker,\n oneOf: createEnumTypeChecker,\n oneOfType: createUnionTypeChecker,\n shape: createShapeTypeChecker,\n exact: createStrictShapeTypeChecker,\n };\n\n /**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\n /*eslint-disable no-self-compare*/\n function is(x, y) {\n // SameValue algorithm\n if (x === y) {\n // Steps 1-5, 7-10\n // Steps 6.b-6.e: +0 != -0\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // Step 6.a: NaN == NaN\n return x !== x && y !== y;\n }\n }\n /*eslint-enable no-self-compare*/\n\n /**\n * We use an Error-like object for backward compatibility as people may call\n * PropTypes directly and inspect their output. However, we don't use real\n * Errors anymore. We don't inspect their stack anyway, and creating them\n * is prohibitively expensive if they are created too often, such as what\n * happens in oneOfType() for any type before the one that matched.\n */\n function PropTypeError(message, data) {\n this.message = message;\n this.data = data && typeof data === 'object' ? data: {};\n this.stack = '';\n }\n // Make `instanceof Error` still work for returned errors.\n PropTypeError.prototype = Error.prototype;\n\n function createChainableTypeChecker(validate) {\n if (process.env.NODE_ENV !== 'production') {\n var manualPropTypeCallCache = {};\n var manualPropTypeWarningCount = 0;\n }\n function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {\n componentName = componentName || ANONYMOUS;\n propFullName = propFullName || propName;\n\n if (secret !== ReactPropTypesSecret) {\n if (throwOnDirectAccess) {\n // New behavior only for users of `prop-types` package\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use `PropTypes.checkPropTypes()` to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n } else if (process.env.NODE_ENV !== 'production' && typeof console !== 'undefined') {\n // Old behavior for people using React.PropTypes\n var cacheKey = componentName + ':' + propName;\n if (\n !manualPropTypeCallCache[cacheKey] &&\n // Avoid spamming the console because they are often not actionable except for lib authors\n manualPropTypeWarningCount < 3\n ) {\n printWarning(\n 'You are manually calling a React.PropTypes validation ' +\n 'function for the `' + propFullName + '` prop on `' + componentName + '`. This is deprecated ' +\n 'and will throw in the standalone `prop-types` package. ' +\n 'You may be seeing this warning due to a third-party PropTypes ' +\n 'library. See https://fb.me/react-warning-dont-call-proptypes ' + 'for details.'\n );\n manualPropTypeCallCache[cacheKey] = true;\n manualPropTypeWarningCount++;\n }\n }\n }\n if (props[propName] == null) {\n if (isRequired) {\n if (props[propName] === null) {\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required ' + ('in `' + componentName + '`, but its value is `null`.'));\n }\n return new PropTypeError('The ' + location + ' `' + propFullName + '` is marked as required in ' + ('`' + componentName + '`, but its value is `undefined`.'));\n }\n return null;\n } else {\n return validate(props, propName, componentName, location, propFullName);\n }\n }\n\n var chainedCheckType = checkType.bind(null, false);\n chainedCheckType.isRequired = checkType.bind(null, true);\n\n return chainedCheckType;\n }\n\n function createPrimitiveTypeChecker(expectedType) {\n function validate(props, propName, componentName, location, propFullName, secret) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== expectedType) {\n // `propValue` being instance of, say, date/regexp, pass the 'object'\n // check, but we can offer a more precise error message here rather than\n // 'of type `object`'.\n var preciseType = getPreciseType(propValue);\n\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.'),\n {expectedType: expectedType}\n );\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createAnyTypeChecker() {\n return createChainableTypeChecker(emptyFunctionThatReturnsNull);\n }\n\n function createArrayOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside arrayOf.');\n }\n var propValue = props[propName];\n if (!Array.isArray(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.'));\n }\n for (var i = 0; i < propValue.length; i++) {\n var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']', ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!isValidElement(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createElementTypeTypeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n if (!ReactIs.isValidElementType(propValue)) {\n var propType = getPropType(propValue);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected a single ReactElement type.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createInstanceTypeChecker(expectedClass) {\n function validate(props, propName, componentName, location, propFullName) {\n if (!(props[propName] instanceof expectedClass)) {\n var expectedClassName = expectedClass.name || ANONYMOUS;\n var actualClassName = getClassName(props[propName]);\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createEnumTypeChecker(expectedValues) {\n if (!Array.isArray(expectedValues)) {\n if (process.env.NODE_ENV !== 'production') {\n if (arguments.length > 1) {\n printWarning(\n 'Invalid arguments supplied to oneOf, expected an array, got ' + arguments.length + ' arguments. ' +\n 'A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z]).'\n );\n } else {\n printWarning('Invalid argument supplied to oneOf, expected an array.');\n }\n }\n return emptyFunctionThatReturnsNull;\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n for (var i = 0; i < expectedValues.length; i++) {\n if (is(propValue, expectedValues[i])) {\n return null;\n }\n }\n\n var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {\n var type = getPreciseType(value);\n if (type === 'symbol') {\n return String(value);\n }\n return value;\n });\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of value `' + String(propValue) + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createObjectOfTypeChecker(typeChecker) {\n function validate(props, propName, componentName, location, propFullName) {\n if (typeof typeChecker !== 'function') {\n return new PropTypeError('Property `' + propFullName + '` of component `' + componentName + '` has invalid PropType notation inside objectOf.');\n }\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.'));\n }\n for (var key in propValue) {\n if (has(propValue, key)) {\n var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error instanceof Error) {\n return error;\n }\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createUnionTypeChecker(arrayOfTypeCheckers) {\n if (!Array.isArray(arrayOfTypeCheckers)) {\n process.env.NODE_ENV !== 'production' ? printWarning('Invalid argument supplied to oneOfType, expected an instance of array.') : void 0;\n return emptyFunctionThatReturnsNull;\n }\n\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n if (typeof checker !== 'function') {\n printWarning(\n 'Invalid argument supplied to oneOfType. Expected an array of check functions, but ' +\n 'received ' + getPostfixForTypeWarning(checker) + ' at index ' + i + '.'\n );\n return emptyFunctionThatReturnsNull;\n }\n }\n\n function validate(props, propName, componentName, location, propFullName) {\n var expectedTypes = [];\n for (var i = 0; i < arrayOfTypeCheckers.length; i++) {\n var checker = arrayOfTypeCheckers[i];\n var checkerResult = checker(props, propName, componentName, location, propFullName, ReactPropTypesSecret);\n if (checkerResult == null) {\n return null;\n }\n if (checkerResult.data && has(checkerResult.data, 'expectedType')) {\n expectedTypes.push(checkerResult.data.expectedType);\n }\n }\n var expectedTypesMessage = (expectedTypes.length > 0) ? ', expected one of type [' + expectedTypes.join(', ') + ']': '';\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`' + expectedTypesMessage + '.'));\n }\n return createChainableTypeChecker(validate);\n }\n\n function createNodeChecker() {\n function validate(props, propName, componentName, location, propFullName) {\n if (!isNode(props[propName])) {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.'));\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function invalidValidatorError(componentName, location, propFullName, key, type) {\n return new PropTypeError(\n (componentName || 'React class') + ': ' + location + ' type `' + propFullName + '.' + key + '` is invalid; ' +\n 'it must be a function, usually from the `prop-types` package, but received `' + type + '`.'\n );\n }\n\n function createShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n for (var key in shapeTypes) {\n var checker = shapeTypes[key];\n if (typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n return createChainableTypeChecker(validate);\n }\n\n function createStrictShapeTypeChecker(shapeTypes) {\n function validate(props, propName, componentName, location, propFullName) {\n var propValue = props[propName];\n var propType = getPropType(propValue);\n if (propType !== 'object') {\n return new PropTypeError('Invalid ' + location + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.'));\n }\n // We need to check all keys in case some are required but missing from props.\n var allKeys = assign({}, props[propName], shapeTypes);\n for (var key in allKeys) {\n var checker = shapeTypes[key];\n if (has(shapeTypes, key) && typeof checker !== 'function') {\n return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));\n }\n if (!checker) {\n return new PropTypeError(\n 'Invalid ' + location + ' `' + propFullName + '` key `' + key + '` supplied to `' + componentName + '`.' +\n '\\nBad object: ' + JSON.stringify(props[propName], null, ' ') +\n '\\nValid keys: ' + JSON.stringify(Object.keys(shapeTypes), null, ' ')\n );\n }\n var error = checker(propValue, key, componentName, location, propFullName + '.' + key, ReactPropTypesSecret);\n if (error) {\n return error;\n }\n }\n return null;\n }\n\n return createChainableTypeChecker(validate);\n }\n\n function isNode(propValue) {\n switch (typeof propValue) {\n case 'number':\n case 'string':\n case 'undefined':\n return true;\n case 'boolean':\n return !propValue;\n case 'object':\n if (Array.isArray(propValue)) {\n return propValue.every(isNode);\n }\n if (propValue === null || isValidElement(propValue)) {\n return true;\n }\n\n var iteratorFn = getIteratorFn(propValue);\n if (iteratorFn) {\n var iterator = iteratorFn.call(propValue);\n var step;\n if (iteratorFn !== propValue.entries) {\n while (!(step = iterator.next()).done) {\n if (!isNode(step.value)) {\n return false;\n }\n }\n } else {\n // Iterator will provide entry [k,v] tuples rather than values.\n while (!(step = iterator.next()).done) {\n var entry = step.value;\n if (entry) {\n if (!isNode(entry[1])) {\n return false;\n }\n }\n }\n }\n } else {\n return false;\n }\n\n return true;\n default:\n return false;\n }\n }\n\n function isSymbol(propType, propValue) {\n // Native Symbol.\n if (propType === 'symbol') {\n return true;\n }\n\n // falsy value can't be a Symbol\n if (!propValue) {\n return false;\n }\n\n // 19.4.3.5 Symbol.prototype[@@toStringTag] === 'Symbol'\n if (propValue['@@toStringTag'] === 'Symbol') {\n return true;\n }\n\n // Fallback for non-spec compliant Symbols which are polyfilled.\n if (typeof Symbol === 'function' && propValue instanceof Symbol) {\n return true;\n }\n\n return false;\n }\n\n // Equivalent of `typeof` but with special handling for array and regexp.\n function getPropType(propValue) {\n var propType = typeof propValue;\n if (Array.isArray(propValue)) {\n return 'array';\n }\n if (propValue instanceof RegExp) {\n // Old webkits (at least until Android 4.0) return 'function' rather than\n // 'object' for typeof a RegExp. We'll normalize this here so that /bla/\n // passes PropTypes.object.\n return 'object';\n }\n if (isSymbol(propType, propValue)) {\n return 'symbol';\n }\n return propType;\n }\n\n // This handles more types than `getPropType`. Only used for error messages.\n // See `createPrimitiveTypeChecker`.\n function getPreciseType(propValue) {\n if (typeof propValue === 'undefined' || propValue === null) {\n return '' + propValue;\n }\n var propType = getPropType(propValue);\n if (propType === 'object') {\n if (propValue instanceof Date) {\n return 'date';\n } else if (propValue instanceof RegExp) {\n return 'regexp';\n }\n }\n return propType;\n }\n\n // Returns a string that is postfixed to a warning about an invalid type.\n // For example, \"undefined\" or \"of type array\"\n function getPostfixForTypeWarning(value) {\n var type = getPreciseType(value);\n switch (type) {\n case 'array':\n case 'object':\n return 'an ' + type;\n case 'boolean':\n case 'date':\n case 'regexp':\n return 'a ' + type;\n default:\n return type;\n }\n }\n\n // Returns class name of the object, if any.\n function getClassName(propValue) {\n if (!propValue.constructor || !propValue.constructor.name) {\n return ANONYMOUS;\n }\n return propValue.constructor.name;\n }\n\n ReactPropTypes.checkPropTypes = checkPropTypes;\n ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * @mui/styled-engine v7.3.6\n *\n * @license MIT\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use client';\n\n/* eslint-disable no-underscore-dangle */\nimport emStyled from '@emotion/styled';\nimport { serializeStyles as emSerializeStyles } from '@emotion/serialize';\nexport default function styled(tag, options) {\n const stylesFactory = emStyled(tag, options);\n if (process.env.NODE_ENV !== 'production') {\n return (...styles) => {\n const component = typeof tag === 'string' ? `\"${tag}\"` : 'component';\n if (styles.length === 0) {\n console.error([`MUI: Seems like you called \\`styled(${component})()\\` without a \\`style\\` argument.`, 'You must provide a `styles` argument: `styled(\"div\")(styleYouForgotToPass)`.'].join('\\n'));\n } else if (styles.some(style => style === undefined)) {\n console.error(`MUI: the styled(${component})(...args) API requires all its args to be defined.`);\n }\n return stylesFactory(...styles);\n };\n }\n return stylesFactory;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_mutateStyles(tag, processor) {\n // Emotion attaches all the styles as `__emotion_styles`.\n // Ref: https://github.com/emotion-js/emotion/blob/16d971d0da229596d6bcc39d282ba9753c9ee7cf/packages/styled/src/base.js#L186\n if (Array.isArray(tag.__emotion_styles)) {\n tag.__emotion_styles = processor(tag.__emotion_styles);\n }\n}\n\n// Emotion only accepts an array, but we want to avoid allocations\nconst wrapper = [];\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_serializeStyles(styles) {\n wrapper[0] = styles;\n return emSerializeStyles(wrapper);\n}\nexport { ThemeContext, keyframes, css } from '@emotion/react';\nexport { default as StyledEngineProvider } from \"./StyledEngineProvider/index.js\";\nexport { default as GlobalStyles } from \"./GlobalStyles/index.js\";","/**\n * @license React\n * react-is.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\nfunction typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n}\nexports.ContextConsumer = REACT_CONSUMER_TYPE;\nexports.ContextProvider = REACT_CONTEXT_TYPE;\nexports.Element = REACT_ELEMENT_TYPE;\nexports.ForwardRef = REACT_FORWARD_REF_TYPE;\nexports.Fragment = REACT_FRAGMENT_TYPE;\nexports.Lazy = REACT_LAZY_TYPE;\nexports.Memo = REACT_MEMO_TYPE;\nexports.Portal = REACT_PORTAL_TYPE;\nexports.Profiler = REACT_PROFILER_TYPE;\nexports.StrictMode = REACT_STRICT_MODE_TYPE;\nexports.Suspense = REACT_SUSPENSE_TYPE;\nexports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\nexports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n};\nexports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n};\nexports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n};\nexports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n};\nexports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n};\nexports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n};\nexports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n};\nexports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n};\nexports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n};\nexports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n};\nexports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n};\nexports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n};\nexports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n};\nexports.typeOf = typeOf;\n","/**\n * @license React\n * react-is.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function typeOf(object) {\n if (\"object\" === typeof object && null !== object) {\n var $$typeof = object.$$typeof;\n switch ($$typeof) {\n case REACT_ELEMENT_TYPE:\n switch (((object = object.type), object)) {\n case REACT_FRAGMENT_TYPE:\n case REACT_PROFILER_TYPE:\n case REACT_STRICT_MODE_TYPE:\n case REACT_SUSPENSE_TYPE:\n case REACT_SUSPENSE_LIST_TYPE:\n case REACT_VIEW_TRANSITION_TYPE:\n return object;\n default:\n switch (((object = object && object.$$typeof), object)) {\n case REACT_CONTEXT_TYPE:\n case REACT_FORWARD_REF_TYPE:\n case REACT_LAZY_TYPE:\n case REACT_MEMO_TYPE:\n return object;\n case REACT_CONSUMER_TYPE:\n return object;\n default:\n return $$typeof;\n }\n }\n case REACT_PORTAL_TYPE:\n return $$typeof;\n }\n }\n }\n var REACT_ELEMENT_TYPE = Symbol.for(\"react.transitional.element\"),\n REACT_PORTAL_TYPE = Symbol.for(\"react.portal\"),\n REACT_FRAGMENT_TYPE = Symbol.for(\"react.fragment\"),\n REACT_STRICT_MODE_TYPE = Symbol.for(\"react.strict_mode\"),\n REACT_PROFILER_TYPE = Symbol.for(\"react.profiler\"),\n REACT_CONSUMER_TYPE = Symbol.for(\"react.consumer\"),\n REACT_CONTEXT_TYPE = Symbol.for(\"react.context\"),\n REACT_FORWARD_REF_TYPE = Symbol.for(\"react.forward_ref\"),\n REACT_SUSPENSE_TYPE = Symbol.for(\"react.suspense\"),\n REACT_SUSPENSE_LIST_TYPE = Symbol.for(\"react.suspense_list\"),\n REACT_MEMO_TYPE = Symbol.for(\"react.memo\"),\n REACT_LAZY_TYPE = Symbol.for(\"react.lazy\"),\n REACT_VIEW_TRANSITION_TYPE = Symbol.for(\"react.view_transition\"),\n REACT_CLIENT_REFERENCE = Symbol.for(\"react.client.reference\");\n exports.ContextConsumer = REACT_CONSUMER_TYPE;\n exports.ContextProvider = REACT_CONTEXT_TYPE;\n exports.Element = REACT_ELEMENT_TYPE;\n exports.ForwardRef = REACT_FORWARD_REF_TYPE;\n exports.Fragment = REACT_FRAGMENT_TYPE;\n exports.Lazy = REACT_LAZY_TYPE;\n exports.Memo = REACT_MEMO_TYPE;\n exports.Portal = REACT_PORTAL_TYPE;\n exports.Profiler = REACT_PROFILER_TYPE;\n exports.StrictMode = REACT_STRICT_MODE_TYPE;\n exports.Suspense = REACT_SUSPENSE_TYPE;\n exports.SuspenseList = REACT_SUSPENSE_LIST_TYPE;\n exports.isContextConsumer = function (object) {\n return typeOf(object) === REACT_CONSUMER_TYPE;\n };\n exports.isContextProvider = function (object) {\n return typeOf(object) === REACT_CONTEXT_TYPE;\n };\n exports.isElement = function (object) {\n return (\n \"object\" === typeof object &&\n null !== object &&\n object.$$typeof === REACT_ELEMENT_TYPE\n );\n };\n exports.isForwardRef = function (object) {\n return typeOf(object) === REACT_FORWARD_REF_TYPE;\n };\n exports.isFragment = function (object) {\n return typeOf(object) === REACT_FRAGMENT_TYPE;\n };\n exports.isLazy = function (object) {\n return typeOf(object) === REACT_LAZY_TYPE;\n };\n exports.isMemo = function (object) {\n return typeOf(object) === REACT_MEMO_TYPE;\n };\n exports.isPortal = function (object) {\n return typeOf(object) === REACT_PORTAL_TYPE;\n };\n exports.isProfiler = function (object) {\n return typeOf(object) === REACT_PROFILER_TYPE;\n };\n exports.isStrictMode = function (object) {\n return typeOf(object) === REACT_STRICT_MODE_TYPE;\n };\n exports.isSuspense = function (object) {\n return typeOf(object) === REACT_SUSPENSE_TYPE;\n };\n exports.isSuspenseList = function (object) {\n return typeOf(object) === REACT_SUSPENSE_LIST_TYPE;\n };\n exports.isValidElementType = function (type) {\n return \"string\" === typeof type ||\n \"function\" === typeof type ||\n type === REACT_FRAGMENT_TYPE ||\n type === REACT_PROFILER_TYPE ||\n type === REACT_STRICT_MODE_TYPE ||\n type === REACT_SUSPENSE_TYPE ||\n type === REACT_SUSPENSE_LIST_TYPE ||\n (\"object\" === typeof type &&\n null !== type &&\n (type.$$typeof === REACT_LAZY_TYPE ||\n type.$$typeof === REACT_MEMO_TYPE ||\n type.$$typeof === REACT_CONTEXT_TYPE ||\n type.$$typeof === REACT_CONSUMER_TYPE ||\n type.$$typeof === REACT_FORWARD_REF_TYPE ||\n type.$$typeof === REACT_CLIENT_REFERENCE ||\n void 0 !== type.getModuleId))\n ? !0\n : !1;\n };\n exports.typeOf = typeOf;\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","import * as React from 'react';\nimport { isValidElementType } from 'react-is';\n\n// https://github.com/sindresorhus/is-plain-obj/blob/main/index.js\nexport function isPlainObject(item) {\n if (typeof item !== 'object' || item === null) {\n return false;\n }\n const prototype = Object.getPrototypeOf(item);\n return (prototype === null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in item) && !(Symbol.iterator in item);\n}\nfunction deepClone(source) {\n if (/*#__PURE__*/React.isValidElement(source) || isValidElementType(source) || !isPlainObject(source)) {\n return source;\n }\n const output = {};\n Object.keys(source).forEach(key => {\n output[key] = deepClone(source[key]);\n });\n return output;\n}\n\n/**\n * Merge objects deeply.\n * It will shallow copy React elements.\n *\n * If `options.clone` is set to `false` the source object will be merged directly into the target object.\n *\n * @example\n * ```ts\n * deepmerge({ a: { b: 1 }, d: 2 }, { a: { c: 2 }, d: 4 });\n * // => { a: { b: 1, c: 2 }, d: 4 }\n * ````\n *\n * @param target The target object.\n * @param source The source object.\n * @param options The merge options.\n * @param options.clone Set to `false` to merge the source object directly into the target object.\n * @returns The merged object.\n */\nexport default function deepmerge(target, source, options = {\n clone: true\n}) {\n const output = options.clone ? {\n ...target\n } : target;\n if (isPlainObject(target) && isPlainObject(source)) {\n Object.keys(source).forEach(key => {\n if (/*#__PURE__*/React.isValidElement(source[key]) || isValidElementType(source[key])) {\n output[key] = source[key];\n } else if (isPlainObject(source[key]) &&\n // Avoid prototype pollution\n Object.prototype.hasOwnProperty.call(target, key) && isPlainObject(target[key])) {\n // Since `output` is a clone of `target` and we have narrowed `target` in this block we can cast to the same type.\n output[key] = deepmerge(target[key], source[key], options);\n } else if (options.clone) {\n output[key] = isPlainObject(source[key]) ? deepClone(source[key]) : source[key];\n } else {\n output[key] = source[key];\n }\n });\n }\n return output;\n}","// Sorted ASC by size. That's important.\n// It can't be configured as it's used statically for propTypes.\nexport const breakpointKeys = ['xs', 'sm', 'md', 'lg', 'xl'];\nconst sortBreakpointsValues = values => {\n const breakpointsAsArray = Object.keys(values).map(key => ({\n key,\n val: values[key]\n })) || [];\n // Sort in ascending order\n breakpointsAsArray.sort((breakpoint1, breakpoint2) => breakpoint1.val - breakpoint2.val);\n return breakpointsAsArray.reduce((acc, obj) => {\n return {\n ...acc,\n [obj.key]: obj.val\n };\n }, {});\n};\n\n// Keep in mind that @media is inclusive by the CSS specification.\nexport default function createBreakpoints(breakpoints) {\n const {\n // The breakpoint **start** at this value.\n // For instance with the first breakpoint xs: [xs, sm).\n values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n },\n unit = 'px',\n step = 5,\n ...other\n } = breakpoints;\n const sortedValues = sortBreakpointsValues(values);\n const keys = Object.keys(sortedValues);\n function up(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (min-width:${value}${unit})`;\n }\n function down(key) {\n const value = typeof values[key] === 'number' ? values[key] : key;\n return `@media (max-width:${value - step / 100}${unit})`;\n }\n function between(start, end) {\n const endIndex = keys.indexOf(end);\n return `@media (min-width:${typeof values[start] === 'number' ? values[start] : start}${unit}) and ` + `(max-width:${(endIndex !== -1 && typeof values[keys[endIndex]] === 'number' ? values[keys[endIndex]] : end) - step / 100}${unit})`;\n }\n function only(key) {\n if (keys.indexOf(key) + 1 < keys.length) {\n return between(key, keys[keys.indexOf(key) + 1]);\n }\n return up(key);\n }\n function not(key) {\n // handle first and last key separately, for better readability\n const keyIndex = keys.indexOf(key);\n if (keyIndex === 0) {\n return up(keys[1]);\n }\n if (keyIndex === keys.length - 1) {\n return down(keys[keyIndex]);\n }\n return between(key, keys[keys.indexOf(key) + 1]).replace('@media', '@media not all and');\n }\n return {\n keys,\n values: sortedValues,\n up,\n down,\n between,\n only,\n not,\n unit,\n ...other\n };\n}","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n/**\n * For using in `sx` prop to sort the breakpoint from low to high.\n * Note: this function does not work and will not support multiple units.\n * e.g. input: { '@container (min-width:300px)': '1rem', '@container (min-width:40rem)': '2rem' }\n * output: { '@container (min-width:40rem)': '2rem', '@container (min-width:300px)': '1rem' } // since 40 < 300 even though 40rem > 300px\n */\nexport function sortContainerQueries(theme, css) {\n if (!theme.containerQueries) {\n return css;\n }\n const sorted = Object.keys(css).filter(key => key.startsWith('@container')).sort((a, b) => {\n const regex = /min-width:\\s*([0-9.]+)/;\n return +(a.match(regex)?.[1] || 0) - +(b.match(regex)?.[1] || 0);\n });\n if (!sorted.length) {\n return css;\n }\n return sorted.reduce((acc, key) => {\n const value = css[key];\n delete acc[key];\n acc[key] = value;\n return acc;\n }, {\n ...css\n });\n}\nexport function isCqShorthand(breakpointKeys, value) {\n return value === '@' || value.startsWith('@') && (breakpointKeys.some(key => value.startsWith(`@${key}`)) || !!value.match(/^@\\d/));\n}\nexport function getContainerQuery(theme, shorthand) {\n const matches = shorthand.match(/^@([^/]+)?\\/?(.+)?$/);\n if (!matches) {\n if (process.env.NODE_ENV !== 'production') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The provided shorthand ${`(${shorthand})`} is invalid. The format should be \\`@<breakpoint | number>\\` or \\`@<breakpoint | number>/<container>\\`.\\n` + 'For example, `@sm` or `@600` or `@40rem/sidebar`.' : _formatErrorMessage(18, `(${shorthand})`));\n }\n return null;\n }\n const [, containerQuery, containerName] = matches;\n const value = Number.isNaN(+containerQuery) ? containerQuery || 0 : +containerQuery;\n return theme.containerQueries(containerName).up(value);\n}\nexport default function cssContainerQueries(themeInput) {\n const toContainerQuery = (mediaQuery, name) => mediaQuery.replace('@media', name ? `@container ${name}` : '@container');\n function attachCq(node, name) {\n node.up = (...args) => toContainerQuery(themeInput.breakpoints.up(...args), name);\n node.down = (...args) => toContainerQuery(themeInput.breakpoints.down(...args), name);\n node.between = (...args) => toContainerQuery(themeInput.breakpoints.between(...args), name);\n node.only = (...args) => toContainerQuery(themeInput.breakpoints.only(...args), name);\n node.not = (...args) => {\n const result = toContainerQuery(themeInput.breakpoints.not(...args), name);\n if (result.includes('not all and')) {\n // `@container` does not work with `not all and`, so need to invert the logic\n return result.replace('not all and ', '').replace('min-width:', 'width<').replace('max-width:', 'width>').replace('and', 'or');\n }\n return result;\n };\n }\n const node = {};\n const containerQueries = name => {\n attachCq(node, name);\n return node;\n };\n attachCq(containerQueries);\n return {\n ...themeInput,\n containerQueries\n };\n}","const shape = {\n borderRadius: 4\n};\nexport default shape;","import PropTypes from 'prop-types';\nconst responsivePropType = process.env.NODE_ENV !== 'production' ? PropTypes.oneOfType([PropTypes.number, PropTypes.string, PropTypes.object, PropTypes.array]) : {};\nexport default responsivePropType;","import deepmerge from '@mui/utils/deepmerge';\nfunction merge(acc, item) {\n if (!item) {\n return acc;\n }\n return deepmerge(acc, item, {\n clone: false // No need to clone deep, it's way faster.\n });\n}\nexport default merge;","import PropTypes from 'prop-types';\nimport deepmerge from '@mui/utils/deepmerge';\nimport merge from \"../merge/index.js\";\nimport { isCqShorthand, getContainerQuery } from \"../cssContainerQueries/index.js\";\n\n// The breakpoint **start** at this value.\n// For instance with the first breakpoint xs: [xs, sm[.\nexport const values = {\n xs: 0,\n // phone\n sm: 600,\n // tablet\n md: 900,\n // small laptop\n lg: 1200,\n // desktop\n xl: 1536 // large screen\n};\nconst defaultBreakpoints = {\n // Sorted ASC by size. That's important.\n // It can't be configured as it's used statically for propTypes.\n keys: ['xs', 'sm', 'md', 'lg', 'xl'],\n up: key => `@media (min-width:${values[key]}px)`\n};\nconst defaultContainerQueries = {\n containerQueries: containerName => ({\n up: key => {\n let result = typeof key === 'number' ? key : values[key] || key;\n if (typeof result === 'number') {\n result = `${result}px`;\n }\n return containerName ? `@container ${containerName} (min-width:${result})` : `@container (min-width:${result})`;\n }\n })\n};\nexport function handleBreakpoints(props, propValue, styleFromPropValue) {\n const theme = props.theme || {};\n if (Array.isArray(propValue)) {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return propValue.reduce((acc, item, index) => {\n acc[themeBreakpoints.up(themeBreakpoints.keys[index])] = styleFromPropValue(propValue[index]);\n return acc;\n }, {});\n }\n if (typeof propValue === 'object') {\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n return Object.keys(propValue).reduce((acc, breakpoint) => {\n if (isCqShorthand(themeBreakpoints.keys, breakpoint)) {\n const containerKey = getContainerQuery(theme.containerQueries ? theme : defaultContainerQueries, breakpoint);\n if (containerKey) {\n acc[containerKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n }\n }\n // key is breakpoint\n else if (Object.keys(themeBreakpoints.values || values).includes(breakpoint)) {\n const mediaKey = themeBreakpoints.up(breakpoint);\n acc[mediaKey] = styleFromPropValue(propValue[breakpoint], breakpoint);\n } else {\n const cssKey = breakpoint;\n acc[cssKey] = propValue[cssKey];\n }\n return acc;\n }, {});\n }\n const output = styleFromPropValue(propValue);\n return output;\n}\nfunction breakpoints(styleFunction) {\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const newStyleFunction = props => {\n const theme = props.theme || {};\n const base = styleFunction(props);\n const themeBreakpoints = theme.breakpoints || defaultBreakpoints;\n const extended = themeBreakpoints.keys.reduce((acc, key) => {\n if (props[key]) {\n acc = acc || {};\n acc[themeBreakpoints.up(key)] = styleFunction({\n theme,\n ...props[key]\n });\n }\n return acc;\n }, null);\n return merge(base, extended);\n };\n newStyleFunction.propTypes = process.env.NODE_ENV !== 'production' ? {\n ...styleFunction.propTypes,\n xs: PropTypes.object,\n sm: PropTypes.object,\n md: PropTypes.object,\n lg: PropTypes.object,\n xl: PropTypes.object\n } : {};\n newStyleFunction.filterProps = ['xs', 'sm', 'md', 'lg', 'xl', ...styleFunction.filterProps];\n return newStyleFunction;\n}\nexport function createEmptyBreakpointObject(breakpointsInput = {}) {\n const breakpointsInOrder = breakpointsInput.keys?.reduce((acc, key) => {\n const breakpointStyleKey = breakpointsInput.up(key);\n acc[breakpointStyleKey] = {};\n return acc;\n }, {});\n return breakpointsInOrder || {};\n}\nexport function removeUnusedBreakpoints(breakpointKeys, style) {\n return breakpointKeys.reduce((acc, key) => {\n const breakpointOutput = acc[key];\n const isBreakpointUnused = !breakpointOutput || Object.keys(breakpointOutput).length === 0;\n if (isBreakpointUnused) {\n delete acc[key];\n }\n return acc;\n }, style);\n}\nexport function mergeBreakpointsInOrder(breakpointsInput, ...styles) {\n const emptyBreakpoints = createEmptyBreakpointObject(breakpointsInput);\n const mergedOutput = [emptyBreakpoints, ...styles].reduce((prev, next) => deepmerge(prev, next), {});\n return removeUnusedBreakpoints(Object.keys(emptyBreakpoints), mergedOutput);\n}\n\n// compute base for responsive values; e.g.,\n// [1,2,3] => {xs: true, sm: true, md: true}\n// {xs: 1, sm: 2, md: 3} => {xs: true, sm: true, md: true}\nexport function computeBreakpointsBase(breakpointValues, themeBreakpoints) {\n // fixed value\n if (typeof breakpointValues !== 'object') {\n return {};\n }\n const base = {};\n const breakpointsKeys = Object.keys(themeBreakpoints);\n if (Array.isArray(breakpointValues)) {\n breakpointsKeys.forEach((breakpoint, i) => {\n if (i < breakpointValues.length) {\n base[breakpoint] = true;\n }\n });\n } else {\n breakpointsKeys.forEach(breakpoint => {\n if (breakpointValues[breakpoint] != null) {\n base[breakpoint] = true;\n }\n });\n }\n return base;\n}\nexport function resolveBreakpointValues({\n values: breakpointValues,\n breakpoints: themeBreakpoints,\n base: customBase\n}) {\n const base = customBase || computeBreakpointsBase(breakpointValues, themeBreakpoints);\n const keys = Object.keys(base);\n if (keys.length === 0) {\n return breakpointValues;\n }\n let previous;\n return keys.reduce((acc, breakpoint, i) => {\n if (Array.isArray(breakpointValues)) {\n acc[breakpoint] = breakpointValues[i] != null ? breakpointValues[i] : breakpointValues[previous];\n previous = i;\n } else if (typeof breakpointValues === 'object') {\n acc[breakpoint] = breakpointValues[breakpoint] != null ? breakpointValues[breakpoint] : breakpointValues[previous];\n previous = breakpoint;\n } else {\n acc[breakpoint] = breakpointValues;\n }\n return acc;\n }, {});\n}\nexport default breakpoints;","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n// It should to be noted that this function isn't equivalent to `text-transform: capitalize`.\n//\n// A strict capitalization should uppercase the first letter of each word in the sentence.\n// We only handle the first word.\nexport default function capitalize(string) {\n if (typeof string !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'MUI: `capitalize(string)` expects a string argument.' : _formatErrorMessage(7));\n }\n return string.charAt(0).toUpperCase() + string.slice(1);\n}","import capitalize from '@mui/utils/capitalize';\nimport responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function getPath(obj, path, checkVars = true) {\n if (!path || typeof path !== 'string') {\n return null;\n }\n\n // Check if CSS variables are used\n if (obj && obj.vars && checkVars) {\n const val = `vars.${path}`.split('.').reduce((acc, item) => acc && acc[item] ? acc[item] : null, obj);\n if (val != null) {\n return val;\n }\n }\n return path.split('.').reduce((acc, item) => {\n if (acc && acc[item] != null) {\n return acc[item];\n }\n return null;\n }, obj);\n}\nexport function getStyleValue(themeMapping, transform, propValueFinal, userValue = propValueFinal) {\n let value;\n if (typeof themeMapping === 'function') {\n value = themeMapping(propValueFinal);\n } else if (Array.isArray(themeMapping)) {\n value = themeMapping[propValueFinal] || userValue;\n } else {\n value = getPath(themeMapping, propValueFinal) || userValue;\n }\n if (transform) {\n value = transform(value, userValue, themeMapping);\n }\n return value;\n}\nfunction style(options) {\n const {\n prop,\n cssProperty = options.prop,\n themeKey,\n transform\n } = options;\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n if (props[prop] == null) {\n return null;\n }\n const propValue = props[prop];\n const theme = props.theme;\n const themeMapping = getPath(theme, themeKey) || {};\n const styleFromPropValue = propValueFinal => {\n let value = getStyleValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getStyleValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, propValue, styleFromPropValue);\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? {\n [prop]: responsivePropType\n } : {};\n fn.filterProps = [prop];\n return fn;\n}\nexport default style;","export default function memoize(fn) {\n const cache = {};\n return arg => {\n if (cache[arg] === undefined) {\n cache[arg] = fn(arg);\n }\n return cache[arg];\n };\n}","import responsivePropType from \"../responsivePropType/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport { getPath } from \"../style/index.js\";\nimport merge from \"../merge/index.js\";\nimport memoize from \"../memoize/index.js\";\nconst properties = {\n m: 'margin',\n p: 'padding'\n};\nconst directions = {\n t: 'Top',\n r: 'Right',\n b: 'Bottom',\n l: 'Left',\n x: ['Left', 'Right'],\n y: ['Top', 'Bottom']\n};\nconst aliases = {\n marginX: 'mx',\n marginY: 'my',\n paddingX: 'px',\n paddingY: 'py'\n};\n\n// memoize() impact:\n// From 300,000 ops/sec\n// To 350,000 ops/sec\nconst getCssProperties = memoize(prop => {\n // It's not a shorthand notation.\n if (prop.length > 2) {\n if (aliases[prop]) {\n prop = aliases[prop];\n } else {\n return [prop];\n }\n }\n const [a, b] = prop.split('');\n const property = properties[a];\n const direction = directions[b] || '';\n return Array.isArray(direction) ? direction.map(dir => property + dir) : [property + direction];\n});\nexport const marginKeys = ['m', 'mt', 'mr', 'mb', 'ml', 'mx', 'my', 'margin', 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', 'marginX', 'marginY', 'marginInline', 'marginInlineStart', 'marginInlineEnd', 'marginBlock', 'marginBlockStart', 'marginBlockEnd'];\nexport const paddingKeys = ['p', 'pt', 'pr', 'pb', 'pl', 'px', 'py', 'padding', 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', 'paddingX', 'paddingY', 'paddingInline', 'paddingInlineStart', 'paddingInlineEnd', 'paddingBlock', 'paddingBlockStart', 'paddingBlockEnd'];\nconst spacingKeys = [...marginKeys, ...paddingKeys];\nexport function createUnaryUnit(theme, themeKey, defaultValue, propName) {\n const themeSpacing = getPath(theme, themeKey, true) ?? defaultValue;\n if (typeof themeSpacing === 'number' || typeof themeSpacing === 'string') {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (typeof val !== 'number') {\n console.error(`MUI: Expected ${propName} argument to be a number or a string, got ${val}.`);\n }\n }\n if (typeof themeSpacing === 'string') {\n if (themeSpacing.startsWith('var(') && val === 0) {\n return 0;\n }\n if (themeSpacing.startsWith('var(') && val === 1) {\n return themeSpacing;\n }\n return `calc(${val} * ${themeSpacing})`;\n }\n return themeSpacing * val;\n };\n }\n if (Array.isArray(themeSpacing)) {\n return val => {\n if (typeof val === 'string') {\n return val;\n }\n const abs = Math.abs(val);\n if (process.env.NODE_ENV !== 'production') {\n if (!Number.isInteger(abs)) {\n console.error([`MUI: The \\`theme.${themeKey}\\` array type cannot be combined with non integer values.` + `You should either use an integer value that can be used as index, or define the \\`theme.${themeKey}\\` as a number.`].join('\\n'));\n } else if (abs > themeSpacing.length - 1) {\n console.error([`MUI: The value provided (${abs}) overflows.`, `The supported values are: ${JSON.stringify(themeSpacing)}.`, `${abs} > ${themeSpacing.length - 1}, you need to add the missing values.`].join('\\n'));\n }\n }\n const transformed = themeSpacing[abs];\n if (val >= 0) {\n return transformed;\n }\n if (typeof transformed === 'number') {\n return -transformed;\n }\n if (typeof transformed === 'string' && transformed.startsWith('var(')) {\n return `calc(-1 * ${transformed})`;\n }\n return `-${transformed}`;\n };\n }\n if (typeof themeSpacing === 'function') {\n return themeSpacing;\n }\n if (process.env.NODE_ENV !== 'production') {\n console.error([`MUI: The \\`theme.${themeKey}\\` value (${themeSpacing}) is invalid.`, 'It should be a number, an array or a function.'].join('\\n'));\n }\n return () => undefined;\n}\nexport function createUnarySpacing(theme) {\n return createUnaryUnit(theme, 'spacing', 8, 'spacing');\n}\nexport function getValue(transformer, propValue) {\n if (typeof propValue === 'string' || propValue == null) {\n return propValue;\n }\n return transformer(propValue);\n}\nexport function getStyleFromPropValue(cssProperties, transformer) {\n return propValue => cssProperties.reduce((acc, cssProperty) => {\n acc[cssProperty] = getValue(transformer, propValue);\n return acc;\n }, {});\n}\nfunction resolveCssProperty(props, keys, prop, transformer) {\n // Using a hash computation over an array iteration could be faster, but with only 28 items,\n // it's doesn't worth the bundle size.\n if (!keys.includes(prop)) {\n return null;\n }\n const cssProperties = getCssProperties(prop);\n const styleFromPropValue = getStyleFromPropValue(cssProperties, transformer);\n const propValue = props[prop];\n return handleBreakpoints(props, propValue, styleFromPropValue);\n}\nfunction style(props, keys) {\n const transformer = createUnarySpacing(props.theme);\n return Object.keys(props).map(prop => resolveCssProperty(props, keys, prop, transformer)).reduce(merge, {});\n}\nexport function margin(props) {\n return style(props, marginKeys);\n}\nmargin.propTypes = process.env.NODE_ENV !== 'production' ? marginKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nmargin.filterProps = marginKeys;\nexport function padding(props) {\n return style(props, paddingKeys);\n}\npadding.propTypes = process.env.NODE_ENV !== 'production' ? paddingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\npadding.filterProps = paddingKeys;\nfunction spacing(props) {\n return style(props, spacingKeys);\n}\nspacing.propTypes = process.env.NODE_ENV !== 'production' ? spacingKeys.reduce((obj, key) => {\n obj[key] = responsivePropType;\n return obj;\n}, {}) : {};\nspacing.filterProps = spacingKeys;\nexport default spacing;","import { createUnarySpacing } from \"../spacing/index.js\";\n\n// The different signatures imply different meaning for their arguments that can't be expressed structurally.\n// We express the difference with variable names.\n\nexport default function createSpacing(spacingInput = 8,\n// Material Design layouts are visually balanced. Most measurements align to an 8dp grid, which aligns both spacing and the overall layout.\n// Smaller components, such as icons, can align to a 4dp grid.\n// https://m2.material.io/design/layout/understanding-layout.html\ntransform = createUnarySpacing({\n spacing: spacingInput\n})) {\n // Already transformed.\n if (spacingInput.mui) {\n return spacingInput;\n }\n const spacing = (...argsInput) => {\n if (process.env.NODE_ENV !== 'production') {\n if (!(argsInput.length <= 4)) {\n console.error(`MUI: Too many arguments provided, expected between 0 and 4, got ${argsInput.length}`);\n }\n }\n const args = argsInput.length === 0 ? [1] : argsInput;\n return args.map(argument => {\n const output = transform(argument);\n return typeof output === 'number' ? `${output}px` : output;\n }).join(' ');\n };\n spacing.mui = true;\n return spacing;\n}","import merge from \"../merge/index.js\";\nfunction compose(...styles) {\n const handlers = styles.reduce((acc, style) => {\n style.filterProps.forEach(prop => {\n acc[prop] = style;\n });\n return acc;\n }, {});\n\n // false positive\n // eslint-disable-next-line react/function-component-definition\n const fn = props => {\n return Object.keys(props).reduce((acc, prop) => {\n if (handlers[prop]) {\n return merge(acc, handlers[prop](props));\n }\n return acc;\n }, {});\n };\n fn.propTypes = process.env.NODE_ENV !== 'production' ? styles.reduce((acc, style) => Object.assign(acc, style.propTypes), {}) : {};\n fn.filterProps = styles.reduce((acc, style) => acc.concat(style.filterProps), []);\n return fn;\n}\nexport default compose;","import responsivePropType from \"../responsivePropType/index.js\";\nimport style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nexport function borderTransform(value) {\n if (typeof value !== 'number') {\n return value;\n }\n return `${value}px solid`;\n}\nfunction createBorderStyle(prop, transform) {\n return style({\n prop,\n themeKey: 'borders',\n transform\n });\n}\nexport const border = createBorderStyle('border', borderTransform);\nexport const borderTop = createBorderStyle('borderTop', borderTransform);\nexport const borderRight = createBorderStyle('borderRight', borderTransform);\nexport const borderBottom = createBorderStyle('borderBottom', borderTransform);\nexport const borderLeft = createBorderStyle('borderLeft', borderTransform);\nexport const borderColor = createBorderStyle('borderColor');\nexport const borderTopColor = createBorderStyle('borderTopColor');\nexport const borderRightColor = createBorderStyle('borderRightColor');\nexport const borderBottomColor = createBorderStyle('borderBottomColor');\nexport const borderLeftColor = createBorderStyle('borderLeftColor');\nexport const outline = createBorderStyle('outline', borderTransform);\nexport const outlineColor = createBorderStyle('outlineColor');\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const borderRadius = props => {\n if (props.borderRadius !== undefined && props.borderRadius !== null) {\n const transformer = createUnaryUnit(props.theme, 'shape.borderRadius', 4, 'borderRadius');\n const styleFromPropValue = propValue => ({\n borderRadius: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.borderRadius, styleFromPropValue);\n }\n return null;\n};\nborderRadius.propTypes = process.env.NODE_ENV !== 'production' ? {\n borderRadius: responsivePropType\n} : {};\nborderRadius.filterProps = ['borderRadius'];\nconst borders = compose(border, borderTop, borderRight, borderBottom, borderLeft, borderColor, borderTopColor, borderRightColor, borderBottomColor, borderLeftColor, borderRadius, outline, outlineColor);\nexport default borders;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { createUnaryUnit, getValue } from \"../spacing/index.js\";\nimport { handleBreakpoints } from \"../breakpoints/index.js\";\nimport responsivePropType from \"../responsivePropType/index.js\";\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const gap = props => {\n if (props.gap !== undefined && props.gap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'gap');\n const styleFromPropValue = propValue => ({\n gap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.gap, styleFromPropValue);\n }\n return null;\n};\ngap.propTypes = process.env.NODE_ENV !== 'production' ? {\n gap: responsivePropType\n} : {};\ngap.filterProps = ['gap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const columnGap = props => {\n if (props.columnGap !== undefined && props.columnGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'columnGap');\n const styleFromPropValue = propValue => ({\n columnGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.columnGap, styleFromPropValue);\n }\n return null;\n};\ncolumnGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n columnGap: responsivePropType\n} : {};\ncolumnGap.filterProps = ['columnGap'];\n\n// false positive\n// eslint-disable-next-line react/function-component-definition\nexport const rowGap = props => {\n if (props.rowGap !== undefined && props.rowGap !== null) {\n const transformer = createUnaryUnit(props.theme, 'spacing', 8, 'rowGap');\n const styleFromPropValue = propValue => ({\n rowGap: getValue(transformer, propValue)\n });\n return handleBreakpoints(props, props.rowGap, styleFromPropValue);\n }\n return null;\n};\nrowGap.propTypes = process.env.NODE_ENV !== 'production' ? {\n rowGap: responsivePropType\n} : {};\nrowGap.filterProps = ['rowGap'];\nexport const gridColumn = style({\n prop: 'gridColumn'\n});\nexport const gridRow = style({\n prop: 'gridRow'\n});\nexport const gridAutoFlow = style({\n prop: 'gridAutoFlow'\n});\nexport const gridAutoColumns = style({\n prop: 'gridAutoColumns'\n});\nexport const gridAutoRows = style({\n prop: 'gridAutoRows'\n});\nexport const gridTemplateColumns = style({\n prop: 'gridTemplateColumns'\n});\nexport const gridTemplateRows = style({\n prop: 'gridTemplateRows'\n});\nexport const gridTemplateAreas = style({\n prop: 'gridTemplateAreas'\n});\nexport const gridArea = style({\n prop: 'gridArea'\n});\nconst grid = compose(gap, columnGap, rowGap, gridColumn, gridRow, gridAutoFlow, gridAutoColumns, gridAutoRows, gridTemplateColumns, gridTemplateRows, gridTemplateAreas, gridArea);\nexport default grid;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nexport function paletteTransform(value, userValue) {\n if (userValue === 'grey') {\n return userValue;\n }\n return value;\n}\nexport const color = style({\n prop: 'color',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const bgcolor = style({\n prop: 'bgcolor',\n cssProperty: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nexport const backgroundColor = style({\n prop: 'backgroundColor',\n themeKey: 'palette',\n transform: paletteTransform\n});\nconst palette = compose(color, bgcolor, backgroundColor);\nexport default palette;","import style from \"../style/index.js\";\nimport compose from \"../compose/index.js\";\nimport { handleBreakpoints, values as breakpointsValues } from \"../breakpoints/index.js\";\nexport function sizingTransform(value) {\n return value <= 1 && value !== 0 ? `${value * 100}%` : value;\n}\nexport const width = style({\n prop: 'width',\n transform: sizingTransform\n});\nexport const maxWidth = props => {\n if (props.maxWidth !== undefined && props.maxWidth !== null) {\n const styleFromPropValue = propValue => {\n const breakpoint = props.theme?.breakpoints?.values?.[propValue] || breakpointsValues[propValue];\n if (!breakpoint) {\n return {\n maxWidth: sizingTransform(propValue)\n };\n }\n if (props.theme?.breakpoints?.unit !== 'px') {\n return {\n maxWidth: `${breakpoint}${props.theme.breakpoints.unit}`\n };\n }\n return {\n maxWidth: breakpoint\n };\n };\n return handleBreakpoints(props, props.maxWidth, styleFromPropValue);\n }\n return null;\n};\nmaxWidth.filterProps = ['maxWidth'];\nexport const minWidth = style({\n prop: 'minWidth',\n transform: sizingTransform\n});\nexport const height = style({\n prop: 'height',\n transform: sizingTransform\n});\nexport const maxHeight = style({\n prop: 'maxHeight',\n transform: sizingTransform\n});\nexport const minHeight = style({\n prop: 'minHeight',\n transform: sizingTransform\n});\nexport const sizeWidth = style({\n prop: 'size',\n cssProperty: 'width',\n transform: sizingTransform\n});\nexport const sizeHeight = style({\n prop: 'size',\n cssProperty: 'height',\n transform: sizingTransform\n});\nexport const boxSizing = style({\n prop: 'boxSizing'\n});\nconst sizing = compose(width, maxWidth, minWidth, height, maxHeight, minHeight, boxSizing);\nexport default sizing;","import { padding, margin } from \"../spacing/index.js\";\nimport { borderRadius, borderTransform } from \"../borders/index.js\";\nimport { gap, rowGap, columnGap } from \"../cssGrid/index.js\";\nimport { paletteTransform } from \"../palette/index.js\";\nimport { maxWidth, sizingTransform } from \"../sizing/index.js\";\nconst defaultSxConfig = {\n // borders\n border: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderTop: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderRight: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderBottom: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderLeft: {\n themeKey: 'borders',\n transform: borderTransform\n },\n borderColor: {\n themeKey: 'palette'\n },\n borderTopColor: {\n themeKey: 'palette'\n },\n borderRightColor: {\n themeKey: 'palette'\n },\n borderBottomColor: {\n themeKey: 'palette'\n },\n borderLeftColor: {\n themeKey: 'palette'\n },\n outline: {\n themeKey: 'borders',\n transform: borderTransform\n },\n outlineColor: {\n themeKey: 'palette'\n },\n borderRadius: {\n themeKey: 'shape.borderRadius',\n style: borderRadius\n },\n // palette\n color: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n bgcolor: {\n themeKey: 'palette',\n cssProperty: 'backgroundColor',\n transform: paletteTransform\n },\n backgroundColor: {\n themeKey: 'palette',\n transform: paletteTransform\n },\n // spacing\n p: {\n style: padding\n },\n pt: {\n style: padding\n },\n pr: {\n style: padding\n },\n pb: {\n style: padding\n },\n pl: {\n style: padding\n },\n px: {\n style: padding\n },\n py: {\n style: padding\n },\n padding: {\n style: padding\n },\n paddingTop: {\n style: padding\n },\n paddingRight: {\n style: padding\n },\n paddingBottom: {\n style: padding\n },\n paddingLeft: {\n style: padding\n },\n paddingX: {\n style: padding\n },\n paddingY: {\n style: padding\n },\n paddingInline: {\n style: padding\n },\n paddingInlineStart: {\n style: padding\n },\n paddingInlineEnd: {\n style: padding\n },\n paddingBlock: {\n style: padding\n },\n paddingBlockStart: {\n style: padding\n },\n paddingBlockEnd: {\n style: padding\n },\n m: {\n style: margin\n },\n mt: {\n style: margin\n },\n mr: {\n style: margin\n },\n mb: {\n style: margin\n },\n ml: {\n style: margin\n },\n mx: {\n style: margin\n },\n my: {\n style: margin\n },\n margin: {\n style: margin\n },\n marginTop: {\n style: margin\n },\n marginRight: {\n style: margin\n },\n marginBottom: {\n style: margin\n },\n marginLeft: {\n style: margin\n },\n marginX: {\n style: margin\n },\n marginY: {\n style: margin\n },\n marginInline: {\n style: margin\n },\n marginInlineStart: {\n style: margin\n },\n marginInlineEnd: {\n style: margin\n },\n marginBlock: {\n style: margin\n },\n marginBlockStart: {\n style: margin\n },\n marginBlockEnd: {\n style: margin\n },\n // display\n displayPrint: {\n cssProperty: false,\n transform: value => ({\n '@media print': {\n display: value\n }\n })\n },\n display: {},\n overflow: {},\n textOverflow: {},\n visibility: {},\n whiteSpace: {},\n // flexbox\n flexBasis: {},\n flexDirection: {},\n flexWrap: {},\n justifyContent: {},\n alignItems: {},\n alignContent: {},\n order: {},\n flex: {},\n flexGrow: {},\n flexShrink: {},\n alignSelf: {},\n justifyItems: {},\n justifySelf: {},\n // grid\n gap: {\n style: gap\n },\n rowGap: {\n style: rowGap\n },\n columnGap: {\n style: columnGap\n },\n gridColumn: {},\n gridRow: {},\n gridAutoFlow: {},\n gridAutoColumns: {},\n gridAutoRows: {},\n gridTemplateColumns: {},\n gridTemplateRows: {},\n gridTemplateAreas: {},\n gridArea: {},\n // positions\n position: {},\n zIndex: {\n themeKey: 'zIndex'\n },\n top: {},\n right: {},\n bottom: {},\n left: {},\n // shadows\n boxShadow: {\n themeKey: 'shadows'\n },\n // sizing\n width: {\n transform: sizingTransform\n },\n maxWidth: {\n style: maxWidth\n },\n minWidth: {\n transform: sizingTransform\n },\n height: {\n transform: sizingTransform\n },\n maxHeight: {\n transform: sizingTransform\n },\n minHeight: {\n transform: sizingTransform\n },\n boxSizing: {},\n // typography\n font: {\n themeKey: 'font'\n },\n fontFamily: {\n themeKey: 'typography'\n },\n fontSize: {\n themeKey: 'typography'\n },\n fontStyle: {\n themeKey: 'typography'\n },\n fontWeight: {\n themeKey: 'typography'\n },\n letterSpacing: {},\n textTransform: {},\n lineHeight: {},\n textAlign: {},\n typography: {\n cssProperty: false,\n themeKey: 'typography'\n }\n};\nexport default defaultSxConfig;","import capitalize from '@mui/utils/capitalize';\nimport merge from \"../merge/index.js\";\nimport { getPath, getStyleValue as getValue } from \"../style/index.js\";\nimport { handleBreakpoints, createEmptyBreakpointObject, removeUnusedBreakpoints } from \"../breakpoints/index.js\";\nimport { sortContainerQueries } from \"../cssContainerQueries/index.js\";\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nfunction objectsHaveSameKeys(...objects) {\n const allKeys = objects.reduce((keys, object) => keys.concat(Object.keys(object)), []);\n const union = new Set(allKeys);\n return objects.every(object => union.size === Object.keys(object).length);\n}\nfunction callIfFn(maybeFn, arg) {\n return typeof maybeFn === 'function' ? maybeFn(arg) : maybeFn;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function unstable_createStyleFunctionSx() {\n function getThemeValue(prop, val, theme, config) {\n const props = {\n [prop]: val,\n theme\n };\n const options = config[prop];\n if (!options) {\n return {\n [prop]: val\n };\n }\n const {\n cssProperty = prop,\n themeKey,\n transform,\n style\n } = options;\n if (val == null) {\n return null;\n }\n\n // TODO v6: remove, see https://github.com/mui/material-ui/pull/38123\n if (themeKey === 'typography' && val === 'inherit') {\n return {\n [prop]: val\n };\n }\n const themeMapping = getPath(theme, themeKey) || {};\n if (style) {\n return style(props);\n }\n const styleFromPropValue = propValueFinal => {\n let value = getValue(themeMapping, transform, propValueFinal);\n if (propValueFinal === value && typeof propValueFinal === 'string') {\n // Haven't found value\n value = getValue(themeMapping, transform, `${prop}${propValueFinal === 'default' ? '' : capitalize(propValueFinal)}`, propValueFinal);\n }\n if (cssProperty === false) {\n return value;\n }\n return {\n [cssProperty]: value\n };\n };\n return handleBreakpoints(props, val, styleFromPropValue);\n }\n function styleFunctionSx(props) {\n const {\n sx,\n theme = {},\n nested\n } = props || {};\n if (!sx) {\n return null; // Emotion & styled-components will neglect null\n }\n const config = theme.unstable_sxConfig ?? defaultSxConfig;\n\n /*\n * Receive `sxInput` as object or callback\n * and then recursively check keys & values to create media query object styles.\n * (the result will be used in `styled`)\n */\n function traverse(sxInput) {\n let sxObject = sxInput;\n if (typeof sxInput === 'function') {\n sxObject = sxInput(theme);\n } else if (typeof sxInput !== 'object') {\n // value\n return sxInput;\n }\n if (!sxObject) {\n return null;\n }\n const emptyBreakpoints = createEmptyBreakpointObject(theme.breakpoints);\n const breakpointsKeys = Object.keys(emptyBreakpoints);\n let css = emptyBreakpoints;\n Object.keys(sxObject).forEach(styleKey => {\n const value = callIfFn(sxObject[styleKey], theme);\n if (value !== null && value !== undefined) {\n if (typeof value === 'object') {\n if (config[styleKey]) {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n } else {\n const breakpointsValues = handleBreakpoints({\n theme\n }, value, x => ({\n [styleKey]: x\n }));\n if (objectsHaveSameKeys(breakpointsValues, value)) {\n css[styleKey] = styleFunctionSx({\n sx: value,\n theme,\n nested: true\n });\n } else {\n css = merge(css, breakpointsValues);\n }\n }\n } else {\n css = merge(css, getThemeValue(styleKey, value, theme, config));\n }\n }\n });\n if (!nested && theme.modularCssLayers) {\n return {\n '@layer sx': sortContainerQueries(theme, removeUnusedBreakpoints(breakpointsKeys, css))\n };\n }\n return sortContainerQueries(theme, removeUnusedBreakpoints(breakpointsKeys, css));\n }\n return Array.isArray(sx) ? sx.map(traverse) : traverse(sx);\n }\n return styleFunctionSx;\n}\nconst styleFunctionSx = unstable_createStyleFunctionSx();\nstyleFunctionSx.filterProps = ['sx'];\nexport default styleFunctionSx;","/**\n * A universal utility to style components with multiple color modes. Always use it from the theme object.\n * It works with:\n * - [Basic theme](https://mui.com/material-ui/customization/dark-mode/)\n * - [CSS theme variables](https://mui.com/material-ui/customization/css-theme-variables/overview/)\n * - Zero-runtime engine\n *\n * Tips: Use an array over object spread and place `theme.applyStyles()` last.\n *\n * With the styled function:\n * ✅ [{ background: '#e5e5e5' }, theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * With the sx prop:\n * ✅ [{ background: '#e5e5e5' }, theme => theme.applyStyles('dark', { background: '#1c1c1c' })]\n * 🚫 { background: '#e5e5e5', ...theme => theme.applyStyles('dark', { background: '#1c1c1c' })}\n *\n * @example\n * 1. using with `styled`:\n * ```jsx\n * const Component = styled('div')(({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]);\n * ```\n *\n * @example\n * 2. using with `sx` prop:\n * ```jsx\n * <Box sx={[\n * { background: '#e5e5e5' },\n * theme => theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ]}\n * />\n * ```\n *\n * @example\n * 3. theming a component:\n * ```jsx\n * extendTheme({\n * components: {\n * MuiButton: {\n * styleOverrides: {\n * root: ({ theme }) => [\n * { background: '#e5e5e5' },\n * theme.applyStyles('dark', {\n * background: '#1c1c1c',\n * color: '#fff',\n * }),\n * ],\n * },\n * }\n * }\n * })\n *```\n */\nexport default function applyStyles(key, styles) {\n // @ts-expect-error this is 'any' type\n const theme = this;\n if (theme.vars) {\n if (!theme.colorSchemes?.[key] || typeof theme.getColorSchemeSelector !== 'function') {\n return {};\n }\n // If CssVarsProvider is used as a provider, returns '*:where({selector}) &'\n let selector = theme.getColorSchemeSelector(key);\n if (selector === '&') {\n return styles;\n }\n if (selector.includes('data-') || selector.includes('.')) {\n // '*' is required as a workaround for Emotion issue (https://github.com/emotion-js/emotion/issues/2836)\n selector = `*:where(${selector.replace(/\\s*&$/, '')}) &`;\n }\n return {\n [selector]: styles\n };\n }\n if (theme.palette.mode === key) {\n return styles;\n }\n return {};\n}","import deepmerge from '@mui/utils/deepmerge';\nimport createBreakpoints from \"../createBreakpoints/createBreakpoints.js\";\nimport cssContainerQueries from \"../cssContainerQueries/index.js\";\nimport shape from \"./shape.js\";\nimport createSpacing from \"./createSpacing.js\";\nimport styleFunctionSx from \"../styleFunctionSx/styleFunctionSx.js\";\nimport defaultSxConfig from \"../styleFunctionSx/defaultSxConfig.js\";\nimport applyStyles from \"./applyStyles.js\";\nfunction createTheme(options = {}, ...args) {\n const {\n breakpoints: breakpointsInput = {},\n palette: paletteInput = {},\n spacing: spacingInput,\n shape: shapeInput = {},\n ...other\n } = options;\n const breakpoints = createBreakpoints(breakpointsInput);\n const spacing = createSpacing(spacingInput);\n let muiTheme = deepmerge({\n breakpoints,\n direction: 'ltr',\n components: {},\n // Inject component definitions.\n palette: {\n mode: 'light',\n ...paletteInput\n },\n spacing,\n shape: {\n ...shape,\n ...shapeInput\n }\n }, other);\n muiTheme = cssContainerQueries(muiTheme);\n muiTheme.applyStyles = applyStyles;\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n muiTheme.unstable_sxConfig = {\n ...defaultSxConfig,\n ...other?.unstable_sxConfig\n };\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n return muiTheme;\n}\nexport default createTheme;","'use client';\n\nimport * as React from 'react';\nimport { ThemeContext } from '@mui/styled-engine';\nfunction isObjectEmpty(obj) {\n return Object.keys(obj).length === 0;\n}\nfunction useTheme(defaultTheme = null) {\n const contextTheme = React.useContext(ThemeContext);\n return !contextTheme || isObjectEmpty(contextTheme) ? defaultTheme : contextTheme;\n}\nexport default useTheme;","'use client';\n\nimport createTheme from \"../createTheme/index.js\";\nimport useThemeWithoutDefault from \"../useThemeWithoutDefault/index.js\";\nexport const systemDefaultTheme = createTheme();\nfunction useTheme(defaultTheme = systemDefaultTheme) {\n return useThemeWithoutDefault(defaultTheme);\n}\nexport default useTheme;","import { isPlainObject } from '@mui/utils/deepmerge';\nimport defaultSxConfig from \"./defaultSxConfig.js\";\nconst splitProps = props => {\n const result = {\n systemProps: {},\n otherProps: {}\n };\n const config = props?.theme?.unstable_sxConfig ?? defaultSxConfig;\n Object.keys(props).forEach(prop => {\n if (config[prop]) {\n result.systemProps[prop] = props[prop];\n } else {\n result.otherProps[prop] = props[prop];\n }\n });\n return result;\n};\nexport default function extendSxProp(props) {\n const {\n sx: inSx,\n ...other\n } = props;\n const {\n systemProps,\n otherProps\n } = splitProps(other);\n let finalSx;\n if (Array.isArray(inSx)) {\n finalSx = [systemProps, ...inSx];\n } else if (typeof inSx === 'function') {\n finalSx = (...args) => {\n const result = inSx(...args);\n if (!isPlainObject(result)) {\n return systemProps;\n }\n return {\n ...systemProps,\n ...result\n };\n };\n } else {\n finalSx = {\n ...systemProps,\n ...inSx\n };\n }\n return {\n ...otherProps,\n sx: finalSx\n };\n}","const defaultGenerator = componentName => componentName;\nconst createClassNameGenerator = () => {\n let generate = defaultGenerator;\n return {\n configure(generator) {\n generate = generator;\n },\n generate(componentName) {\n return generate(componentName);\n },\n reset() {\n generate = defaultGenerator;\n }\n };\n};\nconst ClassNameGenerator = createClassNameGenerator();\nexport default ClassNameGenerator;","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","'use client';\n\nimport * as React from 'react';\nimport clsx from 'clsx';\nimport styled from '@mui/styled-engine';\nimport styleFunctionSx, { extendSxProp } from \"../styleFunctionSx/index.js\";\nimport useTheme from \"../useTheme/index.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createBox(options = {}) {\n const {\n themeId,\n defaultTheme,\n defaultClassName = 'MuiBox-root',\n generateClassName\n } = options;\n const BoxRoot = styled('div', {\n shouldForwardProp: prop => prop !== 'theme' && prop !== 'sx' && prop !== 'as'\n })(styleFunctionSx);\n const Box = /*#__PURE__*/React.forwardRef(function Box(inProps, ref) {\n const theme = useTheme(defaultTheme);\n const {\n className,\n component = 'div',\n ...other\n } = extendSxProp(inProps);\n return /*#__PURE__*/_jsx(BoxRoot, {\n as: component,\n ref: ref,\n className: clsx(className, generateClassName ? generateClassName(defaultClassName) : defaultClassName),\n theme: themeId ? theme[themeId] || theme : theme,\n ...other\n });\n });\n return Box;\n}","import ClassNameGenerator from \"../ClassNameGenerator/index.js\";\nexport const globalStateClasses = {\n active: 'active',\n checked: 'checked',\n completed: 'completed',\n disabled: 'disabled',\n error: 'error',\n expanded: 'expanded',\n focused: 'focused',\n focusVisible: 'focusVisible',\n open: 'open',\n readOnly: 'readOnly',\n required: 'required',\n selected: 'selected'\n};\nexport default function generateUtilityClass(componentName, slot, globalStatePrefix = 'Mui') {\n const globalStateClass = globalStateClasses[slot];\n return globalStateClass ? `${globalStatePrefix}-${globalStateClass}` : `${ClassNameGenerator.generate(componentName)}-${slot}`;\n}\nexport function isGlobalState(slot) {\n return globalStateClasses[slot] !== undefined;\n}","import generateUtilityClass from \"../generateUtilityClass/index.js\";\nexport default function generateUtilityClasses(componentName, slots, globalStatePrefix = 'Mui') {\n const result = {};\n slots.forEach(slot => {\n result[slot] = generateUtilityClass(componentName, slot, globalStatePrefix);\n });\n return result;\n}","import { ForwardRef, Memo } from 'react-is';\nfunction getFunctionComponentName(Component, fallback = '') {\n return Component.displayName || Component.name || fallback;\n}\nfunction getWrappedName(outerType, innerType, wrapperName) {\n const functionName = getFunctionComponentName(innerType);\n return outerType.displayName || (functionName !== '' ? `${wrapperName}(${functionName})` : wrapperName);\n}\n\n/**\n * cherry-pick from\n * https://github.com/facebook/react/blob/769b1f270e1251d9dbdce0fcbd9e92e502d059b8/packages/shared/getComponentName.js\n * originally forked from recompose/getDisplayName\n */\nexport default function getDisplayName(Component) {\n if (Component == null) {\n return undefined;\n }\n if (typeof Component === 'string') {\n return Component;\n }\n if (typeof Component === 'function') {\n return getFunctionComponentName(Component, 'Component');\n }\n\n // TypeScript can't have components as objects but they exist in the form of `memo` or `Suspense`\n if (typeof Component === 'object') {\n switch (Component.$$typeof) {\n case ForwardRef:\n return getWrappedName(Component, Component.render, 'ForwardRef');\n case Memo:\n return getWrappedName(Component, Component.type, 'memo');\n default:\n return undefined;\n }\n }\n return undefined;\n}","import { internal_serializeStyles } from '@mui/styled-engine';\nexport default function preprocessStyles(input) {\n const {\n variants,\n ...style\n } = input;\n const result = {\n variants,\n style: internal_serializeStyles(style),\n isProcessed: true\n };\n\n // Not supported on styled-components\n if (result.style === style) {\n return result;\n }\n if (variants) {\n variants.forEach(variant => {\n if (typeof variant.style !== 'function') {\n variant.style = internal_serializeStyles(variant.style);\n }\n });\n }\n return result;\n}","import styledEngineStyled, { internal_mutateStyles as mutateStyles, internal_serializeStyles as serializeStyles } from '@mui/styled-engine';\nimport { isPlainObject } from '@mui/utils/deepmerge';\nimport capitalize from '@mui/utils/capitalize';\nimport getDisplayName from '@mui/utils/getDisplayName';\nimport createTheme from \"../createTheme/index.js\";\nimport styleFunctionSx from \"../styleFunctionSx/index.js\";\nimport preprocessStyles from \"../preprocessStyles.js\";\n\n/* eslint-disable no-underscore-dangle */\n/* eslint-disable no-labels */\n/* eslint-disable no-lone-blocks */\n\nexport const systemDefaultTheme = createTheme();\n\n// Update /system/styled/#api in case if this changes\nexport function shouldForwardProp(prop) {\n return prop !== 'ownerState' && prop !== 'theme' && prop !== 'sx' && prop !== 'as';\n}\nfunction shallowLayer(serialized, layerName) {\n if (layerName && serialized && typeof serialized === 'object' && serialized.styles && !serialized.styles.startsWith('@layer') // only add the layer if it is not already there.\n ) {\n serialized.styles = `@layer ${layerName}{${String(serialized.styles)}}`;\n }\n return serialized;\n}\nfunction defaultOverridesResolver(slot) {\n if (!slot) {\n return null;\n }\n return (_props, styles) => styles[slot];\n}\nfunction attachTheme(props, themeId, defaultTheme) {\n props.theme = isObjectEmpty(props.theme) ? defaultTheme : props.theme[themeId] || props.theme;\n}\nfunction processStyle(props, style, layerName) {\n /*\n * Style types:\n * - null/undefined\n * - string\n * - CSS style object: { [cssKey]: [cssValue], variants }\n * - Processed style object: { style, variants, isProcessed: true }\n * - Array of any of the above\n */\n\n const resolvedStyle = typeof style === 'function' ? style(props) : style;\n if (Array.isArray(resolvedStyle)) {\n return resolvedStyle.flatMap(subStyle => processStyle(props, subStyle, layerName));\n }\n if (Array.isArray(resolvedStyle?.variants)) {\n let rootStyle;\n if (resolvedStyle.isProcessed) {\n rootStyle = layerName ? shallowLayer(resolvedStyle.style, layerName) : resolvedStyle.style;\n } else {\n const {\n variants,\n ...otherStyles\n } = resolvedStyle;\n rootStyle = layerName ? shallowLayer(serializeStyles(otherStyles), layerName) : otherStyles;\n }\n return processStyleVariants(props, resolvedStyle.variants, [rootStyle], layerName);\n }\n if (resolvedStyle?.isProcessed) {\n return layerName ? shallowLayer(serializeStyles(resolvedStyle.style), layerName) : resolvedStyle.style;\n }\n return layerName ? shallowLayer(serializeStyles(resolvedStyle), layerName) : resolvedStyle;\n}\nfunction processStyleVariants(props, variants, results = [], layerName = undefined) {\n let mergedState; // We might not need it, initialized lazily\n\n variantLoop: for (let i = 0; i < variants.length; i += 1) {\n const variant = variants[i];\n if (typeof variant.props === 'function') {\n mergedState ??= {\n ...props,\n ...props.ownerState,\n ownerState: props.ownerState\n };\n if (!variant.props(mergedState)) {\n continue;\n }\n } else {\n for (const key in variant.props) {\n if (props[key] !== variant.props[key] && props.ownerState?.[key] !== variant.props[key]) {\n continue variantLoop;\n }\n }\n }\n if (typeof variant.style === 'function') {\n mergedState ??= {\n ...props,\n ...props.ownerState,\n ownerState: props.ownerState\n };\n results.push(layerName ? shallowLayer(serializeStyles(variant.style(mergedState)), layerName) : variant.style(mergedState));\n } else {\n results.push(layerName ? shallowLayer(serializeStyles(variant.style), layerName) : variant.style);\n }\n }\n return results;\n}\nexport default function createStyled(input = {}) {\n const {\n themeId,\n defaultTheme = systemDefaultTheme,\n rootShouldForwardProp = shouldForwardProp,\n slotShouldForwardProp = shouldForwardProp\n } = input;\n function styleAttachTheme(props) {\n attachTheme(props, themeId, defaultTheme);\n }\n const styled = (tag, inputOptions = {}) => {\n // If `tag` is already a styled component, filter out the `sx` style function\n // to prevent unnecessary styles generated by the composite components.\n mutateStyles(tag, styles => styles.filter(style => style !== styleFunctionSx));\n const {\n name: componentName,\n slot: componentSlot,\n skipVariantsResolver: inputSkipVariantsResolver,\n skipSx: inputSkipSx,\n // TODO v6: remove `lowercaseFirstLetter()` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n overridesResolver = defaultOverridesResolver(lowercaseFirstLetter(componentSlot)),\n ...options\n } = inputOptions;\n const layerName = componentName && componentName.startsWith('Mui') || !!componentSlot ? 'components' : 'custom';\n\n // if skipVariantsResolver option is defined, take the value, otherwise, true for root and false for other slots.\n const skipVariantsResolver = inputSkipVariantsResolver !== undefined ? inputSkipVariantsResolver :\n // TODO v6: remove `Root` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n componentSlot && componentSlot !== 'Root' && componentSlot !== 'root' || false;\n const skipSx = inputSkipSx || false;\n let shouldForwardPropOption = shouldForwardProp;\n\n // TODO v6: remove `Root` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n if (componentSlot === 'Root' || componentSlot === 'root') {\n shouldForwardPropOption = rootShouldForwardProp;\n } else if (componentSlot) {\n // any other slot specified\n shouldForwardPropOption = slotShouldForwardProp;\n } else if (isStringTag(tag)) {\n // for string (html) tag, preserve the behavior in emotion & styled-components.\n shouldForwardPropOption = undefined;\n }\n const defaultStyledResolver = styledEngineStyled(tag, {\n shouldForwardProp: shouldForwardPropOption,\n label: generateStyledLabel(componentName, componentSlot),\n ...options\n });\n const transformStyle = style => {\n // - On the server Emotion doesn't use React.forwardRef for creating components, so the created\n // component stays as a function. This condition makes sure that we do not interpolate functions\n // which are basically components used as a selectors.\n // - `style` could be a styled component from a babel plugin for component selectors, This condition\n // makes sure that we do not interpolate them.\n if (style.__emotion_real === style) {\n return style;\n }\n if (typeof style === 'function') {\n return function styleFunctionProcessor(props) {\n return processStyle(props, style, props.theme.modularCssLayers ? layerName : undefined);\n };\n }\n if (isPlainObject(style)) {\n const serialized = preprocessStyles(style);\n return function styleObjectProcessor(props) {\n if (!serialized.variants) {\n return props.theme.modularCssLayers ? shallowLayer(serialized.style, layerName) : serialized.style;\n }\n return processStyle(props, serialized, props.theme.modularCssLayers ? layerName : undefined);\n };\n }\n return style;\n };\n const muiStyledResolver = (...expressionsInput) => {\n const expressionsHead = [];\n const expressionsBody = expressionsInput.map(transformStyle);\n const expressionsTail = [];\n\n // Preprocess `props` to set the scoped theme value.\n // This must run before any other expression.\n expressionsHead.push(styleAttachTheme);\n if (componentName && overridesResolver) {\n expressionsTail.push(function styleThemeOverrides(props) {\n const theme = props.theme;\n const styleOverrides = theme.components?.[componentName]?.styleOverrides;\n if (!styleOverrides) {\n return null;\n }\n const resolvedStyleOverrides = {};\n\n // TODO: v7 remove iteration and use `resolveStyleArg(styleOverrides[slot])` directly\n // eslint-disable-next-line guard-for-in\n for (const slotKey in styleOverrides) {\n resolvedStyleOverrides[slotKey] = processStyle(props, styleOverrides[slotKey], props.theme.modularCssLayers ? 'theme' : undefined);\n }\n return overridesResolver(props, resolvedStyleOverrides);\n });\n }\n if (componentName && !skipVariantsResolver) {\n expressionsTail.push(function styleThemeVariants(props) {\n const theme = props.theme;\n const themeVariants = theme?.components?.[componentName]?.variants;\n if (!themeVariants) {\n return null;\n }\n return processStyleVariants(props, themeVariants, [], props.theme.modularCssLayers ? 'theme' : undefined);\n });\n }\n if (!skipSx) {\n expressionsTail.push(styleFunctionSx);\n }\n\n // This function can be called as a tagged template, so the first argument would contain\n // CSS `string[]` values.\n if (Array.isArray(expressionsBody[0])) {\n const inputStrings = expressionsBody.shift();\n\n // We need to add placeholders in the tagged template for the custom functions we have\n // possibly added (attachTheme, overrides, variants, and sx).\n const placeholdersHead = new Array(expressionsHead.length).fill('');\n const placeholdersTail = new Array(expressionsTail.length).fill('');\n let outputStrings;\n // prettier-ignore\n {\n outputStrings = [...placeholdersHead, ...inputStrings, ...placeholdersTail];\n outputStrings.raw = [...placeholdersHead, ...inputStrings.raw, ...placeholdersTail];\n }\n\n // The only case where we put something before `attachTheme`\n expressionsHead.unshift(outputStrings);\n }\n const expressions = [...expressionsHead, ...expressionsBody, ...expressionsTail];\n const Component = defaultStyledResolver(...expressions);\n if (tag.muiName) {\n Component.muiName = tag.muiName;\n }\n if (process.env.NODE_ENV !== 'production') {\n Component.displayName = generateDisplayName(componentName, componentSlot, tag);\n }\n return Component;\n };\n if (defaultStyledResolver.withConfig) {\n muiStyledResolver.withConfig = defaultStyledResolver.withConfig;\n }\n return muiStyledResolver;\n };\n return styled;\n}\nfunction generateDisplayName(componentName, componentSlot, tag) {\n if (componentName) {\n return `${componentName}${capitalize(componentSlot || '')}`;\n }\n return `Styled(${getDisplayName(tag)})`;\n}\nfunction generateStyledLabel(componentName, componentSlot) {\n let label;\n if (process.env.NODE_ENV !== 'production') {\n if (componentName) {\n // TODO v6: remove `lowercaseFirstLetter()` in the next major release\n // For more details: https://github.com/mui/material-ui/pull/37908\n label = `${componentName}-${lowercaseFirstLetter(componentSlot || 'Root')}`;\n }\n }\n return label;\n}\nfunction isObjectEmpty(object) {\n // eslint-disable-next-line\n for (const _ in object) {\n return false;\n }\n return true;\n}\n\n// https://github.com/emotion-js/emotion/blob/26ded6109fcd8ca9875cc2ce4564fee678a3f3c5/packages/styled/src/utils.js#L40\nfunction isStringTag(tag) {\n return typeof tag === 'string' &&\n // 96 is one less than the char code\n // for \"a\" so this is checking that\n // it's a lowercase character\n tag.charCodeAt(0) > 96;\n}\nfunction lowercaseFirstLetter(string) {\n if (!string) {\n return string;\n }\n return string.charAt(0).toLowerCase() + string.slice(1);\n}","import clsx from 'clsx';\n\n/**\n * Add keys, values of `defaultProps` that does not exist in `props`\n * @param defaultProps\n * @param props\n * @param mergeClassNameAndStyle If `true`, merges `className` and `style` props instead of overriding them.\n * When `false` (default), props override defaultProps. When `true`, `className` values are concatenated\n * and `style` objects are merged with props taking precedence.\n * @returns resolved props\n */\nexport default function resolveProps(defaultProps, props, mergeClassNameAndStyle = false) {\n const output = {\n ...props\n };\n for (const key in defaultProps) {\n if (Object.prototype.hasOwnProperty.call(defaultProps, key)) {\n const propName = key;\n if (propName === 'components' || propName === 'slots') {\n output[propName] = {\n ...defaultProps[propName],\n ...output[propName]\n };\n } else if (propName === 'componentsProps' || propName === 'slotProps') {\n const defaultSlotProps = defaultProps[propName];\n const slotProps = props[propName];\n if (!slotProps) {\n output[propName] = defaultSlotProps || {};\n } else if (!defaultSlotProps) {\n output[propName] = slotProps;\n } else {\n output[propName] = {\n ...slotProps\n };\n for (const slotKey in defaultSlotProps) {\n if (Object.prototype.hasOwnProperty.call(defaultSlotProps, slotKey)) {\n const slotPropName = slotKey;\n output[propName][slotPropName] = resolveProps(defaultSlotProps[slotPropName], slotProps[slotPropName], mergeClassNameAndStyle);\n }\n }\n }\n } else if (propName === 'className' && mergeClassNameAndStyle && props.className) {\n output.className = clsx(defaultProps?.className, props?.className);\n } else if (propName === 'style' && mergeClassNameAndStyle && props.style) {\n output.style = {\n ...defaultProps?.style,\n ...props?.style\n };\n } else if (output[propName] === undefined) {\n output[propName] = defaultProps[propName];\n }\n }\n }\n return output;\n}","'use client';\n\nimport * as React from 'react';\n\n/**\n * A version of `React.useLayoutEffect` that does not show a warning when server-side rendering.\n * This is useful for effects that are only needed for client-side rendering but not for SSR.\n *\n * Before you use this hook, make sure to read https://gist.github.com/gaearon/e7d97cdf38a2907924ea12e4ebdf3c85\n * and confirm it doesn't apply to your use-case.\n */\nconst useEnhancedEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nexport default useEnhancedEffect;","function clamp(val, min = Number.MIN_SAFE_INTEGER, max = Number.MAX_SAFE_INTEGER) {\n return Math.max(min, Math.min(val, max));\n}\nexport default clamp;","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\n/* eslint-disable @typescript-eslint/naming-convention */\nimport clamp from '@mui/utils/clamp';\n\n/**\n * Returns a number whose value is limited to the given range.\n * @param {number} value The value to be clamped\n * @param {number} min The lower boundary of the output range\n * @param {number} max The upper boundary of the output range\n * @returns {number} A number in the range [min, max]\n */\nfunction clampWrapper(value, min = 0, max = 1) {\n if (process.env.NODE_ENV !== 'production') {\n if (value < min || value > max) {\n console.error(`MUI: The value provided ${value} is out of range [${min}, ${max}].`);\n }\n }\n return clamp(value, min, max);\n}\n\n/**\n * Converts a color from CSS hex format to CSS rgb format.\n * @param {string} color - Hex color, i.e. #nnn or #nnnnnn\n * @returns {string} A CSS rgb color string\n */\nexport function hexToRgb(color) {\n color = color.slice(1);\n const re = new RegExp(`.{1,${color.length >= 6 ? 2 : 1}}`, 'g');\n let colors = color.match(re);\n if (colors && colors[0].length === 1) {\n colors = colors.map(n => n + n);\n }\n if (process.env.NODE_ENV !== 'production') {\n if (color.length !== color.trim().length) {\n console.error(`MUI: The color: \"${color}\" is invalid. Make sure the color input doesn't contain leading/trailing space.`);\n }\n }\n return colors ? `rgb${colors.length === 4 ? 'a' : ''}(${colors.map((n, index) => {\n return index < 3 ? parseInt(n, 16) : Math.round(parseInt(n, 16) / 255 * 1000) / 1000;\n }).join(', ')})` : '';\n}\nfunction intToHex(int) {\n const hex = int.toString(16);\n return hex.length === 1 ? `0${hex}` : hex;\n}\n\n/**\n * Returns an object with the type and values of a color.\n *\n * Note: Does not support rgb % values.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {object} - A MUI color object: {type: string, values: number[]}\n */\nexport function decomposeColor(color) {\n // Idempotent\n if (color.type) {\n return color;\n }\n if (color.charAt(0) === '#') {\n return decomposeColor(hexToRgb(color));\n }\n const marker = color.indexOf('(');\n const type = color.substring(0, marker);\n if (!['rgb', 'rgba', 'hsl', 'hsla', 'color'].includes(type)) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: Unsupported \\`${color}\\` color.\\n` + 'The following formats are supported: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color().' : _formatErrorMessage(9, color));\n }\n let values = color.substring(marker + 1, color.length - 1);\n let colorSpace;\n if (type === 'color') {\n values = values.split(' ');\n colorSpace = values.shift();\n if (values.length === 4 && values[3].charAt(0) === '/') {\n values[3] = values[3].slice(1);\n }\n if (!['srgb', 'display-p3', 'a98-rgb', 'prophoto-rgb', 'rec-2020'].includes(colorSpace)) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: unsupported \\`${colorSpace}\\` color space.\\n` + 'The following color spaces are supported: srgb, display-p3, a98-rgb, prophoto-rgb, rec-2020.' : _formatErrorMessage(10, colorSpace));\n }\n } else {\n values = values.split(',');\n }\n values = values.map(value => parseFloat(value));\n return {\n type,\n values,\n colorSpace\n };\n}\n\n/**\n * Returns a channel created from the input color.\n *\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {string} - The channel for the color, that can be used in rgba or hsla colors\n */\nexport const colorChannel = color => {\n const decomposedColor = decomposeColor(color);\n return decomposedColor.values.slice(0, 3).map((val, idx) => decomposedColor.type.includes('hsl') && idx !== 0 ? `${val}%` : val).join(' ');\n};\nexport const private_safeColorChannel = (color, warning) => {\n try {\n return colorChannel(color);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n};\n\n/**\n * Converts a color object with type and values to a string.\n * @param {object} color - Decomposed color\n * @param {string} color.type - One of: 'rgb', 'rgba', 'hsl', 'hsla', 'color'\n * @param {array} color.values - [n,n,n] or [n,n,n,n]\n * @returns {string} A CSS color string\n */\nexport function recomposeColor(color) {\n const {\n type,\n colorSpace\n } = color;\n let {\n values\n } = color;\n if (type.includes('rgb')) {\n // Only convert the first 3 values to int (i.e. not alpha)\n values = values.map((n, i) => i < 3 ? parseInt(n, 10) : n);\n } else if (type.includes('hsl')) {\n values[1] = `${values[1]}%`;\n values[2] = `${values[2]}%`;\n }\n if (type.includes('color')) {\n values = `${colorSpace} ${values.join(' ')}`;\n } else {\n values = `${values.join(', ')}`;\n }\n return `${type}(${values})`;\n}\n\n/**\n * Converts a color from CSS rgb format to CSS hex format.\n * @param {string} color - RGB color, i.e. rgb(n, n, n)\n * @returns {string} A CSS rgb color string, i.e. #nnnnnn\n */\nexport function rgbToHex(color) {\n // Idempotent\n if (color.startsWith('#')) {\n return color;\n }\n const {\n values\n } = decomposeColor(color);\n return `#${values.map((n, i) => intToHex(i === 3 ? Math.round(255 * n) : n)).join('')}`;\n}\n\n/**\n * Converts a color from hsl format to rgb format.\n * @param {string} color - HSL color values\n * @returns {string} rgb color values\n */\nexport function hslToRgb(color) {\n color = decomposeColor(color);\n const {\n values\n } = color;\n const h = values[0];\n const s = values[1] / 100;\n const l = values[2] / 100;\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n let type = 'rgb';\n const rgb = [Math.round(f(0) * 255), Math.round(f(8) * 255), Math.round(f(4) * 255)];\n if (color.type === 'hsla') {\n type += 'a';\n rgb.push(values[3]);\n }\n return recomposeColor({\n type,\n values: rgb\n });\n}\n/**\n * The relative brightness of any point in a color space,\n * normalized to 0 for darkest black and 1 for lightest white.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @returns {number} The relative brightness of the color in the range 0 - 1\n */\nexport function getLuminance(color) {\n color = decomposeColor(color);\n let rgb = color.type === 'hsl' || color.type === 'hsla' ? decomposeColor(hslToRgb(color)).values : color.values;\n rgb = rgb.map(val => {\n if (color.type !== 'color') {\n val /= 255; // normalized\n }\n return val <= 0.03928 ? val / 12.92 : ((val + 0.055) / 1.055) ** 2.4;\n });\n\n // Truncate at 3 digits\n return Number((0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]).toFixed(3));\n}\n\n/**\n * Calculates the contrast ratio between two colors.\n *\n * Formula: https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests\n * @param {string} foreground - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @param {string} background - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla()\n * @returns {number} A contrast ratio value in the range 0 - 21.\n */\nexport function getContrastRatio(foreground, background) {\n const lumA = getLuminance(foreground);\n const lumB = getLuminance(background);\n return (Math.max(lumA, lumB) + 0.05) / (Math.min(lumA, lumB) + 0.05);\n}\n\n/**\n * Sets the absolute transparency of a color.\n * Any existing alpha values are overwritten.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} value - value to set the alpha channel to in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nexport function alpha(color, value) {\n color = decomposeColor(color);\n value = clampWrapper(value);\n if (color.type === 'rgb' || color.type === 'hsl') {\n color.type += 'a';\n }\n if (color.type === 'color') {\n color.values[3] = `/${value}`;\n } else {\n color.values[3] = value;\n }\n return recomposeColor(color);\n}\nexport function private_safeAlpha(color, value, warning) {\n try {\n return alpha(color, value);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Darkens a color.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nexport function darken(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clampWrapper(coefficient);\n if (color.type.includes('hsl')) {\n color.values[2] *= 1 - coefficient;\n } else if (color.type.includes('rgb') || color.type.includes('color')) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] *= 1 - coefficient;\n }\n }\n return recomposeColor(color);\n}\nexport function private_safeDarken(color, coefficient, warning) {\n try {\n return darken(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Lightens a color.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nexport function lighten(color, coefficient) {\n color = decomposeColor(color);\n coefficient = clampWrapper(coefficient);\n if (color.type.includes('hsl')) {\n color.values[2] += (100 - color.values[2]) * coefficient;\n } else if (color.type.includes('rgb')) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] += (255 - color.values[i]) * coefficient;\n }\n } else if (color.type.includes('color')) {\n for (let i = 0; i < 3; i += 1) {\n color.values[i] += (1 - color.values[i]) * coefficient;\n }\n }\n return recomposeColor(color);\n}\nexport function private_safeLighten(color, coefficient, warning) {\n try {\n return lighten(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Darken or lighten a color, depending on its luminance.\n * Light colors are darkened, dark colors are lightened.\n * @param {string} color - CSS color, i.e. one of: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color()\n * @param {number} coefficient=0.15 - multiplier in the range 0 - 1\n * @returns {string} A CSS color string. Hex input values are returned as rgb\n */\nexport function emphasize(color, coefficient = 0.15) {\n return getLuminance(color) > 0.5 ? darken(color, coefficient) : lighten(color, coefficient);\n}\nexport function private_safeEmphasize(color, coefficient, warning) {\n try {\n return emphasize(color, coefficient);\n } catch (error) {\n if (warning && process.env.NODE_ENV !== 'production') {\n console.warn(warning);\n }\n return color;\n }\n}\n\n/**\n * Blend a transparent overlay color with a background color, resulting in a single\n * RGB color.\n * @param {string} background - CSS color\n * @param {string} overlay - CSS color\n * @param {number} opacity - Opacity multiplier in the range 0 - 1\n * @param {number} [gamma=1.0] - Gamma correction factor. For gamma-correct blending, 2.2 is usual.\n */\nexport function blend(background, overlay, opacity, gamma = 1.0) {\n const blendChannel = (b, o) => Math.round((b ** (1 / gamma) * (1 - opacity) + o ** (1 / gamma) * opacity) ** gamma);\n const backgroundColor = decomposeColor(background);\n const overlayColor = decomposeColor(overlay);\n const rgb = [blendChannel(backgroundColor.values[0], overlayColor.values[0]), blendChannel(backgroundColor.values[1], overlayColor.values[1]), blendChannel(backgroundColor.values[2], overlayColor.values[2])];\n return recomposeColor({\n type: 'rgb',\n values: rgb\n });\n}","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport resolveProps from '@mui/utils/resolveProps';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst PropsContext = /*#__PURE__*/React.createContext(undefined);\nfunction DefaultPropsProvider({\n value,\n children\n}) {\n return /*#__PURE__*/_jsx(PropsContext.Provider, {\n value: value,\n children: children\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? DefaultPropsProvider.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * @ignore\n */\n value: PropTypes.object\n} : void 0;\nfunction getThemeProps(params) {\n const {\n theme,\n name,\n props\n } = params;\n if (!theme || !theme.components || !theme.components[name]) {\n return props;\n }\n const config = theme.components[name];\n if (config.defaultProps) {\n // compatible with v5 signature\n return resolveProps(config.defaultProps, props, theme.components.mergeClassNameAndStyle);\n }\n if (!config.styleOverrides && !config.variants) {\n // v6 signature, no property 'defaultProps'\n return resolveProps(config, props, theme.components.mergeClassNameAndStyle);\n }\n return props;\n}\nexport function useDefaultProps({\n props,\n name\n}) {\n const ctx = React.useContext(PropsContext);\n return getThemeProps({\n props,\n name,\n theme: {\n components: ctx\n }\n });\n}\nexport default DefaultPropsProvider;","'use client';\n\nimport * as React from 'react';\nlet globalId = 0;\n\n// TODO React 17: Remove `useGlobalId` once React 17 support is removed\nfunction useGlobalId(idOverride) {\n const [defaultId, setDefaultId] = React.useState(idOverride);\n const id = idOverride || defaultId;\n React.useEffect(() => {\n if (defaultId == null) {\n // Fallback to this default id when possible.\n // Use the incrementing value for client-side rendering only.\n // We can't use it server-side.\n // If you want to use random values please consider the Birthday Problem: https://en.wikipedia.org/wiki/Birthday_problem\n globalId += 1;\n setDefaultId(`mui-${globalId}`);\n }\n }, [defaultId]);\n return id;\n}\n\n// See https://github.com/mui/material-ui/issues/41190#issuecomment-2040873379 for why\nconst safeReact = {\n ...React\n};\nconst maybeReactUseId = safeReact.useId;\n\n/**\n *\n * @example <div id={useId()} />\n * @param idOverride\n * @returns {string}\n */\nexport default function useId(idOverride) {\n // React.useId() is only available from React 17.0.0.\n if (maybeReactUseId !== undefined) {\n const reactId = maybeReactUseId();\n return idOverride ?? reactId;\n }\n\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler\n // eslint-disable-next-line react-hooks/rules-of-hooks -- `React.useId` is invariant at runtime.\n return useGlobalId(idOverride);\n}","import preprocessStyles from \"./preprocessStyles.js\";\n\n/* eslint-disable @typescript-eslint/naming-convention */\n\n// We need to pass an argument as `{ theme }` for PigmentCSS, but we don't want to\n// allocate more objects.\nconst arg = {\n theme: undefined\n};\n\n/**\n * Memoize style function on theme.\n * Intended to be used in styled() calls that only need access to the theme.\n */\nexport default function unstable_memoTheme(styleFn) {\n let lastValue;\n let lastTheme;\n return function styleMemoized(props) {\n let value = lastValue;\n if (value === undefined || props.theme !== lastTheme) {\n arg.theme = props.theme;\n value = preprocessStyles(styleFn(arg));\n lastValue = value;\n lastTheme = props.theme;\n }\n return value;\n };\n}","/**\n * The benefit of this function is to help developers get CSS var from theme without specifying the whole variable\n * and they does not need to remember the prefix (defined once).\n */\nexport default function createGetCssVar(prefix = '') {\n function appendVar(...vars) {\n if (!vars.length) {\n return '';\n }\n const value = vars[0];\n if (typeof value === 'string' && !value.match(/(#|\\(|\\)|(-?(\\d*\\.)?\\d+)(px|em|%|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc))|^(-?(\\d*\\.)?\\d+)$|(\\d+ \\d+ \\d+)/)) {\n return `, var(--${prefix ? `${prefix}-` : ''}${value}${appendVar(...vars.slice(1))})`;\n }\n return `, ${value}`;\n }\n\n // AdditionalVars makes `getCssVar` less strict, so it can be use like this `getCssVar('non-mui-variable')` without type error.\n const getCssVar = (field, ...fallbacks) => {\n return `var(--${prefix ? `${prefix}-` : ''}${field}${appendVar(...fallbacks)})`;\n };\n return getCssVar;\n}","/**\n * This function create an object from keys, value and then assign to target\n *\n * @param {Object} obj : the target object to be assigned\n * @param {string[]} keys\n * @param {string | number} value\n *\n * @example\n * const source = {}\n * assignNestedKeys(source, ['palette', 'primary'], 'var(--palette-primary)')\n * console.log(source) // { palette: { primary: 'var(--palette-primary)' } }\n *\n * @example\n * const source = { palette: { primary: 'var(--palette-primary)' } }\n * assignNestedKeys(source, ['palette', 'secondary'], 'var(--palette-secondary)')\n * console.log(source) // { palette: { primary: 'var(--palette-primary)', secondary: 'var(--palette-secondary)' } }\n */\nexport const assignNestedKeys = (obj, keys, value, arrayKeys = []) => {\n let temp = obj;\n keys.forEach((k, index) => {\n if (index === keys.length - 1) {\n if (Array.isArray(temp)) {\n temp[Number(k)] = value;\n } else if (temp && typeof temp === 'object') {\n temp[k] = value;\n }\n } else if (temp && typeof temp === 'object') {\n if (!temp[k]) {\n temp[k] = arrayKeys.includes(k) ? [] : {};\n }\n temp = temp[k];\n }\n });\n};\n\n/**\n *\n * @param {Object} obj : source object\n * @param {Function} callback : a function that will be called when\n * - the deepest key in source object is reached\n * - the value of the deepest key is NOT `undefined` | `null`\n *\n * @example\n * walkObjectDeep({ palette: { primary: { main: '#000000' } } }, console.log)\n * // ['palette', 'primary', 'main'] '#000000'\n */\nexport const walkObjectDeep = (obj, callback, shouldSkipPaths) => {\n function recurse(object, parentKeys = [], arrayKeys = []) {\n Object.entries(object).forEach(([key, value]) => {\n if (!shouldSkipPaths || shouldSkipPaths && !shouldSkipPaths([...parentKeys, key])) {\n if (value !== undefined && value !== null) {\n if (typeof value === 'object' && Object.keys(value).length > 0) {\n recurse(value, [...parentKeys, key], Array.isArray(value) ? [...arrayKeys, key] : arrayKeys);\n } else {\n callback([...parentKeys, key], value, arrayKeys);\n }\n }\n }\n });\n }\n recurse(obj);\n};\nconst getCssValue = (keys, value) => {\n if (typeof value === 'number') {\n if (['lineHeight', 'fontWeight', 'opacity', 'zIndex'].some(prop => keys.includes(prop))) {\n // CSS property that are unitless\n return value;\n }\n const lastKey = keys[keys.length - 1];\n if (lastKey.toLowerCase().includes('opacity')) {\n // opacity values are unitless\n return value;\n }\n return `${value}px`;\n }\n return value;\n};\n\n/**\n * a function that parse theme and return { css, vars }\n *\n * @param {Object} theme\n * @param {{\n * prefix?: string,\n * shouldSkipGeneratingVar?: (objectPathKeys: Array<string>, value: string | number) => boolean\n * }} options.\n * `prefix`: The prefix of the generated CSS variables. This function does not change the value.\n *\n * @returns {{ css: Object, vars: Object }} `css` is the stylesheet, `vars` is an object to get css variable (same structure as theme).\n *\n * @example\n * const { css, vars } = parser({\n * fontSize: 12,\n * lineHeight: 1.2,\n * palette: { primary: { 500: 'var(--color)' } }\n * }, { prefix: 'foo' })\n *\n * console.log(css) // { '--foo-fontSize': '12px', '--foo-lineHeight': 1.2, '--foo-palette-primary-500': 'var(--color)' }\n * console.log(vars) // { fontSize: 'var(--foo-fontSize)', lineHeight: 'var(--foo-lineHeight)', palette: { primary: { 500: 'var(--foo-palette-primary-500)' } } }\n */\nexport default function cssVarsParser(theme, options) {\n const {\n prefix,\n shouldSkipGeneratingVar\n } = options || {};\n const css = {};\n const vars = {};\n const varsWithDefaults = {};\n walkObjectDeep(theme, (keys, value, arrayKeys) => {\n if (typeof value === 'string' || typeof value === 'number') {\n if (!shouldSkipGeneratingVar || !shouldSkipGeneratingVar(keys, value)) {\n // only create css & var if `shouldSkipGeneratingVar` return false\n const cssVar = `--${prefix ? `${prefix}-` : ''}${keys.join('-')}`;\n const resolvedValue = getCssValue(keys, value);\n Object.assign(css, {\n [cssVar]: resolvedValue\n });\n assignNestedKeys(vars, keys, `var(${cssVar})`, arrayKeys);\n assignNestedKeys(varsWithDefaults, keys, `var(${cssVar}, ${resolvedValue})`, arrayKeys);\n }\n }\n }, keys => keys[0] === 'vars' // skip 'vars/*' paths\n );\n return {\n css,\n vars,\n varsWithDefaults\n };\n}","import deepmerge from '@mui/utils/deepmerge';\nimport cssVarsParser from \"./cssVarsParser.js\";\nfunction prepareCssVars(theme, parserConfig = {}) {\n const {\n getSelector = defaultGetSelector,\n disableCssColorScheme,\n colorSchemeSelector: selector,\n enableContrastVars\n } = parserConfig;\n // @ts-ignore - ignore components do not exist\n const {\n colorSchemes = {},\n components,\n defaultColorScheme = 'light',\n ...otherTheme\n } = theme;\n const {\n vars: rootVars,\n css: rootCss,\n varsWithDefaults: rootVarsWithDefaults\n } = cssVarsParser(otherTheme, parserConfig);\n let themeVars = rootVarsWithDefaults;\n const colorSchemesMap = {};\n const {\n [defaultColorScheme]: defaultScheme,\n ...otherColorSchemes\n } = colorSchemes;\n Object.entries(otherColorSchemes || {}).forEach(([key, scheme]) => {\n const {\n vars,\n css,\n varsWithDefaults\n } = cssVarsParser(scheme, parserConfig);\n themeVars = deepmerge(themeVars, varsWithDefaults);\n colorSchemesMap[key] = {\n css,\n vars\n };\n });\n if (defaultScheme) {\n // default color scheme vars should be merged last to set as default\n const {\n css,\n vars,\n varsWithDefaults\n } = cssVarsParser(defaultScheme, parserConfig);\n themeVars = deepmerge(themeVars, varsWithDefaults);\n colorSchemesMap[defaultColorScheme] = {\n css,\n vars\n };\n }\n function defaultGetSelector(colorScheme, cssObject) {\n let rule = selector;\n if (selector === 'class') {\n rule = '.%s';\n }\n if (selector === 'data') {\n rule = '[data-%s]';\n }\n if (selector?.startsWith('data-') && !selector.includes('%s')) {\n // 'data-joy-color-scheme' -> '[data-joy-color-scheme=\"%s\"]'\n rule = `[${selector}=\"%s\"]`;\n }\n if (colorScheme) {\n if (rule === 'media') {\n if (theme.defaultColorScheme === colorScheme) {\n return ':root';\n }\n const mode = colorSchemes[colorScheme]?.palette?.mode || colorScheme;\n return {\n [`@media (prefers-color-scheme: ${mode})`]: {\n ':root': cssObject\n }\n };\n }\n if (rule) {\n if (theme.defaultColorScheme === colorScheme) {\n return `:root, ${rule.replace('%s', String(colorScheme))}`;\n }\n return rule.replace('%s', String(colorScheme));\n }\n }\n return ':root';\n }\n const generateThemeVars = () => {\n let vars = {\n ...rootVars\n };\n Object.entries(colorSchemesMap).forEach(([, {\n vars: schemeVars\n }]) => {\n vars = deepmerge(vars, schemeVars);\n });\n return vars;\n };\n const generateStyleSheets = () => {\n const stylesheets = [];\n const colorScheme = theme.defaultColorScheme || 'light';\n function insertStyleSheet(key, css) {\n if (Object.keys(css).length) {\n stylesheets.push(typeof key === 'string' ? {\n [key]: {\n ...css\n }\n } : key);\n }\n }\n insertStyleSheet(getSelector(undefined, {\n ...rootCss\n }), rootCss);\n const {\n [colorScheme]: defaultSchemeVal,\n ...other\n } = colorSchemesMap;\n if (defaultSchemeVal) {\n // default color scheme has to come before other color schemes\n const {\n css\n } = defaultSchemeVal;\n const cssColorSheme = colorSchemes[colorScheme]?.palette?.mode;\n const finalCss = !disableCssColorScheme && cssColorSheme ? {\n colorScheme: cssColorSheme,\n ...css\n } : {\n ...css\n };\n insertStyleSheet(getSelector(colorScheme, {\n ...finalCss\n }), finalCss);\n }\n Object.entries(other).forEach(([key, {\n css\n }]) => {\n const cssColorSheme = colorSchemes[key]?.palette?.mode;\n const finalCss = !disableCssColorScheme && cssColorSheme ? {\n colorScheme: cssColorSheme,\n ...css\n } : {\n ...css\n };\n insertStyleSheet(getSelector(key, {\n ...finalCss\n }), finalCss);\n });\n if (enableContrastVars) {\n stylesheets.push({\n ':root': {\n // use double underscore to indicate that these are private variables\n '--__l-threshold': '0.7',\n '--__l': 'clamp(0, (l / var(--__l-threshold) - 1) * -infinity, 1)',\n '--__a': 'clamp(0.87, (l / var(--__l-threshold) - 1) * -infinity, 1)' // 0.87 is the default alpha value for black text.\n }\n });\n }\n return stylesheets;\n };\n return {\n vars: themeVars,\n generateThemeVars,\n generateStyleSheets\n };\n}\nexport default prepareCssVars;","/* eslint-disable import/prefer-default-export */\nexport function createGetColorSchemeSelector(selector) {\n return function getColorSchemeSelector(colorScheme) {\n if (selector === 'media') {\n if (process.env.NODE_ENV !== 'production') {\n if (colorScheme !== 'light' && colorScheme !== 'dark') {\n console.error(`MUI: @media (prefers-color-scheme) supports only 'light' or 'dark', but receive '${colorScheme}'.`);\n }\n }\n return `@media (prefers-color-scheme: ${colorScheme})`;\n }\n if (selector) {\n if (selector.startsWith('data-') && !selector.includes('%s')) {\n return `[${selector}=\"${colorScheme}\"] &`;\n }\n if (selector === 'class') {\n return `.${colorScheme} &`;\n }\n if (selector === 'data') {\n return `[data-${colorScheme}] &`;\n }\n return `${selector.replace('%s', colorScheme)} &`;\n }\n return '&';\n };\n}","/* eslint no-restricted-syntax: 0, prefer-template: 0, guard-for-in: 0\n ---\n These rules are preventing the performance optimizations below.\n */\n\n/**\n * Compose classes from multiple sources.\n *\n * @example\n * ```tsx\n * const slots = {\n * root: ['root', 'primary'],\n * label: ['label'],\n * };\n *\n * const getUtilityClass = (slot) => `MuiButton-${slot}`;\n *\n * const classes = {\n * root: 'my-root-class',\n * };\n *\n * const output = composeClasses(slots, getUtilityClass, classes);\n * // {\n * // root: 'MuiButton-root MuiButton-primary my-root-class',\n * // label: 'MuiButton-label',\n * // }\n * ```\n *\n * @param slots a list of classes for each possible slot\n * @param getUtilityClass a function to resolve the class based on the slot name\n * @param classes the input classes from props\n * @returns the resolved classes for all slots\n */\nexport default function composeClasses(slots, getUtilityClass, classes = undefined) {\n const output = {};\n for (const slotName in slots) {\n const slot = slots[slotName];\n let buffer = '';\n let start = true;\n for (let i = 0; i < slot.length; i += 1) {\n const value = slot[i];\n if (value) {\n buffer += (start === true ? '' : ' ') + getUtilityClass(value);\n start = false;\n if (classes && classes[value]) {\n buffer += ' ' + classes[value];\n }\n }\n }\n output[slotName] = buffer;\n }\n return output;\n}","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\nimport deepmerge from '@mui/utils/deepmerge';\nimport { darken, getContrastRatio, lighten } from '@mui/system/colorManipulator';\nimport common from \"../colors/common.js\";\nimport grey from \"../colors/grey.js\";\nimport purple from \"../colors/purple.js\";\nimport red from \"../colors/red.js\";\nimport orange from \"../colors/orange.js\";\nimport blue from \"../colors/blue.js\";\nimport lightBlue from \"../colors/lightBlue.js\";\nimport green from \"../colors/green.js\";\nfunction getLight() {\n return {\n // The colors used to style the text.\n text: {\n // The most important text.\n primary: 'rgba(0, 0, 0, 0.87)',\n // Secondary text.\n secondary: 'rgba(0, 0, 0, 0.6)',\n // Disabled text have even lower visual prominence.\n disabled: 'rgba(0, 0, 0, 0.38)'\n },\n // The color used to divide different elements.\n divider: 'rgba(0, 0, 0, 0.12)',\n // The background colors used to style the surfaces.\n // Consistency between these values is important.\n background: {\n paper: common.white,\n default: common.white\n },\n // The colors used to style the action elements.\n action: {\n // The color of an active action like an icon button.\n active: 'rgba(0, 0, 0, 0.54)',\n // The color of an hovered action.\n hover: 'rgba(0, 0, 0, 0.04)',\n hoverOpacity: 0.04,\n // The color of a selected action.\n selected: 'rgba(0, 0, 0, 0.08)',\n selectedOpacity: 0.08,\n // The color of a disabled action.\n disabled: 'rgba(0, 0, 0, 0.26)',\n // The background color of a disabled action.\n disabledBackground: 'rgba(0, 0, 0, 0.12)',\n disabledOpacity: 0.38,\n focus: 'rgba(0, 0, 0, 0.12)',\n focusOpacity: 0.12,\n activatedOpacity: 0.12\n }\n };\n}\nexport const light = getLight();\nfunction getDark() {\n return {\n text: {\n primary: common.white,\n secondary: 'rgba(255, 255, 255, 0.7)',\n disabled: 'rgba(255, 255, 255, 0.5)',\n icon: 'rgba(255, 255, 255, 0.5)'\n },\n divider: 'rgba(255, 255, 255, 0.12)',\n background: {\n paper: '#121212',\n default: '#121212'\n },\n action: {\n active: common.white,\n hover: 'rgba(255, 255, 255, 0.08)',\n hoverOpacity: 0.08,\n selected: 'rgba(255, 255, 255, 0.16)',\n selectedOpacity: 0.16,\n disabled: 'rgba(255, 255, 255, 0.3)',\n disabledBackground: 'rgba(255, 255, 255, 0.12)',\n disabledOpacity: 0.38,\n focus: 'rgba(255, 255, 255, 0.12)',\n focusOpacity: 0.12,\n activatedOpacity: 0.24\n }\n };\n}\nexport const dark = getDark();\nfunction addLightOrDark(intent, direction, shade, tonalOffset) {\n const tonalOffsetLight = tonalOffset.light || tonalOffset;\n const tonalOffsetDark = tonalOffset.dark || tonalOffset * 1.5;\n if (!intent[direction]) {\n if (intent.hasOwnProperty(shade)) {\n intent[direction] = intent[shade];\n } else if (direction === 'light') {\n intent.light = lighten(intent.main, tonalOffsetLight);\n } else if (direction === 'dark') {\n intent.dark = darken(intent.main, tonalOffsetDark);\n }\n }\n}\nfunction mixLightOrDark(colorSpace, intent, direction, shade, tonalOffset) {\n const tonalOffsetLight = tonalOffset.light || tonalOffset;\n const tonalOffsetDark = tonalOffset.dark || tonalOffset * 1.5;\n if (!intent[direction]) {\n if (intent.hasOwnProperty(shade)) {\n intent[direction] = intent[shade];\n } else if (direction === 'light') {\n intent.light = `color-mix(in ${colorSpace}, ${intent.main}, #fff ${(tonalOffsetLight * 100).toFixed(0)}%)`;\n } else if (direction === 'dark') {\n intent.dark = `color-mix(in ${colorSpace}, ${intent.main}, #000 ${(tonalOffsetDark * 100).toFixed(0)}%)`;\n }\n }\n}\nfunction getDefaultPrimary(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: blue[200],\n light: blue[50],\n dark: blue[400]\n };\n }\n return {\n main: blue[700],\n light: blue[400],\n dark: blue[800]\n };\n}\nfunction getDefaultSecondary(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: purple[200],\n light: purple[50],\n dark: purple[400]\n };\n }\n return {\n main: purple[500],\n light: purple[300],\n dark: purple[700]\n };\n}\nfunction getDefaultError(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: red[500],\n light: red[300],\n dark: red[700]\n };\n }\n return {\n main: red[700],\n light: red[400],\n dark: red[800]\n };\n}\nfunction getDefaultInfo(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: lightBlue[400],\n light: lightBlue[300],\n dark: lightBlue[700]\n };\n }\n return {\n main: lightBlue[700],\n light: lightBlue[500],\n dark: lightBlue[900]\n };\n}\nfunction getDefaultSuccess(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: green[400],\n light: green[300],\n dark: green[700]\n };\n }\n return {\n main: green[800],\n light: green[500],\n dark: green[900]\n };\n}\nfunction getDefaultWarning(mode = 'light') {\n if (mode === 'dark') {\n return {\n main: orange[400],\n light: orange[300],\n dark: orange[700]\n };\n }\n return {\n main: '#ed6c02',\n // closest to orange[800] that pass 3:1.\n light: orange[500],\n dark: orange[900]\n };\n}\n\n// Use the same name as the experimental CSS `contrast-color` function.\nexport function contrastColor(background) {\n return `oklch(from ${background} var(--__l) 0 h / var(--__a))`;\n}\nexport default function createPalette(palette) {\n const {\n mode = 'light',\n contrastThreshold = 3,\n tonalOffset = 0.2,\n colorSpace,\n ...other\n } = palette;\n const primary = palette.primary || getDefaultPrimary(mode);\n const secondary = palette.secondary || getDefaultSecondary(mode);\n const error = palette.error || getDefaultError(mode);\n const info = palette.info || getDefaultInfo(mode);\n const success = palette.success || getDefaultSuccess(mode);\n const warning = palette.warning || getDefaultWarning(mode);\n\n // Use the same logic as\n // Bootstrap: https://github.com/twbs/bootstrap/blob/1d6e3710dd447de1a200f29e8fa521f8a0908f70/scss/_functions.scss#L59\n // and material-components-web https://github.com/material-components/material-components-web/blob/ac46b8863c4dab9fc22c4c662dc6bd1b65dd652f/packages/mdc-theme/_functions.scss#L54\n function getContrastText(background) {\n if (colorSpace) {\n return contrastColor(background);\n }\n const contrastText = getContrastRatio(background, dark.text.primary) >= contrastThreshold ? dark.text.primary : light.text.primary;\n if (process.env.NODE_ENV !== 'production') {\n const contrast = getContrastRatio(background, contrastText);\n if (contrast < 3) {\n console.error([`MUI: The contrast ratio of ${contrast}:1 for ${contrastText} on ${background}`, 'falls below the WCAG recommended absolute minimum contrast ratio of 3:1.', 'https://www.w3.org/TR/2008/REC-WCAG20-20081211/#visual-audio-contrast-contrast'].join('\\n'));\n }\n }\n return contrastText;\n }\n const augmentColor = ({\n color,\n name,\n mainShade = 500,\n lightShade = 300,\n darkShade = 700\n }) => {\n color = {\n ...color\n };\n if (!color.main && color[mainShade]) {\n color.main = color[mainShade];\n }\n if (!color.hasOwnProperty('main')) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The color${name ? ` (${name})` : ''} provided to augmentColor(color) is invalid.\\n` + `The color object needs to have a \\`main\\` property or a \\`${mainShade}\\` property.` : _formatErrorMessage(11, name ? ` (${name})` : '', mainShade));\n }\n if (typeof color.main !== 'string') {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The color${name ? ` (${name})` : ''} provided to augmentColor(color) is invalid.\\n` + `\\`color.main\\` should be a string, but \\`${JSON.stringify(color.main)}\\` was provided instead.\\n` + '\\n' + 'Did you intend to use one of the following approaches?\\n' + '\\n' + 'import { green } from \"@mui/material/colors\";\\n' + '\\n' + 'const theme1 = createTheme({ palette: {\\n' + ' primary: green,\\n' + '} });\\n' + '\\n' + 'const theme2 = createTheme({ palette: {\\n' + ' primary: { main: green[500] },\\n' + '} });' : _formatErrorMessage(12, name ? ` (${name})` : '', JSON.stringify(color.main)));\n }\n if (colorSpace) {\n mixLightOrDark(colorSpace, color, 'light', lightShade, tonalOffset);\n mixLightOrDark(colorSpace, color, 'dark', darkShade, tonalOffset);\n } else {\n addLightOrDark(color, 'light', lightShade, tonalOffset);\n addLightOrDark(color, 'dark', darkShade, tonalOffset);\n }\n if (!color.contrastText) {\n color.contrastText = getContrastText(color.main);\n }\n return color;\n };\n let modeHydrated;\n if (mode === 'light') {\n modeHydrated = getLight();\n } else if (mode === 'dark') {\n modeHydrated = getDark();\n }\n if (process.env.NODE_ENV !== 'production') {\n if (!modeHydrated) {\n console.error(`MUI: The palette mode \\`${mode}\\` is not supported.`);\n }\n }\n const paletteOutput = deepmerge({\n // A collection of common colors.\n common: {\n ...common\n },\n // prevent mutable object.\n // The palette mode, can be light or dark.\n mode,\n // The colors used to represent primary interface elements for a user.\n primary: augmentColor({\n color: primary,\n name: 'primary'\n }),\n // The colors used to represent secondary interface elements for a user.\n secondary: augmentColor({\n color: secondary,\n name: 'secondary',\n mainShade: 'A400',\n lightShade: 'A200',\n darkShade: 'A700'\n }),\n // The colors used to represent interface elements that the user should be made aware of.\n error: augmentColor({\n color: error,\n name: 'error'\n }),\n // The colors used to represent potentially dangerous actions or important messages.\n warning: augmentColor({\n color: warning,\n name: 'warning'\n }),\n // The colors used to present information to the user that is neutral and not necessarily important.\n info: augmentColor({\n color: info,\n name: 'info'\n }),\n // The colors used to indicate the successful completion of an action that user triggered.\n success: augmentColor({\n color: success,\n name: 'success'\n }),\n // The grey colors.\n grey,\n // Used by `getContrastText()` to maximize the contrast between\n // the background and the text.\n contrastThreshold,\n // Takes a background color and returns the text color that maximizes the contrast.\n getContrastText,\n // Generate a rich color object.\n augmentColor,\n // Used by the functions below to shift a color's luminance by approximately\n // two indexes within its tonal palette.\n // E.g., shift from Red 500 to Red 300 or Red 700.\n tonalOffset,\n // The light and dark mode object.\n ...modeHydrated\n }, other);\n return paletteOutput;\n}","export default function prepareTypographyVars(typography) {\n const vars = {};\n const entries = Object.entries(typography);\n entries.forEach(entry => {\n const [key, value] = entry;\n if (typeof value === 'object') {\n vars[key] = `${value.fontStyle ? `${value.fontStyle} ` : ''}${value.fontVariant ? `${value.fontVariant} ` : ''}${value.fontWeight ? `${value.fontWeight} ` : ''}${value.fontStretch ? `${value.fontStretch} ` : ''}${value.fontSize || ''}${value.lineHeight ? `/${value.lineHeight} ` : ''}${value.fontFamily || ''}`;\n }\n });\n return vars;\n}","export default function createMixins(breakpoints, mixins) {\n return {\n toolbar: {\n minHeight: 56,\n [breakpoints.up('xs')]: {\n '@media (orientation: landscape)': {\n minHeight: 48\n }\n },\n [breakpoints.up('sm')]: {\n minHeight: 64\n }\n },\n ...mixins\n };\n}","import deepmerge from '@mui/utils/deepmerge';\nfunction round(value) {\n return Math.round(value * 1e5) / 1e5;\n}\nconst caseAllCaps = {\n textTransform: 'uppercase'\n};\nconst defaultFontFamily = '\"Roboto\", \"Helvetica\", \"Arial\", sans-serif';\n\n/**\n * @see @link{https://m2.material.io/design/typography/the-type-system.html}\n * @see @link{https://m2.material.io/design/typography/understanding-typography.html}\n */\nexport default function createTypography(palette, typography) {\n const {\n fontFamily = defaultFontFamily,\n // The default font size of the Material Specification.\n fontSize = 14,\n // px\n fontWeightLight = 300,\n fontWeightRegular = 400,\n fontWeightMedium = 500,\n fontWeightBold = 700,\n // Tell MUI what's the font-size on the html element.\n // 16px is the default font-size used by browsers.\n htmlFontSize = 16,\n // Apply the CSS properties to all the variants.\n allVariants,\n pxToRem: pxToRem2,\n ...other\n } = typeof typography === 'function' ? typography(palette) : typography;\n if (process.env.NODE_ENV !== 'production') {\n if (typeof fontSize !== 'number') {\n console.error('MUI: `fontSize` is required to be a number.');\n }\n if (typeof htmlFontSize !== 'number') {\n console.error('MUI: `htmlFontSize` is required to be a number.');\n }\n }\n const coef = fontSize / 14;\n const pxToRem = pxToRem2 || (size => `${size / htmlFontSize * coef}rem`);\n const buildVariant = (fontWeight, size, lineHeight, letterSpacing, casing) => ({\n fontFamily,\n fontWeight,\n fontSize: pxToRem(size),\n // Unitless following https://meyerweb.com/eric/thoughts/2006/02/08/unitless-line-heights/\n lineHeight,\n // The letter spacing was designed for the Roboto font-family. Using the same letter-spacing\n // across font-families can cause issues with the kerning.\n ...(fontFamily === defaultFontFamily ? {\n letterSpacing: `${round(letterSpacing / size)}em`\n } : {}),\n ...casing,\n ...allVariants\n });\n const variants = {\n h1: buildVariant(fontWeightLight, 96, 1.167, -1.5),\n h2: buildVariant(fontWeightLight, 60, 1.2, -0.5),\n h3: buildVariant(fontWeightRegular, 48, 1.167, 0),\n h4: buildVariant(fontWeightRegular, 34, 1.235, 0.25),\n h5: buildVariant(fontWeightRegular, 24, 1.334, 0),\n h6: buildVariant(fontWeightMedium, 20, 1.6, 0.15),\n subtitle1: buildVariant(fontWeightRegular, 16, 1.75, 0.15),\n subtitle2: buildVariant(fontWeightMedium, 14, 1.57, 0.1),\n body1: buildVariant(fontWeightRegular, 16, 1.5, 0.15),\n body2: buildVariant(fontWeightRegular, 14, 1.43, 0.15),\n button: buildVariant(fontWeightMedium, 14, 1.75, 0.4, caseAllCaps),\n caption: buildVariant(fontWeightRegular, 12, 1.66, 0.4),\n overline: buildVariant(fontWeightRegular, 12, 2.66, 1, caseAllCaps),\n // TODO v6: Remove handling of 'inherit' variant from the theme as it is already handled in Material UI's Typography component. Also, remember to remove the associated types.\n inherit: {\n fontFamily: 'inherit',\n fontWeight: 'inherit',\n fontSize: 'inherit',\n lineHeight: 'inherit',\n letterSpacing: 'inherit'\n }\n };\n return deepmerge({\n htmlFontSize,\n pxToRem,\n fontFamily,\n fontSize,\n fontWeightLight,\n fontWeightRegular,\n fontWeightMedium,\n fontWeightBold,\n ...variants\n }, other, {\n clone: false // No need to clone deep\n });\n}","const shadowKeyUmbraOpacity = 0.2;\nconst shadowKeyPenumbraOpacity = 0.14;\nconst shadowAmbientShadowOpacity = 0.12;\nfunction createShadow(...px) {\n return [`${px[0]}px ${px[1]}px ${px[2]}px ${px[3]}px rgba(0,0,0,${shadowKeyUmbraOpacity})`, `${px[4]}px ${px[5]}px ${px[6]}px ${px[7]}px rgba(0,0,0,${shadowKeyPenumbraOpacity})`, `${px[8]}px ${px[9]}px ${px[10]}px ${px[11]}px rgba(0,0,0,${shadowAmbientShadowOpacity})`].join(',');\n}\n\n// Values from https://github.com/material-components/material-components-web/blob/be8747f94574669cb5e7add1a7c54fa41a89cec7/packages/mdc-elevation/_variables.scss\nconst shadows = ['none', createShadow(0, 2, 1, -1, 0, 1, 1, 0, 0, 1, 3, 0), createShadow(0, 3, 1, -2, 0, 2, 2, 0, 0, 1, 5, 0), createShadow(0, 3, 3, -2, 0, 3, 4, 0, 0, 1, 8, 0), createShadow(0, 2, 4, -1, 0, 4, 5, 0, 0, 1, 10, 0), createShadow(0, 3, 5, -1, 0, 5, 8, 0, 0, 1, 14, 0), createShadow(0, 3, 5, -1, 0, 6, 10, 0, 0, 1, 18, 0), createShadow(0, 4, 5, -2, 0, 7, 10, 1, 0, 2, 16, 1), createShadow(0, 5, 5, -3, 0, 8, 10, 1, 0, 3, 14, 2), createShadow(0, 5, 6, -3, 0, 9, 12, 1, 0, 3, 16, 2), createShadow(0, 6, 6, -3, 0, 10, 14, 1, 0, 4, 18, 3), createShadow(0, 6, 7, -4, 0, 11, 15, 1, 0, 4, 20, 3), createShadow(0, 7, 8, -4, 0, 12, 17, 2, 0, 5, 22, 4), createShadow(0, 7, 8, -4, 0, 13, 19, 2, 0, 5, 24, 4), createShadow(0, 7, 9, -4, 0, 14, 21, 2, 0, 5, 26, 4), createShadow(0, 8, 9, -5, 0, 15, 22, 2, 0, 6, 28, 5), createShadow(0, 8, 10, -5, 0, 16, 24, 2, 0, 6, 30, 5), createShadow(0, 8, 11, -5, 0, 17, 26, 2, 0, 6, 32, 5), createShadow(0, 9, 11, -5, 0, 18, 28, 2, 0, 7, 34, 6), createShadow(0, 9, 12, -6, 0, 19, 29, 2, 0, 7, 36, 6), createShadow(0, 10, 13, -6, 0, 20, 31, 3, 0, 8, 38, 7), createShadow(0, 10, 13, -6, 0, 21, 33, 3, 0, 8, 40, 7), createShadow(0, 10, 14, -6, 0, 22, 35, 3, 0, 8, 42, 7), createShadow(0, 11, 14, -7, 0, 23, 36, 3, 0, 9, 44, 8), createShadow(0, 11, 15, -7, 0, 24, 38, 3, 0, 9, 46, 8)];\nexport default shadows;","// Follow https://material.google.com/motion/duration-easing.html#duration-easing-natural-easing-curves\n// to learn the context in which each easing should be used.\nexport const easing = {\n // This is the most common easing curve.\n easeInOut: 'cubic-bezier(0.4, 0, 0.2, 1)',\n // Objects enter the screen at full velocity from off-screen and\n // slowly decelerate to a resting point.\n easeOut: 'cubic-bezier(0.0, 0, 0.2, 1)',\n // Objects leave the screen at full velocity. They do not decelerate when off-screen.\n easeIn: 'cubic-bezier(0.4, 0, 1, 1)',\n // The sharp curve is used by objects that may return to the screen at any time.\n sharp: 'cubic-bezier(0.4, 0, 0.6, 1)'\n};\n\n// Follow https://m2.material.io/guidelines/motion/duration-easing.html#duration-easing-common-durations\n// to learn when use what timing\nexport const duration = {\n shortest: 150,\n shorter: 200,\n short: 250,\n // most basic recommended timing\n standard: 300,\n // this is to be used in complex animations\n complex: 375,\n // recommended when something is entering screen\n enteringScreen: 225,\n // recommended when something is leaving screen\n leavingScreen: 195\n};\nfunction formatMs(milliseconds) {\n return `${Math.round(milliseconds)}ms`;\n}\nfunction getAutoHeightDuration(height) {\n if (!height) {\n return 0;\n }\n const constant = height / 36;\n\n // https://www.desmos.com/calculator/vbrp3ggqet\n return Math.min(Math.round((4 + 15 * constant ** 0.25 + constant / 5) * 10), 3000);\n}\nexport default function createTransitions(inputTransitions) {\n const mergedEasing = {\n ...easing,\n ...inputTransitions.easing\n };\n const mergedDuration = {\n ...duration,\n ...inputTransitions.duration\n };\n const create = (props = ['all'], options = {}) => {\n const {\n duration: durationOption = mergedDuration.standard,\n easing: easingOption = mergedEasing.easeInOut,\n delay = 0,\n ...other\n } = options;\n if (process.env.NODE_ENV !== 'production') {\n const isString = value => typeof value === 'string';\n const isNumber = value => !Number.isNaN(parseFloat(value));\n if (!isString(props) && !Array.isArray(props)) {\n console.error('MUI: Argument \"props\" must be a string or Array.');\n }\n if (!isNumber(durationOption) && !isString(durationOption)) {\n console.error(`MUI: Argument \"duration\" must be a number or a string but found ${durationOption}.`);\n }\n if (!isString(easingOption)) {\n console.error('MUI: Argument \"easing\" must be a string.');\n }\n if (!isNumber(delay) && !isString(delay)) {\n console.error('MUI: Argument \"delay\" must be a number or a string.');\n }\n if (typeof options !== 'object') {\n console.error(['MUI: Secong argument of transition.create must be an object.', \"Arguments should be either `create('prop1', options)` or `create(['prop1', 'prop2'], options)`\"].join('\\n'));\n }\n if (Object.keys(other).length !== 0) {\n console.error(`MUI: Unrecognized argument(s) [${Object.keys(other).join(',')}].`);\n }\n }\n return (Array.isArray(props) ? props : [props]).map(animatedProp => `${animatedProp} ${typeof durationOption === 'string' ? durationOption : formatMs(durationOption)} ${easingOption} ${typeof delay === 'string' ? delay : formatMs(delay)}`).join(',');\n };\n return {\n getAutoHeightDuration,\n create,\n ...inputTransitions,\n easing: mergedEasing,\n duration: mergedDuration\n };\n}","// We need to centralize the zIndex definitions as they work\n// like global values in the browser.\nconst zIndex = {\n mobileStepper: 1000,\n fab: 1050,\n speedDial: 1050,\n appBar: 1100,\n drawer: 1200,\n modal: 1300,\n snackbar: 1400,\n tooltip: 1500\n};\nexport default zIndex;","/* eslint-disable import/prefer-default-export */\nimport { isPlainObject } from '@mui/utils/deepmerge';\nfunction isSerializable(val) {\n return isPlainObject(val) || typeof val === 'undefined' || typeof val === 'string' || typeof val === 'boolean' || typeof val === 'number' || Array.isArray(val);\n}\n\n/**\n * `baseTheme` usually comes from `createTheme()` or `extendTheme()`.\n *\n * This function is intended to be used with zero-runtime CSS-in-JS like Pigment CSS\n * For example, in a Next.js project:\n *\n * ```js\n * // next.config.js\n * const { extendTheme } = require('@mui/material/styles');\n *\n * const theme = extendTheme();\n * // `.toRuntimeSource` is Pigment CSS specific to create a theme that is available at runtime.\n * theme.toRuntimeSource = stringifyTheme;\n *\n * module.exports = withPigment({\n * theme,\n * });\n * ```\n */\nexport function stringifyTheme(baseTheme = {}) {\n const serializableTheme = {\n ...baseTheme\n };\n function serializeTheme(object) {\n const array = Object.entries(object);\n // eslint-disable-next-line no-plusplus\n for (let index = 0; index < array.length; index++) {\n const [key, value] = array[index];\n if (!isSerializable(value) || key.startsWith('unstable_')) {\n delete object[key];\n } else if (isPlainObject(value)) {\n object[key] = {\n ...value\n };\n serializeTheme(object[key]);\n }\n }\n }\n serializeTheme(serializableTheme);\n return `import { unstable_createBreakpoints as createBreakpoints, createTransitions } from '@mui/material/styles';\n\nconst theme = ${JSON.stringify(serializableTheme, null, 2)};\n\ntheme.breakpoints = createBreakpoints(theme.breakpoints || {});\ntheme.transitions = createTransitions(theme.transitions || {});\n\nexport default theme;`;\n}","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\nimport deepmerge from '@mui/utils/deepmerge';\nimport styleFunctionSx, { unstable_defaultSxConfig as defaultSxConfig } from '@mui/system/styleFunctionSx';\nimport systemCreateTheme from '@mui/system/createTheme';\nimport { alpha as systemAlpha, lighten as systemLighten, darken as systemDarken } from '@mui/system/colorManipulator';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nimport createMixins from \"./createMixins.js\";\nimport createPalette from \"./createPalette.js\";\nimport createTypography from \"./createTypography.js\";\nimport shadows from \"./shadows.js\";\nimport createTransitions from \"./createTransitions.js\";\nimport zIndex from \"./zIndex.js\";\nimport { stringifyTheme } from \"./stringifyTheme.js\";\nfunction coefficientToPercentage(coefficient) {\n if (typeof coefficient === 'number') {\n return `${(coefficient * 100).toFixed(0)}%`;\n }\n return `calc((${coefficient}) * 100%)`;\n}\n\n// This can be removed when moved to `color-mix()` entirely.\nconst parseAddition = str => {\n if (!Number.isNaN(+str)) {\n return +str;\n }\n const numbers = str.match(/\\d*\\.?\\d+/g);\n if (!numbers) {\n return 0;\n }\n let sum = 0;\n for (let i = 0; i < numbers.length; i += 1) {\n sum += +numbers[i];\n }\n return sum;\n};\nfunction attachColorManipulators(theme) {\n Object.assign(theme, {\n alpha(color, coefficient) {\n const obj = this || theme;\n if (obj.colorSpace) {\n return `oklch(from ${color} l c h / ${typeof coefficient === 'string' ? `calc(${coefficient})` : coefficient})`;\n }\n if (obj.vars) {\n // To preserve the behavior of the CSS theme variables\n // In the future, this could be replaced by `color-mix` (when https://caniuse.com/?search=color-mix reaches 95%).\n return `rgba(${color.replace(/var\\(--([^,\\s)]+)(?:,[^)]+)?\\)+/g, 'var(--$1Channel)')} / ${typeof coefficient === 'string' ? `calc(${coefficient})` : coefficient})`;\n }\n return systemAlpha(color, parseAddition(coefficient));\n },\n lighten(color, coefficient) {\n const obj = this || theme;\n if (obj.colorSpace) {\n return `color-mix(in ${obj.colorSpace}, ${color}, #fff ${coefficientToPercentage(coefficient)})`;\n }\n return systemLighten(color, coefficient);\n },\n darken(color, coefficient) {\n const obj = this || theme;\n if (obj.colorSpace) {\n return `color-mix(in ${obj.colorSpace}, ${color}, #000 ${coefficientToPercentage(coefficient)})`;\n }\n return systemDarken(color, coefficient);\n }\n });\n}\nfunction createThemeNoVars(options = {}, ...args) {\n const {\n breakpoints: breakpointsInput,\n mixins: mixinsInput = {},\n spacing: spacingInput,\n palette: paletteInput = {},\n transitions: transitionsInput = {},\n typography: typographyInput = {},\n shape: shapeInput,\n colorSpace,\n ...other\n } = options;\n if (options.vars &&\n // The error should throw only for the root theme creation because user is not allowed to use a custom node `vars`.\n // `generateThemeVars` is the closest identifier for checking that the `options` is a result of `createTheme` with CSS variables so that user can create new theme for nested ThemeProvider.\n options.generateThemeVars === undefined) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? 'MUI: `vars` is a private field used for CSS variables support.\\n' +\n // #host-reference\n 'Please use another name or follow the [docs](https://mui.com/material-ui/customization/css-theme-variables/usage/) to enable the feature.' : _formatErrorMessage(20));\n }\n const palette = createPalette({\n ...paletteInput,\n colorSpace\n });\n const systemTheme = systemCreateTheme(options);\n let muiTheme = deepmerge(systemTheme, {\n mixins: createMixins(systemTheme.breakpoints, mixinsInput),\n palette,\n // Don't use [...shadows] until you've verified its transpiled code is not invoking the iterator protocol.\n shadows: shadows.slice(),\n typography: createTypography(palette, typographyInput),\n transitions: createTransitions(transitionsInput),\n zIndex: {\n ...zIndex\n }\n });\n muiTheme = deepmerge(muiTheme, other);\n muiTheme = args.reduce((acc, argument) => deepmerge(acc, argument), muiTheme);\n if (process.env.NODE_ENV !== 'production') {\n // TODO v6: Refactor to use globalStateClassesMapping from @mui/utils once `readOnly` state class is used in Rating component.\n const stateClasses = ['active', 'checked', 'completed', 'disabled', 'error', 'expanded', 'focused', 'focusVisible', 'required', 'selected'];\n const traverse = (node, component) => {\n let key;\n\n // eslint-disable-next-line guard-for-in\n for (key in node) {\n const child = node[key];\n if (stateClasses.includes(key) && Object.keys(child).length > 0) {\n if (process.env.NODE_ENV !== 'production') {\n const stateClass = generateUtilityClass('', key);\n console.error([`MUI: The \\`${component}\\` component increases ` + `the CSS specificity of the \\`${key}\\` internal state.`, 'You can not override it like this: ', JSON.stringify(node, null, 2), '', `Instead, you need to use the '&.${stateClass}' syntax:`, JSON.stringify({\n root: {\n [`&.${stateClass}`]: child\n }\n }, null, 2), '', 'https://mui.com/r/state-classes-guide'].join('\\n'));\n }\n // Remove the style to prevent global conflicts.\n node[key] = {};\n }\n }\n };\n Object.keys(muiTheme.components).forEach(component => {\n const styleOverrides = muiTheme.components[component].styleOverrides;\n if (styleOverrides && component.startsWith('Mui')) {\n traverse(styleOverrides, component);\n }\n });\n }\n muiTheme.unstable_sxConfig = {\n ...defaultSxConfig,\n ...other?.unstable_sxConfig\n };\n muiTheme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n muiTheme.toRuntimeSource = stringifyTheme; // for Pigment CSS integration\n\n attachColorManipulators(muiTheme);\n return muiTheme;\n}\nexport default createThemeNoVars;","// Inspired by https://github.com/material-components/material-components-ios/blob/bca36107405594d5b7b16265a5b0ed698f85a5ee/components/Elevation/src/UIColor%2BMaterialElevation.m#L61\nexport default function getOverlayAlpha(elevation) {\n let alphaValue;\n if (elevation < 1) {\n alphaValue = 5.11916 * elevation ** 2;\n } else {\n alphaValue = 4.5 * Math.log(elevation + 1) + 2;\n }\n return Math.round(alphaValue * 10) / 1000;\n}","import createPalette from \"./createPalette.js\";\nimport getOverlayAlpha from \"./getOverlayAlpha.js\";\nconst defaultDarkOverlays = [...Array(25)].map((_, index) => {\n if (index === 0) {\n return 'none';\n }\n const overlay = getOverlayAlpha(index);\n return `linear-gradient(rgba(255 255 255 / ${overlay}), rgba(255 255 255 / ${overlay}))`;\n});\nexport function getOpacity(mode) {\n return {\n inputPlaceholder: mode === 'dark' ? 0.5 : 0.42,\n inputUnderline: mode === 'dark' ? 0.7 : 0.42,\n switchTrackDisabled: mode === 'dark' ? 0.2 : 0.12,\n switchTrack: mode === 'dark' ? 0.3 : 0.38\n };\n}\nexport function getOverlays(mode) {\n return mode === 'dark' ? defaultDarkOverlays : [];\n}\nexport default function createColorScheme(options) {\n const {\n palette: paletteInput = {\n mode: 'light'\n },\n // need to cast to avoid module augmentation test\n opacity,\n overlays,\n colorSpace,\n ...other\n } = options;\n // need to cast because `colorSpace` is considered internal at the moment.\n const palette = createPalette({\n ...paletteInput,\n colorSpace\n });\n return {\n palette,\n opacity: {\n ...getOpacity(palette.mode),\n ...opacity\n },\n overlays: overlays || getOverlays(palette.mode),\n ...other\n };\n}","export default function shouldSkipGeneratingVar(keys) {\n return !!keys[0].match(/(cssVarPrefix|colorSchemeSelector|modularCssLayers|rootSelector|typography|mixins|breakpoints|direction|transitions)/) || !!keys[0].match(/sxConfig$/) ||\n // ends with sxConfig\n keys[0] === 'palette' && !!keys[1]?.match(/(mode|contrastThreshold|tonalOffset)/);\n}","/**\n * @internal These variables should not appear in the :root stylesheet when the `defaultColorScheme=\"dark\"`\n */\nconst excludeVariablesFromRoot = cssVarPrefix => [...[...Array(25)].map((_, index) => `--${cssVarPrefix ? `${cssVarPrefix}-` : ''}overlays-${index}`), `--${cssVarPrefix ? `${cssVarPrefix}-` : ''}palette-AppBar-darkBg`, `--${cssVarPrefix ? `${cssVarPrefix}-` : ''}palette-AppBar-darkColor`];\nexport default excludeVariablesFromRoot;","import excludeVariablesFromRoot from \"./excludeVariablesFromRoot.js\";\nexport default theme => (colorScheme, css) => {\n const root = theme.rootSelector || ':root';\n const selector = theme.colorSchemeSelector;\n let rule = selector;\n if (selector === 'class') {\n rule = '.%s';\n }\n if (selector === 'data') {\n rule = '[data-%s]';\n }\n if (selector?.startsWith('data-') && !selector.includes('%s')) {\n // 'data-mui-color-scheme' -> '[data-mui-color-scheme=\"%s\"]'\n rule = `[${selector}=\"%s\"]`;\n }\n if (theme.defaultColorScheme === colorScheme) {\n if (colorScheme === 'dark') {\n const excludedVariables = {};\n excludeVariablesFromRoot(theme.cssVarPrefix).forEach(cssVar => {\n excludedVariables[cssVar] = css[cssVar];\n delete css[cssVar];\n });\n if (rule === 'media') {\n return {\n [root]: css,\n [`@media (prefers-color-scheme: dark)`]: {\n [root]: excludedVariables\n }\n };\n }\n if (rule) {\n return {\n [rule.replace('%s', colorScheme)]: excludedVariables,\n [`${root}, ${rule.replace('%s', colorScheme)}`]: css\n };\n }\n return {\n [root]: {\n ...css,\n ...excludedVariables\n }\n };\n }\n if (rule && rule !== 'media') {\n return `${root}, ${rule.replace('%s', String(colorScheme))}`;\n }\n } else if (colorScheme) {\n if (rule === 'media') {\n return {\n [`@media (prefers-color-scheme: ${String(colorScheme)})`]: {\n [root]: css\n }\n };\n }\n if (rule) {\n return rule.replace('%s', String(colorScheme));\n }\n }\n return root;\n};","import _formatErrorMessage from \"@mui/utils/formatMuiErrorMessage\";\nimport deepmerge from '@mui/utils/deepmerge';\nimport { unstable_createGetCssVar as systemCreateGetCssVar, createSpacing } from '@mui/system';\nimport { createUnarySpacing } from '@mui/system/spacing';\nimport { prepareCssVars, prepareTypographyVars, createGetColorSchemeSelector } from '@mui/system/cssVars';\nimport styleFunctionSx, { unstable_defaultSxConfig as defaultSxConfig } from '@mui/system/styleFunctionSx';\nimport { private_safeColorChannel as safeColorChannel, private_safeAlpha as safeAlpha, private_safeDarken as safeDarken, private_safeLighten as safeLighten, private_safeEmphasize as safeEmphasize, hslToRgb } from '@mui/system/colorManipulator';\nimport createThemeNoVars from \"./createThemeNoVars.js\";\nimport createColorScheme, { getOpacity, getOverlays } from \"./createColorScheme.js\";\nimport defaultShouldSkipGeneratingVar from \"./shouldSkipGeneratingVar.js\";\nimport defaultGetSelector from \"./createGetSelector.js\";\nimport { stringifyTheme } from \"./stringifyTheme.js\";\nimport { light, dark } from \"./createPalette.js\";\nfunction assignNode(obj, keys) {\n keys.forEach(k => {\n if (!obj[k]) {\n obj[k] = {};\n }\n });\n}\nfunction setColor(obj, key, defaultValue) {\n if (!obj[key] && defaultValue) {\n obj[key] = defaultValue;\n }\n}\nfunction toRgb(color) {\n if (typeof color !== 'string' || !color.startsWith('hsl')) {\n return color;\n }\n return hslToRgb(color);\n}\nfunction setColorChannel(obj, key) {\n if (!(`${key}Channel` in obj)) {\n // custom channel token is not provided, generate one.\n // if channel token can't be generated, show a warning.\n obj[`${key}Channel`] = safeColorChannel(toRgb(obj[key]), `MUI: Can't create \\`palette.${key}Channel\\` because \\`palette.${key}\\` is not one of these formats: #nnn, #nnnnnn, rgb(), rgba(), hsl(), hsla(), color().` + '\\n' + `To suppress this warning, you need to explicitly provide the \\`palette.${key}Channel\\` as a string (in rgb format, for example \"12 12 12\") or undefined if you want to remove the channel token.`);\n }\n}\nfunction getSpacingVal(spacingInput) {\n if (typeof spacingInput === 'number') {\n return `${spacingInput}px`;\n }\n if (typeof spacingInput === 'string' || typeof spacingInput === 'function' || Array.isArray(spacingInput)) {\n return spacingInput;\n }\n return '8px';\n}\nconst silent = fn => {\n try {\n return fn();\n } catch (error) {\n // ignore error\n }\n return undefined;\n};\nexport const createGetCssVar = (cssVarPrefix = 'mui') => systemCreateGetCssVar(cssVarPrefix);\nfunction attachColorScheme(colorSpace, colorSchemes, scheme, restTheme, colorScheme) {\n if (!scheme) {\n return undefined;\n }\n scheme = scheme === true ? {} : scheme;\n const mode = colorScheme === 'dark' ? 'dark' : 'light';\n if (!restTheme) {\n colorSchemes[colorScheme] = createColorScheme({\n ...scheme,\n palette: {\n mode,\n ...scheme?.palette\n },\n colorSpace\n });\n return undefined;\n }\n const {\n palette,\n ...muiTheme\n } = createThemeNoVars({\n ...restTheme,\n palette: {\n mode,\n ...scheme?.palette\n },\n colorSpace\n });\n colorSchemes[colorScheme] = {\n ...scheme,\n palette,\n opacity: {\n ...getOpacity(mode),\n ...scheme?.opacity\n },\n overlays: scheme?.overlays || getOverlays(mode)\n };\n return muiTheme;\n}\n\n/**\n * A default `createThemeWithVars` comes with a single color scheme, either `light` or `dark` based on the `defaultColorScheme`.\n * This is better suited for apps that only need a single color scheme.\n *\n * To enable built-in `light` and `dark` color schemes, either:\n * 1. provide a `colorSchemeSelector` to define how the color schemes will change.\n * 2. provide `colorSchemes.dark` will set `colorSchemeSelector: 'media'` by default.\n */\nexport default function createThemeWithVars(options = {}, ...args) {\n const {\n colorSchemes: colorSchemesInput = {\n light: true\n },\n defaultColorScheme: defaultColorSchemeInput,\n disableCssColorScheme = false,\n cssVarPrefix = 'mui',\n nativeColor = false,\n shouldSkipGeneratingVar = defaultShouldSkipGeneratingVar,\n colorSchemeSelector: selector = colorSchemesInput.light && colorSchemesInput.dark ? 'media' : undefined,\n rootSelector = ':root',\n ...input\n } = options;\n const firstColorScheme = Object.keys(colorSchemesInput)[0];\n const defaultColorScheme = defaultColorSchemeInput || (colorSchemesInput.light && firstColorScheme !== 'light' ? 'light' : firstColorScheme);\n const getCssVar = createGetCssVar(cssVarPrefix);\n const {\n [defaultColorScheme]: defaultSchemeInput,\n light: builtInLight,\n dark: builtInDark,\n ...customColorSchemes\n } = colorSchemesInput;\n const colorSchemes = {\n ...customColorSchemes\n };\n let defaultScheme = defaultSchemeInput;\n\n // For built-in light and dark color schemes, ensure that the value is valid if they are the default color scheme.\n if (defaultColorScheme === 'dark' && !('dark' in colorSchemesInput) || defaultColorScheme === 'light' && !('light' in colorSchemesInput)) {\n defaultScheme = true;\n }\n if (!defaultScheme) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: The \\`colorSchemes.${defaultColorScheme}\\` option is either missing or invalid.` : _formatErrorMessage(21, defaultColorScheme));\n }\n\n // The reason to use `oklch` is that it is the most perceptually uniform color space and widely supported.\n let colorSpace;\n if (nativeColor) {\n colorSpace = 'oklch';\n }\n\n // Create the palette for the default color scheme, either `light`, `dark`, or custom color scheme.\n const muiTheme = attachColorScheme(colorSpace, colorSchemes, defaultScheme, input, defaultColorScheme);\n if (builtInLight && !colorSchemes.light) {\n attachColorScheme(colorSpace, colorSchemes, builtInLight, undefined, 'light');\n }\n if (builtInDark && !colorSchemes.dark) {\n attachColorScheme(colorSpace, colorSchemes, builtInDark, undefined, 'dark');\n }\n let theme = {\n defaultColorScheme,\n ...muiTheme,\n cssVarPrefix,\n colorSchemeSelector: selector,\n rootSelector,\n getCssVar,\n colorSchemes,\n font: {\n ...prepareTypographyVars(muiTheme.typography),\n ...muiTheme.font\n },\n spacing: getSpacingVal(input.spacing)\n };\n Object.keys(theme.colorSchemes).forEach(key => {\n const palette = theme.colorSchemes[key].palette;\n const setCssVarColor = cssVar => {\n const tokens = cssVar.split('-');\n const color = tokens[1];\n const colorToken = tokens[2];\n return getCssVar(cssVar, palette[color][colorToken]);\n };\n\n // attach black & white channels to common node\n if (palette.mode === 'light') {\n setColor(palette.common, 'background', '#fff');\n setColor(palette.common, 'onBackground', '#000');\n }\n if (palette.mode === 'dark') {\n setColor(palette.common, 'background', '#000');\n setColor(palette.common, 'onBackground', '#fff');\n }\n function colorMix(method, color, coefficient) {\n if (colorSpace) {\n let mixer;\n if (method === safeAlpha) {\n mixer = `transparent ${((1 - coefficient) * 100).toFixed(0)}%`;\n }\n if (method === safeDarken) {\n mixer = `#000 ${(coefficient * 100).toFixed(0)}%`;\n }\n if (method === safeLighten) {\n mixer = `#fff ${(coefficient * 100).toFixed(0)}%`;\n }\n return `color-mix(in ${colorSpace}, ${color}, ${mixer})`;\n }\n return method(color, coefficient);\n }\n\n // assign component variables\n assignNode(palette, ['Alert', 'AppBar', 'Avatar', 'Button', 'Chip', 'FilledInput', 'LinearProgress', 'Skeleton', 'Slider', 'SnackbarContent', 'SpeedDialAction', 'StepConnector', 'StepContent', 'Switch', 'TableCell', 'Tooltip']);\n if (palette.mode === 'light') {\n setColor(palette.Alert, 'errorColor', colorMix(safeDarken, palette.error.light, 0.6));\n setColor(palette.Alert, 'infoColor', colorMix(safeDarken, palette.info.light, 0.6));\n setColor(palette.Alert, 'successColor', colorMix(safeDarken, palette.success.light, 0.6));\n setColor(palette.Alert, 'warningColor', colorMix(safeDarken, palette.warning.light, 0.6));\n setColor(palette.Alert, 'errorFilledBg', setCssVarColor('palette-error-main'));\n setColor(palette.Alert, 'infoFilledBg', setCssVarColor('palette-info-main'));\n setColor(palette.Alert, 'successFilledBg', setCssVarColor('palette-success-main'));\n setColor(palette.Alert, 'warningFilledBg', setCssVarColor('palette-warning-main'));\n setColor(palette.Alert, 'errorFilledColor', silent(() => palette.getContrastText(palette.error.main)));\n setColor(palette.Alert, 'infoFilledColor', silent(() => palette.getContrastText(palette.info.main)));\n setColor(palette.Alert, 'successFilledColor', silent(() => palette.getContrastText(palette.success.main)));\n setColor(palette.Alert, 'warningFilledColor', silent(() => palette.getContrastText(palette.warning.main)));\n setColor(palette.Alert, 'errorStandardBg', colorMix(safeLighten, palette.error.light, 0.9));\n setColor(palette.Alert, 'infoStandardBg', colorMix(safeLighten, palette.info.light, 0.9));\n setColor(palette.Alert, 'successStandardBg', colorMix(safeLighten, palette.success.light, 0.9));\n setColor(palette.Alert, 'warningStandardBg', colorMix(safeLighten, palette.warning.light, 0.9));\n setColor(palette.Alert, 'errorIconColor', setCssVarColor('palette-error-main'));\n setColor(palette.Alert, 'infoIconColor', setCssVarColor('palette-info-main'));\n setColor(palette.Alert, 'successIconColor', setCssVarColor('palette-success-main'));\n setColor(palette.Alert, 'warningIconColor', setCssVarColor('palette-warning-main'));\n setColor(palette.AppBar, 'defaultBg', setCssVarColor('palette-grey-100'));\n setColor(palette.Avatar, 'defaultBg', setCssVarColor('palette-grey-400'));\n setColor(palette.Button, 'inheritContainedBg', setCssVarColor('palette-grey-300'));\n setColor(palette.Button, 'inheritContainedHoverBg', setCssVarColor('palette-grey-A100'));\n setColor(palette.Chip, 'defaultBorder', setCssVarColor('palette-grey-400'));\n setColor(palette.Chip, 'defaultAvatarColor', setCssVarColor('palette-grey-700'));\n setColor(palette.Chip, 'defaultIconColor', setCssVarColor('palette-grey-700'));\n setColor(palette.FilledInput, 'bg', 'rgba(0, 0, 0, 0.06)');\n setColor(palette.FilledInput, 'hoverBg', 'rgba(0, 0, 0, 0.09)');\n setColor(palette.FilledInput, 'disabledBg', 'rgba(0, 0, 0, 0.12)');\n setColor(palette.LinearProgress, 'primaryBg', colorMix(safeLighten, palette.primary.main, 0.62));\n setColor(palette.LinearProgress, 'secondaryBg', colorMix(safeLighten, palette.secondary.main, 0.62));\n setColor(palette.LinearProgress, 'errorBg', colorMix(safeLighten, palette.error.main, 0.62));\n setColor(palette.LinearProgress, 'infoBg', colorMix(safeLighten, palette.info.main, 0.62));\n setColor(palette.LinearProgress, 'successBg', colorMix(safeLighten, palette.success.main, 0.62));\n setColor(palette.LinearProgress, 'warningBg', colorMix(safeLighten, palette.warning.main, 0.62));\n setColor(palette.Skeleton, 'bg', colorSpace ? colorMix(safeAlpha, palette.text.primary, 0.11) : `rgba(${setCssVarColor('palette-text-primaryChannel')} / 0.11)`);\n setColor(palette.Slider, 'primaryTrack', colorMix(safeLighten, palette.primary.main, 0.62));\n setColor(palette.Slider, 'secondaryTrack', colorMix(safeLighten, palette.secondary.main, 0.62));\n setColor(palette.Slider, 'errorTrack', colorMix(safeLighten, palette.error.main, 0.62));\n setColor(palette.Slider, 'infoTrack', colorMix(safeLighten, palette.info.main, 0.62));\n setColor(palette.Slider, 'successTrack', colorMix(safeLighten, palette.success.main, 0.62));\n setColor(palette.Slider, 'warningTrack', colorMix(safeLighten, palette.warning.main, 0.62));\n const snackbarContentBackground = colorSpace ? colorMix(safeDarken, palette.background.default, 0.6825) // use `0.6825` instead of `0.8` to match the contrast ratio of JS implementation\n : safeEmphasize(palette.background.default, 0.8);\n setColor(palette.SnackbarContent, 'bg', snackbarContentBackground);\n setColor(palette.SnackbarContent, 'color', silent(() => colorSpace ? dark.text.primary : palette.getContrastText(snackbarContentBackground)));\n setColor(palette.SpeedDialAction, 'fabHoverBg', safeEmphasize(palette.background.paper, 0.15));\n setColor(palette.StepConnector, 'border', setCssVarColor('palette-grey-400'));\n setColor(palette.StepContent, 'border', setCssVarColor('palette-grey-400'));\n setColor(palette.Switch, 'defaultColor', setCssVarColor('palette-common-white'));\n setColor(palette.Switch, 'defaultDisabledColor', setCssVarColor('palette-grey-100'));\n setColor(palette.Switch, 'primaryDisabledColor', colorMix(safeLighten, palette.primary.main, 0.62));\n setColor(palette.Switch, 'secondaryDisabledColor', colorMix(safeLighten, palette.secondary.main, 0.62));\n setColor(palette.Switch, 'errorDisabledColor', colorMix(safeLighten, palette.error.main, 0.62));\n setColor(palette.Switch, 'infoDisabledColor', colorMix(safeLighten, palette.info.main, 0.62));\n setColor(palette.Switch, 'successDisabledColor', colorMix(safeLighten, palette.success.main, 0.62));\n setColor(palette.Switch, 'warningDisabledColor', colorMix(safeLighten, palette.warning.main, 0.62));\n setColor(palette.TableCell, 'border', colorMix(safeLighten, colorMix(safeAlpha, palette.divider, 1), 0.88));\n setColor(palette.Tooltip, 'bg', colorMix(safeAlpha, palette.grey[700], 0.92));\n }\n if (palette.mode === 'dark') {\n setColor(palette.Alert, 'errorColor', colorMix(safeLighten, palette.error.light, 0.6));\n setColor(palette.Alert, 'infoColor', colorMix(safeLighten, palette.info.light, 0.6));\n setColor(palette.Alert, 'successColor', colorMix(safeLighten, palette.success.light, 0.6));\n setColor(palette.Alert, 'warningColor', colorMix(safeLighten, palette.warning.light, 0.6));\n setColor(palette.Alert, 'errorFilledBg', setCssVarColor('palette-error-dark'));\n setColor(palette.Alert, 'infoFilledBg', setCssVarColor('palette-info-dark'));\n setColor(palette.Alert, 'successFilledBg', setCssVarColor('palette-success-dark'));\n setColor(palette.Alert, 'warningFilledBg', setCssVarColor('palette-warning-dark'));\n setColor(palette.Alert, 'errorFilledColor', silent(() => palette.getContrastText(palette.error.dark)));\n setColor(palette.Alert, 'infoFilledColor', silent(() => palette.getContrastText(palette.info.dark)));\n setColor(palette.Alert, 'successFilledColor', silent(() => palette.getContrastText(palette.success.dark)));\n setColor(palette.Alert, 'warningFilledColor', silent(() => palette.getContrastText(palette.warning.dark)));\n setColor(palette.Alert, 'errorStandardBg', colorMix(safeDarken, palette.error.light, 0.9));\n setColor(palette.Alert, 'infoStandardBg', colorMix(safeDarken, palette.info.light, 0.9));\n setColor(palette.Alert, 'successStandardBg', colorMix(safeDarken, palette.success.light, 0.9));\n setColor(palette.Alert, 'warningStandardBg', colorMix(safeDarken, palette.warning.light, 0.9));\n setColor(palette.Alert, 'errorIconColor', setCssVarColor('palette-error-main'));\n setColor(palette.Alert, 'infoIconColor', setCssVarColor('palette-info-main'));\n setColor(palette.Alert, 'successIconColor', setCssVarColor('palette-success-main'));\n setColor(palette.Alert, 'warningIconColor', setCssVarColor('palette-warning-main'));\n setColor(palette.AppBar, 'defaultBg', setCssVarColor('palette-grey-900'));\n setColor(palette.AppBar, 'darkBg', setCssVarColor('palette-background-paper')); // specific for dark mode\n setColor(palette.AppBar, 'darkColor', setCssVarColor('palette-text-primary')); // specific for dark mode\n setColor(palette.Avatar, 'defaultBg', setCssVarColor('palette-grey-600'));\n setColor(palette.Button, 'inheritContainedBg', setCssVarColor('palette-grey-800'));\n setColor(palette.Button, 'inheritContainedHoverBg', setCssVarColor('palette-grey-700'));\n setColor(palette.Chip, 'defaultBorder', setCssVarColor('palette-grey-700'));\n setColor(palette.Chip, 'defaultAvatarColor', setCssVarColor('palette-grey-300'));\n setColor(palette.Chip, 'defaultIconColor', setCssVarColor('palette-grey-300'));\n setColor(palette.FilledInput, 'bg', 'rgba(255, 255, 255, 0.09)');\n setColor(palette.FilledInput, 'hoverBg', 'rgba(255, 255, 255, 0.13)');\n setColor(palette.FilledInput, 'disabledBg', 'rgba(255, 255, 255, 0.12)');\n setColor(palette.LinearProgress, 'primaryBg', colorMix(safeDarken, palette.primary.main, 0.5));\n setColor(palette.LinearProgress, 'secondaryBg', colorMix(safeDarken, palette.secondary.main, 0.5));\n setColor(palette.LinearProgress, 'errorBg', colorMix(safeDarken, palette.error.main, 0.5));\n setColor(palette.LinearProgress, 'infoBg', colorMix(safeDarken, palette.info.main, 0.5));\n setColor(palette.LinearProgress, 'successBg', colorMix(safeDarken, palette.success.main, 0.5));\n setColor(palette.LinearProgress, 'warningBg', colorMix(safeDarken, palette.warning.main, 0.5));\n setColor(palette.Skeleton, 'bg', colorSpace ? colorMix(safeAlpha, palette.text.primary, 0.13) : `rgba(${setCssVarColor('palette-text-primaryChannel')} / 0.13)`);\n setColor(palette.Slider, 'primaryTrack', colorMix(safeDarken, palette.primary.main, 0.5));\n setColor(palette.Slider, 'secondaryTrack', colorMix(safeDarken, palette.secondary.main, 0.5));\n setColor(palette.Slider, 'errorTrack', colorMix(safeDarken, palette.error.main, 0.5));\n setColor(palette.Slider, 'infoTrack', colorMix(safeDarken, palette.info.main, 0.5));\n setColor(palette.Slider, 'successTrack', colorMix(safeDarken, palette.success.main, 0.5));\n setColor(palette.Slider, 'warningTrack', colorMix(safeDarken, palette.warning.main, 0.5));\n const snackbarContentBackground = colorSpace ? colorMix(safeLighten, palette.background.default, 0.985) // use `0.985` instead of `0.98` to match the contrast ratio of JS implementation\n : safeEmphasize(palette.background.default, 0.98);\n setColor(palette.SnackbarContent, 'bg', snackbarContentBackground);\n setColor(palette.SnackbarContent, 'color', silent(() => colorSpace ? light.text.primary : palette.getContrastText(snackbarContentBackground)));\n setColor(palette.SpeedDialAction, 'fabHoverBg', safeEmphasize(palette.background.paper, 0.15));\n setColor(palette.StepConnector, 'border', setCssVarColor('palette-grey-600'));\n setColor(palette.StepContent, 'border', setCssVarColor('palette-grey-600'));\n setColor(palette.Switch, 'defaultColor', setCssVarColor('palette-grey-300'));\n setColor(palette.Switch, 'defaultDisabledColor', setCssVarColor('palette-grey-600'));\n setColor(palette.Switch, 'primaryDisabledColor', colorMix(safeDarken, palette.primary.main, 0.55));\n setColor(palette.Switch, 'secondaryDisabledColor', colorMix(safeDarken, palette.secondary.main, 0.55));\n setColor(palette.Switch, 'errorDisabledColor', colorMix(safeDarken, palette.error.main, 0.55));\n setColor(palette.Switch, 'infoDisabledColor', colorMix(safeDarken, palette.info.main, 0.55));\n setColor(palette.Switch, 'successDisabledColor', colorMix(safeDarken, palette.success.main, 0.55));\n setColor(palette.Switch, 'warningDisabledColor', colorMix(safeDarken, palette.warning.main, 0.55));\n setColor(palette.TableCell, 'border', colorMix(safeDarken, colorMix(safeAlpha, palette.divider, 1), 0.68));\n setColor(palette.Tooltip, 'bg', colorMix(safeAlpha, palette.grey[700], 0.92));\n }\n\n // MUI X - DataGrid needs this token.\n setColorChannel(palette.background, 'default');\n\n // added for consistency with the `background.default` token\n setColorChannel(palette.background, 'paper');\n setColorChannel(palette.common, 'background');\n setColorChannel(palette.common, 'onBackground');\n setColorChannel(palette, 'divider');\n Object.keys(palette).forEach(color => {\n const colors = palette[color];\n\n // The default palettes (primary, secondary, error, info, success, and warning) errors are handled by the above `createTheme(...)`.\n\n if (color !== 'tonalOffset' && colors && typeof colors === 'object') {\n // Silent the error for custom palettes.\n if (colors.main) {\n setColor(palette[color], 'mainChannel', safeColorChannel(toRgb(colors.main)));\n }\n if (colors.light) {\n setColor(palette[color], 'lightChannel', safeColorChannel(toRgb(colors.light)));\n }\n if (colors.dark) {\n setColor(palette[color], 'darkChannel', safeColorChannel(toRgb(colors.dark)));\n }\n if (colors.contrastText) {\n setColor(palette[color], 'contrastTextChannel', safeColorChannel(toRgb(colors.contrastText)));\n }\n if (color === 'text') {\n // Text colors: text.primary, text.secondary\n setColorChannel(palette[color], 'primary');\n setColorChannel(palette[color], 'secondary');\n }\n if (color === 'action') {\n // Action colors: action.active, action.selected\n if (colors.active) {\n setColorChannel(palette[color], 'active');\n }\n if (colors.selected) {\n setColorChannel(palette[color], 'selected');\n }\n }\n }\n });\n });\n theme = args.reduce((acc, argument) => deepmerge(acc, argument), theme);\n const parserConfig = {\n prefix: cssVarPrefix,\n disableCssColorScheme,\n shouldSkipGeneratingVar,\n getSelector: defaultGetSelector(theme),\n enableContrastVars: nativeColor\n };\n const {\n vars,\n generateThemeVars,\n generateStyleSheets\n } = prepareCssVars(theme, parserConfig);\n theme.vars = vars;\n Object.entries(theme.colorSchemes[theme.defaultColorScheme]).forEach(([key, value]) => {\n theme[key] = value;\n });\n theme.generateThemeVars = generateThemeVars;\n theme.generateStyleSheets = generateStyleSheets;\n theme.generateSpacing = function generateSpacing() {\n return createSpacing(input.spacing, createUnarySpacing(this));\n };\n theme.getColorSchemeSelector = createGetColorSchemeSelector(selector);\n theme.spacing = theme.generateSpacing();\n theme.shouldSkipGeneratingVar = shouldSkipGeneratingVar;\n theme.unstable_sxConfig = {\n ...defaultSxConfig,\n ...input?.unstable_sxConfig\n };\n theme.unstable_sx = function sx(props) {\n return styleFunctionSx({\n sx: props,\n theme: this\n });\n };\n theme.toRuntimeSource = stringifyTheme; // for Pigment CSS integration\n\n return theme;\n}","import createPalette from \"./createPalette.js\";\nimport createThemeWithVars from \"./createThemeWithVars.js\";\nimport createThemeNoVars from \"./createThemeNoVars.js\";\n// eslint-disable-next-line consistent-return\nfunction attachColorScheme(theme, scheme, colorScheme) {\n if (!theme.colorSchemes) {\n return undefined;\n }\n if (colorScheme) {\n theme.colorSchemes[scheme] = {\n ...(colorScheme !== true && colorScheme),\n palette: createPalette({\n ...(colorScheme === true ? {} : colorScheme.palette),\n mode: scheme\n }) // cast type to skip module augmentation test\n };\n }\n}\n\n/**\n * Generate a theme base on the options received.\n * @param options Takes an incomplete theme object and adds the missing parts.\n * @param args Deep merge the arguments with the about to be returned theme.\n * @returns A complete, ready-to-use theme object.\n */\nexport default function createTheme(options = {},\n// cast type to skip module augmentation test\n...args) {\n const {\n palette,\n cssVariables = false,\n colorSchemes: initialColorSchemes = !palette ? {\n light: true\n } : undefined,\n defaultColorScheme: initialDefaultColorScheme = palette?.mode,\n ...other\n } = options;\n const defaultColorSchemeInput = initialDefaultColorScheme || 'light';\n const defaultScheme = initialColorSchemes?.[defaultColorSchemeInput];\n const colorSchemesInput = {\n ...initialColorSchemes,\n ...(palette ? {\n [defaultColorSchemeInput]: {\n ...(typeof defaultScheme !== 'boolean' && defaultScheme),\n palette\n }\n } : undefined)\n };\n if (cssVariables === false) {\n if (!('colorSchemes' in options)) {\n // Behaves exactly as v5\n return createThemeNoVars(options, ...args);\n }\n let paletteOptions = palette;\n if (!('palette' in options)) {\n if (colorSchemesInput[defaultColorSchemeInput]) {\n if (colorSchemesInput[defaultColorSchemeInput] !== true) {\n paletteOptions = colorSchemesInput[defaultColorSchemeInput].palette;\n } else if (defaultColorSchemeInput === 'dark') {\n // @ts-ignore to prevent the module augmentation test from failing\n paletteOptions = {\n mode: 'dark'\n };\n }\n }\n }\n const theme = createThemeNoVars({\n ...options,\n palette: paletteOptions\n }, ...args);\n theme.defaultColorScheme = defaultColorSchemeInput;\n theme.colorSchemes = colorSchemesInput;\n if (theme.palette.mode === 'light') {\n theme.colorSchemes.light = {\n ...(colorSchemesInput.light !== true && colorSchemesInput.light),\n palette: theme.palette\n };\n attachColorScheme(theme, 'dark', colorSchemesInput.dark);\n }\n if (theme.palette.mode === 'dark') {\n theme.colorSchemes.dark = {\n ...(colorSchemesInput.dark !== true && colorSchemesInput.dark),\n palette: theme.palette\n };\n attachColorScheme(theme, 'light', colorSchemesInput.light);\n }\n return theme;\n }\n if (!palette && !('light' in colorSchemesInput) && defaultColorSchemeInput === 'light') {\n colorSchemesInput.light = true;\n }\n return createThemeWithVars({\n ...other,\n colorSchemes: colorSchemesInput,\n defaultColorScheme: defaultColorSchemeInput,\n ...(typeof cssVariables !== 'boolean' && cssVariables)\n }, ...args);\n}","'use client';\n\nimport createTheme from \"./createTheme.js\";\nconst defaultTheme = createTheme();\nexport default defaultTheme;","'use client';\n\nimport * as React from 'react';\nimport { useTheme as useThemeSystem } from '@mui/system';\nimport defaultTheme from \"./defaultTheme.js\";\nimport THEME_ID from \"./identifier.js\";\nexport default function useTheme() {\n const theme = useThemeSystem(defaultTheme);\n if (process.env.NODE_ENV !== 'production') {\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler\n // eslint-disable-next-line react-hooks/rules-of-hooks\n React.useDebugValue(theme);\n }\n return theme[THEME_ID] || theme;\n}","// copied from @mui/system/createStyled\nfunction slotShouldForwardProp(prop) {\n return prop !== 'ownerState' && prop !== 'theme' && prop !== 'sx' && prop !== 'as';\n}\nexport default slotShouldForwardProp;","import slotShouldForwardProp from \"./slotShouldForwardProp.js\";\nconst rootShouldForwardProp = prop => slotShouldForwardProp(prop) && prop !== 'classes';\nexport default rootShouldForwardProp;","'use client';\n\nimport createStyled from '@mui/system/createStyled';\nimport defaultTheme from \"./defaultTheme.js\";\nimport THEME_ID from \"./identifier.js\";\nimport rootShouldForwardProp from \"./rootShouldForwardProp.js\";\nexport { default as slotShouldForwardProp } from \"./slotShouldForwardProp.js\";\nexport { default as rootShouldForwardProp } from \"./rootShouldForwardProp.js\";\nconst styled = createStyled({\n themeId: THEME_ID,\n defaultTheme,\n rootShouldForwardProp\n});\nexport default styled;","import { extendSxProp } from '@mui/system/styleFunctionSx';\nimport useTheme from \"../styles/useTheme.js\";\nimport GlobalStyles from \"../GlobalStyles/index.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport { css, keyframes } from '@mui/system';\nexport { default as styled } from \"../styles/styled.js\";\nexport function globalCss(styles) {\n return function GlobalStylesWrapper(props) {\n return (\n /*#__PURE__*/\n // Pigment CSS `globalCss` support callback with theme inside an object but `GlobalStyles` support theme as a callback value.\n _jsx(GlobalStyles, {\n styles: typeof styles === 'function' ? theme => styles({\n theme,\n ...props\n }) : styles\n })\n );\n };\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function internal_createExtendSxProp() {\n return extendSxProp;\n}\nexport { useTheme };","import { unstable_memoTheme } from '@mui/system';\nconst memoTheme = unstable_memoTheme;\nexport default memoTheme;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport SystemDefaultPropsProvider, { useDefaultProps as useSystemDefaultProps } from '@mui/system/DefaultPropsProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction DefaultPropsProvider(props) {\n return /*#__PURE__*/_jsx(SystemDefaultPropsProvider, {\n ...props\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? DefaultPropsProvider.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the TypeScript types and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * @ignore\n */\n value: PropTypes.object.isRequired\n} : void 0;\nexport default DefaultPropsProvider;\nexport function useDefaultProps(params) {\n return useSystemDefaultProps(params);\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getSvgIconUtilityClass(slot) {\n return generateUtilityClass('MuiSvgIcon', slot);\n}\nconst svgIconClasses = generateUtilityClasses('MuiSvgIcon', ['root', 'colorPrimary', 'colorSecondary', 'colorAction', 'colorError', 'colorDisabled', 'fontSizeInherit', 'fontSizeSmall', 'fontSizeMedium', 'fontSizeLarge']);\nexport default svgIconClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport composeClasses from '@mui/utils/composeClasses';\nimport capitalize from \"../utils/capitalize.js\";\nimport { styled } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport { getSvgIconUtilityClass } from \"./svgIconClasses.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n color,\n fontSize,\n classes\n } = ownerState;\n const slots = {\n root: ['root', color !== 'inherit' && `color${capitalize(color)}`, `fontSize${capitalize(fontSize)}`]\n };\n return composeClasses(slots, getSvgIconUtilityClass, classes);\n};\nconst SvgIconRoot = styled('svg', {\n name: 'MuiSvgIcon',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, ownerState.color !== 'inherit' && styles[`color${capitalize(ownerState.color)}`], styles[`fontSize${capitalize(ownerState.fontSize)}`]];\n }\n})(memoTheme(({\n theme\n}) => ({\n userSelect: 'none',\n width: '1em',\n height: '1em',\n display: 'inline-block',\n flexShrink: 0,\n transition: theme.transitions?.create?.('fill', {\n duration: (theme.vars ?? theme).transitions?.duration?.shorter\n }),\n variants: [{\n props: props => !props.hasSvgAsChild,\n style: {\n // the <svg> will define the property that has `currentColor`\n // for example heroicons uses fill=\"none\" and stroke=\"currentColor\"\n fill: 'currentColor'\n }\n }, {\n props: {\n fontSize: 'inherit'\n },\n style: {\n fontSize: 'inherit'\n }\n }, {\n props: {\n fontSize: 'small'\n },\n style: {\n fontSize: theme.typography?.pxToRem?.(20) || '1.25rem'\n }\n }, {\n props: {\n fontSize: 'medium'\n },\n style: {\n fontSize: theme.typography?.pxToRem?.(24) || '1.5rem'\n }\n }, {\n props: {\n fontSize: 'large'\n },\n style: {\n fontSize: theme.typography?.pxToRem?.(35) || '2.1875rem'\n }\n },\n // TODO v5 deprecate color prop, v6 remove for sx\n ...Object.entries((theme.vars ?? theme).palette).filter(([, value]) => value && value.main).map(([color]) => ({\n props: {\n color\n },\n style: {\n color: (theme.vars ?? theme).palette?.[color]?.main\n }\n })), {\n props: {\n color: 'action'\n },\n style: {\n color: (theme.vars ?? theme).palette?.action?.active\n }\n }, {\n props: {\n color: 'disabled'\n },\n style: {\n color: (theme.vars ?? theme).palette?.action?.disabled\n }\n }, {\n props: {\n color: 'inherit'\n },\n style: {\n color: undefined\n }\n }]\n})));\nconst SvgIcon = /*#__PURE__*/React.forwardRef(function SvgIcon(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiSvgIcon'\n });\n const {\n children,\n className,\n color = 'inherit',\n component = 'svg',\n fontSize = 'medium',\n htmlColor,\n inheritViewBox = false,\n titleAccess,\n viewBox = '0 0 24 24',\n ...other\n } = props;\n const hasSvgAsChild = /*#__PURE__*/React.isValidElement(children) && children.type === 'svg';\n const ownerState = {\n ...props,\n color,\n component,\n fontSize,\n instanceFontSize: inProps.fontSize,\n inheritViewBox,\n viewBox,\n hasSvgAsChild\n };\n const more = {};\n if (!inheritViewBox) {\n more.viewBox = viewBox;\n }\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsxs(SvgIconRoot, {\n as: component,\n className: clsx(classes.root, className),\n focusable: \"false\",\n color: htmlColor,\n \"aria-hidden\": titleAccess ? undefined : true,\n role: titleAccess ? 'img' : undefined,\n ref: ref,\n ...more,\n ...other,\n ...(hasSvgAsChild && children.props),\n ownerState: ownerState,\n children: [hasSvgAsChild ? children.props.children : children, titleAccess ? /*#__PURE__*/_jsx(\"title\", {\n children: titleAccess\n }) : null]\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? SvgIcon.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Node passed into the SVG element.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The color of the component.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n * You can use the `htmlColor` prop to apply a color attribute to the SVG element.\n * @default 'inherit'\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'action', 'disabled', 'primary', 'secondary', 'error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The fontSize applied to the icon. Defaults to 24px, but can be configure to inherit font size.\n * @default 'medium'\n */\n fontSize: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'large', 'medium', 'small']), PropTypes.string]),\n /**\n * Applies a color attribute to the SVG element.\n */\n htmlColor: PropTypes.string,\n /**\n * If `true`, the root node will inherit the custom `component`'s viewBox and the `viewBox`\n * prop will be ignored.\n * Useful when you want to reference a custom `component` and have `SvgIcon` pass that\n * `component`'s viewBox to the root node.\n * @default false\n */\n inheritViewBox: PropTypes.bool,\n /**\n * The shape-rendering attribute. The behavior of the different options is described on the\n * [MDN Web Docs](https://developer.mozilla.org/en-US/docs/Web/SVG/Reference/Attribute/shape-rendering).\n * If you are having issues with blurry icons you should investigate this prop.\n */\n shapeRendering: PropTypes.string,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * Provides a human-readable title for the element that contains it.\n * https://www.w3.org/TR/SVG-access/#Equivalent\n */\n titleAccess: PropTypes.string,\n /**\n * Allows you to redefine what the coordinates without units mean inside an SVG element.\n * For example, if the SVG element is 500 (width) by 200 (height),\n * and you pass viewBox=\"0 0 50 20\",\n * this means that the coordinates inside the SVG will go from the top left corner (0,0)\n * to bottom right (50,20) and each unit will be worth 10px.\n * @default '0 0 24 24'\n */\n viewBox: PropTypes.string\n} : void 0;\nSvgIcon.muiName = 'SvgIcon';\nexport default SvgIcon;","'use client';\n\nimport * as React from 'react';\nimport SvgIcon from \"../SvgIcon/index.js\";\n\n/**\n * Private module reserved for @mui packages.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default function createSvgIcon(path, displayName) {\n function Component(props, ref) {\n return /*#__PURE__*/_jsx(SvgIcon, {\n \"data-testid\": process.env.NODE_ENV !== 'production' ? `${displayName}Icon` : undefined,\n ref: ref,\n ...props,\n children: path\n });\n }\n if (process.env.NODE_ENV !== 'production') {\n // Need to set `displayName` on the inner component for React.memo.\n // React prior to 16.14 ignores `displayName` on the wrapper.\n Component.displayName = `${displayName}Icon`;\n }\n Component.muiName = SvgIcon.muiName;\n return /*#__PURE__*/React.memo(/*#__PURE__*/React.forwardRef(Component));\n}","'use client';\n\nimport * as React from 'react';\nimport useEnhancedEffect from \"../useEnhancedEffect/index.js\";\n\n/**\n * Inspired by https://github.com/facebook/react/issues/14099#issuecomment-440013892\n * See RFC in https://github.com/reactjs/rfcs/pull/220\n */\n\nfunction useEventCallback(fn) {\n const ref = React.useRef(fn);\n useEnhancedEffect(() => {\n ref.current = fn;\n });\n return React.useRef((...args) =>\n // @ts-expect-error hide `this`\n (0, ref.current)(...args)).current;\n}\nexport default useEventCallback;","'use client';\n\nimport * as React from 'react';\n\n/**\n * Merges refs into a single memoized callback ref or `null`.\n *\n * ```tsx\n * const rootRef = React.useRef<Instance>(null);\n * const refFork = useForkRef(rootRef, props.ref);\n *\n * return (\n * <Root {...props} ref={refFork} />\n * );\n * ```\n *\n * @param {Array<React.Ref<Instance> | undefined>} refs The ref array.\n * @returns {React.RefCallback<Instance> | null} The new ref callback.\n */\nexport default function useForkRef(...refs) {\n const cleanupRef = React.useRef(undefined);\n const refEffect = React.useCallback(instance => {\n const cleanups = refs.map(ref => {\n if (ref == null) {\n return null;\n }\n if (typeof ref === 'function') {\n const refCallback = ref;\n const refCleanup = refCallback(instance);\n return typeof refCleanup === 'function' ? refCleanup : () => {\n refCallback(null);\n };\n }\n ref.current = instance;\n return () => {\n ref.current = null;\n };\n });\n return () => {\n cleanups.forEach(refCleanup => refCleanup?.());\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n return React.useMemo(() => {\n if (refs.every(ref => ref == null)) {\n return null;\n }\n return value => {\n if (cleanupRef.current) {\n cleanupRef.current();\n cleanupRef.current = undefined;\n }\n if (value != null) {\n cleanupRef.current = refEffect(value);\n }\n };\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- intentionally ignoring that the dependency array must be an array literal\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}","export default function chainPropTypes(propType1, propType2) {\n if (process.env.NODE_ENV === 'production') {\n return () => null;\n }\n return function validate(...args) {\n return propType1(...args) || propType2(...args);\n };\n}","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (-1 !== e.indexOf(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","function _setPrototypeOf(t, e) {\n return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {\n return t.__proto__ = e, t;\n }, _setPrototypeOf(t, e);\n}\nexport { _setPrototypeOf as default };","import setPrototypeOf from \"./setPrototypeOf.js\";\nfunction _inheritsLoose(t, o) {\n t.prototype = Object.create(o.prototype), t.prototype.constructor = t, setPrototypeOf(t, o);\n}\nexport { _inheritsLoose as default };","import React from 'react';\nexport default React.createContext(null);","function _assertThisInitialized(e) {\n if (void 0 === e) throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n return e;\n}\nexport { _assertThisInitialized as default };","import { Children, cloneElement, isValidElement } from 'react';\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\n\nexport function getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && isValidElement(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\nexport function mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nexport function getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\nexport function getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!isValidElement(child)) return;\n var hasPrev = (key in prevChildMapping);\n var hasNext = (key in nextChildMapping);\n var prevChild = prevChildMapping[key];\n var isLeaving = isValidElement(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = cloneElement(child, {\n in: false\n });\n } else if (hasNext && hasPrev && isValidElement(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = cloneElement(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { getChildMapping, getInitialChildMapping, getNextChildMapping } from './utils/ChildMapping';\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n};\n/**\n * The `<TransitionGroup>` component manages a set of transition components\n * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n * components, `<TransitionGroup>` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the `<TransitionGroup>`.\n *\n * Note that `<TransitionGroup>` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\nvar TransitionGroup = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_this)); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? getInitialChildMapping(nextProps, handleExited) : getNextChildMapping(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n } // node is `undefined` when user provided `nodeRef` prop\n ;\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = getChildMapping(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, children);\n }\n\n return /*#__PURE__*/React.createElement(TransitionGroupContext.Provider, {\n value: contextValue\n }, /*#__PURE__*/React.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(React.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * `<TransitionGroup>` renders a `<div>` by default. You can change this\n * behavior by providing a `component` prop.\n * If you use React v16+ and would like to avoid a wrapping `<div>` element\n * you can pass in `component={null}`. This is useful if the wrapping div\n * borks your css styles.\n */\n component: PropTypes.any,\n\n /**\n * A set of `<Transition>` components, that are toggled `in` and out as they\n * leave. the `<TransitionGroup>` will inject specific transition props, so\n * remember to spread them through if you are wrapping the `<Transition>` as\n * with our `<Fade>` example.\n *\n * While this component is meant for multiple `Transition` or `CSSTransition`\n * children, sometimes you may want to have a single transition child with\n * content that you want to be transitioned out and in when you change it\n * (e.g. routes, images etc.) In that case you can change the `key` prop of\n * the transition child as you change its content, this will cause\n * `TransitionGroup` to transition the child out and back in.\n */\n children: PropTypes.node,\n\n /**\n * A convenience prop that enables or disables appear animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n appear: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables enter animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * A convenience prop that enables or disables exit animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * You may need to apply reactive updates to a child as it is exiting.\n * This is generally done by using `cloneElement` however in the case of an exiting\n * child the element has already been removed and not accessible to the consumer.\n *\n * If you do need to update a child as it leaves you can provide a `childFactory`\n * to wrap every child, even the ones that are leaving.\n *\n * @type Function(child: ReactElement) -> ReactElement\n */\n childFactory: PropTypes.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\nexport default TransitionGroup;","'use client';\n\nimport * as React from 'react';\nconst UNINITIALIZED = {};\n\n/**\n * A React.useRef() that is initialized lazily with a function. Note that it accepts an optional\n * initialization argument, so the initialization function doesn't need to be an inline closure.\n *\n * @usage\n * const ref = useLazyRef(sortColumns, columns)\n */\nexport default function useLazyRef(init, initArg) {\n const ref = React.useRef(UNINITIALIZED);\n if (ref.current === UNINITIALIZED) {\n ref.current = init(initArg);\n }\n return ref;\n}","'use client';\n\nimport * as React from 'react';\nconst EMPTY = [];\n\n/**\n * A React.useEffect equivalent that runs once, when the component is mounted.\n */\nexport default function useOnMount(fn) {\n // TODO: uncomment once we enable eslint-plugin-react-compiler // eslint-disable-next-line react-compiler/react-compiler -- no need to put `fn` in the dependency array\n /* eslint-disable react-hooks/exhaustive-deps */\n React.useEffect(fn, EMPTY);\n /* eslint-enable react-hooks/exhaustive-deps */\n}","'use client';\n\nimport useLazyRef from \"../useLazyRef/useLazyRef.js\";\nimport useOnMount from \"../useOnMount/useOnMount.js\";\nexport class Timeout {\n static create() {\n return new Timeout();\n }\n currentId = null;\n\n /**\n * Executes `fn` after `delay`, clearing any previously scheduled call.\n */\n start(delay, fn) {\n this.clear();\n this.currentId = setTimeout(() => {\n this.currentId = null;\n fn();\n }, delay);\n }\n clear = () => {\n if (this.currentId !== null) {\n clearTimeout(this.currentId);\n this.currentId = null;\n }\n };\n disposeEffect = () => {\n return this.clear;\n };\n}\nexport default function useTimeout() {\n const timeout = useLazyRef(Timeout.create).current;\n useOnMount(timeout.disposeEffect);\n return timeout;\n}","import PropTypes from 'prop-types';\nimport chainPropTypes from \"../chainPropTypes/index.js\";\nfunction isClassComponent(elementType) {\n // elementType.prototype?.isReactComponent\n const {\n prototype = {}\n } = elementType;\n return Boolean(prototype.isReactComponent);\n}\nfunction elementTypeAcceptingRef(props, propName, componentName, location, propFullName) {\n const propValue = props[propName];\n const safePropName = propFullName || propName;\n if (propValue == null ||\n // When server-side rendering React doesn't warn either.\n // This is not an accurate check for SSR.\n // This is only in place for emotion compat.\n // TODO: Revisit once https://github.com/facebook/react/issues/20047 is resolved.\n typeof window === 'undefined') {\n return null;\n }\n let warningHint;\n\n /**\n * Blacklisting instead of whitelisting\n *\n * Blacklisting will miss some components, such as React.Fragment. Those will at least\n * trigger a warning in React.\n * We can't whitelist because there is no safe way to detect React.forwardRef\n * or class components. \"Safe\" means there's no public API.\n *\n */\n if (typeof propValue === 'function' && !isClassComponent(propValue)) {\n warningHint = 'Did you accidentally provide a plain function component instead?';\n }\n if (warningHint !== undefined) {\n return new Error(`Invalid ${location} \\`${safePropName}\\` supplied to \\`${componentName}\\`. ` + `Expected an element type that can hold a ref. ${warningHint} ` + 'For more information see https://mui.com/r/caveat-with-refs-guide');\n }\n return null;\n}\nexport default chainPropTypes(PropTypes.elementType, elementTypeAcceptingRef);","/**\n * Determines if a given element is a DOM element name (i.e. not a React component).\n */\nfunction isHostComponent(element) {\n return typeof element === 'string';\n}\nexport default isHostComponent;","import isHostComponent from \"../isHostComponent/index.js\";\n\n/**\n * Type of the ownerState based on the type of an element it applies to.\n * This resolves to the provided OwnerState for React components and `undefined` for host components.\n * Falls back to `OwnerState | undefined` when the exact type can't be determined in development time.\n */\n\n/**\n * Appends the ownerState object to the props, merging with the existing one if necessary.\n *\n * @param elementType Type of the element that owns the `existingProps`. If the element is a DOM node or undefined, `ownerState` is not applied.\n * @param otherProps Props of the element.\n * @param ownerState\n */\nfunction appendOwnerState(elementType, otherProps, ownerState) {\n if (elementType === undefined || isHostComponent(elementType)) {\n return otherProps;\n }\n return {\n ...otherProps,\n ownerState: {\n ...otherProps.ownerState,\n ...ownerState\n }\n };\n}\nexport default appendOwnerState;","/**\n * If `componentProps` is a function, calls it with the provided `ownerState`.\n * Otherwise, just returns `componentProps`.\n */\nfunction resolveComponentProps(componentProps, ownerState, slotState) {\n if (typeof componentProps === 'function') {\n return componentProps(ownerState, slotState);\n }\n return componentProps;\n}\nexport default resolveComponentProps;","/**\n * Extracts event handlers from a given object.\n * A prop is considered an event handler if it is a function and its name starts with `on`.\n *\n * @param object An object to extract event handlers from.\n * @param excludeKeys An array of keys to exclude from the returned object.\n */\nfunction extractEventHandlers(object, excludeKeys = []) {\n if (object === undefined) {\n return {};\n }\n const result = {};\n Object.keys(object).filter(prop => prop.match(/^on[A-Z]/) && typeof object[prop] === 'function' && !excludeKeys.includes(prop)).forEach(prop => {\n result[prop] = object[prop];\n });\n return result;\n}\nexport default extractEventHandlers;","/**\n * Removes event handlers from the given object.\n * A field is considered an event handler if it is a function with a name beginning with `on`.\n *\n * @param object Object to remove event handlers from.\n * @returns Object with event handlers removed.\n */\nfunction omitEventHandlers(object) {\n if (object === undefined) {\n return {};\n }\n const result = {};\n Object.keys(object).filter(prop => !(prop.match(/^on[A-Z]/) && typeof object[prop] === 'function')).forEach(prop => {\n result[prop] = object[prop];\n });\n return result;\n}\nexport default omitEventHandlers;","import clsx from 'clsx';\nimport extractEventHandlers from \"../extractEventHandlers/index.js\";\nimport omitEventHandlers from \"../omitEventHandlers/index.js\";\n/**\n * Merges the slot component internal props (usually coming from a hook)\n * with the externally provided ones.\n *\n * The merge order is (the latter overrides the former):\n * 1. The internal props (specified as a getter function to work with get*Props hook result)\n * 2. Additional props (specified internally on a Base UI component)\n * 3. External props specified on the owner component. These should only be used on a root slot.\n * 4. External props specified in the `slotProps.*` prop.\n * 5. The `className` prop - combined from all the above.\n * @param parameters\n * @returns\n */\nfunction mergeSlotProps(parameters) {\n const {\n getSlotProps,\n additionalProps,\n externalSlotProps,\n externalForwardedProps,\n className\n } = parameters;\n if (!getSlotProps) {\n // The simpler case - getSlotProps is not defined, so no internal event handlers are defined,\n // so we can simply merge all the props without having to worry about extracting event handlers.\n const joinedClasses = clsx(additionalProps?.className, className, externalForwardedProps?.className, externalSlotProps?.className);\n const mergedStyle = {\n ...additionalProps?.style,\n ...externalForwardedProps?.style,\n ...externalSlotProps?.style\n };\n const props = {\n ...additionalProps,\n ...externalForwardedProps,\n ...externalSlotProps\n };\n if (joinedClasses.length > 0) {\n props.className = joinedClasses;\n }\n if (Object.keys(mergedStyle).length > 0) {\n props.style = mergedStyle;\n }\n return {\n props,\n internalRef: undefined\n };\n }\n\n // In this case, getSlotProps is responsible for calling the external event handlers.\n // We don't need to include them in the merged props because of this.\n\n const eventHandlers = extractEventHandlers({\n ...externalForwardedProps,\n ...externalSlotProps\n });\n const componentsPropsWithoutEventHandlers = omitEventHandlers(externalSlotProps);\n const otherPropsWithoutEventHandlers = omitEventHandlers(externalForwardedProps);\n const internalSlotProps = getSlotProps(eventHandlers);\n\n // The order of classes is important here.\n // Emotion (that we use in libraries consuming Base UI) depends on this order\n // to properly override style. It requires the most important classes to be last\n // (see https://github.com/mui/material-ui/pull/33205) for the related discussion.\n const joinedClasses = clsx(internalSlotProps?.className, additionalProps?.className, className, externalForwardedProps?.className, externalSlotProps?.className);\n const mergedStyle = {\n ...internalSlotProps?.style,\n ...additionalProps?.style,\n ...externalForwardedProps?.style,\n ...externalSlotProps?.style\n };\n const props = {\n ...internalSlotProps,\n ...additionalProps,\n ...otherPropsWithoutEventHandlers,\n ...componentsPropsWithoutEventHandlers\n };\n if (joinedClasses.length > 0) {\n props.className = joinedClasses;\n }\n if (Object.keys(mergedStyle).length > 0) {\n props.style = mergedStyle;\n }\n return {\n props,\n internalRef: internalSlotProps.ref\n };\n}\nexport default mergeSlotProps;","'use client';\n\nimport useForkRef from '@mui/utils/useForkRef';\nimport appendOwnerState from '@mui/utils/appendOwnerState';\nimport resolveComponentProps from '@mui/utils/resolveComponentProps';\nimport mergeSlotProps from '@mui/utils/mergeSlotProps';\n/**\n * An internal function to create a Material UI slot.\n *\n * This is an advanced version of Base UI `useSlotProps` because Material UI allows leaf component to be customized via `component` prop\n * while Base UI does not need to support leaf component customization.\n *\n * @param {string} name: name of the slot\n * @param {object} parameters\n * @returns {[Slot, slotProps]} The slot's React component and the slot's props\n *\n * Note: the returned slot's props\n * - will never contain `component` prop.\n * - might contain `as` prop.\n */\nexport default function useSlot(\n/**\n * The slot's name. All Material UI components should have `root` slot.\n *\n * If the name is `root`, the logic behaves differently from other slots,\n * e.g. the `externalForwardedProps` are spread to `root` slot but not other slots.\n */\nname, parameters) {\n const {\n className,\n elementType: initialElementType,\n ownerState,\n externalForwardedProps,\n internalForwardedProps,\n shouldForwardComponentProp = false,\n ...useSlotPropsParams\n } = parameters;\n const {\n component: rootComponent,\n slots = {\n [name]: undefined\n },\n slotProps = {\n [name]: undefined\n },\n ...other\n } = externalForwardedProps;\n const elementType = slots[name] || initialElementType;\n\n // `slotProps[name]` can be a callback that receives the component's ownerState.\n // `resolvedComponentsProps` is always a plain object.\n const resolvedComponentsProps = resolveComponentProps(slotProps[name], ownerState);\n const {\n props: {\n component: slotComponent,\n ...mergedProps\n },\n internalRef\n } = mergeSlotProps({\n className,\n ...useSlotPropsParams,\n externalForwardedProps: name === 'root' ? other : undefined,\n externalSlotProps: resolvedComponentsProps\n });\n const ref = useForkRef(internalRef, resolvedComponentsProps?.ref, parameters.ref);\n const LeafComponent = name === 'root' ? slotComponent || rootComponent : slotComponent;\n const props = appendOwnerState(elementType, {\n ...(name === 'root' && !rootComponent && !slots[name] && internalForwardedProps),\n ...(name !== 'root' && !slots[name] && internalForwardedProps),\n ...mergedProps,\n ...(LeafComponent && !shouldForwardComponentProp && {\n as: LeafComponent\n }),\n ...(LeafComponent && shouldForwardComponentProp && {\n component: LeafComponent\n }),\n ref\n }, ownerState);\n return [elementType, props];\n}","export function getTypeByValue(value) {\n const valueType = typeof value;\n switch (valueType) {\n case 'number':\n if (Number.isNaN(value)) {\n return 'NaN';\n }\n if (!Number.isFinite(value)) {\n return 'Infinity';\n }\n if (value !== Math.floor(value)) {\n return 'float';\n }\n return 'number';\n case 'object':\n if (value === null) {\n return 'null';\n }\n return value.constructor.name;\n default:\n return valueType;\n }\n}\nfunction requiredInteger(props, propName, componentName, location) {\n const propValue = props[propName];\n if (propValue == null || !Number.isInteger(propValue)) {\n const propType = getTypeByValue(propValue);\n return new RangeError(`Invalid ${location} \\`${propName}\\` of type \\`${propType}\\` supplied to \\`${componentName}\\`, expected \\`integer\\`.`);\n }\n return null;\n}\nfunction validator(props, propName, componentName, location) {\n const propValue = props[propName];\n if (propValue === undefined) {\n return null;\n }\n return requiredInteger(props, propName, componentName, location);\n}\nfunction validatorNoop() {\n return null;\n}\nvalidator.isRequired = requiredInteger;\nvalidatorNoop.isRequired = validatorNoop;\nconst integerPropType = process.env.NODE_ENV === 'production' ? validatorNoop : validator;\nexport default integerPropType;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getPaperUtilityClass(slot) {\n return generateUtilityClass('MuiPaper', slot);\n}\nconst paperClasses = generateUtilityClasses('MuiPaper', ['root', 'rounded', 'outlined', 'elevation', 'elevation0', 'elevation1', 'elevation2', 'elevation3', 'elevation4', 'elevation5', 'elevation6', 'elevation7', 'elevation8', 'elevation9', 'elevation10', 'elevation11', 'elevation12', 'elevation13', 'elevation14', 'elevation15', 'elevation16', 'elevation17', 'elevation18', 'elevation19', 'elevation20', 'elevation21', 'elevation22', 'elevation23', 'elevation24']);\nexport default paperClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport integerPropType from '@mui/utils/integerPropType';\nimport chainPropTypes from '@mui/utils/chainPropTypes';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { alpha } from '@mui/system/colorManipulator';\nimport { styled, useTheme } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport getOverlayAlpha from \"../styles/getOverlayAlpha.js\";\nimport { getPaperUtilityClass } from \"./paperClasses.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n square,\n elevation,\n variant,\n classes\n } = ownerState;\n const slots = {\n root: ['root', variant, !square && 'rounded', variant === 'elevation' && `elevation${elevation}`]\n };\n return composeClasses(slots, getPaperUtilityClass, classes);\n};\nconst PaperRoot = styled('div', {\n name: 'MuiPaper',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, styles[ownerState.variant], !ownerState.square && styles.rounded, ownerState.variant === 'elevation' && styles[`elevation${ownerState.elevation}`]];\n }\n})(memoTheme(({\n theme\n}) => ({\n backgroundColor: (theme.vars || theme).palette.background.paper,\n color: (theme.vars || theme).palette.text.primary,\n transition: theme.transitions.create('box-shadow'),\n variants: [{\n props: ({\n ownerState\n }) => !ownerState.square,\n style: {\n borderRadius: theme.shape.borderRadius\n }\n }, {\n props: {\n variant: 'outlined'\n },\n style: {\n border: `1px solid ${(theme.vars || theme).palette.divider}`\n }\n }, {\n props: {\n variant: 'elevation'\n },\n style: {\n boxShadow: 'var(--Paper-shadow)',\n backgroundImage: 'var(--Paper-overlay)'\n }\n }]\n})));\nconst Paper = /*#__PURE__*/React.forwardRef(function Paper(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiPaper'\n });\n const theme = useTheme();\n const {\n className,\n component = 'div',\n elevation = 1,\n square = false,\n variant = 'elevation',\n ...other\n } = props;\n const ownerState = {\n ...props,\n component,\n elevation,\n square,\n variant\n };\n const classes = useUtilityClasses(ownerState);\n if (process.env.NODE_ENV !== 'production') {\n if (theme.shadows[elevation] === undefined) {\n console.error([`MUI: The elevation provided <Paper elevation={${elevation}}> is not available in the theme.`, `Please make sure that \\`theme.shadows[${elevation}]\\` is defined.`].join('\\n'));\n }\n }\n return /*#__PURE__*/_jsx(PaperRoot, {\n as: component,\n ownerState: ownerState,\n className: clsx(classes.root, className),\n ref: ref,\n ...other,\n style: {\n ...(variant === 'elevation' && {\n '--Paper-shadow': (theme.vars || theme).shadows[elevation],\n ...(theme.vars && {\n '--Paper-overlay': theme.vars.overlays?.[elevation]\n }),\n ...(!theme.vars && theme.palette.mode === 'dark' && {\n '--Paper-overlay': `linear-gradient(${alpha('#fff', getOverlayAlpha(elevation))}, ${alpha('#fff', getOverlayAlpha(elevation))})`\n })\n }),\n ...other.style\n }\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Paper.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * Shadow depth, corresponds to `dp` in the spec.\n * It accepts values between 0 and 24 inclusive.\n * @default 1\n */\n elevation: chainPropTypes(integerPropType, props => {\n const {\n elevation,\n variant\n } = props;\n if (elevation > 0 && variant === 'outlined') {\n return new Error(`MUI: Combining \\`elevation={${elevation}}\\` with \\`variant=\"${variant}\"\\` has no effect. Either use \\`elevation={0}\\` or use a different \\`variant\\`.`);\n }\n return null;\n }),\n /**\n * If `true`, rounded corners are disabled.\n * @default false\n */\n square: PropTypes.bool,\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The variant to use.\n * @default 'elevation'\n */\n variant: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['elevation', 'outlined']), PropTypes.string])\n} : void 0;\nexport default Paper;","import PropTypes from 'prop-types';\nconst refType = PropTypes.oneOfType([PropTypes.func, PropTypes.object]);\nexport default refType;","/**\n * Returns a boolean indicating if the event's target has :focus-visible\n */\nexport default function isFocusVisible(element) {\n try {\n return element.matches(':focus-visible');\n } catch (error) {\n // Do not warn on jsdom tests, otherwise all tests that rely on focus have to be skipped\n // Tests that rely on `:focus-visible` will still have to be skipped in jsdom\n if (process.env.NODE_ENV !== 'production' && !window.navigator.userAgent.includes('jsdom')) {\n console.warn(['MUI: The `:focus-visible` pseudo class is not supported in this browser.', 'Some components rely on this feature to work properly.'].join('\\n'));\n }\n }\n return false;\n}","'use client';\n\nimport * as React from 'react';\nimport useLazyRef from '@mui/utils/useLazyRef';\n/**\n * Lazy initialization container for the Ripple instance. This improves\n * performance by delaying mounting the ripple until it's needed.\n */\nexport class LazyRipple {\n /** React ref to the ripple instance */\n\n /** If the ripple component should be mounted */\n\n /** Promise that resolves when the ripple component is mounted */\n\n /** If the ripple component has been mounted */\n\n /** React state hook setter */\n\n static create() {\n return new LazyRipple();\n }\n static use() {\n /* eslint-disable */\n const ripple = useLazyRef(LazyRipple.create).current;\n const [shouldMount, setShouldMount] = React.useState(false);\n ripple.shouldMount = shouldMount;\n ripple.setShouldMount = setShouldMount;\n React.useEffect(ripple.mountEffect, [shouldMount]);\n /* eslint-enable */\n\n return ripple;\n }\n constructor() {\n this.ref = {\n current: null\n };\n this.mounted = null;\n this.didMount = false;\n this.shouldMount = false;\n this.setShouldMount = null;\n }\n mount() {\n if (!this.mounted) {\n this.mounted = createControlledPromise();\n this.shouldMount = true;\n this.setShouldMount(this.shouldMount);\n }\n return this.mounted;\n }\n mountEffect = () => {\n if (this.shouldMount && !this.didMount) {\n if (this.ref.current !== null) {\n this.didMount = true;\n this.mounted.resolve();\n }\n }\n };\n\n /* Ripple API */\n\n start(...args) {\n this.mount().then(() => this.ref.current?.start(...args));\n }\n stop(...args) {\n this.mount().then(() => this.ref.current?.stop(...args));\n }\n pulsate(...args) {\n this.mount().then(() => this.ref.current?.pulsate(...args));\n }\n}\nexport default function useLazyRipple() {\n return LazyRipple.use();\n}\nfunction createControlledPromise() {\n let resolve;\n let reject;\n const p = new Promise((resolveFn, rejectFn) => {\n resolve = resolveFn;\n reject = rejectFn;\n });\n p.resolve = resolve;\n p.reject = reject;\n return p;\n}","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction Ripple(props) {\n const {\n className,\n classes,\n pulsate = false,\n rippleX,\n rippleY,\n rippleSize,\n in: inProp,\n onExited,\n timeout\n } = props;\n const [leaving, setLeaving] = React.useState(false);\n const rippleClassName = clsx(className, classes.ripple, classes.rippleVisible, pulsate && classes.ripplePulsate);\n const rippleStyles = {\n width: rippleSize,\n height: rippleSize,\n top: -(rippleSize / 2) + rippleY,\n left: -(rippleSize / 2) + rippleX\n };\n const childClassName = clsx(classes.child, leaving && classes.childLeaving, pulsate && classes.childPulsate);\n if (!inProp && !leaving) {\n setLeaving(true);\n }\n React.useEffect(() => {\n if (!inProp && onExited != null) {\n // react-transition-group#onExited\n const timeoutId = setTimeout(onExited, timeout);\n return () => {\n clearTimeout(timeoutId);\n };\n }\n return undefined;\n }, [onExited, inProp, timeout]);\n return /*#__PURE__*/_jsx(\"span\", {\n className: rippleClassName,\n style: rippleStyles,\n children: /*#__PURE__*/_jsx(\"span\", {\n className: childClassName\n })\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? Ripple.propTypes /* remove-proptypes */ = {\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object.isRequired,\n className: PropTypes.string,\n /**\n * @ignore - injected from TransitionGroup\n */\n in: PropTypes.bool,\n /**\n * @ignore - injected from TransitionGroup\n */\n onExited: PropTypes.func,\n /**\n * If `true`, the ripple pulsates, typically indicating the keyboard focus state of an element.\n */\n pulsate: PropTypes.bool,\n /**\n * Diameter of the ripple.\n */\n rippleSize: PropTypes.number,\n /**\n * Horizontal position of the ripple center.\n */\n rippleX: PropTypes.number,\n /**\n * Vertical position of the ripple center.\n */\n rippleY: PropTypes.number,\n /**\n * exit delay\n */\n timeout: PropTypes.number.isRequired\n} : void 0;\nexport default Ripple;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getTouchRippleUtilityClass(slot) {\n return generateUtilityClass('MuiTouchRipple', slot);\n}\nconst touchRippleClasses = generateUtilityClasses('MuiTouchRipple', ['root', 'ripple', 'rippleVisible', 'ripplePulsate', 'child', 'childLeaving', 'childPulsate']);\nexport default touchRippleClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { TransitionGroup } from 'react-transition-group';\nimport clsx from 'clsx';\nimport useTimeout from '@mui/utils/useTimeout';\nimport { keyframes, styled } from \"../zero-styled/index.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport Ripple from \"./Ripple.js\";\nimport touchRippleClasses from \"./touchRippleClasses.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst DURATION = 550;\nexport const DELAY_RIPPLE = 80;\nconst enterKeyframe = keyframes`\n 0% {\n transform: scale(0);\n opacity: 0.1;\n }\n\n 100% {\n transform: scale(1);\n opacity: 0.3;\n }\n`;\nconst exitKeyframe = keyframes`\n 0% {\n opacity: 1;\n }\n\n 100% {\n opacity: 0;\n }\n`;\nconst pulsateKeyframe = keyframes`\n 0% {\n transform: scale(1);\n }\n\n 50% {\n transform: scale(0.92);\n }\n\n 100% {\n transform: scale(1);\n }\n`;\nexport const TouchRippleRoot = styled('span', {\n name: 'MuiTouchRipple',\n slot: 'Root'\n})({\n overflow: 'hidden',\n pointerEvents: 'none',\n position: 'absolute',\n zIndex: 0,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n borderRadius: 'inherit'\n});\n\n// This `styled()` function invokes keyframes. `styled-components` only supports keyframes\n// in string templates. Do not convert these styles in JS object as it will break.\nexport const TouchRippleRipple = styled(Ripple, {\n name: 'MuiTouchRipple',\n slot: 'Ripple'\n})`\n opacity: 0;\n position: absolute;\n\n &.${touchRippleClasses.rippleVisible} {\n opacity: 0.3;\n transform: scale(1);\n animation-name: ${enterKeyframe};\n animation-duration: ${DURATION}ms;\n animation-timing-function: ${({\n theme\n}) => theme.transitions.easing.easeInOut};\n }\n\n &.${touchRippleClasses.ripplePulsate} {\n animation-duration: ${({\n theme\n}) => theme.transitions.duration.shorter}ms;\n }\n\n & .${touchRippleClasses.child} {\n opacity: 1;\n display: block;\n width: 100%;\n height: 100%;\n border-radius: 50%;\n background-color: currentColor;\n }\n\n & .${touchRippleClasses.childLeaving} {\n opacity: 0;\n animation-name: ${exitKeyframe};\n animation-duration: ${DURATION}ms;\n animation-timing-function: ${({\n theme\n}) => theme.transitions.easing.easeInOut};\n }\n\n & .${touchRippleClasses.childPulsate} {\n position: absolute;\n /* @noflip */\n left: 0px;\n top: 0;\n animation-name: ${pulsateKeyframe};\n animation-duration: 2500ms;\n animation-timing-function: ${({\n theme\n}) => theme.transitions.easing.easeInOut};\n animation-iteration-count: infinite;\n animation-delay: 200ms;\n }\n`;\n\n/**\n * @ignore - internal component.\n *\n * TODO v5: Make private\n */\nconst TouchRipple = /*#__PURE__*/React.forwardRef(function TouchRipple(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiTouchRipple'\n });\n const {\n center: centerProp = false,\n classes = {},\n className,\n ...other\n } = props;\n const [ripples, setRipples] = React.useState([]);\n const nextKey = React.useRef(0);\n const rippleCallback = React.useRef(null);\n React.useEffect(() => {\n if (rippleCallback.current) {\n rippleCallback.current();\n rippleCallback.current = null;\n }\n }, [ripples]);\n\n // Used to filter out mouse emulated events on mobile.\n const ignoringMouseDown = React.useRef(false);\n // We use a timer in order to only show the ripples for touch \"click\" like events.\n // We don't want to display the ripple for touch scroll events.\n const startTimer = useTimeout();\n\n // This is the hook called once the previous timeout is ready.\n const startTimerCommit = React.useRef(null);\n const container = React.useRef(null);\n const startCommit = React.useCallback(params => {\n const {\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n } = params;\n setRipples(oldRipples => [...oldRipples, /*#__PURE__*/_jsx(TouchRippleRipple, {\n classes: {\n ripple: clsx(classes.ripple, touchRippleClasses.ripple),\n rippleVisible: clsx(classes.rippleVisible, touchRippleClasses.rippleVisible),\n ripplePulsate: clsx(classes.ripplePulsate, touchRippleClasses.ripplePulsate),\n child: clsx(classes.child, touchRippleClasses.child),\n childLeaving: clsx(classes.childLeaving, touchRippleClasses.childLeaving),\n childPulsate: clsx(classes.childPulsate, touchRippleClasses.childPulsate)\n },\n timeout: DURATION,\n pulsate: pulsate,\n rippleX: rippleX,\n rippleY: rippleY,\n rippleSize: rippleSize\n }, nextKey.current)]);\n nextKey.current += 1;\n rippleCallback.current = cb;\n }, [classes]);\n const start = React.useCallback((event = {}, options = {}, cb = () => {}) => {\n const {\n pulsate = false,\n center = centerProp || options.pulsate,\n fakeElement = false // For test purposes\n } = options;\n if (event?.type === 'mousedown' && ignoringMouseDown.current) {\n ignoringMouseDown.current = false;\n return;\n }\n if (event?.type === 'touchstart') {\n ignoringMouseDown.current = true;\n }\n const element = fakeElement ? null : container.current;\n const rect = element ? element.getBoundingClientRect() : {\n width: 0,\n height: 0,\n left: 0,\n top: 0\n };\n\n // Get the size of the ripple\n let rippleX;\n let rippleY;\n let rippleSize;\n if (center || event === undefined || event.clientX === 0 && event.clientY === 0 || !event.clientX && !event.touches) {\n rippleX = Math.round(rect.width / 2);\n rippleY = Math.round(rect.height / 2);\n } else {\n const {\n clientX,\n clientY\n } = event.touches && event.touches.length > 0 ? event.touches[0] : event;\n rippleX = Math.round(clientX - rect.left);\n rippleY = Math.round(clientY - rect.top);\n }\n if (center) {\n rippleSize = Math.sqrt((2 * rect.width ** 2 + rect.height ** 2) / 3);\n\n // For some reason the animation is broken on Mobile Chrome if the size is even.\n if (rippleSize % 2 === 0) {\n rippleSize += 1;\n }\n } else {\n const sizeX = Math.max(Math.abs((element ? element.clientWidth : 0) - rippleX), rippleX) * 2 + 2;\n const sizeY = Math.max(Math.abs((element ? element.clientHeight : 0) - rippleY), rippleY) * 2 + 2;\n rippleSize = Math.sqrt(sizeX ** 2 + sizeY ** 2);\n }\n\n // Touch devices\n if (event?.touches) {\n // check that this isn't another touchstart due to multitouch\n // otherwise we will only clear a single timer when unmounting while two\n // are running\n if (startTimerCommit.current === null) {\n // Prepare the ripple effect.\n startTimerCommit.current = () => {\n startCommit({\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n });\n };\n // Delay the execution of the ripple effect.\n // We have to make a tradeoff with this delay value.\n startTimer.start(DELAY_RIPPLE, () => {\n if (startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n }\n });\n }\n } else {\n startCommit({\n pulsate,\n rippleX,\n rippleY,\n rippleSize,\n cb\n });\n }\n }, [centerProp, startCommit, startTimer]);\n const pulsate = React.useCallback(() => {\n start({}, {\n pulsate: true\n });\n }, [start]);\n const stop = React.useCallback((event, cb) => {\n startTimer.clear();\n\n // The touch interaction occurs too quickly.\n // We still want to show ripple effect.\n if (event?.type === 'touchend' && startTimerCommit.current) {\n startTimerCommit.current();\n startTimerCommit.current = null;\n startTimer.start(0, () => {\n stop(event, cb);\n });\n return;\n }\n startTimerCommit.current = null;\n setRipples(oldRipples => {\n if (oldRipples.length > 0) {\n return oldRipples.slice(1);\n }\n return oldRipples;\n });\n rippleCallback.current = cb;\n }, [startTimer]);\n React.useImperativeHandle(ref, () => ({\n pulsate,\n start,\n stop\n }), [pulsate, start, stop]);\n return /*#__PURE__*/_jsx(TouchRippleRoot, {\n className: clsx(touchRippleClasses.root, classes.root, className),\n ref: container,\n ...other,\n children: /*#__PURE__*/_jsx(TransitionGroup, {\n component: null,\n exit: true,\n children: ripples\n })\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? TouchRipple.propTypes /* remove-proptypes */ = {\n /**\n * If `true`, the ripple starts at the center of the component\n * rather than at the point of interaction.\n */\n center: PropTypes.bool,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string\n} : void 0;\nexport default TouchRipple;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getButtonBaseUtilityClass(slot) {\n return generateUtilityClass('MuiButtonBase', slot);\n}\nconst buttonBaseClasses = generateUtilityClasses('MuiButtonBase', ['root', 'disabled', 'focusVisible']);\nexport default buttonBaseClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport refType from '@mui/utils/refType';\nimport elementTypeAcceptingRef from '@mui/utils/elementTypeAcceptingRef';\nimport composeClasses from '@mui/utils/composeClasses';\nimport isFocusVisible from '@mui/utils/isFocusVisible';\nimport { styled } from \"../zero-styled/index.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport useForkRef from \"../utils/useForkRef.js\";\nimport useEventCallback from \"../utils/useEventCallback.js\";\nimport useLazyRipple from \"../useLazyRipple/index.js\";\nimport TouchRipple from \"./TouchRipple.js\";\nimport buttonBaseClasses, { getButtonBaseUtilityClass } from \"./buttonBaseClasses.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n disabled,\n focusVisible,\n focusVisibleClassName,\n classes\n } = ownerState;\n const slots = {\n root: ['root', disabled && 'disabled', focusVisible && 'focusVisible']\n };\n const composedClasses = composeClasses(slots, getButtonBaseUtilityClass, classes);\n if (focusVisible && focusVisibleClassName) {\n composedClasses.root += ` ${focusVisibleClassName}`;\n }\n return composedClasses;\n};\nexport const ButtonBaseRoot = styled('button', {\n name: 'MuiButtonBase',\n slot: 'Root'\n})({\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n position: 'relative',\n boxSizing: 'border-box',\n WebkitTapHighlightColor: 'transparent',\n backgroundColor: 'transparent',\n // Reset default value\n // We disable the focus ring for mouse, touch and keyboard users.\n outline: 0,\n border: 0,\n margin: 0,\n // Remove the margin in Safari\n borderRadius: 0,\n padding: 0,\n // Remove the padding in Firefox\n cursor: 'pointer',\n userSelect: 'none',\n verticalAlign: 'middle',\n MozAppearance: 'none',\n // Reset\n WebkitAppearance: 'none',\n // Reset\n textDecoration: 'none',\n // So we take precedent over the style of a native <a /> element.\n color: 'inherit',\n '&::-moz-focus-inner': {\n borderStyle: 'none' // Remove Firefox dotted outline.\n },\n [`&.${buttonBaseClasses.disabled}`]: {\n pointerEvents: 'none',\n // Disable link interactions\n cursor: 'default'\n },\n '@media print': {\n colorAdjust: 'exact'\n }\n});\n\n/**\n * `ButtonBase` contains as few styles as possible.\n * It aims to be a simple building block for creating a button.\n * It contains a load of style reset and some focus/ripple logic.\n */\nconst ButtonBase = /*#__PURE__*/React.forwardRef(function ButtonBase(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiButtonBase'\n });\n const {\n action,\n centerRipple = false,\n children,\n className,\n component = 'button',\n disabled = false,\n disableRipple = false,\n disableTouchRipple = false,\n focusRipple = false,\n focusVisibleClassName,\n LinkComponent = 'a',\n onBlur,\n onClick,\n onContextMenu,\n onDragLeave,\n onFocus,\n onFocusVisible,\n onKeyDown,\n onKeyUp,\n onMouseDown,\n onMouseLeave,\n onMouseUp,\n onTouchEnd,\n onTouchMove,\n onTouchStart,\n tabIndex = 0,\n TouchRippleProps,\n touchRippleRef,\n type,\n ...other\n } = props;\n const buttonRef = React.useRef(null);\n const ripple = useLazyRipple();\n const handleRippleRef = useForkRef(ripple.ref, touchRippleRef);\n const [focusVisible, setFocusVisible] = React.useState(false);\n if (disabled && focusVisible) {\n setFocusVisible(false);\n }\n React.useImperativeHandle(action, () => ({\n focusVisible: () => {\n setFocusVisible(true);\n buttonRef.current.focus();\n }\n }), []);\n const enableTouchRipple = ripple.shouldMount && !disableRipple && !disabled;\n React.useEffect(() => {\n if (focusVisible && focusRipple && !disableRipple) {\n ripple.pulsate();\n }\n }, [disableRipple, focusRipple, focusVisible, ripple]);\n const handleMouseDown = useRippleHandler(ripple, 'start', onMouseDown, disableTouchRipple);\n const handleContextMenu = useRippleHandler(ripple, 'stop', onContextMenu, disableTouchRipple);\n const handleDragLeave = useRippleHandler(ripple, 'stop', onDragLeave, disableTouchRipple);\n const handleMouseUp = useRippleHandler(ripple, 'stop', onMouseUp, disableTouchRipple);\n const handleMouseLeave = useRippleHandler(ripple, 'stop', event => {\n if (focusVisible) {\n event.preventDefault();\n }\n if (onMouseLeave) {\n onMouseLeave(event);\n }\n }, disableTouchRipple);\n const handleTouchStart = useRippleHandler(ripple, 'start', onTouchStart, disableTouchRipple);\n const handleTouchEnd = useRippleHandler(ripple, 'stop', onTouchEnd, disableTouchRipple);\n const handleTouchMove = useRippleHandler(ripple, 'stop', onTouchMove, disableTouchRipple);\n const handleBlur = useRippleHandler(ripple, 'stop', event => {\n if (!isFocusVisible(event.target)) {\n setFocusVisible(false);\n }\n if (onBlur) {\n onBlur(event);\n }\n }, false);\n const handleFocus = useEventCallback(event => {\n // Fix for https://github.com/facebook/react/issues/7769\n if (!buttonRef.current) {\n buttonRef.current = event.currentTarget;\n }\n if (isFocusVisible(event.target)) {\n setFocusVisible(true);\n if (onFocusVisible) {\n onFocusVisible(event);\n }\n }\n if (onFocus) {\n onFocus(event);\n }\n });\n const isNonNativeButton = () => {\n const button = buttonRef.current;\n return component && component !== 'button' && !(button.tagName === 'A' && button.href);\n };\n const handleKeyDown = useEventCallback(event => {\n // Check if key is already down to avoid repeats being counted as multiple activations\n if (focusRipple && !event.repeat && focusVisible && event.key === ' ') {\n ripple.stop(event, () => {\n ripple.start(event);\n });\n }\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === ' ') {\n event.preventDefault();\n }\n if (onKeyDown) {\n onKeyDown(event);\n }\n\n // Keyboard accessibility for non interactive elements\n if (event.target === event.currentTarget && isNonNativeButton() && event.key === 'Enter' && !disabled) {\n event.preventDefault();\n if (onClick) {\n onClick(event);\n }\n }\n });\n const handleKeyUp = useEventCallback(event => {\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/p/sandbox/button-keyup-preventdefault-dn7f0\n if (focusRipple && event.key === ' ' && focusVisible && !event.defaultPrevented) {\n ripple.stop(event, () => {\n ripple.pulsate(event);\n });\n }\n if (onKeyUp) {\n onKeyUp(event);\n }\n\n // Keyboard accessibility for non interactive elements\n if (onClick && event.target === event.currentTarget && isNonNativeButton() && event.key === ' ' && !event.defaultPrevented) {\n onClick(event);\n }\n });\n let ComponentProp = component;\n if (ComponentProp === 'button' && (other.href || other.to)) {\n ComponentProp = LinkComponent;\n }\n const buttonProps = {};\n if (ComponentProp === 'button') {\n const hasFormAttributes = !!other.formAction;\n // ButtonBase was defaulting to type=\"button\" when no type prop was provided, which prevented form submission and broke formAction functionality.\n // The fix checks for form-related attributes and skips the default type to allow the browser's natural submit behavior (type=\"submit\").\n buttonProps.type = type === undefined && !hasFormAttributes ? 'button' : type;\n buttonProps.disabled = disabled;\n } else {\n if (!other.href && !other.to) {\n buttonProps.role = 'button';\n }\n if (disabled) {\n buttonProps['aria-disabled'] = disabled;\n }\n }\n const handleRef = useForkRef(ref, buttonRef);\n const ownerState = {\n ...props,\n centerRipple,\n component,\n disabled,\n disableRipple,\n disableTouchRipple,\n focusRipple,\n tabIndex,\n focusVisible\n };\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsxs(ButtonBaseRoot, {\n as: ComponentProp,\n className: clsx(classes.root, className),\n ownerState: ownerState,\n onBlur: handleBlur,\n onClick: onClick,\n onContextMenu: handleContextMenu,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n onKeyUp: handleKeyUp,\n onMouseDown: handleMouseDown,\n onMouseLeave: handleMouseLeave,\n onMouseUp: handleMouseUp,\n onDragLeave: handleDragLeave,\n onTouchEnd: handleTouchEnd,\n onTouchMove: handleTouchMove,\n onTouchStart: handleTouchStart,\n ref: handleRef,\n tabIndex: disabled ? -1 : tabIndex,\n type: type,\n ...buttonProps,\n ...other,\n children: [children, enableTouchRipple ? /*#__PURE__*/_jsx(TouchRipple, {\n ref: handleRippleRef,\n center: centerRipple,\n ...TouchRippleProps\n }) : null]\n });\n});\nfunction useRippleHandler(ripple, rippleAction, eventCallback, skipRippleAction = false) {\n return useEventCallback(event => {\n if (eventCallback) {\n eventCallback(event);\n }\n if (!skipRippleAction) {\n ripple[rippleAction](event);\n }\n return true;\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? ButtonBase.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * A ref for imperative actions.\n * It currently only supports `focusVisible()` action.\n */\n action: refType,\n /**\n * If `true`, the ripples are centered.\n * They won't start at the cursor interaction position.\n * @default false\n */\n centerRipple: PropTypes.bool,\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: elementTypeAcceptingRef,\n /**\n * If `true`, the component is disabled.\n * @default false\n */\n disabled: PropTypes.bool,\n /**\n * If `true`, the ripple effect is disabled.\n *\n * ⚠️ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `.Mui-focusVisible` class.\n * @default false\n */\n disableRipple: PropTypes.bool,\n /**\n * If `true`, the touch ripple effect is disabled.\n * @default false\n */\n disableTouchRipple: PropTypes.bool,\n /**\n * If `true`, the base button will have a keyboard focus ripple.\n * @default false\n */\n focusRipple: PropTypes.bool,\n /**\n * This prop can help identify which element has keyboard focus.\n * The class name will be applied when the element gains the focus through keyboard interaction.\n * It's a polyfill for the [CSS :focus-visible selector](https://drafts.csswg.org/selectors-4/#the-focus-visible-pseudo).\n * The rationale for using this feature [is explained here](https://github.com/WICG/focus-visible/blob/HEAD/explainer.md).\n * A [polyfill can be used](https://github.com/WICG/focus-visible) to apply a `focus-visible` class to other components\n * if needed.\n */\n focusVisibleClassName: PropTypes.string,\n /**\n * @ignore\n */\n formAction: PropTypes.oneOfType([PropTypes.func, PropTypes.string]),\n /**\n * @ignore\n */\n href: PropTypes /* @typescript-to-proptypes-ignore */.any,\n /**\n * The component used to render a link when the `href` prop is provided.\n * @default 'a'\n */\n LinkComponent: PropTypes.elementType,\n /**\n * @ignore\n */\n onBlur: PropTypes.func,\n /**\n * @ignore\n */\n onClick: PropTypes.func,\n /**\n * @ignore\n */\n onContextMenu: PropTypes.func,\n /**\n * @ignore\n */\n onDragLeave: PropTypes.func,\n /**\n * @ignore\n */\n onFocus: PropTypes.func,\n /**\n * Callback fired when the component is focused with a keyboard.\n * We trigger a `onFocus` callback too.\n */\n onFocusVisible: PropTypes.func,\n /**\n * @ignore\n */\n onKeyDown: PropTypes.func,\n /**\n * @ignore\n */\n onKeyUp: PropTypes.func,\n /**\n * @ignore\n */\n onMouseDown: PropTypes.func,\n /**\n * @ignore\n */\n onMouseLeave: PropTypes.func,\n /**\n * @ignore\n */\n onMouseUp: PropTypes.func,\n /**\n * @ignore\n */\n onTouchEnd: PropTypes.func,\n /**\n * @ignore\n */\n onTouchMove: PropTypes.func,\n /**\n * @ignore\n */\n onTouchStart: PropTypes.func,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * @default 0\n */\n tabIndex: PropTypes.number,\n /**\n * Props applied to the `TouchRipple` element.\n */\n TouchRippleProps: PropTypes.object,\n /**\n * A ref that points to the `TouchRipple` element.\n */\n touchRippleRef: PropTypes.oneOfType([PropTypes.func, PropTypes.shape({\n current: PropTypes.shape({\n pulsate: PropTypes.func.isRequired,\n start: PropTypes.func.isRequired,\n stop: PropTypes.func.isRequired\n })\n })]),\n /**\n * @ignore\n */\n type: PropTypes.oneOfType([PropTypes.oneOf(['button', 'reset', 'submit']), PropTypes.string])\n} : void 0;\nexport default ButtonBase;","/**\n * Type guard to check if the object has a \"main\" property of type string.\n *\n * @param obj - the object to check\n * @returns boolean\n */\nfunction hasCorrectMainProperty(obj) {\n return typeof obj.main === 'string';\n}\n/**\n * Checks if the object conforms to the SimplePaletteColorOptions type.\n * The minimum requirement is that the object has a \"main\" property of type string, this is always checked.\n * Optionally, you can pass additional properties to check.\n *\n * @param obj - The object to check\n * @param additionalPropertiesToCheck - Array containing \"light\", \"dark\", and/or \"contrastText\"\n * @returns boolean\n */\nfunction checkSimplePaletteColorValues(obj, additionalPropertiesToCheck = []) {\n if (!hasCorrectMainProperty(obj)) {\n return false;\n }\n for (const value of additionalPropertiesToCheck) {\n if (!obj.hasOwnProperty(value) || typeof obj[value] !== 'string') {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Creates a filter function used to filter simple palette color options.\n * The minimum requirement is that the object has a \"main\" property of type string, this is always checked.\n * Optionally, you can pass additional properties to check.\n *\n * @param additionalPropertiesToCheck - Array containing \"light\", \"dark\", and/or \"contrastText\"\n * @returns ([, value]: [any, PaletteColorOptions]) => boolean\n */\nexport default function createSimplePaletteValueFilter(additionalPropertiesToCheck = []) {\n return ([, value]) => value && checkSimplePaletteColorValues(value, additionalPropertiesToCheck);\n}","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getAlertUtilityClass(slot) {\n return generateUtilityClass('MuiAlert', slot);\n}\nconst alertClasses = generateUtilityClasses('MuiAlert', ['root', 'action', 'icon', 'message', 'filled', 'colorSuccess', 'colorInfo', 'colorWarning', 'colorError', 'filledSuccess', 'filledInfo', 'filledWarning', 'filledError', 'outlined', 'outlinedSuccess', 'outlinedInfo', 'outlinedWarning', 'outlinedError', 'standard', 'standardSuccess', 'standardInfo', 'standardWarning', 'standardError']);\nexport default alertClasses;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getCircularProgressUtilityClass(slot) {\n return generateUtilityClass('MuiCircularProgress', slot);\n}\nconst circularProgressClasses = generateUtilityClasses('MuiCircularProgress', ['root', 'determinate', 'indeterminate', 'colorPrimary', 'colorSecondary', 'svg', 'track', 'circle', 'circleDeterminate', 'circleIndeterminate', 'circleDisableShrink']);\nexport default circularProgressClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport chainPropTypes from '@mui/utils/chainPropTypes';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { keyframes, css, styled } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport capitalize from \"../utils/capitalize.js\";\nimport createSimplePaletteValueFilter from \"../utils/createSimplePaletteValueFilter.js\";\nimport { getCircularProgressUtilityClass } from \"./circularProgressClasses.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst SIZE = 44;\nconst circularRotateKeyframe = keyframes`\n 0% {\n transform: rotate(0deg);\n }\n\n 100% {\n transform: rotate(360deg);\n }\n`;\nconst circularDashKeyframe = keyframes`\n 0% {\n stroke-dasharray: 1px, 200px;\n stroke-dashoffset: 0;\n }\n\n 50% {\n stroke-dasharray: 100px, 200px;\n stroke-dashoffset: -15px;\n }\n\n 100% {\n stroke-dasharray: 1px, 200px;\n stroke-dashoffset: -126px;\n }\n`;\n\n// This implementation is for supporting both Styled-components v4+ and Pigment CSS.\n// A global animation has to be created here for Styled-components v4+ (https://github.com/styled-components/styled-components/blob/main/packages/styled-components/src/utils/errors.md#12).\n// which can be done by checking typeof indeterminate1Keyframe !== 'string' (at runtime, Pigment CSS transform keyframes`` to a string).\nconst rotateAnimation = typeof circularRotateKeyframe !== 'string' ? css`\n animation: ${circularRotateKeyframe} 1.4s linear infinite;\n ` : null;\nconst dashAnimation = typeof circularDashKeyframe !== 'string' ? css`\n animation: ${circularDashKeyframe} 1.4s ease-in-out infinite;\n ` : null;\nconst useUtilityClasses = ownerState => {\n const {\n classes,\n variant,\n color,\n disableShrink\n } = ownerState;\n const slots = {\n root: ['root', variant, `color${capitalize(color)}`],\n svg: ['svg'],\n track: ['track'],\n circle: ['circle', `circle${capitalize(variant)}`, disableShrink && 'circleDisableShrink']\n };\n return composeClasses(slots, getCircularProgressUtilityClass, classes);\n};\nconst CircularProgressRoot = styled('span', {\n name: 'MuiCircularProgress',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, styles[ownerState.variant], styles[`color${capitalize(ownerState.color)}`]];\n }\n})(memoTheme(({\n theme\n}) => ({\n display: 'inline-block',\n variants: [{\n props: {\n variant: 'determinate'\n },\n style: {\n transition: theme.transitions.create('transform')\n }\n }, {\n props: {\n variant: 'indeterminate'\n },\n style: rotateAnimation || {\n animation: `${circularRotateKeyframe} 1.4s linear infinite`\n }\n }, ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter()).map(([color]) => ({\n props: {\n color\n },\n style: {\n color: (theme.vars || theme).palette[color].main\n }\n }))]\n})));\nconst CircularProgressSVG = styled('svg', {\n name: 'MuiCircularProgress',\n slot: 'Svg'\n})({\n display: 'block' // Keeps the progress centered\n});\nconst CircularProgressCircle = styled('circle', {\n name: 'MuiCircularProgress',\n slot: 'Circle',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.circle, styles[`circle${capitalize(ownerState.variant)}`], ownerState.disableShrink && styles.circleDisableShrink];\n }\n})(memoTheme(({\n theme\n}) => ({\n stroke: 'currentColor',\n variants: [{\n props: {\n variant: 'determinate'\n },\n style: {\n transition: theme.transitions.create('stroke-dashoffset')\n }\n }, {\n props: {\n variant: 'indeterminate'\n },\n style: {\n // Some default value that looks fine waiting for the animation to kicks in.\n strokeDasharray: '80px, 200px',\n strokeDashoffset: 0 // Add the unit to fix a Edge 16 and below bug.\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.variant === 'indeterminate' && !ownerState.disableShrink,\n style: dashAnimation || {\n // At runtime for Pigment CSS, `bufferAnimation` will be null and the generated keyframe will be used.\n animation: `${circularDashKeyframe} 1.4s ease-in-out infinite`\n }\n }]\n})));\nconst CircularProgressTrack = styled('circle', {\n name: 'MuiCircularProgress',\n slot: 'Track'\n})(memoTheme(({\n theme\n}) => ({\n stroke: 'currentColor',\n opacity: (theme.vars || theme).palette.action.activatedOpacity\n})));\n\n/**\n * ## ARIA\n *\n * If the progress bar is describing the loading progress of a particular region of a page,\n * you should use `aria-describedby` to point to the progress bar, and set the `aria-busy`\n * attribute to `true` on that region until it has finished loading.\n */\nconst CircularProgress = /*#__PURE__*/React.forwardRef(function CircularProgress(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiCircularProgress'\n });\n const {\n className,\n color = 'primary',\n disableShrink = false,\n enableTrackSlot = false,\n size = 40,\n style,\n thickness = 3.6,\n value = 0,\n variant = 'indeterminate',\n ...other\n } = props;\n const ownerState = {\n ...props,\n color,\n disableShrink,\n size,\n thickness,\n value,\n variant,\n enableTrackSlot\n };\n const classes = useUtilityClasses(ownerState);\n const circleStyle = {};\n const rootStyle = {};\n const rootProps = {};\n if (variant === 'determinate') {\n const circumference = 2 * Math.PI * ((SIZE - thickness) / 2);\n circleStyle.strokeDasharray = circumference.toFixed(3);\n rootProps['aria-valuenow'] = Math.round(value);\n circleStyle.strokeDashoffset = `${((100 - value) / 100 * circumference).toFixed(3)}px`;\n rootStyle.transform = 'rotate(-90deg)';\n }\n return /*#__PURE__*/_jsx(CircularProgressRoot, {\n className: clsx(classes.root, className),\n style: {\n width: size,\n height: size,\n ...rootStyle,\n ...style\n },\n ownerState: ownerState,\n ref: ref,\n role: \"progressbar\",\n ...rootProps,\n ...other,\n children: /*#__PURE__*/_jsxs(CircularProgressSVG, {\n className: classes.svg,\n ownerState: ownerState,\n viewBox: `${SIZE / 2} ${SIZE / 2} ${SIZE} ${SIZE}`,\n children: [enableTrackSlot ? /*#__PURE__*/_jsx(CircularProgressTrack, {\n className: classes.track,\n ownerState: ownerState,\n cx: SIZE,\n cy: SIZE,\n r: (SIZE - thickness) / 2,\n fill: \"none\",\n strokeWidth: thickness,\n \"aria-hidden\": \"true\"\n }) : null, /*#__PURE__*/_jsx(CircularProgressCircle, {\n className: classes.circle,\n style: circleStyle,\n ownerState: ownerState,\n cx: SIZE,\n cy: SIZE,\n r: (SIZE - thickness) / 2,\n fill: \"none\",\n strokeWidth: thickness\n })]\n })\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? CircularProgress.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The color of the component.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n * @default 'primary'\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'primary', 'secondary', 'error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * If `true`, the shrink animation is disabled.\n * This only works if variant is `indeterminate`.\n * @default false\n */\n disableShrink: chainPropTypes(PropTypes.bool, props => {\n if (props.disableShrink && props.variant && props.variant !== 'indeterminate') {\n return new Error('MUI: You have provided the `disableShrink` prop ' + 'with a variant other than `indeterminate`. This will have no effect.');\n }\n return null;\n }),\n /**\n * If `true`, a track circle slot is mounted to show a subtle background for the progress.\n * The `size` and `thickness` apply to the track slot to be consistent with the progress circle.\n * @default false\n */\n enableTrackSlot: PropTypes.bool,\n /**\n * The size of the component.\n * If using a number, the pixel unit is assumed.\n * If using a string, you need to provide the CSS unit, for example '3rem'.\n * @default 40\n */\n size: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The thickness of the circle.\n * @default 3.6\n */\n thickness: PropTypes.number,\n /**\n * The value of the progress indicator for the determinate variant.\n * Value between 0 and 100.\n * @default 0\n */\n value: PropTypes.number,\n /**\n * The variant to use.\n * Use indeterminate when there is no progress value.\n * @default 'indeterminate'\n */\n variant: PropTypes.oneOf(['determinate', 'indeterminate'])\n} : void 0;\nexport default CircularProgress;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getIconButtonUtilityClass(slot) {\n return generateUtilityClass('MuiIconButton', slot);\n}\nconst iconButtonClasses = generateUtilityClasses('MuiIconButton', ['root', 'disabled', 'colorInherit', 'colorPrimary', 'colorSecondary', 'colorError', 'colorInfo', 'colorSuccess', 'colorWarning', 'edgeStart', 'edgeEnd', 'sizeSmall', 'sizeMedium', 'sizeLarge', 'loading', 'loadingIndicator', 'loadingWrapper']);\nexport default iconButtonClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport chainPropTypes from '@mui/utils/chainPropTypes';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { unstable_useId as useId } from \"../utils/index.js\";\nimport { styled } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport createSimplePaletteValueFilter from \"../utils/createSimplePaletteValueFilter.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport ButtonBase from \"../ButtonBase/index.js\";\nimport CircularProgress from \"../CircularProgress/index.js\";\nimport capitalize from \"../utils/capitalize.js\";\nimport iconButtonClasses, { getIconButtonUtilityClass } from \"./iconButtonClasses.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n classes,\n disabled,\n color,\n edge,\n size,\n loading\n } = ownerState;\n const slots = {\n root: ['root', loading && 'loading', disabled && 'disabled', color !== 'default' && `color${capitalize(color)}`, edge && `edge${capitalize(edge)}`, `size${capitalize(size)}`],\n loadingIndicator: ['loadingIndicator'],\n loadingWrapper: ['loadingWrapper']\n };\n return composeClasses(slots, getIconButtonUtilityClass, classes);\n};\nconst IconButtonRoot = styled(ButtonBase, {\n name: 'MuiIconButton',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, ownerState.loading && styles.loading, ownerState.color !== 'default' && styles[`color${capitalize(ownerState.color)}`], ownerState.edge && styles[`edge${capitalize(ownerState.edge)}`], styles[`size${capitalize(ownerState.size)}`]];\n }\n})(memoTheme(({\n theme\n}) => ({\n textAlign: 'center',\n flex: '0 0 auto',\n fontSize: theme.typography.pxToRem(24),\n padding: 8,\n borderRadius: '50%',\n color: (theme.vars || theme).palette.action.active,\n transition: theme.transitions.create('background-color', {\n duration: theme.transitions.duration.shortest\n }),\n variants: [{\n props: props => !props.disableRipple,\n style: {\n '--IconButton-hoverBg': theme.alpha((theme.vars || theme).palette.action.active, (theme.vars || theme).palette.action.hoverOpacity),\n '&:hover': {\n backgroundColor: 'var(--IconButton-hoverBg)',\n // Reset on touch devices, it doesn't add specificity\n '@media (hover: none)': {\n backgroundColor: 'transparent'\n }\n }\n }\n }, {\n props: {\n edge: 'start'\n },\n style: {\n marginLeft: -12\n }\n }, {\n props: {\n edge: 'start',\n size: 'small'\n },\n style: {\n marginLeft: -3\n }\n }, {\n props: {\n edge: 'end'\n },\n style: {\n marginRight: -12\n }\n }, {\n props: {\n edge: 'end',\n size: 'small'\n },\n style: {\n marginRight: -3\n }\n }]\n})), memoTheme(({\n theme\n}) => ({\n variants: [{\n props: {\n color: 'inherit'\n },\n style: {\n color: 'inherit'\n }\n }, ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter()) // check all the used fields in the style below\n .map(([color]) => ({\n props: {\n color\n },\n style: {\n color: (theme.vars || theme).palette[color].main\n }\n })), ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter()) // check all the used fields in the style below\n .map(([color]) => ({\n props: {\n color\n },\n style: {\n '--IconButton-hoverBg': theme.alpha((theme.vars || theme).palette[color].main, (theme.vars || theme).palette.action.hoverOpacity)\n }\n })), {\n props: {\n size: 'small'\n },\n style: {\n padding: 5,\n fontSize: theme.typography.pxToRem(18)\n }\n }, {\n props: {\n size: 'large'\n },\n style: {\n padding: 12,\n fontSize: theme.typography.pxToRem(28)\n }\n }],\n [`&.${iconButtonClasses.disabled}`]: {\n backgroundColor: 'transparent',\n color: (theme.vars || theme).palette.action.disabled\n },\n [`&.${iconButtonClasses.loading}`]: {\n color: 'transparent'\n }\n})));\nconst IconButtonLoadingIndicator = styled('span', {\n name: 'MuiIconButton',\n slot: 'LoadingIndicator'\n})(({\n theme\n}) => ({\n display: 'none',\n position: 'absolute',\n visibility: 'visible',\n top: '50%',\n left: '50%',\n transform: 'translate(-50%, -50%)',\n color: (theme.vars || theme).palette.action.disabled,\n variants: [{\n props: {\n loading: true\n },\n style: {\n display: 'flex'\n }\n }]\n}));\n\n/**\n * Refer to the [Icons](/material-ui/icons/) section of the documentation\n * regarding the available icon options.\n */\nconst IconButton = /*#__PURE__*/React.forwardRef(function IconButton(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiIconButton'\n });\n const {\n edge = false,\n children,\n className,\n color = 'default',\n disabled = false,\n disableFocusRipple = false,\n size = 'medium',\n id: idProp,\n loading = null,\n loadingIndicator: loadingIndicatorProp,\n ...other\n } = props;\n const loadingId = useId(idProp);\n const loadingIndicator = loadingIndicatorProp ?? /*#__PURE__*/_jsx(CircularProgress, {\n \"aria-labelledby\": loadingId,\n color: \"inherit\",\n size: 16\n });\n const ownerState = {\n ...props,\n edge,\n color,\n disabled,\n disableFocusRipple,\n loading,\n loadingIndicator,\n size\n };\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsxs(IconButtonRoot, {\n id: loading ? loadingId : idProp,\n className: clsx(classes.root, className),\n centerRipple: true,\n focusRipple: !disableFocusRipple,\n disabled: disabled || loading,\n ref: ref,\n ...other,\n ownerState: ownerState,\n children: [typeof loading === 'boolean' &&\n /*#__PURE__*/\n // use plain HTML span to minimize the runtime overhead\n _jsx(\"span\", {\n className: classes.loadingWrapper,\n style: {\n display: 'contents'\n },\n children: /*#__PURE__*/_jsx(IconButtonLoadingIndicator, {\n className: classes.loadingIndicator,\n ownerState: ownerState,\n children: loading && loadingIndicator\n })\n }), children]\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? IconButton.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The icon to display.\n */\n children: chainPropTypes(PropTypes.node, props => {\n const found = React.Children.toArray(props.children).some(child => /*#__PURE__*/React.isValidElement(child) && child.props.onClick);\n if (found) {\n return new Error(['MUI: You are providing an onClick event listener to a child of a button element.', 'Prefer applying it to the IconButton directly.', 'This guarantees that the whole <button> will be responsive to click events.'].join('\\n'));\n }\n return null;\n }),\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The color of the component.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n * @default 'default'\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['inherit', 'default', 'primary', 'secondary', 'error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * If `true`, the component is disabled.\n * @default false\n */\n disabled: PropTypes.bool,\n /**\n * If `true`, the keyboard focus ripple is disabled.\n * @default false\n */\n disableFocusRipple: PropTypes.bool,\n /**\n * If `true`, the ripple effect is disabled.\n *\n * ⚠️ Without a ripple there is no styling for :focus-visible by default. Be sure\n * to highlight the element by applying separate styles with the `.Mui-focusVisible` class.\n * @default false\n */\n disableRipple: PropTypes.bool,\n /**\n * If given, uses a negative margin to counteract the padding on one\n * side (this is often helpful for aligning the left or right\n * side of the icon with content above or below, without ruining the border\n * size and shape).\n * @default false\n */\n edge: PropTypes.oneOf(['end', 'start', false]),\n /**\n * @ignore\n */\n id: PropTypes.string,\n /**\n * If `true`, the loading indicator is visible and the button is disabled.\n * If `true | false`, the loading wrapper is always rendered before the children to prevent [Google Translation Crash](https://github.com/mui/material-ui/issues/27853).\n * @default null\n */\n loading: PropTypes.bool,\n /**\n * Element placed before the children if the button is in loading state.\n * The node should contain an element with `role=\"progressbar\"` with an accessible name.\n * By default, it renders a `CircularProgress` that is labeled by the button itself.\n * @default <CircularProgress color=\"inherit\" size={16} />\n */\n loadingIndicator: PropTypes.node,\n /**\n * The size of the component.\n * `small` is equivalent to the dense button styling.\n * @default 'medium'\n */\n size: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['small', 'medium', 'large']), PropTypes.string]),\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default IconButton;","'use client';\n\nimport createSvgIcon from \"../../utils/createSvgIcon.js\";\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M20,12A8,8 0 0,1 12,20A8,8 0 0,1 4,12A8,8 0 0,1 12,4C12.76,4 13.5,4.11 14.2, 4.31L15.77,2.74C14.61,2.26 13.34,2 12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0, 0 22,12M7.91,10.08L6.5,11.5L11,16L21,6L19.59,4.58L11,13.17L7.91,10.08Z\"\n}), 'SuccessOutlined');","'use client';\n\nimport createSvgIcon from \"../../utils/createSvgIcon.js\";\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M12 5.99L19.53 19H4.47L12 5.99M12 2L1 21h22L12 2zm1 14h-2v2h2v-2zm0-6h-2v4h2v-4z\"\n}), 'ReportProblemOutlined');","'use client';\n\nimport createSvgIcon from \"../../utils/createSvgIcon.js\";\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M11 15h2v2h-2zm0-8h2v6h-2zm.99-5C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2zM12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z\"\n}), 'ErrorOutline');","'use client';\n\nimport createSvgIcon from \"../../utils/createSvgIcon.js\";\n\n/**\n * @ignore - internal component.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M11,9H13V7H11M12,20C7.59,20 4,16.41 4,12C4,7.59 7.59,4 12,4C16.41,4 20,7.59 20, 12C20,16.41 16.41,20 12,20M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12A10, 10 0 0,0 12,2M11,17H13V11H11V17Z\"\n}), 'InfoOutlined');","'use client';\n\nimport createSvgIcon from \"../../utils/createSvgIcon.js\";\n\n/**\n * @ignore - internal component.\n *\n * Alias to `Clear`.\n */\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z\"\n}), 'Close');","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { styled } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport useSlot from \"../utils/useSlot.js\";\nimport capitalize from \"../utils/capitalize.js\";\nimport createSimplePaletteValueFilter from \"../utils/createSimplePaletteValueFilter.js\";\nimport Paper from \"../Paper/index.js\";\nimport alertClasses, { getAlertUtilityClass } from \"./alertClasses.js\";\nimport IconButton from \"../IconButton/index.js\";\nimport SuccessOutlinedIcon from \"../internal/svg-icons/SuccessOutlined.js\";\nimport ReportProblemOutlinedIcon from \"../internal/svg-icons/ReportProblemOutlined.js\";\nimport ErrorOutlineIcon from \"../internal/svg-icons/ErrorOutline.js\";\nimport InfoOutlinedIcon from \"../internal/svg-icons/InfoOutlined.js\";\nimport CloseIcon from \"../internal/svg-icons/Close.js\";\nimport { jsx as _jsx, jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n variant,\n color,\n severity,\n classes\n } = ownerState;\n const slots = {\n root: ['root', `color${capitalize(color || severity)}`, `${variant}${capitalize(color || severity)}`, `${variant}`],\n icon: ['icon'],\n message: ['message'],\n action: ['action']\n };\n return composeClasses(slots, getAlertUtilityClass, classes);\n};\nconst AlertRoot = styled(Paper, {\n name: 'MuiAlert',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, styles[ownerState.variant], styles[`${ownerState.variant}${capitalize(ownerState.color || ownerState.severity)}`]];\n }\n})(memoTheme(({\n theme\n}) => {\n const getColor = theme.palette.mode === 'light' ? theme.darken : theme.lighten;\n const getBackgroundColor = theme.palette.mode === 'light' ? theme.lighten : theme.darken;\n return {\n ...theme.typography.body2,\n backgroundColor: 'transparent',\n display: 'flex',\n padding: '6px 16px',\n variants: [...Object.entries(theme.palette).filter(createSimplePaletteValueFilter(['light'])).map(([color]) => ({\n props: {\n colorSeverity: color,\n variant: 'standard'\n },\n style: {\n color: theme.vars ? theme.vars.palette.Alert[`${color}Color`] : getColor(theme.palette[color].light, 0.6),\n backgroundColor: theme.vars ? theme.vars.palette.Alert[`${color}StandardBg`] : getBackgroundColor(theme.palette[color].light, 0.9),\n [`& .${alertClasses.icon}`]: theme.vars ? {\n color: theme.vars.palette.Alert[`${color}IconColor`]\n } : {\n color: theme.palette[color].main\n }\n }\n })), ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter(['light'])).map(([color]) => ({\n props: {\n colorSeverity: color,\n variant: 'outlined'\n },\n style: {\n color: theme.vars ? theme.vars.palette.Alert[`${color}Color`] : getColor(theme.palette[color].light, 0.6),\n border: `1px solid ${(theme.vars || theme).palette[color].light}`,\n [`& .${alertClasses.icon}`]: theme.vars ? {\n color: theme.vars.palette.Alert[`${color}IconColor`]\n } : {\n color: theme.palette[color].main\n }\n }\n })), ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter(['dark'])).map(([color]) => ({\n props: {\n colorSeverity: color,\n variant: 'filled'\n },\n style: {\n fontWeight: theme.typography.fontWeightMedium,\n ...(theme.vars ? {\n color: theme.vars.palette.Alert[`${color}FilledColor`],\n backgroundColor: theme.vars.palette.Alert[`${color}FilledBg`]\n } : {\n backgroundColor: theme.palette.mode === 'dark' ? theme.palette[color].dark : theme.palette[color].main,\n color: theme.palette.getContrastText(theme.palette[color].main)\n })\n }\n }))]\n };\n}));\nconst AlertIcon = styled('div', {\n name: 'MuiAlert',\n slot: 'Icon'\n})({\n marginRight: 12,\n padding: '7px 0',\n display: 'flex',\n fontSize: 22,\n opacity: 0.9\n});\nconst AlertMessage = styled('div', {\n name: 'MuiAlert',\n slot: 'Message'\n})({\n padding: '8px 0',\n minWidth: 0,\n overflow: 'auto'\n});\nconst AlertAction = styled('div', {\n name: 'MuiAlert',\n slot: 'Action'\n})({\n display: 'flex',\n alignItems: 'flex-start',\n padding: '4px 0 0 16px',\n marginLeft: 'auto',\n marginRight: -8\n});\nconst defaultIconMapping = {\n success: /*#__PURE__*/_jsx(SuccessOutlinedIcon, {\n fontSize: \"inherit\"\n }),\n warning: /*#__PURE__*/_jsx(ReportProblemOutlinedIcon, {\n fontSize: \"inherit\"\n }),\n error: /*#__PURE__*/_jsx(ErrorOutlineIcon, {\n fontSize: \"inherit\"\n }),\n info: /*#__PURE__*/_jsx(InfoOutlinedIcon, {\n fontSize: \"inherit\"\n })\n};\nconst Alert = /*#__PURE__*/React.forwardRef(function Alert(inProps, ref) {\n const props = useDefaultProps({\n props: inProps,\n name: 'MuiAlert'\n });\n const {\n action,\n children,\n className,\n closeText = 'Close',\n color,\n components = {},\n componentsProps = {},\n icon,\n iconMapping = defaultIconMapping,\n onClose,\n role = 'alert',\n severity = 'success',\n slotProps = {},\n slots = {},\n variant = 'standard',\n ...other\n } = props;\n const ownerState = {\n ...props,\n color,\n severity,\n variant,\n colorSeverity: color || severity\n };\n const classes = useUtilityClasses(ownerState);\n const externalForwardedProps = {\n slots: {\n closeButton: components.CloseButton,\n closeIcon: components.CloseIcon,\n ...slots\n },\n slotProps: {\n ...componentsProps,\n ...slotProps\n }\n };\n const [RootSlot, rootSlotProps] = useSlot('root', {\n ref,\n shouldForwardComponentProp: true,\n className: clsx(classes.root, className),\n elementType: AlertRoot,\n externalForwardedProps: {\n ...externalForwardedProps,\n ...other\n },\n ownerState,\n additionalProps: {\n role,\n elevation: 0\n }\n });\n const [IconSlot, iconSlotProps] = useSlot('icon', {\n className: classes.icon,\n elementType: AlertIcon,\n externalForwardedProps,\n ownerState\n });\n const [MessageSlot, messageSlotProps] = useSlot('message', {\n className: classes.message,\n elementType: AlertMessage,\n externalForwardedProps,\n ownerState\n });\n const [ActionSlot, actionSlotProps] = useSlot('action', {\n className: classes.action,\n elementType: AlertAction,\n externalForwardedProps,\n ownerState\n });\n const [CloseButtonSlot, closeButtonProps] = useSlot('closeButton', {\n elementType: IconButton,\n externalForwardedProps,\n ownerState\n });\n const [CloseIconSlot, closeIconProps] = useSlot('closeIcon', {\n elementType: CloseIcon,\n externalForwardedProps,\n ownerState\n });\n return /*#__PURE__*/_jsxs(RootSlot, {\n ...rootSlotProps,\n children: [icon !== false ? /*#__PURE__*/_jsx(IconSlot, {\n ...iconSlotProps,\n children: icon || iconMapping[severity] || defaultIconMapping[severity]\n }) : null, /*#__PURE__*/_jsx(MessageSlot, {\n ...messageSlotProps,\n children: children\n }), action != null ? /*#__PURE__*/_jsx(ActionSlot, {\n ...actionSlotProps,\n children: action\n }) : null, action == null && onClose ? /*#__PURE__*/_jsx(ActionSlot, {\n ...actionSlotProps,\n children: /*#__PURE__*/_jsx(CloseButtonSlot, {\n size: \"small\",\n \"aria-label\": closeText,\n title: closeText,\n color: \"inherit\",\n onClick: onClose,\n ...closeButtonProps,\n children: /*#__PURE__*/_jsx(CloseIconSlot, {\n fontSize: \"small\",\n ...closeIconProps\n })\n })\n }) : null]\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Alert.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * The action to display. It renders after the message, at the end of the alert.\n */\n action: PropTypes.node,\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * Override the default label for the *close popup* icon button.\n *\n * For localization purposes, you can use the provided [translations](https://mui.com/material-ui/guides/localization/).\n * @default 'Close'\n */\n closeText: PropTypes.string,\n /**\n * The color of the component. Unless provided, the value is taken from the `severity` prop.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * The components used for each slot inside.\n *\n * @deprecated use the `slots` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.\n *\n * @default {}\n */\n components: PropTypes.shape({\n CloseButton: PropTypes.elementType,\n CloseIcon: PropTypes.elementType\n }),\n /**\n * The extra props for the slot components.\n * You can override the existing props or add new ones.\n *\n * @deprecated use the `slotProps` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.\n *\n * @default {}\n */\n componentsProps: PropTypes.shape({\n closeButton: PropTypes.object,\n closeIcon: PropTypes.object\n }),\n /**\n * Override the icon displayed before the children.\n * Unless provided, the icon is mapped to the value of the `severity` prop.\n * Set to `false` to remove the `icon`.\n */\n icon: PropTypes.node,\n /**\n * The component maps the `severity` prop to a range of different icons,\n * for instance success to `<SuccessOutlined>`.\n * If you wish to change this mapping, you can provide your own.\n * Alternatively, you can use the `icon` prop to override the icon displayed.\n */\n iconMapping: PropTypes.shape({\n error: PropTypes.node,\n info: PropTypes.node,\n success: PropTypes.node,\n warning: PropTypes.node\n }),\n /**\n * Callback fired when the component requests to be closed.\n * When provided and no `action` prop is set, a close icon button is displayed that triggers the callback when clicked.\n * @param {React.SyntheticEvent} event The event source of the callback.\n */\n onClose: PropTypes.func,\n /**\n * The ARIA role attribute of the element.\n * @default 'alert'\n */\n role: PropTypes.string,\n /**\n * The severity of the alert. This defines the color and icon used.\n * @default 'success'\n */\n severity: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['error', 'info', 'success', 'warning']), PropTypes.string]),\n /**\n * The props used for each slot inside.\n * @default {}\n */\n slotProps: PropTypes.shape({\n action: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n closeButton: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n closeIcon: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n icon: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n message: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n root: PropTypes.oneOfType([PropTypes.func, PropTypes.object])\n }),\n /**\n * The components used for each slot inside.\n * @default {}\n */\n slots: PropTypes.shape({\n action: PropTypes.elementType,\n closeButton: PropTypes.elementType,\n closeIcon: PropTypes.elementType,\n icon: PropTypes.elementType,\n message: PropTypes.elementType,\n root: PropTypes.elementType\n }),\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * The variant to use.\n * @default 'standard'\n */\n variant: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['filled', 'outlined', 'standard']), PropTypes.string])\n} : void 0;\nexport default Alert;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nimport generateUtilityClass from '@mui/utils/generateUtilityClass';\nexport function getTypographyUtilityClass(slot) {\n return generateUtilityClass('MuiTypography', slot);\n}\nconst typographyClasses = generateUtilityClasses('MuiTypography', ['root', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'subtitle1', 'subtitle2', 'body1', 'body2', 'inherit', 'button', 'caption', 'overline', 'alignLeft', 'alignRight', 'alignCenter', 'alignJustify', 'noWrap', 'gutterBottom', 'paragraph']);\nexport default typographyClasses;","'use client';\n\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport clsx from 'clsx';\nimport composeClasses from '@mui/utils/composeClasses';\nimport { styled, internal_createExtendSxProp } from \"../zero-styled/index.js\";\nimport memoTheme from \"../utils/memoTheme.js\";\nimport { useDefaultProps } from \"../DefaultPropsProvider/index.js\";\nimport capitalize from \"../utils/capitalize.js\";\nimport createSimplePaletteValueFilter from \"../utils/createSimplePaletteValueFilter.js\";\nimport { getTypographyUtilityClass } from \"./typographyClasses.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst v6Colors = {\n primary: true,\n secondary: true,\n error: true,\n info: true,\n success: true,\n warning: true,\n textPrimary: true,\n textSecondary: true,\n textDisabled: true\n};\nconst extendSxProp = internal_createExtendSxProp();\nconst useUtilityClasses = ownerState => {\n const {\n align,\n gutterBottom,\n noWrap,\n paragraph,\n variant,\n classes\n } = ownerState;\n const slots = {\n root: ['root', variant, ownerState.align !== 'inherit' && `align${capitalize(align)}`, gutterBottom && 'gutterBottom', noWrap && 'noWrap', paragraph && 'paragraph']\n };\n return composeClasses(slots, getTypographyUtilityClass, classes);\n};\nexport const TypographyRoot = styled('span', {\n name: 'MuiTypography',\n slot: 'Root',\n overridesResolver: (props, styles) => {\n const {\n ownerState\n } = props;\n return [styles.root, ownerState.variant && styles[ownerState.variant], ownerState.align !== 'inherit' && styles[`align${capitalize(ownerState.align)}`], ownerState.noWrap && styles.noWrap, ownerState.gutterBottom && styles.gutterBottom, ownerState.paragraph && styles.paragraph];\n }\n})(memoTheme(({\n theme\n}) => ({\n margin: 0,\n variants: [{\n props: {\n variant: 'inherit'\n },\n style: {\n // Some elements, like <button> on Chrome have default font that doesn't inherit, reset this.\n font: 'inherit',\n lineHeight: 'inherit',\n letterSpacing: 'inherit'\n }\n }, ...Object.entries(theme.typography).filter(([variant, value]) => variant !== 'inherit' && value && typeof value === 'object').map(([variant, value]) => ({\n props: {\n variant\n },\n style: value\n })), ...Object.entries(theme.palette).filter(createSimplePaletteValueFilter()).map(([color]) => ({\n props: {\n color\n },\n style: {\n color: (theme.vars || theme).palette[color].main\n }\n })), ...Object.entries(theme.palette?.text || {}).filter(([, value]) => typeof value === 'string').map(([color]) => ({\n props: {\n color: `text${capitalize(color)}`\n },\n style: {\n color: (theme.vars || theme).palette.text[color]\n }\n })), {\n props: ({\n ownerState\n }) => ownerState.align !== 'inherit',\n style: {\n textAlign: 'var(--Typography-textAlign)'\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.noWrap,\n style: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap'\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.gutterBottom,\n style: {\n marginBottom: '0.35em'\n }\n }, {\n props: ({\n ownerState\n }) => ownerState.paragraph,\n style: {\n marginBottom: 16\n }\n }]\n})));\nconst defaultVariantMapping = {\n h1: 'h1',\n h2: 'h2',\n h3: 'h3',\n h4: 'h4',\n h5: 'h5',\n h6: 'h6',\n subtitle1: 'h6',\n subtitle2: 'h6',\n body1: 'p',\n body2: 'p',\n inherit: 'p'\n};\nconst Typography = /*#__PURE__*/React.forwardRef(function Typography(inProps, ref) {\n const {\n color,\n ...themeProps\n } = useDefaultProps({\n props: inProps,\n name: 'MuiTypography'\n });\n const isSxColor = !v6Colors[color];\n // TODO: Remove `extendSxProp` in v7\n const props = extendSxProp({\n ...themeProps,\n ...(isSxColor && {\n color\n })\n });\n const {\n align = 'inherit',\n className,\n component,\n gutterBottom = false,\n noWrap = false,\n paragraph = false,\n variant = 'body1',\n variantMapping = defaultVariantMapping,\n ...other\n } = props;\n const ownerState = {\n ...props,\n align,\n color,\n className,\n component,\n gutterBottom,\n noWrap,\n paragraph,\n variant,\n variantMapping\n };\n const Component = component || (paragraph ? 'p' : variantMapping[variant] || defaultVariantMapping[variant]) || 'span';\n const classes = useUtilityClasses(ownerState);\n return /*#__PURE__*/_jsx(TypographyRoot, {\n as: Component,\n ref: ref,\n className: clsx(classes.root, className),\n ...other,\n ownerState: ownerState,\n style: {\n ...(align !== 'inherit' && {\n '--Typography-textAlign': align\n }),\n ...other.style\n }\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Typography.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * Set the text-align on the component.\n * @default 'inherit'\n */\n align: PropTypes.oneOf(['center', 'inherit', 'justify', 'left', 'right']),\n /**\n * The content of the component.\n */\n children: PropTypes.node,\n /**\n * Override or extend the styles applied to the component.\n */\n classes: PropTypes.object,\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * The color of the component.\n * It supports both default and custom theme colors, which can be added as shown in the\n * [palette customization guide](https://mui.com/material-ui/customization/palette/#custom-colors).\n */\n color: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['primary', 'secondary', 'success', 'error', 'info', 'warning', 'textPrimary', 'textSecondary', 'textDisabled']), PropTypes.string]),\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * If `true`, the text will have a bottom margin.\n * @default false\n */\n gutterBottom: PropTypes.bool,\n /**\n * If `true`, the text will not wrap, but instead will truncate with a text overflow ellipsis.\n *\n * Note that text overflow can only happen with block or inline-block level elements\n * (the element needs to have a width in order to overflow).\n * @default false\n */\n noWrap: PropTypes.bool,\n /**\n * If `true`, the element will be a paragraph element.\n * @default false\n * @deprecated Use the `component` prop instead. This prop will be removed in a future major release. See [Migrating from deprecated APIs](https://mui.com/material-ui/migration/migrating-from-deprecated-apis/) for more details.\n */\n paragraph: PropTypes.bool,\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object]),\n /**\n * Applies the theme typography styles.\n * @default 'body1'\n */\n variant: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([PropTypes.oneOf(['body1', 'body2', 'button', 'caption', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'inherit', 'overline', 'subtitle1', 'subtitle2']), PropTypes.string]),\n /**\n * The component maps the variant prop to a range of different HTML element types.\n * For instance, subtitle1 to `<h6>`.\n * If you wish to change that mapping, you can provide your own.\n * Alternatively, you can use the `component` prop.\n * @default {\n * h1: 'h1',\n * h2: 'h2',\n * h3: 'h3',\n * h4: 'h4',\n * h5: 'h5',\n * h6: 'h6',\n * subtitle1: 'h6',\n * subtitle2: 'h6',\n * body1: 'p',\n * body2: 'p',\n * inherit: 'p',\n * }\n */\n variantMapping: PropTypes /* @typescript-to-proptypes-ignore */.object\n} : void 0;\nexport default Typography;","import generateUtilityClasses from '@mui/utils/generateUtilityClasses';\nconst boxClasses = generateUtilityClasses('MuiBox', ['root']);\nexport default boxClasses;","'use client';\n\nimport { createBox } from '@mui/system';\nimport PropTypes from 'prop-types';\nimport { unstable_ClassNameGenerator as ClassNameGenerator } from \"../className/index.js\";\nimport { createTheme } from \"../styles/index.js\";\nimport THEME_ID from \"../styles/identifier.js\";\nimport boxClasses from \"./boxClasses.js\";\nconst defaultTheme = createTheme();\nconst Box = createBox({\n themeId: THEME_ID,\n defaultTheme,\n defaultClassName: boxClasses.root,\n generateClassName: ClassNameGenerator.generate\n});\nprocess.env.NODE_ENV !== \"production\" ? Box.propTypes /* remove-proptypes */ = {\n // ┌────────────────────────────── Warning ──────────────────────────────┐\n // │ These PropTypes are generated from the TypeScript type definitions. │\n // │ To update them, edit the d.ts file and run `pnpm proptypes`. │\n // └─────────────────────────────────────────────────────────────────────┘\n /**\n * @ignore\n */\n children: PropTypes.node,\n /**\n * The component used for the root node.\n * Either a string to use a HTML element or a component.\n */\n component: PropTypes.elementType,\n /**\n * The system prop that allows defining system overrides as well as additional CSS styles.\n */\n sx: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.object, PropTypes.bool])), PropTypes.func, PropTypes.object])\n} : void 0;\nexport default Box;","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon([/*#__PURE__*/_jsx(\"path\", {\n d: \"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2M12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8\"\n}, \"0\"), /*#__PURE__*/_jsx(\"path\", {\n d: \"M12.5 7H11v6l5.25 3.15.75-1.23-4.5-2.67z\"\n}, \"1\")], 'AccessTime');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"m12 4-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z\"\n}), 'ArrowForward');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M20 3h-1V1h-2v2H7V1H5v2H4c-1.1 0-2 .9-2 2v16c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2m0 18H4V8h16z\"\n}), 'CalendarToday');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2m-2 15-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8z\"\n}), 'CheckCircle');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7m0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5\"\n}), 'LocationOn');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon([/*#__PURE__*/_jsx(\"path\", {\n d: \"M11.99 2C6.47 2 2 6.48 2 12s4.47 10 9.99 10C17.52 22 22 17.52 22 12S17.52 2 11.99 2M12 20c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8\"\n}, \"0\"), /*#__PURE__*/_jsx(\"path\", {\n d: \"M12.5 7H11v6l5.25 3.15.75-1.23-4.5-2.67z\"\n}, \"1\")], 'Schedule');","\"use client\";\n\nimport createSvgIcon from \"./utils/createSvgIcon.js\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport default createSvgIcon(/*#__PURE__*/_jsx(\"path\", {\n d: \"M17 10.5V7c0-.55-.45-1-1-1H4c-.55 0-1 .45-1 1v10c0 .55.45 1 1 1h12c.55 0 1-.45 1-1v-3.5l4 4v-11zM14 13h-3v3H9v-3H6v-2h3V8h2v3h3z\"\n}), 'VideoCall');","import React from \"react\";\r\nimport { Box, Typography, Paper, CircularProgress, Alert } from \"@mui/material\";\r\nimport {\r\n AccessTime as AccessTimeIcon,\r\n CalendarToday as CalendarTodayIcon,\r\n LocationOn as LocationOnIcon,\r\n VideoCall as VideoCallIcon,\r\n} from \"@mui/icons-material\";\r\n/**\r\n * @description Formats a date string to a readable format\r\n * @param {string} dateString - ISO date string\r\n * @returns {string} Formatted date string\r\n */\r\nexport const formatDate = (dateString: string): string => {\r\n try {\r\n const date = new Date(dateString);\r\n return date.toLocaleString(\"en-US\", {\r\n year: \"numeric\",\r\n month: \"short\",\r\n day: \"numeric\",\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n });\r\n } catch (error) {\r\n return dateString;\r\n }\r\n};\r\n\r\n/**\r\n * @description Formats date and time for meeting display\r\n * @param {string} startTime - ISO start time string\r\n * @param {string} endTime - ISO end time string\r\n * @param {string} timezone - Timezone string\r\n * @returns {string} Formatted date/time string\r\n */\r\nexport const formatMeetingTime = (\r\n startTime: string,\r\n endTime: string,\r\n timezone?: string\r\n): string => {\r\n try {\r\n const start = new Date(startTime);\r\n const end = new Date(endTime);\r\n const dateStr = start.toLocaleDateString(\"en-US\", {\r\n weekday: \"long\",\r\n year: \"numeric\",\r\n month: \"long\",\r\n day: \"numeric\",\r\n });\r\n const startStr = start.toLocaleTimeString(\"en-US\", {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n });\r\n const endStr = end.toLocaleTimeString(\"en-US\", {\r\n hour: \"2-digit\",\r\n minute: \"2-digit\",\r\n });\r\n return `${dateStr} | ${startStr} - ${endStr}${\r\n timezone ? ` (${timezone})` : \"\"\r\n }`;\r\n } catch (error) {\r\n return `${formatDate(startTime)} - ${formatDate(endTime)}`;\r\n }\r\n};\r\n\r\nexport interface CalendarBooking {\r\n cal_booking_id: string;\r\n title: string;\r\n attendee_name?: string;\r\n attendee_email?: string;\r\n start_time: string;\r\n end_time: string;\r\n timezone?: string;\r\n meeting_url?: string;\r\n}\r\n\r\nexport interface CalendarBookingsProps {\r\n email?: string;\r\n isLoading: boolean;\r\n error: unknown;\r\n data:\r\n | {\r\n success?: boolean;\r\n urban_data?: CalendarBooking[];\r\n errors?: string;\r\n }\r\n | undefined;\r\n}\r\n\r\nexport const CalendarBookings: React.FC<CalendarBookingsProps> = ({\r\n email,\r\n isLoading,\r\n error,\r\n data,\r\n}) => {\r\n return (\r\n <Paper sx={{ p: 3, mb: 3 }}>\r\n <Typography variant=\"h6\" gutterBottom sx={{ mb: 2 }}>\r\n Calendar Bookings\r\n </Typography>\r\n {!email && (\r\n <Alert severity=\"info\" sx={{ mb: 2 }}>\r\n Please log in to view your calendar bookings.\r\n </Alert>\r\n )}\r\n {isLoading && email && (\r\n <Box sx={{ display: \"flex\", justifyContent: \"center\", py: 4 }}>\r\n <CircularProgress />\r\n </Box>\r\n )}\r\n {!!error && (\r\n <Alert severity=\"error\" sx={{ mb: 2 }}>\r\n Failed to load bookings. Please try again later.\r\n </Alert>\r\n )}\r\n {data && data.success && data.urban_data && (\r\n <Box sx={{ display: \"flex\", flexDirection: \"column\", gap: 2 }}>\r\n {data.urban_data.length === 0 ? (\r\n <Typography variant=\"body2\" color=\"text.secondary\">\r\n No bookings found.\r\n </Typography>\r\n ) : (\r\n data.urban_data.map((booking: any, index: number) => (\r\n <Box key={booking.cal_booking_id || index}>\r\n <Paper\r\n elevation={1}\r\n sx={{\r\n position: \"relative\",\r\n bgcolor: \"#ffffff\",\r\n borderRadius: 2,\r\n overflow: \"hidden\",\r\n borderLeft: \"4px solid #d32f2f\",\r\n mb: index < data.urban_data!.length - 1 ? 2 : 0,\r\n }}\r\n >\r\n <Box sx={{ p: 3 }}>\r\n {/* Title */}\r\n <Typography\r\n variant=\"h5\"\r\n sx={{\r\n fontWeight: 700,\r\n mb: 3,\r\n color: \"#000\",\r\n fontSize: \"1.5rem\",\r\n }}\r\n >\r\n {booking.title || \"Untitled Meeting\"}\r\n </Typography>\r\n\r\n {/* What Section */}\r\n <Box sx={{ mb: 2.5 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ fontWeight: 700, mb: 1, color: \"#000\" }}\r\n >\r\n What\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: 1.5,\r\n }}\r\n >\r\n <AccessTimeIcon\r\n sx={{ color: \"#666\", fontSize: 20, mt: 0.5 }}\r\n />\r\n <Typography variant=\"body2\" sx={{ color: \"#000\" }}>\r\n {booking.title || \"Untitled Meeting\"}\r\n {booking.attendee_name &&\r\n ` between Open Org and ${booking.attendee_name}`}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n\r\n {/* When Section */}\r\n <Box sx={{ mb: 2.5 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ fontWeight: 700, mb: 1, color: \"#000\" }}\r\n >\r\n When\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: 1.5,\r\n }}\r\n >\r\n <CalendarTodayIcon\r\n sx={{ color: \"#666\", fontSize: 20, mt: 0.5 }}\r\n />\r\n <Typography variant=\"body2\" sx={{ color: \"#000\" }}>\r\n {formatMeetingTime(\r\n booking.start_time,\r\n booking.end_time,\r\n booking.timezone\r\n )}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n\r\n {/* Who Section */}\r\n <Box sx={{ mb: 2.5 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ fontWeight: 700, mb: 1, color: \"#000\" }}\r\n >\r\n Who\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: 1.5,\r\n }}\r\n >\r\n <LocationOnIcon\r\n sx={{ color: \"#666\", fontSize: 20, mt: 0.5 }}\r\n />\r\n <Box sx={{ flex: 1 }}>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ color: \"#000\", mb: 0.5 }}\r\n >\r\n Open Org - Organizer{\" \"}\r\n <a\r\n href={`mailto:${email || \"\"}`}\r\n style={{\r\n color: \"#000\",\r\n textDecoration: \"underline\",\r\n }}\r\n >\r\n {email || \"N/A\"}\r\n </a>\r\n </Typography>\r\n {booking.attendee_name && (\r\n <Typography variant=\"body2\" sx={{ color: \"#000\" }}>\r\n {booking.attendee_name}\r\n {booking.attendee_email && (\r\n <>\r\n {\" \"}\r\n <span style={{ color: \"#999\" }}>\r\n _ Guest\r\n </span>{\" \"}\r\n <a\r\n href={`mailto:${booking.attendee_email}`}\r\n style={{\r\n color: \"#000\",\r\n textDecoration: \"underline\",\r\n }}\r\n >\r\n {booking.attendee_email}\r\n </a>\r\n </>\r\n )}\r\n </Typography>\r\n )}\r\n </Box>\r\n </Box>\r\n </Box>\r\n\r\n {/* Where Section */}\r\n {booking.meeting_url && (\r\n <Box>\r\n <Typography\r\n variant=\"body2\"\r\n sx={{ fontWeight: 700, mb: 1, color: \"#000\" }}\r\n >\r\n Where\r\n </Typography>\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: 1.5,\r\n }}\r\n >\r\n <VideoCallIcon\r\n sx={{ color: \"#666\", fontSize: 20, mt: 0.5 }}\r\n />\r\n <Typography variant=\"body2\" sx={{ color: \"#000\" }}>\r\n Google Meet:{\" \"}\r\n <a\r\n href={booking.meeting_url}\r\n target=\"_blank\"\r\n rel=\"noopener noreferrer\"\r\n style={{\r\n color: \"#000\",\r\n textDecoration: \"underline\",\r\n }}\r\n >\r\n {booking.meeting_url}\r\n </a>\r\n </Typography>\r\n </Box>\r\n </Box>\r\n )}\r\n </Box>\r\n </Paper>\r\n </Box>\r\n ))\r\n )}\r\n </Box>\r\n )}\r\n {data && !data.success && (\r\n <Alert severity=\"warning\" sx={{ mb: 2 }}>\r\n {data.errors || \"Failed to load bookings.\"}\r\n </Alert>\r\n )}\r\n </Paper>\r\n );\r\n};\r\n","import React from \"react\";\r\nimport { Box, Typography, Paper } from \"@mui/material\";\r\nimport {\r\n CheckCircle as CheckCircleIcon,\r\n Schedule as ScheduleIcon,\r\n CalendarToday as CalendarTodayIcon,\r\n ArrowForward as ArrowForwardIcon,\r\n} from \"@mui/icons-material\";\r\n\r\n/**\r\n * @description Verification step status type\r\n */\r\nexport type VerificationStatus = \"completed\" | \"in-progress\" | \"pending\";\r\n\r\n/**\r\n * @description Verification step interface\r\n */\r\nexport interface VerificationStep {\r\n id: string;\r\n title: string;\r\n subtitle: string;\r\n status: VerificationStatus;\r\n date?: string;\r\n}\r\n\r\n/**\r\n * @description Verification progress component showing application status\r\n * @param {Object} props - Component props\r\n * @param {string} [props.userName] - Name of the user to display in the application step (optional)\r\n * @param {VerificationStep[]} [props.steps] - Custom verification steps (optional)\r\n * @param {Object} [props.nextStep] - Next step information (optional)\r\n * @returns {JSX.Element} Verification progress section\r\n */\r\nexport interface VerificationProgressProps {\r\n userName?: string;\r\n steps?: VerificationStep[];\r\n nextStep?: {\r\n title: string;\r\n description: string;\r\n date?: string;\r\n link?: string;\r\n };\r\n}\r\n\r\nexport const VerificationProgress: React.FC<VerificationProgressProps> = ({\r\n userName,\r\n steps,\r\n nextStep,\r\n}) => {\r\n // Default verification steps matching Verification module structure\r\n const defaultSteps: VerificationStep[] = [\r\n {\r\n id: \"application\",\r\n title: \"Application\",\r\n subtitle: userName ? `Submitted for ${userName}` : \"Submitted\",\r\n status: \"completed\",\r\n date: \"Oct 24\",\r\n },\r\n {\r\n id: \"intro-call\",\r\n title: \"Intro Call\",\r\n subtitle: \"Scheduled\",\r\n status: \"completed\",\r\n date: \"Oct 26\",\r\n },\r\n {\r\n id: \"review\",\r\n title: \"Review\",\r\n subtitle: \"In Progress\",\r\n status: \"in-progress\",\r\n },\r\n {\r\n id: \"approved\",\r\n title: \"Approved\",\r\n subtitle: \"Unlock Grants\",\r\n status: \"pending\",\r\n },\r\n ];\r\n\r\n const verificationSteps = steps || defaultSteps;\r\n\r\n // Default next step matching Verification module\r\n const defaultNextStep = {\r\n title: \"Next Step: Intro Call with Umar A.\",\r\n description: \"Your 15-min onboarding call is confirmed for\",\r\n date: \"tomorrow at 10:00 AM EST\",\r\n link: \"#\",\r\n };\r\n\r\n const nextStepData = nextStep || defaultNextStep;\r\n\r\n return (\r\n <Paper\r\n elevation={1}\r\n sx={{\r\n p: 3,\r\n mb: 3,\r\n bgcolor: \"#ffffff\",\r\n borderRadius: 2,\r\n }}\r\n >\r\n <Typography\r\n variant=\"h6\"\r\n sx={{\r\n fontWeight: 700,\r\n mb: 3,\r\n color: \"#000\",\r\n fontSize: \"1.125rem\",\r\n }}\r\n >\r\n Verification Progress\r\n </Typography>\r\n\r\n {/* Progress Steps */}\r\n <Box\r\n sx={{\r\n position: \"relative\",\r\n mb: 3,\r\n }}\r\n >\r\n {/* Progress Line */}\r\n <Box\r\n sx={{\r\n position: \"absolute\",\r\n top: \"16px\",\r\n left: 0,\r\n right: 0,\r\n height: \"2px\",\r\n bgcolor: \"#e2e8f0\",\r\n zIndex: 0,\r\n display: { xs: \"none\", md: \"block\" },\r\n }}\r\n />\r\n <Box\r\n sx={{\r\n position: \"absolute\",\r\n left: \"16px\",\r\n top: 0,\r\n bottom: 0,\r\n width: \"2px\",\r\n bgcolor: \"#e2e8f0\",\r\n zIndex: 0,\r\n display: { xs: \"block\", md: \"none\" },\r\n }}\r\n />\r\n\r\n {/* Steps */}\r\n <Box\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: { xs: \"column\", md: \"row\" },\r\n justifyContent: \"space-between\",\r\n gap: { xs: 3, md: 0 },\r\n position: \"relative\",\r\n zIndex: 1,\r\n }}\r\n >\r\n {verificationSteps.map((step) => {\r\n const isCompleted = step.status === \"completed\";\r\n const isInProgress = step.status === \"in-progress\";\r\n const isPending = step.status === \"pending\";\r\n\r\n return (\r\n <Box\r\n key={step.id}\r\n sx={{\r\n display: \"flex\",\r\n flexDirection: { xs: \"row\", md: \"column\" },\r\n alignItems: { xs: \"center\", md: \"center\" },\r\n gap: { xs: 2, md: 1 },\r\n opacity: isPending ? 0.5 : 1,\r\n }}\r\n >\r\n {/* Step Icon */}\r\n <Box\r\n sx={{\r\n width: 32,\r\n height: 32,\r\n borderRadius: \"50%\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n border: \"4px solid\",\r\n borderColor: isInProgress ? \"#6366f1\" : \"#ffffff\",\r\n bgcolor: isCompleted\r\n ? \"#10b981\"\r\n : isInProgress\r\n ? \"#6366f1\"\r\n : \"#e2e8f0\",\r\n color: isPending ? \"#94a3b8\" : \"#ffffff\",\r\n boxShadow: \"0 1px 3px rgba(0,0,0,0.1)\",\r\n animation: isInProgress\r\n ? \"pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite\"\r\n : \"none\",\r\n \"@keyframes pulse\": {\r\n \"0%, 100%\": {\r\n opacity: 1,\r\n },\r\n \"50%\": {\r\n opacity: 0.7,\r\n },\r\n },\r\n }}\r\n >\r\n {isCompleted ? (\r\n <CheckCircleIcon sx={{ fontSize: 16 }} />\r\n ) : isInProgress ? (\r\n <ScheduleIcon sx={{ fontSize: 16 }} />\r\n ) : (\r\n <Box\r\n sx={{\r\n width: 8,\r\n height: 8,\r\n borderRadius: \"50%\",\r\n bgcolor: \"#94a3b8\",\r\n }}\r\n />\r\n )}\r\n </Box>\r\n\r\n {/* Step Info */}\r\n <Box\r\n sx={{\r\n textAlign: { xs: \"left\", md: \"center\" },\r\n }}\r\n >\r\n <Typography\r\n sx={{\r\n fontWeight: 700,\r\n fontSize: \"0.875rem\",\r\n color: isInProgress ? \"#6366f1\" : \"#000\",\r\n mb: 0.5,\r\n }}\r\n >\r\n {step.title}\r\n </Typography>\r\n <Typography\r\n sx={{\r\n fontSize: \"0.75rem\",\r\n color: isInProgress ? \"#6366f1\" : \"#64748b\",\r\n fontWeight: isInProgress ? 600 : 400,\r\n }}\r\n >\r\n {step.subtitle}\r\n {step.date && ` ${step.date}`}\r\n </Typography>\r\n </Box>\r\n </Box>\r\n );\r\n })}\r\n </Box>\r\n </Box>\r\n\r\n {/* Next Step Card */}\r\n <Box\r\n sx={{\r\n mt: 3,\r\n p: 2,\r\n bgcolor: \"#eef2ff\",\r\n borderRadius: 2,\r\n border: \"1px solid #c7d2fe\",\r\n display: \"flex\",\r\n alignItems: \"flex-start\",\r\n gap: 2,\r\n }}\r\n >\r\n <Box\r\n sx={{\r\n p: 1,\r\n bgcolor: \"#c7d2fe\",\r\n borderRadius: 1,\r\n color: \"#6366f1\",\r\n display: \"flex\",\r\n alignItems: \"center\",\r\n justifyContent: \"center\",\r\n }}\r\n >\r\n <CalendarTodayIcon sx={{ fontSize: 20 }} />\r\n </Box>\r\n <Box sx={{ flex: 1 }}>\r\n <Typography\r\n sx={{\r\n fontWeight: 700,\r\n fontSize: \"0.875rem\",\r\n color: \"#312e81\",\r\n mb: 0.5,\r\n }}\r\n >\r\n {nextStepData.title}\r\n </Typography>\r\n <Typography\r\n sx={{\r\n fontSize: \"0.875rem\",\r\n color: \"#4338ca\",\r\n mb: 1,\r\n }}\r\n >\r\n {nextStepData.description}{\" \"}\r\n {nextStepData.date && (\r\n <Box component=\"span\" sx={{ fontWeight: 600 }}>\r\n {nextStepData.date}\r\n </Box>\r\n )}{\" \"}\r\n via Google Meet.\r\n </Typography>\r\n {nextStepData.link && (\r\n <Box\r\n component=\"a\"\r\n href={nextStepData.link}\r\n sx={{\r\n display: \"inline-flex\",\r\n alignItems: \"center\",\r\n gap: 0.5,\r\n color: \"#6366f1\",\r\n fontWeight: 700,\r\n fontSize: \"0.75rem\",\r\n textDecoration: \"none\",\r\n \"&:hover\": {\r\n textDecoration: \"underline\",\r\n },\r\n }}\r\n >\r\n View Calendar Event <ArrowForwardIcon sx={{ fontSize: 12 }} />\r\n </Box>\r\n )}\r\n </Box>\r\n </Box>\r\n </Paper>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface ButtonGroupProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const ButtonGroup: React.FC<ButtonGroupProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n inline-flex \r\n ${componentProps.orientation === 'vertical' ? 'flex-col' : 'flex-row'}\r\n ${designSystem === 'MUI' ? 'rounded shadow-sm' : ''}\r\n ${designSystem === 'Apple' ? 'bg-gray-100 dark:bg-gray-800 p-1 rounded-lg' : ''}\r\n ${designSystem === 'Custom' ? 'gap-1' : ''}\r\n `}\r\n >\r\n {['One', 'Two', 'Three'].map((label, idx) => (\r\n <button\r\n key={label}\r\n className={`\r\n px-4 py-2 text-sm font-medium transition-all relative\r\n ${componentProps.orientation === 'vertical' ? 'w-full' : ''}\r\n \r\n ${designSystem === 'MUI' ? `\r\n bg-white dark:bg-gray-900 border border-gray-300 dark:border-gray-700 text-gray-700 dark:text-gray-200 hover:bg-gray-50 dark:hover:bg-gray-800\r\n ${componentProps.orientation === 'horizontal' ? (idx === 0 ? 'rounded-l' : idx === 2 ? 'rounded-r' : 'border-l-0') : (idx === 0 ? 'rounded-t' : idx === 2 ? 'rounded-b' : 'border-t-0')}\r\n focus:z-10 focus:ring-1 focus:${getColorShade(globalConfig, 'ring', 500)} focus:${getColorShade(globalConfig, 'text', 600)}\r\n ` : ''}\r\n\r\n ${designSystem === 'Apple' ? `\r\n rounded-md\r\n ${idx === 1 ? 'bg-white dark:bg-gray-700 text-black dark:text-white shadow-sm' : 'text-gray-500 dark:text-gray-400 hover:text-gray-700'}\r\n ` : ''}\r\n\r\n ${designSystem === 'Custom' ? `\r\n bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 text-gray-700 dark:text-gray-300 rounded hover:${getColorShade(globalConfig, 'border', 400)}\r\n ` : ''}\r\n `}\r\n >\r\n {componentProps.isLoading ? <Loader2 size={14} className=\"animate-spin mx-auto\"/> : label}\r\n </button>\r\n ))}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Plus, Edit } from 'lucide-react';\r\nimport { getAppliedStyles, getComponentVariantClasses, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface FABProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const FloatingActionButton: React.FC<FABProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const isExtended = componentProps.text && componentProps.text.length > 0;\r\n \r\n // Use 'primary' variant logic by default but add shadow and shape\r\n const variantClasses = getComponentVariantClasses(designSystem, { ...componentProps, variant: 'primary' }, globalConfig, 'button');\r\n\r\n return (\r\n <button\r\n style={appliedStyles}\r\n disabled={componentProps.isDisabled || componentProps.isLoading}\r\n className={`\r\n relative flex items-center justify-center transition-all duration-300\r\n ${isExtended ? 'px-6 py-4' : 'p-0 aspect-square'}\r\n ${componentProps.size === 'SM' ? 'min-h-[40px] min-w-[40px]' : componentProps.size === 'LG' ? 'min-h-[64px] min-w-[64px]' : 'min-h-[56px] min-w-[56px]'}\r\n ${designSystem === 'MUI' ? 'rounded-full shadow-lg' : getRadiusClass(globalConfig)}\r\n ${variantClasses}\r\n ${designSystem === 'Apple' ? 'shadow-xl' : 'shadow-md'}\r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <Loader2 className=\"animate-spin\" size={24} />\r\n ) : (\r\n <>\r\n {isExtended ? <Edit size={20} className=\"mr-2\" /> : <Plus size={24} />}\r\n {isExtended && <span className=\"font-semibold\">{componentProps.text}</span>}\r\n </>\r\n )}\r\n </button>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Loader2, Bold, Italic, Underline } from 'lucide-react';\r\nimport { getAppliedStyles, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface ToggleButtonProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const ToggleButton: React.FC<ToggleButtonProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [selectedToggles, setSelectedToggles] = useState<string[]>(['bold']);\r\n\r\n const handleToggle = (val: string) => {\r\n if (selectedToggles.includes(val)) {\r\n setSelectedToggles(selectedToggles.filter(t => t !== val));\r\n } else {\r\n setSelectedToggles([...selectedToggles, val]);\r\n }\r\n };\r\n\r\n return (\r\n <div \r\n style={appliedStyles}\r\n className={`\r\n inline-flex \r\n ${designSystem === 'MUI' ? 'rounded-md shadow-sm' : ''}\r\n ${designSystem === 'Apple' ? 'bg-gray-100 dark:bg-gray-800 p-1 rounded-lg' : ''}\r\n ${designSystem === 'Custom' ? 'gap-2' : ''}\r\n `}\r\n >\r\n {[\r\n { val: 'bold', Icon: Bold },\r\n { val: 'italic', Icon: Italic },\r\n { val: 'underline', Icon: Underline }\r\n ].map(({ val, Icon }, idx, arr) => {\r\n const isSelected = selectedToggles.includes(val);\r\n return (\r\n <button\r\n key={val}\r\n onClick={() => handleToggle(val)}\r\n disabled={componentProps.isDisabled}\r\n className={`\r\n flex items-center justify-center transition-all duration-200\r\n ${componentProps.size === 'SM' ? 'w-8 h-8' : componentProps.size === 'LG' ? 'w-12 h-12' : 'w-10 h-10'}\r\n ${componentProps.isDisabled ? 'opacity-50 cursor-not-allowed' : ''}\r\n\r\n ${designSystem === 'MUI' ? `\r\n border border-gray-300 dark:border-gray-600 \r\n ${idx === 0 ? 'rounded-l-md' : ''} ${idx === arr.length - 1 ? 'rounded-r-md' : ''}\r\n ${idx !== 0 ? '-ml-px' : ''}\r\n ${isSelected \r\n ? `${getColorShade(globalConfig, 'bg', 50)} dark:${getColorShade(globalConfig, 'bg', 900)}/30 ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'text', 400)} z-10 ${getColorShade(globalConfig, 'border', 200)} dark:${getColorShade(globalConfig, 'border', 800)}` \r\n : 'bg-white dark:bg-gray-900 text-gray-500 dark:text-gray-400 hover:bg-gray-50 dark:hover:bg-gray-800'}\r\n ` : ''}\r\n\r\n ${designSystem === 'Apple' ? `\r\n rounded-md\r\n ${isSelected \r\n ? 'bg-white dark:bg-gray-700 shadow-sm text-gray-900 dark:text-white' \r\n : 'text-gray-500 dark:text-gray-400 hover:text-gray-700'}\r\n ` : ''}\r\n\r\n ${designSystem === 'Custom' ? `\r\n border rounded-md\r\n ${isSelected \r\n ? `${getColorShade(globalConfig, 'bg', 100)} dark:${getColorShade(globalConfig, 'bg', 900)}/30 ${getColorShade(globalConfig, 'border', 300)} dark:${getColorShade(globalConfig, 'border', 700)} ${getColorShade(globalConfig, 'text', 700)} dark:${getColorShade(globalConfig, 'text', 300)}` \r\n : 'bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-700 text-gray-600 dark:text-gray-400 hover:bg-gray-50'}\r\n ` : ''}\r\n `}\r\n >\r\n {componentProps.isLoading ? (\r\n <Loader2 size={16} className=\"animate-spin\" />\r\n ) : (\r\n <Icon size={componentProps.size === 'SM' ? 14 : componentProps.size === 'LG' ? 20 : 18} />\r\n )}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { X, Inbox, Mail, Settings, User } from 'lucide-react';\r\nimport { getAppliedStyles, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface DrawerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Drawer: React.FC<DrawerProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"relative w-full h-full overflow-hidden\">\r\n <button \r\n onClick={() => setIsOpen(true)}\r\n className={`px-4 py-2 border ${getColorShade(globalConfig, 'border', 200)} rounded-md ${getColorShade(globalConfig, 'bg', 50).replace('bg-', 'hover:bg-')} dark:${getColorShade(globalConfig, 'bg', 800).replace('bg-', 'hover:bg-')} ${getColorShade(globalConfig, 'text', 700)} dark:${getColorShade(globalConfig, 'text', 200)}`}\r\n >\r\n Open Drawer\r\n </button>\r\n\r\n {/* Backdrop */}\r\n <div \r\n className={`\r\n absolute inset-0 bg-black/50 transition-opacity duration-300 z-40\r\n ${isOpen ? 'opacity-100' : 'opacity-0 pointer-events-none'}\r\n `}\r\n onClick={() => setIsOpen(false)}\r\n />\r\n \r\n {/* Drawer Panel */}\r\n <div className={`\r\n absolute inset-y-0 left-0 w-80 max-w-[85%] bg-white dark:bg-gray-900 shadow-xl transform transition-transform duration-300 ease-in-out z-50 flex flex-col\r\n ${isOpen ? 'translate-x-0' : '-translate-x-full'}\r\n ${isMUI ? 'border-r border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'rounded-r-2xl my-2 ml-2 h-[calc(100%-16px)]' : ''}\r\n ${isCustom ? `border-r border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"p-4 flex items-center justify-between border-b border-gray-100 dark:border-gray-800 flex-shrink-0\">\r\n <span className=\"font-bold text-lg text-gray-900 dark:text-white\">Menu</span>\r\n <button \r\n onClick={() => setIsOpen(false)} \r\n className=\"p-2 hover:bg-gray-100 dark:hover:bg-gray-800 rounded-full transition-colors\"\r\n >\r\n <X size={20} className=\"text-gray-600 dark:text-gray-400\" />\r\n </button>\r\n </div>\r\n <div className=\"flex-1 overflow-y-auto p-2 space-y-1\">\r\n {[\r\n { label: 'Inbox', icon: Inbox },\r\n { label: 'Sent', icon: Mail },\r\n { label: 'Profile', icon: User },\r\n { label: 'Settings', icon: Settings },\r\n ].map(item => (\r\n <button \r\n key={item.label} \r\n className=\"flex items-center gap-3 w-full px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-gray-800 text-left text-gray-700 dark:text-gray-200 transition-colors\"\r\n >\r\n <item.icon size={20} />\r\n {item.label}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { MoreHorizontal, Trash2, Share2, Copy, X } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface ActionSheetProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const ActionSheet: React.FC<ActionSheetProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isOpen, setIsOpen] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"flex flex-col items-center justify-end h-full w-full relative overflow-hidden bg-gray-100 dark:bg-gray-900/50 rounded-lg border border-dashed border-gray-300 dark:border-gray-700\">\r\n \r\n <button \r\n onClick={() => setIsOpen(true)}\r\n className={`mb-auto mt-20 px-4 py-2 ${getColorShade(globalConfig, 'bg', 50)} dark:${getColorShade(globalConfig, 'bg', 800)} shadow-sm rounded-md font-medium text-sm ${getColorShade(globalConfig, 'text', 700)} dark:${getColorShade(globalConfig, 'text', 200)}`}\r\n >\r\n Show Actions\r\n </button>\r\n\r\n {/* Overlay */}\r\n {isOpen && (\r\n <div className=\"absolute inset-0 bg-black/60 z-10 transition-opacity backdrop-blur-sm\" onClick={() => setIsOpen(false)} />\r\n )}\r\n\r\n {/* Sheet */}\r\n <div className={`\r\n absolute bottom-0 left-0 right-0 z-20 transition-transform duration-300\r\n ${isOpen ? 'translate-y-0' : 'translate-y-full'}\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded-t-xl' : ''}\r\n ${isApple ? 'bg-transparent px-2 pb-2' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border-t border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)} rounded-b-none` : ''}\r\n `}>\r\n {isMUI && (\r\n <div className=\"py-2\">\r\n <div className=\"flex items-center gap-4 px-4 py-3 hover:bg-gray-100 dark:hover:bg-gray-700 cursor-pointer\">\r\n <Share2 size={20} className=\"text-gray-500\" />\r\n <span className=\"text-gray-900 dark:text-white\">Share</span>\r\n </div>\r\n <div className=\"flex items-center gap-4 px-4 py-3 hover:bg-gray-100 dark:hover:bg-gray-700 cursor-pointer\">\r\n <Copy size={20} className=\"text-gray-500\" />\r\n <span className=\"text-gray-900 dark:text-white\">Copy Link</span>\r\n </div>\r\n <div className=\"flex items-center gap-4 px-4 py-3 hover:bg-gray-100 dark:hover:bg-gray-700 cursor-pointer text-red-600\">\r\n <Trash2 size={20} />\r\n <span>Delete</span>\r\n </div>\r\n </div>\r\n )}\r\n\r\n {isApple && (\r\n <div className=\"space-y-2\">\r\n <div className=\"bg-white/90 dark:bg-gray-800/90 backdrop-blur-xl rounded-xl overflow-hidden\">\r\n <button className={`w-full py-3.5 ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'text', 400)} text-center font-normal border-b border-gray-200 dark:border-gray-700 active:bg-gray-100 dark:active:bg-gray-700`}>\r\n Share\r\n </button>\r\n <button className={`w-full py-3.5 ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'text', 400)} text-center font-normal border-b border-gray-200 dark:border-gray-700 active:bg-gray-100 dark:active:bg-gray-700`}>\r\n Copy Link\r\n </button>\r\n <button className=\"w-full py-3.5 text-red-600 text-center font-normal active:bg-gray-100 dark:active:bg-gray-700\">\r\n Delete\r\n </button>\r\n </div>\r\n <button \r\n onClick={() => setIsOpen(false)}\r\n className={`w-full py-3.5 bg-white dark:bg-gray-800 rounded-xl font-semibold ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'text', 400)} shadow-sm active:scale-[0.99] transition-transform`}\r\n >\r\n Cancel\r\n </button>\r\n </div>\r\n )}\r\n\r\n {isCustom && (\r\n <div className=\"p-4 space-y-2\">\r\n <h3 className=\"text-sm font-bold text-gray-500 uppercase tracking-wider mb-2\">Actions</h3>\r\n <div className=\"grid grid-cols-3 gap-2\">\r\n <button className=\"flex flex-col items-center gap-2 p-3 rounded-lg border border-gray-100 dark:border-gray-800 hover:bg-gray-50 dark:hover:bg-gray-800\">\r\n <Share2 size={20} className=\"text-gray-600 dark:text-gray-300\" />\r\n <span className=\"text-xs\">Share</span>\r\n </button>\r\n <button className=\"flex flex-col items-center gap-2 p-3 rounded-lg border border-gray-100 dark:border-gray-800 hover:bg-gray-50 dark:hover:bg-gray-800\">\r\n <Copy size={20} className=\"text-gray-600 dark:text-gray-300\" />\r\n <span className=\"text-xs\">Copy</span>\r\n </button>\r\n <button className=\"flex flex-col items-center gap-2 p-3 rounded-lg border border-gray-100 dark:border-gray-800 hover:bg-red-50 dark:hover:bg-red-900/10 text-red-600\">\r\n <Trash2 size={20} />\r\n <span className=\"text-xs\">Delete</span>\r\n </button>\r\n </div>\r\n <button onClick={() => setIsOpen(false)} className=\"w-full py-3 mt-2 text-sm font-medium text-gray-500 hover:text-gray-800\">\r\n Cancel\r\n </button>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Camera as CameraIcon, SwitchCamera, Zap, ZapOff, Image as ImageIcon, Circle } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface CameraProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Camera: React.FC<CameraProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const videoRef = useRef<HTMLVideoElement>(null);\r\n const [hasPermission, setHasPermission] = useState(false);\r\n const [flash, setFlash] = useState(false);\r\n const [facingMode, setFacingMode] = useState<'user' | 'environment'>('user');\r\n\r\n // Mock stream for demo purposes if permission logic fails or isn't needed for UI preview\r\n useEffect(() => {\r\n // In a real app, we would request navigator.mediaDevices.getUserMedia\r\n // For this UI demo, we'll simulate a \"ready\" state or show a placeholder\r\n setHasPermission(true);\r\n }, []);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div \r\n style={appliedStyles} \r\n className={`\r\n w-full max-w-sm aspect-[9/16] bg-black relative overflow-hidden flex flex-col justify-between\r\n ${isMUI ? 'rounded-none shadow-xl' : ''}\r\n ${isApple ? 'rounded-[3rem] shadow-2xl border-4 border-gray-900' : ''}\r\n ${isCustom ? `${getRadiusClass(globalConfig)} border-2 border-gray-800` : ''}\r\n `}\r\n >\r\n {/* Camera Preview Placeholder */}\r\n <div className=\"absolute inset-0 bg-gray-900 flex items-center justify-center\">\r\n {/* Simulated feed */}\r\n <div className=\"text-gray-500 flex flex-col items-center gap-2\">\r\n <CameraIcon size={48} className=\"opacity-20\" />\r\n <span className=\"text-xs uppercase tracking-widest opacity-40\">Camera Preview</span>\r\n </div>\r\n {/* Grid overlay */}\r\n <div className=\"absolute inset-0 grid grid-cols-3 grid-rows-3 opacity-20 pointer-events-none\">\r\n <div className=\"border-r border-b border-gray-500/30\"></div>\r\n <div className=\"border-r border-b border-gray-500/30\"></div>\r\n <div className=\"border-b border-gray-500/30\"></div>\r\n <div className=\"border-r border-b border-gray-500/30\"></div>\r\n <div className=\"border-r border-b border-gray-500/30\"></div>\r\n <div className=\"border-b border-gray-500/30\"></div>\r\n <div className=\"border-r border-gray-500/30\"></div>\r\n <div className=\"border-r border-gray-500/30\"></div>\r\n <div></div>\r\n </div>\r\n </div>\r\n\r\n {/* Top Controls */}\r\n <div className=\"relative z-10 flex justify-between items-center p-4 bg-gradient-to-b from-black/50 to-transparent\">\r\n <button \r\n onClick={() => setFlash(!flash)}\r\n className=\"p-2 rounded-full bg-black/20 backdrop-blur-md text-white hover:bg-black/40 transition-colors\"\r\n >\r\n {flash ? <Zap size={20} className=\"text-yellow-400\" fill=\"currentColor\" /> : <ZapOff size={20} />}\r\n </button>\r\n <div className=\"px-3 py-1 rounded-full bg-black/20 backdrop-blur-md text-white text-xs font-medium\">\r\n HD 30 • 16:9\r\n </div>\r\n </div>\r\n\r\n {/* Bottom Controls */}\r\n <div className=\"relative z-10 p-6 pb-8 bg-gradient-to-t from-black/80 via-black/20 to-transparent flex flex-col gap-6\">\r\n \r\n {/* Mode Selector */}\r\n <div className=\"flex justify-center gap-6 text-sm font-medium text-white/70 overflow-x-auto no-scrollbar\">\r\n <span className=\"hover:text-white cursor-pointer transition-colors\">Video</span>\r\n <span className=\"text-yellow-400 cursor-pointer\">Photo</span>\r\n <span className=\"hover:text-white cursor-pointer transition-colors\">Portrait</span>\r\n </div>\r\n\r\n <div className=\"flex items-center justify-between\">\r\n {/* Gallery Preview */}\r\n <button className=\"w-12 h-12 rounded-full bg-gray-800 border-2 border-white overflow-hidden hover:scale-105 transition-transform\">\r\n <div className=\"w-full h-full bg-gradient-to-tr from-purple-500 to-blue-500\" />\r\n </button>\r\n\r\n {/* Shutter Button */}\r\n <button \r\n className={`\r\n w-20 h-20 rounded-full border-4 border-white flex items-center justify-center transition-transform active:scale-95\r\n ${isMUI ? 'bg-white/20' : ''}\r\n ${isApple ? 'bg-white' : ''}\r\n ${isCustom ? `bg-${globalConfig.primaryColor}-500/80` : ''}\r\n `}\r\n >\r\n <div className={`w-16 h-16 rounded-full ${isApple ? 'border-2 border-black bg-white' : 'bg-white'}`} />\r\n </button>\r\n\r\n {/* Flip Camera */}\r\n <button \r\n onClick={() => setFacingMode(prev => prev === 'user' ? 'environment' : 'user')}\r\n className=\"w-12 h-12 rounded-full bg-black/40 backdrop-blur-md flex items-center justify-center text-white hover:bg-black/60 transition-colors\"\r\n >\r\n <SwitchCamera size={24} />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { MapPin, Navigation, Plus, Minus, Search, Menu, Layers } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface MapProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Map: React.FC<MapProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div \r\n style={appliedStyles} \r\n className={`\r\n w-full h-full min-h-[400px] relative overflow-hidden ${getColorShade(globalConfig, 'bg', 50)} dark:bg-gray-900 flex flex-col\r\n ${isMUI ? 'shadow-md rounded' : ''}\r\n ${isApple ? 'rounded-2xl shadow-xl border border-gray-200/50' : ''}\r\n ${isCustom ? `${getRadiusClass(globalConfig)} border border-gray-200 dark:border-gray-800` : ''}\r\n `}\r\n >\r\n {/* Mock Map Background */}\r\n <div className=\"absolute inset-0 opacity-30\" \r\n style={{ \r\n backgroundImage: 'url(\"https://images.unsplash.com/photo-1524661135-423995f22d0b?ixlib=rb-4.0.3&auto=format&fit=crop&w=1000&q=80\")',\r\n backgroundSize: 'cover',\r\n backgroundPosition: 'center'\r\n }} \r\n />\r\n \r\n {/* UI Overlay */}\r\n <div className=\"absolute inset-0 pointer-events-none p-4 flex flex-col justify-between\">\r\n \r\n {/* Top Bar / Search */}\r\n <div className=\"flex gap-2 pointer-events-auto\">\r\n <div className={`\r\n flex-1 flex items-center bg-white dark:bg-gray-800 shadow-md h-12 px-4 gap-3\r\n ${isMUI ? 'rounded-sm' : 'rounded-xl'}\r\n ${isCustom ? getRadiusClass(globalConfig) : ''}\r\n `}>\r\n <Menu size={20} className=\"text-gray-500\" />\r\n <input \r\n type=\"text\" \r\n placeholder=\"Search here\" \r\n className=\"flex-1 bg-transparent border-none focus:ring-0 text-sm\" \r\n />\r\n <Search size={20} className=\"text-gray-500\" />\r\n </div>\r\n <div className={`\r\n w-12 h-12 bg-white dark:bg-gray-800 shadow-md flex items-center justify-center text-gray-600\r\n ${isMUI ? 'rounded-full' : 'rounded-xl'}\r\n `}>\r\n <div className=\"w-8 h-8 rounded-full bg-purple-500 flex items-center justify-center text-white font-bold text-xs\">O</div>\r\n </div>\r\n </div>\r\n\r\n {/* Map Pins */}\r\n <div className=\"absolute top-1/2 left-1/2 transform -translate-x-1/2 -translate-y-1/2 pointer-events-auto cursor-pointer group\">\r\n <div className=\"relative\">\r\n <MapPin \r\n size={40} \r\n className={`\r\n drop-shadow-lg transition-transform group-hover:-translate-y-2\r\n ${isMUI ? 'text-red-600' : getColorShade(globalConfig, 'text', 500)}\r\n ${isCustom ? getColorClass(globalConfig, 'text') : ''}\r\n `} \r\n fill=\"currentColor\"\r\n />\r\n <div className=\"absolute top-full left-1/2 -translate-x-1/2 w-4 h-2 bg-black/20 rounded-full blur-[2px] group-hover:scale-75 transition-transform\" />\r\n </div>\r\n </div>\r\n\r\n {/* Bottom Controls */}\r\n <div className=\"flex justify-between items-end pointer-events-auto\">\r\n <div className=\"flex flex-col gap-2\">\r\n <button className=\"w-10 h-10 bg-white dark:bg-gray-800 shadow-md rounded flex items-center justify-center text-gray-600 hover:text-black\">\r\n <Layers size={20} />\r\n </button>\r\n </div>\r\n\r\n <div className=\"flex flex-col gap-2\">\r\n <button className=\"w-10 h-10 bg-white dark:bg-gray-800 shadow-md rounded-t flex items-center justify-center text-gray-600 hover:text-black\">\r\n <Plus size={20} />\r\n </button>\r\n <button className=\"w-10 h-10 bg-white dark:bg-gray-800 shadow-md rounded-b flex items-center justify-center text-gray-600 hover:text-black mt-[-1px]\">\r\n <Minus size={20} />\r\n </button>\r\n <button className={`w-10 h-10 ${getColorShade(globalConfig, 'bg', 600)} shadow-md rounded-full flex items-center justify-center text-white ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} mt-2`}>\r\n <Navigation size={20} fill=\"currentColor\" />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect, useRef } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Send, Bot, User, Sparkles } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface AIChatbotProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\ninterface Message {\r\n id: number;\r\n text: string;\r\n sender: 'user' | 'ai';\r\n}\r\n\r\nexport const AIChatbot: React.FC<AIChatbotProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [messages, setMessages] = useState<Message[]>([\r\n { id: 1, text: \"Hello! How can I help you today?\", sender: 'ai' }\r\n ]);\r\n const [input, setInput] = useState('');\r\n const [isTyping, setIsTyping] = useState(false);\r\n const scrollRef = useRef<HTMLDivElement>(null);\r\n\r\n const handleSend = () => {\r\n if (!input.trim()) return;\r\n \r\n const userMsg: Message = { id: Date.now(), text: input, sender: 'user' };\r\n setMessages(prev => [...prev, userMsg]);\r\n setInput('');\r\n setIsTyping(true);\r\n\r\n // Mock AI response\r\n setTimeout(() => {\r\n setIsTyping(false);\r\n setMessages(prev => [...prev, { \r\n id: Date.now() + 1, \r\n text: \"I'm processing your request. This is a simulated response based on the OpenGrid design system parameters.\", \r\n sender: 'ai' \r\n }]);\r\n }, 1500);\r\n };\r\n\r\n // Auto-scroll\r\n useEffect(() => {\r\n if (scrollRef.current) {\r\n scrollRef.current.scrollTop = scrollRef.current.scrollHeight;\r\n }\r\n }, [messages, isTyping]);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className={`\r\n w-full h-full flex flex-col overflow-hidden\r\n ${isMUI ? 'bg-white dark:bg-gray-900 shadow-xl rounded-lg border border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl rounded-2xl shadow-2xl border border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {/* Header */}\r\n <div className={`\r\n flex items-center gap-3 p-4 border-b border-gray-100 dark:border-gray-800\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} text-white` : ''}\r\n ${isApple ? 'bg-white/50 dark:bg-gray-800/50 backdrop-blur-md' : ''}\r\n ${isCustom ? 'bg-gray-50 dark:bg-gray-900' : ''}\r\n `}>\r\n <div className={`\r\n w-10 h-10 rounded-full flex items-center justify-center\r\n ${isMUI ? 'bg-white/20' : isApple ? `${getColorShade(globalConfig, 'bg', 500)} text-white` : `${getColorClass(globalConfig, 'bg')} text-white`}\r\n `}>\r\n <Bot size={20} />\r\n </div>\r\n <div>\r\n <h3 className={`font-bold text-sm ${isMUI ? 'text-white' : 'text-gray-900 dark:text-white'}`}>AI Assistant</h3>\r\n <span className={`text-xs ${isMUI ? `${getColorShade(globalConfig, 'text', 100)}` : 'text-green-500 flex items-center gap-1'}`}>\r\n {isMUI ? 'Online' : <><span className=\"w-1.5 h-1.5 rounded-full bg-green-500 inline-block\"/> Online</>}\r\n </span>\r\n </div>\r\n </div>\r\n\r\n {/* Chat Area */}\r\n <div ref={scrollRef} className=\"flex-1 overflow-y-auto p-4 space-y-4\">\r\n {messages.map((msg) => (\r\n <div key={msg.id} className={`flex ${msg.sender === 'user' ? 'justify-end' : 'justify-start'}`}>\r\n <div className={`\r\n max-w-[80%] p-3 text-sm\r\n ${msg.sender === 'user' \r\n ? (isMUI ? `${getColorShade(globalConfig, 'bg', 600)} text-white rounded-l-lg rounded-tr-lg` \r\n : isApple ? `${getColorShade(globalConfig, 'bg', 500)} text-white rounded-2xl rounded-tr-sm` \r\n : `${getColorClass(globalConfig, 'bg')} text-white rounded-lg`)\r\n : (isMUI ? 'bg-gray-100 dark:bg-gray-800 text-gray-900 dark:text-white rounded-r-lg rounded-tl-lg'\r\n : isApple ? 'bg-gray-200 dark:bg-gray-800 text-gray-900 dark:text-white rounded-2xl rounded-tl-sm'\r\n : 'bg-gray-100 dark:bg-gray-900 text-gray-800 dark:text-gray-200 rounded-lg border border-gray-200 dark:border-gray-800')\r\n }\r\n `}>\r\n {msg.text}\r\n </div>\r\n </div>\r\n ))}\r\n \r\n {isTyping && (\r\n <div className=\"flex justify-start\">\r\n <div className={`\r\n flex gap-1 p-4 rounded-2xl\r\n ${isApple ? 'bg-gray-200 dark:bg-gray-800' : 'bg-gray-100 dark:bg-gray-900'}\r\n `}>\r\n <span className=\"w-1.5 h-1.5 bg-gray-400 rounded-full animate-bounce\" />\r\n <span className=\"w-1.5 h-1.5 bg-gray-400 rounded-full animate-bounce delay-75\" />\r\n <span className=\"w-1.5 h-1.5 bg-gray-400 rounded-full animate-bounce delay-150\" />\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n\r\n {/* Input Area */}\r\n <div className=\"p-4 border-t border-gray-100 dark:border-gray-800 bg-white dark:bg-gray-900\">\r\n <div className={`\r\n flex items-center gap-2 p-2\r\n ${isMUI ? 'bg-gray-100 dark:bg-gray-800 rounded' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-full border border-gray-200 dark:border-gray-700' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <input \r\n type=\"text\" \r\n value={input}\r\n onChange={(e) => setInput(e.target.value)}\r\n onKeyDown={(e) => e.key === 'Enter' && handleSend()}\r\n placeholder=\"Type a message...\"\r\n className=\"flex-1 bg-transparent border-none focus:ring-0 text-sm text-gray-900 dark:text-white placeholder-gray-400\"\r\n />\r\n <button \r\n onClick={handleSend}\r\n disabled={!input.trim()}\r\n className={`\r\n p-2 rounded-full transition-all disabled:opacity-50 disabled:cursor-not-allowed\r\n ${isMUI ? `${getColorShade(globalConfig, 'text', 600)} ${getColorShade(globalConfig, 'bg', 50).replace('bg-', 'hover:bg-')}` : ''}\r\n ${isApple ? `${getColorShade(globalConfig, 'bg', 500)} text-white ${getColorShade(globalConfig, 'bg', 600).replace('bg-', 'hover:bg-')} shadow-sm` : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} text-white hover:opacity-90` : ''}\r\n `}\r\n >\r\n <Send size={18} />\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Code2, Terminal, Copy, Check, Sparkles, Loader2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface CodeGeneratorProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nconst MOCK_CODE_RESULT = `import React from 'react';\r\n\r\n// Generated Component\r\nconst UserProfile = ({ name, role }) => {\r\n return (\r\n <div className=\"p-6 bg-white rounded-lg shadow-md\">\r\n <div className=\"flex items-center gap-4\">\r\n <div className=\"w-12 h-12 bg-blue-100 rounded-full flex items-center justify-center\">\r\n <span className=\"text-blue-600 font-bold\">\r\n {name.charAt(0)}\r\n </span>\r\n </div>\r\n <div>\r\n <h3 className=\"text-lg font-bold\">{name}</h3>\r\n <p className=\"text-gray-500\">{role}</p>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n\r\nexport default UserProfile;`;\r\n\r\nexport const CodeGenerator: React.FC<CodeGeneratorProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [prompt, setPrompt] = useState('Create a React component for a user profile card with tailwind css.');\r\n const [isGenerating, setIsGenerating] = useState(false);\r\n const [displayedCode, setDisplayedCode] = useState('');\r\n const [isCopied, setIsCopied] = useState(false);\r\n\r\n const handleGenerate = () => {\r\n setIsGenerating(true);\r\n setDisplayedCode('');\r\n \r\n // Typewriter effect simulation\r\n setTimeout(() => {\r\n let i = 0;\r\n const interval = setInterval(() => {\r\n setDisplayedCode(MOCK_CODE_RESULT.substring(0, i));\r\n i++;\r\n if (i > MOCK_CODE_RESULT.length) {\r\n clearInterval(interval);\r\n setIsGenerating(false);\r\n }\r\n }, 15); // Speed of typing\r\n }, 1000);\r\n };\r\n\r\n const handleCopy = () => {\r\n setIsCopied(true);\r\n setTimeout(() => setIsCopied(false), 2000);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col gap-4 overflow-hidden\">\r\n \r\n {/* Input Panel */}\r\n <div className={`\r\n p-4 flex-shrink-0\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-sm rounded border border-gray-300 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl border border-gray-200/50 dark:border-gray-700/50 shadow-sm rounded-xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"flex gap-4\">\r\n <div className=\"flex-1\">\r\n <div className=\"relative\">\r\n <div className=\"absolute top-3 left-3 text-gray-400\">\r\n <Terminal size={18} />\r\n </div>\r\n <input \r\n type=\"text\" \r\n value={prompt}\r\n onChange={(e) => setPrompt(e.target.value)}\r\n className={`\r\n w-full pl-10 pr-4 py-2.5 text-sm focus:outline-none transition-all\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 dark:border-gray-600 focus:border-blue-600' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-lg focus:bg-white dark:focus:bg-black focus:ring-2 focus:ring-blue-500/20' : ''}\r\n ${isCustom ? `bg-gray-50 dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-md focus:border-${globalConfig.primaryColor}-500` : ''}\r\n `}\r\n placeholder=\"Describe the code you want...\"\r\n />\r\n </div>\r\n </div>\r\n \r\n <select className={`\r\n w-32 px-3 py-2 text-sm appearance-none cursor-pointer\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 dark:border-gray-600 rounded-t' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-lg' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-md` : ''}\r\n `}>\r\n <option>React</option>\r\n <option>Vue</option>\r\n <option>Svelte</option>\r\n <option>HTML</option>\r\n </select>\r\n\r\n <button \r\n onClick={handleGenerate}\r\n disabled={isGenerating}\r\n className={`\r\n px-4 py-2 flex items-center gap-2 font-medium text-white transition-all\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} shadow uppercase text-sm rounded` : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black hover:opacity-90 rounded-lg text-sm' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} rounded-md hover:opacity-90` : ''}\r\n `}\r\n >\r\n {isGenerating ? <Loader2 size={16} className=\"animate-spin\" /> : <Sparkles size={16} />}\r\n <span className=\"hidden sm:inline\">Generate</span>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Code Output */}\r\n <div className={`\r\n relative overflow-hidden flex-1 flex flex-col min-h-0\r\n ${isMUI ? 'rounded border border-gray-800' : ''}\r\n ${isApple ? 'rounded-xl shadow-2xl border border-gray-800' : ''}\r\n ${isCustom ? `rounded-lg border border-gray-800` : ''}\r\n `}>\r\n {/* Editor Header */}\r\n <div className=\"bg-gray-900 border-b border-gray-800 p-3 flex items-center justify-between flex-shrink-0\">\r\n <div className=\"flex items-center gap-2\">\r\n <div className=\"flex gap-1.5 mr-4\">\r\n <div className=\"w-3 h-3 rounded-full bg-red-500/80\" />\r\n <div className=\"w-3 h-3 rounded-full bg-yellow-500/80\" />\r\n <div className=\"w-3 h-3 rounded-full bg-green-500/80\" />\r\n </div>\r\n <span className=\"text-xs text-gray-400 font-mono\">UserProfile.jsx</span>\r\n </div>\r\n <button \r\n onClick={handleCopy}\r\n className=\"text-gray-400 hover:text-white transition-colors\"\r\n title=\"Copy Code\"\r\n >\r\n {isCopied ? <Check size={16} className=\"text-green-500\" /> : <Copy size={16} />}\r\n </button>\r\n </div>\r\n\r\n {/* Editor Body */}\r\n <div className=\"bg-[#0D1117] p-4 flex-1 font-mono text-sm overflow-auto min-h-0\">\r\n <pre>\r\n <code className=\"text-gray-300\">\r\n {displayedCode}\r\n {isGenerating && <span className=\"inline-block w-2 h-4 bg-blue-500 ml-1 animate-pulse align-middle\" />}\r\n </code>\r\n </pre>\r\n {!displayedCode && !isGenerating && (\r\n <div className=\"absolute inset-0 flex items-center justify-center text-gray-700 pointer-events-none\">\r\n <Code2 size={48} className=\"opacity-20\" />\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Image as ImageIcon, Sparkles, Download, Maximize2, Loader2, RefreshCw } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface ImageGeneratorProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nconst MOCK_IMAGES = [\r\n 'https://images.unsplash.com/photo-1620641788421-7a1c342ea42e?w=500&auto=format&fit=crop&q=60',\r\n 'https://images.unsplash.com/photo-1633412802994-5c058f151b66?w=500&auto=format&fit=crop&q=60',\r\n 'https://images.unsplash.com/photo-1618005182384-a83a8bd57fbe?w=500&auto=format&fit=crop&q=60',\r\n 'https://images.unsplash.com/photo-1620121692029-d088224ddc74?w=500&auto=format&fit=crop&q=60'\r\n];\r\n\r\nexport const ImageGenerator: React.FC<ImageGeneratorProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [prompt, setPrompt] = useState('Abstract geometric shapes in pastel colors, 3d render, high quality.');\r\n const [isGenerating, setIsGenerating] = useState(false);\r\n const [generatedImages, setGeneratedImages] = useState<string[]>([]);\r\n\r\n const handleGenerate = () => {\r\n setIsGenerating(true);\r\n setGeneratedImages([]);\r\n \r\n setTimeout(() => {\r\n setGeneratedImages(MOCK_IMAGES);\r\n setIsGenerating(false);\r\n }, 2000);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col md:flex-row gap-4 overflow-hidden\">\r\n \r\n {/* Controls Sidebar */}\r\n <div className={`\r\n w-full md:w-80 flex-none md:flex-none p-4 flex flex-col gap-4 overflow-y-auto min-h-0 max-h-[40%] md:max-h-none\r\n ${isMUI ? 'bg-white dark:bg-gray-800 md:border-r border-b md:border-b-0 border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/50 dark:bg-gray-900/50 backdrop-blur-xl border border-gray-200/50 dark:border-gray-700/50 rounded-2xl md:rounded-r-none md:rounded-l-2xl' : ''}\r\n ${isCustom ? `bg-gray-50 dark:bg-gray-950 border border-gray-100 dark:border-gray-800 ${getRadiusClass(globalConfig)} md:border-r md:border-b-0` : ''}\r\n `}>\r\n <div>\r\n <h3 className=\"font-bold text-gray-900 dark:text-white mb-4 flex items-center gap-2\">\r\n <Sparkles size={18} className=\"text-purple-500\" /> Image Studio\r\n </h3>\r\n \r\n <div className=\"space-y-3\">\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase mb-2 block\">Prompt</label>\r\n <textarea \r\n value={prompt}\r\n onChange={(e) => setPrompt(e.target.value)}\r\n className={`\r\n w-full h-24 md:h-32 p-3 text-sm resize-none focus:outline-none focus:ring-2\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border border-gray-300 dark:border-gray-600 rounded focus:border-blue-500' : ''}\r\n ${isApple ? 'bg-white dark:bg-gray-800 rounded-xl border border-gray-200 dark:border-gray-700 focus:ring-purple-500/20' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-md focus:border-${globalConfig.primaryColor}-500` : ''}\r\n `}\r\n />\r\n </div>\r\n\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase mb-2 block\">Style</label>\r\n <div className=\"grid grid-cols-2 gap-2\">\r\n {['Realistic', 'Anime', '3D Render', 'Oil Painting'].map(style => (\r\n <button \r\n key={style}\r\n className={`\r\n text-xs py-2 px-3 border rounded transition-all text-left\r\n ${isMUI ? 'border-gray-300 hover:bg-gray-100' : ''}\r\n ${isApple ? 'bg-white dark:bg-gray-800 border-transparent shadow-sm hover:shadow' : ''}\r\n ${isCustom ? 'bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-800 hover:border-purple-400' : ''}\r\n `}\r\n >\r\n {style}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase mb-2 block\">Dimensions</label>\r\n <div className=\"flex gap-2 bg-gray-200 dark:bg-gray-800 p-1 rounded-lg\">\r\n <button className=\"flex-1 py-1.5 text-xs font-medium bg-white dark:bg-gray-700 shadow-sm rounded-md\">1:1</button>\r\n <button className=\"flex-1 py-1.5 text-xs font-medium text-gray-500 hover:text-gray-900\">16:9</button>\r\n <button className=\"flex-1 py-1.5 text-xs font-medium text-gray-500 hover:text-gray-900\">9:16</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div className=\"mt-auto\">\r\n <button \r\n onClick={handleGenerate}\r\n disabled={isGenerating}\r\n className={`\r\n w-full py-3 font-medium text-white transition-all flex items-center justify-center gap-2\r\n ${isMUI ? 'bg-purple-600 hover:bg-purple-700 rounded shadow uppercase text-sm' : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black rounded-xl text-sm shadow-lg hover:scale-[1.02]' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} rounded-lg shadow-md hover:opacity-90` : ''}\r\n `}\r\n >\r\n {isGenerating ? <Loader2 size={18} className=\"animate-spin\" /> : <Sparkles size={18} />}\r\n Generate\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Gallery Area */}\r\n <div className=\"flex-1 bg-gray-100 dark:bg-gray-900/50 rounded-2xl p-4 overflow-y-auto min-h-0\">\r\n {isGenerating ? (\r\n <div className=\"h-full flex flex-col items-center justify-center text-gray-400\">\r\n <Loader2 size={48} className=\"animate-spin mb-4 text-purple-500\" />\r\n <p>Dreaming up images...</p>\r\n </div>\r\n ) : generatedImages.length > 0 ? (\r\n <div className=\"grid grid-cols-1 sm:grid-cols-2 gap-4 h-full content-start\">\r\n {generatedImages.map((src, i) => (\r\n <div key={i} className=\"group relative aspect-square rounded-xl overflow-hidden shadow-sm bg-gray-200 dark:bg-gray-800\">\r\n <img src={src} alt={`Generated ${i}`} className=\"w-full h-full object-cover transition-transform duration-500 group-hover:scale-110\" />\r\n \r\n {/* Overlay */}\r\n <div className=\"absolute inset-0 bg-black/0 group-hover:bg-black/30 transition-colors flex items-center justify-center opacity-0 group-hover:opacity-100 gap-2\">\r\n <button className=\"p-2 bg-white/20 backdrop-blur-md rounded-full text-white hover:bg-white/40\">\r\n <Maximize2 size={18} />\r\n </button>\r\n <button className=\"p-2 bg-white/20 backdrop-blur-md rounded-full text-white hover:bg-white/40\">\r\n <Download size={18} />\r\n </button>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n ) : (\r\n <div className=\"h-full flex flex-col items-center justify-center text-gray-400\">\r\n <ImageIcon size={64} className=\"mb-4 opacity-20\" />\r\n <p>Enter a prompt to start creating.</p>\r\n </div>\r\n )}\r\n </div>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { PenTool, Wand2, Copy, RotateCcw, Check, AlignLeft, Bold, Italic } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface TextGeneratorProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const TextGenerator: React.FC<TextGeneratorProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [prompt, setPrompt] = useState('');\r\n const [result, setResult] = useState('');\r\n const [isGenerating, setIsGenerating] = useState(false);\r\n\r\n const handleGenerate = () => {\r\n setIsGenerating(true);\r\n setResult('');\r\n \r\n const mockText = \"OpenGrid is an innovative design system that prioritizes fluidity and transparency. Built for modern web applications, it seamlessly adapts to various viewports and user needs. By leveraging a comprehensive set of tokens and components, developers can build consistent interfaces faster than ever before. The system is not just a library, but a philosophy of structure meeting motion.\";\r\n \r\n // Typewriter\r\n let i = 0;\r\n const interval = setInterval(() => {\r\n setResult(mockText.substring(0, i));\r\n i++;\r\n if (i > mockText.length) {\r\n clearInterval(interval);\r\n setIsGenerating(false);\r\n }\r\n }, 20);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col gap-4 overflow-hidden\">\r\n \r\n {/* Controls */}\r\n <div className={`\r\n p-4 flex-shrink-0 transition-all\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow rounded border border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl border border-gray-200/50 shadow-sm rounded-2xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"flex flex-col gap-4\">\r\n <div className=\"flex gap-2\">\r\n <input \r\n type=\"text\" \r\n value={prompt}\r\n onChange={(e) => setPrompt(e.target.value)}\r\n placeholder=\"What would you like to write about?\"\r\n className={`\r\n flex-1 p-3 text-sm outline-none transition-all\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 focus:border-blue-600 rounded-t' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-xl focus:bg-white dark:focus:bg-black focus:ring-2 focus:ring-blue-500/20' : ''}\r\n ${isCustom ? `bg-gray-50 dark:bg-gray-900 border border-gray-200 dark:border-gray-800 rounded-md focus:border-${globalConfig.primaryColor}-500` : ''}\r\n `}\r\n />\r\n <button \r\n onClick={handleGenerate}\r\n disabled={isGenerating}\r\n className={`\r\n px-6 font-medium text-white transition-all flex items-center gap-2\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} shadow uppercase text-sm rounded` : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black rounded-xl hover:scale-105' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} rounded-md hover:opacity-90` : ''}\r\n `}\r\n >\r\n {isGenerating ? <RotateCcw size={18} className=\"animate-spin\" /> : <Wand2 size={18} />}\r\n </button>\r\n </div>\r\n\r\n <div className=\"flex gap-3 overflow-x-auto pb-2\">\r\n {['Professional', 'Casual', 'Witty', 'Concise'].map(tone => (\r\n <button \r\n key={tone}\r\n className={`\r\n px-3 py-1.5 text-xs font-medium border rounded-full transition-colors whitespace-nowrap\r\n ${isMUI ? 'border-gray-300 text-gray-600 hover:bg-gray-100' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 border-transparent text-gray-700 dark:text-gray-300 hover:bg-gray-200' : ''}\r\n ${isCustom ? 'border-gray-200 text-gray-500 hover:border-blue-400 hover:text-blue-500' : ''}\r\n `}\r\n >\r\n {tone}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Output */}\r\n <div className={`\r\n flex-1 p-6 relative overflow-y-auto min-h-0\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow rounded border border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white dark:bg-gray-900 rounded-2xl shadow-sm border border-gray-100 dark:border-gray-800' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {/* Toolbar Mock */}\r\n <div className=\"absolute top-4 right-4 flex gap-2 text-gray-400\">\r\n <Copy size={16} className=\"cursor-pointer hover:text-gray-600\" />\r\n <Check size={16} className=\"cursor-pointer hover:text-gray-600\" />\r\n </div>\r\n\r\n {/* Formatting Toolbar Mock (Left) */}\r\n <div className=\"absolute top-4 left-4 flex gap-3 text-gray-400 border-b border-gray-100 dark:border-gray-800 pb-2 w-[calc(100%-48px)]\">\r\n <Bold size={16} />\r\n <Italic size={16} />\r\n <AlignLeft size={16} />\r\n </div>\r\n\r\n <div className=\"mt-8 text-gray-700 dark:text-gray-200 leading-relaxed\">\r\n {result || <span className=\"text-gray-400 italic\">Generated text will appear here...</span>}\r\n {isGenerating && <span className={`inline-block w-1.5 h-4 ${getColorShade(globalConfig, 'bg', 500)} ml-1 animate-pulse align-middle`} />}\r\n </div>\r\n </div>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Play, Loader2, Sparkles, Video, Film, Download, Share2 } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface VideoGeneratorProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const VideoGenerator: React.FC<VideoGeneratorProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [prompt, setPrompt] = useState('A cyberpunk city street at night with neon lights reflecting on wet pavement.');\r\n const [isGenerating, setIsGenerating] = useState(false);\r\n const [progress, setProgress] = useState(0);\r\n const [hasResult, setHasResult] = useState(false);\r\n\r\n const handleGenerate = () => {\r\n setIsGenerating(true);\r\n setHasResult(false);\r\n setProgress(0);\r\n \r\n // Simulate generation\r\n let p = 0;\r\n const interval = setInterval(() => {\r\n p += 5;\r\n setProgress(p);\r\n if (p >= 100) {\r\n clearInterval(interval);\r\n setIsGenerating(false);\r\n setHasResult(true);\r\n }\r\n }, 150);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col gap-4 overflow-hidden\">\r\n \r\n {/* Input Area */}\r\n <div className={`\r\n p-4 flex-shrink-0\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-md rounded-lg border border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-xl border border-gray-200/50 dark:border-gray-700/50 shadow-lg rounded-2xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"flex items-center gap-2 mb-4\">\r\n <div className={`p-2 rounded-lg ${isCustom ? getColorClass(globalConfig, 'bg') : 'bg-purple-600'} text-white`}>\r\n <Video size={20} />\r\n </div>\r\n <h3 className=\"font-bold text-gray-900 dark:text-white\">AI Video Generator</h3>\r\n </div>\r\n\r\n <div className=\"space-y-3\">\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase tracking-wider mb-1.5 block\">Prompt</label>\r\n <textarea \r\n value={prompt}\r\n onChange={(e) => setPrompt(e.target.value)}\r\n className={`\r\n w-full p-2 text-sm min-h-[60px] max-h-[80px] focus:outline-none focus:ring-2 resize-none transition-all\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 dark:border-gray-600 focus:border-purple-600 rounded-t-md focus:ring-0' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 border-transparent rounded-xl focus:bg-white dark:focus:bg-black focus:ring-purple-500/30' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)} focus:border-${globalConfig.primaryColor}-500 focus:ring-${globalConfig.primaryColor}-500/20` : ''}\r\n `}\r\n />\r\n </div>\r\n\r\n <div className=\"flex flex-col sm:flex-row gap-3\">\r\n <div className=\"flex-1\">\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase tracking-wider mb-1.5 block\">Aspect Ratio</label>\r\n <select className={`\r\n w-full p-2.5 text-sm appearance-none\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 dark:border-gray-600 rounded-t-md' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-lg border-r-8 border-transparent' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <option>16:9 (Widescreen)</option>\r\n <option>9:16 (Vertical)</option>\r\n <option>1:1 (Square)</option>\r\n </select>\r\n </div>\r\n <div className=\"flex-1\">\r\n <label className=\"text-xs font-semibold text-gray-500 uppercase tracking-wider mb-1.5 block\">Duration</label>\r\n <select className={`\r\n w-full p-2.5 text-sm appearance-none\r\n ${isMUI ? 'bg-gray-50 dark:bg-gray-900 border-b-2 border-gray-300 dark:border-gray-600 rounded-t-md' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 rounded-lg border-r-8 border-transparent' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <option>5 Seconds</option>\r\n <option>10 Seconds</option>\r\n <option>15 Seconds</option>\r\n </select>\r\n </div>\r\n </div>\r\n\r\n <button \r\n onClick={handleGenerate}\r\n disabled={isGenerating}\r\n className={`\r\n w-full py-3 flex items-center justify-center gap-2 font-medium text-white transition-all\r\n ${isMUI ? 'bg-purple-600 hover:bg-purple-700 shadow-md uppercase tracking-wide rounded' : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black hover:opacity-90 rounded-xl shadow-sm' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} ${getRadiusClass(globalConfig)} hover:opacity-90` : ''}\r\n ${isGenerating ? 'opacity-70 cursor-not-allowed' : ''}\r\n `}\r\n >\r\n {isGenerating ? <Loader2 size={18} className=\"animate-spin\" /> : <Sparkles size={18} />}\r\n {isGenerating ? 'Rendering Video...' : 'Generate Video'}\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Result Area */}\r\n <div className={`\r\n relative flex-1 w-full min-h-0 overflow-hidden flex items-center justify-center\r\n ${isMUI ? 'bg-black rounded shadow-lg border border-gray-800' : ''}\r\n ${isApple ? 'bg-black/90 rounded-2xl shadow-xl border border-white/10' : ''}\r\n ${isCustom ? `bg-gray-900 ${getRadiusClass(globalConfig)} border border-gray-800` : ''}\r\n `}>\r\n {isGenerating ? (\r\n <div className=\"text-center space-y-4 w-64\">\r\n <Loader2 size={48} className={`animate-spin mx-auto ${isCustom ? getColorClass(globalConfig, 'text') : 'text-purple-500'}`} />\r\n <div className=\"space-y-1\">\r\n <div className=\"flex justify-between text-xs text-gray-400\">\r\n <span>Generating frames...</span>\r\n <span>{progress}%</span>\r\n </div>\r\n <div className=\"w-full h-1.5 bg-gray-800 rounded-full overflow-hidden\">\r\n <div \r\n className={`h-full transition-all duration-150 ${isCustom ? getColorClass(globalConfig, 'bg') : 'bg-purple-500'}`} \r\n style={{ width: `${progress}%` }} \r\n />\r\n </div>\r\n </div>\r\n </div>\r\n ) : hasResult ? (\r\n <div className=\"w-full h-full relative group\">\r\n <img \r\n src=\"https://images.unsplash.com/photo-1535498730771-e735b998cd64?ixlib=rb-1.2.1&auto=format&fit=crop&w=1600&q=80\" \r\n alt=\"Generated content\" \r\n className=\"w-full h-full object-cover opacity-80\"\r\n />\r\n <div className=\"absolute inset-0 flex items-center justify-center bg-black/20 group-hover:bg-black/40 transition-colors\">\r\n <button className={`w-16 h-16 flex items-center justify-center rounded-full bg-white/20 backdrop-blur-md text-white border border-white/30 hover:scale-110 transition-transform`}>\r\n <Play size={32} fill=\"currentColor\" className=\"ml-1\" />\r\n </button>\r\n </div>\r\n <div className=\"absolute bottom-4 right-4 flex gap-2 opacity-0 group-hover:opacity-100 transition-opacity\">\r\n <button className=\"p-2 bg-black/60 text-white rounded-full hover:bg-black/80\"><Download size={18} /></button>\r\n <button className=\"p-2 bg-black/60 text-white rounded-full hover:bg-black/80\"><Share2 size={18} /></button>\r\n </div>\r\n </div>\r\n ) : (\r\n <div className=\"text-center text-gray-500\">\r\n <Film size={48} className=\"mx-auto mb-4 opacity-20\" />\r\n <p className=\"text-sm\">Video preview will appear here</p>\r\n </div>\r\n )}\r\n </div>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Mic, MicOff, Volume2, Globe, Loader2, StopCircle } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface VoiceChatbotProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const VoiceChatbot: React.FC<VoiceChatbotProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [state, setState] = useState<'idle' | 'listening' | 'processing' | 'speaking'>('idle');\r\n const [transcript, setTranscript] = useState('');\r\n const [response, setResponse] = useState('');\r\n\r\n const toggleListen = () => {\r\n if (state === 'idle') {\r\n setState('listening');\r\n setTranscript('');\r\n setResponse('');\r\n // Simulate speech input\r\n setTimeout(() => {\r\n setTranscript(\"What's the weather like in Tokyo right now?\");\r\n setState('processing');\r\n }, 3000);\r\n } else {\r\n setState('idle');\r\n }\r\n };\r\n\r\n useEffect(() => {\r\n if (state === 'processing') {\r\n // Simulate AI thinking\r\n setTimeout(() => {\r\n setState('speaking');\r\n setResponse(\"Currently in Tokyo, it's mostly clear with a temperature of 18 degrees Celsius. Humidity is around 45%.\");\r\n }, 2000);\r\n }\r\n if (state === 'speaking') {\r\n // Simulate finished speaking\r\n setTimeout(() => {\r\n setState('idle');\r\n }, 5000);\r\n }\r\n }, [state]);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className={`\r\n w-full h-full p-8 flex flex-col items-center justify-between relative overflow-hidden transition-colors\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded shadow-xl' : ''}\r\n ${isApple ? 'bg-gray-100/50 dark:bg-gray-900/50 backdrop-blur-3xl rounded-[40px] border border-white/20' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n \r\n {/* Status Indicator */}\r\n <div className=\"absolute top-6 left-6 flex items-center gap-2\">\r\n <Globe size={16} className=\"text-gray-400\" />\r\n <span className=\"text-xs font-mono text-gray-500 uppercase\">{state}</span>\r\n </div>\r\n\r\n {/* Central Visualizer */}\r\n <div className=\"flex-1 flex items-center justify-center w-full relative\">\r\n \r\n {/* Ambient Glow */}\r\n <div className={`\r\n absolute w-64 h-64 rounded-full blur-[100px] opacity-20 transition-colors duration-700\r\n ${state === 'listening' ? 'bg-red-500' : state === 'speaking' ? 'bg-green-500' : state === 'processing' ? `${getColorShade(globalConfig, 'bg', 500)}` : 'bg-gray-400'}\r\n `} />\r\n\r\n {/* Orb / Waveform */}\r\n <div className={`\r\n w-32 h-32 rounded-full flex items-center justify-center transition-all duration-500 relative z-10\r\n ${state === 'listening' ? 'scale-110 shadow-[0_0_50px_rgba(239,68,68,0.4)]' : ''}\r\n ${state === 'speaking' ? 'scale-105 shadow-[0_0_50px_rgba(34,197,94,0.4)]' : ''}\r\n ${isApple ? 'bg-black/5 dark:bg-white/10 backdrop-blur-md border border-white/20' : ''}\r\n ${isCustom ? `border-2 ${getColorClass(globalConfig, 'border')}` : ''}\r\n `}>\r\n {state === 'processing' ? (\r\n <Loader2 size={40} className={`animate-spin ${isCustom ? getColorClass(globalConfig, 'text') : getColorShade(globalConfig, 'text', 500)}`} />\r\n ) : state === 'listening' ? (\r\n <div className=\"flex gap-1 h-12 items-center\">\r\n {[1,2,3,4,5].map(i => (\r\n <div key={i} className=\"w-1.5 bg-red-500 rounded-full animate-[bounce_1s_infinite]\" style={{ animationDelay: `${i * 0.1}s`, height: Math.random() * 40 + 10 + 'px' }} />\r\n ))}\r\n </div>\r\n ) : state === 'speaking' ? (\r\n <div className=\"flex gap-1 h-12 items-center\">\r\n {[1,2,3,4,5].map(i => (\r\n <div key={i} className=\"w-1.5 bg-green-500 rounded-full animate-[pulse_0.5s_infinite]\" style={{ animationDelay: `${i * 0.1}s`, height: '30px' }} />\r\n ))}\r\n </div>\r\n ) : (\r\n <MicOff size={32} className=\"text-gray-300 dark:text-gray-600\" />\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Text Output */}\r\n <div className=\"w-full text-center space-y-2 mb-8 min-h-[60px] z-10\">\r\n {transcript && (\r\n <p className=\"text-lg font-medium text-gray-800 dark:text-gray-200 animate-in fade-in slide-in-from-bottom-2\">\r\n \"{transcript}\"\r\n </p>\r\n )}\r\n {response && (\r\n <p className=\"text-sm text-gray-500 dark:text-gray-400 font-mono animate-in fade-in zoom-in-95\">\r\n {response}\r\n </p>\r\n )}\r\n </div>\r\n\r\n {/* Controls */}\r\n <button\r\n onClick={toggleListen}\r\n className={`\r\n w-full py-4 rounded-xl font-bold transition-all transform active:scale-95 flex items-center justify-center gap-2\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} text-white shadow-lg uppercase tracking-wider` : ''}\r\n ${isApple ? 'bg-white dark:bg-gray-800 text-black dark:text-white shadow-xl hover:shadow-2xl' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} text-white` : ''}\r\n `}\r\n >\r\n {state === 'listening' ? <StopCircle size={20}/> : <Mic size={20}/>}\r\n {state === 'listening' ? 'Stop Listening' : 'Tap to Speak'}\r\n </button>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Mic, MicOff } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface VoiceUIProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const VoiceUI: React.FC<VoiceUIProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isListening, setIsListening] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col items-center justify-center gap-8\">\r\n {/* Waveform Visualization (Mock) */}\r\n <div className={`h-16 flex items-center gap-1 ${isListening ? '' : 'opacity-20'}`}>\r\n {[...Array(12)].map((_, i) => (\r\n <div \r\n key={i} \r\n className={`w-1.5 rounded-full bg-current transition-all duration-100 ease-in-out ${isListening ? 'animate-pulse' : ''}`}\r\n style={{ \r\n height: isListening ? Math.max(20, Math.random() * 60) + 'px' : '4px',\r\n color: isCustom ? getColorClass(globalConfig, 'bg').split(' ')[0].replace('bg-', 'text-') : '#3b82f6'\r\n }}\r\n />\r\n ))}\r\n </div>\r\n\r\n {/* Mic Button */}\r\n <button\r\n onClick={() => setIsListening(!isListening)}\r\n className={`\r\n w-20 h-20 rounded-full flex items-center justify-center transition-all duration-300 relative\r\n ${isListening ? 'scale-110 shadow-[0_0_0_10px_rgba(59,130,246,0.2)]' : 'shadow-lg'}\r\n \r\n ${isMUI ? `bg-blue-600 text-white ${isListening ? 'bg-red-500' : ''}` : ''}\r\n \r\n ${isApple ? `bg-white dark:bg-gray-800 text-blue-500 ${isListening ? 'bg-gradient-to-tr from-blue-500 to-purple-600 text-white' : ''}` : ''}\r\n\r\n ${isCustom ? `${getRadiusClass(globalConfig)} ${isListening ? 'bg-red-500 text-white' : `${getColorClass(globalConfig, 'bg')} text-white`}` : ''}\r\n `}\r\n >\r\n {isListening ? <div className=\"w-8 h-8 bg-white rounded-sm\" /> : <Mic size={32} />}\r\n </button>\r\n\r\n <p className=\"text-gray-500 font-medium\">\r\n {isListening ? 'Listening...' : 'Tap to Speak'}\r\n </p>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Filter, Plus, X, ChevronDown } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface DataQueryProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const DataQuery: React.FC<DataQueryProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full min-h-[300px] flex flex-col\">\r\n <div className={`\r\n border p-4 flex-1 flex flex-col\r\n ${isMUI ? 'bg-white dark:bg-gray-900 rounded shadow-sm border-gray-200 dark:border-gray-700' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur rounded-xl border-gray-200/50 shadow-sm' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <div className=\"flex items-center justify-between mb-4\">\r\n <h3 className=\"text-sm font-semibold flex items-center gap-2\">\r\n <Filter size={16} /> Filter Builder\r\n </h3>\r\n <button className={`text-xs ${getColorShade(globalConfig, 'text', 600)} hover:underline`}>Clear All</button>\r\n </div>\r\n\r\n {/* Logic Group */}\r\n <div className=\"flex items-start gap-2 mb-3 flex-1 min-h-0 overflow-y-auto\">\r\n <div className={`w-16 h-8 flex items-center justify-center text-xs font-bold text-white rounded flex-shrink-0 ${getColorShade(globalConfig, 'bg', 600)}`}>AND</div>\r\n <div className=\"flex-1 space-y-2 min-w-0\">\r\n \r\n {/* Rule 1 */}\r\n <div className=\"flex items-center gap-2 flex-wrap\">\r\n <select className=\"text-xs p-1.5 border rounded bg-transparent min-w-[80px] flex-shrink-0\">\r\n <option>Name</option>\r\n <option>Email</option>\r\n <option>Status</option>\r\n </select>\r\n <select className=\"text-xs p-1.5 border rounded bg-transparent min-w-[80px] flex-shrink-0\">\r\n <option>Contains</option>\r\n <option>Equals</option>\r\n <option>Starts with</option>\r\n </select>\r\n <input type=\"text\" defaultValue=\"John\" className=\"text-xs p-1.5 border rounded flex-1 min-w-[100px] bg-transparent\" />\r\n <button className=\"text-gray-400 hover:text-red-500 flex-shrink-0\" title=\"Remove rule\"><X size={14} /></button>\r\n </div>\r\n\r\n {/* Rule 2 */}\r\n <div className=\"flex items-center gap-2 flex-wrap\">\r\n <select className=\"text-xs p-1.5 border rounded bg-transparent min-w-[80px] flex-shrink-0\">\r\n <option>Age</option>\r\n <option>Date</option>\r\n <option>Amount</option>\r\n </select>\r\n <select className=\"text-xs p-1.5 border rounded bg-transparent min-w-[80px] flex-shrink-0\">\r\n <option>Greater</option>\r\n <option>Less</option>\r\n <option>Equals</option>\r\n </select>\r\n <input type=\"number\" defaultValue=\"18\" className=\"text-xs p-1.5 border rounded flex-1 min-w-[100px] bg-transparent\" />\r\n <button className=\"text-gray-400 hover:text-red-500 flex-shrink-0\" title=\"Remove rule\"><X size={14} /></button>\r\n </div>\r\n\r\n {/* Add Rule Button */}\r\n <button className={`flex items-center gap-1 text-xs font-medium mt-2 ${getColorShade(globalConfig, 'text', 600)} hover:underline`}>\r\n <Plus size={12} /> Add Rule\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Pencil, Eraser, Trash2, Undo, Redo, Download } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade } from '../utils/styleUtils';\r\n\r\ninterface WhiteboardProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const Whiteboard: React.FC<WhiteboardProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const canvasRef = useRef<HTMLCanvasElement>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const historyRef = useRef<ImageData[]>([]);\r\n const historyStepRef = useRef<number>(-1);\r\n \r\n const [isDrawing, setIsDrawing] = useState(false);\r\n const [tool, setTool] = useState<'pen' | 'eraser'>('pen');\r\n const [color, setColor] = useState('#000000');\r\n const [lineWidth, setLineWidth] = useState(3);\r\n const [canUndo, setCanUndo] = useState(false);\r\n const [canRedo, setCanRedo] = useState(false);\r\n \r\n // Save canvas state to history\r\n const saveState = () => {\r\n const canvas = canvasRef.current;\r\n if (!canvas) return;\r\n const ctx = canvas.getContext('2d');\r\n if (!ctx) return;\r\n \r\n const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);\r\n historyStepRef.current += 1;\r\n historyRef.current = historyRef.current.slice(0, historyStepRef.current);\r\n historyRef.current.push(imageData);\r\n \r\n // Update undo/redo availability\r\n setCanUndo(historyStepRef.current > 0);\r\n setCanRedo(false);\r\n };\r\n\r\n // Initialize canvas size\r\n useEffect(() => {\r\n const canvas = canvasRef.current;\r\n const container = containerRef.current;\r\n if (canvas && container) {\r\n const resizeCanvas = () => {\r\n // Set canvas size to match container\r\n canvas.width = container.offsetWidth;\r\n canvas.height = container.offsetHeight;\r\n \r\n // Default styles\r\n const ctx = canvas.getContext('2d');\r\n if (ctx) {\r\n ctx.lineCap = 'round';\r\n ctx.lineJoin = 'round';\r\n ctx.fillStyle = 'transparent';\r\n ctx.fillRect(0, 0, canvas.width, canvas.height);\r\n }\r\n \r\n // Save initial state\r\n saveState();\r\n };\r\n \r\n resizeCanvas();\r\n \r\n // Handle window resize\r\n const resizeObserver = new ResizeObserver(() => {\r\n resizeCanvas();\r\n });\r\n \r\n resizeObserver.observe(container);\r\n \r\n return () => {\r\n resizeObserver.disconnect();\r\n };\r\n }\r\n }, []);\r\n\r\n // Update undo/redo state when history changes\r\n useEffect(() => {\r\n setCanUndo(historyStepRef.current > 0);\r\n setCanRedo(historyStepRef.current < historyRef.current.length - 1);\r\n }, [isDrawing]);\r\n\r\n const startDrawing = (e: React.MouseEvent<HTMLCanvasElement> | React.TouchEvent<HTMLCanvasElement>) => {\r\n setIsDrawing(true);\r\n const canvas = canvasRef.current;\r\n if (!canvas) return;\r\n \r\n const ctx = canvas.getContext('2d');\r\n if (!ctx) return;\r\n\r\n // Save state before drawing\r\n saveState();\r\n\r\n const { offsetX, offsetY } = getCoordinates(e, canvas);\r\n \r\n ctx.beginPath();\r\n ctx.moveTo(offsetX, offsetY);\r\n ctx.strokeStyle = tool === 'eraser' ? '#ffffff' : color;\r\n ctx.lineWidth = lineWidth;\r\n \r\n // For eraser, we actually want to clear, but \"painting white\" is simpler for a demo unless transparent background is critical.\r\n // If we want transparency eraser:\r\n if (tool === 'eraser') {\r\n ctx.globalCompositeOperation = 'destination-out';\r\n } else {\r\n ctx.globalCompositeOperation = 'source-over';\r\n }\r\n };\r\n\r\n const draw = (e: React.MouseEvent<HTMLCanvasElement> | React.TouchEvent<HTMLCanvasElement>) => {\r\n if (!isDrawing) return;\r\n const canvas = canvasRef.current;\r\n if (!canvas) return;\r\n \r\n const ctx = canvas.getContext('2d');\r\n if (!ctx) return;\r\n\r\n const { offsetX, offsetY } = getCoordinates(e, canvas);\r\n \r\n ctx.lineTo(offsetX, offsetY);\r\n ctx.stroke();\r\n };\r\n\r\n const stopDrawing = () => {\r\n setIsDrawing(false);\r\n const canvas = canvasRef.current;\r\n if (canvas) {\r\n const ctx = canvas.getContext('2d');\r\n if (ctx) ctx.closePath();\r\n }\r\n };\r\n\r\n const getCoordinates = (e: React.MouseEvent | React.TouchEvent, canvas: HTMLCanvasElement) => {\r\n let clientX, clientY;\r\n if ('touches' in e) {\r\n clientX = e.touches[0].clientX;\r\n clientY = e.touches[0].clientY;\r\n } else {\r\n clientX = (e as React.MouseEvent).clientX;\r\n clientY = (e as React.MouseEvent).clientY;\r\n }\r\n \r\n const rect = canvas.getBoundingClientRect();\r\n return {\r\n offsetX: clientX - rect.left,\r\n offsetY: clientY - rect.top\r\n };\r\n };\r\n\r\n const clearCanvas = () => {\r\n const canvas = canvasRef.current;\r\n if (canvas) {\r\n saveState();\r\n const ctx = canvas.getContext('2d');\r\n if (ctx) {\r\n ctx.clearRect(0, 0, canvas.width, canvas.height);\r\n }\r\n }\r\n };\r\n\r\n const undo = () => {\r\n const canvas = canvasRef.current;\r\n if (!canvas || historyStepRef.current <= 0) return;\r\n \r\n historyStepRef.current -= 1;\r\n const ctx = canvas.getContext('2d');\r\n if (ctx && historyRef.current[historyStepRef.current]) {\r\n ctx.putImageData(historyRef.current[historyStepRef.current], 0, 0);\r\n }\r\n \r\n // Update undo/redo availability\r\n setCanUndo(historyStepRef.current > 0);\r\n setCanRedo(historyStepRef.current < historyRef.current.length - 1);\r\n };\r\n\r\n const redo = () => {\r\n const canvas = canvasRef.current;\r\n if (!canvas || historyStepRef.current >= historyRef.current.length - 1) return;\r\n \r\n historyStepRef.current += 1;\r\n const ctx = canvas.getContext('2d');\r\n if (ctx && historyRef.current[historyStepRef.current]) {\r\n ctx.putImageData(historyRef.current[historyStepRef.current], 0, 0);\r\n }\r\n \r\n // Update undo/redo availability\r\n setCanUndo(historyStepRef.current > 0);\r\n setCanRedo(historyStepRef.current < historyRef.current.length - 1);\r\n };\r\n\r\n const downloadCanvas = () => {\r\n const canvas = canvasRef.current;\r\n if (!canvas) return;\r\n \r\n const link = document.createElement('a');\r\n link.download = `whiteboard-${Date.now()}.png`;\r\n link.href = canvas.toDataURL('image/png');\r\n link.click();\r\n };\r\n\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full flex flex-col relative\">\r\n \r\n {/* Toolbar */}\r\n <div className={`\r\n absolute top-3 sm:top-4 left-1/2 transform -translate-x-1/2 z-10 flex items-center gap-2 sm:gap-3 p-2 sm:p-3 flex-wrap justify-center max-w-[calc(100%-24px)] sm:max-w-none\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-lg border border-gray-300 dark:border-gray-700 rounded-lg' : ''}\r\n ${isApple ? 'bg-white/90 dark:bg-gray-900/90 backdrop-blur-xl shadow-xl border border-gray-200/50 dark:border-gray-700/50 rounded-full px-3 sm:px-5' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 shadow-md ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n {/* Tools */}\r\n <div className=\"flex items-center gap-1 sm:gap-1.5 border-r border-gray-200 dark:border-gray-700 pr-2 sm:pr-3 mr-2 sm:mr-3\">\r\n <button \r\n onClick={() => setTool('pen')}\r\n className={`p-2 sm:p-2.5 rounded-md transition-all ${\r\n tool === 'pen' \r\n ? `${getColorShade(globalConfig, 'bg', 100)} ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'bg', 900)}/30 dark:${getColorShade(globalConfig, 'text', 400)} shadow-sm` \r\n : 'text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800'\r\n }`}\r\n title=\"Pen Tool\"\r\n >\r\n <Pencil size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n <button \r\n onClick={() => setTool('eraser')}\r\n className={`p-2 sm:p-2.5 rounded-md transition-all ${\r\n tool === 'eraser' \r\n ? `${getColorShade(globalConfig, 'bg', 100)} ${getColorShade(globalConfig, 'text', 600)} dark:${getColorShade(globalConfig, 'bg', 900)}/30 dark:${getColorShade(globalConfig, 'text', 400)} shadow-sm` \r\n : 'text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800'\r\n }`}\r\n title=\"Eraser Tool\"\r\n >\r\n <Eraser size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n </div>\r\n\r\n {/* Colors */}\r\n <div className=\"flex items-center gap-1.5 sm:gap-2 border-r border-gray-200 dark:border-gray-700 pr-2 sm:pr-3 mr-2 sm:mr-3\">\r\n {['#000000', '#ef4444', '#3b82f6', '#10b981'].map(c => {\r\n const isActive = color === c && tool === 'pen';\r\n const ringColor = getColorShade(globalConfig, 'border', 500).replace('border-', 'ring-');\r\n return (\r\n <button \r\n key={c}\r\n onClick={() => { setColor(c); setTool('pen'); }}\r\n className={`w-6 h-6 sm:w-7 sm:h-7 rounded-full border-2 shadow-md transition-all flex-shrink-0 ${\r\n isActive \r\n ? `scale-110 ring-2 ring-offset-2 ${ringColor} border-gray-400 dark:border-gray-500` \r\n : 'border-gray-300 dark:border-gray-600 hover:scale-110'\r\n }`}\r\n style={{ backgroundColor: c }}\r\n title={`Color: ${c}`}\r\n />\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Width */}\r\n <div className=\"flex items-center gap-1.5 sm:gap-2 border-r border-gray-200 dark:border-gray-700 pr-2 sm:pr-3 mr-2 sm:mr-3\">\r\n {[2, 4, 8].map(w => (\r\n <button\r\n key={w}\r\n onClick={() => setLineWidth(w)}\r\n className={`w-7 h-7 sm:w-9 sm:h-9 flex items-center justify-center rounded-md transition-all flex-shrink-0 ${\r\n lineWidth === w \r\n ? 'bg-gray-200 dark:bg-gray-700 shadow-inner' \r\n : 'hover:bg-gray-100 dark:hover:bg-gray-800'\r\n }`}\r\n title={`Line width: ${w}px`}\r\n >\r\n <div className=\"bg-gray-800 dark:bg-gray-300 rounded-full\" style={{ width: Math.max(w, 2), height: Math.max(w, 2) }} />\r\n </button>\r\n ))}\r\n </div>\r\n\r\n {/* Actions */}\r\n <div className=\"flex items-center gap-1 sm:gap-1.5\">\r\n <button \r\n onClick={undo} \r\n disabled={!canUndo}\r\n className={`p-2 sm:p-2.5 rounded-md transition-all flex-shrink-0 ${\r\n canUndo \r\n ? 'text-gray-600 dark:text-gray-400 hover:text-gray-800 hover:bg-gray-100 dark:hover:bg-gray-800 dark:hover:text-gray-200' \r\n : 'text-gray-300 dark:text-gray-700 cursor-not-allowed'\r\n }`}\r\n title=\"Undo\"\r\n >\r\n <Undo size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n <button \r\n onClick={redo} \r\n disabled={!canRedo}\r\n className={`p-2 sm:p-2.5 rounded-md transition-all flex-shrink-0 ${\r\n canRedo \r\n ? 'text-gray-600 dark:text-gray-400 hover:text-gray-800 hover:bg-gray-100 dark:hover:bg-gray-800 dark:hover:text-gray-200' \r\n : 'text-gray-300 dark:text-gray-700 cursor-not-allowed'\r\n }`}\r\n title=\"Redo\"\r\n >\r\n <Redo size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n <button \r\n onClick={clearCanvas} \r\n className=\"p-2 sm:p-2.5 text-gray-600 dark:text-gray-400 hover:text-red-600 hover:bg-red-50 dark:hover:bg-red-900/20 dark:hover:text-red-400 rounded-md transition-all flex-shrink-0\" \r\n title=\"Clear Canvas\"\r\n >\r\n <Trash2 size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n <button \r\n onClick={downloadCanvas} \r\n className=\"p-2 sm:p-2.5 text-gray-600 dark:text-gray-400 hover:text-blue-600 hover:bg-blue-50 dark:hover:bg-blue-900/20 dark:hover:text-blue-400 rounded-md transition-all flex-shrink-0\" \r\n title=\"Download\"\r\n >\r\n <Download size={18} className=\"sm:w-5 sm:h-5\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Canvas Container */}\r\n <div \r\n ref={containerRef}\r\n className={`\r\n w-full h-full relative overflow-hidden bg-white dark:bg-gray-900\r\n ${isMUI ? 'border border-gray-300 rounded-sm' : ''}\r\n ${isApple ? 'border border-gray-200 dark:border-gray-800 rounded-2xl shadow-inner' : ''}\r\n ${isCustom ? `border border-gray-200 dark:border-gray-800 ${getRadiusClass(globalConfig)}` : ''}\r\n `}\r\n >\r\n {/* Grid Background */}\r\n <div \r\n className=\"absolute inset-0 pointer-events-none opacity-20 dark:opacity-10\"\r\n style={{\r\n backgroundImage: `\r\n linear-gradient(to right, #9ca3af 1px, transparent 1px),\r\n linear-gradient(to bottom, #9ca3af 1px, transparent 1px)\r\n `,\r\n backgroundSize: '20px 20px'\r\n }}\r\n />\r\n\r\n <canvas\r\n ref={canvasRef}\r\n onMouseDown={startDrawing}\r\n onMouseMove={draw}\r\n onMouseUp={stopDrawing}\r\n onMouseLeave={stopDrawing}\r\n onTouchStart={startDrawing}\r\n onTouchMove={draw}\r\n onTouchEnd={stopDrawing}\r\n className=\"absolute inset-0 cursor-crosshair touch-none\"\r\n />\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { QrCode as QrIcon } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface QRCodeProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const QRCode: React.FC<QRCodeProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Mock Data generation for QR Pattern (Visual only)\r\n const generatePattern = () => {\r\n const rows = [];\r\n for(let i=0; i<15; i++) {\r\n const cells = [];\r\n for(let j=0; j<15; j++) {\r\n // Corner markers (Finders)\r\n const isCorner = (i < 4 && j < 4) || (i < 4 && j > 10) || (i > 10 && j < 4);\r\n const isPixel = Math.random() > 0.5 || isCorner;\r\n cells.push(\r\n <div \r\n key={`${i}-${j}`} \r\n className={`w-1.5 h-1.5 ${isPixel ? (isCorner ? 'bg-black dark:bg-white' : 'bg-gray-800 dark:bg-gray-200') : 'bg-transparent'}`} \r\n />\r\n );\r\n }\r\n rows.push(<div key={i} className=\"flex\">{cells}</div>);\r\n }\r\n return rows;\r\n };\r\n\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div style={appliedStyles} className=\"w-full h-full min-h-[300px] flex flex-col items-center justify-center gap-4\">\r\n <div className={`\r\n p-4 bg-white dark:bg-white rounded-xl shadow-sm border border-gray-200 flex-shrink-0\r\n ${isCustom ? getRadiusClass(globalConfig) : ''}\r\n `}>\r\n <div className=\"relative\">\r\n {/* Simplified SVG Mock */}\r\n <div className=\"w-32 h-32 flex flex-col items-center justify-center bg-white\">\r\n {generatePattern()}\r\n </div>\r\n \r\n {/* Center Logo */}\r\n {designSystem !== 'MUI' && (\r\n <div className=\"absolute inset-0 flex items-center justify-center\">\r\n <div className=\"w-8 h-8 bg-white rounded-full flex items-center justify-center p-1 shadow-sm\">\r\n <div className={`w-full h-full rounded-full ${getColorClass(globalConfig, 'bg')}`} />\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n <p className=\"text-sm font-mono text-gray-500\">SCAN ME</p>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Wifi, CreditCard as CardIcon } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface CreditCardProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const CreditCard: React.FC<CreditCardProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const [isFlipped, setIsFlipped] = useState(false);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n const cardBaseClasses = `\r\n w-full max-w-[340px] aspect-[1.586/1] rounded-xl relative transition-all duration-500 transform [transform-style:preserve-3d] cursor-pointer shadow-xl\r\n ${isFlipped ? '[transform:rotateY(180deg)]' : ''}\r\n `;\r\n\r\n // Styling based on Design System\r\n const getCardStyle = () => {\r\n if (isMUI) return 'bg-gradient-to-br from-gray-800 to-black text-white border border-gray-700';\r\n if (isApple) return 'bg-gradient-to-br from-white to-gray-200 text-gray-800 border border-gray-300 shadow-sm';\r\n // Custom: Uses primary color gradient\r\n return 'text-white border-transparent';\r\n };\r\n\r\n const getCardGradient = () => {\r\n if (isCustom) {\r\n const primaryColor = getColorValue(globalConfig, 'primary', 600);\r\n const primaryColorDark = getColorValue(globalConfig, 'primary', 800);\r\n return {\r\n background: `linear-gradient(to bottom right, ${primaryColor}, ${primaryColorDark})`\r\n };\r\n }\r\n return {};\r\n };\r\n\r\n return (\r\n <div style={{ perspective: '1000px' }} onClick={() => setIsFlipped(!isFlipped)}>\r\n <div \r\n style={{ ...appliedStyles, ...getCardGradient() }}\r\n className={`${cardBaseClasses} ${getCardStyle()}`}\r\n >\r\n {/* Front Face */}\r\n <div className=\"absolute inset-0 [backface-visibility:hidden] p-6 flex flex-col justify-between\">\r\n {/* Header: Chip & Wifi */}\r\n <div className=\"flex justify-between items-start\">\r\n <div className=\"w-10 h-8 bg-yellow-500/20 rounded border border-yellow-500/50 flex items-center justify-center relative overflow-hidden\">\r\n <div className=\"absolute inset-0 grid grid-cols-2 grid-rows-2\">\r\n <div className=\"border-r border-b border-yellow-600/30\"></div>\r\n <div className=\"border-b border-yellow-600/30\"></div>\r\n <div className=\"border-r border-yellow-600/30\"></div>\r\n <div className=\"\"></div>\r\n </div>\r\n </div>\r\n <Wifi size={20} className=\"opacity-70\" />\r\n </div>\r\n\r\n {/* Card Number */}\r\n <div className=\"text-xl font-mono tracking-widest mt-4 drop-shadow-md break-words\">\r\n <div className=\"flex items-center gap-2\">\r\n <span>4242</span>\r\n <span>4242</span>\r\n <span>4242</span>\r\n <span>4242</span>\r\n </div>\r\n </div>\r\n\r\n {/* Footer: Name & Expiry & Logo */}\r\n <div className=\"flex justify-between items-end\">\r\n <div className=\"flex flex-col gap-1\">\r\n <span className=\"text-[10px] uppercase opacity-70 tracking-wider\">Card Holder</span>\r\n <span className=\"text-sm font-medium tracking-wide uppercase\">John Doe</span>\r\n </div>\r\n <div className=\"flex flex-col gap-1 mr-4\">\r\n <span className=\"text-[10px] uppercase opacity-70 tracking-wider\">Expires</span>\r\n <span className=\"text-sm font-medium tracking-wide\">12/28</span>\r\n </div>\r\n \r\n {/* Logo Mock */}\r\n <div className=\"flex -space-x-2\">\r\n <div className=\"w-8 h-8 rounded-full bg-red-500/80 mix-blend-hard-light\"></div>\r\n <div className=\"w-8 h-8 rounded-full bg-yellow-500/80 mix-blend-hard-light\"></div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Back Face */}\r\n <div \r\n style={getCardGradient()}\r\n className={`absolute inset-0 [backface-visibility:hidden] [transform:rotateY(180deg)] rounded-xl overflow-hidden ${getCardStyle()}`}\r\n >\r\n <div className=\"w-full h-10 bg-black mt-6 opacity-80\"></div>\r\n \r\n <div className=\"px-6 mt-4\">\r\n <div className=\"w-full h-8 bg-white/30 rounded flex items-center justify-end px-2\">\r\n <span className=\"font-mono text-black text-sm italic pr-2\">CVC</span>\r\n <span className=\"font-mono text-black font-bold\">123</span>\r\n </div>\r\n <p className=\"text-[8px] mt-4 opacity-70 text-justify leading-tight\">\r\n This card is property of the issuing bank and must be returned upon request. \r\n Use of this card is governed by the cardholder agreement. \r\n If found, please return to any branch of OpenGrid Bank.\r\n </p>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <p className=\"text-center mt-8 text-xs text-gray-500 animate-pulse\">Click card to flip</p>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useEffect, useRef, useState } from 'react';\r\nimport { AnimationConfig, GlobalConfig } from '../types';\r\nimport { Play } from 'lucide-react';\r\nimport { getColorShade, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface AnimationPreviewProps {\r\n config: AnimationConfig;\r\n globalConfig?: GlobalConfig;\r\n}\r\n\r\nexport const AnimationPreview: React.FC<AnimationPreviewProps> = ({ config, globalConfig }) => {\r\n const defaultGlobalConfig: GlobalConfig = globalConfig || { primaryColor: 'blue', baseRadius: 8 };\r\n const [isPlaying, setIsPlaying] = useState(true);\r\n const [points, setPoints] = useState<{x: number, y: number}[]>([]);\r\n const [variant, setVariant] = useState<'translate' | 'rotate' | 'scale' | 'fade' | 'slide' | 'bounce'>('translate');\r\n const ballRef = useRef<HTMLDivElement>(null);\r\n \r\n // Math Solvers\r\n const solveSpring = (stiffness: number, damping: number, mass: number, velocity: number) => {\r\n const pts = [];\r\n let position = 0;\r\n let v = velocity;\r\n const dt = 1/60;\r\n for (let i = 0; i < 120; i++) {\r\n const force = -stiffness * (position - 1) - damping * v;\r\n const acceleration = force / mass;\r\n v += acceleration * dt;\r\n position += v * dt;\r\n pts.push({ x: (i/120)*100, y: position });\r\n }\r\n return pts;\r\n };\r\n\r\n const solveBezier = (p1x: number, p1y: number, p2x: number, p2y: number) => {\r\n const pts = [];\r\n // Simplified bezier sampling\r\n for (let t = 0; t <= 1; t += 0.01) {\r\n // Cubic Bezier formula B(t) = (1-t)^3 P0 + 3(1-t)^2 t P1 + 3(1-t) t^2 P2 + t^3 P3\r\n // P0=(0,0), P3=(1,1)\r\n const cx = 3 * p1x;\r\n const bx = 3 * (p2x - p1x) - cx;\r\n const ax = 1 - cx - bx;\r\n \r\n const cy = 3 * p1y;\r\n const by = 3 * (p2y - p1y) - cy;\r\n const ay = 1 - cy - by;\r\n\r\n const x = ((ax * t + bx) * t + cx) * t;\r\n const y = ((ay * t + by) * t + cy) * t;\r\n pts.push({ x: x * 100, y: y });\r\n }\r\n return pts;\r\n };\r\n\r\n const solvePenner = (name: string) => {\r\n const pts = [];\r\n for (let t = 0; t <= 1; t += 0.01) {\r\n let y = 0;\r\n switch (name) {\r\n case 'inSine': y = 1 - Math.cos((t * Math.PI) / 2); break;\r\n case 'outSine': y = Math.sin((t * Math.PI) / 2); break;\r\n case 'inOutSine': y = -(Math.cos(Math.PI * t) - 1) / 2; break;\r\n case 'inExpo': y = t === 0 ? 0 : Math.pow(2, 10 * t - 10); break;\r\n case 'outExpo': y = t === 1 ? 1 : 1 - Math.pow(2, -10 * t); break;\r\n case 'inOutExpo': \r\n y = t === 0 ? 0 : t === 1 ? 1 : t < 0.5 ? Math.pow(2, 20 * t - 10) / 2 : (2 - Math.pow(2, -20 * t + 10)) / 2; break;\r\n case 'inCirc': y = 1 - Math.sqrt(1 - Math.pow(t, 2)); break;\r\n case 'outCirc': y = Math.sqrt(1 - Math.pow(t - 1, 2)); break;\r\n case 'inOutCirc': y = t < 0.5 ? (1 - Math.sqrt(1 - Math.pow(2 * t, 2))) / 2 : (Math.sqrt(1 - Math.pow(-2 * t + 2, 2)) + 1) / 2; break;\r\n case 'inBack': { const c1 = 1.70158; const c3 = c1 + 1; y = c3 * t * t * t - c1 * t * t; break; }\r\n case 'outBack': { const c1 = 1.70158; const c3 = c1 + 1; y = 1 + c3 * Math.pow(t - 1, 3) + c1 * Math.pow(t - 1, 2); break; }\r\n case 'inOutBack': { const c1 = 1.70158; const c2 = c1 * 1.525; y = t < 0.5 ? (Math.pow(2 * t, 2) * ((c2 + 1) * 2 * t - c2)) / 2 : (Math.pow(2 * t - 2, 2) * ((c2 + 1) * (t * 2 - 2) + c2) + 2) / 2; break; }\r\n case 'inElastic': { const c4 = (2 * Math.PI) / 3; y = t === 0 ? 0 : t === 1 ? 1 : -Math.pow(2, 10 * t - 10) * Math.sin((t * 10 - 10.75) * c4); break; }\r\n case 'outElastic': { const c4 = (2 * Math.PI) / 3; y = t === 0 ? 0 : t === 1 ? 1 : Math.pow(2, -10 * t) * Math.sin((t * 10 - 0.75) * c4) + 1; break; }\r\n case 'inBounce': { y = 1 - bounceOut(1 - t); break; }\r\n case 'outBounce': { y = bounceOut(t); break; }\r\n case 'inOutBounce': { y = t < 0.5 ? (1 - bounceOut(1 - 2 * t)) / 2 : (1 + bounceOut(2 * t - 1)) / 2; break; }\r\n default: y = t;\r\n }\r\n pts.push({ x: t * 100, y });\r\n }\r\n return pts;\r\n };\r\n\r\n const bounceOut = (x: number) => {\r\n const n1 = 7.5625;\r\n const d1 = 2.75;\r\n if (x < 1 / d1) return n1 * x * x;\r\n else if (x < 2 / d1) return n1 * (x -= 1.5 / d1) * x + 0.75;\r\n else if (x < 2.5 / d1) return n1 * (x -= 2.25 / d1) * x + 0.9375;\r\n else return n1 * (x -= 2.625 / d1) * x + 0.984375;\r\n };\r\n\r\n // Calculate Points based on config\r\n useEffect(() => {\r\n let newPoints: {x: number, y: number}[] = [];\r\n if (config.type === 'spring') {\r\n newPoints = solveSpring(config.stiffness, config.damping, config.mass, config.velocity);\r\n } else if (config.type === 'easing') {\r\n if (config.preset.startsWith('bezier')) {\r\n // Simplified hardcoded mapping for bezier presets\r\n if (config.preset === 'bezier-in') newPoints = solveBezier(0.42, 0, 1, 1);\r\n else if (config.preset === 'bezier-out') newPoints = solveBezier(0, 0, 0.58, 1);\r\n else if (config.preset === 'bezier-in-out') newPoints = solveBezier(0.42, 0, 0.58, 1);\r\n else if (config.preset === 'bezier-out-in') newPoints = solveBezier(0, 0.42, 1, 0.58); // Approx\r\n } else {\r\n newPoints = solvePenner(config.preset);\r\n }\r\n } else if (config.type === 'steps') {\r\n const steps = 5; \r\n const isStart = config.preset === 'steps-start';\r\n for (let t = 0; t <= 1; t += 0.01) {\r\n let y = isStart ? Math.ceil(t * steps) / steps : Math.floor(t * steps) / steps;\r\n if (isStart && t === 0) y = 0; // Fix start 0\r\n if (!isStart && t === 1) y = 1; // Fix end 1\r\n newPoints.push({ x: t * 100, y });\r\n }\r\n }\r\n setPoints(newPoints);\r\n setIsPlaying(true);\r\n }, [config, variant]);\r\n\r\n // Auto-play on mount and config change\r\n useEffect(() => {\r\n setIsPlaying(true);\r\n }, [config, variant]);\r\n\r\n // Animation Loop using requestAnimationFrame\r\n useEffect(() => {\r\n if (!isPlaying || points.length === 0) return;\r\n \r\n let startTime: number;\r\n const duration = config.duration || 1000;\r\n \r\n const animate = (time: number) => {\r\n if (!startTime) startTime = time;\r\n const progress = (time - startTime) / duration;\r\n \r\n if (progress >= 1) {\r\n // Reset and loop\r\n setIsPlaying(false);\r\n setTimeout(() => setIsPlaying(true), 100);\r\n return;\r\n }\r\n\r\n // Interpolate Y value from pre-calculated points based on progress X (0-100)\r\n const currentX = progress * 100;\r\n // Find closest point\r\n const point = points.reduce((prev, curr) => Math.abs(curr.x - currentX) < Math.abs(prev.x - currentX) ? curr : prev);\r\n \r\n if (ballRef.current) {\r\n const maxDist = 300;\r\n let transform = '';\r\n \r\n switch (variant) {\r\n case 'translate':\r\n transform = `translateX(${point.y * maxDist}px)`;\r\n break;\r\n case 'rotate':\r\n transform = `rotate(${point.y * 360}deg)`;\r\n break;\r\n case 'scale':\r\n transform = `scale(${0.5 + point.y * 0.5})`;\r\n break;\r\n case 'fade':\r\n transform = `translateX(${point.y * maxDist}px)`;\r\n ballRef.current.style.opacity = `${point.y}`;\r\n break;\r\n case 'slide':\r\n transform = `translateX(${point.y * maxDist}px) translateY(${Math.sin(point.y * Math.PI) * 50}px)`;\r\n break;\r\n case 'bounce':\r\n const bounceY = point.y > 1 ? 1 - (point.y - 1) * 0.3 : point.y;\r\n transform = `translateX(${point.y * maxDist}px) translateY(${(1 - bounceY) * 100}px)`;\r\n break;\r\n default:\r\n transform = `translateX(${point.y * maxDist}px)`;\r\n }\r\n \r\n ballRef.current.style.transform = transform;\r\n if (variant !== 'fade') {\r\n ballRef.current.style.opacity = '1';\r\n }\r\n }\r\n\r\n requestAnimationFrame(animate);\r\n };\r\n\r\n requestAnimationFrame(animate);\r\n }, [isPlaying, points, config.duration, variant]);\r\n\r\n const handlePlay = () => {\r\n if (ballRef.current) ballRef.current.style.transform = 'translateX(0)';\r\n setIsPlaying(false);\r\n setTimeout(() => setIsPlaying(true), 50);\r\n };\r\n\r\n const generatePath = () => {\r\n if (points.length === 0) return '';\r\n const startY = 150; // Baseline\r\n const targetY = 50; // Target (1.0)\r\n const range = startY - targetY;\r\n\r\n return points.map((p, i) => {\r\n const x = (p.x / 100) * 400; \r\n const y = startY - (p.y * range);\r\n return `${i === 0 ? 'M' : 'L'} ${x} ${y}`;\r\n }).join(' ');\r\n };\r\n\r\n return (\r\n <div className=\"w-full h-full flex flex-col gap-8 text-gray-800 dark:text-gray-200 overflow-y-auto items-center px-4 py-6\">\r\n {/* Variant Selector */}\r\n <div className=\"flex flex-wrap gap-2 justify-center w-full max-w-5xl\">\r\n {(['translate', 'rotate', 'scale', 'fade', 'slide', 'bounce'] as const).map((v) => (\r\n <button\r\n key={v}\r\n onClick={() => setVariant(v)}\r\n className={`px-4 py-2 text-sm rounded-lg font-semibold transition-all capitalize border shadow-sm ${\r\n variant === v\r\n ? `${getColorShade(defaultGlobalConfig, 'bg', 600)} text-white border-transparent`\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-200 border-gray-200 dark:border-gray-700 hover:bg-gray-200 dark:hover:bg-gray-700'\r\n }`}\r\n >\r\n {v}\r\n </button>\r\n ))}\r\n </div>\r\n\r\n {/* Graph card with chrome header */}\r\n <div className=\"w-full max-w-5xl bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 rounded-xl shadow-sm overflow-hidden\">\r\n <div className=\"flex items-center justify-between px-3 py-2 border-b border-gray-200 dark:border-gray-800 bg-gray-50 dark:bg-gray-900/70\">\r\n <div className=\"flex items-center gap-1.5\">\r\n <span className=\"w-2.5 h-2.5 rounded-full bg-red-400\" />\r\n <span className=\"w-2.5 h-2.5 rounded-full bg-yellow-400\" />\r\n <span className=\"w-2.5 h-2.5 rounded-full bg-green-400\" />\r\n </div>\r\n <div className=\"text-[11px] text-gray-500 dark:text-gray-400 font-mono\">1024px</div>\r\n </div>\r\n\r\n <div className=\"p-6 flex flex-col gap-6\">\r\n <div className=\"relative w-full h-56 bg-gray-900 rounded-xl overflow-hidden shadow-inner border border-gray-800\">\r\n <div\r\n className=\"absolute inset-0 opacity-20\"\r\n style={{\r\n backgroundImage:\r\n 'linear-gradient(rgba(255,255,255,0.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.08) 1px, transparent 1px)',\r\n backgroundSize: '20px 20px',\r\n }}\r\n />\r\n <div className=\"absolute left-0 right-0 top-[150px] h-px bg-white/10\" />\r\n <div className={`absolute left-0 right-0 top-[50px] h-px ${getColorShade(defaultGlobalConfig, 'bg', 500)}/50`} />\r\n\r\n <svg viewBox=\"0 0 400 200\" className=\"w-full h-full\" preserveAspectRatio=\"none\">\r\n <path\r\n d={generatePath()}\r\n fill=\"none\"\r\n stroke={getColorValue(defaultGlobalConfig, 'primary', 400)}\r\n strokeWidth=\"3\"\r\n strokeLinecap=\"round\"\r\n strokeLinejoin=\"round\"\r\n style={{ filter: `drop-shadow(0 0 10px ${getColorValue(defaultGlobalConfig, 'primary', 400)}80)` }}\r\n />\r\n </svg>\r\n </div>\r\n\r\n {/* Preview with replay */}\r\n <div className=\"flex items-center justify-between\">\r\n <h3 className=\"text-lg font-bold\">Preview</h3>\r\n <button\r\n onClick={handlePlay}\r\n className={`flex items-center gap-2 px-4 py-2 rounded-md text-sm font-semibold shadow-sm ${getColorShade(defaultGlobalConfig, 'bg', 600)} ${getColorShade(defaultGlobalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} text-white transition-colors`}\r\n >\r\n <Play size={16} fill=\"currentColor\" /> Replay\r\n </button>\r\n </div>\r\n\r\n <div\r\n className={`h-32 bg-gray-50 dark:bg-gray-900 rounded-xl border border-gray-200 dark:border-gray-800 flex items-center px-12 overflow-hidden relative ${\r\n variant === 'rotate' || variant === 'scale' ? 'justify-center' : ''\r\n }`}\r\n >\r\n <div className=\"absolute left-12 top-0 bottom-0 w-px border-l border-dashed border-gray-300 dark:border-gray-600 opacity-40\"></div>\r\n <div className=\"absolute left-[calc(12px+300px)] top-0 bottom-0 w-px border-l border-dashed border-gray-300 dark:border-gray-600 opacity-50\"></div>\r\n\r\n <div\r\n ref={ballRef}\r\n className={`w-12 h-12 ${getColorShade(defaultGlobalConfig, 'bg', 500)} rounded-full shadow-lg relative z-10 will-change-transform ${\r\n variant === 'fade' ? 'transition-opacity duration-75' : ''\r\n }`}\r\n style={variant === 'fade' ? {} : { opacity: 1 }}\r\n ></div>\r\n </div>\r\n\r\n {/* Code snippet */}\r\n <div className=\"bg-gray-900 rounded-lg p-4 font-mono text-sm text-gray-200 overflow-x-auto border border-gray-800\">\r\n <pre>{`// Configuration\r\n${JSON.stringify(config, null, 2)}`}</pre>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","import React, { useMemo, useState } from 'react';\r\nimport { Search, X, Smartphone, MonitorSmartphone, SlidersHorizontal } from 'lucide-react';\r\nimport { GlobalConfig } from '../types';\r\nimport { getColorClass, getColorShade } from '../utils/styleUtils';\r\n\r\ntype EmojiPlatform = 'auto' | 'ios' | 'android';\r\n\r\ninterface EmojiItem {\r\n name: string;\r\n emoji: string;\r\n keywords: string[];\r\n categories: string[];\r\n}\r\n\r\ninterface EmojisPreviewProps {\r\n hideInstructions?: boolean;\r\n globalConfig?: GlobalConfig;\r\n}\r\n\r\nconst EMOJI_DATA: EmojiItem[] = [\r\n { name: 'Smile', emoji: '😊', keywords: ['happy', 'face', 'smile'], categories: ['Smileys'] },\r\n { name: 'Laugh', emoji: '😂', keywords: ['joy', 'lol', 'laugh'], categories: ['Smileys'] },\r\n { name: 'Wink', emoji: '😉', keywords: ['wink', 'friendly'], categories: ['Smileys'] },\r\n { name: 'Heart Eyes', emoji: '😍', keywords: ['love', 'heart'], categories: ['Smileys'] },\r\n { name: 'Thumbs Up', emoji: '👍', keywords: ['like', 'approve'], categories: ['Hands'] },\r\n { name: 'Clap', emoji: '👏', keywords: ['applause', 'clap'], categories: ['Hands'] },\r\n { name: 'Folded Hands', emoji: '🙏', keywords: ['thank you', 'pray'], categories: ['Hands'] },\r\n { name: 'Point Right', emoji: '👉', keywords: ['point', 'right'], categories: ['Hands'] },\r\n { name: 'Fire', emoji: '🔥', keywords: ['fire', 'lit'], categories: ['Objects'] },\r\n { name: 'Star', emoji: '⭐', keywords: ['star', 'favorite'], categories: ['Objects'] },\r\n { name: 'Sparkles', emoji: '✨', keywords: ['sparkle', 'shine'], categories: ['Objects'] },\r\n { name: 'Rocket', emoji: '🚀', keywords: ['ship', 'launch', 'fast'], categories: ['Objects', 'Travel'] },\r\n { name: 'Laptop', emoji: '💻', keywords: ['computer', 'work'], categories: ['Objects'] },\r\n { name: 'Bulb', emoji: '💡', keywords: ['idea', 'light'], categories: ['Objects'] },\r\n { name: 'Camera', emoji: '📷', keywords: ['photo', 'camera'], categories: ['Objects'] },\r\n { name: 'Trophy', emoji: '🏆', keywords: ['win', 'award'], categories: ['Activities'] },\r\n { name: 'Medal', emoji: '🥇', keywords: ['gold', 'medal'], categories: ['Activities'] },\r\n { name: 'Soccer', emoji: '⚽', keywords: ['sports', 'soccer'], categories: ['Activities'] },\r\n { name: 'Basketball', emoji: '🏀', keywords: ['sports', 'basketball'], categories: ['Activities'] },\r\n { name: 'Pizza', emoji: '🍕', keywords: ['food', 'pizza'], categories: ['Food'] },\r\n { name: 'Burger', emoji: '🍔', keywords: ['food', 'burger'], categories: ['Food'] },\r\n { name: 'Coffee', emoji: '☕', keywords: ['coffee', 'drink'], categories: ['Food'] },\r\n { name: 'Cake', emoji: '🎂', keywords: ['dessert', 'cake'], categories: ['Food'] },\r\n { name: 'Tree', emoji: '🌳', keywords: ['tree', 'nature'], categories: ['Nature'] },\r\n { name: 'Sun', emoji: '☀️', keywords: ['sun', 'weather'], categories: ['Nature'] },\r\n { name: 'Cloud', emoji: '☁️', keywords: ['cloud', 'weather'], categories: ['Nature'] },\r\n { name: 'Rainbow', emoji: '🌈', keywords: ['rainbow', 'nature'], categories: ['Nature'] },\r\n { name: 'Globe', emoji: '🌍', keywords: ['earth', 'globe'], categories: ['Travel'] },\r\n { name: 'Airplane', emoji: '✈️', keywords: ['travel', 'airplane'], categories: ['Travel'] },\r\n { name: 'Train', emoji: '🚆', keywords: ['travel', 'train'], categories: ['Travel'] },\r\n { name: 'Car', emoji: '🚗', keywords: ['travel', 'car'], categories: ['Travel'] },\r\n { name: 'Lock', emoji: '🔒', keywords: ['security', 'lock'], categories: ['Symbols'] },\r\n { name: 'Key', emoji: '🔑', keywords: ['key', 'unlock'], categories: ['Symbols'] },\r\n { name: 'Chart Up', emoji: '📈', keywords: ['chart', 'growth'], categories: ['Symbols'] },\r\n { name: 'Toolbox', emoji: '🧰', keywords: ['tools', 'fix'], categories: ['Objects'] },\r\n { name: 'Robot', emoji: '🤖', keywords: ['ai', 'robot'], categories: ['Objects'] },\r\n { name: 'Brain', emoji: '🧠', keywords: ['brain', 'idea'], categories: ['Objects'] },\r\n { name: 'DNA', emoji: '🧬', keywords: ['dna', 'science'], categories: ['Objects'] },\r\n { name: 'Chip', emoji: '💽', keywords: ['chip', 'data'], categories: ['Objects'] },\r\n { name: 'Shield', emoji: '🛡️', keywords: ['protect', 'security'], categories: ['Symbols'] },\r\n { name: 'Bell', emoji: '🔔', keywords: ['notification', 'bell'], categories: ['Symbols'] },\r\n { name: 'Warning', emoji: '⚠️', keywords: ['warning', 'alert'], categories: ['Symbols'] },\r\n { name: 'Check', emoji: '✅', keywords: ['check', 'complete'], categories: ['Symbols'] },\r\n { name: 'Cross', emoji: '❌', keywords: ['cross', 'fail'], categories: ['Symbols'] },\r\n { name: 'Megaphone', emoji: '📣', keywords: ['announce', 'megaphone'], categories: ['Objects'] },\r\n { name: 'Calendar', emoji: '📅', keywords: ['calendar', 'date'], categories: ['Objects'] },\r\n { name: 'Clock', emoji: '⏰', keywords: ['time', 'clock'], categories: ['Objects'] },\r\n { name: 'Link', emoji: '🔗', keywords: ['link', 'chain'], categories: ['Symbols'] },\r\n { name: 'Folder', emoji: '📁', keywords: ['folder', 'files'], categories: ['Objects'] },\r\n { name: 'Paperclip', emoji: '📎', keywords: ['attach', 'paperclip'], categories: ['Objects'] },\r\n { name: 'Spark', emoji: '⚡', keywords: ['lightning', 'spark'], categories: ['Nature'] },\r\n { name: 'Gem', emoji: '💎', keywords: ['gem', 'diamond'], categories: ['Objects'] },\r\n { name: 'Crown', emoji: '👑', keywords: ['crown', 'royal'], categories: ['Smileys'] },\r\n { name: 'Palette', emoji: '🎨', keywords: ['art', 'palette'], categories: ['Activities'] },\r\n { name: 'Microphone', emoji: '🎤', keywords: ['mic', 'audio'], categories: ['Activities'] },\r\n { name: 'Headphones', emoji: '🎧', keywords: ['music', 'audio'], categories: ['Activities'] },\r\n];\r\n\r\nconst CATEGORIES = ['All', 'Smileys', 'Hands', 'Objects', 'Activities', 'Food', 'Nature', 'Travel', 'Symbols'];\r\n\r\nconst platformFontMap: Record<EmojiPlatform, string> = {\r\n auto: 'system-ui, -apple-system, \"Segoe UI Emoji\", \"Noto Color Emoji\", \"Apple Color Emoji\"',\r\n ios: '\"Apple Color Emoji\", \"Helvetica Neue\", Arial, sans-serif',\r\n android: '\"Noto Color Emoji\", \"Noto Color Emoji UI\", \"Segoe UI Emoji\", sans-serif',\r\n};\r\n\r\nexport const EmojisPreview: React.FC<EmojisPreviewProps> = ({ hideInstructions = false, globalConfig }) => {\r\n const defaultGlobalConfig: GlobalConfig = globalConfig || { primaryColor: 'blue', baseRadius: 8 };\r\n const [search, setSearch] = useState('');\r\n const [platform, setPlatform] = useState<EmojiPlatform>('auto');\r\n const [category, setCategory] = useState<string>('All');\r\n\r\n const filtered = useMemo(() => {\r\n const query = search.trim().toLowerCase();\r\n return EMOJI_DATA.filter((item) => {\r\n const inCategory = category === 'All' || item.categories.includes(category);\r\n const inSearch =\r\n !query ||\r\n item.name.toLowerCase().includes(query) ||\r\n item.keywords.some((k) => k.toLowerCase().includes(query));\r\n return inCategory && inSearch;\r\n });\r\n }, [category, search]);\r\n\r\n return (\r\n <div className=\"w-full flex flex-col gap-4\">\r\n {!hideInstructions && (\r\n <div className=\"rounded-lg border border-gray-200 dark:border-gray-800 bg-gray-50 dark:bg-gray-900/40 p-3 flex flex-wrap items-center gap-3 text-xs text-gray-600 dark:text-gray-300\">\r\n <span className=\"font-semibold text-gray-900 dark:text-white\">Emoji foundations</span>\r\n <span className=\"text-gray-500 dark:text-gray-400\">Search, filter by category, and preview platform rendering.</span>\r\n <div className=\"flex items-center gap-2 text-gray-500\">\r\n <Smartphone size={14} />\r\n <span>iOS</span>\r\n <MonitorSmartphone size={14} />\r\n <span>Android</span>\r\n </div>\r\n </div>\r\n )}\r\n\r\n <div className=\"flex flex-col gap-3\">\r\n <div className=\"flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between\">\r\n <div className=\"relative w-full sm:w-96\">\r\n <Search className=\"absolute left-3 top-2.5 h-4 w-4 text-gray-400\" />\r\n <input\r\n value={search}\r\n onChange={(e) => setSearch(e.target.value)}\r\n placeholder=\"Search emoji by name or keyword\"\r\n className={`w-full rounded-lg border pl-9 pr-10 py-2 text-sm bg-white dark:bg-gray-900 border-gray-200 dark:border-gray-800 focus:outline-none focus:ring-2 ${getColorClass(defaultGlobalConfig, 'ring')} ${getColorShade(defaultGlobalConfig, 'border', 300)} transition ${search ? `${getColorShade(defaultGlobalConfig, 'border', 300)} ring-1` : ''}`}\r\n />\r\n {search && (\r\n <button\r\n className=\"absolute right-2 top-2.5 text-gray-400 hover:text-gray-600\"\r\n onClick={() => setSearch('')}\r\n aria-label=\"Clear search\"\r\n >\r\n <X size={16} />\r\n </button>\r\n )}\r\n </div>\r\n\r\n <div className=\"flex items-center gap-2\">\r\n {(['auto', 'ios', 'android'] as EmojiPlatform[]).map((p) => (\r\n <button\r\n key={p}\r\n onClick={() => setPlatform(p)}\r\n className={`px-3 py-2 rounded-lg text-xs font-semibold border transition shadow-sm ${\r\n platform === p\r\n ? `${getColorShade(defaultGlobalConfig, 'border', 300)} ${getColorShade(defaultGlobalConfig, 'bg', 50)} ${getColorShade(defaultGlobalConfig, 'text', 700)} dark:${getColorShade(defaultGlobalConfig, 'bg', 900)}/50 dark:${getColorShade(defaultGlobalConfig, 'border', 800)} dark:${getColorShade(defaultGlobalConfig, 'text', 200)}`\r\n : 'border-gray-200 dark:border-gray-800 text-gray-700 dark:text-gray-300 hover:border-gray-300 hover:bg-gray-50 dark:hover:border-gray-700/60 dark:hover:bg-gray-800/50'\r\n }`}\r\n title={`Render using ${p === 'auto' ? 'system default' : p.toUpperCase()} emoji font`}\r\n >\r\n {p === 'auto' ? 'Auto' : p.toUpperCase()}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div className=\"flex items-center gap-2 overflow-x-auto pb-1\">\r\n <div className=\"flex items-center gap-1 text-xs font-semibold text-gray-500 dark:text-gray-400\">\r\n <SlidersHorizontal size={14} />\r\n <span>Categories</span>\r\n </div>\r\n {CATEGORIES.map((cat) => (\r\n <button\r\n key={cat}\r\n onClick={() => setCategory(cat)}\r\n className={`px-3 py-1.5 rounded-full text-xs font-semibold border transition ${\r\n category === cat\r\n ? `${getColorShade(defaultGlobalConfig, 'border', 300)} ${getColorShade(defaultGlobalConfig, 'bg', 50)} ${getColorShade(defaultGlobalConfig, 'text', 700)} dark:${getColorShade(defaultGlobalConfig, 'bg', 900)}/50 dark:${getColorShade(defaultGlobalConfig, 'border', 800)} dark:${getColorShade(defaultGlobalConfig, 'text', 200)}`\r\n : 'border-gray-200 dark:border-gray-800 text-gray-700 dark:text-gray-300 hover:border-gray-300 hover:bg-gray-50 dark:hover:border-gray-700/60 dark:hover:bg-gray-800/50'\r\n }`}\r\n >\r\n {cat}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div\r\n className=\"grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-5 gap-3\"\r\n style={{ fontFamily: platformFontMap[platform] }}\r\n >\r\n {filtered.map((item) => (\r\n <div\r\n key={item.name}\r\n className=\"flex items-center gap-3 p-3 rounded-lg border border-gray-200 dark:border-gray-800 bg-white dark:bg-gray-900 shadow-sm hover:shadow-md transition\"\r\n title={item.keywords.join(', ')}\r\n >\r\n <span className=\"text-2xl\">{item.emoji}</span>\r\n <div className=\"flex flex-col\">\r\n <span className=\"text-sm font-semibold text-gray-900 dark:text-white\">{item.name}</span>\r\n <span className=\"text-[11px] text-gray-500 dark:text-gray-400\">{item.categories.join(' • ')}</span>\r\n </div>\r\n </div>\r\n ))}\r\n {filtered.length === 0 && (\r\n <div className=\"col-span-full text-center text-sm text-gray-500 dark:text-gray-400 py-6\">\r\n No emojis match this filter. Try another category or search term.\r\n </div>\r\n )}\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport { AnimationConfig } from '../types';\r\n\r\n// Generate CSS keyframes from AnimationConfig\r\nexport const generateAnimationKeyframes = (config: AnimationConfig): string => {\r\n const duration = config.duration || 1000;\r\n const steps = 60; // 60 keyframes for smooth animation\r\n \r\n let keyframes = '';\r\n \r\n if (config.type === 'spring') {\r\n // Spring physics solver\r\n const solveSpring = (stiffness: number, damping: number, mass: number, velocity: number) => {\r\n const pts: number[] = [];\r\n let position = 0;\r\n let v = velocity;\r\n const dt = 1 / 60;\r\n for (let i = 0; i < steps; i++) {\r\n const force = -stiffness * (position - 1) - damping * v;\r\n const acceleration = force / mass;\r\n v += acceleration * dt;\r\n position += v * dt;\r\n pts.push(position);\r\n }\r\n return pts;\r\n };\r\n \r\n const positions = solveSpring(config.stiffness, config.damping, config.mass, config.velocity);\r\n keyframes = positions.map((pos, i) => {\r\n const percent = (i / (steps - 1)) * 100;\r\n const scale = 0.8 + (pos * 0.2); // Scale from 0.8 to 1.0\r\n return `${percent}% { transform: scale(${scale}); }`;\r\n }).join('\\n');\r\n \r\n } else if (config.type === 'easing') {\r\n // Easing functions\r\n const solveEasing = (preset: string, t: number): number => {\r\n switch (preset) {\r\n case 'inSine': return 1 - Math.cos((t * Math.PI) / 2);\r\n case 'outSine': return Math.sin((t * Math.PI) / 2);\r\n case 'inOutSine': return -(Math.cos(Math.PI * t) - 1) / 2;\r\n case 'inExpo': return t === 0 ? 0 : Math.pow(2, 10 * t - 10);\r\n case 'outExpo': return t === 1 ? 1 : 1 - Math.pow(2, -10 * t);\r\n case 'inOutExpo': \r\n return t === 0 ? 0 : t === 1 ? 1 : t < 0.5 \r\n ? Math.pow(2, 20 * t - 10) / 2 \r\n : (2 - Math.pow(2, -20 * t + 10)) / 2;\r\n case 'inBack': {\r\n const c1 = 1.70158;\r\n const c3 = c1 + 1;\r\n return c3 * t * t * t - c1 * t * t;\r\n }\r\n case 'outBack': {\r\n const c1 = 1.70158;\r\n const c3 = c1 + 1;\r\n return 1 + c3 * Math.pow(t - 1, 3) + c1 * Math.pow(t - 1, 2);\r\n }\r\n case 'inBounce': {\r\n const bounceOut = (x: number) => {\r\n const n1 = 7.5625;\r\n const d1 = 2.75;\r\n if (x < 1 / d1) return n1 * x * x;\r\n else if (x < 2 / d1) return n1 * (x -= 1.5 / d1) * x + 0.75;\r\n else if (x < 2.5 / d1) return n1 * (x -= 2.25 / d1) * x + 0.9375;\r\n else return n1 * (x -= 2.625 / d1) * x + 0.984375;\r\n };\r\n return 1 - bounceOut(1 - t);\r\n }\r\n case 'outBounce': {\r\n const bounceOut = (x: number) => {\r\n const n1 = 7.5625;\r\n const d1 = 2.75;\r\n if (x < 1 / d1) return n1 * x * x;\r\n else if (x < 2 / d1) return n1 * (x -= 1.5 / d1) * x + 0.75;\r\n else if (x < 2.5 / d1) return n1 * (x -= 2.25 / d1) * x + 0.9375;\r\n else return n1 * (x -= 2.625 / d1) * x + 0.984375;\r\n };\r\n return bounceOut(t);\r\n }\r\n default: return t;\r\n }\r\n };\r\n \r\n keyframes = Array.from({ length: steps }, (_, i) => {\r\n const t = i / (steps - 1);\r\n const percent = t * 100;\r\n const value = solveEasing(config.preset, t);\r\n const scale = 0.8 + (value * 0.2); // Scale from 0.8 to 1.0\r\n return `${percent}% { transform: scale(${scale}); }`;\r\n }).join('\\n');\r\n \r\n } else if (config.type === 'steps') {\r\n // Steps animation\r\n const stepCount = 5;\r\n const isStart = config.preset === 'steps-start';\r\n keyframes = Array.from({ length: steps }, (_, i) => {\r\n const t = i / (steps - 1);\r\n const percent = t * 100;\r\n let stepValue = isStart ? Math.ceil(t * stepCount) / stepCount : Math.floor(t * stepCount) / stepCount;\r\n if (isStart && t === 0) stepValue = 0;\r\n if (!isStart && t === 1) stepValue = 1;\r\n const scale = 0.8 + (stepValue * 0.2);\r\n return `${percent}% { transform: scale(${scale}); }`;\r\n }).join('\\n');\r\n }\r\n \r\n return keyframes;\r\n};\r\n\r\n// Generate CSS animation string\r\nexport const generateAnimationCSS = (config: AnimationConfig, animationName: string = 'custom-animation'): string => {\r\n const keyframes = generateAnimationKeyframes(config);\r\n const duration = config.duration || 1000;\r\n \r\n return `\r\n @keyframes ${animationName} {\r\n ${keyframes}\r\n }\r\n `;\r\n};\r\n\r\n// Get inline animation style\r\nexport const getAnimationStyle = (config: AnimationConfig, animationName: string = 'custom-animation'): React.CSSProperties => {\r\n const duration = config.duration || 1000;\r\n \r\n return {\r\n animationName: animationName,\r\n animationDuration: `${duration}ms`,\r\n animationTimingFunction: 'linear',\r\n animationFillMode: 'both',\r\n };\r\n};\r\n\r\n\r\n","import React, { ReactNode, useState, Component, useEffect, useLayoutEffect, useMemo, useId, startTransition } from 'react';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\n\r\ninterface Props {\r\n icon: any;\r\n size?: number;\r\n style?: React.CSSProperties;\r\n className?: string;\r\n fallback?: ReactNode;\r\n}\r\n\r\n// Fallback SVG component\r\nconst FallbackIcon: React.FC<{ size?: number; style?: React.CSSProperties; className?: string }> = ({ size = 24, style, className }) => (\r\n <svg\r\n width={size}\r\n height={size}\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke=\"currentColor\"\r\n strokeWidth=\"2\"\r\n style={style}\r\n className={className}\r\n >\r\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\r\n </svg>\r\n);\r\n\r\n// Internal icon renderer component\r\nconst FontAwesomeIconRenderer: React.FC<Props> = ({ icon, size, style, className, fallback }) => {\r\n const [shouldRender, setShouldRender] = useState(false);\r\n const [hasError, setHasError] = useState(false);\r\n\r\n // Use useId to ensure React's dispatcher is available\r\n // This helps ensure React 19 context is properly initialized\r\n const testId = useId();\r\n\r\n // Use useLayoutEffect to ensure React context is ready before rendering FontAwesome\r\n // This prevents useId hook errors in React 19\r\n useLayoutEffect(() => {\r\n // Use startTransition to ensure React's dispatcher is fully initialized\r\n // This is necessary for React 19 compatibility with FontAwesome's useId hook\r\n startTransition(() => {\r\n // Use requestAnimationFrame to ensure DOM and React are fully ready\r\n requestAnimationFrame(() => {\r\n setShouldRender(true);\r\n });\r\n });\r\n }, []);\r\n\r\n // Validate icon before attempting to render\r\n const isValidIcon = useMemo(() => {\r\n if (!icon) return false;\r\n // Check if icon has the required structure\r\n return typeof icon === 'object' && icon !== null && Array.isArray((icon as any).icon);\r\n }, [icon]);\r\n\r\n // If not ready to render, show fallback\r\n if (!shouldRender) {\r\n return <>{fallback || <FallbackIcon size={size} style={style} className={className} />}</>;\r\n }\r\n\r\n // Validate icon before attempting to render\r\n if (!isValidIcon) {\r\n console.warn('FontAwesome icon is invalid:', icon);\r\n return <>{fallback || <FallbackIcon size={size} style={style} className={className} />}</>;\r\n }\r\n\r\n // If error state is set, show fallback\r\n if (hasError) {\r\n return <>{fallback || <FallbackIcon size={size} style={style} className={className} />}</>;\r\n }\r\n\r\n // Render FontAwesomeIcon - hooks inside will be called now that React context is ready\r\n // Errors will be caught by the error boundary\r\n return (\r\n <FontAwesomeIcon\r\n icon={icon}\r\n style={{ fontSize: size, width: size, height: size, ...style }}\r\n className={className}\r\n />\r\n );\r\n};\r\n\r\n// Error boundary wrapper component\r\nclass FontAwesomeErrorBoundary extends Component<\r\n { children: React.ReactNode; fallback?: ReactNode; size?: number; style?: React.CSSProperties; className?: string },\r\n { hasError: boolean }\r\n> {\r\n constructor(props: any) {\r\n super(props);\r\n this.state = { hasError: false };\r\n }\r\n\r\n static getDerivedStateFromError() {\r\n return { hasError: true };\r\n }\r\n\r\n componentDidCatch(error: Error, errorInfo: React.ErrorInfo) {\r\n // Only log non-useId errors to avoid spam\r\n if (!error.message?.includes('useId') && !error.message?.includes('Cannot read properties of null')) {\r\n console.warn('FontAwesome icon error:', error, errorInfo);\r\n }\r\n // Set error state to prevent re-rendering attempts\r\n this.setState({ hasError: true });\r\n }\r\n\r\n render() {\r\n if (this.state.hasError) {\r\n return <>{this.props.fallback || <FallbackIcon size={this.props.size} style={this.props.style} className={this.props.className} />}</>;\r\n }\r\n return this.props.children;\r\n }\r\n}\r\n\r\n// Main wrapper component\r\nexport const FontAwesomeWrapper: React.FC<Props> = (props) => {\r\n return (\r\n <FontAwesomeErrorBoundary\r\n fallback={props.fallback}\r\n size={props.size}\r\n style={props.style}\r\n className={props.className}\r\n >\r\n <FontAwesomeIconRenderer {...props} />\r\n </FontAwesomeErrorBoundary>\r\n );\r\n};\r\n\r\n","\r\nimport React, { useState, useMemo, useEffect, useRef } from 'react';\r\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\r\nimport { library, config } from '@fortawesome/fontawesome-svg-core';\r\nimport { fas } from '@fortawesome/free-solid-svg-icons';\r\nimport { far } from '@fortawesome/free-regular-svg-icons';\r\nimport { fab } from '@fortawesome/free-brands-svg-icons';\r\nimport { Search, Copy, Check, X, SlidersHorizontal, Download, Code2, Grid3X3, List, ChevronLeft, ChevronRight } from 'lucide-react';\r\nimport { GlobalConfig, AnimationConfig } from '../types';\r\nimport { getColorShade, getColorValue } from '../utils/styleUtils';\r\nimport { generateAnimationCSS, getAnimationStyle } from '../utils/animationUtils';\r\nimport { FontAwesomeWrapper } from './FontAwesomeWrapper';\r\n\r\n// Configure FontAwesome - allow CSS for proper icon rendering\r\nconfig.autoAddCss = true;\r\n\r\n// Initialize library only once - use a flag to prevent multiple additions\r\nlet libraryInitialized = false;\r\nif (!libraryInitialized) {\r\n try {\r\n library.add(fas, far, fab);\r\n libraryInitialized = true;\r\n } catch (error) {\r\n console.warn('FontAwesome library initialization failed:', error);\r\n }\r\n}\r\n\r\ninterface IconItem {\r\n icon: any;\r\n name: string;\r\n style: 'solid' | 'regular' | 'brands';\r\n prefix: 'fas' | 'far' | 'fab';\r\n iconDefinition: any;\r\n originalKey: string; // Original key from the icon set for uniqueness\r\n}\r\n\r\ninterface IconsPreviewProps {\r\n globalConfig?: GlobalConfig;\r\n animationConfig?: AnimationConfig;\r\n componentProps?: {\r\n orientation?: 'horizontal' | 'vertical';\r\n textAlign?: 'left' | 'center' | 'right';\r\n variant?: string;\r\n size?: string;\r\n };\r\n hideInstructions?: boolean;\r\n}\r\n\r\n// Extract ALL icons from the library\r\nconst getAllIcons = (): IconItem[] => {\r\n const icons: IconItem[] = [];\r\n const seenKeys = new Set<string>(); // Track seen keys to prevent duplicates\r\n \r\n // Extract from fas (free-solid)\r\n Object.keys(fas).forEach(key => {\r\n const iconDef = fas[key as keyof typeof fas];\r\n // FontAwesome icons are IconDefinition objects\r\n if (iconDef && typeof iconDef === 'object' && iconDef !== null) {\r\n // Check if it's a valid IconDefinition (has icon array)\r\n if (Array.isArray((iconDef as any).icon)) {\r\n const iconName = (iconDef as any).iconName || key.replace(/^fa/, '').replace(/([A-Z])/g, '-$1').toLowerCase().replace(/^-/, '');\r\n const uniqueKey = `fas-${iconName}-${key}`; // Include original key for uniqueness\r\n if (!seenKeys.has(uniqueKey)) {\r\n seenKeys.add(uniqueKey);\r\n icons.push({\r\n icon: iconDef,\r\n name: iconName,\r\n style: 'solid',\r\n prefix: 'fas',\r\n iconDefinition: iconDef,\r\n originalKey: key\r\n });\r\n }\r\n }\r\n }\r\n });\r\n \r\n // Extract from far (free-regular)\r\n Object.keys(far).forEach(key => {\r\n const iconDef = far[key as keyof typeof far];\r\n if (iconDef && typeof iconDef === 'object' && iconDef !== null) {\r\n if (Array.isArray((iconDef as any).icon)) {\r\n const iconName = (iconDef as any).iconName || key.replace(/^fa/, '').replace(/([A-Z])/g, '-$1').toLowerCase().replace(/^-/, '');\r\n const uniqueKey = `far-${iconName}-${key}`; // Include original key for uniqueness\r\n if (!seenKeys.has(uniqueKey)) {\r\n seenKeys.add(uniqueKey);\r\n icons.push({\r\n icon: iconDef,\r\n name: iconName,\r\n style: 'regular',\r\n prefix: 'far',\r\n iconDefinition: iconDef,\r\n originalKey: key\r\n });\r\n }\r\n }\r\n }\r\n });\r\n \r\n // Extract from fab (free-brands)\r\n Object.keys(fab).forEach(key => {\r\n const iconDef = fab[key as keyof typeof fab];\r\n if (iconDef && typeof iconDef === 'object' && iconDef !== null) {\r\n if (Array.isArray((iconDef as any).icon)) {\r\n const iconName = (iconDef as any).iconName || key.replace(/^fa/, '').replace(/([A-Z])/g, '-$1').toLowerCase().replace(/^-/, '');\r\n const uniqueKey = `fab-${iconName}-${key}`; // Include original key for uniqueness\r\n if (!seenKeys.has(uniqueKey)) {\r\n seenKeys.add(uniqueKey);\r\n icons.push({\r\n icon: iconDef,\r\n name: iconName,\r\n style: 'brands',\r\n prefix: 'fab',\r\n iconDefinition: iconDef,\r\n originalKey: key\r\n });\r\n }\r\n }\r\n }\r\n });\r\n \r\n return icons.sort((a, b) => a.name.localeCompare(b.name));\r\n};\r\n\r\nexport const IconsPreview: React.FC<IconsPreviewProps> = ({ globalConfig, animationConfig, componentProps, hideInstructions = false }) => {\r\n const [allIcons, setAllIcons] = useState<IconItem[]>([]);\r\n const [searchQuery, setSearchQuery] = useState('');\r\n const [selectedIcons, setSelectedIcons] = useState<Set<string>>(new Set());\r\n const [copiedIcon, setCopiedIcon] = useState<string | null>(null);\r\n const [showControls, setShowControls] = useState(false);\r\n const [currentPage, setCurrentPage] = useState(1);\r\n const itemsPerPage = 25;\r\n \r\n // Derive initial sortBy from componentProps, but make it changeable\r\n const initialSortBy = componentProps?.textAlign === 'left' ? 'name' : componentProps?.textAlign === 'center' ? 'style' : 'name';\r\n const [sortBy, setSortBy] = useState<'name' | 'style'>(initialSortBy);\r\n \r\n // Style filter state - make it user-controllable\r\n const initialStyle = componentProps?.variant === 'primary' ? 'all' : \r\n componentProps?.variant === 'solid' ? 'solid' :\r\n componentProps?.variant === 'regular' ? 'regular' :\r\n componentProps?.variant === 'brands' ? 'brands' : 'all';\r\n const [selectedStyle, setSelectedStyle] = useState<'all' | 'solid' | 'regular' | 'brands'>(initialStyle);\r\n \r\n // View mode state - make it user-controllable\r\n const initialViewMode = componentProps?.orientation === 'vertical' ? 'list' : 'grid';\r\n const [viewMode, setViewMode] = useState<'grid' | 'list'>(initialViewMode);\r\n \r\n // Ensure FontAwesome library is initialized in React context\r\n useEffect(() => {\r\n if (!libraryInitialized) {\r\n try {\r\n library.add(fas, far, fab);\r\n libraryInitialized = true;\r\n } catch (error) {\r\n console.warn('FontAwesome library initialization failed:', error);\r\n }\r\n }\r\n }, []);\r\n\r\n const defaultGlobalConfig: GlobalConfig = globalConfig || { \r\n primaryColor: 'blue', \r\n baseRadius: 8,\r\n iconSize: 48,\r\n iconColor: 'default',\r\n iconCustomColor: '#3b82f6'\r\n };\r\n\r\n // Use global config values, fallback to defaults\r\n const iconSize = globalConfig?.iconSize || 48;\r\n const iconColor = globalConfig?.iconColor || 'default';\r\n const customColor = globalConfig?.iconCustomColor || '#3b82f6';\r\n\r\n // Load all icons on mount\r\n useEffect(() => {\r\n try {\r\n const icons = getAllIcons();\r\n console.log('Loaded icons:', icons.length);\r\n if (icons.length === 0) {\r\n console.warn('No icons loaded from FontAwesome library. Checking library state...');\r\n console.log('FAS sample:', Object.keys(fas).slice(0, 5));\r\n console.log('FAR sample:', Object.keys(far).slice(0, 5));\r\n console.log('FAB sample:', Object.keys(fab).slice(0, 5));\r\n }\r\n setAllIcons(icons);\r\n } catch (error) {\r\n console.error('Error loading icons:', error);\r\n }\r\n }, []);\r\n\r\n const filteredIcons = useMemo(() => {\r\n const query = searchQuery.toLowerCase().trim();\r\n let filtered = allIcons.filter(icon => {\r\n // Enhanced search - matches name, prefix, or style\r\n const matchesSearch = !query || \r\n icon.name.toLowerCase().includes(query) ||\r\n icon.prefix.toLowerCase().includes(query) ||\r\n icon.style.toLowerCase().includes(query);\r\n const matchesStyle = selectedStyle === 'all' || icon.style === selectedStyle;\r\n return matchesSearch && matchesStyle;\r\n });\r\n\r\n // Sort\r\n filtered = [...filtered].sort((a, b) => {\r\n if (sortBy === 'style') {\r\n if (a.style !== b.style) return a.style.localeCompare(b.style);\r\n return a.name.localeCompare(b.name);\r\n } else {\r\n return a.name.localeCompare(b.name);\r\n }\r\n });\r\n\r\n return filtered;\r\n }, [allIcons, searchQuery, selectedStyle, sortBy]);\r\n\r\n // Pagination\r\n const totalPages = Math.ceil(filteredIcons.length / itemsPerPage);\r\n const paginatedIcons = useMemo(() => {\r\n const startIndex = (currentPage - 1) * itemsPerPage;\r\n return filteredIcons.slice(startIndex, startIndex + itemsPerPage);\r\n }, [filteredIcons, currentPage, itemsPerPage]);\r\n\r\n // Reset to page 1 when filters change\r\n useEffect(() => {\r\n setCurrentPage(1);\r\n }, [searchQuery, selectedStyle, sortBy]);\r\n\r\n const toggleIconSelection = (iconKey: string) => {\r\n const newSelection = new Set(selectedIcons);\r\n if (newSelection.has(iconKey)) {\r\n newSelection.delete(iconKey);\r\n } else {\r\n newSelection.add(iconKey);\r\n }\r\n setSelectedIcons(newSelection);\r\n };\r\n\r\n const selectAll = () => {\r\n const allKeys = new Set(filteredIcons.map(icon => getIconKey(icon)));\r\n setSelectedIcons(allKeys);\r\n };\r\n\r\n const deselectAll = () => {\r\n setSelectedIcons(new Set());\r\n };\r\n\r\n const copyToClipboard = (icon: IconItem, includeSelection = false) => {\r\n const iconsToCopy = includeSelection && selectedIcons.size > 0\r\n ? filteredIcons.filter(i => selectedIcons.has(getIconKey(i)))\r\n : [icon];\r\n\r\n const imports: string[] = [];\r\n const usages: string[] = [];\r\n const libraryAdds: string[] = [];\r\n\r\n iconsToCopy.forEach(ic => {\r\n const camelCaseName = ic.name.split('-').map((word, index) => \r\n index === 0 ? word : word.charAt(0).toUpperCase() + word.slice(1)\r\n ).join('');\r\n const faIconName = `fa${camelCaseName.charAt(0).toUpperCase() + camelCaseName.slice(1)}`;\r\n \r\n const packageName = ic.style === 'brands' \r\n ? '@fortawesome/free-brands-svg-icons'\r\n : ic.style === 'regular'\r\n ? '@fortawesome/free-regular-svg-icons'\r\n : '@fortawesome/free-solid-svg-icons';\r\n \r\n imports.push(`import { ${faIconName} } from '${packageName}';`);\r\n usages.push(`<FontAwesomeIcon icon={${faIconName}} size=\"${iconSize}\" style={{ color: '${iconColor === 'primary' ? getColorValue(defaultGlobalConfig, 'primary', 600) : iconColor === 'secondary' ? getColorValue(defaultGlobalConfig, 'secondary', 500) : iconColor === 'custom' ? customColor : 'currentColor'}' }} />`);\r\n libraryAdds.push(faIconName);\r\n });\r\n\r\n const fullCode = `${imports.join('\\n')}\\n\\nlibrary.add(${libraryAdds.join(', ')});\\n\\n${usages.join('\\n')}`;\r\n \r\n navigator.clipboard.writeText(fullCode);\r\n setCopiedIcon(includeSelection ? 'selection' : getIconKey(icon));\r\n setTimeout(() => setCopiedIcon(null), 2000);\r\n };\r\n\r\n // Generate unique key using prefix, name, and original key\r\n const getIconKey = (icon: IconItem) => {\r\n // Use icon definition's iconName if available, otherwise use name\r\n const iconName = (icon.iconDefinition as any)?.iconName || icon.name;\r\n // Use original key for true uniqueness (handles duplicate icon names across sets)\r\n return `${icon.prefix}-${iconName}-${icon.originalKey}`;\r\n };\r\n\r\n const getIconColor = () => {\r\n if (iconColor === 'primary') return getColorValue(defaultGlobalConfig, 'primary', 600);\r\n if (iconColor === 'secondary') return getColorValue(defaultGlobalConfig, 'secondary', 500);\r\n if (iconColor === 'custom') return customColor;\r\n return 'currentColor'; // Use currentColor for default\r\n };\r\n\r\n const getSelectedIconsInfo = () => {\r\n if (selectedIcons.size === 0) return null;\r\n \r\n const selected = filteredIcons.filter(i => selectedIcons.has(getIconKey(i)));\r\n const byStyle = {\r\n solid: selected.filter(i => i.style === 'solid').length,\r\n regular: selected.filter(i => i.style === 'regular').length,\r\n brands: selected.filter(i => i.style === 'brands').length,\r\n };\r\n \r\n return { count: selectedIcons.size, byStyle };\r\n };\r\n\r\n const selectedInfo = getSelectedIconsInfo();\r\n\r\n // Generate animation styles\r\n const animationName = 'icon-animation';\r\n const animationStyle = animationConfig ? getAnimationStyle(animationConfig, animationName) : {};\r\n const animationKeyframes = animationConfig ? generateAnimationCSS(animationConfig, animationName) : '';\r\n\r\n // Inject keyframes into document\r\n useEffect(() => {\r\n if (!animationConfig || !animationKeyframes) return;\r\n \r\n const styleId = 'icon-animation-keyframes';\r\n let styleElement = document.getElementById(styleId) as HTMLStyleElement;\r\n \r\n if (!styleElement) {\r\n styleElement = document.createElement('style');\r\n styleElement.id = styleId;\r\n document.head.appendChild(styleElement);\r\n }\r\n \r\n styleElement.textContent = animationKeyframes;\r\n \r\n return () => {\r\n // Cleanup on unmount\r\n const element = document.getElementById(styleId);\r\n if (element) element.remove();\r\n };\r\n }, [animationConfig, animationKeyframes]);\r\n\r\n return (\r\n <div className=\"w-full space-y-6 p-6\">\r\n {/* Header */}\r\n <div className=\"space-y-4\">\r\n <div className=\"flex items-start justify-between\">\r\n <div>\r\n <h2 className=\"text-lg font-bold text-gray-900 dark:text-white mb-2\">Font Awesome Icons</h2>\r\n <p className=\"text-sm text-gray-600 dark:text-gray-400\">\r\n Browse all {allIcons.length.toLocaleString()} icons in your library. Select icons to manipulate and copy code.\r\n </p>\r\n </div>\r\n <button\r\n onClick={() => setShowControls(!showControls)}\r\n className={`p-2 rounded-lg transition-colors ${showControls ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400'}`}\r\n title=\"Toggle Controls\"\r\n >\r\n <SlidersHorizontal size={20} />\r\n </button>\r\n </div>\r\n\r\n {/* Controls Panel */}\r\n {showControls && (\r\n <div className=\"p-4 bg-gray-50 dark:bg-gray-800/50 rounded-lg border border-gray-200 dark:border-gray-700 space-y-4\">\r\n {/* Sort Options */}\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-700 dark:text-gray-300 mb-2 block\">\r\n Sort By\r\n </label>\r\n <div className=\"flex gap-2\">\r\n {(['name', 'style'] as const).map(option => (\r\n <button\r\n key={option}\r\n onClick={() => setSortBy(option)}\r\n className={`px-3 py-1.5 rounded-md text-xs font-medium transition-colors capitalize ${\r\n sortBy === option\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'\r\n }`}\r\n >\r\n {option}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div className=\"p-3 bg-blue-50 dark:bg-blue-900/20 rounded-lg border border-blue-200 dark:border-blue-800\">\r\n <p className=\"text-xs text-blue-900 dark:text-blue-100 font-semibold mb-1\">\r\n 💡 Tip: Use Inspector Controls\r\n </p>\r\n <p className=\"text-xs text-blue-700 dark:text-blue-300\">\r\n Icon size, color, and other settings are controlled globally via the Inspector panel on the right. Open the Inspector and go to the Theme tab to adjust these settings.\r\n </p>\r\n </div>\r\n\r\n {/* Selection Actions */}\r\n {selectedInfo && (\r\n <div className=\"flex items-center justify-between p-3 bg-blue-50 dark:bg-blue-900/20 rounded-lg border border-blue-200 dark:border-blue-800\">\r\n <div>\r\n <span className=\"text-sm font-semibold text-blue-900 dark:text-blue-100\">\r\n {selectedInfo.count} icon{selectedInfo.count !== 1 ? 's' : ''} selected\r\n </span>\r\n <div className=\"text-xs text-blue-700 dark:text-blue-300 mt-1\">\r\n Solid: {selectedInfo.byStyle.solid} • Regular: {selectedInfo.byStyle.regular} • Brands: {selectedInfo.byStyle.brands}\r\n </div>\r\n </div>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={() => copyToClipboard(filteredIcons[0], true)}\r\n className=\"px-3 py-1.5 bg-blue-600 text-white rounded-md text-xs font-medium hover:bg-blue-700 transition-colors flex items-center gap-1\"\r\n >\r\n <Copy size={14} />\r\n Copy Selected\r\n </button>\r\n <button\r\n onClick={deselectAll}\r\n className=\"px-3 py-1.5 bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 rounded-md text-xs font-medium hover:bg-gray-300 dark:hover:bg-gray-600 transition-colors\"\r\n >\r\n Clear\r\n </button>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n\r\n {/* Search and Filter */}\r\n <div className=\"flex flex-col sm:flex-row gap-4\">\r\n <div className=\"flex-1 relative\">\r\n <Search className=\"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400\" size={18} />\r\n <input\r\n type=\"text\"\r\n placeholder={`Search ${allIcons.length.toLocaleString()} icons...`}\r\n value={searchQuery}\r\n onChange={(e) => setSearchQuery(e.target.value)}\r\n className={`w-full pl-10 pr-4 py-2 border rounded-lg bg-white dark:bg-gray-800 text-gray-900 dark:text-white focus:ring-2 focus:ring-blue-500 focus:border-transparent transition-colors ${\r\n searchQuery ? 'border-blue-300 dark:border-blue-700' : 'border-gray-300 dark:border-gray-700'\r\n }`}\r\n />\r\n {searchQuery && (\r\n <button\r\n onClick={() => setSearchQuery('')}\r\n className=\"absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300\"\r\n title=\"Clear search\"\r\n >\r\n <X size={16} />\r\n </button>\r\n )}\r\n </div>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={() => setViewMode('grid')}\r\n className={`p-2 rounded-lg transition-colors ${viewMode === 'grid' ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-200 dark:hover:bg-gray-700'}`}\r\n title=\"Grid View\"\r\n >\r\n <Grid3X3 size={18} />\r\n </button>\r\n <button\r\n onClick={() => setViewMode('list')}\r\n className={`p-2 rounded-lg transition-colors ${viewMode === 'list' ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-200 dark:hover:bg-gray-700'}`}\r\n title=\"List View\"\r\n >\r\n <List size={18} />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Style Filter */}\r\n <div className=\"flex flex-wrap items-center gap-2\">\r\n {(['all', 'solid', 'regular', 'brands'] as const).map(style => {\r\n const count = style === 'all' ? allIcons.length : allIcons.filter(i => i.style === style).length;\r\n return (\r\n <button\r\n key={style}\r\n onClick={() => setSelectedStyle(style)}\r\n className={`\r\n px-4 py-2 rounded-lg text-sm font-medium transition-all capitalize\r\n ${selectedStyle === style\r\n ? 'bg-blue-600 text-white shadow-md ring-2 ring-blue-300 dark:ring-blue-700'\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-700 hover:shadow-sm'\r\n }\r\n `}\r\n title={`Filter by ${style} style (${count} icons)`}\r\n >\r\n <span className=\"capitalize\">{style === 'all' ? 'All' : style}</span>\r\n <span className=\"ml-2 text-xs opacity-75\">({count.toLocaleString()})</span>\r\n </button>\r\n );\r\n })}\r\n {(searchQuery || selectedStyle !== 'all') && (\r\n <button\r\n onClick={() => {\r\n setSearchQuery('');\r\n setSelectedStyle('all');\r\n }}\r\n className=\"px-3 py-2 rounded-lg text-sm font-medium text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800 transition-colors flex items-center gap-1\"\r\n title=\"Clear all filters\"\r\n >\r\n <X size={14} />\r\n Clear Filters\r\n </button>\r\n )}\r\n </div>\r\n\r\n {/* Bulk Actions */}\r\n <div className=\"flex items-center justify-between text-xs text-gray-500 dark:text-gray-400\">\r\n <span>\r\n Showing {((currentPage - 1) * itemsPerPage + 1).toLocaleString()}-{Math.min(currentPage * itemsPerPage, filteredIcons.length).toLocaleString()} of {filteredIcons.length.toLocaleString()} icons\r\n {filteredIcons.length !== allIcons.length && ` (${allIcons.length.toLocaleString()} total)`}\r\n </span>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={selectAll}\r\n className=\"hover:text-blue-600 dark:hover:text-blue-400 transition-colors\"\r\n >\r\n Select All Visible\r\n </button>\r\n {selectedIcons.size > 0 && (\r\n <>\r\n <span>•</span>\r\n <button\r\n onClick={deselectAll}\r\n className=\"hover:text-red-600 dark:hover:text-red-400 transition-colors\"\r\n >\r\n Deselect All\r\n </button>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Icons Grid */}\r\n {filteredIcons.length > 0 ? (\r\n <>\r\n <div className={viewMode === 'grid' \r\n ? 'grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-5 xl:grid-cols-6 gap-4'\r\n : 'space-y-4'\r\n }>\r\n {paginatedIcons.map((icon) => {\r\n const iconKey = getIconKey(icon);\r\n const isSelected = selectedIcons.has(iconKey);\r\n const isCopied = copiedIcon === iconKey;\r\n return (\r\n <div\r\n key={iconKey}\r\n className={`\r\n group relative rounded-lg border-2 transition-all overflow-hidden\r\n ${isSelected\r\n ? 'border-blue-500 bg-blue-50 dark:bg-blue-900/20 ring-2 ring-blue-200 dark:ring-blue-800'\r\n : isCopied\r\n ? 'border-green-500 bg-green-50 dark:bg-green-900/20'\r\n : 'border-gray-200 dark:border-gray-700 hover:border-blue-500 hover:shadow-lg bg-white dark:bg-gray-800'\r\n }\r\n ${viewMode === 'list' ? 'flex items-center gap-4 p-4' : 'aspect-square p-4 flex flex-col'}\r\n `}\r\n >\r\n {isSelected && (\r\n <div className=\"absolute top-1 right-1 w-5 h-5 bg-blue-600 rounded-full flex items-center justify-center z-10\">\r\n <Check size={12} className=\"text-white\" />\r\n </div>\r\n )}\r\n \r\n {/* Icon Preview */}\r\n <div className={`\r\n ${viewMode === 'list' ? 'w-24 h-24 flex-shrink-0' : 'flex-1'}\r\n flex items-center justify-center bg-gray-50 dark:bg-gray-900/50 rounded overflow-hidden\r\n `}>\r\n <div \r\n className={`flex items-center justify-center ${animationConfig ? 'cursor-pointer' : 'transition-transform group-hover:scale-110'}`}\r\n style={animationConfig ? animationStyle : {}}\r\n onClick={() => {\r\n if (animationConfig) {\r\n // Trigger animation by removing and re-adding the style\r\n const element = document.querySelector(`[data-icon-key=\"${iconKey}\"]`) as HTMLElement;\r\n if (element) {\r\n element.style.animation = 'none';\r\n setTimeout(() => {\r\n element.style.animation = '';\r\n Object.assign(element.style, animationStyle);\r\n }, 10);\r\n }\r\n }\r\n }}\r\n data-icon-key={iconKey}\r\n >\r\n <FontAwesomeWrapper\r\n icon={icon.iconDefinition || icon.icon}\r\n size={viewMode === 'list' ? iconSize : Math.max(iconSize, 48)}\r\n style={isCopied ? {} : { color: iconColor !== 'default' ? getIconColor() : 'currentColor' }}\r\n className={isCopied ? 'text-green-600 dark:text-green-400' : ''}\r\n fallback={\r\n <svg\r\n width={viewMode === 'list' ? iconSize : Math.max(iconSize, 48)}\r\n height={viewMode === 'list' ? iconSize : Math.max(iconSize, 48)}\r\n viewBox=\"0 0 24 24\"\r\n fill=\"none\"\r\n stroke={isCopied ? 'currentColor' : (iconColor !== 'default' ? getIconColor() : 'currentColor')}\r\n strokeWidth=\"2\"\r\n className={isCopied ? 'text-green-600 dark:text-green-400' : ''}\r\n style={isCopied ? {} : { color: iconColor !== 'default' ? getIconColor() : 'currentColor' }}\r\n >\r\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\r\n </svg>\r\n }\r\n />\r\n </div>\r\n </div>\r\n\r\n {/* Info */}\r\n <div className={viewMode === 'list' ? 'flex-1' : 'mt-2'}>\r\n <div className=\"text-xs font-semibold text-gray-900 dark:text-white truncate\">\r\n {icon.name}\r\n </div>\r\n <div className=\"text-[10px] text-gray-400 dark:text-gray-500 capitalize mt-0.5\">\r\n {icon.prefix}\r\n </div>\r\n </div>\r\n\r\n {/* Actions */}\r\n <div className={`\r\n absolute top-2 right-2 flex gap-1 opacity-0 group-hover:opacity-100 transition-opacity\r\n ${isCopied ? 'opacity-100' : ''}\r\n `}>\r\n <button\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n copyToClipboard(icon);\r\n }}\r\n className={`p-2 rounded-md transition-colors ${\r\n isCopied \r\n ? 'bg-green-500 text-white' \r\n : 'bg-white dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 shadow-sm'\r\n }`}\r\n title=\"Copy code\"\r\n >\r\n {isCopied ? <Check size={14} /> : <Copy size={14} />}\r\n </button>\r\n </div>\r\n\r\n {/* Click to select */}\r\n <div\r\n className=\"absolute inset-0 cursor-pointer\"\r\n onClick={(e) => {\r\n if (e.target === e.currentTarget || (e.target as HTMLElement).tagName !== 'BUTTON') {\r\n if (e.shiftKey || e.metaKey || e.ctrlKey) {\r\n toggleIconSelection(iconKey);\r\n } else {\r\n copyToClipboard(icon);\r\n }\r\n }\r\n }}\r\n onDoubleClick={() => toggleIconSelection(iconKey)}\r\n />\r\n </div>\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Pagination */}\r\n {totalPages > 1 && (\r\n <div className=\"flex items-center justify-center gap-2 mt-6\">\r\n <button\r\n onClick={() => setCurrentPage(prev => Math.max(1, prev - 1))}\r\n disabled={currentPage === 1}\r\n className={`p-2 rounded-lg transition-colors ${\r\n currentPage === 1\r\n ? 'bg-gray-100 dark:bg-gray-800 text-gray-400 cursor-not-allowed'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n <ChevronLeft size={18} />\r\n </button>\r\n \r\n <div className=\"flex gap-1\">\r\n {Array.from({ length: Math.min(7, totalPages) }, (_, i) => {\r\n let pageNum: number;\r\n if (totalPages <= 7) {\r\n pageNum = i + 1;\r\n } else if (currentPage <= 4) {\r\n pageNum = i + 1;\r\n } else if (currentPage >= totalPages - 3) {\r\n pageNum = totalPages - 6 + i;\r\n } else {\r\n pageNum = currentPage - 3 + i;\r\n }\r\n \r\n return (\r\n <button\r\n key={pageNum}\r\n onClick={() => setCurrentPage(pageNum)}\r\n className={`px-3 py-1.5 rounded-lg text-sm font-medium transition-colors ${\r\n currentPage === pageNum\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n {pageNum}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n\r\n <button\r\n onClick={() => setCurrentPage(prev => Math.min(totalPages, prev + 1))}\r\n disabled={currentPage === totalPages}\r\n className={`p-2 rounded-lg transition-colors ${\r\n currentPage === totalPages\r\n ? 'bg-gray-100 dark:bg-gray-800 text-gray-400 cursor-not-allowed'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n <ChevronRight size={18} />\r\n </button>\r\n </div>\r\n )}\r\n </>\r\n ) : (\r\n <div className=\"text-center py-12\">\r\n <p className=\"text-gray-500 dark:text-gray-400\">No icons found matching your search.</p>\r\n </div>\r\n )}\r\n\r\n {/* Usage Instructions - Hidden in sticker sheet */}\r\n {!hideInstructions && (\r\n <div className=\"mt-8 p-4 bg-gray-50 dark:bg-gray-800/50 rounded-lg border border-gray-200 dark:border-gray-700\">\r\n <h3 className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">Usage Instructions</h3>\r\n <ol className=\"text-xs text-gray-600 dark:text-gray-400 space-y-2 list-decimal list-inside\">\r\n <li><strong>Click</strong> an icon to copy its import and usage code</li>\r\n <li><strong>Double-click</strong> or <strong>Shift/Cmd/Ctrl+Click</strong> to select multiple icons</li>\r\n <li><strong>Use controls</strong> to adjust size and color, then copy selected icons</li>\r\n <li><strong>Search</strong> by icon name or style (fas, far, fab)</li>\r\n <li>Selected icons can be copied together with current size and color settings</li>\r\n </ol>\r\n \r\n {/* Mixed Import Pattern - Recommended */}\r\n <div className=\"mt-4 p-3 bg-blue-50 dark:bg-blue-900/20 rounded border border-blue-200 dark:border-blue-800\">\r\n <p className=\"text-xs font-semibold text-blue-900 dark:text-blue-100 mb-2\">Mixed Import Pattern (Recommended):</p>\r\n <p className=\"text-xs font-mono text-gray-700 dark:text-gray-300\">\r\n <span className=\"text-blue-600\">import</span> {'{'} library {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/fontawesome-svg-core'</span>;<br />\r\n <br />\r\n <span className=\"text-gray-500\">/* Bulk imports for entire icon sets */</span><br />\r\n <span className=\"text-blue-600\">import</span> {'{'} fas {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/free-solid-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} fass {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/sharp-solid-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} fad {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/pro-duotone-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} fadt {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/duotone-thin-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} fasds {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/sharp-duotone-solid-svg-icons'</span>;<br />\r\n <br />\r\n <span className=\"text-gray-500\">/* Individual icon imports */</span><br />\r\n <span className=\"text-blue-600\">import</span> {'{'} faTwitter, faFontAwesome {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/free-brands-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} faHatCowboy {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/pro-thin-svg-icons'</span>;<br />\r\n <span className=\"text-blue-600\">import</span> {'{'} faHatChef {'}'} <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'@fortawesome/sharp-solid-svg-icons'</span>;<br />\r\n <br />\r\n library.add(fas, fass, fad, fadt, fasds, faTwitter, faFontAwesome, faHatCowboy, faHatChef);<br />\r\n <br />\r\n <span className=\"text-gray-500\">// Usage:</span><br />\r\n {'<'}FontAwesomeIcon icon={'{'}fas.faHome{'}'} size=\"24\" style={'{{'} color: '#3b82f6' {'}}'} /{'>'} <span className=\"text-gray-500\">// from bulk import</span><br />\r\n {'<'}FontAwesomeIcon icon={'{'}faTwitter{'}'} /{'>'} <span className=\"text-gray-500\">// from individual import</span>\r\n </p>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useMemo, useEffect } from 'react';\r\nimport { Search, Copy, Check, Download, ExternalLink, Grid3X3, List, SlidersHorizontal, ChevronLeft, ChevronRight, X } from 'lucide-react';\r\nimport { GlobalConfig, AnimationConfig } from '../types';\r\nimport { getColorValue } from '../utils/styleUtils';\r\nimport { generateAnimationCSS, getAnimationStyle } from '../utils/animationUtils';\r\n\r\n// Helper function to convert hex color to CSS filter\r\nconst getColorFilter = (hex: string): string => {\r\n // This is a simplified filter - for production, use a proper color-to-filter converter\r\n const r = parseInt(hex.slice(1, 3), 16);\r\n const g = parseInt(hex.slice(3, 5), 16);\r\n const b = parseInt(hex.slice(5, 7), 16);\r\n // Return a basic filter approximation\r\n return `sepia(100%) saturate(200%) hue-rotate(${Math.round((r + g + b) / 3)}deg)`;\r\n};\r\n\r\ninterface IllustrationItem {\r\n category: string;\r\n subcategory?: string;\r\n style?: string;\r\n name: string;\r\n path: string;\r\n url: string;\r\n}\r\n\r\ninterface IllustrationsPreviewProps {\r\n globalConfig?: GlobalConfig;\r\n animationConfig?: AnimationConfig;\r\n componentProps?: {\r\n orientation?: 'horizontal' | 'vertical';\r\n textAlign?: 'left' | 'center' | 'right';\r\n variant?: string;\r\n size?: string;\r\n };\r\n hideInstructions?: boolean;\r\n}\r\n\r\n// Get all SVG files using Vite's glob import\r\nconst getAllIllustrations = async (): Promise<IllustrationItem[]> => {\r\n const illustrations: IllustrationItem[] = [];\r\n \r\n // Use Vite's import.meta.glob to get all SVG files\r\n const svgModules = import.meta.glob('/assets/illustrations/**/*.svg', { eager: false });\r\n \r\n // Convert glob paths to illustration items\r\n Object.keys(svgModules).forEach((path) => {\r\n // Extract category from path: assets/illustrations/{category}/{...subfolders}/{name}.svg\r\n const parts = path.replace('/assets/illustrations/', '').split('/');\r\n const fileName = parts[parts.length - 1];\r\n const name = fileName.replace('.svg', '');\r\n const category = parts[0];\r\n const subcategory = parts.length > 2 ? parts.slice(1, -1).join('/') : undefined;\r\n const style = parts.length > 2 ? parts[1] : undefined;\r\n \r\n illustrations.push({\r\n category,\r\n subcategory,\r\n style,\r\n name,\r\n path,\r\n url: path // Will be resolved by Vite\r\n });\r\n });\r\n \r\n return illustrations.sort((a, b) => {\r\n if (a.category !== b.category) return a.category.localeCompare(b.category);\r\n if (a.name !== b.name) return a.name.localeCompare(b.name);\r\n return 0;\r\n });\r\n};\r\n\r\n// Category metadata\r\nconst CATEGORY_INFO: Record<string, { name: string; description: string }> = {\r\n core: { name: 'Core', description: 'Essential illustrations for common use cases' },\r\n block: { name: 'Block', description: 'Block-style geometric illustrations' },\r\n freehand: { name: 'Freehand', description: 'Hand-drawn style illustrations' },\r\n sharp: { name: 'Sharp', description: 'Sharp, angular illustrations' },\r\n plump: { name: 'Plump', description: 'Rounded, soft illustrations' },\r\n ultimate: { name: 'Ultimate', description: 'Premium detailed illustrations' },\r\n guidance: { name: 'Guidance', description: 'Onboarding and help illustrations' },\r\n kameleon: { name: 'Kameleon', description: 'Colorful, vibrant illustrations' },\r\n pixel: { name: 'Pixel', description: 'Retro pixel art style' },\r\n flex: { name: 'Flex', description: 'Flexible, adaptable illustrations' },\r\n cyber: { name: 'Cyber', description: 'Cyberpunk and tech-themed illustrations' },\r\n logos: { name: 'Logos', description: 'Brand and logo illustrations' },\r\n stickies: { name: 'Stickies', description: 'Sticky note style illustrations' },\r\n covid: { name: 'COVID', description: 'COVID-19 related illustrations' },\r\n memes: { name: 'Memes', description: 'Meme-style illustrations' },\r\n 'freebies-freemojis': { name: 'Freebies & Freemojis', description: 'Free emoji and bonus illustrations' },\r\n 'nasty-icons': { name: 'Nasty Icons', description: 'Bold, edgy icon style' },\r\n};\r\n\r\nexport const IllustrationsPreview: React.FC<IllustrationsPreviewProps> = ({ globalConfig, animationConfig, componentProps, hideInstructions = false }) => {\r\n const [allIllustrations, setAllIllustrations] = useState<IllustrationItem[]>([]);\r\n const [isLoading, setIsLoading] = useState(true);\r\n const [searchQuery, setSearchQuery] = useState('');\r\n const [selectedCategory, setSelectedCategory] = useState<string>('all');\r\n const [selectedStyle, setSelectedStyle] = useState<string>('all');\r\n const [copiedIllustration, setCopiedIllustration] = useState<string | null>(null);\r\n const [selectedIllustrations, setSelectedIllustrations] = useState<Set<string>>(new Set());\r\n const [showControls, setShowControls] = useState(false);\r\n const [currentPage, setCurrentPage] = useState(1);\r\n const itemsPerPage = 25;\r\n\r\n // View mode state - make it user-controllable\r\n const initialViewMode = componentProps?.orientation === 'vertical' ? 'list' : (componentProps?.orientation === 'horizontal' ? 'grid' : 'grid');\r\n const [viewMode, setViewMode] = useState<'grid' | 'list'>(initialViewMode);\r\n \r\n // Sort state - make it user-controllable\r\n const initialSortBy = componentProps?.textAlign === 'left' ? 'name' : \r\n componentProps?.textAlign === 'center' ? 'category' : \r\n componentProps?.textAlign === 'right' ? 'newest' : 'name';\r\n const [sortBy, setSortBy] = useState<'name' | 'category' | 'newest'>(initialSortBy);\r\n\r\n const defaultGlobalConfig: GlobalConfig = globalConfig || { \r\n primaryColor: 'blue', \r\n baseRadius: 8,\r\n illustrationSize: 100,\r\n illustrationColor: 'default',\r\n illustrationCustomColor: '#3b82f6'\r\n };\r\n\r\n // Use global config values, fallback to defaults\r\n const illustrationSize = globalConfig?.illustrationSize || 100;\r\n const illustrationColor = globalConfig?.illustrationColor || 'default';\r\n const illustrationCustomColor = globalConfig?.illustrationCustomColor || '#3b82f6';\r\n\r\n // Load all illustrations\r\n useEffect(() => {\r\n const loadIllustrations = async () => {\r\n try {\r\n const illustrations = await getAllIllustrations();\r\n setAllIllustrations(illustrations);\r\n } catch (error) {\r\n console.error('Error loading illustrations:', error);\r\n // Fallback: try to load from public folder structure\r\n setAllIllustrations([]);\r\n }\r\n setIsLoading(false);\r\n };\r\n \r\n loadIllustrations();\r\n }, []);\r\n\r\n // Get unique categories\r\n const categories = useMemo(() => {\r\n const cats = Array.from(new Set(allIllustrations.map(i => i.category)));\r\n return cats.sort();\r\n }, [allIllustrations]);\r\n\r\n // Get unique styles for selected category\r\n const styles = useMemo(() => {\r\n if (selectedCategory === 'all') {\r\n const allStyles = new Set<string>();\r\n allIllustrations.forEach(i => {\r\n if (i.style) allStyles.add(i.style);\r\n });\r\n return Array.from(allStyles).sort();\r\n }\r\n const catStyles = new Set<string>();\r\n allIllustrations\r\n .filter(i => i.category === selectedCategory)\r\n .forEach(i => {\r\n if (i.style) catStyles.add(i.style);\r\n });\r\n return Array.from(catStyles).sort();\r\n }, [allIllustrations, selectedCategory]);\r\n\r\n // Filter and sort illustrations\r\n const filteredIllustrations = useMemo(() => {\r\n const query = searchQuery.toLowerCase().trim();\r\n let filtered = allIllustrations.filter(illustration => {\r\n // Enhanced search - matches name, category, subcategory, or style\r\n const matchesSearch = !query || \r\n illustration.name.toLowerCase().includes(query) ||\r\n illustration.category.toLowerCase().includes(query) ||\r\n (illustration.subcategory && illustration.subcategory.toLowerCase().includes(query)) ||\r\n (illustration.style && illustration.style.toLowerCase().includes(query));\r\n const matchesCategory = selectedCategory === 'all' || illustration.category === selectedCategory;\r\n const matchesStyle = selectedStyle === 'all' || illustration.style === selectedStyle;\r\n return matchesSearch && matchesCategory && matchesStyle;\r\n });\r\n\r\n // Sort\r\n filtered = [...filtered].sort((a, b) => {\r\n if (sortBy === 'category') {\r\n if (a.category !== b.category) return a.category.localeCompare(b.category);\r\n return a.name.localeCompare(b.name);\r\n } else if (sortBy === 'newest') {\r\n // For newest, we'll sort by name as a proxy (could be enhanced with file dates)\r\n return b.name.localeCompare(a.name);\r\n } else {\r\n return a.name.localeCompare(b.name);\r\n }\r\n });\r\n\r\n return filtered;\r\n }, [allIllustrations, searchQuery, selectedCategory, selectedStyle, sortBy]);\r\n\r\n // Pagination\r\n const totalPages = Math.ceil(filteredIllustrations.length / itemsPerPage);\r\n const paginatedIllustrations = useMemo(() => {\r\n const startIndex = (currentPage - 1) * itemsPerPage;\r\n return filteredIllustrations.slice(startIndex, startIndex + itemsPerPage);\r\n }, [filteredIllustrations, currentPage, itemsPerPage]);\r\n\r\n // Reset to page 1 when filters change\r\n useEffect(() => {\r\n setCurrentPage(1);\r\n }, [searchQuery, selectedCategory, selectedStyle, sortBy]);\r\n\r\n const toggleIllustrationSelection = (path: string) => {\r\n const newSelection = new Set(selectedIllustrations);\r\n if (newSelection.has(path)) {\r\n newSelection.delete(path);\r\n } else {\r\n newSelection.add(path);\r\n }\r\n setSelectedIllustrations(newSelection);\r\n };\r\n\r\n const selectAll = () => {\r\n const allPaths = new Set(filteredIllustrations.map(i => i.path));\r\n setSelectedIllustrations(allPaths);\r\n };\r\n\r\n const deselectAll = () => {\r\n setSelectedIllustrations(new Set());\r\n };\r\n\r\n const copyToClipboard = async (illustration: IllustrationItem) => {\r\n const code = `<img src=\"${illustration.url}\" alt=\"${illustration.name}\" />`;\r\n await navigator.clipboard.writeText(code);\r\n setCopiedIllustration(illustration.path);\r\n setTimeout(() => setCopiedIllustration(null), 2000);\r\n };\r\n\r\n const downloadSVG = async (illustration: IllustrationItem) => {\r\n try {\r\n // Try to fetch the SVG\r\n const response = await fetch(illustration.url);\r\n if (response.ok) {\r\n const svgContent = await response.text();\r\n const blob = new Blob([svgContent], { type: 'image/svg+xml' });\r\n const url = URL.createObjectURL(blob);\r\n const a = document.createElement('a');\r\n a.href = url;\r\n a.download = `${illustration.name}.svg`;\r\n document.body.appendChild(a);\r\n a.click();\r\n document.body.removeChild(a);\r\n URL.revokeObjectURL(url);\r\n }\r\n } catch (error) {\r\n console.error('Error downloading SVG:', error);\r\n }\r\n };\r\n\r\n const getSelectedInfo = () => {\r\n if (selectedIllustrations.size === 0) return null;\r\n const selected = filteredIllustrations.filter(i => selectedIllustrations.has(i.path));\r\n const byCategory: Record<string, number> = {};\r\n selected.forEach(i => {\r\n byCategory[i.category] = (byCategory[i.category] || 0) + 1;\r\n });\r\n return { count: selectedIllustrations.size, byCategory };\r\n };\r\n\r\n const selectedInfo = getSelectedInfo();\r\n\r\n // Generate animation styles\r\n const animationName = 'illustration-animation';\r\n const animationStyle = animationConfig ? getAnimationStyle(animationConfig, animationName) : {};\r\n const animationKeyframes = animationConfig ? generateAnimationCSS(animationConfig, animationName) : '';\r\n\r\n // Inject keyframes into document\r\n useEffect(() => {\r\n if (!animationConfig || !animationKeyframes) return;\r\n \r\n const styleId = 'illustration-animation-keyframes';\r\n let styleElement = document.getElementById(styleId) as HTMLStyleElement;\r\n \r\n if (!styleElement) {\r\n styleElement = document.createElement('style');\r\n styleElement.id = styleId;\r\n document.head.appendChild(styleElement);\r\n }\r\n \r\n styleElement.textContent = animationKeyframes;\r\n \r\n return () => {\r\n // Cleanup on unmount\r\n const element = document.getElementById(styleId);\r\n if (element) element.remove();\r\n };\r\n }, [animationConfig, animationKeyframes]);\r\n\r\n return (\r\n <div className=\"w-full space-y-6 p-6\">\r\n {/* Header */}\r\n <div className=\"space-y-4\">\r\n <div className=\"flex items-start justify-between\">\r\n <div>\r\n <h2 className=\"text-lg font-bold text-gray-900 dark:text-white mb-2\">Streamline Illustrations</h2>\r\n <p className=\"text-sm text-gray-600 dark:text-gray-400\">\r\n Browse {allIllustrations.length.toLocaleString()} free vector illustrations from{' '}\r\n <a \r\n href=\"https://github.com/webalys-hq/streamline-vectors\" \r\n target=\"_blank\" \r\n rel=\"noopener noreferrer\"\r\n className=\"text-blue-600 hover:underline inline-flex items-center gap-1\"\r\n >\r\n Streamline Vectors <ExternalLink size={14} />\r\n </a>\r\n . Licensed under{' '}\r\n <a \r\n href=\"https://creativecommons.org/licenses/by/4.0/\" \r\n target=\"_blank\" \r\n rel=\"noopener noreferrer\"\r\n className=\"text-blue-600 hover:underline\"\r\n >\r\n CC BY 4.0\r\n </a>\r\n .\r\n </p>\r\n </div>\r\n <button\r\n onClick={() => setShowControls(!showControls)}\r\n className={`p-2 rounded-lg transition-colors ${showControls ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400'}`}\r\n title=\"Toggle Controls\"\r\n >\r\n <SlidersHorizontal size={20} />\r\n </button>\r\n </div>\r\n\r\n {/* Controls Panel */}\r\n {showControls && (\r\n <div className=\"p-4 bg-gray-50 dark:bg-gray-800/50 rounded-lg border border-gray-200 dark:border-gray-700 space-y-4\">\r\n {/* Sort Options */}\r\n <div>\r\n <label className=\"text-xs font-semibold text-gray-700 dark:text-gray-300 mb-2 block\">\r\n Sort By\r\n </label>\r\n <div className=\"flex gap-2\">\r\n {(['name', 'category', 'newest'] as const).map(option => (\r\n <button\r\n key={option}\r\n onClick={() => setSortBy(option)}\r\n className={`px-3 py-1.5 rounded-md text-xs font-medium transition-colors capitalize ${\r\n sortBy === option\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'\r\n }`}\r\n >\r\n {option}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n <div className=\"p-3 bg-purple-50 dark:bg-purple-900/20 rounded-lg border border-purple-200 dark:border-purple-800\">\r\n <p className=\"text-xs text-purple-900 dark:text-purple-100 font-semibold mb-1\">\r\n 💡 Tip: Use Inspector Controls\r\n </p>\r\n <p className=\"text-xs text-purple-700 dark:text-purple-300\">\r\n Illustration size, color overlay, and other settings are controlled globally via the Inspector panel on the right. Open the Inspector and go to the Theme tab to adjust these settings.\r\n </p>\r\n </div>\r\n\r\n {/* Selection Actions */}\r\n {selectedInfo && (\r\n <div className=\"flex items-center justify-between p-3 bg-blue-50 dark:bg-blue-900/20 rounded-lg border border-blue-200 dark:border-blue-800\">\r\n <div>\r\n <span className=\"text-sm font-semibold text-blue-900 dark:text-blue-100\">\r\n {selectedInfo.count} illustration{selectedInfo.count !== 1 ? 's' : ''} selected\r\n </span>\r\n </div>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={deselectAll}\r\n className=\"px-3 py-1.5 bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 rounded-md text-xs font-medium hover:bg-gray-300 dark:hover:bg-gray-600 transition-colors\"\r\n >\r\n Clear Selection\r\n </button>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n )}\r\n\r\n {/* Search and Filters */}\r\n <div className=\"flex flex-col sm:flex-row gap-4\">\r\n <div className=\"flex-1 relative\">\r\n <Search className=\"absolute left-3 top-1/2 transform -translate-y-1/2 text-gray-400\" size={18} />\r\n <input\r\n type=\"text\"\r\n placeholder={`Search ${allIllustrations.length.toLocaleString()} illustrations...`}\r\n value={searchQuery}\r\n onChange={(e) => setSearchQuery(e.target.value)}\r\n className={`w-full pl-10 pr-4 py-2 border rounded-lg bg-white dark:bg-gray-800 text-gray-900 dark:text-white focus:ring-2 focus:ring-blue-500 focus:border-transparent transition-colors ${\r\n searchQuery ? 'border-blue-300 dark:border-blue-700' : 'border-gray-300 dark:border-gray-700'\r\n }`}\r\n />\r\n {searchQuery && (\r\n <button\r\n onClick={() => setSearchQuery('')}\r\n className=\"absolute right-3 top-1/2 transform -translate-y-1/2 text-gray-400 hover:text-gray-600 dark:hover:text-gray-300\"\r\n title=\"Clear search\"\r\n >\r\n <X size={16} />\r\n </button>\r\n )}\r\n </div>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={() => setViewMode('grid')}\r\n className={`p-2 rounded-lg transition-colors ${viewMode === 'grid' ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-200 dark:hover:bg-gray-700'}`}\r\n title=\"Grid View\"\r\n >\r\n <Grid3X3 size={18} />\r\n </button>\r\n <button\r\n onClick={() => setViewMode('list')}\r\n className={`p-2 rounded-lg transition-colors ${viewMode === 'list' ? 'bg-blue-600 text-white' : 'bg-gray-100 dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-200 dark:hover:bg-gray-700'}`}\r\n title=\"List View\"\r\n >\r\n <List size={18} />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Category Filter */}\r\n <div className=\"flex flex-wrap items-center gap-2\">\r\n <button\r\n onClick={() => { setSelectedCategory('all'); setSelectedStyle('all'); }}\r\n className={`px-4 py-2 rounded-lg text-sm font-medium transition-all ${\r\n selectedCategory === 'all'\r\n ? 'bg-blue-600 text-white shadow-md ring-2 ring-blue-300 dark:ring-blue-700'\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-700 hover:shadow-sm'\r\n }`}\r\n >\r\n All Categories\r\n <span className=\"ml-2 text-xs opacity-75\">({allIllustrations.length.toLocaleString()})</span>\r\n </button>\r\n {categories.map(category => {\r\n const count = allIllustrations.filter(i => i.category === category).length;\r\n const info = CATEGORY_INFO[category] || { name: category, description: '' };\r\n return (\r\n <button\r\n key={category}\r\n onClick={() => { setSelectedCategory(category); setSelectedStyle('all'); }}\r\n className={`px-4 py-2 rounded-lg text-sm font-medium transition-all flex items-center gap-2 ${\r\n selectedCategory === category\r\n ? 'bg-blue-600 text-white shadow-md ring-2 ring-blue-300 dark:ring-blue-700'\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-700 hover:shadow-sm'\r\n }`}\r\n title={info.description || `${info.name} category`}\r\n >\r\n {info.name}\r\n <span className=\"text-xs opacity-75\">({count.toLocaleString()})</span>\r\n </button>\r\n );\r\n })}\r\n {(searchQuery || selectedCategory !== 'all' || selectedStyle !== 'all') && (\r\n <button\r\n onClick={() => {\r\n setSearchQuery('');\r\n setSelectedCategory('all');\r\n setSelectedStyle('all');\r\n }}\r\n className=\"px-3 py-2 rounded-lg text-sm font-medium text-gray-600 dark:text-gray-400 hover:text-gray-900 dark:hover:text-gray-200 hover:bg-gray-100 dark:hover:bg-gray-800 transition-colors flex items-center gap-1\"\r\n title=\"Clear all filters\"\r\n >\r\n <X size={14} />\r\n Clear Filters\r\n </button>\r\n )}\r\n </div>\r\n\r\n {/* Style Filter (if category selected and has styles) */}\r\n {selectedCategory !== 'all' && styles.length > 0 && (\r\n <div className=\"flex flex-wrap gap-2\">\r\n <button\r\n onClick={() => setSelectedStyle('all')}\r\n className={`px-3 py-1.5 rounded-md text-xs font-medium transition-colors ${\r\n selectedStyle === 'all'\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-700'\r\n }`}\r\n >\r\n All Styles\r\n </button>\r\n {styles.map(style => (\r\n <button\r\n key={style}\r\n onClick={() => setSelectedStyle(style)}\r\n className={`px-3 py-1.5 rounded-md text-xs font-medium transition-colors capitalize ${\r\n selectedStyle === style\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-gray-100 dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-200 dark:hover:bg-gray-700'\r\n }`}\r\n >\r\n {style}\r\n </button>\r\n ))}\r\n </div>\r\n )}\r\n\r\n {/* Bulk Actions */}\r\n <div className=\"flex items-center justify-between text-xs text-gray-500 dark:text-gray-400\">\r\n <span>\r\n Showing {((currentPage - 1) * itemsPerPage + 1).toLocaleString()}-{Math.min(currentPage * itemsPerPage, filteredIllustrations.length).toLocaleString()} of {filteredIllustrations.length.toLocaleString()} illustrations\r\n {filteredIllustrations.length !== allIllustrations.length && ` (${allIllustrations.length.toLocaleString()} total)`}\r\n </span>\r\n <div className=\"flex gap-2\">\r\n <button\r\n onClick={selectAll}\r\n className=\"hover:text-blue-600 dark:hover:text-blue-400 transition-colors\"\r\n >\r\n Select All Visible\r\n </button>\r\n {selectedIllustrations.size > 0 && (\r\n <>\r\n <span>•</span>\r\n <button\r\n onClick={deselectAll}\r\n className=\"hover:text-red-600 dark:hover:text-red-400 transition-colors\"\r\n >\r\n Deselect All\r\n </button>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Illustrations Display */}\r\n {isLoading ? (\r\n <div className=\"text-center py-12\">\r\n <div className=\"inline-block animate-spin rounded-full h-8 w-8 border-b-2 border-blue-600 mb-4\"></div>\r\n <p className=\"text-gray-500 dark:text-gray-400\">Loading illustrations...</p>\r\n </div>\r\n ) : filteredIllustrations.length > 0 ? (\r\n <>\r\n <div className={viewMode === 'grid' \r\n ? 'grid grid-cols-2 sm:grid-cols-3 md:grid-cols-4 lg:grid-cols-5 xl:grid-cols-6 gap-4' \r\n : 'space-y-4'\r\n }>\r\n {paginatedIllustrations.map((illustration) => {\r\n const isSelected = selectedIllustrations.has(illustration.path);\r\n const isCopied = copiedIllustration === illustration.path;\r\n return (\r\n <div\r\n key={illustration.path}\r\n className={`\r\n group relative rounded-lg border-2 transition-all overflow-hidden\r\n ${isSelected\r\n ? 'border-blue-500 bg-blue-50 dark:bg-blue-900/20 ring-2 ring-blue-200 dark:ring-blue-800'\r\n : isCopied\r\n ? 'border-green-500 bg-green-50 dark:bg-green-900/20'\r\n : 'border-gray-200 dark:border-gray-700 hover:border-blue-500 hover:shadow-lg bg-white dark:bg-gray-800'\r\n }\r\n ${viewMode === 'list' ? 'flex items-center gap-4 p-4' : 'aspect-square p-4 flex flex-col'}\r\n `}\r\n >\r\n {isSelected && (\r\n <div className=\"absolute top-1 right-1 w-5 h-5 bg-blue-600 rounded-full flex items-center justify-center z-10\">\r\n <Check size={12} className=\"text-white\" />\r\n </div>\r\n )}\r\n \r\n {/* Illustration Preview */}\r\n <div className={`\r\n ${viewMode === 'list' ? 'w-24 h-24 flex-shrink-0' : 'flex-1'}\r\n flex items-center justify-center bg-gray-50 dark:bg-gray-900/50 rounded overflow-hidden\r\n `}>\r\n <img\r\n src={illustration.url}\r\n alt={illustration.name}\r\n className={`w-full h-full object-contain p-2 ${animationConfig ? 'cursor-pointer' : ''}`}\r\n style={{\r\n width: `${illustrationSize}%`,\r\n height: `${illustrationSize}%`,\r\n filter: illustrationColor === 'default' \r\n ? 'none' \r\n : illustrationColor === 'primary'\r\n ? `hue-rotate(${getColorValue(defaultGlobalConfig, 'primary', 600) === '#2563eb' ? '0deg' : '180deg'}) saturate(1.2) brightness(1.1)`\r\n : illustrationColor === 'secondary'\r\n ? `hue-rotate(${getColorValue(defaultGlobalConfig, 'secondary', 500) === '#3b82f6' ? '0deg' : '180deg'}) saturate(1.1) brightness(1.05)`\r\n : `brightness(0) saturate(100%) invert(${getColorFilter(illustrationCustomColor)})`,\r\n ...(animationConfig ? animationStyle : {})\r\n }}\r\n onClick={() => {\r\n if (animationConfig) {\r\n // Trigger animation by removing and re-adding the style\r\n const element = document.querySelector(`[data-illustration-path=\"${illustration.path}\"]`) as HTMLElement;\r\n if (element) {\r\n element.style.animation = 'none';\r\n setTimeout(() => {\r\n element.style.animation = '';\r\n Object.assign(element.style, animationStyle);\r\n }, 10);\r\n }\r\n }\r\n }}\r\n data-illustration-path={illustration.path}\r\n onError={(e) => {\r\n e.currentTarget.style.display = 'none';\r\n const parent = e.currentTarget.parentElement;\r\n if (parent) {\r\n parent.innerHTML = `<div class=\"w-full h-full flex items-center justify-center text-gray-400 text-xs\">Failed to load</div>`;\r\n }\r\n }}\r\n />\r\n </div>\r\n\r\n {/* Info */}\r\n <div className={viewMode === 'list' ? 'flex-1' : 'mt-2'}>\r\n <div className=\"text-xs font-semibold text-gray-900 dark:text-white truncate\">\r\n {illustration.name}\r\n </div>\r\n <div className=\"text-[10px] text-gray-400 dark:text-gray-500 capitalize mt-0.5\">\r\n {illustration.category}\r\n {illustration.style && ` • ${illustration.style}`}\r\n </div>\r\n </div>\r\n\r\n {/* Actions */}\r\n <div className={`\r\n absolute top-2 right-2 flex gap-1 opacity-0 group-hover:opacity-100 transition-opacity\r\n ${isCopied ? 'opacity-100' : ''}\r\n `}>\r\n <button\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n copyToClipboard(illustration);\r\n }}\r\n className={`p-2 rounded-md transition-colors ${\r\n isCopied \r\n ? 'bg-green-500 text-white' \r\n : 'bg-white dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 shadow-sm'\r\n }`}\r\n title=\"Copy code\"\r\n >\r\n {isCopied ? <Check size={14} /> : <Copy size={14} />}\r\n </button>\r\n <button\r\n onClick={(e) => {\r\n e.stopPropagation();\r\n downloadSVG(illustration);\r\n }}\r\n className=\"p-2 rounded-md bg-white dark:bg-gray-800 text-gray-600 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 shadow-sm transition-colors\"\r\n title=\"Download SVG\"\r\n >\r\n <Download size={14} />\r\n </button>\r\n </div>\r\n\r\n {/* Click to select */}\r\n <div\r\n className=\"absolute inset-0 cursor-pointer\"\r\n onClick={(e) => {\r\n if (e.target === e.currentTarget || (e.target as HTMLElement).tagName !== 'BUTTON') {\r\n toggleIllustrationSelection(illustration.path);\r\n }\r\n }}\r\n />\r\n </div>\r\n );\r\n })}\r\n </div>\r\n\r\n {/* Pagination */}\r\n {totalPages > 1 && (\r\n <div className=\"flex items-center justify-center gap-2 mt-6\">\r\n <button\r\n onClick={() => setCurrentPage(prev => Math.max(1, prev - 1))}\r\n disabled={currentPage === 1}\r\n className={`p-2 rounded-lg transition-colors ${\r\n currentPage === 1\r\n ? 'bg-gray-100 dark:bg-gray-800 text-gray-400 cursor-not-allowed'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n <ChevronLeft size={18} />\r\n </button>\r\n \r\n <div className=\"flex gap-1\">\r\n {Array.from({ length: Math.min(7, totalPages) }, (_, i) => {\r\n let pageNum: number;\r\n if (totalPages <= 7) {\r\n pageNum = i + 1;\r\n } else if (currentPage <= 4) {\r\n pageNum = i + 1;\r\n } else if (currentPage >= totalPages - 3) {\r\n pageNum = totalPages - 6 + i;\r\n } else {\r\n pageNum = currentPage - 3 + i;\r\n }\r\n \r\n return (\r\n <button\r\n key={pageNum}\r\n onClick={() => setCurrentPage(pageNum)}\r\n className={`px-3 py-1.5 rounded-lg text-sm font-medium transition-colors ${\r\n currentPage === pageNum\r\n ? 'bg-blue-600 text-white'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n {pageNum}\r\n </button>\r\n );\r\n })}\r\n </div>\r\n\r\n <button\r\n onClick={() => setCurrentPage(prev => Math.min(totalPages, prev + 1))}\r\n disabled={currentPage === totalPages}\r\n className={`p-2 rounded-lg transition-colors ${\r\n currentPage === totalPages\r\n ? 'bg-gray-100 dark:bg-gray-800 text-gray-400 cursor-not-allowed'\r\n : 'bg-white dark:bg-gray-800 text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700 border border-gray-300 dark:border-gray-700'\r\n }`}\r\n >\r\n <ChevronRight size={18} />\r\n </button>\r\n </div>\r\n )}\r\n </>\r\n ) : (\r\n <div className=\"text-center py-12\">\r\n <p className=\"text-gray-500 dark:text-gray-400\">No illustrations found matching your search.</p>\r\n </div>\r\n )}\r\n\r\n {/* Usage Instructions - Hidden in sticker sheet */}\r\n {!hideInstructions && (\r\n <div className=\"mt-8 p-4 bg-gray-50 dark:bg-gray-800/50 rounded-lg border border-gray-200 dark:border-gray-700\">\r\n <h3 className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">Usage Instructions</h3>\r\n <ol className=\"text-xs text-gray-600 dark:text-gray-400 space-y-2 list-decimal list-inside\">\r\n <li>Browse illustrations by category or search by name</li>\r\n <li>Click an illustration to select it (or use Select All Visible)</li>\r\n <li>Click the copy icon to copy the image tag code</li>\r\n <li>Click the download icon to download the SVG file</li>\r\n <li>All illustrations are free to use under CC BY 4.0 license</li>\r\n <li>Attribution: Include a link to <a href=\"https://streamlinehq.com\" className=\"text-blue-600 hover:underline\">streamlinehq.com</a> when using</li>\r\n </ol>\r\n <div className=\"mt-4 p-3 bg-white dark:bg-gray-900 rounded border border-gray-200 dark:border-gray-700\">\r\n <p className=\"text-xs font-mono text-gray-700 dark:text-gray-300 mb-2\">\r\n <span className=\"text-gray-500\">// Using as image:</span><br />\r\n <span className=\"text-blue-600\">&lt;img</span> <span className=\"text-green-600\">src</span>=<span className=\"text-orange-600\">\"{'{'}illustration.url{'}'}\"</span> <span className=\"text-green-600\">alt</span>=<span className=\"text-orange-600\">\"description\"</span> <span className=\"text-blue-600\">/&gt;</span>\r\n </p>\r\n <p className=\"text-xs font-mono text-gray-700 dark:text-gray-300\">\r\n <span className=\"text-gray-500\">// Or inline SVG:</span><br />\r\n <span className=\"text-blue-600\">import</span> illustration <span className=\"text-blue-600\">from</span> <span className=\"text-green-600\">'./assets/illustrations/...'</span>;\r\n </p>\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState, useEffect, useRef } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Play, Pause, Volume2, VolumeX, Maximize, Settings, SkipForward, SkipBack } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface VideoPlayerProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const VideoPlayer: React.FC<VideoPlayerProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [isPlaying, setIsPlaying] = useState(false);\r\n const [isMuted, setIsMuted] = useState(false);\r\n const [progress, setProgress] = useState(30); // Mock progress 30%\r\n const [showControls, setShowControls] = useState(true);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n\r\n const togglePlay = () => setIsPlaying(!isPlaying);\r\n const toggleMute = () => setIsMuted(!isMuted);\r\n\r\n // Auto-hide controls simulation\r\n useEffect(() => {\r\n if (isPlaying) {\r\n const timer = setTimeout(() => setShowControls(false), 2000);\r\n return () => clearTimeout(timer);\r\n } else {\r\n setShowControls(true);\r\n }\r\n }, [isPlaying, showControls]);\r\n\r\n // Handle hover to show controls\r\n const handleMouseEnter = () => setShowControls(true);\r\n const handleMouseLeave = () => isPlaying && setShowControls(false);\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div \r\n ref={containerRef}\r\n style={appliedStyles}\r\n className={`\r\n relative w-full h-full min-h-[300px] aspect-video overflow-hidden group flex flex-col\r\n ${isMUI ? 'shadow-lg' : ''}\r\n ${isApple ? 'rounded-2xl shadow-xl' : ''}\r\n ${isCustom ? `${getRadiusClass(globalConfig)} border border-gray-200 dark:border-gray-800` : ''}\r\n `}\r\n onMouseEnter={handleMouseEnter}\r\n onMouseLeave={handleMouseLeave}\r\n >\r\n {/* Video Placeholder (Image) */}\r\n <div className=\"flex-1 min-h-0 relative\">\r\n <img \r\n src=\"https://images.unsplash.com/photo-1492691527719-9d1e07e534b4?ixlib=rb-1.2.1&auto=format&fit=crop&w=1600&q=80\" \r\n alt=\"Video content\" \r\n className=\"w-full h-full object-cover\"\r\n />\r\n </div>\r\n \r\n {/* Center Play Button - White Icon on Video */}\r\n {!isPlaying && (\r\n <div className=\"absolute inset-0 flex items-center justify-center z-10 pointer-events-auto cursor-pointer\" onClick={togglePlay}>\r\n <div className=\"w-16 h-16 flex items-center justify-center rounded-full transition-transform duration-300 hover:scale-110\">\r\n <Play size={48} className=\"text-white drop-shadow-lg\" fill=\"currentColor\" />\r\n </div>\r\n </div>\r\n )}\r\n\r\n {/* Controls Container */}\r\n <div \r\n className={`\r\n absolute bottom-0 left-0 right-0 z-20 transition-all duration-300\r\n ${showControls ? 'opacity-100 translate-y-0' : 'opacity-0 translate-y-4'}\r\n ${isMUI ? 'p-4' : ''}\r\n ${isApple ? 'p-6 pb-8' : ''}\r\n ${isCustom ? 'p-4 bg-white/90 dark:bg-gray-900/90 border-t border-gray-200 dark:border-gray-800' : ''}\r\n `}\r\n >\r\n {/* Custom: Progress Bar at top of controls */}\r\n {isCustom && (\r\n <div className=\"w-full h-1 bg-gray-200 dark:bg-gray-700 rounded-full mb-4 cursor-pointer relative group/slider\">\r\n <div className={`h-full rounded-full ${getColorClass(globalConfig, 'bg')}`} style={{ width: `${progress}%` }} />\r\n <div className=\"absolute top-1/2 -translate-y-1/2 w-3 h-3 bg-white border border-gray-300 rounded-full shadow-sm opacity-0 group-hover/slider:opacity-100 transition-opacity\" style={{ left: `${progress}%` }} />\r\n </div>\r\n )}\r\n\r\n <div className=\"flex items-center gap-4 text-white\">\r\n \r\n {/* Play/Pause */}\r\n <button onClick={togglePlay} className={`hover:scale-110 transition-transform ${isCustom ? 'text-gray-900 dark:text-white' : ''}`}>\r\n {isPlaying ? <Pause size={isMUI ? 28 : 24} fill={isMUI ? \"currentColor\" : \"none\"} /> : <Play size={isMUI ? 28 : 24} fill={isMUI ? \"currentColor\" : \"none\"} />}\r\n </button>\r\n\r\n {/* Volume */}\r\n <div className={`flex items-center gap-2 group/vol ${isCustom ? 'text-gray-600 dark:text-gray-400' : ''}`}>\r\n <button onClick={toggleMute}>\r\n {isMuted ? <VolumeX size={20} /> : <Volume2 size={20} />}\r\n </button>\r\n <div className=\"w-0 overflow-hidden group-hover/vol:w-20 transition-all duration-300\">\r\n <div className=\"w-20 h-1 bg-white/30 rounded-full ml-2 relative\">\r\n <div className=\"absolute left-0 top-0 bottom-0 bg-white rounded-full\" style={{ width: '60%' }} />\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {/* Time Display */}\r\n <span className={`text-xs font-medium font-mono ${isCustom ? 'text-gray-500' : 'opacity-80'}`}>\r\n 02:14 / 08:30\r\n </span>\r\n\r\n {/* Progress Bar (MUI / Apple) */}\r\n {!isCustom && (\r\n <div className=\"flex-1 mx-4 h-1 bg-white/30 rounded-full cursor-pointer relative group/track\">\r\n <div className={`absolute left-0 top-0 bottom-0 bg-white rounded-full ${isMUI ? 'bg-red-600' : ''}`} style={{ width: `${progress}%` }} />\r\n {isApple && (\r\n <div \r\n className=\"absolute top-1/2 -translate-y-1/2 w-4 h-4 bg-white rounded-full shadow-lg opacity-0 group-hover/track:opacity-100 transition-opacity\"\r\n style={{ left: `${progress}%` }}\r\n />\r\n )}\r\n </div>\r\n )}\r\n \r\n {/* Custom Spacer */}\r\n {isCustom && <div className=\"flex-1\" />}\r\n\r\n {/* Settings & Fullscreen */}\r\n <div className={`flex items-center gap-3 ${isCustom ? 'text-gray-600 dark:text-gray-400' : ''}`}>\r\n <button><Settings size={20} /></button>\r\n <button><Maximize size={20} /></button>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n {/* Loading State Overlay */}\r\n {componentProps.isLoading && (\r\n <div className=\"absolute inset-0 bg-black/60 z-30 flex items-center justify-center\">\r\n <div className=\"w-10 h-10 border-4 border-white/30 border-t-white rounded-full animate-spin\" />\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};","\r\nimport React, { useState } from 'react';\r\nimport { Monitor, Smartphone, Tablet, Tv, Printer, Globe } from 'lucide-react';\r\n\r\ninterface TypographyPreviewProps {\r\n activeFont?: string;\r\n hideDeviceSelector?: boolean;\r\n deviceType?: 'mobile' | 'tablet' | 'desktop' | 'largeScreen' | 'tv' | 'web';\r\n viewportWidth?: number;\r\n}\r\n\r\n// Device-specific typography scales\r\nconst DEVICE_SCALES = {\r\n mobile: {\r\n display2xl: { size: '48px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '40px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '32px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '28px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '24px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '20px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '18px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '16px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '18px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '16px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '14px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '12px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n tablet: {\r\n display2xl: { size: '56px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '48px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '40px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '32px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '28px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '22px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '19px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '16px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '19px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '16px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '14px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '12px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n desktop: {\r\n display2xl: { size: '72px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '60px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '48px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '36px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '30px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '24px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '20px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '16px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '20px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '16px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '14px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '12px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n largeScreen: {\r\n display2xl: { size: '96px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '80px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '64px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '48px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '40px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '32px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '24px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '18px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '24px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '18px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '16px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '14px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n tv: {\r\n display2xl: { size: '120px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '100px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '80px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '64px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '52px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '40px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '32px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '24px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '28px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '22px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '20px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '18px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n print: {\r\n display2xl: { size: '36pt', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '30pt', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '24pt', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '18pt', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '16pt', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '14pt', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '12pt', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '10pt', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '12pt', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '10pt', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '9pt', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '8pt', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n web: {\r\n display2xl: { size: '72px', lineHeight: '1.0', weight: 'ExtraBold' },\r\n displayxl: { size: '60px', lineHeight: '1.1', weight: 'Bold' },\r\n h1: { size: '48px', lineHeight: '1.2', weight: 'Bold' },\r\n h2: { size: '36px', lineHeight: '1.3', weight: 'Semibold' },\r\n h3: { size: '30px', lineHeight: '1.3', weight: 'Semibold' },\r\n h4: { size: '24px', lineHeight: '1.4', weight: 'Medium' },\r\n h5: { size: '20px', lineHeight: '1.4', weight: 'Medium' },\r\n h6: { size: '16px', lineHeight: '1.4', weight: 'Semibold' },\r\n lead: { size: '20px', lineHeight: '1.6', weight: 'Regular' },\r\n base: { size: '16px', lineHeight: '1.5', weight: 'Regular' },\r\n small: { size: '14px', lineHeight: '1.4', weight: 'Regular' },\r\n tiny: { size: '12px', lineHeight: '1.2', weight: 'Medium' },\r\n },\r\n};\r\n\r\nconst DEVICE_ICONS = {\r\n mobile: Smartphone,\r\n tablet: Tablet,\r\n desktop: Monitor,\r\n largeScreen: Monitor,\r\n tv: Tv,\r\n print: Printer,\r\n web: Globe,\r\n};\r\n\r\nexport const TypographyPreview: React.FC<TypographyPreviewProps> = ({ \r\n activeFont = 'Inter', \r\n hideDeviceSelector = false,\r\n deviceType,\r\n viewportWidth = 1024\r\n}) => {\r\n const [selectedDevice, setSelectedDevice] = useState<keyof typeof DEVICE_SCALES>(deviceType || 'web');\r\n \r\n // Use deviceType prop if provided, otherwise use selectedDevice state\r\n const activeDeviceType = deviceType || selectedDevice;\r\n const scale = DEVICE_SCALES[activeDeviceType];\r\n \r\n // Calculate responsive font sizes based on viewport width\r\n // Using fluid typography: clamp(min, preferred, max)\r\n const getResponsiveSize = (baseSize: string, minScale: number = 0.75, maxScale: number = 1.25) => {\r\n const base = parseInt(baseSize);\r\n const min = Math.round(base * minScale);\r\n const max = Math.round(base * maxScale);\r\n \r\n // For very small viewports, scale down more aggressively\r\n if (viewportWidth < 640) {\r\n return `${Math.max(min, Math.round(base * (viewportWidth / 1024)))}px`;\r\n }\r\n \r\n // For larger viewports, scale up proportionally\r\n if (viewportWidth > 1024) {\r\n const scaleFactor = Math.min(maxScale, viewportWidth / 1024);\r\n return `${Math.min(max, Math.round(base * scaleFactor))}px`;\r\n }\r\n \r\n return baseSize;\r\n };\r\n\r\n return (\r\n <div \r\n className=\"space-y-6 p-4 md:p-6 bg-white dark:bg-gray-950\" \r\n style={{ \r\n fontFamily: activeFont,\r\n width: '100%',\r\n maxWidth: '100%',\r\n overflowX: 'hidden'\r\n }}\r\n >\r\n \r\n {/* Device Selector - Hidden when used in foundation pages */}\r\n {!hideDeviceSelector && (\r\n <div className=\"flex items-center gap-2 pb-4 border-b border-gray-200 dark:border-gray-800\">\r\n <span className=\"text-xs font-bold text-gray-500 uppercase tracking-wider mr-2\">Device Type:</span>\r\n <div className=\"flex bg-gray-100 dark:bg-gray-800 rounded-lg p-1\">\r\n {(Object.keys(DEVICE_SCALES) as Array<keyof typeof DEVICE_SCALES>).map(device => {\r\n const Icon = DEVICE_ICONS[device];\r\n return (\r\n <button\r\n key={device}\r\n onClick={() => setSelectedDevice(device)}\r\n className={`\r\n p-2 rounded-md transition-all flex items-center gap-2 text-xs font-medium\r\n ${selectedDevice === device \r\n ? 'bg-white dark:bg-gray-700 text-blue-600 dark:text-blue-400 shadow-sm' \r\n : 'text-gray-500 hover:text-gray-900 dark:hover:text-gray-300'}\r\n `}\r\n >\r\n <Icon size={14} />\r\n <span className=\"hidden sm:inline capitalize\">{device === 'largeScreen' ? 'Large Screen' : device}</span>\r\n </button>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n )}\r\n \r\n {/* Display Styles */}\r\n <section className=\"space-y-6\">\r\n <div className=\"mb-6\">\r\n <h4 className=\"text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wider mb-1\">Display</h4>\r\n <div className=\"h-px bg-gray-200 dark:bg-gray-800\"></div>\r\n </div>\r\n \r\n <div className=\"space-y-10\">\r\n {/* Display 2XL */}\r\n <div className=\"pb-6 border-b border-gray-100 dark:border-gray-800/50\">\r\n <div className=\"mb-3\">\r\n <div className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">Display 2XL</div>\r\n <div className=\"flex items-center gap-2 text-xs text-gray-500 dark:text-gray-400\">\r\n <span className=\"font-medium\">{activeFont}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">{scale.display2xl.weight}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">{scale.display2xl.size} / {scale.display2xl.lineHeight}</span>\r\n </div>\r\n </div>\r\n <h1 \r\n className=\"font-extrabold tracking-tight text-gray-900 dark:text-white break-words leading-none\"\r\n style={{ \r\n fontSize: getResponsiveSize(scale.display2xl.size, 0.6, 1.2), \r\n lineHeight: scale.display2xl.lineHeight,\r\n fontWeight: scale.display2xl.weight === 'ExtraBold' ? 800 : 700\r\n }}\r\n >\r\n Fluid &amp; Open\r\n </h1>\r\n </div>\r\n\r\n {/* Display XL */}\r\n <div className=\"pb-6 border-b border-gray-100 dark:border-gray-800/50\">\r\n <div className=\"mb-3\">\r\n <div className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">Display XL</div>\r\n <div className=\"flex items-center gap-2 text-xs text-gray-500 dark:text-gray-400\">\r\n <span className=\"font-medium\">{activeFont}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">{scale.displayxl.weight}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">{scale.displayxl.size} / {scale.displayxl.lineHeight}</span>\r\n </div>\r\n </div>\r\n <h1 \r\n className=\"font-bold tracking-tight text-gray-900 dark:text-white break-words leading-none\"\r\n style={{ \r\n fontSize: getResponsiveSize(scale.displayxl.size, 0.65, 1.15), \r\n lineHeight: scale.displayxl.lineHeight,\r\n fontWeight: 700\r\n }}\r\n >\r\n Design System\r\n </h1>\r\n </div>\r\n </div>\r\n </section>\r\n\r\n {/* Headings */}\r\n <section className=\"space-y-6 mt-10\">\r\n <div className=\"mb-6\">\r\n <h4 className=\"text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wider mb-1\">Headings</h4>\r\n <div className=\"h-px bg-gray-200 dark:bg-gray-800\"></div>\r\n </div>\r\n\r\n <div className=\"space-y-6\">\r\n {[\r\n { key: 'h1', label: 'H1', text: 'The quick brown fox' },\r\n { key: 'h2', label: 'H2', text: 'Jumps over the lazy dog' },\r\n { key: 'h3', label: 'H3', text: 'System Design Principles' },\r\n { key: 'h4', label: 'H4', text: 'Clarity in motion' },\r\n { key: 'h5', label: 'H5', text: 'Component Architecture' },\r\n { key: 'h6', label: 'H6', text: 'Documentation', uppercase: true },\r\n ].map((h, index, array) => {\r\n const scaleData = scale[h.key as keyof typeof scale];\r\n const fontWeight = scaleData.weight === 'Bold' ? 700 : \r\n scaleData.weight === 'Semibold' ? 600 : \r\n scaleData.weight === 'Medium' ? 500 : 400;\r\n const responsiveSize = getResponsiveSize(scaleData.size, 0.7, 1.1);\r\n const isLast = index === array.length - 1;\r\n return (\r\n <div key={h.key} className={`pb-6 ${!isLast ? 'border-b border-gray-100 dark:border-gray-800/50' : ''}`}>\r\n <div className=\"mb-3\">\r\n <div className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">{h.label}</div>\r\n <div className=\"flex items-center gap-2 text-xs text-gray-500 dark:text-gray-400\">\r\n <span className=\"font-mono\">{scaleData.size}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono uppercase\">{scaleData.weight}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">Line height: {scaleData.lineHeight}</span>\r\n </div>\r\n </div>\r\n <div \r\n className={`text-gray-900 dark:text-white break-words ${h.uppercase ? 'uppercase tracking-wide' : ''}`}\r\n style={{ \r\n fontSize: responsiveSize, \r\n lineHeight: scaleData.lineHeight,\r\n fontWeight\r\n }}\r\n >\r\n {h.text}\r\n </div>\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </section>\r\n\r\n {/* Body */}\r\n <section className=\"space-y-6 mt-10\">\r\n <div className=\"mb-6\">\r\n <h4 className=\"text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase tracking-wider mb-1\">Body Text</h4>\r\n <div className=\"h-px bg-gray-200 dark:bg-gray-800\"></div>\r\n </div>\r\n\r\n <div className=\"space-y-6\">\r\n {[\r\n { key: 'lead', label: 'Lead', text: 'OpenGrid is an open, transparent and fluid design platform. It moves like water, adjusts like air and reveals structure like light. Nothing is rigid unless you choose it to be.', color: 'text-gray-600 dark:text-gray-300' },\r\n { key: 'base', label: 'Base', text: 'Typography is the art and technique of arranging type to make written language legible, readable, and appealing when displayed. The arrangement of type involves selecting typefaces, point sizes, line lengths, line-spacing, and letter-spacing, and adjusting the space between pairs of letters.', color: 'text-gray-700 dark:text-gray-400' },\r\n { key: 'small', label: 'Small', text: 'This text is often used for secondary information, captions, or helper text. It should remain legible but recede visually compared to the body text. Effective use of small text helps establish visual hierarchy.', color: 'text-gray-500 dark:text-gray-500' },\r\n { key: 'tiny', label: 'Tiny', text: 'Copyright © 2024 OpenGrid Systems. All rights reserved.', color: 'text-gray-400', uppercase: true },\r\n ].map((item, index, array) => {\r\n const scaleData = scale[item.key as keyof typeof scale];\r\n const isLast = index === array.length - 1;\r\n const responsiveSize = item.key === 'lead' ? getResponsiveSize(scaleData.size, 0.8, 1.1) :\r\n item.key === 'base' ? getResponsiveSize(scaleData.size, 0.85, 1.05) :\r\n item.key === 'small' ? getResponsiveSize(scaleData.size, 0.85, 1.05) :\r\n getResponsiveSize(scaleData.size, 0.9, 1.0);\r\n \r\n return (\r\n <div key={item.key} className={`pb-6 ${!isLast ? 'border-b border-gray-100 dark:border-gray-800/50' : ''}`}>\r\n <div className=\"mb-3\">\r\n <div className=\"text-sm font-semibold text-gray-900 dark:text-white mb-2\">{item.label}</div>\r\n <div className=\"flex items-center gap-2 text-xs text-gray-500 dark:text-gray-400\">\r\n <span className=\"font-mono\">{scaleData.size}</span>\r\n <span className=\"text-gray-300 dark:text-gray-600\">•</span>\r\n <span className=\"font-mono\">Line height: {scaleData.lineHeight}</span>\r\n </div>\r\n </div>\r\n <p \r\n className={`${item.color} break-words ${item.uppercase ? 'uppercase tracking-wider font-medium' : ''}`}\r\n style={{ \r\n fontSize: responsiveSize, \r\n lineHeight: scaleData.lineHeight\r\n }}\r\n >\r\n {item.text}\r\n </p>\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </section>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Trash2, Plus, Minus, ArrowRight, Tag } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass, getColorShade, getColorValue } from '../utils/styleUtils';\r\n\r\ninterface ShoppingCartProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nconst INITIAL_ITEMS = [\r\n { id: 1, name: 'Minimalist Chair', price: 180, quantity: 1, image: 'https://images.unsplash.com/photo-1592078615290-033ee584e267?auto=format&fit=crop&q=80&w=200' },\r\n { id: 2, name: 'Ceramic Vase', price: 45, quantity: 2, image: 'https://images.unsplash.com/photo-1581783342308-f792caec1d9c?auto=format&fit=crop&q=80&w=200' },\r\n];\r\n\r\nexport const ShoppingCart: React.FC<ShoppingCartProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [items, setItems] = useState(INITIAL_ITEMS);\r\n const [couponCode, setCouponCode] = useState('');\r\n\r\n const updateQuantity = (id: number, delta: number) => {\r\n setItems(items.map(item => {\r\n if (item.id === id) {\r\n const newQty = Math.max(1, item.quantity + delta);\r\n return { ...item, quantity: newQty };\r\n }\r\n return item;\r\n }));\r\n };\r\n\r\n const removeItem = (id: number) => {\r\n setItems(items.filter(item => item.id !== id));\r\n };\r\n\r\n const subtotal = items.reduce((sum, item) => sum + (item.price * item.quantity), 0);\r\n const shipping = 20;\r\n const total = subtotal + shipping;\r\n\r\n const formatPrice = (price: number) => {\r\n return price.toFixed(2);\r\n };\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n return (\r\n <div \r\n style={appliedStyles} \r\n className=\"w-full h-full min-h-[400px] flex flex-col lg:flex-row gap-4 sm:gap-6 lg:gap-8 p-3 sm:p-4 lg:p-0 overflow-hidden\"\r\n >\r\n {/* Cart Items */}\r\n <div className={`\r\n flex-1 min-h-0 flex flex-col overflow-hidden\r\n ${isMUI ? 'bg-white dark:bg-gray-800 shadow-md rounded-lg p-4 sm:p-6' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-md rounded-2xl p-4 sm:p-6 border border-gray-200/50 dark:border-gray-700/50' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-900 border border-gray-200 dark:border-gray-800 p-4 sm:p-6 ${getRadiusClass(globalConfig)}` : ''}\r\n `}>\r\n <h2 className=\"text-lg sm:text-xl font-bold text-gray-900 dark:text-white mb-4 sm:mb-6 flex-shrink-0\">Shopping Cart ({items.length})</h2>\r\n \r\n <div className=\"flex-1 min-h-0 overflow-y-auto space-y-4 sm:space-y-6\">\r\n {items.length === 0 ? (\r\n <div className=\"text-center py-12 text-gray-500 dark:text-gray-400\">Your cart is empty.</div>\r\n ) : items.map((item) => (\r\n <div key={item.id} className=\"flex gap-3 sm:gap-4 items-start pb-4 sm:pb-6 border-b border-gray-100 dark:border-gray-800 last:border-0 last:pb-0\">\r\n <img \r\n src={item.image} \r\n alt={item.name} \r\n className={`w-16 h-16 sm:w-20 sm:h-20 object-cover flex-shrink-0 ${isApple || isCustom ? 'rounded-lg' : 'rounded-sm'}`}\r\n onError={(e) => {\r\n const target = e.target as HTMLImageElement;\r\n target.src = 'data:image/svg+xml,%3Csvg xmlns=\"http://www.w3.org/2000/svg\" width=\"200\" height=\"200\"%3E%3Crect width=\"200\" height=\"200\" fill=\"%23e5e7eb\"/%3E%3Ctext x=\"50%25\" y=\"50%25\" dominant-baseline=\"middle\" text-anchor=\"middle\" fill=\"%239ca3af\" font-family=\"sans-serif\" font-size=\"14\"%3EImage%3C/text%3E%3C/svg%3E';\r\n }}\r\n />\r\n \r\n <div className=\"flex-1 min-w-0 flex flex-col gap-2 sm:gap-3\">\r\n <div className=\"flex justify-between items-start gap-2\">\r\n <h3 className=\"font-medium text-gray-900 dark:text-white text-xs sm:text-sm lg:text-base truncate flex-1\">{item.name}</h3>\r\n <button \r\n onClick={() => removeItem(item.id)} \r\n className=\"transition-colors p-1 flex-shrink-0 hover:opacity-70\"\r\n style={{ color: getColorValue(globalConfig, 'tertiary', 500) }}\r\n onMouseEnter={(e) => e.currentTarget.style.color = getColorValue(globalConfig, 'tertiary', 600)}\r\n onMouseLeave={(e) => e.currentTarget.style.color = getColorValue(globalConfig, 'tertiary', 500)}\r\n aria-label={`Remove ${item.name} from cart`}\r\n >\r\n <Trash2 size={14} className=\"sm:w-4 sm:h-4\" />\r\n </button>\r\n </div>\r\n <p className=\"text-xs sm:text-sm text-gray-500 dark:text-gray-400\">${formatPrice(item.price)}</p>\r\n \r\n <div className=\"flex items-center gap-2 sm:gap-4 justify-between flex-wrap\">\r\n <div className={`\r\n flex items-center border rounded-md overflow-hidden\r\n ${isMUI ? 'border-gray-300 dark:border-gray-600' : ''}\r\n ${isApple ? 'bg-gray-100 dark:bg-gray-800 border-transparent' : ''}\r\n ${isCustom ? `border-gray-200 dark:border-gray-700` : ''}\r\n `}>\r\n <button \r\n onClick={() => updateQuantity(item.id, -1)} \r\n className=\"p-1 sm:p-1.5 px-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors text-gray-600 dark:text-gray-400 flex-shrink-0\"\r\n aria-label=\"Decrease quantity\"\r\n >\r\n <Minus size={12} className=\"sm:w-3.5 sm:h-3.5\"/>\r\n </button>\r\n <span className=\"px-2 sm:px-3 text-xs sm:text-sm font-medium min-w-[28px] sm:min-w-[32px] text-center text-gray-900 dark:text-white\">{item.quantity}</span>\r\n <button \r\n onClick={() => updateQuantity(item.id, 1)} \r\n className=\"p-1 sm:p-1.5 px-2 hover:bg-gray-100 dark:hover:bg-gray-700 transition-colors text-gray-600 dark:text-gray-400 flex-shrink-0\"\r\n aria-label=\"Increase quantity\"\r\n >\r\n <Plus size={12} className=\"sm:w-3.5 sm:h-3.5\"/>\r\n </button>\r\n </div>\r\n <div className=\"text-xs sm:text-sm font-bold text-gray-900 dark:text-white whitespace-nowrap\">${formatPrice(item.price * item.quantity)}</div>\r\n </div>\r\n </div>\r\n </div>\r\n ))}\r\n </div>\r\n </div>\r\n\r\n {/* Order Summary */}\r\n <div className={`\r\n w-full lg:w-80 flex-shrink-0\r\n ${isMUI ? 'bg-white dark:bg-gray-800 rounded-lg p-4 sm:p-6 border border-gray-200 dark:border-gray-700 shadow-md' : ''}\r\n ${isApple ? 'bg-white/80 dark:bg-gray-900/80 backdrop-blur-md rounded-2xl p-4 sm:p-6 border border-gray-200/50 dark:border-gray-700/50 shadow-xl' : ''}\r\n ${isCustom ? `bg-white dark:bg-gray-950 border border-gray-200 dark:border-gray-800 p-4 sm:p-6 ${getRadiusClass(globalConfig)} shadow-sm` : ''}\r\n `}>\r\n <h3 className=\"text-lg sm:text-xl font-bold text-gray-900 dark:text-white mb-4 sm:mb-6\">Order Summary</h3>\r\n \r\n <div className=\"space-y-2 sm:space-y-3 mb-4 sm:mb-6\">\r\n <div className=\"flex justify-between text-xs sm:text-sm text-gray-600 dark:text-gray-400\">\r\n <span>Subtotal</span>\r\n <span className=\"font-medium text-gray-900 dark:text-white\">${formatPrice(subtotal)}</span>\r\n </div>\r\n <div className=\"flex justify-between text-xs sm:text-sm text-gray-600 dark:text-gray-400\">\r\n <span>Shipping</span>\r\n <span className=\"font-medium text-gray-900 dark:text-white\">${formatPrice(shipping)}</span>\r\n </div>\r\n <div className=\"pt-2 sm:pt-3 border-t border-gray-200 dark:border-gray-700 flex justify-between items-center\">\r\n <span className=\"text-base sm:text-lg font-bold text-gray-900 dark:text-white\">Total</span>\r\n <span className=\"text-base sm:text-lg font-bold text-gray-900 dark:text-white\">${formatPrice(total)}</span>\r\n </div>\r\n </div>\r\n\r\n <div className=\"space-y-3 sm:space-y-4\">\r\n <div className=\"relative\">\r\n <input \r\n type=\"text\" \r\n placeholder=\"Coupon Code\" \r\n value={couponCode}\r\n onChange={(e) => setCouponCode(e.target.value)}\r\n className={`\r\n w-full pl-8 sm:pl-9 pr-3 sm:pr-4 py-2 sm:py-2.5 text-xs sm:text-sm bg-gray-50 dark:bg-gray-900 border rounded-lg focus:ring-2 focus:outline-none transition-all\r\n ${isMUI ? 'border-gray-300 dark:border-gray-600 focus:border-blue-500 focus:ring-blue-500/20' : ''}\r\n ${isApple ? 'border-gray-200 dark:border-gray-700 focus:border-gray-900 dark:focus:border-white focus:ring-gray-900/20 dark:focus:ring-white/20' : ''}\r\n ${isCustom ? `border-gray-200 dark:border-gray-700 ${getColorShade(globalConfig, 'border', 500)} focus:${getColorShade(globalConfig, 'border', 500)} focus:ring-${getColorShade(globalConfig, 'border', 500).replace('border-', '')}/20` : ''}\r\n `} \r\n />\r\n <Tag size={14} className=\"absolute left-2.5 sm:left-3 top-1/2 -translate-y-1/2 text-gray-400 dark:text-gray-500 sm:w-4 sm:h-4\" />\r\n </div>\r\n\r\n <button \r\n className={`\r\n w-full py-2.5 sm:py-3.5 px-3 sm:px-4 flex items-center justify-center gap-2 text-white font-medium transition-all rounded-lg text-xs sm:text-sm\r\n ${isMUI ? `${getColorShade(globalConfig, 'bg', 600)} ${getColorShade(globalConfig, 'bg', 700).replace('bg-', 'hover:bg-')} shadow-md hover:shadow-lg uppercase tracking-wide` : ''}\r\n ${isApple ? 'bg-black dark:bg-white dark:text-black hover:opacity-90 rounded-xl sm:text-base font-semibold' : ''}\r\n ${isCustom ? `${getColorClass(globalConfig, 'bg')} ${getRadiusClass(globalConfig)} hover:opacity-90 shadow-md hover:shadow-lg` : ''}\r\n `}\r\n aria-label=\"Proceed to checkout\"\r\n >\r\n Checkout <ArrowRight size={14} className=\"sm:w-4 sm:h-4\" />\r\n </button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { Delete, ArrowUp, Globe, Smile } from 'lucide-react';\r\nimport { getAppliedStyles, getColorClass, getRadiusClass } from '../utils/styleUtils';\r\n\r\ninterface VirtualKeyboardProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n viewportWidth?: number;\r\n}\r\n\r\ntype KeyboardType = 'letters' | 'numbers' | 'emoji';\r\ntype KeyboardStyle = 'ios' | 'android' | 'mac' | 'windows' | 'mobile' | 'web' | 'tv';\r\ntype Language = 'english' | 'urdu' | 'arabic';\r\n\r\nexport const VirtualKeyboard: React.FC<VirtualKeyboardProps> = ({ designSystem, componentProps, globalConfig, granularStyles, viewportWidth }) => {\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n const [keyboardType, setKeyboardType] = useState<KeyboardType>('letters');\r\n const [language, setLanguage] = useState<Language>('english');\r\n const [isShift, setIsShift] = useState(false);\r\n\r\n // Auto-detect platform based on viewport width (mapped from top viewport selector)\r\n const getAutoDetectedStyle = (): KeyboardStyle => {\r\n if (!viewportWidth) {\r\n // Default based on design system\r\n if (designSystem === 'Apple') return 'mac';\r\n return 'web';\r\n }\r\n \r\n // TV (3XL - 1920px+)\r\n if (viewportWidth >= 1920) return 'tv';\r\n \r\n // Desktop platforms (XL, 2XL - 1280px+)\r\n if (viewportWidth >= 1280) {\r\n if (designSystem === 'Apple') return 'mac';\r\n if (designSystem === 'MUI') return 'windows';\r\n return 'web';\r\n }\r\n \r\n // Tablet (MD, LG - 768px to 1279px)\r\n if (viewportWidth >= 768) {\r\n return 'web';\r\n }\r\n \r\n // Mobile (XS, SM - <768px)\r\n if (viewportWidth < 768) {\r\n // Use design system to determine mobile style\r\n if (designSystem === 'Apple') return 'ios';\r\n return 'android';\r\n }\r\n \r\n return 'web';\r\n };\r\n\r\n const keyboardStyle = getAutoDetectedStyle();\r\n\r\n // Keyboard layouts\r\n const englishKeys = [\r\n ['q','w','e','r','t','y','u','i','o','p'],\r\n ['a','s','d','f','g','h','j','k','l'],\r\n ['shift','z','x','c','v','b','n','m','backspace'],\r\n ];\r\n\r\n const urduKeys = [\r\n ['ق','و','ع','ر','ت','ے','ٹ','پ','ا','ل'],\r\n ['ذ','د','ڈ','گ','ھ','ج','ح','ک','خ'],\r\n ['shift','ط','ظ','ز','ر','ب','ن','م','backspace'],\r\n ];\r\n\r\n const arabicKeys = [\r\n ['ض','ص','ث','ق','ف','غ','ع','ه','خ','ح'],\r\n ['ش','س','ي','ب','ل','ا','ت','ن','م'],\r\n ['shift','ك','ط','ئ','ء','ؤ','ر','لا','backspace'],\r\n ];\r\n\r\n const numericKeys = [\r\n ['1','2','3'],\r\n ['4','5','6'],\r\n ['7','8','9'],\r\n ['#+=' ,'0','backspace'],\r\n ];\r\n\r\n const emojiKeys = [\r\n ['😀','😃','😄','😁','😆','😅','😂','🤣','😊','😇'],\r\n ['🙂','🙃','😉','😌','😍','🥰','😘','😗','😙','😚'],\r\n ['😋','😛','😝','😜','🤪','🤨','🧐','🤓','😎','🤩'],\r\n ['🥳','😏','😒','😞','😔','😟','😕','🙁','☹️','😣'],\r\n ];\r\n\r\n const getCurrentKeys = () => {\r\n if (keyboardType === 'numbers') return numericKeys;\r\n if (keyboardType === 'emoji') return emojiKeys;\r\n \r\n switch (language) {\r\n case 'urdu': return urduKeys;\r\n case 'arabic': return arabicKeys;\r\n default: return englishKeys;\r\n }\r\n };\r\n\r\n const keys = getCurrentKeys();\r\n\r\n const isMUI = designSystem === 'MUI';\r\n const isApple = designSystem === 'Apple';\r\n const isCustom = designSystem === 'Custom';\r\n\r\n // Platform-specific styling\r\n const getKeyStyle = (key: string) => {\r\n const styles: Record<KeyboardStyle, { base: string; special: string; action: string }> = {\r\n ios: {\r\n base: 'bg-white dark:bg-gray-700 shadow-sm',\r\n special: 'bg-gray-300 dark:bg-gray-600',\r\n action: 'bg-blue-500 dark:bg-blue-600 text-white'\r\n },\r\n android: {\r\n base: 'bg-gray-100 dark:bg-gray-700 shadow-md',\r\n special: 'bg-gray-200 dark:bg-gray-600',\r\n action: 'bg-blue-600 dark:bg-blue-700 text-white'\r\n },\r\n mac: {\r\n base: 'bg-white dark:bg-gray-800 shadow-lg border border-gray-200 dark:border-gray-700',\r\n special: 'bg-gray-200 dark:bg-gray-700',\r\n action: 'bg-blue-600 dark:bg-blue-700 text-white'\r\n },\r\n windows: {\r\n base: 'bg-white dark:bg-gray-800 shadow-md border border-gray-300 dark:border-gray-600',\r\n special: 'bg-gray-200 dark:bg-gray-700',\r\n action: 'bg-blue-600 dark:bg-blue-700 text-white'\r\n },\r\n mobile: {\r\n base: keyboardStyle === 'ios' ? 'bg-white dark:bg-gray-700 shadow-sm' : 'bg-gray-100 dark:bg-gray-700 shadow-md',\r\n special: keyboardStyle === 'ios' ? 'bg-gray-300 dark:bg-gray-600' : 'bg-gray-200 dark:bg-gray-600',\r\n action: 'bg-blue-500 dark:bg-blue-600 text-white'\r\n },\r\n web: {\r\n base: 'bg-white dark:bg-gray-800 shadow-lg border border-gray-200 dark:border-gray-700',\r\n special: 'bg-gray-200 dark:bg-gray-700',\r\n action: 'bg-blue-600 dark:bg-blue-700 text-white'\r\n },\r\n tv: {\r\n base: 'bg-gray-800 dark:bg-gray-900 shadow-xl border-2 border-gray-600 dark:border-gray-700 text-white',\r\n special: 'bg-gray-700 dark:bg-gray-800 text-white',\r\n action: 'bg-blue-600 dark:bg-blue-700 text-white'\r\n }\r\n };\r\n\r\n const style = styles[keyboardStyle];\r\n \r\n if (['shift', 'backspace', '123', '#+='].includes(key)) return style.special;\r\n if (key === 'return' || key === 'Go') return style.action;\r\n if (key === 'space') return style.base;\r\n return style.base;\r\n };\r\n\r\n const getContainerStyle = () => {\r\n const styles: Record<KeyboardStyle, string> = {\r\n ios: 'bg-gray-200 dark:bg-gray-800',\r\n android: 'bg-gray-100 dark:bg-gray-900',\r\n mac: 'bg-gray-50 dark:bg-gray-900 border border-gray-200 dark:border-gray-800',\r\n windows: 'bg-gray-100 dark:bg-gray-900 border border-gray-300 dark:border-gray-700',\r\n mobile: keyboardStyle === 'ios' ? 'bg-gray-200 dark:bg-gray-800' : 'bg-gray-100 dark:bg-gray-900',\r\n web: 'bg-gray-50 dark:bg-gray-900 border border-gray-200 dark:border-gray-800',\r\n tv: 'bg-gray-900 dark:bg-black border-2 border-gray-700 dark:border-gray-800'\r\n };\r\n return styles[keyboardStyle];\r\n };\r\n\r\n const getKeySize = () => {\r\n if (keyboardStyle === 'tv') return { height: 'h-16', text: 'text-xl', gap: 'gap-3', padding: 'p-4', maxWidth: 'max-w-4xl' };\r\n if (keyboardStyle === 'web' || keyboardStyle === 'mac' || keyboardStyle === 'windows') {\r\n return { height: 'h-12', text: 'text-base', gap: 'gap-2', padding: 'p-4', maxWidth: 'max-w-5xl' };\r\n }\r\n return { height: 'h-11', text: 'text-lg', gap: 'gap-1.5', padding: 'p-3', maxWidth: 'max-w-lg' };\r\n };\r\n\r\n const keySize = getKeySize();\r\n const borderRadius = keyboardStyle === 'ios' || keyboardStyle === 'mac' ? 'rounded-lg' : keyboardStyle === 'tv' ? 'rounded-xl' : 'rounded-md';\r\n\r\n const handleKeyPress = (key: string) => {\r\n if (key === 'shift') {\r\n setIsShift(!isShift);\r\n } else if (key === '123') {\r\n setKeyboardType('numbers');\r\n } else if (key === '#+=') {\r\n setKeyboardType('letters');\r\n } else if (key === 'emoji') {\r\n setKeyboardType('emoji');\r\n }\r\n };\r\n\r\n const renderKey = (key: string, index: number) => {\r\n // Wider keys for desktop platforms (mac, windows, web)\r\n const isDesktop = keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web';\r\n const baseWidth = keyboardStyle === 'tv' ? 'w-14' : isDesktop ? 'w-11' : 'w-9';\r\n let width = baseWidth;\r\n let content: any = key;\r\n const iconSize = keyboardStyle === 'tv' ? 20 : isDesktop ? 18 : 16;\r\n \r\n if (key === 'shift') { \r\n width = keyboardStyle === 'tv' ? 'w-16' : isDesktop ? 'w-16' : 'w-12'; \r\n content = <ArrowUp size={iconSize} className={isShift ? 'text-blue-500' : ''}/>; \r\n }\r\n if (key === 'backspace') { \r\n width = keyboardStyle === 'tv' ? 'w-16' : isDesktop ? 'w-16' : 'w-12'; \r\n content = <Delete size={iconSize}/>; \r\n }\r\n if (key === 'space') { \r\n width = isDesktop ? 'flex-1 max-w-md' : 'flex-1 max-w-xs'; \r\n content = ''; \r\n }\r\n if (key === 'return' || key === 'Go') { \r\n width = keyboardStyle === 'tv' ? 'w-24' : isDesktop ? 'w-24' : 'w-20'; \r\n content = 'Go'; \r\n }\r\n if (key === '123') { \r\n width = keyboardStyle === 'tv' ? 'w-16' : isDesktop ? 'w-16' : 'w-12'; \r\n }\r\n if (key === '#+=') {\r\n width = keyboardStyle === 'tv' ? 'w-20' : isDesktop ? 'w-20' : 'w-16';\r\n }\r\n if (keyboardType === 'emoji') {\r\n width = keyboardStyle === 'tv' ? 'w-14' : isDesktop ? 'w-11' : 'w-9';\r\n }\r\n\r\n const bg = getKeyStyle(key);\r\n const fontWeight = keyboardStyle === 'ios' || keyboardStyle === 'mac' ? 'font-normal' : 'font-medium';\r\n\r\n // TV keyboard needs white text for visibility\r\n const textColor = keyboardStyle === 'tv' ? 'text-white' : 'text-gray-900 dark:text-white';\r\n\r\n return (\r\n <button \r\n key={`${key}-${index}`}\r\n onClick={() => handleKeyPress(key)}\r\n className={`\r\n ${keySize.height} ${borderRadius} flex items-center justify-center ${keySize.text} ${fontWeight}\r\n active:scale-95 transition-transform ${width} ${bg}\r\n ${isCustom ? getRadiusClass(globalConfig) : ''}\r\n ${textColor}\r\n `}\r\n >\r\n {content}\r\n </button>\r\n );\r\n };\r\n\r\n return (\r\n <div style={appliedStyles} className={`w-full ${keySize.maxWidth} ${getContainerStyle()} ${keySize.padding} rounded-xl pb-6`}>\r\n {/* Language Switcher */}\r\n <div className={`flex items-center justify-center mb-3 px-1 ${keyboardStyle === 'tv' ? 'mb-4' : ''}`}>\r\n <div className=\"flex items-center gap-1.5 flex-wrap\">\r\n <button\r\n onClick={() => setLanguage('english')}\r\n className={`px-3 py-1.5 ${keyboardStyle === 'tv' ? 'text-sm' : 'text-xs'} rounded-md transition-all flex items-center gap-1.5 font-medium ${\r\n language === 'english' \r\n ? 'bg-blue-500 text-white shadow-sm' \r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'\r\n }`}\r\n >\r\n <Globe size={12} />\r\n EN\r\n </button>\r\n <button\r\n onClick={() => setLanguage('urdu')}\r\n className={`px-3 py-1.5 ${keyboardStyle === 'tv' ? 'text-sm' : 'text-xs'} rounded-md transition-all flex items-center gap-1.5 font-medium ${\r\n language === 'urdu' \r\n ? 'bg-blue-500 text-white shadow-sm' \r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'\r\n }`}\r\n >\r\n <Globe size={12} />\r\n اردو\r\n </button>\r\n <button\r\n onClick={() => setLanguage('arabic')}\r\n className={`px-3 py-1.5 ${keyboardStyle === 'tv' ? 'text-sm' : 'text-xs'} rounded-md transition-all flex items-center gap-1.5 font-medium ${\r\n language === 'arabic' \r\n ? 'bg-blue-500 text-white shadow-sm' \r\n : 'bg-gray-200 dark:bg-gray-700 text-gray-700 dark:text-gray-300 hover:bg-gray-300 dark:hover:bg-gray-600'\r\n }`}\r\n >\r\n <Globe size={12} />\r\n عربي\r\n </button>\r\n </div>\r\n </div>\r\n\r\n {/* Keyboard */}\r\n <div className={`flex flex-col ${keySize.gap} w-full`}>\r\n {keys.map((row, rI) => (\r\n <div key={rI} className={`flex justify-center ${keySize.gap}`}>\r\n {row.map((key, kI) => renderKey(key, kI))}\r\n </div>\r\n ))}\r\n \r\n {/* Bottom Row */}\r\n <div className={`flex justify-center ${keySize.gap} mt-1`}>\r\n {keyboardType === 'numbers' ? (\r\n <>\r\n <button\r\n onClick={() => setKeyboardType('emoji')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-16' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-16' : 'w-12'} ${borderRadius} ${getKeyStyle('emoji')} flex items-center justify-center transition-all hover:scale-105`}\r\n title=\"Emoji Keyboard\"\r\n >\r\n <Smile size={keyboardStyle === 'tv' ? 20 : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 18 : 16} />\r\n </button>\r\n <button\r\n onClick={() => setKeyboardType('letters')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-20' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-20' : 'w-16'} ${borderRadius} ${getKeyStyle('#+=')} flex items-center justify-center ${keySize.text}`}\r\n >\r\n ABC\r\n </button>\r\n </>\r\n ) : keyboardType === 'emoji' ? (\r\n <>\r\n <button\r\n onClick={() => setKeyboardType('numbers')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-16' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-16' : 'w-12'} ${borderRadius} ${getKeyStyle('123')} flex items-center justify-center ${keySize.text}`}\r\n >\r\n 123\r\n </button>\r\n <button\r\n onClick={() => setKeyboardType('letters')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-20' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-20' : 'w-16'} ${borderRadius} ${getKeyStyle('#+=')} flex items-center justify-center ${keySize.text}`}\r\n >\r\n ABC\r\n </button>\r\n </>\r\n ) : (\r\n <>\r\n <button\r\n onClick={() => setKeyboardType('numbers')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-16' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-16' : 'w-12'} ${borderRadius} ${getKeyStyle('123')} flex items-center justify-center ${keySize.text}`}\r\n >\r\n 123\r\n </button>\r\n <button\r\n onClick={() => setKeyboardType('emoji')}\r\n className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-16' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-16' : 'w-12'} ${borderRadius} ${getKeyStyle('emoji')} flex items-center justify-center transition-all hover:scale-105`}\r\n title=\"Emoji Keyboard\"\r\n >\r\n <Smile size={keyboardStyle === 'tv' ? 20 : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 18 : 16} />\r\n </button>\r\n </>\r\n )}\r\n <button className={`${keySize.height} ${(keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'flex-1 max-w-md' : 'flex-1 max-w-xs'} ${borderRadius} ${getKeyStyle('space')}`}></button>\r\n <button className={`${keySize.height} ${keyboardStyle === 'tv' ? 'w-24' : (keyboardStyle === 'mac' || keyboardStyle === 'windows' || keyboardStyle === 'web') ? 'w-24' : 'w-20'} ${borderRadius} ${getKeyStyle('Go')} flex items-center justify-center`}>\r\n Go\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","// Custom 90s Retro Cursor Effects\r\n// Inspired by classic video games and retro web aesthetics\r\n\r\nexport interface CursorParticle {\r\n x: number;\r\n y: number;\r\n vx: number;\r\n vy: number;\r\n life: number;\r\n maxLife: number;\r\n size: number;\r\n color: string;\r\n rotation?: number;\r\n rotationSpeed?: number;\r\n}\r\n\r\nexport class RetroCursorEffect {\r\n private canvas: HTMLCanvasElement;\r\n private ctx: CanvasRenderingContext2D;\r\n private particles: CursorParticle[] = [];\r\n private mouseX = 0;\r\n private mouseY = 0;\r\n private animationId: number | null = null;\r\n private colors: string[];\r\n private effectType: string = '';\r\n private resizeHandler: () => void;\r\n\r\n constructor(\r\n container: HTMLElement,\r\n type: string,\r\n colors: string[]\r\n ) {\r\n this.colors = colors;\r\n this.effectType = type;\r\n this.canvas = document.createElement('canvas');\r\n this.canvas.style.position = 'absolute';\r\n this.canvas.style.top = '0';\r\n this.canvas.style.left = '0';\r\n this.canvas.style.width = '100%';\r\n this.canvas.style.height = '100%';\r\n this.canvas.style.pointerEvents = 'none';\r\n this.canvas.style.zIndex = '50';\r\n container.appendChild(this.canvas);\r\n \r\n this.resizeHandler = () => {\r\n const rect = container.getBoundingClientRect();\r\n this.canvas.width = rect.width;\r\n this.canvas.height = rect.height;\r\n };\r\n \r\n this.resizeHandler();\r\n window.addEventListener('resize', this.resizeHandler);\r\n \r\n this.ctx = this.canvas.getContext('2d')!;\r\n \r\n container.addEventListener('mousemove', this.handleMouseMove);\r\n this.animate();\r\n }\r\n\r\n private handleMouseMove = (e: MouseEvent) => {\r\n const container = this.canvas.parentElement;\r\n if (!container) return;\r\n const rect = container.getBoundingClientRect();\r\n this.mouseX = e.clientX - rect.left;\r\n this.mouseY = e.clientY - rect.top;\r\n };\r\n \r\n private animate = () => {\r\n this.ctx.clearRect(0, 0, this.canvas.width, this.canvas.height);\r\n \r\n // Draw effect-specific visuals\r\n if (this.effectType === 'crosshair') {\r\n this.drawCrosshair();\r\n } else if (this.effectType === 'scanlines') {\r\n this.drawScanlines();\r\n }\r\n \r\n // Update and draw particles\r\n this.particles = this.particles.filter(p => {\r\n p.life++;\r\n p.x += p.vx;\r\n p.y += p.vy;\r\n if (p.rotation !== undefined) {\r\n p.rotation += p.rotationSpeed || 0;\r\n }\r\n \r\n const alpha = 1 - (p.life / p.maxLife);\r\n if (alpha <= 0) return false;\r\n \r\n this.ctx.save();\r\n this.ctx.globalAlpha = alpha;\r\n this.ctx.fillStyle = p.color;\r\n this.ctx.strokeStyle = p.color;\r\n this.ctx.translate(p.x, p.y);\r\n \r\n if (p.rotation !== undefined) {\r\n this.ctx.rotate(p.rotation);\r\n }\r\n \r\n // Draw different shapes based on effect type\r\n if (this.effectType === 'starfield') {\r\n // Draw star shape (cross)\r\n this.ctx.lineWidth = 1;\r\n this.ctx.beginPath();\r\n this.ctx.moveTo(0, -p.size);\r\n this.ctx.lineTo(0, p.size);\r\n this.ctx.moveTo(-p.size, 0);\r\n this.ctx.lineTo(p.size, 0);\r\n this.ctx.stroke();\r\n } else if (this.effectType === 'neon-glow') {\r\n // Draw glowing circle with gradient\r\n const gradient = this.ctx.createRadialGradient(0, 0, 0, 0, 0, p.size);\r\n gradient.addColorStop(0, p.color);\r\n gradient.addColorStop(1, 'transparent');\r\n this.ctx.fillStyle = gradient;\r\n this.ctx.beginPath();\r\n this.ctx.arc(0, 0, p.size, 0, Math.PI * 2);\r\n this.ctx.fill();\r\n } else if (this.effectType === 'matrix-rain') {\r\n // Draw vertical line for matrix effect\r\n this.ctx.lineWidth = p.size;\r\n this.ctx.beginPath();\r\n this.ctx.moveTo(0, -p.size * 2);\r\n this.ctx.lineTo(0, p.size * 2);\r\n this.ctx.stroke();\r\n } else if (this.effectType === 'explosion') {\r\n // Draw particle with glow\r\n const gradient = this.ctx.createRadialGradient(0, 0, 0, 0, 0, p.size);\r\n gradient.addColorStop(0, p.color);\r\n gradient.addColorStop(0.5, p.color + '80');\r\n gradient.addColorStop(1, 'transparent');\r\n this.ctx.fillStyle = gradient;\r\n this.ctx.beginPath();\r\n this.ctx.arc(0, 0, p.size, 0, Math.PI * 2);\r\n this.ctx.fill();\r\n } else {\r\n // Default: draw square (for pixel-trail)\r\n this.ctx.fillRect(-p.size / 2, -p.size / 2, p.size, p.size);\r\n }\r\n \r\n this.ctx.restore();\r\n \r\n return true;\r\n });\r\n \r\n this.animationId = requestAnimationFrame(this.animate);\r\n };\r\n \r\n private drawCrosshair() {\r\n if (this.mouseX === 0 && this.mouseY === 0) return;\r\n \r\n this.ctx.save();\r\n this.ctx.strokeStyle = this.colors[0];\r\n this.ctx.lineWidth = 2;\r\n this.ctx.globalAlpha = 0.8;\r\n \r\n // Horizontal line\r\n this.ctx.beginPath();\r\n this.ctx.moveTo(this.mouseX - 15, this.mouseY);\r\n this.ctx.lineTo(this.mouseX + 15, this.mouseY);\r\n this.ctx.stroke();\r\n \r\n // Vertical line\r\n this.ctx.beginPath();\r\n this.ctx.moveTo(this.mouseX, this.mouseY - 15);\r\n this.ctx.lineTo(this.mouseX, this.mouseY + 15);\r\n this.ctx.stroke();\r\n \r\n // Center circle\r\n this.ctx.beginPath();\r\n this.ctx.arc(this.mouseX, this.mouseY, 3, 0, Math.PI * 2);\r\n this.ctx.fillStyle = this.colors[0];\r\n this.ctx.fill();\r\n \r\n this.ctx.restore();\r\n }\r\n \r\n private drawScanlines() {\r\n this.ctx.save();\r\n this.ctx.strokeStyle = this.colors[0];\r\n this.ctx.lineWidth = 1;\r\n this.ctx.globalAlpha = 0.1;\r\n \r\n // Draw horizontal scanlines across the entire canvas\r\n for (let y = 0; y < this.canvas.height; y += 4) {\r\n this.ctx.beginPath();\r\n this.ctx.moveTo(0, y);\r\n this.ctx.lineTo(this.canvas.width, y);\r\n this.ctx.stroke();\r\n }\r\n \r\n this.ctx.restore();\r\n }\r\n\r\n // 90s Video Game Crosshair - draws crosshair directly, no particles needed\r\n createCrosshair() {\r\n // Crosshair is drawn in animate() method, no particles needed\r\n return () => {};\r\n }\r\n\r\n // Pixel Trail (Mario-style)\r\n createPixelTrail() {\r\n const interval = setInterval(() => {\r\n for (let i = 0; i < 3; i++) {\r\n this.particles.push({\r\n x: this.mouseX + (Math.random() - 0.5) * 10,\r\n y: this.mouseY + (Math.random() - 0.5) * 10,\r\n vx: (Math.random() - 0.5) * 2,\r\n vy: (Math.random() - 0.5) * 2,\r\n life: 0,\r\n maxLife: 20,\r\n size: 4,\r\n color: this.colors[Math.floor(Math.random() * this.colors.length)],\r\n });\r\n }\r\n }, 16);\r\n \r\n return () => clearInterval(interval);\r\n }\r\n\r\n // Neon Glow (Tron-style)\r\n createNeonGlow() {\r\n const interval = setInterval(() => {\r\n this.particles.push({\r\n x: this.mouseX,\r\n y: this.mouseY,\r\n vx: (Math.random() - 0.5) * 0.5,\r\n vy: (Math.random() - 0.5) * 0.5,\r\n life: 0,\r\n maxLife: 60,\r\n size: Math.random() * 8 + 4,\r\n color: this.colors[Math.floor(Math.random() * this.colors.length)],\r\n });\r\n }, 20);\r\n \r\n return () => clearInterval(interval);\r\n }\r\n\r\n // Starfield (Space Invaders)\r\n createStarfield() {\r\n const interval = setInterval(() => {\r\n this.particles.push({\r\n x: this.mouseX,\r\n y: this.mouseY,\r\n vx: (Math.random() - 0.5) * 3,\r\n vy: (Math.random() - 0.5) * 3,\r\n life: 0,\r\n maxLife: 40,\r\n size: 2,\r\n color: this.colors[0],\r\n rotation: 0,\r\n rotationSpeed: Math.random() * 0.2 - 0.1,\r\n });\r\n }, 30);\r\n \r\n return () => clearInterval(interval);\r\n }\r\n\r\n // Matrix Rain (90s hacker aesthetic)\r\n createMatrixRain() {\r\n const interval = setInterval(() => {\r\n this.particles.push({\r\n x: this.mouseX + (Math.random() - 0.5) * 20,\r\n y: this.mouseY,\r\n vx: 0,\r\n vy: Math.random() * 3 + 2,\r\n life: 0,\r\n maxLife: 50,\r\n size: Math.random() * 4 + 2,\r\n color: this.colors[Math.floor(Math.random() * this.colors.length)],\r\n });\r\n }, 25);\r\n \r\n return () => clearInterval(interval);\r\n }\r\n\r\n // Explosion (Doom-style)\r\n createExplosion() {\r\n const interval = setInterval(() => {\r\n for (let i = 0; i < 5; i++) {\r\n const angle = (Math.PI * 2 * i) / 5 + Math.random() * 0.5;\r\n this.particles.push({\r\n x: this.mouseX,\r\n y: this.mouseY,\r\n vx: Math.cos(angle) * (Math.random() * 2 + 1),\r\n vy: Math.sin(angle) * (Math.random() * 2 + 1),\r\n life: 0,\r\n maxLife: 30,\r\n size: Math.random() * 6 + 4,\r\n color: this.colors[Math.floor(Math.random() * this.colors.length)],\r\n });\r\n }\r\n }, 100);\r\n \r\n return () => clearInterval(interval);\r\n }\r\n\r\n // Scanlines (CRT monitor effect) - drawn directly, no particles needed\r\n createScanlines() {\r\n // Scanlines are drawn in animate() method, no particles needed\r\n return () => {};\r\n }\r\n\r\n destroy() {\r\n if (this.animationId !== null) {\r\n cancelAnimationFrame(this.animationId);\r\n }\r\n const container = this.canvas.parentElement;\r\n if (container) {\r\n container.removeEventListener('mousemove', this.handleMouseMove);\r\n }\r\n if (this.resizeHandler) {\r\n window.removeEventListener('resize', this.resizeHandler);\r\n }\r\n this.canvas.remove();\r\n }\r\n}\r\n\r\n","import React, { useState, useEffect, useRef } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles, getColorValue } from '../utils/styleUtils';\r\nimport { MousePointer2, Sparkles, Ghost, Circle, Droplet, Smile, Clock, Snowflake, Gamepad2, Zap, Target, ChevronDown } from 'lucide-react';\r\nimport { \r\n ghostCursor, \r\n rainbowCursor, \r\n emojiCursor, \r\n springyEmojiCursor,\r\n bubbleCursor,\r\n fairyDustCursor,\r\n trailingCursor,\r\n followingDotCursor,\r\n snowflakeCursor,\r\n textFlag,\r\n characterCursor,\r\n clockCursor\r\n} from 'cursor-effects';\r\nimport { RetroCursorEffect } from '../utils/cursorEffects';\r\n\r\ninterface InteractiveCursorProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\ntype CursorEffect = \r\n // Original cursor-effects library\r\n | 'ghost' \r\n | 'rainbow' \r\n | 'emoji' \r\n | 'springy-emoji' \r\n | 'bubbles' \r\n | 'fairy-dust' \r\n | 'trailing' \r\n | 'following-dot' \r\n | 'snowflake' \r\n | 'text-flag' \r\n | 'character'\r\n | 'clock'\r\n // 90s Retro Effects\r\n | 'crosshair'\r\n | 'pixel-trail'\r\n | 'neon-glow'\r\n | 'starfield'\r\n | 'matrix-rain'\r\n | 'explosion'\r\n | 'scanlines';\r\n\r\nexport const InteractiveCursor: React.FC<InteractiveCursorProps> = ({ \r\n designSystem, \r\n componentProps, \r\n globalConfig, \r\n granularStyles \r\n}) => {\r\n // Use globalConfig cursorEffect if available, otherwise default\r\n const [selectedEffect, setSelectedEffect] = useState<CursorEffect>(\r\n (globalConfig.cursorEffect as CursorEffect) || 'following-dot'\r\n );\r\n const [isDropdownOpen, setIsDropdownOpen] = useState(false);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const cursorEffectRef = useRef<{ destroy(): void } | null>(null);\r\n const retroEffectRef = useRef<RetroCursorEffect | null>(null);\r\n const cleanupRef = useRef<(() => void) | null>(null);\r\n\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n \r\n // Use cursor colors from globalConfig if available, otherwise fall back to theme colors\r\n const cursorColor = globalConfig.cursorColor || getColorValue(globalConfig, 'primary', 500);\r\n const cursorSecondaryColor = globalConfig.cursorSecondaryColor || getColorValue(globalConfig, 'secondary', 500);\r\n const cursorTertiaryColor = globalConfig.cursorTertiaryColor || getColorValue(globalConfig, 'tertiary', 500);\r\n \r\n const primaryColor = getColorValue(globalConfig, 'primary', 500);\r\n const secondaryColor = getColorValue(globalConfig, 'secondary', 500);\r\n const tertiaryColor = getColorValue(globalConfig, 'tertiary', 500);\r\n\r\n // Create and destroy cursor effects\r\n useEffect(() => {\r\n // Destroy previous effects\r\n if (cursorEffectRef.current) {\r\n cursorEffectRef.current.destroy();\r\n cursorEffectRef.current = null;\r\n }\r\n if (retroEffectRef.current) {\r\n retroEffectRef.current.destroy();\r\n retroEffectRef.current = null;\r\n }\r\n if (cleanupRef.current) {\r\n cleanupRef.current();\r\n cleanupRef.current = null;\r\n }\r\n\r\n if (!containerRef.current) return;\r\n\r\n const element = containerRef.current;\r\n const colors = [cursorColor, cursorSecondaryColor, cursorTertiaryColor];\r\n\r\n // Create new effect based on selection\r\n try {\r\n // 90s Retro Effects\r\n if (['crosshair', 'pixel-trail', 'neon-glow', 'starfield', 'matrix-rain', 'explosion', 'scanlines'].includes(selectedEffect)) {\r\n retroEffectRef.current = new RetroCursorEffect(element, selectedEffect, colors);\r\n \r\n switch (selectedEffect) {\r\n case 'crosshair':\r\n cleanupRef.current = retroEffectRef.current.createCrosshair();\r\n break;\r\n case 'pixel-trail':\r\n cleanupRef.current = retroEffectRef.current.createPixelTrail();\r\n break;\r\n case 'neon-glow':\r\n cleanupRef.current = retroEffectRef.current.createNeonGlow();\r\n break;\r\n case 'starfield':\r\n cleanupRef.current = retroEffectRef.current.createStarfield();\r\n break;\r\n case 'matrix-rain':\r\n cleanupRef.current = retroEffectRef.current.createMatrixRain();\r\n break;\r\n case 'explosion':\r\n cleanupRef.current = retroEffectRef.current.createExplosion();\r\n break;\r\n case 'scanlines':\r\n cleanupRef.current = retroEffectRef.current.createScanlines();\r\n break;\r\n }\r\n } else {\r\n // Original cursor-effects library\r\n switch (selectedEffect) {\r\n case 'ghost':\r\n cursorEffectRef.current = ghostCursor({\r\n element: element,\r\n image: `data:image/svg+xml,${encodeURIComponent(`<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"${cursorColor}\"><path d=\"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8z\"/></svg>`)}`\r\n });\r\n break;\r\n\r\n case 'rainbow':\r\n cursorEffectRef.current = rainbowCursor({\r\n length: 3,\r\n colors: colors,\r\n size: 4,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'emoji':\r\n cursorEffectRef.current = emojiCursor({\r\n emoji: [\"🔥\", \"🐬\", \"🦆\"],\r\n delay: 16,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'springy-emoji':\r\n cursorEffectRef.current = springyEmojiCursor({\r\n emoji: \"🤷‍♂️\",\r\n element: element\r\n });\r\n break;\r\n\r\n case 'bubbles':\r\n cursorEffectRef.current = bubbleCursor({\r\n element: element\r\n });\r\n break;\r\n\r\n case 'fairy-dust':\r\n cursorEffectRef.current = fairyDustCursor({\r\n colors: colors,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'trailing':\r\n cursorEffectRef.current = trailingCursor({\r\n particles: 15,\r\n rate: 0.8,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'following-dot':\r\n cursorEffectRef.current = followingDotCursor({\r\n color: cursorColor,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'snowflake':\r\n cursorEffectRef.current = snowflakeCursor({\r\n element: element\r\n });\r\n break;\r\n\r\n case 'text-flag':\r\n cursorEffectRef.current = textFlag({\r\n text: \"OpenGrid\",\r\n color: cursorColor,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'character':\r\n cursorEffectRef.current = characterCursor({\r\n characters: [\"h\", \"e\", \"l\", \"l\", \"o\"],\r\n font: \"15px serif\",\r\n colors: colors,\r\n element: element\r\n });\r\n break;\r\n\r\n case 'clock':\r\n cursorEffectRef.current = clockCursor({\r\n dateColor: cursorColor,\r\n faceColor: cursorSecondaryColor,\r\n secondsColor: cursorTertiaryColor,\r\n minutesColor: cursorColor,\r\n hoursColor: cursorSecondaryColor,\r\n element: element\r\n });\r\n break;\r\n\r\n default:\r\n cursorEffectRef.current = followingDotCursor({\r\n color: cursorColor,\r\n element: element\r\n });\r\n }\r\n }\r\n } catch (error) {\r\n console.error('Error creating cursor effect:', error);\r\n }\r\n\r\n // Cleanup on unmount or effect change\r\n return () => {\r\n if (cursorEffectRef.current) {\r\n cursorEffectRef.current.destroy();\r\n cursorEffectRef.current = null;\r\n }\r\n if (retroEffectRef.current) {\r\n retroEffectRef.current.destroy();\r\n retroEffectRef.current = null;\r\n }\r\n if (cleanupRef.current) {\r\n cleanupRef.current();\r\n cleanupRef.current = null;\r\n }\r\n };\r\n }, [selectedEffect, cursorColor, cursorSecondaryColor, cursorTertiaryColor]);\r\n\r\n // Update selectedEffect when globalConfig changes\r\n useEffect(() => {\r\n if (globalConfig.cursorEffect && globalConfig.cursorEffect !== selectedEffect) {\r\n setSelectedEffect(globalConfig.cursorEffect as CursorEffect);\r\n }\r\n }, [globalConfig.cursorEffect, selectedEffect]);\r\n\r\n const effects: Array<{ id: CursorEffect; name: string; icon: React.ReactNode; category: 'classic' | 'retro' }> = [\r\n // Classic Effects\r\n { id: 'following-dot', name: 'Following Dot', icon: <Circle size={16} />, category: 'classic' },\r\n { id: 'ghost', name: 'Ghost', icon: <Ghost size={16} />, category: 'classic' },\r\n { id: 'rainbow', name: 'Rainbow', icon: <Sparkles size={16} />, category: 'classic' },\r\n { id: 'emoji', name: 'Emoji', icon: <Smile size={16} />, category: 'classic' },\r\n { id: 'springy-emoji', name: 'Springy Emoji', icon: <Smile size={16} />, category: 'classic' },\r\n { id: 'bubbles', name: 'Bubbles', icon: <Droplet size={16} />, category: 'classic' },\r\n { id: 'fairy-dust', name: 'Fairy Dust', icon: <Sparkles size={16} />, category: 'classic' },\r\n { id: 'trailing', name: 'Trailing', icon: <MousePointer2 size={16} />, category: 'classic' },\r\n { id: 'snowflake', name: 'Snowflake', icon: <Snowflake size={16} />, category: 'classic' },\r\n { id: 'text-flag', name: 'Text Flag', icon: <MousePointer2 size={16} />, category: 'classic' },\r\n { id: 'character', name: 'Character', icon: <Circle size={16} />, category: 'classic' },\r\n { id: 'clock', name: 'Clock', icon: <Clock size={16} />, category: 'classic' },\r\n // 90s Retro Effects\r\n { id: 'crosshair', name: 'Crosshair (FPS)', icon: <Target size={16} />, category: 'retro' },\r\n { id: 'pixel-trail', name: 'Pixel Trail (Mario)', icon: <Gamepad2 size={16} />, category: 'retro' },\r\n { id: 'neon-glow', name: 'Neon Glow (Tron)', icon: <Zap size={16} />, category: 'retro' },\r\n { id: 'starfield', name: 'Starfield (Space Invaders)', icon: <Sparkles size={16} />, category: 'retro' },\r\n { id: 'matrix-rain', name: 'Matrix Rain', icon: <Zap size={16} />, category: 'retro' },\r\n { id: 'explosion', name: 'Explosion (Doom)', icon: <Zap size={16} />, category: 'retro' },\r\n { id: 'scanlines', name: 'Scanlines (CRT)', icon: <Zap size={16} />, category: 'retro' },\r\n ];\r\n\r\n const selectedEffectData = effects.find(e => e.id === selectedEffect);\r\n\r\n return (\r\n <div \r\n ref={containerRef}\r\n className=\"relative w-full h-full bg-gradient-to-br from-gray-50 to-gray-100 dark:from-gray-900 dark:to-gray-800 rounded-xl border border-gray-200 dark:border-gray-700 overflow-hidden cursor-none\"\r\n style={appliedStyles}\r\n >\r\n {/* Dropdown Selector */}\r\n <div className=\"absolute top-4 left-4 z-10\">\r\n <div className=\"relative\">\r\n <button\r\n onClick={() => setIsDropdownOpen(!isDropdownOpen)}\r\n className=\"flex items-center gap-2 px-4 py-2 bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg text-sm font-medium text-gray-700 dark:text-gray-300 hover:bg-gray-50 dark:hover:bg-gray-700 transition-colors shadow-sm min-w-[200px] justify-between\"\r\n >\r\n <div className=\"flex items-center gap-2\">\r\n {selectedEffectData?.icon}\r\n <span>{selectedEffectData?.name}</span>\r\n </div>\r\n <ChevronDown size={16} className={`transition-transform ${isDropdownOpen ? 'rotate-180' : ''}`} />\r\n </button>\r\n\r\n {isDropdownOpen && (\r\n <>\r\n <div \r\n className=\"absolute inset-0 z-40 bg-black/40 backdrop-blur-sm\" \r\n onClick={() => setIsDropdownOpen(false)}\r\n />\r\n <div className=\"absolute top-full left-0 mt-2 bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-lg shadow-lg z-50 max-h-96 overflow-y-auto min-w-[200px]\">\r\n <div className=\"p-2\">\r\n <div className=\"text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase px-2 py-1 mb-1\">Classic</div>\r\n {effects.filter(e => e.category === 'classic').map(effect => (\r\n <button\r\n key={effect.id}\r\n onClick={() => {\r\n setSelectedEffect(effect.id);\r\n setIsDropdownOpen(false);\r\n }}\r\n className={`\r\n w-full flex items-center gap-2 px-3 py-2 rounded-md text-sm transition-colors text-left\r\n ${selectedEffect === effect.id\r\n ? 'bg-blue-50 dark:bg-blue-900/20 text-blue-600 dark:text-blue-400'\r\n : 'text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700'\r\n }\r\n `}\r\n >\r\n {effect.icon}\r\n {effect.name}\r\n </button>\r\n ))}\r\n <div className=\"text-xs font-semibold text-gray-500 dark:text-gray-400 uppercase px-2 py-1 mt-3 mb-1\">90s Retro</div>\r\n {effects.filter(e => e.category === 'retro').map(effect => (\r\n <button\r\n key={effect.id}\r\n onClick={() => {\r\n setSelectedEffect(effect.id);\r\n setIsDropdownOpen(false);\r\n }}\r\n className={`\r\n w-full flex items-center gap-2 px-3 py-2 rounded-md text-sm transition-colors text-left\r\n ${selectedEffect === effect.id\r\n ? 'bg-purple-50 dark:bg-purple-900/20 text-purple-600 dark:text-purple-400'\r\n : 'text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700'\r\n }\r\n `}\r\n >\r\n {effect.icon}\r\n {effect.name}\r\n </button>\r\n ))}\r\n </div>\r\n </div>\r\n </>\r\n )}\r\n </div>\r\n </div>\r\n\r\n {/* Instructions */}\r\n <div className=\"absolute bottom-4 left-4 right-4 z-10 text-center\">\r\n <p className=\"text-sm text-gray-600 dark:text-gray-400 bg-white/80 dark:bg-gray-900/80 backdrop-blur-sm px-4 py-2 rounded-lg inline-block\">\r\n Move your mouse to see the {selectedEffect.replace('-', ' ')} effect\r\n </p>\r\n </div>\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface MagnetLinesProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const MagnetLines: React.FC<MagnetLinesProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const canvasRef = useRef<HTMLCanvasElement>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n useEffect(() => {\r\n const canvas = canvasRef.current;\r\n const container = containerRef.current;\r\n if (!canvas || !container) return;\r\n\r\n const ctx = canvas.getContext('2d');\r\n if (!ctx) return;\r\n\r\n let width = container.clientWidth;\r\n let height = container.clientHeight;\r\n \r\n // Grid settings\r\n const rows = 15;\r\n const cols = 20;\r\n const cellWidth = width / cols;\r\n const cellHeight = height / rows;\r\n const lineLength = Math.min(cellWidth, cellHeight) * 0.6;\r\n\r\n let mouseX = -1000;\r\n let mouseY = -1000;\r\n\r\n const resize = () => {\r\n width = container.clientWidth;\r\n height = container.clientHeight;\r\n canvas.width = width;\r\n canvas.height = height;\r\n };\r\n\r\n window.addEventListener('resize', resize);\r\n resize();\r\n\r\n const draw = () => {\r\n ctx.clearRect(0, 0, width, height);\r\n ctx.strokeStyle = designSystem === 'MUI' ? '#3b82f6' : '#94a3b8';\r\n ctx.lineWidth = 2;\r\n ctx.lineCap = 'round';\r\n\r\n for (let i = 0; i < rows; i++) {\r\n for (let j = 0; j < cols; j++) {\r\n const centerX = j * cellWidth + cellWidth / 2;\r\n const centerY = i * cellHeight + cellHeight / 2;\r\n\r\n const dx = mouseX - centerX;\r\n const dy = mouseY - centerY;\r\n const angle = Math.atan2(dy, dx);\r\n \r\n // Calculate distance for influence falloff\r\n const dist = Math.sqrt(dx*dx + dy*dy);\r\n const maxDist = 300;\r\n // If close, rotate towards mouse. If far, default to 0 or noise.\r\n // Smooth falloff\r\n const influence = Math.max(0, 1 - dist / maxDist);\r\n const finalAngle = angle * influence; // Simple interpolation to 0\r\n\r\n ctx.save();\r\n ctx.translate(centerX, centerY);\r\n ctx.rotate(angle); // Always point to mouse for magnet effect\r\n \r\n // Draw line\r\n ctx.beginPath();\r\n ctx.moveTo(-lineLength/2, 0);\r\n ctx.lineTo(lineLength/2, 0);\r\n ctx.stroke();\r\n \r\n ctx.restore();\r\n }\r\n }\r\n requestAnimationFrame(draw);\r\n };\r\n\r\n const animId = requestAnimationFrame(draw);\r\n\r\n const handleMouseMove = (e: MouseEvent) => {\r\n const rect = canvas.getBoundingClientRect();\r\n mouseX = e.clientX - rect.left;\r\n mouseY = e.clientY - rect.top;\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n mouseX = -1000;\r\n mouseY = -1000;\r\n };\r\n\r\n canvas.addEventListener('mousemove', handleMouseMove);\r\n canvas.addEventListener('mouseleave', handleMouseLeave);\r\n\r\n return () => {\r\n window.removeEventListener('resize', resize);\r\n cancelAnimationFrame(animId);\r\n canvas.removeEventListener('mousemove', handleMouseMove);\r\n canvas.removeEventListener('mouseleave', handleMouseLeave);\r\n };\r\n }, [designSystem, globalConfig]);\r\n\r\n return (\r\n <div ref={containerRef} style={appliedStyles} className=\"w-full h-[400px] bg-gray-50 dark:bg-gray-900 rounded-xl overflow-hidden border border-gray-200 dark:border-gray-800\">\r\n <canvas ref={canvasRef} className=\"w-full h-full\" />\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useRef, useEffect } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface PixelTrailProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const PixelTrail: React.FC<PixelTrailProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const canvasRef = useRef<HTMLCanvasElement>(null);\r\n const containerRef = useRef<HTMLDivElement>(null);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n useEffect(() => {\r\n const canvas = canvasRef.current;\r\n const container = containerRef.current;\r\n if (!canvas || !container) return;\r\n\r\n const ctx = canvas.getContext('2d');\r\n if (!ctx) return;\r\n\r\n let width = container.clientWidth;\r\n let height = container.clientHeight;\r\n \r\n // Pixel Grid\r\n const pixelSize = 20; // Size of \"pixels\"\r\n const cols = Math.ceil(width / pixelSize);\r\n const rows = Math.ceil(height / pixelSize);\r\n \r\n // State of pixels (opacity)\r\n const grid = new Float32Array(cols * rows).fill(0);\r\n\r\n const resize = () => {\r\n width = container.clientWidth;\r\n height = container.clientHeight;\r\n canvas.width = width;\r\n canvas.height = height;\r\n };\r\n \r\n window.addEventListener('resize', resize);\r\n resize();\r\n\r\n let mouseX = -100;\r\n let mouseY = -100;\r\n\r\n const handleMouseMove = (e: MouseEvent) => {\r\n const rect = canvas.getBoundingClientRect();\r\n mouseX = e.clientX - rect.left;\r\n mouseY = e.clientY - rect.top;\r\n };\r\n\r\n canvas.addEventListener('mousemove', handleMouseMove);\r\n\r\n const draw = () => {\r\n ctx.clearRect(0, 0, width, height);\r\n \r\n const decay = 0.05;\r\n\r\n // Update Grid\r\n for (let i = 0; i < cols; i++) {\r\n for (let j = 0; j < rows; j++) {\r\n const idx = j * cols + i;\r\n const px = i * pixelSize;\r\n const py = j * pixelSize;\r\n\r\n // Check distance to mouse\r\n const cx = px + pixelSize/2;\r\n const cy = py + pixelSize/2;\r\n const dist = Math.sqrt((mouseX - cx)**2 + (mouseY - cy)**2);\r\n\r\n if (dist < 40) {\r\n grid[idx] = 1; // Activate\r\n } else {\r\n grid[idx] = Math.max(0, grid[idx] - decay);\r\n }\r\n\r\n if (grid[idx] > 0.01) {\r\n ctx.fillStyle = `rgba(59, 130, 246, ${grid[idx]})`; // Blue default\r\n if (designSystem === 'MUI') ctx.fillStyle = `rgba(25, 118, 210, ${grid[idx]})`; // MUI Blue\r\n \r\n ctx.fillRect(px, py, pixelSize, pixelSize);\r\n }\r\n }\r\n }\r\n\r\n requestAnimationFrame(draw);\r\n };\r\n\r\n const animId = requestAnimationFrame(draw);\r\n\r\n return () => {\r\n window.removeEventListener('resize', resize);\r\n canvas.removeEventListener('mousemove', handleMouseMove);\r\n cancelAnimationFrame(animId);\r\n };\r\n }, [globalConfig, designSystem]);\r\n\r\n return (\r\n <div ref={containerRef} style={appliedStyles} className=\"w-full h-[400px] bg-black rounded-xl overflow-hidden border border-gray-800 relative cursor-none\">\r\n <div className=\"absolute inset-0 flex items-center justify-center pointer-events-none z-10\">\r\n <h3 className=\"text-2xl font-bold text-white mix-blend-difference\">Move Cursor</h3>\r\n </div>\r\n <canvas ref={canvasRef} className=\"w-full h-full block\" />\r\n </div>\r\n );\r\n};\r\n","\r\nimport React, { useRef, useState } from 'react';\r\nimport { ComponentProps, DesignSystem, GlobalConfig, GranularStyles } from '../types';\r\nimport { getAppliedStyles } from '../utils/styleUtils';\r\n\r\ninterface DecayCardProps {\r\n designSystem: DesignSystem;\r\n componentProps: ComponentProps;\r\n globalConfig: GlobalConfig;\r\n granularStyles: GranularStyles;\r\n}\r\n\r\nexport const DecayCard: React.FC<DecayCardProps> = ({ designSystem, componentProps, globalConfig, granularStyles }) => {\r\n const cardRef = useRef<HTMLDivElement>(null);\r\n const [rotation, setRotation] = useState({ x: 0, y: 0 });\r\n const [scale, setScale] = useState(1);\r\n const appliedStyles = getAppliedStyles(granularStyles, globalConfig);\r\n\r\n const handleMouseMove = (e: React.MouseEvent<HTMLDivElement>) => {\r\n if (!cardRef.current) return;\r\n const rect = cardRef.current.getBoundingClientRect();\r\n const x = e.clientX - rect.left;\r\n const y = e.clientY - rect.top;\r\n \r\n // Calculate rotation based on cursor position relative to center\r\n const centerX = rect.width / 2;\r\n const centerY = rect.height / 2;\r\n \r\n const rotateX = ((y - centerY) / centerY) * -15; // Max 15deg tilt\r\n const rotateY = ((x - centerX) / centerX) * 15;\r\n \r\n setRotation({ x: rotateX, y: rotateY });\r\n };\r\n\r\n const handleMouseEnter = () => {\r\n setScale(1.05);\r\n };\r\n\r\n const handleMouseLeave = () => {\r\n setRotation({ x: 0, y: 0 });\r\n setScale(1);\r\n };\r\n\r\n return (\r\n <div className=\"[perspective:1000px] w-full h-[400px] flex items-center justify-center bg-gray-900 rounded-xl overflow-hidden relative\">\r\n <div className=\"absolute inset-0 opacity-20 pointer-events-none\" \r\n style={{ backgroundImage: 'radial-gradient(circle at 50% 50%, #444 1px, transparent 1px)', backgroundSize: '20px 20px' }}></div>\r\n \r\n <div \r\n ref={cardRef}\r\n onMouseMove={handleMouseMove}\r\n onMouseEnter={handleMouseEnter}\r\n onMouseLeave={handleMouseLeave}\r\n style={{\r\n ...appliedStyles,\r\n transform: `rotateX(${rotation.x}deg) rotateY(${rotation.y}deg) scale(${scale})`,\r\n transformStyle: 'preserve-3d',\r\n transition: 'transform 0.1s ease-out'\r\n }}\r\n className=\"w-64 h-96 relative cursor-pointer\"\r\n >\r\n {/* Card Layers simulating fragmentation/decay */}\r\n <div className=\"absolute inset-0 bg-gradient-to-br from-blue-600 to-purple-700 rounded-xl shadow-2xl border border-white/10 flex flex-col justify-end p-6\">\r\n <h3 className=\"text-2xl font-bold text-white mb-2 translate-z-10\">Neon Nights</h3>\r\n <p className=\"text-blue-100 text-sm translate-z-5\">Hover to see the physics effect.</p>\r\n </div>\r\n\r\n {/* Glitch Overlay */}\r\n <div \r\n className=\"absolute inset-0 bg-white mix-blend-overlay opacity-0 hover:opacity-20 transition-opacity rounded-xl\"\r\n style={{ transform: 'translateZ(20px)' }}\r\n />\r\n \r\n {/* Floating Particles (Simulated) */}\r\n <div className=\"absolute -top-4 -right-4 w-8 h-8 bg-purple-500 rounded-full blur-xl opacity-50 animate-pulse\"></div>\r\n <div className=\"absolute -bottom-4 -left-4 w-12 h-12 bg-blue-500 rounded-full blur-xl opacity-50 animate-pulse delay-75\"></div>\r\n </div>\r\n </div>\r\n );\r\n};\r\n"],"names":["getRadiusClass","globalConfig","baseRadius","getColorClass","type","role","primaryColor","secondaryColor","tertiaryColor","colorMap","shades","getColorShade","shade","c","getColorValue","colorName","targetShade","_a","getComponentVariantClasses","designSystem","componentProps","baseType","variant","isHovered","isFocused","isActive","isTouched","isError","isDisabled","classes","getBorderRadius","granularStyles","getAppliedStyles","defaultComponentProps","defaultGlobalConfig","defaultGranularStyles","Button","children","className","disabled","style","rest","mergedComponentProps","appliedStyles","variantClasses","jsxs","jsx","Loader2","Alert","XCircle","AlertTriangle","CheckCircle","Info","Avatar","bgClass","Badge","badgeClasses","Bell","Mail","Box","width","height","opacityValue","baseStyles","Fragment","Breadcrumbs","items","item","isLast","Home","ChevronRight","Card","effectiveVariant","Chip","isVisible","setIsVisible","useState","User","e","X","MAX_WIDTH_MAP","Container","maxWidthKey","maxWidth","containerStyles","Divider","isVertical","hasText","isSolid","isDashed","isDotted","borderStyle","thickness","containerStyle","textAlign","Link","List","i","Paper","getElevation","isOutlined","Skeleton","baseClass","Stack","direction","spacingPx","stackStyles","Tooltip","isMUI","isApple","isCustom","Autocomplete","ChevronDown","opt","Checkbox","internalChecked","setInternalChecked","useEffect","Minus","Check","ColorPicker","hue","setHue","color","setColor","DatePicker","isOpen","setIsOpen","selectedDate","setSelectedDate","toggleCalendar","days","_","weekDays","primaryBg","Calendar","ChevronLeft","d","day","NumberField","value","setValue","min","max","handleIncrement","v","handleDecrement","isGrouped","Plus","Radio","Select","Signature","cleared","setCleared","PenTool","Eraser","Slider","trackRef","useRef","isDragging","setIsDragging","handleInteract","rect","newValue","handleMouseDown","handleGlobalMouseMove","handleGlobalMouseUp","Switch","isOn","dims","sz","TextArea","setIsFocused","keyboardType","setKeyboardType","keyboardStyle","setKeyboardStyle","language","setLanguage","isShift","setIsShift","textareaRef","englishKeys","urduKeys","arabicKeys","numericKeys","emojiKeys","keys","effectiveStyle","getKeyStyle","key","baseStyle","specialKeyStyle","handleKeyPress","textarea","start","end","text","newText","char","row","rowIndex","keyIndex","ArrowUp","Delete","Smile","TextField","textValue","setTextValue","internalFocused","setInternalFocused","inputBorderRadius","AlertCircle","Upload","files","setFiles","handleDrop","prev","f","UploadCloud","file","File","CheckCircle2","VerificationCode","length","values","setValues","inputs","handleChange","index","val","newValues","handleKeyDown","el","AppBar","Menu","Search","MoreVertical","SettingsIcon","BottomNavigation","active","setActive","Heart","MapPin","toggleMenu","Settings","LogOut","Pagination","page","setPage","count","renderPageButton","p","isSelected","SpeedDial","open","setOpen","Copy","Save","Printer","Share2","action","Stepper","activeStep","setActiveStep","steps","handleNext","handleBack","label","stepNum","isCompleted","React","Tabs","tab","Backdrop","Dialog","toggleDialog","Modal","toggleModal","Progress","isLoading","animatedValue","setAnimatedValue","interval","getTrackClass","getBarClass","progressValue","size","radius","circumference","offset","stepValue","isPartial","Snackbar","STOCK_DATA","PORTFOLIO_DATA","ASSET_ALLOCATION_DATA","VOLUME_DATA","Charts","activeTab","setActiveTab","successColor","dangerColor","getPieChartColors","CustomTooltip","payload","entry","renderCandlestickChart","data","ResponsiveContainer","RechartsAreaChart","CartesianGrid","XAxis","YAxis","Area","Line","renderAreaChart","ReferenceLine","renderLineChart","RechartsLineChart","renderBarChart","BarChart","Bar","renderPieChart","pieColors","assetAllocation","asset","RechartsPieChart","Pie","name","percent","Cell","AreaChart","TrendingUp","LineChart","BarChart3","PieChart","itemData","ImageList","isQuilted","isMasonry","isStandard","Rating","ratingValue","setRatingValue","hoverValue","setHoverValue","stars","getStarColor","getStarSize","s","Star","MOCK_DATA","Table","selectedRows","setSelectedRows","sortConfig","setSortConfig","toggleSelectAll","toggleSelectRow","id","newSelected","handleSort","getStatusBadge","status","base","densityClass","primaryColorBg","primaryColorBorder","Filter","Trash2","h","ArrowDown","ArrowUpDown","CreditCard","MoreHorizontal","ChevronsLeft","ChevronsRight","TransferList","TREE_DATA","TreeView","expanded","setExpanded","selected","setSelected","toggleExpand","newExpanded","renderNode","node","depth","isExpanded","hasChildren","Icon","FolderOpen","Folder","Image","Film","paddingLeft","child","OrderSummary","ShoppingBag","ArrowRight","ShieldCheck","common","red","purple","blue","lightBlue","green","orange","grey","formatMuiErrorMessage","code","args","url","arg","THEME_ID","_extends","n","r","sheetForTag","tag","createStyleElement","options","StyleSheet","_this","before","_proto","nodes","rule","sheet","_tag$parentNode","MS","MOZ","WEBKIT","COMMENT","RULESET","DECLARATION","IMPORT","KEYFRAMES","LAYER","abs","from","assign","hash","charat","trim","match","pattern","replace","replacement","indexof","search","substr","begin","strlen","sizeof","append","array","combine","callback","line","column","position","character","characters","root","parent","props","copy","next","peek","caret","slice","token","alloc","dealloc","delimit","delimiter","whitespace","escaping","commenter","identifier","compile","parse","rules","rulesets","pseudo","points","declarations","atrule","property","previous","variable","scanning","ampersand","reference","comment","declaration","ruleset","post","j","k","x","y","z","serialize","output","stringify","element","middleware","collection","rulesheet","memoize","fn","cache","identifierWithPointTracking","toRules","parsed","getRules","fixedElements","compat","isImplicitRule","parentRules","removeLabel","prefix","prefixer","defaultStylisPlugins","createCache","ssrStyles","dataEmotionAttribute","stylisPlugins","inserted","container","nodesToHydrate","attrib","_insert","omnipresentPlugins","currentSheet","finalizingPlugins","serializer","stylis","styles","selector","serialized","shouldCache","b","g","l","m","q","t","w","a","u","A","reactIs_production_min","hasSymbol","REACT_ELEMENT_TYPE","REACT_PORTAL_TYPE","REACT_FRAGMENT_TYPE","REACT_STRICT_MODE_TYPE","REACT_PROFILER_TYPE","REACT_PROVIDER_TYPE","REACT_CONTEXT_TYPE","REACT_ASYNC_MODE_TYPE","REACT_CONCURRENT_MODE_TYPE","REACT_FORWARD_REF_TYPE","REACT_SUSPENSE_TYPE","REACT_SUSPENSE_LIST_TYPE","REACT_MEMO_TYPE","REACT_LAZY_TYPE","REACT_BLOCK_TYPE","REACT_FUNDAMENTAL_TYPE","REACT_RESPONDER_TYPE","REACT_SCOPE_TYPE","isValidElementType","typeOf","object","$$typeof","$$typeofType","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","ForwardRef","Lazy","Memo","Portal","Profiler","StrictMode","Suspense","hasWarnedAboutDeprecatedIsAsyncMode","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isElement","isForwardRef","isFragment","isLazy","isMemo","isPortal","isProfiler","isStrictMode","isSuspense","reactIs_development","reactIsModule","require$$0","require$$1","reactIs","FORWARD_REF_STATICS","MEMO_STATICS","TYPE_STATICS","isBrowser","getRegisteredStyles","registered","registeredStyles","classNames","rawClassName","registerStyles","isStringTag","insertStyles","current","murmur2","str","len","unitlessKeys","hyphenateRegex","animationRegex","isCustomProperty","isProcessableValue","processStyleName","styleName","processStyleValue","p1","p2","cursor","unitless","handleInterpolation","mergedProps","interpolation","componentSelector","keyframes","serializedStyles","createStringFromObject","previousCursor","result","asString","cached","obj","string","_i","interpolated","labelPattern","serializeStyles","stringMode","strings","asTemplateStringsArr","templateStringsArr","identifierName","hashString","syncFallback","create","useInsertionEffect","useInsertionEffectAlwaysWithSyncFallback","EmotionCacheContext","withEmotionCache","func","forwardRef","ref","useContext","ThemeContext","hasOwn","typePropName","createEmotionProps","newProps","_key","Insertion","_ref","Emotion","cssProp","WrappedComponent","_key2","Emotion$1","argsLength","createElementArgArray","_jsx","JSX","css","_len","insertable","reactPropsRegex","isPropValid","prop","testOmitPropsOnStringTag","testOmitPropsOnComponent","getDefaultShouldForwardProp","composeShouldForwardProps","isReal","shouldForwardProp","optionsShouldForwardProp","propName","createStyled","baseTag","targetClassName","defaultShouldForwardProp","shouldUseAs","Styled","FinalTag","classInterpolations","finalShouldForwardProp","nextTag","nextOptions","newStyled","tags","styled","tagName","getOwnPropertySymbols","hasOwnProperty","propIsEnumerable","toObject","shouldUseNative","test1","test2","order2","test3","letter","objectAssign","target","source","to","symbols","ReactPropTypesSecret","ReactPropTypesSecret_1","has","printWarning","loggedTypeFailures","message","checkPropTypes","typeSpecs","location","componentName","getStack","typeSpecName","error","err","ex","stack","checkPropTypes_1","ReactIs","require$$2","require$$3","require$$4","emptyFunctionThatReturnsNull","factoryWithTypeCheckers","isValidElement","throwOnDirectAccess","ITERATOR_SYMBOL","FAUX_ITERATOR_SYMBOL","getIteratorFn","maybeIterable","iteratorFn","ANONYMOUS","ReactPropTypes","createPrimitiveTypeChecker","createAnyTypeChecker","createArrayOfTypeChecker","createElementTypeChecker","createElementTypeTypeChecker","createInstanceTypeChecker","createNodeChecker","createObjectOfTypeChecker","createEnumTypeChecker","createUnionTypeChecker","createShapeTypeChecker","createStrictShapeTypeChecker","is","PropTypeError","createChainableTypeChecker","validate","manualPropTypeCallCache","manualPropTypeWarningCount","checkType","isRequired","propFullName","secret","cacheKey","chainedCheckType","expectedType","propValue","propType","getPropType","preciseType","getPreciseType","typeChecker","expectedClass","expectedClassName","actualClassName","getClassName","expectedValues","valuesString","arrayOfTypeCheckers","checker","getPostfixForTypeWarning","expectedTypes","checkerResult","expectedTypesMessage","isNode","invalidValidatorError","shapeTypes","allKeys","iterator","step","isSymbol","emptyFunction","emptyFunctionWithReset","factoryWithThrowingShims","shim","getShim","propTypesModule","stylesFactory","emStyled","component","internal_mutateStyles","processor","wrapper","internal_serializeStyles","emSerializeStyles","REACT_CONSUMER_TYPE","REACT_VIEW_TRANSITION_TYPE","REACT_CLIENT_REFERENCE","reactIs_production","isPlainObject","prototype","deepClone","deepmerge","sortBreakpointsValues","breakpointsAsArray","breakpoint1","breakpoint2","acc","createBreakpoints","breakpoints","unit","other","sortedValues","up","down","between","endIndex","only","not","sortContainerQueries","theme","sorted","regex","_b","isCqShorthand","breakpointKeys","getContainerQuery","shorthand","matches","_formatErrorMessage","containerQuery","containerName","cssContainerQueries","themeInput","toContainerQuery","mediaQuery","attachCq","containerQueries","shape","responsivePropType","PropTypes","merge","defaultBreakpoints","defaultContainerQueries","handleBreakpoints","styleFromPropValue","themeBreakpoints","breakpoint","containerKey","mediaKey","cssKey","createEmptyBreakpointObject","breakpointsInput","breakpointStyleKey","removeUnusedBreakpoints","breakpointOutput","capitalize","getPath","path","checkVars","getStyleValue","themeMapping","transform","propValueFinal","userValue","cssProperty","themeKey","properties","directions","aliases","getCssProperties","dir","marginKeys","paddingKeys","spacingKeys","createUnaryUnit","defaultValue","themeSpacing","transformed","createUnarySpacing","getValue","transformer","getStyleFromPropValue","cssProperties","resolveCssProperty","margin","padding","createSpacing","spacingInput","spacing","argsInput","argument","compose","handlers","borderTransform","createBorderStyle","border","borderTop","borderRight","borderBottom","borderLeft","borderColor","borderTopColor","borderRightColor","borderBottomColor","borderLeftColor","outline","outlineColor","borderRadius","gap","columnGap","rowGap","gridColumn","gridRow","gridAutoFlow","gridAutoColumns","gridAutoRows","gridTemplateColumns","gridTemplateRows","gridTemplateAreas","gridArea","paletteTransform","bgcolor","backgroundColor","sizingTransform","_c","breakpointsValues","_e","_d","minWidth","maxHeight","minHeight","boxSizing","defaultSxConfig","objectsHaveSameKeys","objects","union","callIfFn","maybeFn","unstable_createStyleFunctionSx","getThemeValue","config","styleFunctionSx","sx","nested","traverse","sxInput","sxObject","emptyBreakpoints","breakpointsKeys","styleKey","applyStyles","createTheme","paletteInput","shapeInput","muiTheme","isObjectEmpty","useTheme","defaultTheme","contextTheme","systemDefaultTheme","useThemeWithoutDefault","splitProps","extendSxProp","inSx","systemProps","otherProps","finalSx","defaultGenerator","createClassNameGenerator","generate","generator","ClassNameGenerator","o","clsx","createBox","themeId","defaultClassName","generateClassName","BoxRoot","inProps","globalStateClasses","generateUtilityClass","slot","globalStatePrefix","globalStateClass","generateUtilityClasses","slots","getFunctionComponentName","Component","fallback","getWrappedName","outerType","innerType","wrapperName","functionName","getDisplayName","preprocessStyles","input","variants","shallowLayer","layerName","defaultOverridesResolver","_props","attachTheme","processStyle","resolvedStyle","subStyle","rootStyle","otherStyles","processStyleVariants","results","mergedState","variantLoop","rootShouldForwardProp","slotShouldForwardProp","styleAttachTheme","inputOptions","mutateStyles","componentSlot","inputSkipVariantsResolver","inputSkipSx","overridesResolver","lowercaseFirstLetter","skipVariantsResolver","skipSx","shouldForwardPropOption","defaultStyledResolver","styledEngineStyled","generateStyledLabel","transformStyle","muiStyledResolver","expressionsInput","expressionsHead","expressionsBody","expressionsTail","styleOverrides","resolvedStyleOverrides","slotKey","themeVariants","inputStrings","placeholdersHead","placeholdersTail","outputStrings","expressions","generateDisplayName","resolveProps","defaultProps","mergeClassNameAndStyle","defaultSlotProps","slotProps","slotPropName","useEnhancedEffect","clamp","clampWrapper","hexToRgb","re","colors","decomposeColor","marker","colorSpace","colorChannel","decomposedColor","idx","private_safeColorChannel","warning","recomposeColor","hslToRgb","rgb","getLuminance","getContrastRatio","foreground","background","lumA","lumB","alpha","private_safeAlpha","darken","coefficient","private_safeDarken","lighten","private_safeLighten","emphasize","private_safeEmphasize","PropsContext","getThemeProps","params","useDefaultProps","ctx","globalId","useGlobalId","idOverride","defaultId","setDefaultId","safeReact","maybeReactUseId","useId","reactId","unstable_memoTheme","styleFn","lastValue","lastTheme","createGetCssVar","appendVar","vars","field","fallbacks","assignNestedKeys","arrayKeys","temp","walkObjectDeep","shouldSkipPaths","recurse","parentKeys","getCssValue","cssVarsParser","shouldSkipGeneratingVar","varsWithDefaults","cssVar","resolvedValue","prepareCssVars","parserConfig","getSelector","defaultGetSelector","disableCssColorScheme","enableContrastVars","colorSchemes","components","defaultColorScheme","otherTheme","rootVars","rootCss","rootVarsWithDefaults","themeVars","colorSchemesMap","defaultScheme","otherColorSchemes","scheme","colorScheme","cssObject","schemeVars","stylesheets","insertStyleSheet","defaultSchemeVal","cssColorSheme","finalCss","createGetColorSchemeSelector","composeClasses","getUtilityClass","slotName","buffer","getLight","light","getDark","dark","addLightOrDark","intent","tonalOffset","tonalOffsetLight","tonalOffsetDark","mixLightOrDark","getDefaultPrimary","mode","getDefaultSecondary","getDefaultError","getDefaultInfo","getDefaultSuccess","getDefaultWarning","contrastColor","createPalette","palette","contrastThreshold","primary","secondary","info","success","getContrastText","contrastText","contrast","augmentColor","mainShade","lightShade","darkShade","modeHydrated","prepareTypographyVars","typography","createMixins","mixins","round","caseAllCaps","defaultFontFamily","createTypography","fontFamily","fontSize","fontWeightLight","fontWeightRegular","fontWeightMedium","fontWeightBold","htmlFontSize","allVariants","pxToRem2","coef","pxToRem","buildVariant","fontWeight","lineHeight","letterSpacing","casing","shadowKeyUmbraOpacity","shadowKeyPenumbraOpacity","shadowAmbientShadowOpacity","createShadow","px","shadows","easing","duration","formatMs","milliseconds","getAutoHeightDuration","constant","createTransitions","inputTransitions","mergedEasing","mergedDuration","durationOption","easingOption","delay","isString","isNumber","animatedProp","zIndex","isSerializable","stringifyTheme","baseTheme","serializableTheme","serializeTheme","coefficientToPercentage","parseAddition","numbers","sum","attachColorManipulators","systemAlpha","systemLighten","systemDarken","createThemeNoVars","mixinsInput","transitionsInput","typographyInput","systemTheme","systemCreateTheme","stateClasses","stateClass","getOverlayAlpha","elevation","alphaValue","defaultDarkOverlays","overlay","getOpacity","getOverlays","createColorScheme","opacity","overlays","excludeVariablesFromRoot","cssVarPrefix","excludedVariables","assignNode","toRgb","setColorChannel","safeColorChannel","getSpacingVal","silent","systemCreateGetCssVar","attachColorScheme","restTheme","createThemeWithVars","colorSchemesInput","defaultColorSchemeInput","nativeColor","defaultShouldSkipGeneratingVar","rootSelector","firstColorScheme","getCssVar","defaultSchemeInput","builtInLight","builtInDark","customColorSchemes","setCssVarColor","tokens","colorToken","colorMix","method","mixer","safeAlpha","safeDarken","safeLighten","snackbarContentBackground","safeEmphasize","generateThemeVars","generateStyleSheets","cssVariables","initialColorSchemes","initialDefaultColorScheme","paletteOptions","useThemeSystem","internal_createExtendSxProp","memoTheme","useSystemDefaultProps","getSvgIconUtilityClass","useUtilityClasses","ownerState","SvgIconRoot","_f","_h","_g","_j","_l","_k","_n","_m","SvgIcon","htmlColor","inheritViewBox","titleAccess","viewBox","hasSvgAsChild","more","_jsxs","createSvgIcon","displayName","useEventCallback","useForkRef","refs","cleanupRef","refEffect","instance","cleanups","refCallback","refCleanup","chainPropTypes","propType1","propType2","_objectWithoutPropertiesLoose","_setPrototypeOf","_inheritsLoose","setPrototypeOf","TransitionGroupContext","_assertThisInitialized","getChildMapping","mapFn","mapper","Children","mergeChildMappings","getValueForKey","nextKeysPending","pendingKeys","prevKey","childMapping","nextKey","pendingNextKey","getProp","getInitialChildMapping","onExited","cloneElement","getNextChildMapping","nextProps","prevChildMapping","nextChildMapping","hasPrev","hasNext","prevChild","isLeaving","TransitionGroup","_React$Component","context","handleExited","firstRender","currentChildMapping","state","_this$props","childFactory","contextValue","UNINITIALIZED","useLazyRef","init","initArg","EMPTY","useOnMount","Timeout","__publicField","useTimeout","timeout","isClassComponent","elementType","elementTypeAcceptingRef","safePropName","warningHint","elementTypeAcceptingRef$1","isHostComponent","appendOwnerState","resolveComponentProps","slotState","extractEventHandlers","excludeKeys","omitEventHandlers","mergeSlotProps","parameters","getSlotProps","additionalProps","externalSlotProps","externalForwardedProps","joinedClasses","mergedStyle","eventHandlers","componentsPropsWithoutEventHandlers","otherPropsWithoutEventHandlers","internalSlotProps","useSlot","initialElementType","internalForwardedProps","shouldForwardComponentProp","useSlotPropsParams","rootComponent","resolvedComponentsProps","slotComponent","internalRef","LeafComponent","getTypeByValue","valueType","requiredInteger","validator","validatorNoop","integerPropType","getPaperUtilityClass","square","PaperRoot","refType","isFocusVisible","LazyRipple","ripple","shouldMount","setShouldMount","createControlledPromise","useLazyRipple","resolve","reject","resolveFn","rejectFn","Ripple","pulsate","rippleX","rippleY","rippleSize","inProp","leaving","setLeaving","rippleClassName","rippleStyles","childClassName","timeoutId","touchRippleClasses","DURATION","DELAY_RIPPLE","enterKeyframe","exitKeyframe","pulsateKeyframe","TouchRippleRoot","TouchRippleRipple","TouchRipple","centerProp","ripples","setRipples","rippleCallback","ignoringMouseDown","startTimer","startTimerCommit","startCommit","cb","oldRipples","event","center","fakeElement","clientX","clientY","sizeX","sizeY","stop","getButtonBaseUtilityClass","buttonBaseClasses","focusVisible","focusVisibleClassName","composedClasses","ButtonBaseRoot","ButtonBase","centerRipple","disableRipple","disableTouchRipple","focusRipple","LinkComponent","onBlur","onClick","onContextMenu","onDragLeave","onFocus","onFocusVisible","onKeyDown","onKeyUp","onMouseDown","onMouseLeave","onMouseUp","onTouchEnd","onTouchMove","onTouchStart","tabIndex","TouchRippleProps","touchRippleRef","buttonRef","handleRippleRef","setFocusVisible","enableTouchRipple","useRippleHandler","handleContextMenu","handleDragLeave","handleMouseUp","handleMouseLeave","handleTouchStart","handleTouchEnd","handleTouchMove","handleBlur","handleFocus","isNonNativeButton","button","handleKeyUp","ComponentProp","buttonProps","hasFormAttributes","handleRef","rippleAction","eventCallback","skipRippleAction","hasCorrectMainProperty","checkSimplePaletteColorValues","additionalPropertiesToCheck","createSimplePaletteValueFilter","getAlertUtilityClass","alertClasses","getCircularProgressUtilityClass","SIZE","circularRotateKeyframe","circularDashKeyframe","rotateAnimation","dashAnimation","disableShrink","CircularProgressRoot","CircularProgressSVG","CircularProgressCircle","CircularProgressTrack","CircularProgress","enableTrackSlot","circleStyle","rootProps","getIconButtonUtilityClass","iconButtonClasses","edge","loading","IconButtonRoot","IconButtonLoadingIndicator","IconButton","disableFocusRipple","idProp","loadingIndicatorProp","loadingId","loadingIndicator","SuccessOutlinedIcon","ReportProblemOutlinedIcon","ErrorOutlineIcon","InfoOutlinedIcon","ClearIcon","severity","AlertRoot","getColor","getBackgroundColor","AlertIcon","AlertMessage","AlertAction","defaultIconMapping","closeText","componentsProps","icon","iconMapping","onClose","RootSlot","rootSlotProps","IconSlot","iconSlotProps","MessageSlot","messageSlotProps","ActionSlot","actionSlotProps","CloseButtonSlot","closeButtonProps","CloseIconSlot","closeIconProps","CloseIcon","getTypographyUtilityClass","v6Colors","align","gutterBottom","noWrap","paragraph","TypographyRoot","defaultVariantMapping","Typography","themeProps","isSxColor","variantMapping","boxClasses","AccessTimeIcon","ArrowForwardIcon","CalendarTodayIcon","CheckCircleIcon","LocationOnIcon","ScheduleIcon","VideoCallIcon","formatDate","dateString","formatMeetingTime","startTime","endTime","timezone","dateStr","startStr","endStr","CalendarBookings","email","booking","VerificationProgress","userName","nextStep","defaultSteps","verificationSteps","nextStepData","isInProgress","isPending","ButtonGroup","FloatingActionButton","isExtended","Edit","ToggleButton","selectedToggles","setSelectedToggles","handleToggle","Bold","Italic","Underline","arr","Drawer","Inbox","ActionSheet","Camera","hasPermission","setHasPermission","flash","setFlash","facingMode","setFacingMode","CameraIcon","Zap","ZapOff","SwitchCamera","Map","Layers","Navigation","AIChatbot","messages","setMessages","setInput","isTyping","setIsTyping","scrollRef","handleSend","userMsg","Bot","msg","Send","MOCK_CODE_RESULT","CodeGenerator","prompt","setPrompt","isGenerating","setIsGenerating","displayedCode","setDisplayedCode","isCopied","setIsCopied","handleGenerate","handleCopy","Terminal","Sparkles","Code2","MOCK_IMAGES","ImageGenerator","generatedImages","setGeneratedImages","src","Maximize2","Download","ImageIcon","TextGenerator","setResult","mockText","RotateCcw","Wand2","tone","AlignLeft","VideoGenerator","progress","setProgress","hasResult","setHasResult","Video","Play","VoiceChatbot","setState","transcript","setTranscript","response","setResponse","toggleListen","Globe","MicOff","StopCircle","Mic","VoiceUI","isListening","setIsListening","DataQuery","Whiteboard","canvasRef","containerRef","historyRef","historyStepRef","isDrawing","setIsDrawing","tool","setTool","lineWidth","setLineWidth","canUndo","setCanUndo","canRedo","setCanRedo","saveState","canvas","imageData","resizeCanvas","resizeObserver","startDrawing","offsetX","offsetY","getCoordinates","draw","stopDrawing","clearCanvas","undo","redo","downloadCanvas","link","Pencil","ringColor","Undo","Redo","QRCode","generatePattern","rows","cells","isCorner","isPixel","isFlipped","setIsFlipped","cardBaseClasses","getCardStyle","getCardGradient","primaryColorDark","Wifi","AnimationPreview","isPlaying","setIsPlaying","setPoints","setVariant","ballRef","solveSpring","stiffness","damping","mass","velocity","pts","dt","acceleration","solveBezier","p1x","p1y","p2x","p2y","cx","bx","ax","cy","by","ay","solvePenner","c2","c4","bounceOut","newPoints","isStart","animate","time","currentX","point","curr","bounceY","handlePlay","generatePath","startY","range","EMOJI_DATA","CATEGORIES","platformFontMap","EmojisPreview","hideInstructions","setSearch","platform","setPlatform","category","setCategory","filtered","useMemo","query","inCategory","inSearch","Smartphone","MonitorSmartphone","SlidersHorizontal","cat","generateAnimationKeyframes","pos","scale","solveEasing","preset","generateAnimationCSS","animationName","getAnimationStyle","FallbackIcon","FontAwesomeIconRenderer","shouldRender","setShouldRender","hasError","setHasError","useLayoutEffect","startTransition","isValidIcon","FontAwesomeIcon","FontAwesomeErrorBoundary","errorInfo","FontAwesomeWrapper","libraryInitialized","library","fas","far","fab","getAllIcons","icons","seenKeys","iconDef","iconName","uniqueKey","IconsPreview","animationConfig","allIcons","setAllIcons","searchQuery","setSearchQuery","selectedIcons","setSelectedIcons","copiedIcon","setCopiedIcon","showControls","setShowControls","currentPage","setCurrentPage","itemsPerPage","initialSortBy","sortBy","setSortBy","initialStyle","selectedStyle","setSelectedStyle","initialViewMode","viewMode","setViewMode","iconSize","iconColor","customColor","filteredIcons","matchesSearch","matchesStyle","totalPages","paginatedIcons","startIndex","toggleIconSelection","iconKey","newSelection","selectAll","getIconKey","deselectAll","copyToClipboard","includeSelection","iconsToCopy","imports","usages","libraryAdds","ic","camelCaseName","word","faIconName","packageName","fullCode","getIconColor","selectedInfo","byStyle","animationStyle","animationKeyframes","styleId","styleElement","option","Grid3X3","pageNum","getColorFilter","hex","getAllIllustrations","illustrations","parts","subcategory","CATEGORY_INFO","IllustrationsPreview","allIllustrations","setAllIllustrations","setIsLoading","selectedCategory","setSelectedCategory","copiedIllustration","setCopiedIllustration","selectedIllustrations","setSelectedIllustrations","illustrationSize","illustrationColor","illustrationCustomColor","categories","allStyles","catStyles","filteredIllustrations","illustration","matchesCategory","paginatedIllustrations","toggleIllustrationSelection","allPaths","downloadSVG","svgContent","blob","byCategory","ExternalLink","VideoPlayer","isMuted","setIsMuted","togglePlay","toggleMute","timer","handleMouseEnter","Pause","VolumeX","Volume2","Maximize","DEVICE_SCALES","DEVICE_ICONS","Tablet","Monitor","Tv","TypographyPreview","activeFont","hideDeviceSelector","deviceType","viewportWidth","selectedDevice","setSelectedDevice","getResponsiveSize","baseSize","minScale","maxScale","scaleFactor","device","scaleData","responsiveSize","INITIAL_ITEMS","ShoppingCart","setItems","couponCode","setCouponCode","updateQuantity","delta","newQty","removeItem","subtotal","shipping","total","formatPrice","price","Tag","VirtualKeyboard","getContainerStyle","keySize","renderKey","isDesktop","content","bg","textColor","rI","kI","RetroCursorEffect","gradient","angle","InteractiveCursor","selectedEffect","setSelectedEffect","isDropdownOpen","setIsDropdownOpen","cursorEffectRef","retroEffectRef","cursorColor","cursorSecondaryColor","cursorTertiaryColor","ghostCursor","rainbowCursor","emojiCursor","springyEmojiCursor","bubbleCursor","fairyDustCursor","trailingCursor","followingDotCursor","snowflakeCursor","textFlag","characterCursor","clockCursor","effects","Circle","Ghost","Droplet","MousePointer2","Snowflake","Clock","Target","Gamepad2","selectedEffectData","effect","MagnetLines","cols","cellWidth","cellHeight","lineLength","mouseX","mouseY","resize","centerX","centerY","dx","dy","animId","handleMouseMove","PixelTrail","pixelSize","grid","decay","py","DecayCard","cardRef","rotation","setRotation","setScale","rotateX","rotateY"],"mappings":"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","x_google_ignoreList":[50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220]}