@bloomreach/react-banana-ui 1.1.0-next.1

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 (366) hide show
  1. package/README.md +310 -0
  2. package/dist/bloomreach-react-banana-ui.es.js +7683 -0
  3. package/dist/bloomreach-react-banana-ui.es.js.map +1 -0
  4. package/dist/bloomreach-react-banana-ui.umd.js +52 -0
  5. package/dist/bloomreach-react-banana-ui.umd.js.map +1 -0
  6. package/dist/components/buttons/button/button.d.ts +71 -0
  7. package/dist/components/buttons/button/button.qa.stories.d.ts +8 -0
  8. package/dist/components/buttons/button/button.stories.d.ts +16 -0
  9. package/dist/components/buttons/button/index.d.ts +1 -0
  10. package/dist/components/buttons/button-group/button-group.d.ts +41 -0
  11. package/dist/components/buttons/button-group/button-group.stories.d.ts +9 -0
  12. package/dist/components/buttons/button-group/index.d.ts +2 -0
  13. package/dist/components/buttons/index.d.ts +4 -0
  14. package/dist/components/buttons/toggle-button/index.d.ts +2 -0
  15. package/dist/components/buttons/toggle-button/toggle-button.d.ts +75 -0
  16. package/dist/components/buttons/toggle-button/toggle-button.stories.d.ts +7 -0
  17. package/dist/components/buttons/toggle-button-group/index.d.ts +2 -0
  18. package/dist/components/buttons/toggle-button-group/toggle-button-group.d.ts +94 -0
  19. package/dist/components/buttons/toggle-button-group/toggle-button-group.stories.d.ts +8 -0
  20. package/dist/components/containers/dropdown/dropdown.d.ts +131 -0
  21. package/dist/components/containers/scroll-region/scroll-region.d.ts +106 -0
  22. package/dist/components/containers/scroll-view/scroll-view.d.ts +115 -0
  23. package/dist/components/feedback/alert/alert-title.d.ts +13 -0
  24. package/dist/components/feedback/alert/alert.d.ts +41 -0
  25. package/dist/components/feedback/alert/alert.stories.d.ts +11 -0
  26. package/dist/components/feedback/alert/index.d.ts +2 -0
  27. package/dist/components/feedback/index.d.ts +1 -0
  28. package/dist/components/foundations/icon/icon.d.ts +41 -0
  29. package/dist/components/foundations/icon/icon.qa.stories.d.ts +6 -0
  30. package/dist/components/foundations/icon/icon.stories.d.ts +16 -0
  31. package/dist/components/foundations/icon/icons/AbTestIcon.d.ts +4 -0
  32. package/dist/components/foundations/icon/icons/AggregateIcon.d.ts +4 -0
  33. package/dist/components/foundations/icon/icons/AnalyticsIcon.d.ts +4 -0
  34. package/dist/components/foundations/icon/icons/AndroidIcon.d.ts +4 -0
  35. package/dist/components/foundations/icon/icons/AnonymizeIcon.d.ts +4 -0
  36. package/dist/components/foundations/icon/icons/AppleIcon.d.ts +4 -0
  37. package/dist/components/foundations/icon/icons/ArchiveAltIcon.d.ts +4 -0
  38. package/dist/components/foundations/icon/icons/ArchiveIcon.d.ts +4 -0
  39. package/dist/components/foundations/icon/icons/ArrowCollapseIcon.d.ts +4 -0
  40. package/dist/components/foundations/icon/icons/ArrowDownIcon.d.ts +4 -0
  41. package/dist/components/foundations/icon/icons/ArrowExpandIcon.d.ts +4 -0
  42. package/dist/components/foundations/icon/icons/ArrowKeyboardNextIcon.d.ts +4 -0
  43. package/dist/components/foundations/icon/icons/ArrowKeyboardPreviousIcon.d.ts +4 -0
  44. package/dist/components/foundations/icon/icons/ArrowKeyboardUpIcon.d.ts +4 -0
  45. package/dist/components/foundations/icon/icons/ArrowLeftIcon.d.ts +4 -0
  46. package/dist/components/foundations/icon/icons/ArrowRightIcon.d.ts +4 -0
  47. package/dist/components/foundations/icon/icons/ArrowUpIcon.d.ts +4 -0
  48. package/dist/components/foundations/icon/icons/AxisIcon.d.ts +4 -0
  49. package/dist/components/foundations/icon/icons/AxisLimtIcon.d.ts +4 -0
  50. package/dist/components/foundations/icon/icons/BarChartIcon.d.ts +4 -0
  51. package/dist/components/foundations/icon/icons/BooleanIcon.d.ts +4 -0
  52. package/dist/components/foundations/icon/icons/BracketsCancelIcon.d.ts +4 -0
  53. package/dist/components/foundations/icon/icons/BracketsIcon.d.ts +4 -0
  54. package/dist/components/foundations/icon/icons/BrowserIcon.d.ts +4 -0
  55. package/dist/components/foundations/icon/icons/BrowserPushIcon.d.ts +4 -0
  56. package/dist/components/foundations/icon/icons/CalendarAltIcon.d.ts +4 -0
  57. package/dist/components/foundations/icon/icons/CalendarIcon.d.ts +4 -0
  58. package/dist/components/foundations/icon/icons/CatalogIcon.d.ts +4 -0
  59. package/dist/components/foundations/icon/icons/ChatAddIcon.d.ts +4 -0
  60. package/dist/components/foundations/icon/icons/ChatIcon.d.ts +4 -0
  61. package/dist/components/foundations/icon/icons/ChatsIcon.d.ts +4 -0
  62. package/dist/components/foundations/icon/icons/CheckCircleIcon.d.ts +4 -0
  63. package/dist/components/foundations/icon/icons/CheckFilledIcon.d.ts +4 -0
  64. package/dist/components/foundations/icon/icons/CheckIcon.d.ts +4 -0
  65. package/dist/components/foundations/icon/icons/CheckSmallIcon.d.ts +4 -0
  66. package/dist/components/foundations/icon/icons/ChevronDownFillIcon.d.ts +4 -0
  67. package/dist/components/foundations/icon/icons/ChevronDownIcon.d.ts +4 -0
  68. package/dist/components/foundations/icon/icons/ChevronLeftFillIcon.d.ts +4 -0
  69. package/dist/components/foundations/icon/icons/ChevronLeftIcon.d.ts +4 -0
  70. package/dist/components/foundations/icon/icons/ChevronRightFillIcon.d.ts +4 -0
  71. package/dist/components/foundations/icon/icons/ChevronRightIcon.d.ts +4 -0
  72. package/dist/components/foundations/icon/icons/ChevronUpFillIcon.d.ts +4 -0
  73. package/dist/components/foundations/icon/icons/ChevronUpIcon.d.ts +4 -0
  74. package/dist/components/foundations/icon/icons/ClearFillIcon.d.ts +4 -0
  75. package/dist/components/foundations/icon/icons/ClearIcon.d.ts +4 -0
  76. package/dist/components/foundations/icon/icons/ClipboardAddIcon.d.ts +4 -0
  77. package/dist/components/foundations/icon/icons/ClockCircleIcon.d.ts +4 -0
  78. package/dist/components/foundations/icon/icons/CloneIcon.d.ts +4 -0
  79. package/dist/components/foundations/icon/icons/CloseIcon.d.ts +4 -0
  80. package/dist/components/foundations/icon/icons/CloseSmallIcon.d.ts +4 -0
  81. package/dist/components/foundations/icon/icons/CloudCheckIcon.d.ts +4 -0
  82. package/dist/components/foundations/icon/icons/CloudDownloadIcon.d.ts +4 -0
  83. package/dist/components/foundations/icon/icons/CodeIcon.d.ts +4 -0
  84. package/dist/components/foundations/icon/icons/ColorPickerAltIcon.d.ts +4 -0
  85. package/dist/components/foundations/icon/icons/ColorPickerIcon.d.ts +4 -0
  86. package/dist/components/foundations/icon/icons/ColumnsIcon.d.ts +4 -0
  87. package/dist/components/foundations/icon/icons/ConditionAltIcon.d.ts +4 -0
  88. package/dist/components/foundations/icon/icons/ConditionIcon.d.ts +4 -0
  89. package/dist/components/foundations/icon/icons/ConsoleIcon.d.ts +4 -0
  90. package/dist/components/foundations/icon/icons/ConstantAltIcon.d.ts +4 -0
  91. package/dist/components/foundations/icon/icons/ConstantIcon.d.ts +4 -0
  92. package/dist/components/foundations/icon/icons/ContextualPersonalizationIcon.d.ts +4 -0
  93. package/dist/components/foundations/icon/icons/CopyIcon.d.ts +4 -0
  94. package/dist/components/foundations/icon/icons/CopyToDashboardIcon.d.ts +4 -0
  95. package/dist/components/foundations/icon/icons/CsvIcon.d.ts +4 -0
  96. package/dist/components/foundations/icon/icons/CustomRowIcon.d.ts +4 -0
  97. package/dist/components/foundations/icon/icons/CustomerIcon.d.ts +4 -0
  98. package/dist/components/foundations/icon/icons/CustomersFilterIcon.d.ts +4 -0
  99. package/dist/components/foundations/icon/icons/CustomersSegmentationIcon.d.ts +4 -0
  100. package/dist/components/foundations/icon/icons/DateTimeIcon.d.ts +4 -0
  101. package/dist/components/foundations/icon/icons/DescriptionIcon.d.ts +4 -0
  102. package/dist/components/foundations/icon/icons/DesktopIcon.d.ts +4 -0
  103. package/dist/components/foundations/icon/icons/DisabledIcon.d.ts +4 -0
  104. package/dist/components/foundations/icon/icons/DivideIcon.d.ts +4 -0
  105. package/dist/components/foundations/icon/icons/DocumentationIcon.d.ts +4 -0
  106. package/dist/components/foundations/icon/icons/DownloadIcon.d.ts +4 -0
  107. package/dist/components/foundations/icon/icons/DragHorizontalIcon.d.ts +4 -0
  108. package/dist/components/foundations/icon/icons/DragVericalIcon.d.ts +4 -0
  109. package/dist/components/foundations/icon/icons/EditIcon.d.ts +4 -0
  110. package/dist/components/foundations/icon/icons/EducationHubIcon.d.ts +4 -0
  111. package/dist/components/foundations/icon/icons/EllipsisVerticalIcon.d.ts +4 -0
  112. package/dist/components/foundations/icon/icons/EllipsissHorizontalIcon.d.ts +4 -0
  113. package/dist/components/foundations/icon/icons/EmailIcon.d.ts +4 -0
  114. package/dist/components/foundations/icon/icons/EmojiPickerIcon.d.ts +4 -0
  115. package/dist/components/foundations/icon/icons/ErrorFillIcon.d.ts +4 -0
  116. package/dist/components/foundations/icon/icons/EventIcon.d.ts +4 -0
  117. package/dist/components/foundations/icon/icons/EventsSegmentationIcon.d.ts +4 -0
  118. package/dist/components/foundations/icon/icons/ExperimentIcon.d.ts +4 -0
  119. package/dist/components/foundations/icon/icons/ExposeIcon.d.ts +4 -0
  120. package/dist/components/foundations/icon/icons/ExpressionIcon.d.ts +4 -0
  121. package/dist/components/foundations/icon/icons/ExternalLinkIcon.d.ts +4 -0
  122. package/dist/components/foundations/icon/icons/EyeCrossedIcon.d.ts +4 -0
  123. package/dist/components/foundations/icon/icons/EyeIcon.d.ts +4 -0
  124. package/dist/components/foundations/icon/icons/FastForwardIcon.d.ts +4 -0
  125. package/dist/components/foundations/icon/icons/FileIcon.d.ts +4 -0
  126. package/dist/components/foundations/icon/icons/FilterIcon.d.ts +4 -0
  127. package/dist/components/foundations/icon/icons/FireIcon.d.ts +4 -0
  128. package/dist/components/foundations/icon/icons/FolderEmptyIcon.d.ts +4 -0
  129. package/dist/components/foundations/icon/icons/FolderFullIcon.d.ts +4 -0
  130. package/dist/components/foundations/icon/icons/FormulaExpressionIcon.d.ts +4 -0
  131. package/dist/components/foundations/icon/icons/FormulaIcon.d.ts +4 -0
  132. package/dist/components/foundations/icon/icons/FromStartAltIcon.d.ts +4 -0
  133. package/dist/components/foundations/icon/icons/FullscreenIcon.d.ts +4 -0
  134. package/dist/components/foundations/icon/icons/GiftIcon.d.ts +4 -0
  135. package/dist/components/foundations/icon/icons/GoToIcon.d.ts +4 -0
  136. package/dist/components/foundations/icon/icons/GraphStatsIcon.d.ts +4 -0
  137. package/dist/components/foundations/icon/icons/GridAltIcon.d.ts +4 -0
  138. package/dist/components/foundations/icon/icons/GridIcon.d.ts +4 -0
  139. package/dist/components/foundations/icon/icons/HelpIcon.d.ts +4 -0
  140. package/dist/components/foundations/icon/icons/HistoryIcon.d.ts +4 -0
  141. package/dist/components/foundations/icon/icons/HomeIcon.d.ts +4 -0
  142. package/dist/components/foundations/icon/icons/HtmlIcon.d.ts +4 -0
  143. package/dist/components/foundations/icon/icons/ImagesIcon.d.ts +4 -0
  144. package/dist/components/foundations/icon/icons/InfoFilledIcon.d.ts +4 -0
  145. package/dist/components/foundations/icon/icons/InfoIcon.d.ts +4 -0
  146. package/dist/components/foundations/icon/icons/InfoSmallIcon.d.ts +4 -0
  147. package/dist/components/foundations/icon/icons/InternetIcon.d.ts +4 -0
  148. package/dist/components/foundations/icon/icons/KeyIcon.d.ts +4 -0
  149. package/dist/components/foundations/icon/icons/LayoutIcon.d.ts +4 -0
  150. package/dist/components/foundations/icon/icons/LikeIcon.d.ts +4 -0
  151. package/dist/components/foundations/icon/icons/LineChartIcon.d.ts +4 -0
  152. package/dist/components/foundations/icon/icons/LinkIcon.d.ts +4 -0
  153. package/dist/components/foundations/icon/icons/ListIcon.d.ts +4 -0
  154. package/dist/components/foundations/icon/icons/LoaderIcon.d.ts +4 -0
  155. package/dist/components/foundations/icon/icons/LockIcon.d.ts +4 -0
  156. package/dist/components/foundations/icon/icons/MapIcon.d.ts +4 -0
  157. package/dist/components/foundations/icon/icons/MetricAltIcon.d.ts +4 -0
  158. package/dist/components/foundations/icon/icons/MinusIcon.d.ts +4 -0
  159. package/dist/components/foundations/icon/icons/MobileAppInboxIcon.d.ts +4 -0
  160. package/dist/components/foundations/icon/icons/MobileImageMessageIcon.d.ts +4 -0
  161. package/dist/components/foundations/icon/icons/MobilePhoneLandscapeIcon.d.ts +4 -0
  162. package/dist/components/foundations/icon/icons/MobilePhonePortraitIcon.d.ts +4 -0
  163. package/dist/components/foundations/icon/icons/MobilePushIcon.d.ts +4 -0
  164. package/dist/components/foundations/icon/icons/MobileSmsIcon.d.ts +4 -0
  165. package/dist/components/foundations/icon/icons/MobileTextMessageIcon.d.ts +4 -0
  166. package/dist/components/foundations/icon/icons/MoveIcon.d.ts +4 -0
  167. package/dist/components/foundations/icon/icons/NegationIcon.d.ts +4 -0
  168. package/dist/components/foundations/icon/icons/NotificationIcon.d.ts +4 -0
  169. package/dist/components/foundations/icon/icons/NumberIcon.d.ts +4 -0
  170. package/dist/components/foundations/icon/icons/OfflineFillIcon.d.ts +4 -0
  171. package/dist/components/foundations/icon/icons/OfflineIcon.d.ts +4 -0
  172. package/dist/components/foundations/icon/icons/PaintIcon.d.ts +4 -0
  173. package/dist/components/foundations/icon/icons/ParagraphCenterAlignIcon.d.ts +4 -0
  174. package/dist/components/foundations/icon/icons/ParagraphLeftAlignIcon.d.ts +4 -0
  175. package/dist/components/foundations/icon/icons/ParagraphRightAlignIcon.d.ts +4 -0
  176. package/dist/components/foundations/icon/icons/PercentageIcon.d.ts +4 -0
  177. package/dist/components/foundations/icon/icons/PersAlt1Icon.d.ts +4 -0
  178. package/dist/components/foundations/icon/icons/PersAlt2Icon.d.ts +4 -0
  179. package/dist/components/foundations/icon/icons/PersAlt3Icon.d.ts +4 -0
  180. package/dist/components/foundations/icon/icons/PersAlt4Icon.d.ts +4 -0
  181. package/dist/components/foundations/icon/icons/PictureAltIcon.d.ts +4 -0
  182. package/dist/components/foundations/icon/icons/PictureIcon.d.ts +4 -0
  183. package/dist/components/foundations/icon/icons/PinIcon.d.ts +4 -0
  184. package/dist/components/foundations/icon/icons/PlugPlayIcon.d.ts +4 -0
  185. package/dist/components/foundations/icon/icons/PlusCircleFillIcon.d.ts +4 -0
  186. package/dist/components/foundations/icon/icons/PlusCircleIcon.d.ts +4 -0
  187. package/dist/components/foundations/icon/icons/PlusIcon.d.ts +4 -0
  188. package/dist/components/foundations/icon/icons/PoverButtonIcon.d.ts +4 -0
  189. package/dist/components/foundations/icon/icons/RefreshIcon.d.ts +4 -0
  190. package/dist/components/foundations/icon/icons/ReleaseNotesIcon.d.ts +4 -0
  191. package/dist/components/foundations/icon/icons/RenameAltIcon.d.ts +4 -0
  192. package/dist/components/foundations/icon/icons/RenameIcon.d.ts +4 -0
  193. package/dist/components/foundations/icon/icons/ReorderIcon.d.ts +4 -0
  194. package/dist/components/foundations/icon/icons/ReportIcon.d.ts +4 -0
  195. package/dist/components/foundations/icon/icons/RetentionIcon.d.ts +4 -0
  196. package/dist/components/foundations/icon/icons/RewertLeftIcon.d.ts +4 -0
  197. package/dist/components/foundations/icon/icons/RewertRightIcon.d.ts +4 -0
  198. package/dist/components/foundations/icon/icons/RibbonIcon.d.ts +4 -0
  199. package/dist/components/foundations/icon/icons/RoadmapIcon.d.ts +4 -0
  200. package/dist/components/foundations/icon/icons/RobotIcon.d.ts +4 -0
  201. package/dist/components/foundations/icon/icons/RunningAggregateIcon.d.ts +4 -0
  202. package/dist/components/foundations/icon/icons/SaveIcon.d.ts +4 -0
  203. package/dist/components/foundations/icon/icons/ScenarioIcon.d.ts +4 -0
  204. package/dist/components/foundations/icon/icons/SearchIcon.d.ts +4 -0
  205. package/dist/components/foundations/icon/icons/SecurityShieldIcon.d.ts +4 -0
  206. package/dist/components/foundations/icon/icons/SendIcon.d.ts +4 -0
  207. package/dist/components/foundations/icon/icons/SettingsAltIcon.d.ts +4 -0
  208. package/dist/components/foundations/icon/icons/SettingsIcon.d.ts +4 -0
  209. package/dist/components/foundations/icon/icons/ShareIcon.d.ts +4 -0
  210. package/dist/components/foundations/icon/icons/ShopIcon.d.ts +4 -0
  211. package/dist/components/foundations/icon/icons/ShrinkIcon.d.ts +4 -0
  212. package/dist/components/foundations/icon/icons/SortIcon.d.ts +4 -0
  213. package/dist/components/foundations/icon/icons/SplitFlowIcon.d.ts +4 -0
  214. package/dist/components/foundations/icon/icons/SqlIcon.d.ts +4 -0
  215. package/dist/components/foundations/icon/icons/StarFillIcon.d.ts +4 -0
  216. package/dist/components/foundations/icon/icons/StarIcon.d.ts +4 -0
  217. package/dist/components/foundations/icon/icons/StartFillIcon.d.ts +4 -0
  218. package/dist/components/foundations/icon/icons/StartIcon.d.ts +4 -0
  219. package/dist/components/foundations/icon/icons/StatusDotIcon.d.ts +4 -0
  220. package/dist/components/foundations/icon/icons/StopIcon.d.ts +4 -0
  221. package/dist/components/foundations/icon/icons/StopwatchIcon.d.ts +4 -0
  222. package/dist/components/foundations/icon/icons/StringComponentIcon.d.ts +4 -0
  223. package/dist/components/foundations/icon/icons/StringIcon.d.ts +4 -0
  224. package/dist/components/foundations/icon/icons/SuggestionIcon.d.ts +4 -0
  225. package/dist/components/foundations/icon/icons/SurveyIcon.d.ts +4 -0
  226. package/dist/components/foundations/icon/icons/SwapIcon.d.ts +4 -0
  227. package/dist/components/foundations/icon/icons/TabletLangscapeIcon.d.ts +4 -0
  228. package/dist/components/foundations/icon/icons/TabletPortraitIcon.d.ts +4 -0
  229. package/dist/components/foundations/icon/icons/TagAltIcon.d.ts +4 -0
  230. package/dist/components/foundations/icon/icons/TagIcon.d.ts +4 -0
  231. package/dist/components/foundations/icon/icons/TemplateIcon.d.ts +4 -0
  232. package/dist/components/foundations/icon/icons/TextBoldIcon.d.ts +4 -0
  233. package/dist/components/foundations/icon/icons/TextItalicIcon.d.ts +4 -0
  234. package/dist/components/foundations/icon/icons/TextStyleIcon.d.ts +4 -0
  235. package/dist/components/foundations/icon/icons/TragetIcon.d.ts +4 -0
  236. package/dist/components/foundations/icon/icons/TransferIcon.d.ts +4 -0
  237. package/dist/components/foundations/icon/icons/TrashIcon.d.ts +4 -0
  238. package/dist/components/foundations/icon/icons/TrendIcon.d.ts +4 -0
  239. package/dist/components/foundations/icon/icons/UnExposeIcon.d.ts +4 -0
  240. package/dist/components/foundations/icon/icons/UnarchiveAltIcon.d.ts +4 -0
  241. package/dist/components/foundations/icon/icons/UndoIcon.d.ts +4 -0
  242. package/dist/components/foundations/icon/icons/UnlinkIcon.d.ts +4 -0
  243. package/dist/components/foundations/icon/icons/UnlockIcon.d.ts +4 -0
  244. package/dist/components/foundations/icon/icons/UntilNowAltIcon.d.ts +4 -0
  245. package/dist/components/foundations/icon/icons/UploadIcon.d.ts +4 -0
  246. package/dist/components/foundations/icon/icons/UsagesIcon.d.ts +4 -0
  247. package/dist/components/foundations/icon/icons/UsersIcon.d.ts +4 -0
  248. package/dist/components/foundations/icon/icons/VisualIcon.d.ts +4 -0
  249. package/dist/components/foundations/icon/icons/VoucherIcon.d.ts +4 -0
  250. package/dist/components/foundations/icon/icons/WaitIcon.d.ts +4 -0
  251. package/dist/components/foundations/icon/icons/WalkthroughsIcon.d.ts +4 -0
  252. package/dist/components/foundations/icon/icons/WarningFillIcon.d.ts +4 -0
  253. package/dist/components/foundations/icon/icons/WebhookIcon.d.ts +4 -0
  254. package/dist/components/foundations/icon/icons/WeblayerIcon.d.ts +4 -0
  255. package/dist/components/foundations/icon/icons/WrenchIcon.d.ts +4 -0
  256. package/dist/components/foundations/icon/icons/index.d.ts +225 -0
  257. package/dist/components/foundations/icon/index.d.ts +3 -0
  258. package/dist/components/foundations/index.d.ts +1 -0
  259. package/dist/components/index.d.ts +6 -0
  260. package/dist/components/inputs/base-field/base-field.d.ts +48 -0
  261. package/dist/components/inputs/base-field/generate-field-id.d.ts +4 -0
  262. package/dist/components/inputs/base-field/index.d.ts +2 -0
  263. package/dist/components/inputs/base-input/base-input.d.ts +104 -0
  264. package/dist/components/inputs/base-input/index.d.ts +2 -0
  265. package/dist/components/inputs/index.d.ts +2 -0
  266. package/dist/components/inputs/input-field/index.d.ts +2 -0
  267. package/dist/components/inputs/input-field/input-field.d.ts +119 -0
  268. package/dist/components/inputs/input-field/input-field.qa.stories.d.ts +13 -0
  269. package/dist/components/inputs/input-field/input-field.stories.d.ts +23 -0
  270. package/dist/components/inputs/internal.d.ts +2 -0
  271. package/dist/components/inputs/selection/selection.d.ts +233 -0
  272. package/dist/components/inputs/text-field/index.d.ts +2 -0
  273. package/dist/components/inputs/text-field/text-field.d.ts +138 -0
  274. package/dist/components/inputs/text-field/text-field.qa.stories.d.ts +14 -0
  275. package/dist/components/inputs/text-field/text-field.stories.d.ts +25 -0
  276. package/dist/components/internal.d.ts +1 -0
  277. package/dist/components/lists/list-view/list-view.d.ts +149 -0
  278. package/dist/components/loaders/loader/loader.d.ts +24 -0
  279. package/dist/components/navigation/index.d.ts +1 -0
  280. package/dist/components/navigation/pagination/index.d.ts +2 -0
  281. package/dist/components/navigation/pagination/pagination-config.d.ts +4 -0
  282. package/dist/components/navigation/pagination/pagination-context.d.ts +5 -0
  283. package/dist/components/navigation/pagination/pagination-items-per-page-selector.d.ts +2 -0
  284. package/dist/components/navigation/pagination/pagination-navigation-helpers.d.ts +11 -0
  285. package/dist/components/navigation/pagination/pagination-navigation-item.d.ts +6 -0
  286. package/dist/components/navigation/pagination/pagination-navigation.d.ts +2 -0
  287. package/dist/components/navigation/pagination/pagination-summary.d.ts +2 -0
  288. package/dist/components/navigation/pagination/pagination-types.d.ts +38 -0
  289. package/dist/components/navigation/pagination/pagination.d.ts +21 -0
  290. package/dist/components/navigation/pagination/pagination.qa.stories.d.ts +8 -0
  291. package/dist/components/navigation/pagination/pagination.stories.d.ts +20 -0
  292. package/dist/components/popovers/index.d.ts +2 -0
  293. package/dist/components/popovers/modal/index.d.ts +8 -0
  294. package/dist/components/popovers/modal/modal-body.d.ts +8 -0
  295. package/dist/components/popovers/modal/modal-close-button.d.ts +13 -0
  296. package/dist/components/popovers/modal/modal-context.d.ts +5 -0
  297. package/dist/components/popovers/modal/modal-footer-actions.d.ts +8 -0
  298. package/dist/components/popovers/modal/modal-footer.d.ts +10 -0
  299. package/dist/components/popovers/modal/modal-header-title.d.ts +7 -0
  300. package/dist/components/popovers/modal/modal-header.d.ts +9 -0
  301. package/dist/components/popovers/modal/modal-types.d.ts +94 -0
  302. package/dist/components/popovers/modal/modal.d.ts +37 -0
  303. package/dist/components/popovers/modal/modal.qa.stories.d.ts +10 -0
  304. package/dist/components/popovers/modal/modal.stories.d.ts +14 -0
  305. package/dist/components/popovers/tooltip/index.d.ts +2 -0
  306. package/dist/components/popovers/tooltip/tooltip-config.d.ts +2 -0
  307. package/dist/components/popovers/tooltip/tooltip.d.ts +50 -0
  308. package/dist/components/popovers/tooltip/tooltip.qa.stories.d.ts +8 -0
  309. package/dist/components/popovers/tooltip/tooltip.stories.d.ts +25 -0
  310. package/dist/components/types.d.ts +19 -0
  311. package/dist/index.d.ts +1 -0
  312. package/dist/style.css +1 -0
  313. package/dist/utils/add-font.d.ts +29 -0
  314. package/dist/utils/after-render.d.ts +5 -0
  315. package/dist/utils/async-dom-render.d.ts +6 -0
  316. package/dist/utils/chalk.d.ts +44 -0
  317. package/dist/utils/chunk.d.ts +4 -0
  318. package/dist/utils/classnames.d.ts +6 -0
  319. package/dist/utils/clone-client-rect.d.ts +26 -0
  320. package/dist/utils/compare-client-rect.d.ts +5 -0
  321. package/dist/utils/compare-sets.d.ts +5 -0
  322. package/dist/utils/compose-refs.d.ts +5 -0
  323. package/dist/utils/cookie-parser.d.ts +8 -0
  324. package/dist/utils/copy-text-to-clipboard.d.ts +7 -0
  325. package/dist/utils/debounce.d.ts +4 -0
  326. package/dist/utils/deep-clone.d.ts +5 -0
  327. package/dist/utils/deep-equal.d.ts +4 -0
  328. package/dist/utils/ensure-modal-root.d.ts +4 -0
  329. package/dist/utils/event-element-position.d.ts +4 -0
  330. package/dist/utils/filter-react-children.d.ts +6 -0
  331. package/dist/utils/find-react-children.d.ts +10 -0
  332. package/dist/utils/flatten-array.d.ts +5 -0
  333. package/dist/utils/fuzzy-groups.d.ts +51 -0
  334. package/dist/utils/get-decimal.d.ts +8 -0
  335. package/dist/utils/get-error-message.d.ts +6 -0
  336. package/dist/utils/get-first-with-class.d.ts +5 -0
  337. package/dist/utils/get-index.d.ts +5 -0
  338. package/dist/utils/get-selected-text.d.ts +4 -0
  339. package/dist/utils/get-type-name.d.ts +14 -0
  340. package/dist/utils/group-react-children.d.ts +8 -0
  341. package/dist/utils/has-child.d.ts +4 -0
  342. package/dist/utils/hooks/index.d.ts +1 -0
  343. package/dist/utils/hooks/use-hover.d.ts +10 -0
  344. package/dist/utils/index.d.ts +43 -0
  345. package/dist/utils/local-storage.d.ts +42 -0
  346. package/dist/utils/make-buffer.d.ts +28 -0
  347. package/dist/utils/map-lookup-values.d.ts +65 -0
  348. package/dist/utils/no-op.d.ts +4 -0
  349. package/dist/utils/normalize-wheel/ExecutionEnvironment.d.ts +38 -0
  350. package/dist/utils/normalize-wheel/UserAgent_DEPRECATED.d.ts +116 -0
  351. package/dist/utils/normalize-wheel/index.d.ts +2 -0
  352. package/dist/utils/normalize-wheel/isEventSupported.d.ts +46 -0
  353. package/dist/utils/normalize-wheel/normalizeWheel.d.ts +139 -0
  354. package/dist/utils/promise-resolver.d.ts +36 -0
  355. package/dist/utils/relative-client-rect.d.ts +5 -0
  356. package/dist/utils/rush.d.ts +4 -0
  357. package/dist/utils/state-controls.d.ts +28 -0
  358. package/dist/utils/stop-all-propagation.d.ts +8 -0
  359. package/dist/utils/template.d.ts +49 -0
  360. package/dist/utils/to-digits.d.ts +4 -0
  361. package/dist/utils/to-query-params.d.ts +14 -0
  362. package/dist/utils/types.d.ts +69 -0
  363. package/dist/utils/url-join.d.ts +24 -0
  364. package/dist/utils/wait.d.ts +1 -0
  365. package/dist/utils/when.d.ts +2 -0
  366. package/package.json +117 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bloomreach-react-banana-ui.umd.js","sources":["../node_modules/@babel/runtime/helpers/esm/extends.js","../node_modules/@mui/base/utils/isHostComponent.js","../node_modules/@mui/base/utils/appendOwnerState.js","../node_modules/@mui/base/utils/ClassNameConfigurator.js","../node_modules/@mui/base/utils/extractEventHandlers.js","../node_modules/@mui/base/utils/resolveComponentProps.js","../node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js","../node_modules/@mui/utils/esm/chainPropTypes/chainPropTypes.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.production.min.js","../node_modules/prop-types/node_modules/react-is/cjs/react-is.development.js","../node_modules/prop-types/node_modules/react-is/index.js","../node_modules/object-assign/index.js","../node_modules/prop-types/lib/ReactPropTypesSecret.js","../node_modules/prop-types/lib/has.js","../node_modules/prop-types/checkPropTypes.js","../node_modules/prop-types/factoryWithTypeCheckers.js","../node_modules/prop-types/factoryWithThrowingShims.js","../node_modules/prop-types/index.js","../node_modules/@mui/utils/esm/elementAcceptingRef.js","../node_modules/@mui/utils/esm/exactProp/exactProp.js","../node_modules/@mui/utils/esm/formatMuiErrorMessage.js","../node_modules/@mui/utils/esm/HTMLElementType/HTMLElementType.js","../node_modules/@mui/utils/esm/createChainedFunction.js","../node_modules/@mui/utils/esm/debounce/debounce.js","../node_modules/@mui/utils/esm/ownerDocument/ownerDocument.js","../node_modules/@mui/utils/esm/ownerWindow/ownerWindow.js","../node_modules/@mui/utils/esm/setRef.js","../node_modules/@mui/utils/esm/useEnhancedEffect/useEnhancedEffect.js","../node_modules/@mui/utils/esm/useEventCallback/useEventCallback.js","../node_modules/@mui/utils/esm/useForkRef/useForkRef.js","../node_modules/@mui/utils/esm/useIsFocusVisible.js","../node_modules/@mui/utils/esm/getScrollbarSize.js","../node_modules/@mui/utils/esm/composeClasses/composeClasses.js","../node_modules/@mui/utils/esm/ClassNameGenerator/ClassNameGenerator.js","../node_modules/@mui/utils/esm/generateUtilityClass/generateUtilityClass.js","../node_modules/@mui/utils/esm/generateUtilityClasses/generateUtilityClasses.js","../node_modules/clsx/dist/clsx.mjs","../node_modules/@mui/base/utils/omitEventHandlers.js","../node_modules/@mui/base/utils/mergeSlotProps.js","../node_modules/@mui/base/utils/useSlotProps.js","../node_modules/@mui/base/utils/prepareForSlot.js","../node_modules/@mui/base/useButton/useButton.js","../node_modules/@mui/base/FocusTrap/FocusTrap.js","../node_modules/@mui/base/FormControl/FormControlContext.js","../node_modules/@mui/base/FormControl/useFormControlContext.js","../node_modules/@mui/base/useInput/useInput.js","../node_modules/@mui/base/Portal/Portal.js","../node_modules/@mui/base/unstable_useModal/ModalManager.js","../node_modules/@mui/base/unstable_useModal/useModal.js","../node_modules/@mui/base/Modal/modalClasses.js","../node_modules/@mui/base/Modal/Modal.js","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/utils/dom/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.mjs","../node_modules/@mui/base/TextareaAutosize/TextareaAutosize.js","../node_modules/classnames/index.js","../node_modules/@bloomreach/banana-theme/dist/assets/icons/ab-test.svg?react","../src/components/foundations/icon/icon.tsx","../src/components/foundations/icon/icons/AbTestIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/aggregate.svg?react","../src/components/foundations/icon/icons/AggregateIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/analytics.svg?react","../src/components/foundations/icon/icons/AnalyticsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/android.svg?react","../src/components/foundations/icon/icons/AndroidIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/anonymize.svg?react","../src/components/foundations/icon/icons/AnonymizeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/apple.svg?react","../src/components/foundations/icon/icons/AppleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/archive-alt.svg?react","../src/components/foundations/icon/icons/ArchiveAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/archive.svg?react","../src/components/foundations/icon/icons/ArchiveIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-collapse.svg?react","../src/components/foundations/icon/icons/ArrowCollapseIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-down.svg?react","../src/components/foundations/icon/icons/ArrowDownIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-expand.svg?react","../src/components/foundations/icon/icons/ArrowExpandIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-keyboard-next.svg?react","../src/components/foundations/icon/icons/ArrowKeyboardNextIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-keyboard-previous.svg?react","../src/components/foundations/icon/icons/ArrowKeyboardPreviousIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-keyboard-up.svg?react","../src/components/foundations/icon/icons/ArrowKeyboardUpIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-left.svg?react","../src/components/foundations/icon/icons/ArrowLeftIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-right.svg?react","../src/components/foundations/icon/icons/ArrowRightIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/arrow-up.svg?react","../src/components/foundations/icon/icons/ArrowUpIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/axis.svg?react","../src/components/foundations/icon/icons/AxisIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/axis-limt.svg?react","../src/components/foundations/icon/icons/AxisLimtIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/bar-chart.svg?react","../src/components/foundations/icon/icons/BarChartIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/boolean.svg?react","../src/components/foundations/icon/icons/BooleanIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/brackets-cancel.svg?react","../src/components/foundations/icon/icons/BracketsCancelIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/brackets.svg?react","../src/components/foundations/icon/icons/BracketsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/browser.svg?react","../src/components/foundations/icon/icons/BrowserIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/browser-push.svg?react","../src/components/foundations/icon/icons/BrowserPushIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/calendar-alt.svg?react","../src/components/foundations/icon/icons/CalendarAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/calendar.svg?react","../src/components/foundations/icon/icons/CalendarIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/catalog.svg?react","../src/components/foundations/icon/icons/CatalogIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chat-add.svg?react","../src/components/foundations/icon/icons/ChatAddIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chat.svg?react","../src/components/foundations/icon/icons/ChatIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chats.svg?react","../src/components/foundations/icon/icons/ChatsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/check-circle.svg?react","../src/components/foundations/icon/icons/CheckCircleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/check-filled.svg?react","../src/components/foundations/icon/icons/CheckFilledIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/check.svg?react","../src/components/foundations/icon/icons/CheckIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/check-small.svg?react","../src/components/foundations/icon/icons/CheckSmallIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-down-fill.svg?react","../src/components/foundations/icon/icons/ChevronDownFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-down.svg?react","../src/components/foundations/icon/icons/ChevronDownIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-left-fill.svg?react","../src/components/foundations/icon/icons/ChevronLeftFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-left.svg?react","../src/components/foundations/icon/icons/ChevronLeftIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-right-fill.svg?react","../src/components/foundations/icon/icons/ChevronRightFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-right.svg?react","../src/components/foundations/icon/icons/ChevronRightIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-up-fill.svg?react","../src/components/foundations/icon/icons/ChevronUpFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/chevron-up.svg?react","../src/components/foundations/icon/icons/ChevronUpIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/clear-fill.svg?react","../src/components/foundations/icon/icons/ClearFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/clear.svg?react","../src/components/foundations/icon/icons/ClearIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/clipboard-add.svg?react","../src/components/foundations/icon/icons/ClipboardAddIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/clock-circle.svg?react","../src/components/foundations/icon/icons/ClockCircleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/clone.svg?react","../src/components/foundations/icon/icons/CloneIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/close.svg?react","../src/components/foundations/icon/icons/CloseIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/close-small.svg?react","../src/components/foundations/icon/icons/CloseSmallIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/cloud-check.svg?react","../src/components/foundations/icon/icons/CloudCheckIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/cloud-download.svg?react","../src/components/foundations/icon/icons/CloudDownloadIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/code.svg?react","../src/components/foundations/icon/icons/CodeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/color-picker-alt.svg?react","../src/components/foundations/icon/icons/ColorPickerAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/color-picker.svg?react","../src/components/foundations/icon/icons/ColorPickerIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/columns.svg?react","../src/components/foundations/icon/icons/ColumnsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/condition-alt.svg?react","../src/components/foundations/icon/icons/ConditionAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/condition.svg?react","../src/components/foundations/icon/icons/ConditionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/console.svg?react","../src/components/foundations/icon/icons/ConsoleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/constant-alt.svg?react","../src/components/foundations/icon/icons/ConstantAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/constant.svg?react","../src/components/foundations/icon/icons/ConstantIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/contextual-personalization.svg?react","../src/components/foundations/icon/icons/ContextualPersonalizationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/copy.svg?react","../src/components/foundations/icon/icons/CopyIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/copy-to-dashboard.svg?react","../src/components/foundations/icon/icons/CopyToDashboardIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/csv.svg?react","../src/components/foundations/icon/icons/CsvIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/custom-row.svg?react","../src/components/foundations/icon/icons/CustomRowIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/customer-.svg?react","../src/components/foundations/icon/icons/CustomerIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/customers-filter.svg?react","../src/components/foundations/icon/icons/CustomersFilterIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/customers-segmentation.svg?react","../src/components/foundations/icon/icons/CustomersSegmentationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/date-time.svg?react","../src/components/foundations/icon/icons/DateTimeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/description.svg?react","../src/components/foundations/icon/icons/DescriptionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/desktop.svg?react","../src/components/foundations/icon/icons/DesktopIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/disabled.svg?react","../src/components/foundations/icon/icons/DisabledIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/divide.svg?react","../src/components/foundations/icon/icons/DivideIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/documentation.svg?react","../src/components/foundations/icon/icons/DocumentationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/download.svg?react","../src/components/foundations/icon/icons/DownloadIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/drag-horizontal.svg?react","../src/components/foundations/icon/icons/DragHorizontalIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/drag-verical.svg?react","../src/components/foundations/icon/icons/DragVericalIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/edit.svg?react","../src/components/foundations/icon/icons/EditIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/education-hub.svg?react","../src/components/foundations/icon/icons/EducationHubIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/ellipsis-vertical.svg?react","../src/components/foundations/icon/icons/EllipsisVerticalIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/ellipsiss-horizontal.svg?react","../src/components/foundations/icon/icons/EllipsissHorizontalIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/email.svg?react","../src/components/foundations/icon/icons/EmailIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/emoji-picker.svg?react","../src/components/foundations/icon/icons/EmojiPickerIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/error-fill.svg?react","../src/components/foundations/icon/icons/ErrorFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/event.svg?react","../src/components/foundations/icon/icons/EventIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/events-segmentation.svg?react","../src/components/foundations/icon/icons/EventsSegmentationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/experiment.svg?react","../src/components/foundations/icon/icons/ExperimentIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/expose.svg?react","../src/components/foundations/icon/icons/ExposeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/expression.svg?react","../src/components/foundations/icon/icons/ExpressionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/external-link.svg?react","../src/components/foundations/icon/icons/ExternalLinkIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/eye-crossed.svg?react","../src/components/foundations/icon/icons/EyeCrossedIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/eye.svg?react","../src/components/foundations/icon/icons/EyeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/fast-forward.svg?react","../src/components/foundations/icon/icons/FastForwardIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/file.svg?react","../src/components/foundations/icon/icons/FileIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/filter.svg?react","../src/components/foundations/icon/icons/FilterIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/fire.svg?react","../src/components/foundations/icon/icons/FireIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/folder-empty.svg?react","../src/components/foundations/icon/icons/FolderEmptyIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/folder-full.svg?react","../src/components/foundations/icon/icons/FolderFullIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/formula-expression-.svg?react","../src/components/foundations/icon/icons/FormulaExpressionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/formula.svg?react","../src/components/foundations/icon/icons/FormulaIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/from-start-alt.svg?react","../src/components/foundations/icon/icons/FromStartAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/fullscreen.svg?react","../src/components/foundations/icon/icons/FullscreenIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/gift.svg?react","../src/components/foundations/icon/icons/GiftIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/go-to.svg?react","../src/components/foundations/icon/icons/GoToIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/graph-stats.svg?react","../src/components/foundations/icon/icons/GraphStatsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/grid-alt.svg?react","../src/components/foundations/icon/icons/GridAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/grid.svg?react","../src/components/foundations/icon/icons/GridIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/help.svg?react","../src/components/foundations/icon/icons/HelpIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/history.svg?react","../src/components/foundations/icon/icons/HistoryIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/home.svg?react","../src/components/foundations/icon/icons/HomeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/html.svg?react","../src/components/foundations/icon/icons/HtmlIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/images.svg?react","../src/components/foundations/icon/icons/ImagesIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/info-filled.svg?react","../src/components/foundations/icon/icons/InfoFilledIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/info.svg?react","../src/components/foundations/icon/icons/InfoIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/info-small.svg?react","../src/components/foundations/icon/icons/InfoSmallIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/internet.svg?react","../src/components/foundations/icon/icons/InternetIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/key.svg?react","../src/components/foundations/icon/icons/KeyIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/layout.svg?react","../src/components/foundations/icon/icons/LayoutIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/like.svg?react","../src/components/foundations/icon/icons/LikeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/line-chart.svg?react","../src/components/foundations/icon/icons/LineChartIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/link.svg?react","../src/components/foundations/icon/icons/LinkIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/list.svg?react","../src/components/foundations/icon/icons/ListIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/loader.svg?react","../src/components/foundations/icon/icons/LoaderIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/lock.svg?react","../src/components/foundations/icon/icons/LockIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/map.svg?react","../src/components/foundations/icon/icons/MapIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/metric-alt.svg?react","../src/components/foundations/icon/icons/MetricAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/minus.svg?react","../src/components/foundations/icon/icons/MinusIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-app-inbox.svg?react","../src/components/foundations/icon/icons/MobileAppInboxIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-image-message.svg?react","../src/components/foundations/icon/icons/MobileImageMessageIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-phone-landscape.svg?react","../src/components/foundations/icon/icons/MobilePhoneLandscapeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-phone-portrait.svg?react","../src/components/foundations/icon/icons/MobilePhonePortraitIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-push.svg?react","../src/components/foundations/icon/icons/MobilePushIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-sms.svg?react","../src/components/foundations/icon/icons/MobileSmsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/mobile-text-message.svg?react","../src/components/foundations/icon/icons/MobileTextMessageIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/move.svg?react","../src/components/foundations/icon/icons/MoveIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/negation.svg?react","../src/components/foundations/icon/icons/NegationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/notification.svg?react","../src/components/foundations/icon/icons/NotificationIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/number.svg?react","../src/components/foundations/icon/icons/NumberIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/offline-fill.svg?react","../src/components/foundations/icon/icons/OfflineFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/offline.svg?react","../src/components/foundations/icon/icons/OfflineIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/paint.svg?react","../src/components/foundations/icon/icons/PaintIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/paragraph-center-align.svg?react","../src/components/foundations/icon/icons/ParagraphCenterAlignIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/paragraph-left-align.svg?react","../src/components/foundations/icon/icons/ParagraphLeftAlignIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/paragraph-right-align.svg?react","../src/components/foundations/icon/icons/ParagraphRightAlignIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/percentage.svg?react","../src/components/foundations/icon/icons/PercentageIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pers-alt-1.svg?react","../src/components/foundations/icon/icons/PersAlt1Icon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pers-alt-2.svg?react","../src/components/foundations/icon/icons/PersAlt2Icon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pers-alt-3.svg?react","../src/components/foundations/icon/icons/PersAlt3Icon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pers-alt-4.svg?react","../src/components/foundations/icon/icons/PersAlt4Icon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/picture-alt.svg?react","../src/components/foundations/icon/icons/PictureAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/picture.svg?react","../src/components/foundations/icon/icons/PictureIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pin.svg?react","../src/components/foundations/icon/icons/PinIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/plug&play.svg?react","../src/components/foundations/icon/icons/PlugPlayIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/plus-circle-fill.svg?react","../src/components/foundations/icon/icons/PlusCircleFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/plus-circle.svg?react","../src/components/foundations/icon/icons/PlusCircleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/plus.svg?react","../src/components/foundations/icon/icons/PlusIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/pover-button.svg?react","../src/components/foundations/icon/icons/PoverButtonIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/refresh.svg?react","../src/components/foundations/icon/icons/RefreshIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/release-notes.svg?react","../src/components/foundations/icon/icons/ReleaseNotesIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/rename-alt.svg?react","../src/components/foundations/icon/icons/RenameAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/rename.svg?react","../src/components/foundations/icon/icons/RenameIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/reorder.svg?react","../src/components/foundations/icon/icons/ReorderIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/report.svg?react","../src/components/foundations/icon/icons/ReportIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/retention.svg?react","../src/components/foundations/icon/icons/RetentionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/rewert-left.svg?react","../src/components/foundations/icon/icons/RewertLeftIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/rewert-right.svg?react","../src/components/foundations/icon/icons/RewertRightIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/ribbon.svg?react","../src/components/foundations/icon/icons/RibbonIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/roadmap.svg?react","../src/components/foundations/icon/icons/RoadmapIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/robot.svg?react","../src/components/foundations/icon/icons/RobotIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/running-aggregate.svg?react","../src/components/foundations/icon/icons/RunningAggregateIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/save.svg?react","../src/components/foundations/icon/icons/SaveIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/scenario.svg?react","../src/components/foundations/icon/icons/ScenarioIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/search.svg?react","../src/components/foundations/icon/icons/SearchIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/security-shield.svg?react","../src/components/foundations/icon/icons/SecurityShieldIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/send.svg?react","../src/components/foundations/icon/icons/SendIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/settings-alt.svg?react","../src/components/foundations/icon/icons/SettingsAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/settings.svg?react","../src/components/foundations/icon/icons/SettingsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/share.svg?react","../src/components/foundations/icon/icons/ShareIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/shop.svg?react","../src/components/foundations/icon/icons/ShopIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/shrink.svg?react","../src/components/foundations/icon/icons/ShrinkIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/sort.svg?react","../src/components/foundations/icon/icons/SortIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/split-flow.svg?react","../src/components/foundations/icon/icons/SplitFlowIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/sql.svg?react","../src/components/foundations/icon/icons/SqlIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/star-fill.svg?react","../src/components/foundations/icon/icons/StarFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/star.svg?react","../src/components/foundations/icon/icons/StarIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/start-fill.svg?react","../src/components/foundations/icon/icons/StartFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/start.svg?react","../src/components/foundations/icon/icons/StartIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/status-dot.svg?react","../src/components/foundations/icon/icons/StatusDotIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/stop.svg?react","../src/components/foundations/icon/icons/StopIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/stopwatch.svg?react","../src/components/foundations/icon/icons/StopwatchIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/string-component.svg?react","../src/components/foundations/icon/icons/StringComponentIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/string.svg?react","../src/components/foundations/icon/icons/StringIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/suggestion.svg?react","../src/components/foundations/icon/icons/SuggestionIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/survey.svg?react","../src/components/foundations/icon/icons/SurveyIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/swap.svg?react","../src/components/foundations/icon/icons/SwapIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/tablet-langscape.svg?react","../src/components/foundations/icon/icons/TabletLangscapeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/tablet-portrait.svg?react","../src/components/foundations/icon/icons/TabletPortraitIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/tag-alt.svg?react","../src/components/foundations/icon/icons/TagAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/tag.svg?react","../src/components/foundations/icon/icons/TagIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/template.svg?react","../src/components/foundations/icon/icons/TemplateIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/text-bold.svg?react","../src/components/foundations/icon/icons/TextBoldIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/text-italic.svg?react","../src/components/foundations/icon/icons/TextItalicIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/text-style.svg?react","../src/components/foundations/icon/icons/TextStyleIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/traget.svg?react","../src/components/foundations/icon/icons/TragetIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/transfer.svg?react","../src/components/foundations/icon/icons/TransferIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/trash.svg?react","../src/components/foundations/icon/icons/TrashIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/trend.svg?react","../src/components/foundations/icon/icons/TrendIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/un-expose.svg?react","../src/components/foundations/icon/icons/UnExposeIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/unarchive-alt.svg?react","../src/components/foundations/icon/icons/UnarchiveAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/undo.svg?react","../src/components/foundations/icon/icons/UndoIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/unlink.svg?react","../src/components/foundations/icon/icons/UnlinkIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/unlock.svg?react","../src/components/foundations/icon/icons/UnlockIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/until-now-alt.svg?react","../src/components/foundations/icon/icons/UntilNowAltIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/upload.svg?react","../src/components/foundations/icon/icons/UploadIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/usages.svg?react","../src/components/foundations/icon/icons/UsagesIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/users.svg?react","../src/components/foundations/icon/icons/UsersIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/visual.svg?react","../src/components/foundations/icon/icons/VisualIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/voucher.svg?react","../src/components/foundations/icon/icons/VoucherIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/wait.svg?react","../src/components/foundations/icon/icons/WaitIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/walkthroughs.svg?react","../src/components/foundations/icon/icons/WalkthroughsIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/warning-fill.svg?react","../src/components/foundations/icon/icons/WarningFillIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/webhook.svg?react","../src/components/foundations/icon/icons/WebhookIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/weblayer.svg?react","../src/components/foundations/icon/icons/WeblayerIcon.tsx","../node_modules/@bloomreach/banana-theme/dist/assets/icons/wrench.svg?react","../src/components/foundations/icon/icons/WrenchIcon.tsx","../node_modules/@floating-ui/react/utils/dist/floating-ui.react.utils.mjs","../node_modules/tabbable/dist/index.esm.js","../node_modules/@floating-ui/react/dist/floating-ui.react.mjs","../node_modules/react-merge-refs/dist/index.mjs","../src/components/popovers/tooltip/tooltip-config.tsx","../src/components/popovers/tooltip/tooltip.tsx","../src/components/buttons/button/button.tsx","../src/components/buttons/button-group/button-group.tsx","../src/components/buttons/toggle-button/toggle-button.tsx","../src/components/buttons/toggle-button-group/toggle-button-group.tsx","../src/components/feedback/alert/alert.tsx","../src/components/feedback/alert/alert-title.tsx","../src/components/popovers/modal/modal-context.ts","../src/components/popovers/modal/modal.tsx","../src/components/popovers/modal/modal-close-button.tsx","../src/components/popovers/modal/modal-header.tsx","../src/components/popovers/modal/modal-header-title.tsx","../src/components/popovers/modal/modal-body.tsx","../src/components/popovers/modal/modal-footer.tsx","../src/components/popovers/modal/modal-footer-actions.tsx","../src/components/inputs/base-field/base-field.tsx","../src/utils/hooks/use-hover.ts","../src/components/inputs/base-input/base-input.tsx","../src/components/inputs/base-field/generate-field-id.ts","../src/components/inputs/input-field/input-field.tsx","../src/components/inputs/text-field/text-field.tsx","../src/components/navigation/pagination/pagination-context.ts","../src/components/navigation/pagination/pagination-config.ts","../src/utils/no-op.ts","../src/utils/wait.ts","../node_modules/react-dom/client.js","../src/utils/classnames.ts","../src/utils/clone-client-rect.ts","../src/utils/ensure-modal-root.ts","../src/utils/types.ts","../src/utils/get-first-with-class.ts","../src/utils/has-child.ts","../src/utils/normalize-wheel/ExecutionEnvironment.ts","../src/utils/normalize-wheel/isEventSupported.ts","../src/utils/normalize-wheel/UserAgent_DEPRECATED.ts","../src/utils/normalize-wheel/normalizeWheel.ts","../src/utils/state-controls.ts","../src/utils/stop-all-propagation.ts","../src/utils/when.ts","../src/components/types.ts","../src/components/containers/dropdown/dropdown.tsx","../src/components/containers/scroll-region/scroll-region.tsx","../src/components/containers/scroll-view/scroll-view.tsx","../src/components/lists/list-view/list-view.tsx","../src/components/loaders/loader/loader.tsx","../src/components/inputs/selection/selection.tsx","../src/components/navigation/pagination/pagination-items-per-page-selector.tsx","../src/components/navigation/pagination/pagination-navigation-helpers.ts","../src/components/navigation/pagination/pagination-navigation-item.tsx","../src/components/navigation/pagination/pagination-navigation.tsx","../src/components/navigation/pagination/pagination-summary.tsx","../src/components/navigation/pagination/pagination.tsx"],"sourcesContent":["export default function _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}","/**\n * Determines if a given element is a DOM element name (i.e. not a React component).\n */\nexport function isHostComponent(element) {\n return typeof element === 'string';\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { isHostComponent } from './isHostComponent';\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 */\nexport function appendOwnerState(elementType, otherProps, ownerState) {\n if (elementType === undefined || isHostComponent(elementType)) {\n return otherProps;\n }\n return _extends({}, otherProps, {\n ownerState: _extends({}, otherProps.ownerState, ownerState)\n });\n}","'use client';\n\nimport * as React from 'react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst defaultContextValue = {\n disableDefaultClasses: false\n};\nconst ClassNameConfiguratorContext = /*#__PURE__*/React.createContext(defaultContextValue);\n/**\n * @ignore - internal hook.\n *\n * Wraps the `generateUtilityClass` function and controls how the classes are generated.\n * Currently it only affects whether the classes are applied or not.\n *\n * @returns Function to be called with the `generateUtilityClass` function specific to a component to generate the classes.\n */\nexport function useClassNamesOverride(generateUtilityClass) {\n const {\n disableDefaultClasses\n } = React.useContext(ClassNameConfiguratorContext);\n return slot => {\n if (disableDefaultClasses) {\n return '';\n }\n return generateUtilityClass(slot);\n };\n}\n\n/**\n * Allows to configure the components within to not apply any built-in classes.\n */\nexport function ClassNameConfigurator(props) {\n const {\n disableDefaultClasses,\n children\n } = props;\n const contextValue = React.useMemo(() => ({\n disableDefaultClasses: disableDefaultClasses != null ? disableDefaultClasses : false\n }), [disableDefaultClasses]);\n return /*#__PURE__*/_jsx(ClassNameConfiguratorContext.Provider, {\n value: contextValue,\n children: children\n });\n}","/**\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 */\nexport function 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}","/**\n * If `componentProps` is a function, calls it with the provided `ownerState`.\n * Otherwise, just returns `componentProps`.\n */\nexport function resolveComponentProps(componentProps, ownerState, slotState) {\n if (typeof componentProps === 'function') {\n return componentProps(ownerState, slotState);\n }\n return componentProps;\n}","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\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}","/** @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","/*\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","import PropTypes from 'prop-types';\nimport chainPropTypes from './chainPropTypes';\nfunction isClassComponent(elementType) {\n // elementType.prototype?.isReactComponent\n const {\n prototype = {}\n } = elementType;\n return Boolean(prototype.isReactComponent);\n}\nfunction acceptingRef(props, propName, componentName, location, propFullName) {\n const element = props[propName];\n const safePropName = propFullName || propName;\n if (element == 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 const elementType = element.type;\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 elementType === 'function' && !isClassComponent(elementType)) {\n warningHint = 'Did you accidentally use a plain function component for an element instead?';\n }\n if (warningHint !== undefined) {\n return new Error(`Invalid ${location} \\`${safePropName}\\` supplied to \\`${componentName}\\`. ` + `Expected an element that can hold a ref. ${warningHint} ` + 'For more information see https://mui.com/r/caveat-with-refs-guide');\n }\n return null;\n}\nconst elementAcceptingRef = chainPropTypes(PropTypes.element, acceptingRef);\nelementAcceptingRef.isRequired = chainPropTypes(PropTypes.element.isRequired, acceptingRef);\nexport default elementAcceptingRef;","import _extends from \"@babel/runtime/helpers/esm/extends\";\n// This module is based on https://github.com/airbnb/prop-types-exact repository.\n// However, in order to reduce the number of dependencies and to remove some extra safe checks\n// the module was forked.\nconst specialProperty = 'exact-prop: \\u200b';\nexport default function exactProp(propTypes) {\n if (process.env.NODE_ENV === 'production') {\n return propTypes;\n }\n return _extends({}, propTypes, {\n [specialProperty]: props => {\n const unsupportedProps = Object.keys(props).filter(prop => !propTypes.hasOwnProperty(prop));\n if (unsupportedProps.length > 0) {\n return new Error(`The following props are not supported: ${unsupportedProps.map(prop => `\\`${prop}\\``).join(', ')}. Please remove them.`);\n }\n return null;\n }\n });\n}","/**\n * WARNING: Don't import this directly.\n * Use `MuiError` from `@mui/utils/macros/MuiError.macro` instead.\n * @param {number} code\n */\nexport default function formatMuiErrorMessage(code) {\n // Apply babel-plugin-transform-template-literals in loose mode\n // loose mode is safe iff we're concatenating primitives\n // see https://babeljs.io/docs/en/babel-plugin-transform-template-literals#loose\n /* eslint-disable prefer-template */\n let url = 'https://mui.com/production-error/?code=' + code;\n for (let i = 1; i < arguments.length; i += 1) {\n // rest params over-transpile for this case\n // eslint-disable-next-line prefer-rest-params\n url += '&args[]=' + encodeURIComponent(arguments[i]);\n }\n return 'Minified MUI error #' + code + '; visit ' + url + ' for the full message.';\n /* eslint-enable prefer-template */\n}","export default function HTMLElementType(props, propName, componentName, location, propFullName) {\n if (process.env.NODE_ENV === 'production') {\n return null;\n }\n const propValue = props[propName];\n const safePropName = propFullName || propName;\n if (propValue == null) {\n return null;\n }\n if (propValue && propValue.nodeType !== 1) {\n return new Error(`Invalid ${location} \\`${safePropName}\\` supplied to \\`${componentName}\\`. ` + `Expected an HTMLElement.`);\n }\n return null;\n}","/**\n * Safe chained function.\n *\n * Will only create a new function if needed,\n * otherwise will pass back existing functions or null.\n */\nexport default function createChainedFunction(...funcs) {\n return funcs.reduce((acc, func) => {\n if (func == null) {\n return acc;\n }\n return function chainedFunction(...args) {\n acc.apply(this, args);\n func.apply(this, args);\n };\n }, () => {});\n}","// Corresponds to 10 frames at 60 Hz.\n// A few bytes payload overhead when lodash/debounce is ~3 kB and debounce ~300 B.\nexport default function debounce(func, wait = 166) {\n let timeout;\n function debounced(...args) {\n const later = () => {\n // @ts-ignore\n func.apply(this, args);\n };\n clearTimeout(timeout);\n timeout = setTimeout(later, wait);\n }\n debounced.clear = () => {\n clearTimeout(timeout);\n };\n return debounced;\n}","export default function ownerDocument(node) {\n return node && node.ownerDocument || document;\n}","import ownerDocument from '../ownerDocument';\nexport default function ownerWindow(node) {\n const doc = ownerDocument(node);\n return doc.defaultView || window;\n}","/**\n * TODO v5: consider making it private\n *\n * passes {value} to {ref}\n *\n * WARNING: Be sure to only call this inside a callback that is passed as a ref.\n * Otherwise, make sure to cleanup the previous {ref} if it changes. See\n * https://github.com/mui/material-ui/issues/13539\n *\n * Useful if you want to expose the ref of an inner component to the public API\n * while still using it inside the component.\n * @param ref A ref callback or ref object. If anything falsy, this is a no-op.\n */\nexport default function setRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref) {\n ref.current = value;\n }\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;","'use client';\n\nimport * as React from 'react';\nimport useEnhancedEffect from '../useEnhancedEffect';\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 // tslint:disable-next-line:ban-comma-operator\n (0, ref.current)(...args)).current;\n}\nexport default useEventCallback;","'use client';\n\nimport * as React from 'react';\nimport setRef from '../setRef';\nexport default function useForkRef(...refs) {\n /**\n * This will create a new function if the refs passed to this hook change and are all defined.\n * This means react will call the old forkRef with `null` and the new forkRef\n * with the ref. Cleanup naturally emerges from this behavior.\n */\n return React.useMemo(() => {\n if (refs.every(ref => ref == null)) {\n return null;\n }\n return instance => {\n refs.forEach(ref => {\n setRef(ref, instance);\n });\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}","'use client';\n\n// based on https://github.com/WICG/focus-visible/blob/v4.1.5/src/focus-visible.js\nimport * as React from 'react';\nlet hadKeyboardEvent = true;\nlet hadFocusVisibleRecently = false;\nlet hadFocusVisibleRecentlyTimeout;\nconst inputTypesWhitelist = {\n text: true,\n search: true,\n url: true,\n tel: true,\n email: true,\n password: true,\n number: true,\n date: true,\n month: true,\n week: true,\n time: true,\n datetime: true,\n 'datetime-local': true\n};\n\n/**\n * Computes whether the given element should automatically trigger the\n * `focus-visible` class being added, i.e. whether it should always match\n * `:focus-visible` when focused.\n * @param {Element} node\n * @returns {boolean}\n */\nfunction focusTriggersKeyboardModality(node) {\n const {\n type,\n tagName\n } = node;\n if (tagName === 'INPUT' && inputTypesWhitelist[type] && !node.readOnly) {\n return true;\n }\n if (tagName === 'TEXTAREA' && !node.readOnly) {\n return true;\n }\n if (node.isContentEditable) {\n return true;\n }\n return false;\n}\n\n/**\n * Keep track of our keyboard modality state with `hadKeyboardEvent`.\n * If the most recent user interaction was via the keyboard;\n * and the key press did not include a meta, alt/option, or control key;\n * then the modality is keyboard. Otherwise, the modality is not keyboard.\n * @param {KeyboardEvent} event\n */\nfunction handleKeyDown(event) {\n if (event.metaKey || event.altKey || event.ctrlKey) {\n return;\n }\n hadKeyboardEvent = true;\n}\n\n/**\n * If at any point a user clicks with a pointing device, ensure that we change\n * the modality away from keyboard.\n * This avoids the situation where a user presses a key on an already focused\n * element, and then clicks on a different element, focusing it with a\n * pointing device, while we still think we're in keyboard modality.\n */\nfunction handlePointerDown() {\n hadKeyboardEvent = false;\n}\nfunction handleVisibilityChange() {\n if (this.visibilityState === 'hidden') {\n // If the tab becomes active again, the browser will handle calling focus\n // on the element (Safari actually calls it twice).\n // If this tab change caused a blur on an element with focus-visible,\n // re-apply the class when the user switches back to the tab.\n if (hadFocusVisibleRecently) {\n hadKeyboardEvent = true;\n }\n }\n}\nfunction prepare(doc) {\n doc.addEventListener('keydown', handleKeyDown, true);\n doc.addEventListener('mousedown', handlePointerDown, true);\n doc.addEventListener('pointerdown', handlePointerDown, true);\n doc.addEventListener('touchstart', handlePointerDown, true);\n doc.addEventListener('visibilitychange', handleVisibilityChange, true);\n}\nexport function teardown(doc) {\n doc.removeEventListener('keydown', handleKeyDown, true);\n doc.removeEventListener('mousedown', handlePointerDown, true);\n doc.removeEventListener('pointerdown', handlePointerDown, true);\n doc.removeEventListener('touchstart', handlePointerDown, true);\n doc.removeEventListener('visibilitychange', handleVisibilityChange, true);\n}\nfunction isFocusVisible(event) {\n const {\n target\n } = event;\n try {\n return target.matches(':focus-visible');\n } catch (error) {\n // Browsers not implementing :focus-visible will throw a SyntaxError.\n // We use our own heuristic for those browsers.\n // Rethrow might be better if it's not the expected error but do we really\n // want to crash if focus-visible malfunctioned?\n }\n\n // No need for validFocusTarget check. The user does that by attaching it to\n // focusable events only.\n return hadKeyboardEvent || focusTriggersKeyboardModality(target);\n}\nexport default function useIsFocusVisible() {\n const ref = React.useCallback(node => {\n if (node != null) {\n prepare(node.ownerDocument);\n }\n }, []);\n const isFocusVisibleRef = React.useRef(false);\n\n /**\n * Should be called if a blur event is fired\n */\n function handleBlurVisible() {\n // checking against potential state variable does not suffice if we focus and blur synchronously.\n // React wouldn't have time to trigger a re-render so `focusVisible` would be stale.\n // Ideally we would adjust `isFocusVisible(event)` to look at `relatedTarget` for blur events.\n // This doesn't work in IE11 due to https://github.com/facebook/react/issues/3751\n // TODO: check again if React releases their internal changes to focus event handling (https://github.com/facebook/react/pull/19186).\n if (isFocusVisibleRef.current) {\n // To detect a tab/window switch, we look for a blur event followed\n // rapidly by a visibility change.\n // If we don't see a visibility change within 100ms, it's probably a\n // regular focus change.\n hadFocusVisibleRecently = true;\n window.clearTimeout(hadFocusVisibleRecentlyTimeout);\n hadFocusVisibleRecentlyTimeout = window.setTimeout(() => {\n hadFocusVisibleRecently = false;\n }, 100);\n isFocusVisibleRef.current = false;\n return true;\n }\n return false;\n }\n\n /**\n * Should be called if a blur event is fired\n */\n function handleFocusVisible(event) {\n if (isFocusVisible(event)) {\n isFocusVisibleRef.current = true;\n return true;\n }\n return false;\n }\n return {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref\n };\n}","// A change of the browser zoom change the scrollbar size.\n// Credit https://github.com/twbs/bootstrap/blob/488fd8afc535ca3a6ad4dc581f5e89217b6a36ac/js/src/util/scrollbar.js#L14-L18\nexport default function getScrollbarSize(doc) {\n // https://developer.mozilla.org/en-US/docs/Web/API/Window/innerWidth#usage_notes\n const documentWidth = doc.documentElement.clientWidth;\n return Math.abs(window.innerWidth - documentWidth);\n}","export default function composeClasses(slots, getUtilityClass, classes = undefined) {\n const output = {};\n Object.keys(slots).forEach(\n // `Object.keys(slots)` can't be wider than `T` because we infer `T` from `slots`.\n // @ts-expect-error https://github.com/microsoft/TypeScript/pull/12253#issuecomment-263132208\n slot => {\n output[slot] = slots[slot].reduce((acc, key) => {\n if (key) {\n const utilityClass = getUtilityClass(key);\n if (utilityClass !== '') {\n acc.push(utilityClass);\n }\n if (classes && classes[key]) {\n acc.push(classes[key]);\n }\n }\n return acc;\n }, []).join(' ');\n });\n return output;\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;","import ClassNameGenerator from '../ClassNameGenerator';\n\n// If GlobalStateSlot is changed, GLOBAL_STATE_CLASSES in\n// \\packages\\api-docs-builder\\utils\\parseSlotsAndClasses.ts must be updated accordingly.\nconst globalStateClassesMapping = {\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 = globalStateClassesMapping[slot];\n return globalStateClass ? `${globalStatePrefix}-${globalStateClass}` : `${ClassNameGenerator.generate(componentName)}-${slot}`;\n}","import generateUtilityClass from '../generateUtilityClass';\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}","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))for(t=0;t<e.length;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f);else for(t in e)e[t]&&(n&&(n+=\" \"),n+=t);return n}export function clsx(){for(var e,t,f=0,n=\"\";f<arguments.length;)(e=arguments[f++])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\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 */\nexport function 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}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport clsx from 'clsx';\nimport { extractEventHandlers } from './extractEventHandlers';\nimport { omitEventHandlers } from './omitEventHandlers';\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 */\nexport function 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 == null ? void 0 : additionalProps.className, className, externalForwardedProps == null ? void 0 : externalForwardedProps.className, externalSlotProps == null ? void 0 : externalSlotProps.className);\n const mergedStyle = _extends({}, additionalProps == null ? void 0 : additionalProps.style, externalForwardedProps == null ? void 0 : externalForwardedProps.style, externalSlotProps == null ? void 0 : externalSlotProps.style);\n const props = _extends({}, additionalProps, externalForwardedProps, externalSlotProps);\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(_extends({}, externalForwardedProps, externalSlotProps));\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 == null ? void 0 : internalSlotProps.className, additionalProps == null ? void 0 : additionalProps.className, className, externalForwardedProps == null ? void 0 : externalForwardedProps.className, externalSlotProps == null ? void 0 : externalSlotProps.className);\n const mergedStyle = _extends({}, internalSlotProps == null ? void 0 : internalSlotProps.style, additionalProps == null ? void 0 : additionalProps.style, externalForwardedProps == null ? void 0 : externalForwardedProps.style, externalSlotProps == null ? void 0 : externalSlotProps.style);\n const props = _extends({}, internalSlotProps, additionalProps, otherPropsWithoutEventHandlers, componentsPropsWithoutEventHandlers);\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}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"elementType\", \"externalSlotProps\", \"ownerState\", \"skipResolvingSlotProps\"];\nimport { unstable_useForkRef as useForkRef } from '@mui/utils';\nimport { appendOwnerState } from './appendOwnerState';\nimport { mergeSlotProps } from './mergeSlotProps';\nimport { resolveComponentProps } from './resolveComponentProps';\n/**\n * @ignore - do not document.\n * Builds the props to be passed into the slot of an unstyled component.\n * It merges the internal props of the component with the ones supplied by the user, allowing to customize the behavior.\n * If the slot component is not a host component, it also merges in the `ownerState`.\n *\n * @param parameters.getSlotProps - A function that returns the props to be passed to the slot component.\n */\nexport function useSlotProps(parameters) {\n var _parameters$additiona;\n const {\n elementType,\n externalSlotProps,\n ownerState,\n skipResolvingSlotProps = false\n } = parameters,\n rest = _objectWithoutPropertiesLoose(parameters, _excluded);\n const resolvedComponentsProps = skipResolvingSlotProps ? {} : resolveComponentProps(externalSlotProps, ownerState);\n const {\n props: mergedProps,\n internalRef\n } = mergeSlotProps(_extends({}, rest, {\n externalSlotProps: resolvedComponentsProps\n }));\n const ref = useForkRef(internalRef, resolvedComponentsProps == null ? void 0 : resolvedComponentsProps.ref, (_parameters$additiona = parameters.additionalProps) == null ? void 0 : _parameters$additiona.ref);\n const props = appendOwnerState(elementType, _extends({}, mergedProps, {\n ref\n }), ownerState);\n return props;\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"ownerState\"];\nimport * as React from 'react';\nexport function prepareForSlot(Component) {\n return /*#__PURE__*/React.forwardRef(function Slot(props, ref) {\n const other = _objectWithoutPropertiesLoose(props, _excluded);\n return /*#__PURE__*/React.createElement(Component, _extends({}, other, {\n ref\n }));\n });\n}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport { unstable_useForkRef as useForkRef, unstable_useIsFocusVisible as useIsFocusVisible } from '@mui/utils';\nimport { extractEventHandlers } from '../utils/extractEventHandlers';\n/**\n *\n * Demos:\n *\n * - [Button](https://mui.com/base-ui/react-button/#hook)\n *\n * API:\n *\n * - [useButton API](https://mui.com/base-ui/react-button/hooks-api/#use-button)\n */\nexport function useButton(parameters = {}) {\n const {\n disabled = false,\n focusableWhenDisabled,\n href,\n rootRef: externalRef,\n tabIndex,\n to,\n type\n } = parameters;\n const buttonRef = React.useRef();\n const [active, setActive] = React.useState(false);\n const {\n isFocusVisibleRef,\n onFocus: handleFocusVisible,\n onBlur: handleBlurVisible,\n ref: focusVisibleRef\n } = useIsFocusVisible();\n const [focusVisible, setFocusVisible] = React.useState(false);\n if (disabled && !focusableWhenDisabled && focusVisible) {\n setFocusVisible(false);\n }\n React.useEffect(() => {\n isFocusVisibleRef.current = focusVisible;\n }, [focusVisible, isFocusVisibleRef]);\n const [hostElementName, setHostElementName] = React.useState('');\n const createHandleMouseLeave = otherHandlers => event => {\n var _otherHandlers$onMous;\n if (focusVisible) {\n event.preventDefault();\n }\n (_otherHandlers$onMous = otherHandlers.onMouseLeave) == null || _otherHandlers$onMous.call(otherHandlers, event);\n };\n const createHandleBlur = otherHandlers => event => {\n var _otherHandlers$onBlur;\n handleBlurVisible(event);\n if (isFocusVisibleRef.current === false) {\n setFocusVisible(false);\n }\n (_otherHandlers$onBlur = otherHandlers.onBlur) == null || _otherHandlers$onBlur.call(otherHandlers, event);\n };\n const createHandleFocus = otherHandlers => event => {\n var _otherHandlers$onFocu2;\n // Fix for https://github.com/facebook/react/issues/7769\n if (!buttonRef.current) {\n buttonRef.current = event.currentTarget;\n }\n handleFocusVisible(event);\n if (isFocusVisibleRef.current === true) {\n var _otherHandlers$onFocu;\n setFocusVisible(true);\n (_otherHandlers$onFocu = otherHandlers.onFocusVisible) == null || _otherHandlers$onFocu.call(otherHandlers, event);\n }\n (_otherHandlers$onFocu2 = otherHandlers.onFocus) == null || _otherHandlers$onFocu2.call(otherHandlers, event);\n };\n const isNativeButton = () => {\n const button = buttonRef.current;\n return hostElementName === 'BUTTON' || hostElementName === 'INPUT' && ['button', 'submit', 'reset'].includes(button == null ? void 0 : button.type) || hostElementName === 'A' && (button == null ? void 0 : button.href);\n };\n const createHandleClick = otherHandlers => event => {\n if (!disabled) {\n var _otherHandlers$onClic;\n (_otherHandlers$onClic = otherHandlers.onClick) == null || _otherHandlers$onClic.call(otherHandlers, event);\n }\n };\n const createHandleMouseDown = otherHandlers => event => {\n var _otherHandlers$onMous2;\n if (!disabled) {\n setActive(true);\n document.addEventListener('mouseup', () => {\n setActive(false);\n }, {\n once: true\n });\n }\n (_otherHandlers$onMous2 = otherHandlers.onMouseDown) == null || _otherHandlers$onMous2.call(otherHandlers, event);\n };\n const createHandleKeyDown = otherHandlers => event => {\n var _otherHandlers$onKeyD;\n (_otherHandlers$onKeyD = otherHandlers.onKeyDown) == null || _otherHandlers$onKeyD.call(otherHandlers, event);\n if (event.defaultMuiPrevented) {\n return;\n }\n if (event.target === event.currentTarget && !isNativeButton() && event.key === ' ') {\n event.preventDefault();\n }\n if (event.target === event.currentTarget && event.key === ' ' && !disabled) {\n setActive(true);\n }\n\n // Keyboard accessibility for non interactive elements\n if (event.target === event.currentTarget && !isNativeButton() && event.key === 'Enter' && !disabled) {\n var _otherHandlers$onClic2;\n (_otherHandlers$onClic2 = otherHandlers.onClick) == null || _otherHandlers$onClic2.call(otherHandlers, event);\n event.preventDefault();\n }\n };\n const createHandleKeyUp = otherHandlers => event => {\n var _otherHandlers$onKeyU;\n // calling preventDefault in keyUp on a <button> will not dispatch a click event if Space is pressed\n // https://codesandbox.io/s/button-keyup-preventdefault-dn7f0\n\n if (event.target === event.currentTarget) {\n setActive(false);\n }\n (_otherHandlers$onKeyU = otherHandlers.onKeyUp) == null || _otherHandlers$onKeyU.call(otherHandlers, event);\n\n // Keyboard accessibility for non interactive elements\n if (event.target === event.currentTarget && !isNativeButton() && !disabled && event.key === ' ' && !event.defaultMuiPrevented) {\n var _otherHandlers$onClic3;\n (_otherHandlers$onClic3 = otherHandlers.onClick) == null || _otherHandlers$onClic3.call(otherHandlers, event);\n }\n };\n const updateHostElementName = React.useCallback(instance => {\n var _instance$tagName;\n setHostElementName((_instance$tagName = instance == null ? void 0 : instance.tagName) != null ? _instance$tagName : '');\n }, []);\n const handleRef = useForkRef(updateHostElementName, externalRef, focusVisibleRef, buttonRef);\n const buttonProps = {};\n if (tabIndex !== undefined) {\n buttonProps.tabIndex = tabIndex;\n }\n if (hostElementName === 'BUTTON') {\n buttonProps.type = type != null ? type : 'button';\n if (focusableWhenDisabled) {\n buttonProps['aria-disabled'] = disabled;\n } else {\n buttonProps.disabled = disabled;\n }\n } else if (hostElementName !== '') {\n if (!href && !to) {\n buttonProps.role = 'button';\n buttonProps.tabIndex = tabIndex != null ? tabIndex : 0;\n }\n if (disabled) {\n buttonProps['aria-disabled'] = disabled;\n buttonProps.tabIndex = focusableWhenDisabled ? tabIndex != null ? tabIndex : 0 : -1;\n }\n }\n const getRootProps = (externalProps = {}) => {\n const externalEventHandlers = _extends({}, extractEventHandlers(parameters), extractEventHandlers(externalProps));\n const props = _extends({\n type\n }, externalEventHandlers, buttonProps, externalProps, {\n onBlur: createHandleBlur(externalEventHandlers),\n onClick: createHandleClick(externalEventHandlers),\n onFocus: createHandleFocus(externalEventHandlers),\n onKeyDown: createHandleKeyDown(externalEventHandlers),\n onKeyUp: createHandleKeyUp(externalEventHandlers),\n onMouseDown: createHandleMouseDown(externalEventHandlers),\n onMouseLeave: createHandleMouseLeave(externalEventHandlers),\n ref: handleRef\n });\n\n // onFocusVisible can be present on the props or parameters,\n // but it's not a valid React event handler so it must not be forwarded to the inner component.\n // If present, it will be handled by the focus handler.\n delete props.onFocusVisible;\n return props;\n };\n return {\n getRootProps,\n focusVisible,\n setFocusVisible,\n active,\n rootRef: handleRef\n };\n}","'use client';\n\n/* eslint-disable consistent-return, jsx-a11y/no-noninteractive-tabindex */\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { exactProp, elementAcceptingRef, unstable_useForkRef as useForkRef, unstable_ownerDocument as ownerDocument } from '@mui/utils';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\n// Inspired by https://github.com/focus-trap/tabbable\nconst candidatesSelector = ['input', 'select', 'textarea', 'a[href]', 'button', '[tabindex]', 'audio[controls]', 'video[controls]', '[contenteditable]:not([contenteditable=\"false\"])'].join(',');\nfunction getTabIndex(node) {\n const tabindexAttr = parseInt(node.getAttribute('tabindex') || '', 10);\n if (!Number.isNaN(tabindexAttr)) {\n return tabindexAttr;\n }\n\n // Browsers do not return `tabIndex` correctly for contentEditable nodes;\n // https://bugs.chromium.org/p/chromium/issues/detail?id=661108&q=contenteditable%20tabindex&can=2\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n if (node.contentEditable === 'true' || (node.nodeName === 'AUDIO' || node.nodeName === 'VIDEO' || node.nodeName === 'DETAILS') && node.getAttribute('tabindex') === null) {\n return 0;\n }\n return node.tabIndex;\n}\nfunction isNonTabbableRadio(node) {\n if (node.tagName !== 'INPUT' || node.type !== 'radio') {\n return false;\n }\n if (!node.name) {\n return false;\n }\n const getRadio = selector => node.ownerDocument.querySelector(`input[type=\"radio\"]${selector}`);\n let roving = getRadio(`[name=\"${node.name}\"]:checked`);\n if (!roving) {\n roving = getRadio(`[name=\"${node.name}\"]`);\n }\n return roving !== node;\n}\nfunction isNodeMatchingSelectorFocusable(node) {\n if (node.disabled || node.tagName === 'INPUT' && node.type === 'hidden' || isNonTabbableRadio(node)) {\n return false;\n }\n return true;\n}\nfunction defaultGetTabbable(root) {\n const regularTabNodes = [];\n const orderedTabNodes = [];\n Array.from(root.querySelectorAll(candidatesSelector)).forEach((node, i) => {\n const nodeTabIndex = getTabIndex(node);\n if (nodeTabIndex === -1 || !isNodeMatchingSelectorFocusable(node)) {\n return;\n }\n if (nodeTabIndex === 0) {\n regularTabNodes.push(node);\n } else {\n orderedTabNodes.push({\n documentOrder: i,\n tabIndex: nodeTabIndex,\n node: node\n });\n }\n });\n return orderedTabNodes.sort((a, b) => a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex).map(a => a.node).concat(regularTabNodes);\n}\nfunction defaultIsEnabled() {\n return true;\n}\n\n/**\n * Utility component that locks focus inside the component.\n *\n * Demos:\n *\n * - [Focus Trap](https://mui.com/base-ui/react-focus-trap/)\n *\n * API:\n *\n * - [FocusTrap API](https://mui.com/base-ui/react-focus-trap/components-api/#focus-trap)\n */\nfunction FocusTrap(props) {\n const {\n children,\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableRestoreFocus = false,\n getTabbable = defaultGetTabbable,\n isEnabled = defaultIsEnabled,\n open\n } = props;\n const ignoreNextEnforceFocus = React.useRef(false);\n const sentinelStart = React.useRef(null);\n const sentinelEnd = React.useRef(null);\n const nodeToRestore = React.useRef(null);\n const reactFocusEventTarget = React.useRef(null);\n // This variable is useful when disableAutoFocus is true.\n // It waits for the active element to move into the component to activate.\n const activated = React.useRef(false);\n const rootRef = React.useRef(null);\n // @ts-expect-error TODO upstream fix\n const handleRef = useForkRef(children.ref, rootRef);\n const lastKeydown = React.useRef(null);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n activated.current = !disableAutoFocus;\n }, [disableAutoFocus, open]);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n const doc = ownerDocument(rootRef.current);\n if (!rootRef.current.contains(doc.activeElement)) {\n if (!rootRef.current.hasAttribute('tabIndex')) {\n if (process.env.NODE_ENV !== 'production') {\n console.error(['MUI: The modal content node does not accept focus.', 'For the benefit of assistive technologies, ' + 'the tabIndex of the node is being set to \"-1\".'].join('\\n'));\n }\n rootRef.current.setAttribute('tabIndex', '-1');\n }\n if (activated.current) {\n rootRef.current.focus();\n }\n }\n return () => {\n // restoreLastFocus()\n if (!disableRestoreFocus) {\n // In IE11 it is possible for document.activeElement to be null resulting\n // in nodeToRestore.current being null.\n // Not all elements in IE11 have a focus method.\n // Once IE11 support is dropped the focus() call can be unconditional.\n if (nodeToRestore.current && nodeToRestore.current.focus) {\n ignoreNextEnforceFocus.current = true;\n nodeToRestore.current.focus();\n }\n nodeToRestore.current = null;\n }\n };\n // Missing `disableRestoreFocus` which is fine.\n // We don't support changing that prop on an open FocusTrap\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [open]);\n React.useEffect(() => {\n // We might render an empty child.\n if (!open || !rootRef.current) {\n return;\n }\n const doc = ownerDocument(rootRef.current);\n const loopFocus = nativeEvent => {\n lastKeydown.current = nativeEvent;\n if (disableEnforceFocus || !isEnabled() || nativeEvent.key !== 'Tab') {\n return;\n }\n\n // Make sure the next tab starts from the right place.\n // doc.activeElement refers to the origin.\n if (doc.activeElement === rootRef.current && nativeEvent.shiftKey) {\n // We need to ignore the next contain as\n // it will try to move the focus back to the rootRef element.\n ignoreNextEnforceFocus.current = true;\n if (sentinelEnd.current) {\n sentinelEnd.current.focus();\n }\n }\n };\n const contain = () => {\n const rootElement = rootRef.current;\n\n // Cleanup functions are executed lazily in React 17.\n // Contain can be called between the component being unmounted and its cleanup function being run.\n if (rootElement === null) {\n return;\n }\n if (!doc.hasFocus() || !isEnabled() || ignoreNextEnforceFocus.current) {\n ignoreNextEnforceFocus.current = false;\n return;\n }\n\n // The focus is already inside\n if (rootElement.contains(doc.activeElement)) {\n return;\n }\n\n // The disableEnforceFocus is set and the focus is outside of the focus trap (and sentinel nodes)\n if (disableEnforceFocus && doc.activeElement !== sentinelStart.current && doc.activeElement !== sentinelEnd.current) {\n return;\n }\n\n // if the focus event is not coming from inside the children's react tree, reset the refs\n if (doc.activeElement !== reactFocusEventTarget.current) {\n reactFocusEventTarget.current = null;\n } else if (reactFocusEventTarget.current !== null) {\n return;\n }\n if (!activated.current) {\n return;\n }\n let tabbable = [];\n if (doc.activeElement === sentinelStart.current || doc.activeElement === sentinelEnd.current) {\n tabbable = getTabbable(rootRef.current);\n }\n\n // one of the sentinel nodes was focused, so move the focus\n // to the first/last tabbable element inside the focus trap\n if (tabbable.length > 0) {\n var _lastKeydown$current, _lastKeydown$current2;\n const isShiftTab = Boolean(((_lastKeydown$current = lastKeydown.current) == null ? void 0 : _lastKeydown$current.shiftKey) && ((_lastKeydown$current2 = lastKeydown.current) == null ? void 0 : _lastKeydown$current2.key) === 'Tab');\n const focusNext = tabbable[0];\n const focusPrevious = tabbable[tabbable.length - 1];\n if (typeof focusNext !== 'string' && typeof focusPrevious !== 'string') {\n if (isShiftTab) {\n focusPrevious.focus();\n } else {\n focusNext.focus();\n }\n }\n // no tabbable elements in the trap focus or the focus was outside of the focus trap\n } else {\n rootElement.focus();\n }\n };\n doc.addEventListener('focusin', contain);\n doc.addEventListener('keydown', loopFocus, true);\n\n // With Edge, Safari and Firefox, no focus related events are fired when the focused area stops being a focused area.\n // e.g. https://bugzilla.mozilla.org/show_bug.cgi?id=559561.\n // Instead, we can look if the active element was restored on the BODY element.\n //\n // The whatwg spec defines how the browser should behave but does not explicitly mention any events:\n // https://html.spec.whatwg.org/multipage/interaction.html#focus-fixup-rule.\n const interval = setInterval(() => {\n if (doc.activeElement && doc.activeElement.tagName === 'BODY') {\n contain();\n }\n }, 50);\n return () => {\n clearInterval(interval);\n doc.removeEventListener('focusin', contain);\n doc.removeEventListener('keydown', loopFocus, true);\n };\n }, [disableAutoFocus, disableEnforceFocus, disableRestoreFocus, isEnabled, open, getTabbable]);\n const onFocus = event => {\n if (nodeToRestore.current === null) {\n nodeToRestore.current = event.relatedTarget;\n }\n activated.current = true;\n reactFocusEventTarget.current = event.target;\n const childrenPropsHandler = children.props.onFocus;\n if (childrenPropsHandler) {\n childrenPropsHandler(event);\n }\n };\n const handleFocusSentinel = event => {\n if (nodeToRestore.current === null) {\n nodeToRestore.current = event.relatedTarget;\n }\n activated.current = true;\n };\n return /*#__PURE__*/_jsxs(React.Fragment, {\n children: [/*#__PURE__*/_jsx(\"div\", {\n tabIndex: open ? 0 : -1,\n onFocus: handleFocusSentinel,\n ref: sentinelStart,\n \"data-testid\": \"sentinelStart\"\n }), /*#__PURE__*/React.cloneElement(children, {\n ref: handleRef,\n onFocus\n }), /*#__PURE__*/_jsx(\"div\", {\n tabIndex: open ? 0 : -1,\n onFocus: handleFocusSentinel,\n ref: sentinelEnd,\n \"data-testid\": \"sentinelEnd\"\n })]\n });\n}\nprocess.env.NODE_ENV !== \"production\" ? FocusTrap.propTypes /* remove-proptypes */ = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit TypeScript types and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n /**\n * A single child content element.\n */\n children: elementAcceptingRef,\n /**\n * If `true`, the focus trap will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any focus trap children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the focus trap less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableAutoFocus: PropTypes.bool,\n /**\n * If `true`, the focus trap will not prevent focus from leaving the focus trap while open.\n *\n * Generally this should never be set to `true` as it makes the focus trap less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableEnforceFocus: PropTypes.bool,\n /**\n * If `true`, the focus trap will not restore focus to previously focused element once\n * focus trap is hidden or unmounted.\n * @default false\n */\n disableRestoreFocus: PropTypes.bool,\n /**\n * Returns an array of ordered tabbable nodes (i.e. in tab order) within the root.\n * For instance, you can provide the \"tabbable\" npm dependency.\n * @param {HTMLElement} root\n */\n getTabbable: PropTypes.func,\n /**\n * This prop extends the `open` prop.\n * It allows to toggle the open state without having to wait for a rerender when changing the `open` prop.\n * This prop should be memoized.\n * It can be used to support multiple focus trap mounted at the same time.\n * @default function defaultIsEnabled(): boolean {\n * return true;\n * }\n */\n isEnabled: PropTypes.func,\n /**\n * If `true`, focus is locked.\n */\n open: PropTypes.bool.isRequired\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n FocusTrap['propTypes' + ''] = exactProp(FocusTrap.propTypes);\n}\nexport { FocusTrap };","import * as React from 'react';\n/**\n * @ignore - internal component.\n */\nconst FormControlContext = /*#__PURE__*/React.createContext(undefined);\nif (process.env.NODE_ENV !== 'production') {\n FormControlContext.displayName = 'FormControlContext';\n}\nexport { FormControlContext };","'use client';\n\nimport * as React from 'react';\nimport { FormControlContext } from './FormControlContext';\n/**\n *\n * Demos:\n *\n * - [Form Control](https://mui.com/base-ui/react-form-control/#hook)\n *\n * API:\n *\n * - [useFormControlContext API](https://mui.com/base-ui/react-form-control/hooks-api/#use-form-control-context)\n */\nexport function useFormControlContext() {\n return React.useContext(FormControlContext);\n}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport { formatMuiErrorMessage as _formatMuiErrorMessage } from \"@mui/utils\";\nimport * as React from 'react';\nimport { unstable_useForkRef as useForkRef } from '@mui/utils';\nimport { useFormControlContext } from '../FormControl';\nimport { extractEventHandlers } from '../utils/extractEventHandlers';\n/**\n *\n * Demos:\n *\n * - [Input](https://mui.com/base-ui/react-input/#hook)\n *\n * API:\n *\n * - [useInput API](https://mui.com/base-ui/react-input/hooks-api/#use-input)\n */\nexport function useInput(parameters = {}) {\n const {\n defaultValue: defaultValueProp,\n disabled: disabledProp = false,\n error: errorProp = false,\n onBlur,\n onChange,\n onFocus,\n required: requiredProp = false,\n value: valueProp,\n inputRef: inputRefProp\n } = parameters;\n const formControlContext = useFormControlContext();\n let defaultValue;\n let disabled;\n let error;\n let required;\n let value;\n if (formControlContext) {\n var _formControlContext$d, _formControlContext$e, _formControlContext$r;\n defaultValue = undefined;\n disabled = (_formControlContext$d = formControlContext.disabled) != null ? _formControlContext$d : false;\n error = (_formControlContext$e = formControlContext.error) != null ? _formControlContext$e : false;\n required = (_formControlContext$r = formControlContext.required) != null ? _formControlContext$r : false;\n value = formControlContext.value;\n if (process.env.NODE_ENV !== 'production') {\n const definedLocalProps = ['defaultValue', 'disabled', 'error', 'required', 'value'].filter(prop => parameters[prop] !== undefined);\n if (definedLocalProps.length > 0) {\n console.warn(['MUI: You have set props on an input that is inside a FormControl.', 'Set these props on a FormControl instead. Otherwise they will be ignored.', `Ignored props: ${definedLocalProps.join(', ')}`].join('\\n'));\n }\n }\n } else {\n defaultValue = defaultValueProp;\n disabled = disabledProp;\n error = errorProp;\n required = requiredProp;\n value = valueProp;\n }\n const {\n current: isControlled\n } = React.useRef(value != null);\n const handleInputRefWarning = React.useCallback(instance => {\n if (process.env.NODE_ENV !== 'production') {\n if (instance && instance.nodeName !== 'INPUT' && !instance.focus) {\n console.error(['MUI: You have provided a `slots.input` to the input component', 'that does not correctly handle the `ref` prop.', 'Make sure the `ref` prop is called with a HTMLInputElement.'].join('\\n'));\n }\n }\n }, []);\n const inputRef = React.useRef(null);\n const handleInputRef = useForkRef(inputRef, inputRefProp, handleInputRefWarning);\n const [focused, setFocused] = React.useState(false);\n\n // The blur won't fire when the disabled state is set on a focused input.\n // We need to book keep the focused state manually.\n React.useEffect(() => {\n if (!formControlContext && disabled && focused) {\n setFocused(false);\n\n // @ts-ignore\n onBlur == null || onBlur();\n }\n }, [formControlContext, disabled, focused, onBlur]);\n const handleFocus = otherHandlers => event => {\n var _otherHandlers$onFocu;\n // Fix a bug with IE11 where the focus/blur events are triggered\n // while the component is disabled.\n if (formControlContext != null && formControlContext.disabled) {\n event.stopPropagation();\n return;\n }\n (_otherHandlers$onFocu = otherHandlers.onFocus) == null || _otherHandlers$onFocu.call(otherHandlers, event);\n if (formControlContext && formControlContext.onFocus) {\n var _formControlContext$o;\n formControlContext == null || (_formControlContext$o = formControlContext.onFocus) == null || _formControlContext$o.call(formControlContext);\n } else {\n setFocused(true);\n }\n };\n const handleBlur = otherHandlers => event => {\n var _otherHandlers$onBlur;\n (_otherHandlers$onBlur = otherHandlers.onBlur) == null || _otherHandlers$onBlur.call(otherHandlers, event);\n if (formControlContext && formControlContext.onBlur) {\n formControlContext.onBlur();\n } else {\n setFocused(false);\n }\n };\n const handleChange = otherHandlers => (event, ...args) => {\n var _formControlContext$o2, _otherHandlers$onChan;\n if (!isControlled) {\n const element = event.target || inputRef.current;\n if (element == null) {\n throw new Error(process.env.NODE_ENV !== \"production\" ? `MUI: Expected valid input target. Did you use a custom \\`slots.input\\` and forget to forward refs? See https://mui.com/r/input-component-ref-interface for more info.` : _formatMuiErrorMessage(17));\n }\n }\n formControlContext == null || (_formControlContext$o2 = formControlContext.onChange) == null || _formControlContext$o2.call(formControlContext, event);\n\n // @ts-ignore\n (_otherHandlers$onChan = otherHandlers.onChange) == null || _otherHandlers$onChan.call(otherHandlers, event, ...args);\n };\n const handleClick = otherHandlers => event => {\n var _otherHandlers$onClic;\n if (inputRef.current && event.currentTarget === event.target) {\n inputRef.current.focus();\n }\n (_otherHandlers$onClic = otherHandlers.onClick) == null || _otherHandlers$onClic.call(otherHandlers, event);\n };\n const getRootProps = (externalProps = {}) => {\n // onBlur, onChange and onFocus are forwarded to the input slot.\n const propsEventHandlers = extractEventHandlers(parameters, ['onBlur', 'onChange', 'onFocus']);\n const externalEventHandlers = _extends({}, propsEventHandlers, extractEventHandlers(externalProps));\n return _extends({}, externalProps, externalEventHandlers, {\n onClick: handleClick(externalEventHandlers)\n });\n };\n const getInputProps = (externalProps = {}) => {\n const propsEventHandlers = {\n onBlur,\n onChange,\n onFocus\n };\n const externalEventHandlers = _extends({}, propsEventHandlers, extractEventHandlers(externalProps));\n const mergedEventHandlers = _extends({}, externalEventHandlers, {\n onBlur: handleBlur(externalEventHandlers),\n onChange: handleChange(externalEventHandlers),\n onFocus: handleFocus(externalEventHandlers)\n });\n return _extends({}, mergedEventHandlers, {\n 'aria-invalid': error || undefined,\n defaultValue: defaultValue,\n value: value,\n required,\n disabled\n }, externalProps, {\n ref: handleInputRef\n }, mergedEventHandlers);\n };\n return {\n disabled,\n error,\n focused,\n formControlContext,\n getInputProps,\n getRootProps,\n inputRef: handleInputRef,\n required,\n value\n };\n}","'use client';\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport PropTypes from 'prop-types';\nimport { exactProp, HTMLElementType, unstable_useEnhancedEffect as useEnhancedEffect, unstable_useForkRef as useForkRef, unstable_setRef as setRef } from '@mui/utils';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nfunction getContainer(container) {\n return typeof container === 'function' ? container() : container;\n}\n\n/**\n * Portals provide a first-class way to render children into a DOM node\n * that exists outside the DOM hierarchy of the parent component.\n *\n * Demos:\n *\n * - [Portal](https://mui.com/base-ui/react-portal/)\n *\n * API:\n *\n * - [Portal API](https://mui.com/base-ui/react-portal/components-api/#portal)\n */\nconst Portal = /*#__PURE__*/React.forwardRef(function Portal(props, forwardedRef) {\n const {\n children,\n container,\n disablePortal = false\n } = props;\n const [mountNode, setMountNode] = React.useState(null);\n // @ts-expect-error TODO upstream fix\n const handleRef = useForkRef( /*#__PURE__*/React.isValidElement(children) ? children.ref : null, forwardedRef);\n useEnhancedEffect(() => {\n if (!disablePortal) {\n setMountNode(getContainer(container) || document.body);\n }\n }, [container, disablePortal]);\n useEnhancedEffect(() => {\n if (mountNode && !disablePortal) {\n setRef(forwardedRef, mountNode);\n return () => {\n setRef(forwardedRef, null);\n };\n }\n return undefined;\n }, [forwardedRef, mountNode, disablePortal]);\n if (disablePortal) {\n if ( /*#__PURE__*/React.isValidElement(children)) {\n const newProps = {\n ref: handleRef\n };\n return /*#__PURE__*/React.cloneElement(children, newProps);\n }\n return /*#__PURE__*/_jsx(React.Fragment, {\n children: children\n });\n }\n return /*#__PURE__*/_jsx(React.Fragment, {\n children: mountNode ? /*#__PURE__*/ReactDOM.createPortal(children, mountNode) : mountNode\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Portal.propTypes /* remove-proptypes */ = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit TypeScript types and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n /**\n * The children to render into the `container`.\n */\n children: PropTypes.node,\n /**\n * An HTML element or function that returns one.\n * The `container` will have the portal children appended to it.\n *\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),\n /**\n * The `children` will be under the DOM hierarchy of the parent component.\n * @default false\n */\n disablePortal: PropTypes.bool\n} : void 0;\nif (process.env.NODE_ENV !== 'production') {\n // eslint-disable-next-line\n Portal['propTypes' + ''] = exactProp(Portal.propTypes);\n}\nexport { Portal };","import { unstable_ownerWindow as ownerWindow, unstable_ownerDocument as ownerDocument, unstable_getScrollbarSize as getScrollbarSize } from '@mui/utils';\n// Is a vertical scrollbar displayed?\nfunction isOverflowing(container) {\n const doc = ownerDocument(container);\n if (doc.body === container) {\n return ownerWindow(container).innerWidth > doc.documentElement.clientWidth;\n }\n return container.scrollHeight > container.clientHeight;\n}\nexport function ariaHidden(element, show) {\n if (show) {\n element.setAttribute('aria-hidden', 'true');\n } else {\n element.removeAttribute('aria-hidden');\n }\n}\nfunction getPaddingRight(element) {\n return parseInt(ownerWindow(element).getComputedStyle(element).paddingRight, 10) || 0;\n}\nfunction isAriaHiddenForbiddenOnElement(element) {\n // The forbidden HTML tags are the ones from ARIA specification that\n // can be children of body and can't have aria-hidden attribute.\n // cf. https://www.w3.org/TR/html-aria/#docconformance\n const forbiddenTagNames = ['TEMPLATE', 'SCRIPT', 'STYLE', 'LINK', 'MAP', 'META', 'NOSCRIPT', 'PICTURE', 'COL', 'COLGROUP', 'PARAM', 'SLOT', 'SOURCE', 'TRACK'];\n const isForbiddenTagName = forbiddenTagNames.indexOf(element.tagName) !== -1;\n const isInputHidden = element.tagName === 'INPUT' && element.getAttribute('type') === 'hidden';\n return isForbiddenTagName || isInputHidden;\n}\nfunction ariaHiddenSiblings(container, mountElement, currentElement, elementsToExclude, show) {\n const blacklist = [mountElement, currentElement, ...elementsToExclude];\n [].forEach.call(container.children, element => {\n const isNotExcludedElement = blacklist.indexOf(element) === -1;\n const isNotForbiddenElement = !isAriaHiddenForbiddenOnElement(element);\n if (isNotExcludedElement && isNotForbiddenElement) {\n ariaHidden(element, show);\n }\n });\n}\nfunction findIndexOf(items, callback) {\n let idx = -1;\n items.some((item, index) => {\n if (callback(item)) {\n idx = index;\n return true;\n }\n return false;\n });\n return idx;\n}\nfunction handleContainer(containerInfo, props) {\n const restoreStyle = [];\n const container = containerInfo.container;\n if (!props.disableScrollLock) {\n if (isOverflowing(container)) {\n // Compute the size before applying overflow hidden to avoid any scroll jumps.\n const scrollbarSize = getScrollbarSize(ownerDocument(container));\n restoreStyle.push({\n value: container.style.paddingRight,\n property: 'padding-right',\n el: container\n });\n // Use computed style, here to get the real padding to add our scrollbar width.\n container.style.paddingRight = `${getPaddingRight(container) + scrollbarSize}px`;\n\n // .mui-fixed is a global helper.\n const fixedElements = ownerDocument(container).querySelectorAll('.mui-fixed');\n [].forEach.call(fixedElements, element => {\n restoreStyle.push({\n value: element.style.paddingRight,\n property: 'padding-right',\n el: element\n });\n element.style.paddingRight = `${getPaddingRight(element) + scrollbarSize}px`;\n });\n }\n let scrollContainer;\n if (container.parentNode instanceof DocumentFragment) {\n scrollContainer = ownerDocument(container).body;\n } else {\n // Support html overflow-y: auto for scroll stability between pages\n // https://css-tricks.com/snippets/css/force-vertical-scrollbar/\n const parent = container.parentElement;\n const containerWindow = ownerWindow(container);\n scrollContainer = (parent == null ? void 0 : parent.nodeName) === 'HTML' && containerWindow.getComputedStyle(parent).overflowY === 'scroll' ? parent : container;\n }\n\n // Block the scroll even if no scrollbar is visible to account for mobile keyboard\n // screensize shrink.\n restoreStyle.push({\n value: scrollContainer.style.overflow,\n property: 'overflow',\n el: scrollContainer\n }, {\n value: scrollContainer.style.overflowX,\n property: 'overflow-x',\n el: scrollContainer\n }, {\n value: scrollContainer.style.overflowY,\n property: 'overflow-y',\n el: scrollContainer\n });\n scrollContainer.style.overflow = 'hidden';\n }\n const restore = () => {\n restoreStyle.forEach(({\n value,\n el,\n property\n }) => {\n if (value) {\n el.style.setProperty(property, value);\n } else {\n el.style.removeProperty(property);\n }\n });\n };\n return restore;\n}\nfunction getHiddenSiblings(container) {\n const hiddenSiblings = [];\n [].forEach.call(container.children, element => {\n if (element.getAttribute('aria-hidden') === 'true') {\n hiddenSiblings.push(element);\n }\n });\n return hiddenSiblings;\n}\n/**\n * @ignore - do not document.\n *\n * Proper state management for containers and the modals in those containers.\n * Simplified, but inspired by react-overlay's ModalManager class.\n * Used by the Modal to ensure proper styling of containers.\n */\nexport class ModalManager {\n constructor() {\n this.containers = void 0;\n this.modals = void 0;\n this.modals = [];\n this.containers = [];\n }\n add(modal, container) {\n let modalIndex = this.modals.indexOf(modal);\n if (modalIndex !== -1) {\n return modalIndex;\n }\n modalIndex = this.modals.length;\n this.modals.push(modal);\n\n // If the modal we are adding is already in the DOM.\n if (modal.modalRef) {\n ariaHidden(modal.modalRef, false);\n }\n const hiddenSiblings = getHiddenSiblings(container);\n ariaHiddenSiblings(container, modal.mount, modal.modalRef, hiddenSiblings, true);\n const containerIndex = findIndexOf(this.containers, item => item.container === container);\n if (containerIndex !== -1) {\n this.containers[containerIndex].modals.push(modal);\n return modalIndex;\n }\n this.containers.push({\n modals: [modal],\n container,\n restore: null,\n hiddenSiblings\n });\n return modalIndex;\n }\n mount(modal, props) {\n const containerIndex = findIndexOf(this.containers, item => item.modals.indexOf(modal) !== -1);\n const containerInfo = this.containers[containerIndex];\n if (!containerInfo.restore) {\n containerInfo.restore = handleContainer(containerInfo, props);\n }\n }\n remove(modal, ariaHiddenState = true) {\n const modalIndex = this.modals.indexOf(modal);\n if (modalIndex === -1) {\n return modalIndex;\n }\n const containerIndex = findIndexOf(this.containers, item => item.modals.indexOf(modal) !== -1);\n const containerInfo = this.containers[containerIndex];\n containerInfo.modals.splice(containerInfo.modals.indexOf(modal), 1);\n this.modals.splice(modalIndex, 1);\n\n // If that was the last modal in a container, clean up the container.\n if (containerInfo.modals.length === 0) {\n // The modal might be closed before it had the chance to be mounted in the DOM.\n if (containerInfo.restore) {\n containerInfo.restore();\n }\n if (modal.modalRef) {\n // In case the modal wasn't in the DOM yet.\n ariaHidden(modal.modalRef, ariaHiddenState);\n }\n ariaHiddenSiblings(containerInfo.container, modal.mount, modal.modalRef, containerInfo.hiddenSiblings, false);\n this.containers.splice(containerIndex, 1);\n } else {\n // Otherwise make sure the next top modal is visible to a screen reader.\n const nextTop = containerInfo.modals[containerInfo.modals.length - 1];\n // as soon as a modal is adding its modalRef is undefined. it can't set\n // aria-hidden because the dom element doesn't exist either\n // when modal was unmounted before modalRef gets null\n if (nextTop.modalRef) {\n ariaHidden(nextTop.modalRef, false);\n }\n }\n return modalIndex;\n }\n isTopModal(modal) {\n return this.modals.length > 0 && this.modals[this.modals.length - 1] === modal;\n }\n}","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport { unstable_ownerDocument as ownerDocument, unstable_useForkRef as useForkRef, unstable_useEventCallback as useEventCallback, unstable_createChainedFunction as createChainedFunction } from '@mui/utils';\nimport { extractEventHandlers } from '../utils';\nimport { ModalManager, ariaHidden } from './ModalManager';\nfunction getContainer(container) {\n return typeof container === 'function' ? container() : container;\n}\nfunction getHasTransition(children) {\n return children ? children.props.hasOwnProperty('in') : false;\n}\n\n// A modal manager used to track and manage the state of open Modals.\n// Modals don't open on the server so this won't conflict with concurrent requests.\nconst defaultManager = new ModalManager();\n/**\n *\n * Demos:\n *\n * - [Modal](https://mui.com/base-ui/react-modal/#hook)\n *\n * API:\n *\n * - [useModal API](https://mui.com/base-ui/react-modal/hooks-api/#use-modal)\n */\nexport function useModal(parameters) {\n const {\n container,\n disableEscapeKeyDown = false,\n disableScrollLock = false,\n // @ts-ignore internal logic - Base UI supports the manager as a prop too\n manager = defaultManager,\n closeAfterTransition = false,\n onTransitionEnter,\n onTransitionExited,\n children,\n onClose,\n open,\n rootRef\n } = parameters;\n\n // @ts-ignore internal logic\n const modal = React.useRef({});\n const mountNodeRef = React.useRef(null);\n const modalRef = React.useRef(null);\n const handleRef = useForkRef(modalRef, rootRef);\n const [exited, setExited] = React.useState(!open);\n const hasTransition = getHasTransition(children);\n let ariaHiddenProp = true;\n if (parameters['aria-hidden'] === 'false' || parameters['aria-hidden'] === false) {\n ariaHiddenProp = false;\n }\n const getDoc = () => ownerDocument(mountNodeRef.current);\n const getModal = () => {\n modal.current.modalRef = modalRef.current;\n modal.current.mount = mountNodeRef.current;\n return modal.current;\n };\n const handleMounted = () => {\n manager.mount(getModal(), {\n disableScrollLock\n });\n\n // Fix a bug on Chrome where the scroll isn't initially 0.\n if (modalRef.current) {\n modalRef.current.scrollTop = 0;\n }\n };\n const handleOpen = useEventCallback(() => {\n const resolvedContainer = getContainer(container) || getDoc().body;\n manager.add(getModal(), resolvedContainer);\n\n // The element was already mounted.\n if (modalRef.current) {\n handleMounted();\n }\n });\n const isTopModal = React.useCallback(() => manager.isTopModal(getModal()), [manager]);\n const handlePortalRef = useEventCallback(node => {\n mountNodeRef.current = node;\n if (!node) {\n return;\n }\n if (open && isTopModal()) {\n handleMounted();\n } else if (modalRef.current) {\n ariaHidden(modalRef.current, ariaHiddenProp);\n }\n });\n const handleClose = React.useCallback(() => {\n manager.remove(getModal(), ariaHiddenProp);\n }, [ariaHiddenProp, manager]);\n React.useEffect(() => {\n return () => {\n handleClose();\n };\n }, [handleClose]);\n React.useEffect(() => {\n if (open) {\n handleOpen();\n } else if (!hasTransition || !closeAfterTransition) {\n handleClose();\n }\n }, [open, handleClose, hasTransition, closeAfterTransition, handleOpen]);\n const createHandleKeyDown = otherHandlers => event => {\n var _otherHandlers$onKeyD;\n (_otherHandlers$onKeyD = otherHandlers.onKeyDown) == null || _otherHandlers$onKeyD.call(otherHandlers, event);\n\n // The handler doesn't take event.defaultPrevented into account:\n //\n // event.preventDefault() is meant to stop default behaviors like\n // clicking a checkbox to check it, hitting a button to submit a form,\n // and hitting left arrow to move the cursor in a text input etc.\n // Only special HTML elements have these default behaviors.\n if (event.key !== 'Escape' || event.which === 229 ||\n // Wait until IME is settled.\n !isTopModal()) {\n return;\n }\n if (!disableEscapeKeyDown) {\n // Swallow the event, in case someone is listening for the escape key on the body.\n event.stopPropagation();\n if (onClose) {\n onClose(event, 'escapeKeyDown');\n }\n }\n };\n const createHandleBackdropClick = otherHandlers => event => {\n var _otherHandlers$onClic;\n (_otherHandlers$onClic = otherHandlers.onClick) == null || _otherHandlers$onClic.call(otherHandlers, event);\n if (event.target !== event.currentTarget) {\n return;\n }\n if (onClose) {\n onClose(event, 'backdropClick');\n }\n };\n const getRootProps = (otherHandlers = {}) => {\n const propsEventHandlers = extractEventHandlers(parameters);\n\n // The custom event handlers shouldn't be spread on the root element\n delete propsEventHandlers.onTransitionEnter;\n delete propsEventHandlers.onTransitionExited;\n const externalEventHandlers = _extends({}, propsEventHandlers, otherHandlers);\n return _extends({\n role: 'presentation'\n }, externalEventHandlers, {\n onKeyDown: createHandleKeyDown(externalEventHandlers),\n ref: handleRef\n });\n };\n const getBackdropProps = (otherHandlers = {}) => {\n const externalEventHandlers = otherHandlers;\n return _extends({\n 'aria-hidden': true\n }, externalEventHandlers, {\n onClick: createHandleBackdropClick(externalEventHandlers),\n open\n });\n };\n const getTransitionProps = () => {\n const handleEnter = () => {\n setExited(false);\n if (onTransitionEnter) {\n onTransitionEnter();\n }\n };\n const handleExited = () => {\n setExited(true);\n if (onTransitionExited) {\n onTransitionExited();\n }\n if (closeAfterTransition) {\n handleClose();\n }\n };\n return {\n onEnter: createChainedFunction(handleEnter, children == null ? void 0 : children.props.onEnter),\n onExited: createChainedFunction(handleExited, children == null ? void 0 : children.props.onExited)\n };\n };\n return {\n getRootProps,\n getBackdropProps,\n getTransitionProps,\n rootRef: handleRef,\n portalRef: handlePortalRef,\n isTopModal,\n exited,\n hasTransition\n };\n}","import { generateUtilityClasses } from '../generateUtilityClasses';\nimport { generateUtilityClass } from '../generateUtilityClass';\nexport function getModalUtilityClass(slot) {\n return generateUtilityClass('MuiModal', slot);\n}\nexport const modalClasses = generateUtilityClasses('MuiModal', ['root', 'hidden', 'backdrop']);","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"children\", \"closeAfterTransition\", \"container\", \"disableAutoFocus\", \"disableEnforceFocus\", \"disableEscapeKeyDown\", \"disablePortal\", \"disableRestoreFocus\", \"disableScrollLock\", \"hideBackdrop\", \"keepMounted\", \"onBackdropClick\", \"onClose\", \"onKeyDown\", \"open\", \"onTransitionEnter\", \"onTransitionExited\", \"slotProps\", \"slots\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { elementAcceptingRef, HTMLElementType } from '@mui/utils';\nimport { useSlotProps } from '../utils';\nimport { useClassNamesOverride } from '../utils/ClassNameConfigurator';\nimport { unstable_composeClasses as composeClasses } from '../composeClasses';\nimport { Portal } from '../Portal';\nimport { unstable_useModal as useModal } from '../unstable_useModal';\nimport { FocusTrap } from '../FocusTrap';\nimport { getModalUtilityClass } from './modalClasses';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst useUtilityClasses = ownerState => {\n const {\n open,\n exited\n } = ownerState;\n const slots = {\n root: ['root', !open && exited && 'hidden'],\n backdrop: ['backdrop']\n };\n return composeClasses(slots, useClassNamesOverride(getModalUtilityClass));\n};\n\n/**\n * Modal is a lower-level construct that is leveraged by the following components:\n *\n * * [Dialog](https://mui.com/material-ui/api/dialog/)\n * * [Drawer](https://mui.com/material-ui/api/drawer/)\n * * [Menu](https://mui.com/material-ui/api/menu/)\n * * [Popover](https://mui.com/material-ui/api/popover/)\n *\n * If you are creating a modal dialog, you probably want to use the [Dialog](https://mui.com/material-ui/api/dialog/) component\n * rather than directly using Modal.\n *\n * This component shares many concepts with [react-overlays](https://react-bootstrap.github.io/react-overlays/#modals).\n *\n * Demos:\n *\n * - [Modal](https://mui.com/base-ui/react-modal/)\n *\n * API:\n *\n * - [Modal API](https://mui.com/base-ui/react-modal/components-api/#modal)\n */\nconst Modal = /*#__PURE__*/React.forwardRef(function Modal(props, forwardedRef) {\n var _slots$root;\n const {\n children,\n closeAfterTransition = false,\n container,\n disableAutoFocus = false,\n disableEnforceFocus = false,\n disableEscapeKeyDown = false,\n disablePortal = false,\n disableRestoreFocus = false,\n disableScrollLock = false,\n hideBackdrop = false,\n keepMounted = false,\n onBackdropClick,\n open,\n slotProps = {},\n slots = {}\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const propsWithDefaults = _extends({}, props, {\n closeAfterTransition,\n disableAutoFocus,\n disableEnforceFocus,\n disableEscapeKeyDown,\n disablePortal,\n disableRestoreFocus,\n disableScrollLock,\n hideBackdrop,\n keepMounted\n });\n const {\n getRootProps,\n getBackdropProps,\n getTransitionProps,\n portalRef,\n isTopModal,\n exited,\n hasTransition\n } = useModal(_extends({}, propsWithDefaults, {\n rootRef: forwardedRef\n }));\n const ownerState = _extends({}, propsWithDefaults, {\n exited,\n hasTransition\n });\n const classes = useUtilityClasses(ownerState);\n const childProps = {};\n if (children.props.tabIndex === undefined) {\n childProps.tabIndex = '-1';\n }\n\n // It's a Transition like component\n if (hasTransition) {\n const {\n onEnter,\n onExited\n } = getTransitionProps();\n childProps.onEnter = onEnter;\n childProps.onExited = onExited;\n }\n const Root = (_slots$root = slots.root) != null ? _slots$root : 'div';\n const rootProps = useSlotProps({\n elementType: Root,\n externalSlotProps: slotProps.root,\n externalForwardedProps: other,\n getSlotProps: getRootProps,\n className: classes.root,\n ownerState\n });\n const BackdropComponent = slots.backdrop;\n const backdropProps = useSlotProps({\n elementType: BackdropComponent,\n externalSlotProps: slotProps.backdrop,\n getSlotProps: otherHandlers => {\n return getBackdropProps(_extends({}, otherHandlers, {\n onClick: e => {\n if (onBackdropClick) {\n onBackdropClick(e);\n }\n if (otherHandlers != null && otherHandlers.onClick) {\n otherHandlers.onClick(e);\n }\n }\n }));\n },\n className: classes.backdrop,\n ownerState\n });\n if (!keepMounted && !open && (!hasTransition || exited)) {\n return null;\n }\n return /*#__PURE__*/_jsx(Portal, {\n ref: portalRef,\n container: container,\n disablePortal: disablePortal,\n children: /*#__PURE__*/_jsxs(Root, _extends({}, rootProps, {\n children: [!hideBackdrop && BackdropComponent ? /*#__PURE__*/_jsx(BackdropComponent, _extends({}, backdropProps)) : null, /*#__PURE__*/_jsx(FocusTrap, {\n disableEnforceFocus: disableEnforceFocus,\n disableAutoFocus: disableAutoFocus,\n disableRestoreFocus: disableRestoreFocus,\n isEnabled: isTopModal,\n open: open,\n children: /*#__PURE__*/React.cloneElement(children, childProps)\n })]\n }))\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? Modal.propTypes /* remove-proptypes */ = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit TypeScript types and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n /**\n * A single child content element.\n */\n children: elementAcceptingRef.isRequired,\n /**\n * When set to true the Modal waits until a nested Transition is completed before closing.\n * @default false\n */\n closeAfterTransition: PropTypes.bool,\n /**\n * An HTML element or function that returns one.\n * The `container` will have the portal children appended to it.\n *\n * By default, it uses the body of the top-level document object,\n * so it's simply `document.body` most of the time.\n */\n container: PropTypes /* @typescript-to-proptypes-ignore */.oneOfType([HTMLElementType, PropTypes.func]),\n /**\n * If `true`, the modal will not automatically shift focus to itself when it opens, and\n * replace it to the last focused element when it closes.\n * This also works correctly with any modal children that have the `disableAutoFocus` prop.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableAutoFocus: PropTypes.bool,\n /**\n * If `true`, the modal will not prevent focus from leaving the modal while open.\n *\n * Generally this should never be set to `true` as it makes the modal less\n * accessible to assistive technologies, like screen readers.\n * @default false\n */\n disableEnforceFocus: PropTypes.bool,\n /**\n * If `true`, hitting escape will not fire the `onClose` callback.\n * @default false\n */\n disableEscapeKeyDown: PropTypes.bool,\n /**\n * The `children` will be under the DOM hierarchy of the parent component.\n * @default false\n */\n disablePortal: PropTypes.bool,\n /**\n * If `true`, the modal will not restore focus to previously focused element once\n * modal is hidden or unmounted.\n * @default false\n */\n disableRestoreFocus: PropTypes.bool,\n /**\n * Disable the scroll lock behavior.\n * @default false\n */\n disableScrollLock: PropTypes.bool,\n /**\n * If `true`, the backdrop is not rendered.\n * @default false\n */\n hideBackdrop: PropTypes.bool,\n /**\n * Always keep the children in the DOM.\n * This prop can be useful in SEO situation or\n * when you want to maximize the responsiveness of the Modal.\n * @default false\n */\n keepMounted: PropTypes.bool,\n /**\n * Callback fired when the backdrop is clicked.\n * @deprecated Use the `onClose` prop with the `reason` argument to handle the `backdropClick` events.\n */\n onBackdropClick: PropTypes.func,\n /**\n * Callback fired when the component requests to be closed.\n * The `reason` parameter can optionally be used to control the response to `onClose`.\n *\n * @param {object} event The event source of the callback.\n * @param {string} reason Can be: `\"escapeKeyDown\"`, `\"backdropClick\"`.\n */\n onClose: PropTypes.func,\n /**\n * A function called when a transition enters.\n */\n onTransitionEnter: PropTypes.func,\n /**\n * A function called when a transition has exited.\n */\n onTransitionExited: PropTypes.func,\n /**\n * If `true`, the component is shown.\n */\n open: PropTypes.bool.isRequired,\n /**\n * The props used for each slot inside the Modal.\n * @default {}\n */\n slotProps: PropTypes.shape({\n backdrop: PropTypes.oneOfType([PropTypes.func, PropTypes.object]),\n root: PropTypes.oneOfType([PropTypes.func, PropTypes.object])\n }),\n /**\n * The components used for each slot inside the Modal.\n * Either a string to use a HTML element or a component.\n * @default {}\n */\n slots: PropTypes.shape({\n backdrop: PropTypes.elementType,\n root: PropTypes.elementType\n })\n} : void 0;\nexport { Modal };","const sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n x: v,\n y: v\n});\nconst oppositeSideMap = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n start: 'end',\n end: 'start'\n};\nfunction clamp(start, value, end) {\n return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n const alignment = getAlignment(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const length = getAxisLength(alignmentAxis);\n let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n const lr = ['left', 'right'];\n const rl = ['right', 'left'];\n const tb = ['top', 'bottom'];\n const bt = ['bottom', 'top'];\n switch (side) {\n case 'top':\n case 'bottom':\n if (rtl) return isStart ? rl : lr;\n return isStart ? lr : rl;\n case 'left':\n case 'right':\n return isStart ? tb : bt;\n default:\n return [];\n }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n const alignment = getAlignment(placement);\n let list = getSideList(getSide(placement), direction === 'start', rtl);\n if (alignment) {\n list = list.map(side => side + \"-\" + alignment);\n if (flipAlignment) {\n list = list.concat(list.map(getOppositeAlignmentPlacement));\n }\n }\n return list;\n}\nfunction getOppositePlacement(placement) {\n return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\nfunction getPaddingObject(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\nfunction rectToClientRect(rect) {\n return {\n ...rect,\n top: rect.y,\n left: rect.x,\n right: rect.x + rect.width,\n bottom: rect.y + rect.height\n };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let {\n reference,\n floating\n } = _ref;\n const sideAxis = getSideAxis(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const alignLength = getAxisLength(alignmentAxis);\n const side = getSide(placement);\n const isVertical = sideAxis === 'y';\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n let coords;\n switch (side) {\n case 'top':\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n case 'bottom':\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n case 'right':\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n case 'left':\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n switch (getAlignment(placement)) {\n case 'start':\n coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n case 'end':\n coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\n return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a reference element when it is given a certain positioning strategy.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform\n } = config;\n const validMiddleware = middleware.filter(Boolean);\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n let rects = await platform.getElementRects({\n reference,\n floating,\n strategy\n });\n let {\n x,\n y\n } = computeCoordsFromPlacement(rects, placement, rtl);\n let statefulPlacement = placement;\n let middlewareData = {};\n let resetCount = 0;\n for (let i = 0; i < validMiddleware.length; i++) {\n const {\n name,\n fn\n } = validMiddleware[i];\n const {\n x: nextX,\n y: nextY,\n data,\n reset\n } = await fn({\n x,\n y,\n initialPlacement: placement,\n placement: statefulPlacement,\n strategy,\n middlewareData,\n rects,\n platform,\n elements: {\n reference,\n floating\n }\n });\n x = nextX != null ? nextX : x;\n y = nextY != null ? nextY : y;\n middlewareData = {\n ...middlewareData,\n [name]: {\n ...middlewareData[name],\n ...data\n }\n };\n if (reset && resetCount <= 50) {\n resetCount++;\n if (typeof reset === 'object') {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\n if (reset.rects) {\n rects = reset.rects === true ? await platform.getElementRects({\n reference,\n floating,\n strategy\n }) : reset.rects;\n }\n ({\n x,\n y\n } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n i = -1;\n continue;\n }\n }\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n var _await$platform$isEle;\n if (options === void 0) {\n options = {};\n }\n const {\n x,\n y,\n platform,\n rects,\n elements,\n strategy\n } = state;\n const {\n boundary = 'clippingAncestors',\n rootBoundary = 'viewport',\n elementContext = 'floating',\n altBoundary = false,\n padding = 0\n } = evaluate(options, state);\n const paddingObject = getPaddingObject(padding);\n const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n const element = elements[altBoundary ? altContext : elementContext];\n const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n boundary,\n rootBoundary,\n strategy\n }));\n const rect = elementContext === 'floating' ? {\n ...rects.floating,\n x,\n y\n } : rects.reference;\n const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n x: 1,\n y: 1\n } : {\n x: 1,\n y: 1\n };\n const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n rect,\n offsetParent,\n strategy\n }) : rect);\n return {\n top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n name: 'arrow',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n platform,\n elements,\n middlewareData\n } = state;\n // Since `element` is required, we don't Partial<> the type.\n const {\n element,\n padding = 0\n } = evaluate(options, state) || {};\n if (element == null) {\n return {};\n }\n const paddingObject = getPaddingObject(padding);\n const coords = {\n x,\n y\n };\n const axis = getAlignmentAxis(placement);\n const length = getAxisLength(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const isYAxis = axis === 'y';\n const minProp = isYAxis ? 'top' : 'left';\n const maxProp = isYAxis ? 'bottom' : 'right';\n const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n const startDiff = coords[axis] - rects.reference[axis];\n const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n // DOM platform can return `window` as the `offsetParent`.\n if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n clientSize = elements.floating[clientProp] || rects.floating[length];\n }\n const centerToReference = endDiff / 2 - startDiff / 2;\n\n // If the padding is large enough that it causes the arrow to no longer be\n // centered, modify the padding so that it is centered.\n const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds.\n const min$1 = minPadding;\n const max = clientSize - arrowDimensions[length] - maxPadding;\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = clamp(min$1, center, max);\n\n // If the reference is small enough that the arrow's padding causes it to\n // to point to nothing for an aligned placement, adjust the offset of the\n // floating element itself. To ensure `shift()` continues to take action,\n // a single reset is performed when this is true.\n const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center != offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n return {\n [axis]: coords[axis] + alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset - alignmentOffset,\n ...(shouldAddOffset && {\n alignmentOffset\n })\n },\n reset: shouldAddOffset\n };\n }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n return allowedPlacementsSortedByAlignment.filter(placement => {\n if (alignment) {\n return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n }\n return true;\n });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'autoPlacement',\n options,\n async fn(state) {\n var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n const {\n rects,\n middlewareData,\n placement,\n platform,\n elements\n } = state;\n const {\n crossAxis = false,\n alignment,\n allowedPlacements = placements,\n autoAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n const currentPlacement = placements$1[currentIndex];\n if (currentPlacement == null) {\n return {};\n }\n const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n // Make `computeCoords` start from the right place.\n if (placement !== currentPlacement) {\n return {\n reset: {\n placement: placements$1[0]\n }\n };\n }\n const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n placement: currentPlacement,\n overflows: currentOverflows\n }];\n const nextPlacement = placements$1[currentIndex + 1];\n\n // There are more placements to check.\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n const placementsSortedByMostSpace = allOverflows.map(d => {\n const alignment = getAlignment(d.placement);\n return [d.placement, alignment && crossAxis ?\n // Check along the mainAxis and main crossAxis side.\n d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n // Check only the mainAxis.\n d.overflows[0], d.overflows];\n }).sort((a, b) => a[1] - b[1]);\n const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n // Aligned placements should not check their opposite crossAxis\n // side.\n getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n if (resetPlacement !== placement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: resetPlacement\n }\n };\n }\n return {};\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'flip',\n options,\n async fn(state) {\n var _middlewareData$arrow, _middlewareData$flip;\n const {\n placement,\n middlewareData,\n rects,\n initialPlacement,\n platform,\n elements\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true,\n fallbackPlacements: specifiedFallbackPlacements,\n fallbackStrategy = 'bestFit',\n fallbackAxisSideDirection = 'none',\n flipAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n\n // If a reset by the arrow was caused due to an alignment offset being\n // added, we should skip any logic now since `flip()` has already done its\n // work.\n // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n const side = getSide(placement);\n const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n if (!specifiedFallbackPlacements && fallbackAxisSideDirection !== 'none') {\n fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n }\n const placements = [initialPlacement, ...fallbackPlacements];\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n if (checkCrossAxis) {\n const sides = getAlignmentSides(placement, rects, rtl);\n overflows.push(overflow[sides[0]], overflow[sides[1]]);\n }\n overflowsData = [...overflowsData, {\n placement,\n overflows\n }];\n\n // One or more sides is overflowing.\n if (!overflows.every(side => side <= 0)) {\n var _middlewareData$flip2, _overflowsData$filter;\n const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n const nextPlacement = placements[nextIndex];\n if (nextPlacement) {\n // Try next placement and re-run the lifecycle.\n return {\n data: {\n index: nextIndex,\n overflows: overflowsData\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n\n // First, find the candidates that fit on the mainAxis side of overflow,\n // then find the placement that fits the best on the main crossAxis side.\n let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n // Otherwise fallback.\n if (!resetPlacement) {\n switch (fallbackStrategy) {\n case 'bestFit':\n {\n var _overflowsData$map$so;\n const placement = (_overflowsData$map$so = overflowsData.map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0];\n if (placement) {\n resetPlacement = placement;\n }\n break;\n }\n case 'initialPlacement':\n resetPlacement = initialPlacement;\n break;\n }\n }\n if (placement !== resetPlacement) {\n return {\n reset: {\n placement: resetPlacement\n }\n };\n }\n }\n return {};\n }\n };\n};\n\nfunction getSideOffsets(overflow, rect) {\n return {\n top: overflow.top - rect.height,\n right: overflow.right - rect.width,\n bottom: overflow.bottom - rect.height,\n left: overflow.left - rect.width\n };\n}\nfunction isAnySideFullyClipped(overflow) {\n return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'hide',\n options,\n async fn(state) {\n const {\n rects\n } = state;\n const {\n strategy = 'referenceHidden',\n ...detectOverflowOptions\n } = evaluate(options, state);\n switch (strategy) {\n case 'referenceHidden':\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const offsets = getSideOffsets(overflow, rects.reference);\n return {\n data: {\n referenceHiddenOffsets: offsets,\n referenceHidden: isAnySideFullyClipped(offsets)\n }\n };\n }\n case 'escaped':\n {\n const overflow = await detectOverflow(state, {\n ...detectOverflowOptions,\n altBoundary: true\n });\n const offsets = getSideOffsets(overflow, rects.floating);\n return {\n data: {\n escapedOffsets: offsets,\n escaped: isAnySideFullyClipped(offsets)\n }\n };\n }\n default:\n {\n return {};\n }\n }\n }\n };\n};\n\nfunction getBoundingRect(rects) {\n const minX = min(...rects.map(rect => rect.left));\n const minY = min(...rects.map(rect => rect.top));\n const maxX = max(...rects.map(rect => rect.right));\n const maxY = max(...rects.map(rect => rect.bottom));\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n}\nfunction getRectsByLine(rects) {\n const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n const groups = [];\n let prevRect = null;\n for (let i = 0; i < sortedRects.length; i++) {\n const rect = sortedRects[i];\n if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n groups.push([rect]);\n } else {\n groups[groups.length - 1].push(rect);\n }\n prevRect = rect;\n }\n return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'inline',\n options,\n async fn(state) {\n const {\n placement,\n elements,\n rects,\n platform,\n strategy\n } = state;\n // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n // ClientRect's bounds, despite the event listener being triggered. A\n // padding of 2 seems to handle this issue.\n const {\n padding = 2,\n x,\n y\n } = evaluate(options, state);\n const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n const clientRects = getRectsByLine(nativeClientRects);\n const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n const paddingObject = getPaddingObject(padding);\n function getBoundingClientRect() {\n // There are two rects and they are disjoined.\n if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n // Find the first rect in which the point is fully inside.\n return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n }\n\n // There are 2 or more connected rects.\n if (clientRects.length >= 2) {\n if (getSideAxis(placement) === 'y') {\n const firstRect = clientRects[0];\n const lastRect = clientRects[clientRects.length - 1];\n const isTop = getSide(placement) === 'top';\n const top = firstRect.top;\n const bottom = lastRect.bottom;\n const left = isTop ? firstRect.left : lastRect.left;\n const right = isTop ? firstRect.right : lastRect.right;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n const isLeftSide = getSide(placement) === 'left';\n const maxRight = max(...clientRects.map(rect => rect.right));\n const minLeft = min(...clientRects.map(rect => rect.left));\n const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n const top = measureRects[0].top;\n const bottom = measureRects[measureRects.length - 1].bottom;\n const left = minLeft;\n const right = maxRight;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n return fallback;\n }\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\n if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n return {\n reset: {\n rects: resetRects\n }\n };\n }\n return {};\n }\n };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\nasync function convertValueToCoords(state, options) {\n const {\n placement,\n platform,\n elements\n } = state;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isVertical = getSideAxis(placement) === 'y';\n const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = evaluate(options, state);\n\n // eslint-disable-next-line prefer-const\n let {\n mainAxis,\n crossAxis,\n alignmentAxis\n } = typeof rawValue === 'number' ? {\n mainAxis: rawValue,\n crossAxis: 0,\n alignmentAxis: null\n } : {\n mainAxis: 0,\n crossAxis: 0,\n alignmentAxis: null,\n ...rawValue\n };\n if (alignment && typeof alignmentAxis === 'number') {\n crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n }\n return isVertical ? {\n x: crossAxis * crossAxisMulti,\n y: mainAxis * mainAxisMulti\n } : {\n x: mainAxis * mainAxisMulti,\n y: crossAxis * crossAxisMulti\n };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n if (options === void 0) {\n options = 0;\n }\n return {\n name: 'offset',\n options,\n async fn(state) {\n const {\n x,\n y\n } = state;\n const diffCoords = await convertValueToCoords(state, options);\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: diffCoords\n };\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'shift',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = false,\n limiter = {\n fn: _ref => {\n let {\n x,\n y\n } = _ref;\n return {\n x,\n y\n };\n }\n },\n ...detectOverflowOptions\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const crossAxis = getSideAxis(getSide(placement));\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n if (checkMainAxis) {\n const minSide = mainAxis === 'y' ? 'top' : 'left';\n const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n const min = mainAxisCoord + overflow[minSide];\n const max = mainAxisCoord - overflow[maxSide];\n mainAxisCoord = clamp(min, mainAxisCoord, max);\n }\n if (checkCrossAxis) {\n const minSide = crossAxis === 'y' ? 'top' : 'left';\n const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n const min = crossAxisCoord + overflow[minSide];\n const max = crossAxisCoord - overflow[maxSide];\n crossAxisCoord = clamp(min, crossAxisCoord, max);\n }\n const limitedCoords = limiter.fn({\n ...state,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return {\n ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y\n }\n };\n }\n };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n options,\n fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n middlewareData\n } = state;\n const {\n offset = 0,\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const crossAxis = getSideAxis(placement);\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = evaluate(offset, state);\n const computedOffset = typeof rawOffset === 'number' ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\n if (checkMainAxis) {\n const len = mainAxis === 'y' ? 'height' : 'width';\n const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2;\n const len = mainAxis === 'y' ? 'width' : 'height';\n const isOriginSide = ['top', 'left'].includes(getSide(placement));\n const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'size',\n options,\n async fn(state) {\n const {\n placement,\n rects,\n platform,\n elements\n } = state;\n const {\n apply = () => {},\n ...detectOverflowOptions\n } = evaluate(options, state);\n const overflow = await detectOverflow(state, detectOverflowOptions);\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isYAxis = getSideAxis(placement) === 'y';\n const {\n width,\n height\n } = rects.floating;\n let heightSide;\n let widthSide;\n if (side === 'top' || side === 'bottom') {\n heightSide = side;\n widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n } else {\n widthSide = side;\n heightSide = alignment === 'end' ? 'top' : 'bottom';\n }\n const overflowAvailableHeight = height - overflow[heightSide];\n const overflowAvailableWidth = width - overflow[widthSide];\n const noShift = !state.middlewareData.shift;\n let availableHeight = overflowAvailableHeight;\n let availableWidth = overflowAvailableWidth;\n if (isYAxis) {\n const maximumClippingWidth = width - overflow.left - overflow.right;\n availableWidth = alignment || noShift ? min(overflowAvailableWidth, maximumClippingWidth) : maximumClippingWidth;\n } else {\n const maximumClippingHeight = height - overflow.top - overflow.bottom;\n availableHeight = alignment || noShift ? min(overflowAvailableHeight, maximumClippingHeight) : maximumClippingHeight;\n }\n if (noShift && !alignment) {\n const xMin = max(overflow.left, 0);\n const xMax = max(overflow.right, 0);\n const yMin = max(overflow.top, 0);\n const yMax = max(overflow.bottom, 0);\n if (isYAxis) {\n availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n } else {\n availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n }\n }\n await apply({\n ...state,\n availableWidth,\n availableHeight\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n if (width !== nextDimensions.width || height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n return {};\n }\n };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null ? void 0 : (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n // Browsers without `ShadowRoot` support.\n if (typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isContainingBlock(element) {\n const webkit = isWebKit();\n const css = getComputedStyle(element);\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n return css.transform !== 'none' || css.perspective !== 'none' || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else {\n currentNode = getParentNode(currentNode);\n }\n }\n return null;\n}\nfunction isWebKit() {\n if (typeof CSS === 'undefined' || !CSS.supports) return false;\n return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.pageXOffset,\n scrollTop: element.pageYOffset\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], win.frameElement && traverseIframes ? getOverflowAncestors(win.frameElement) : []);\n }\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isWebKit };\n","import { rectToClientRect, computePosition as computePosition$1 } from '@floating-ui/core';\nexport { arrow, autoPlacement, detectOverflow, flip, hide, inline, limitShift, offset, shift, size } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getDocumentElement, getNodeName, isOverflowElement, getNodeScroll, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n const css = getComputedStyle(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = isHTMLElement(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\n\nfunction unwrapElement(element) {\n return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!isHTMLElement(domElement)) {\n return createCoords(1);\n }\n const rect = domElement.getBoundingClientRect();\n const {\n width,\n height,\n $\n } = getCssDimensions(domElement);\n let x = ($ ? round(rect.width) : rect.width) / width;\n let y = ($ ? round(rect.height) : rect.height) / height;\n\n // 0, NaN, or Infinity should always fallback to 1.\n\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n const win = getWindow(element);\n if (!isWebKit() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n return false;\n }\n return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = createCoords(1);\n if (includeScale) {\n if (offsetParent) {\n if (isElement(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = getWindow(domElement);\n const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n let currentIFrame = win.frameElement;\n while (currentIFrame && offsetParent && offsetWin !== win) {\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = getComputedStyle(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentIFrame = getWindow(currentIFrame).frameElement;\n }\n }\n return rectToClientRect({\n width,\n height,\n x,\n y\n });\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n if (offsetParent === documentElement) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = createCoords(1);\n const offsets = createCoords(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isHTMLElement(offsetParent)) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y\n };\n}\n\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\n\nfunction getWindowScrollBarX(element) {\n // If <html> has a CSS width greater than the viewport, then this will be\n // incorrect for RTL.\n return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = element.ownerDocument.body;\n const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if (getComputedStyle(body).direction === 'rtl') {\n x += max(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = getDocumentElement(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = isWebKit();\n if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === 'viewport') {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === 'document') {\n rect = getDocumentRect(getDocumentElement(element));\n } else if (isElement(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n ...clippingAncestor,\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y\n };\n }\n return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = getParentNode(element);\n if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n return false;\n }\n return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = getComputedStyle(element).position === 'fixed';\n let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n const computedStyle = getComputedStyle(currentNode);\n const currentNodeIsContaining = isContainingBlock(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter(ancestor => ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = getParentNode(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const elementClippingAncestors = boundary === 'clippingAncestors' ? getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n const firstClippingAncestor = clippingAncestors[0];\n const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n accRect.top = max(rect.top, accRect.top);\n accRect.right = min(rect.right, accRect.right);\n accRect.bottom = min(rect.bottom, accRect.bottom);\n accRect.left = max(rect.left, accRect.left);\n return accRect;\n }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n return {\n width: clippingRect.right - clippingRect.left,\n height: clippingRect.bottom - clippingRect.top,\n x: clippingRect.left,\n y: clippingRect.top\n };\n}\n\nfunction getDimensions(element) {\n return getCssDimensions(element);\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const isFixed = strategy === 'fixed';\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = createCoords(0);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n }\n return {\n x: rect.left + scroll.scrollLeft - offsets.x,\n y: rect.top + scroll.scrollTop - offsets.y,\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n return element.offsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const window = getWindow(element);\n if (!isHTMLElement(element)) {\n return window;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {\n return window;\n }\n return offsetParent || getContainingBlock(element) || window;\n}\n\nconst getElementRects = async function (_ref) {\n let {\n reference,\n floating,\n strategy\n } = _ref;\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n return {\n reference: getRectRelativeToOffsetParent(reference, await getOffsetParentFn(floating), strategy),\n floating: {\n x: 0,\n y: 0,\n ...(await getDimensionsFn(floating))\n }\n };\n};\n\nfunction isRTL(element) {\n return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement,\n isRTL\n};\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = getDocumentElement(element);\n function cleanup() {\n clearTimeout(timeoutId);\n io && io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const {\n left,\n top,\n width,\n height\n } = element.getBoundingClientRect();\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = floor(top);\n const insetRight = floor(root.clientWidth - (left + width));\n const insetBottom = floor(root.clientHeight - (top + height));\n const insetLeft = floor(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: max(0, min(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n timeoutId = setTimeout(() => {\n refresh(false, 1e-7);\n }, 100);\n } else {\n refresh(false, ratio);\n }\n }\n isFirstUpdate = false;\n }\n\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle <iframe>s\n root: root.ownerDocument\n });\n } catch (e) {\n io = new IntersectionObserver(handleObserve, options);\n }\n io.observe(element);\n }\n refresh(true);\n return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n ancestorScroll = true,\n ancestorResize = true,\n elementResize = typeof ResizeObserver === 'function',\n layoutShift = typeof IntersectionObserver === 'function',\n animationFrame = false\n } = options;\n const referenceEl = unwrapElement(reference);\n const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.addEventListener('scroll', update, {\n passive: true\n });\n ancestorResize && ancestor.addEventListener('resize', update);\n });\n const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n let reobserveFrame = -1;\n let resizeObserver = null;\n if (elementResize) {\n resizeObserver = new ResizeObserver(_ref => {\n let [firstEntry] = _ref;\n if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {\n // Prevent update loops when using the `size` middleware.\n // https://github.com/floating-ui/floating-ui/issues/1740\n resizeObserver.unobserve(floating);\n cancelAnimationFrame(reobserveFrame);\n reobserveFrame = requestAnimationFrame(() => {\n resizeObserver && resizeObserver.observe(floating);\n });\n }\n update();\n });\n if (referenceEl && !animationFrame) {\n resizeObserver.observe(referenceEl);\n }\n resizeObserver.observe(floating);\n }\n let frameId;\n let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n if (animationFrame) {\n frameLoop();\n }\n function frameLoop() {\n const nextRefRect = getBoundingClientRect(reference);\n if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {\n update();\n }\n prevRefRect = nextRefRect;\n frameId = requestAnimationFrame(frameLoop);\n }\n update();\n return () => {\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.removeEventListener('scroll', update);\n ancestorResize && ancestor.removeEventListener('resize', update);\n });\n cleanupIo && cleanupIo();\n resizeObserver && resizeObserver.disconnect();\n resizeObserver = null;\n if (animationFrame) {\n cancelAnimationFrame(frameId);\n }\n };\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a reference element when it is given a certain CSS positioning\n * strategy.\n */\nconst computePosition = (reference, floating, options) => {\n // This caches the expensive `getClippingElementAncestors` function so that\n // multiple lifecycle resets re-use the same result. It only lives for a\n // single call. If other functions become expensive, we can add them as well.\n const cache = new Map();\n const mergedOptions = {\n platform,\n ...options\n };\n const platformWithCache = {\n ...mergedOptions.platform,\n _c: cache\n };\n return computePosition$1(reference, floating, {\n ...mergedOptions,\n platform: platformWithCache\n });\n};\n\nexport { autoUpdate, computePosition, platform };\n","import { arrow as arrow$1, computePosition } from '@floating-ui/dom';\nexport { autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/dom';\nimport * as React from 'react';\nimport { useLayoutEffect, useEffect } from 'react';\nimport * as ReactDOM from 'react-dom';\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => {\n function isRef(value) {\n return {}.hasOwnProperty.call(value, 'current');\n }\n return {\n name: 'arrow',\n options,\n fn(state) {\n const {\n element,\n padding\n } = typeof options === 'function' ? options(state) : options;\n if (element && isRef(element)) {\n if (element.current != null) {\n return arrow$1({\n element: element.current,\n padding\n }).fn(state);\n }\n return {};\n } else if (element) {\n return arrow$1({\n element,\n padding\n }).fn(state);\n }\n return {};\n }\n };\n};\n\nvar index = typeof document !== 'undefined' ? useLayoutEffect : useEffect;\n\n// Fork of `fast-deep-equal` that only does the comparisons we need and compares\n// functions\nfunction deepEqual(a, b) {\n if (a === b) {\n return true;\n }\n if (typeof a !== typeof b) {\n return false;\n }\n if (typeof a === 'function' && a.toString() === b.toString()) {\n return true;\n }\n let length, i, keys;\n if (a && b && typeof a == 'object') {\n if (Array.isArray(a)) {\n length = a.length;\n if (length != b.length) return false;\n for (i = length; i-- !== 0;) {\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) {\n return false;\n }\n for (i = length; i-- !== 0;) {\n if (!{}.hasOwnProperty.call(b, keys[i])) {\n return false;\n }\n }\n for (i = length; i-- !== 0;) {\n const key = keys[i];\n if (key === '_owner' && a.$$typeof) {\n continue;\n }\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n }\n return true;\n }\n return a !== a && b !== b;\n}\n\nfunction getDPR(element) {\n if (typeof window === 'undefined') {\n return 1;\n }\n const win = element.ownerDocument.defaultView || window;\n return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n const dpr = getDPR(element);\n return Math.round(value * dpr) / dpr;\n}\n\nfunction useLatestRef(value) {\n const ref = React.useRef(value);\n index(() => {\n ref.current = value;\n });\n return ref;\n}\n\n/**\n * Provides data to position a floating element.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform,\n elements: {\n reference: externalReference,\n floating: externalFloating\n } = {},\n transform = true,\n whileElementsMounted,\n open\n } = options;\n const [data, setData] = React.useState({\n x: 0,\n y: 0,\n strategy,\n placement,\n middlewareData: {},\n isPositioned: false\n });\n const [latestMiddleware, setLatestMiddleware] = React.useState(middleware);\n if (!deepEqual(latestMiddleware, middleware)) {\n setLatestMiddleware(middleware);\n }\n const [_reference, _setReference] = React.useState(null);\n const [_floating, _setFloating] = React.useState(null);\n const setReference = React.useCallback(node => {\n if (node != referenceRef.current) {\n referenceRef.current = node;\n _setReference(node);\n }\n }, [_setReference]);\n const setFloating = React.useCallback(node => {\n if (node !== floatingRef.current) {\n floatingRef.current = node;\n _setFloating(node);\n }\n }, [_setFloating]);\n const referenceEl = externalReference || _reference;\n const floatingEl = externalFloating || _floating;\n const referenceRef = React.useRef(null);\n const floatingRef = React.useRef(null);\n const dataRef = React.useRef(data);\n const whileElementsMountedRef = useLatestRef(whileElementsMounted);\n const platformRef = useLatestRef(platform);\n const update = React.useCallback(() => {\n if (!referenceRef.current || !floatingRef.current) {\n return;\n }\n const config = {\n placement,\n strategy,\n middleware: latestMiddleware\n };\n if (platformRef.current) {\n config.platform = platformRef.current;\n }\n computePosition(referenceRef.current, floatingRef.current, config).then(data => {\n const fullData = {\n ...data,\n isPositioned: true\n };\n if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) {\n dataRef.current = fullData;\n ReactDOM.flushSync(() => {\n setData(fullData);\n });\n }\n });\n }, [latestMiddleware, placement, strategy, platformRef]);\n index(() => {\n if (open === false && dataRef.current.isPositioned) {\n dataRef.current.isPositioned = false;\n setData(data => ({\n ...data,\n isPositioned: false\n }));\n }\n }, [open]);\n const isMountedRef = React.useRef(false);\n index(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n };\n }, []);\n index(() => {\n if (referenceEl) referenceRef.current = referenceEl;\n if (floatingEl) floatingRef.current = floatingEl;\n if (referenceEl && floatingEl) {\n if (whileElementsMountedRef.current) {\n return whileElementsMountedRef.current(referenceEl, floatingEl, update);\n } else {\n update();\n }\n }\n }, [referenceEl, floatingEl, update, whileElementsMountedRef]);\n const refs = React.useMemo(() => ({\n reference: referenceRef,\n floating: floatingRef,\n setReference,\n setFloating\n }), [setReference, setFloating]);\n const elements = React.useMemo(() => ({\n reference: referenceEl,\n floating: floatingEl\n }), [referenceEl, floatingEl]);\n const floatingStyles = React.useMemo(() => {\n const initialStyles = {\n position: strategy,\n left: 0,\n top: 0\n };\n if (!elements.floating) {\n return initialStyles;\n }\n const x = roundByDPR(elements.floating, data.x);\n const y = roundByDPR(elements.floating, data.y);\n if (transform) {\n return {\n ...initialStyles,\n transform: \"translate(\" + x + \"px, \" + y + \"px)\",\n ...(getDPR(elements.floating) >= 1.5 && {\n willChange: 'transform'\n })\n };\n }\n return {\n position: strategy,\n left: x,\n top: y\n };\n }, [strategy, transform, elements.floating, data.x, data.y]);\n return React.useMemo(() => ({\n ...data,\n update,\n refs,\n elements,\n floatingStyles\n }), [data, update, refs, elements, floatingStyles]);\n}\n\nexport { arrow, useFloating };\n","'use client';\n\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nconst _excluded = [\"onChange\", \"maxRows\", \"minRows\", \"style\", \"value\"];\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport * as ReactDOM from 'react-dom';\nimport { unstable_debounce as debounce, unstable_useForkRef as useForkRef, unstable_useEnhancedEffect as useEnhancedEffect, unstable_ownerWindow as ownerWindow } from '@mui/utils';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nfunction getStyleValue(value) {\n return parseInt(value, 10) || 0;\n}\nconst styles = {\n shadow: {\n // Visibility needed to hide the extra text area on iPads\n visibility: 'hidden',\n // Remove from the content flow\n position: 'absolute',\n // Ignore the scrollbar width\n overflow: 'hidden',\n height: 0,\n top: 0,\n left: 0,\n // Create a new layer, increase the isolation of the computed values\n transform: 'translateZ(0)'\n }\n};\nfunction isEmpty(obj) {\n return obj === undefined || obj === null || Object.keys(obj).length === 0 || obj.outerHeightStyle === 0 && !obj.overflow;\n}\n\n/**\n *\n * Demos:\n *\n * - [Textarea Autosize](https://mui.com/base-ui/react-textarea-autosize/)\n * - [Textarea Autosize](https://mui.com/material-ui/react-textarea-autosize/)\n *\n * API:\n *\n * - [TextareaAutosize API](https://mui.com/base-ui/react-textarea-autosize/components-api/#textarea-autosize)\n */\nconst TextareaAutosize = /*#__PURE__*/React.forwardRef(function TextareaAutosize(props, forwardedRef) {\n const {\n onChange,\n maxRows,\n minRows = 1,\n style,\n value\n } = props,\n other = _objectWithoutPropertiesLoose(props, _excluded);\n const {\n current: isControlled\n } = React.useRef(value != null);\n const inputRef = React.useRef(null);\n const handleRef = useForkRef(forwardedRef, inputRef);\n const shadowRef = React.useRef(null);\n const renders = React.useRef(0);\n const [state, setState] = React.useState({\n outerHeightStyle: 0\n });\n const getUpdatedState = React.useCallback(() => {\n const input = inputRef.current;\n const containerWindow = ownerWindow(input);\n const computedStyle = containerWindow.getComputedStyle(input);\n\n // If input's width is shrunk and it's not visible, don't sync height.\n if (computedStyle.width === '0px') {\n return {\n outerHeightStyle: 0\n };\n }\n const inputShallow = shadowRef.current;\n inputShallow.style.width = computedStyle.width;\n inputShallow.value = input.value || props.placeholder || 'x';\n if (inputShallow.value.slice(-1) === '\\n') {\n // Certain fonts which overflow the line height will cause the textarea\n // to report a different scrollHeight depending on whether the last line\n // is empty. Make it non-empty to avoid this issue.\n inputShallow.value += ' ';\n }\n const boxSizing = computedStyle.boxSizing;\n const padding = getStyleValue(computedStyle.paddingBottom) + getStyleValue(computedStyle.paddingTop);\n const border = getStyleValue(computedStyle.borderBottomWidth) + getStyleValue(computedStyle.borderTopWidth);\n\n // The height of the inner content\n const innerHeight = inputShallow.scrollHeight;\n\n // Measure height of a textarea with a single row\n inputShallow.value = 'x';\n const singleRowHeight = inputShallow.scrollHeight;\n\n // The height of the outer content\n let outerHeight = innerHeight;\n if (minRows) {\n outerHeight = Math.max(Number(minRows) * singleRowHeight, outerHeight);\n }\n if (maxRows) {\n outerHeight = Math.min(Number(maxRows) * singleRowHeight, outerHeight);\n }\n outerHeight = Math.max(outerHeight, singleRowHeight);\n\n // Take the box sizing into account for applying this value as a style.\n const outerHeightStyle = outerHeight + (boxSizing === 'border-box' ? padding + border : 0);\n const overflow = Math.abs(outerHeight - innerHeight) <= 1;\n return {\n outerHeightStyle,\n overflow\n };\n }, [maxRows, minRows, props.placeholder]);\n const updateState = (prevState, newState) => {\n const {\n outerHeightStyle,\n overflow\n } = newState;\n // Need a large enough difference to update the height.\n // This prevents infinite rendering loop.\n if (renders.current < 20 && (outerHeightStyle > 0 && Math.abs((prevState.outerHeightStyle || 0) - outerHeightStyle) > 1 || prevState.overflow !== overflow)) {\n renders.current += 1;\n return {\n overflow,\n outerHeightStyle\n };\n }\n if (process.env.NODE_ENV !== 'production') {\n if (renders.current === 20) {\n console.error(['MUI: Too many re-renders. The layout is unstable.', 'TextareaAutosize limits the number of renders to prevent an infinite loop.'].join('\\n'));\n }\n }\n return prevState;\n };\n const syncHeight = React.useCallback(() => {\n const newState = getUpdatedState();\n if (isEmpty(newState)) {\n return;\n }\n setState(prevState => updateState(prevState, newState));\n }, [getUpdatedState]);\n useEnhancedEffect(() => {\n const syncHeightWithFlushSync = () => {\n const newState = getUpdatedState();\n if (isEmpty(newState)) {\n return;\n }\n\n // In React 18, state updates in a ResizeObserver's callback are happening after\n // the paint, this leads to an infinite rendering.\n //\n // Using flushSync ensures that the states is updated before the next pain.\n // Related issue - https://github.com/facebook/react/issues/24331\n ReactDOM.flushSync(() => {\n setState(prevState => updateState(prevState, newState));\n });\n };\n const handleResize = () => {\n renders.current = 0;\n syncHeightWithFlushSync();\n };\n // Workaround a \"ResizeObserver loop completed with undelivered notifications\" error\n // in test.\n // Note that we might need to use this logic in production per https://github.com/WICG/resize-observer/issues/38\n // Also see https://github.com/mui/mui-x/issues/8733\n let rAF;\n const rAFHandleResize = () => {\n cancelAnimationFrame(rAF);\n rAF = requestAnimationFrame(() => {\n handleResize();\n });\n };\n const debounceHandleResize = debounce(handleResize);\n const input = inputRef.current;\n const containerWindow = ownerWindow(input);\n containerWindow.addEventListener('resize', debounceHandleResize);\n let resizeObserver;\n if (typeof ResizeObserver !== 'undefined') {\n resizeObserver = new ResizeObserver(process.env.NODE_ENV === 'test' ? rAFHandleResize : handleResize);\n resizeObserver.observe(input);\n }\n return () => {\n debounceHandleResize.clear();\n cancelAnimationFrame(rAF);\n containerWindow.removeEventListener('resize', debounceHandleResize);\n if (resizeObserver) {\n resizeObserver.disconnect();\n }\n };\n }, [getUpdatedState]);\n useEnhancedEffect(() => {\n syncHeight();\n });\n React.useEffect(() => {\n renders.current = 0;\n }, [value]);\n const handleChange = event => {\n renders.current = 0;\n if (!isControlled) {\n syncHeight();\n }\n if (onChange) {\n onChange(event);\n }\n };\n return /*#__PURE__*/_jsxs(React.Fragment, {\n children: [/*#__PURE__*/_jsx(\"textarea\", _extends({\n value: value,\n onChange: handleChange,\n ref: handleRef\n // Apply the rows prop to get a \"correct\" first SSR paint\n ,\n rows: minRows,\n style: _extends({\n height: state.outerHeightStyle,\n // Need a large enough difference to allow scrolling.\n // This prevents infinite rendering loop.\n overflow: state.overflow ? 'hidden' : undefined\n }, style)\n }, other)), /*#__PURE__*/_jsx(\"textarea\", {\n \"aria-hidden\": true,\n className: props.className,\n readOnly: true,\n ref: shadowRef,\n tabIndex: -1,\n style: _extends({}, styles.shadow, style, {\n paddingTop: 0,\n paddingBottom: 0\n })\n })]\n });\n});\nprocess.env.NODE_ENV !== \"production\" ? TextareaAutosize.propTypes /* remove-proptypes */ = {\n // ----------------------------- Warning --------------------------------\n // | These PropTypes are generated from the TypeScript type definitions |\n // | To update them edit TypeScript types and run \"yarn proptypes\" |\n // ----------------------------------------------------------------------\n /**\n * @ignore\n */\n className: PropTypes.string,\n /**\n * Maximum number of rows to display.\n */\n maxRows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n /**\n * Minimum number of rows to display.\n * @default 1\n */\n minRows: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),\n /**\n * @ignore\n */\n onChange: PropTypes.func,\n /**\n * @ignore\n */\n placeholder: PropTypes.string,\n /**\n * @ignore\n */\n style: PropTypes.object,\n /**\n * @ignore\n */\n value: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.string), PropTypes.number, PropTypes.string])\n} : void 0;\nexport { TextareaAutosize };","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\tvar nativeCodeString = '[native code]';\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAbTest = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M0 .75A.75.75 0 0 1 .75 0h7a.75.75 0 0 1 0 1.5H7.5v11.25a3.25 3.25 0 0 1-6.5 0V1.5H.75A.75.75 0 0 1 0 .75Zm2.5 5v7a1.75 1.75 0 1 0 3.5 0v-7H2.5Zm0-1.5H6v-2.5H2.5v2.5ZM11.16.659A2.25 2.25 0 0 1 15 2.25v4.499a.75.75 0 0 1-1.5 0V5.5H12v1.25a.75.75 0 0 1-1.5 0v-4.5c0-.597.237-1.169.66-1.591ZM13.5 4V2.25a.75.75 0 1 0-1.5 0V4h1.5Zm-2.25 4.5a.75.75 0 0 0-.75.75v6c0 .414.336.75.75.75h1.5a2.25 2.25 0 0 0 1.677-3.75A2.25 2.25 0 0 0 12.75 8.5h-1.5Zm1.5 3H12V10h.75a.75.75 0 0 1 0 1.5Zm-.75 3V13h.75a.75.75 0 0 1 0 1.5H12Z\" }));\nconst ForwardRef = forwardRef(SvgAbTest);\nexport default ForwardRef;\n","import { cloneElement, forwardRef, isValidElement, ReactElement, Ref, SVGAttributes } from 'react';\n\nexport interface BrIconInstanceProps extends SVGAttributes<SVGElement> {\n /**\n * Size of the icon. Sets the width and height on the \\<svg\\> tag\n */\n size?: number;\n /**\n * Color of the icon. Sets the fill color on the \\<svg\\> tag\n */\n color?: string;\n}\n\nexport interface BrIconProps extends BrIconInstanceProps {\n /**\n * SVG icon to wrap\n */\n children: ReactElement<SVGElement>;\n}\n\n/**\n * This is a wrapper component to wrap any SVG icon and provide a unified interface\n * to manipulate its props\n *\n * ### Usage\n * #### Library Icons\n * ```\n * import { FireIcon } from '@bloomreach/react-banana-ui'\n *\n * <FireIcon />\n * ```\n *\n * #### Custom Icons\n * ```\n * import BrIcon from '@bloomreach/react-banana-ui'\n * import CustomSvgIcon from 'path/to/icon.svg?react'\n *\n * <BrIcon size={100} id=\"some-id\" className=\"some-class\" aria-label=\"some description\">\n * <CustomSvgIcon />\n * </BrIcon>\n * ```\n * */\n\nconst BrIcon = forwardRef((props: BrIconProps, ref: Ref<SVGSVGElement>) => {\n const { children, size, color, ...rest } = props;\n\n const svgProps = {\n ...(size ? { width: size, height: size } : {}),\n ...(color ? { fill: color } : {}),\n ref,\n ...rest,\n };\n\n if (isValidElement(children)) {\n return cloneElement(children as ReactElement<SVGAttributes<SVGElement>>, svgProps);\n }\n\n return null;\n});\n\nBrIcon.displayName = 'BrIcon';\n\nexport default BrIcon;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AbTestSvgIcon from '@bloomreach/banana-theme/icons/ab-test.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AbTestIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AbTestSvgIcon />\n </BrIcon>\n );\n});\n\nAbTestIcon.displayName = 'AbTestIcon';\n\nexport default AbTestIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAggregate = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.33 1.665A.75.75 0 0 1 3 1.25h10a.75.75 0 0 1 0 1.5H4.5l3.6 4.8c.2.267.2.633 0 .9l-3.6 4.8H13a.75.75 0 0 1 0 1.5H3a.75.75 0 0 1-.6-1.2L6.563 8 2.4 2.45a.75.75 0 0 1-.07-.785Z\" }));\nconst ForwardRef = forwardRef(SvgAggregate);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AggregateSvgIcon from '@bloomreach/banana-theme/icons/aggregate.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AggregateIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AggregateSvgIcon />\n </BrIcon>\n );\n});\n\nAggregateIcon.displayName = 'AggregateIcon';\n\nexport default AggregateIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAnalytics = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9 .25a.75.75 0 0 0-.75.75v6c0 .414.336.75.75.75h6a.75.75 0 0 0 .75-.75A6.75 6.75 0 0 0 9 .25Zm.75 6V1.804a5.25 5.25 0 0 1 4.447 4.446H9.75ZM7 2.25A6.75 6.75 0 1 0 13.75 9a.75.75 0 0 0-.75-.75H7.75V3A.75.75 0 0 0 7 2.25ZM4.084 4.635a5.25 5.25 0 0 1 2.166-.831V9c0 .414.336.75.75.75h5.197a5.249 5.249 0 0 1-8.909 2.962 5.25 5.25 0 0 1 .796-8.077Z\" }));\nconst ForwardRef = forwardRef(SvgAnalytics);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AnalyticsSvgIcon from '@bloomreach/banana-theme/icons/analytics.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AnalyticsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AnalyticsSvgIcon />\n </BrIcon>\n );\n});\n\nAnalyticsIcon.displayName = 'AnalyticsIcon';\n\nexport default AnalyticsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAndroid = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.25 9.25v6.25c0 .073.021.135.063.188a.29.29 0 0 0 .188.062h9c.072 0 .13-.02.171-.063a.256.256 0 0 0 .079-.187V9.25h-9.5Zm11-1.39a2.63 2.63 0 0 1 1.438.984c.375.49.563 1.041.563 1.656v4a.723.723 0 0 1-.22.531.723.723 0 0 1-.53.219.723.723 0 0 1-.532-.219.723.723 0 0 1-.218-.531v-4c0-.198-.047-.385-.141-.563a1.132 1.132 0 0 0-.36-.437v6c0 .23-.046.453-.14.672a1.632 1.632 0 0 1-.375.578c-.167.156-.36.276-.578.36-.209.093-.427.14-.656.14h-9a1.72 1.72 0 0 1-.875-.234 1.756 1.756 0 0 1-.641-.625 1.75 1.75 0 0 1-.234-.891v-6c-.157.115-.282.26-.375.438a1.305 1.305 0 0 0-.125.562v4a.723.723 0 0 1-.22.531.723.723 0 0 1-.53.219.723.723 0 0 1-.532-.219.723.723 0 0 1-.218-.531v-4c0-.625.187-1.177.562-1.656.375-.49.854-.818 1.438-.985.02-.875.213-1.708.578-2.5a6.226 6.226 0 0 1 1.547-2.046L3.89 1.937a.698.698 0 0 1-.14-.546.74.74 0 0 1 .312-.485.698.698 0 0 1 .547-.14c.208.03.375.13.5.296l1 1.391A6.204 6.204 0 0 1 9 1.75c1.021 0 1.985.234 2.891.703l1-1.39a.73.73 0 0 1 .485-.297.677.677 0 0 1 .562.125.74.74 0 0 1 .297.5c.042.198 0 .38-.125.546l-.984 1.375a6.043 6.043 0 0 1 1.53 2.047c.376.792.574 1.625.595 2.5Zm-3.53-3.75-.094-.063A4.61 4.61 0 0 0 9 3.25a4.616 4.616 0 0 0-2.719.86 4.591 4.591 0 0 0-1.438 1.593A4.702 4.702 0 0 0 4.25 7.75h9.5a4.702 4.702 0 0 0-.594-2.047 4.59 4.59 0 0 0-1.438-1.594ZM6 5.5c0-.208.074-.385.22-.531a.723.723 0 0 1 .53-.219.93.93 0 0 1 .704.297.979.979 0 0 1 .297.719c0 .27-.1.505-.297.703a.954.954 0 0 1-.703.281c-.282 0-.521-.094-.72-.281a.988.988 0 0 1-.28-.703c0-.282.093-.521.28-.72a.979.979 0 0 1 .72-.296.72.72 0 0 1 .53.219.723.723 0 0 1 .22.531.723.723 0 0 1-.22.531.723.723 0 0 1-.53.219.723.723 0 0 1-.532-.219.723.723 0 0 1-.218-.531Zm4.5 0a.72.72 0 0 1 .22-.531.723.723 0 0 1 .53-.219.93.93 0 0 1 .704.297.979.979 0 0 1 .297.719c0 .27-.1.505-.297.703a.954.954 0 0 1-.703.281c-.282 0-.521-.094-.72-.281a.988.988 0 0 1-.28-.703c0-.282.093-.521.28-.72a.979.979 0 0 1 .72-.296.72.72 0 0 1 .53.219.723.723 0 0 1 .22.531.723.723 0 0 1-.22.531.723.723 0 0 1-.53.219.723.723 0 0 1-.532-.219.723.723 0 0 1-.218-.531Z\" }));\nconst ForwardRef = forwardRef(SvgAndroid);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AndroidSvgIcon from '@bloomreach/banana-theme/icons/android.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AndroidIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AndroidSvgIcon />\n </BrIcon>\n );\n});\n\nAndroidIcon.displayName = 'AndroidIcon';\n\nexport default AndroidIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAnonymize = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.941.408a1.551 1.551 0 0 0-.466.065c-.15.046-.314.122-.457.246a.984.984 0 0 0-.333.578l-.817 4.795H1.5a.75.75 0 1 0 0 1.5h15a.75.75 0 0 0 0-1.5h-2.367l-.817-4.795a.983.983 0 0 0-.333-.578 1.254 1.254 0 0 0-.457-.246 1.552 1.552 0 0 0-.933.013L9 1.356 6.408.485A1.534 1.534 0 0 0 5.94.408Zm6.671 5.684H5.39l.097-.57c.096.045.203.07.315.07h6.4a.747.747 0 0 0 .314-.069l.097.569Zm-.704-4.13.364 2.133a.76.76 0 0 0-.07-.003h-6.4a.758.758 0 0 0-.073.003l.364-2.133 2.67.896a.75.75 0 0 0 .476 0l2.67-.896ZM8.176 11.2a3.751 3.751 0 0 0-7.425.75 3.75 3.75 0 0 0 7.425.75h1.65a3.751 3.751 0 0 0 7.425-.75 3.75 3.75 0 0 0-7.425-.75h-1.65Zm-5.925.75a2.25 2.25 0 1 1 4.5 0 2.25 2.25 0 0 1-4.5 0Zm9 0a2.25 2.25 0 1 1 4.5 0 2.25 2.25 0 0 1-4.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgAnonymize);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AnonymizeSvgIcon from '@bloomreach/banana-theme/icons/anonymize.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AnonymizeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AnonymizeSvgIcon />\n </BrIcon>\n );\n});\n\nAnonymizeIcon.displayName = 'AnonymizeIcon';\n\nexport default AnonymizeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgApple = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.5 4.703a.867.867 0 0 0-.53-.265c-.188-.032-.38.026-.579.171-.187.136-.291.303-.312.5-.01.188.062.386.219.594.312.406.526.99.64 1.75a6.814 6.814 0 0 1-.03 2.344c-.168 1.02-.407 1.927-.72 2.719-.302.791-.65 1.422-1.047 1.89-.395.459-.807.724-1.234.797h-.11L8.502 14.5a1.557 1.557 0 0 0-1.594 0l-1.203.5h-.11c-.427-.062-.838-.328-1.234-.797-.396-.468-.75-1.099-1.062-1.89-.302-.792-.537-1.698-.703-2.72a8.62 8.62 0 0 1-.047-2.124c.083-.75.265-1.339.547-1.766.322-.479.724-.729 1.203-.75.541-.031 1.244.219 2.109.75.188.094.396.167.625.219.24.052.464.078.672.078h.203l.39-.406V2.797c.094-.24.09-.432-.015-.578C8.178 2.073 8.016 2 7.798 2c-.25 0-.448.073-.594.219-.135.135-.203.328-.203.578v1.61c-1.136-.699-2.162-.99-3.078-.876-.907.115-1.615.605-2.125 1.47-.386.582-.641 1.322-.766 2.218a9.754 9.754 0 0 0 .063 2.687c.312 1.865.833 3.375 1.562 4.532.76 1.229 1.677 1.916 2.75 2.062.25 0 .427-.01.531-.031a1.02 1.02 0 0 0 .47-.172l1.296-.594h.203l1.297.703c.198.063.349.105.453.125.167.042.313.063.438.063 1.072-.146 1.99-.834 2.75-2.063.729-1.156 1.25-2.666 1.562-4.53a10.02 10.02 0 0 0 0-2.954c-.167-.98-.469-1.76-.906-2.344Zm-2.905.203c.645-.093 1.312-.427 2-1 .583-.698.916-1.4 1-2.109.052-.25.052-.49 0-.719A1.137 1.137 0 0 0 13.298.5c-.146-.24-.334-.39-.563-.453a1.064 1.064 0 0 0-.734.047c-.646.094-1.313.427-2 1-.281.292-.516.62-.703.984a5.237 5.237 0 0 0-.391 1.125 1.75 1.75 0 0 0 0 .735c.052.229.151.416.297.562.198.208.432.354.703.438.27.073.5.062.688-.032ZM11 2.203c.302-.302.703-.505 1.203-.61-.104.5-.307.902-.61 1.204-.291.302-.687.505-1.187.61.094-.5.292-.902.594-1.204Z\" }));\nconst ForwardRef = forwardRef(SvgApple);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AppleSvgIcon from '@bloomreach/banana-theme/icons/apple.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AppleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AppleSvgIcon />\n </BrIcon>\n );\n});\n\nAppleIcon.displayName = 'AppleIcon';\n\nexport default AppleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArchiveAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001.25a.75.75 0 0 1 .75.75v5.44l1.282-1.026a.75.75 0 1 1 .937 1.172L8.473 8.583a.747.747 0 0 1-.947-.002L5.032 6.586a.75.75 0 0 1 .938-1.172L7.25 6.44V1A.75.75 0 0 1 8 .25ZM.764 9.763A1.75 1.75 0 0 1 2 9.25h2.555a.75.75 0 0 1 .651.378 3.217 3.217 0 0 0 5.588 0 .75.75 0 0 1 .651-.378H14A1.75 1.75 0 0 1 15.75 11v3A1.75 1.75 0 0 1 14 15.75H2A1.75 1.75 0 0 1 .251 14v-3c0-.464.184-.91.513-1.237ZM2 10.75a.25.25 0 0 0-.25.25v3a.25.25 0 0 0 .25.25h12a.25.25 0 0 0 .25-.25v-3a.25.25 0 0 0-.25-.25h-2.144a4.717 4.717 0 0 1-7.712 0H2Z\" }));\nconst ForwardRef = forwardRef(SvgArchiveAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArchiveAltSvgIcon from '@bloomreach/banana-theme/icons/archive-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArchiveAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArchiveAltSvgIcon />\n </BrIcon>\n );\n});\n\nArchiveAltIcon.displayName = 'ArchiveAltIcon';\n\nexport default ArchiveAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArchive = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.263 1.263A1.75 1.75 0 0 1 2.501.75h13a1.75 1.75 0 0 1 1.75 1.75v2a.75.75 0 0 1-.75.75h-15a.75.75 0 0 1-.75-.75v-2c0-.464.184-.91.512-1.237Zm1.238.987a.25.25 0 0 0-.25.25v1.25h13.5V2.5a.25.25 0 0 0-.25-.25h-13ZM2.5 5.75a.75.75 0 0 1 .75.75v6a1.25 1.25 0 0 0 1.25 1.25h9a1.25 1.25 0 0 0 1.25-1.25v-6a.75.75 0 0 1 1.5 0v6a2.75 2.75 0 0 1-2.75 2.75h-9a2.75 2.75 0 0 1-2.75-2.75v-6a.75.75 0 0 1 .75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 5.75a1.75 1.75 0 1 0 0 3.5h2a1.75 1.75 0 0 0 0-3.5H8Zm-.176 1.573a.25.25 0 0 1 .177-.073h2a.25.25 0 0 1 0 .5H8a.25.25 0 0 1-.177-.427Z\" }));\nconst ForwardRef = forwardRef(SvgArchive);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArchiveSvgIcon from '@bloomreach/banana-theme/icons/archive.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArchiveIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArchiveSvgIcon />\n </BrIcon>\n );\n});\n\nArchiveIcon.displayName = 'ArchiveIcon';\n\nexport default ArchiveIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowCollapse = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.531 1.47a.75.75 0 0 0-1.06 1.06l3 3a.75.75 0 0 0 1.06 0l3-3a.75.75 0 1 0-1.06-1.06L8 3.94 5.53 1.47Zm0 13.06a.75.75 0 0 1-1.06-1.06l3-3a.75.75 0 0 1 1.06 0l3 3a.75.75 0 1 1-1.06 1.06L8 12.06l-2.47 2.47Z\" }));\nconst ForwardRef = forwardRef(SvgArrowCollapse);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowCollapseSvgIcon from '@bloomreach/banana-theme/icons/arrow-collapse.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowCollapseIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowCollapseSvgIcon />\n </BrIcon>\n );\n});\n\nArrowCollapseIcon.displayName = 'ArrowCollapseIcon';\n\nexport default ArrowCollapseIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowDown = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.99 13.78a.75.75 0 0 0 1.062 0l4.32-4.32a.75.75 0 1 0-1.061-1.061l-3.04 3.04V2.69c0-.382-.336-.691-.75-.691s-.75.31-.75.691v8.747l-3.04-3.04a.75.75 0 0 0-1.06 1.061l4.32 4.32Z\" }));\nconst ForwardRef = forwardRef(SvgArrowDown);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowDownSvgIcon from '@bloomreach/banana-theme/icons/arrow-down.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowDownIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowDownSvgIcon />\n </BrIcon>\n );\n});\n\nArrowDownIcon.displayName = 'ArrowDownIcon';\n\nexport default ArrowDownIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowExpand = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.532 5.03A.75.75 0 0 1 4.47 3.97l3-3a.75.75 0 0 1 1.06 0l3 3a.75.75 0 0 1-1.06 1.06L8 2.56 5.53 5.03Zm0 5.94a.75.75 0 0 0-1.061 1.06l3 3a.75.75 0 0 0 1.06 0l3-3a.75.75 0 1 0-1.06-1.06l-2.47 2.47-2.47-2.47Z\" }));\nconst ForwardRef = forwardRef(SvgArrowExpand);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowExpandSvgIcon from '@bloomreach/banana-theme/icons/arrow-expand.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowExpandIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowExpandSvgIcon />\n </BrIcon>\n );\n});\n\nArrowExpandIcon.displayName = 'ArrowExpandIcon';\n\nexport default ArrowExpandIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowKeyboardNext = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M17.251.998a.75.75 0 1 0-1.5 0v14a.75.75 0 1 0 1.5 0v-14Zm-6.78 3.97a.75.75 0 0 1 1.06 0l2.5 2.5a.748.748 0 0 1 0 1.06l-2.5 2.5a.75.75 0 0 1-1.06-1.06l1.22-1.22H1.5a.75.75 0 0 1 0-1.5h10.19l-1.22-1.22a.75.75 0 0 1 0-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgArrowKeyboardNext);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowKeyboardNextSvgIcon from '@bloomreach/banana-theme/icons/arrow-keyboard-next.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowKeyboardNextIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowKeyboardNextSvgIcon />\n </BrIcon>\n );\n});\n\nArrowKeyboardNextIcon.displayName = 'ArrowKeyboardNextIcon';\n\nexport default ArrowKeyboardNextIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowKeyboardPrevious = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.251.998a.75.75 0 1 0-1.5 0v14a.75.75 0 1 0 1.5 0v-14Zm5.281 3.97a.75.75 0 0 1 0 1.06l-1.22 1.22h10.19a.75.75 0 0 1 0 1.5H6.312l1.22 1.22a.75.75 0 0 1-1.06 1.06l-2.5-2.5A.748.748 0 0 1 3.751 8v-.004c0-.191.073-.382.22-.528l2.5-2.5a.75.75 0 0 1 1.06 0Z\" }));\nconst ForwardRef = forwardRef(SvgArrowKeyboardPrevious);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowKeyboardPreviousSvgIcon from '@bloomreach/banana-theme/icons/arrow-keyboard-previous.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowKeyboardPreviousIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowKeyboardPreviousSvgIcon />\n </BrIcon>\n );\n});\n\nArrowKeyboardPreviousIcon.displayName = 'ArrowKeyboardPreviousIcon';\n\nexport default ArrowKeyboardPreviousIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowKeyboardUp = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15 2.248a.75.75 0 0 0 0-1.5H1a.75.75 0 1 0 0 1.5h14Zm-3.97 5.28a.75.75 0 0 1-1.06 0l-1.22-1.22v10.19a.75.75 0 1 1-1.5 0V6.308l-1.22 1.22a.75.75 0 0 1-1.06-1.06l2.5-2.5a.748.748 0 0 1 .528-.22h.004c.191 0 .382.074.528.22l2.5 2.5a.75.75 0 0 1 0 1.06Z\" }));\nconst ForwardRef = forwardRef(SvgArrowKeyboardUp);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowKeyboardUpSvgIcon from '@bloomreach/banana-theme/icons/arrow-keyboard-up.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowKeyboardUpIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowKeyboardUpSvgIcon />\n </BrIcon>\n );\n});\n\nArrowKeyboardUpIcon.displayName = 'ArrowKeyboardUpIcon';\n\nexport default ArrowKeyboardUpIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowLeft = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.74 7.47a.75.75 0 0 0 0 1.06l4.32 4.32a.75.75 0 1 0 1.06-1.06L4.082 8.75h8.747c.382 0 .692-.336.692-.75 0-.415-.31-.75-.692-.75H4.081l3.04-3.04a.75.75 0 0 0-1.06-1.06L1.74 7.47Z\" }));\nconst ForwardRef = forwardRef(SvgArrowLeft);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowLeftSvgIcon from '@bloomreach/banana-theme/icons/arrow-left.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowLeftIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowLeftSvgIcon />\n </BrIcon>\n );\n});\n\nArrowLeftIcon.displayName = 'ArrowLeftIcon';\n\nexport default ArrowLeftIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowRight = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.3 8.53a.75.75 0 0 0 0-1.06L8.98 3.15a.75.75 0 0 0-1.06 1.06l3.039 3.04H2.212c-.382 0-.691.335-.691.75 0 .414.31.75.69.75h8.748l-3.04 3.04a.75.75 0 0 0 1.061 1.06l4.32-4.32Z\" }));\nconst ForwardRef = forwardRef(SvgArrowRight);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowRightSvgIcon from '@bloomreach/banana-theme/icons/arrow-right.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowRightIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowRightSvgIcon />\n </BrIcon>\n );\n});\n\nArrowRightIcon.displayName = 'ArrowRightIcon';\n\nexport default ArrowRightIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgArrowUp = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.05 2.22a.75.75 0 0 0-1.06 0L2.67 6.54A.75.75 0 1 0 3.73 7.6l3.04-3.04v8.748c0 .382.336.691.75.691.415 0 .75-.31.75-.691V4.56l3.04 3.04a.75.75 0 1 0 1.06-1.061L8.05 2.22Z\" }));\nconst ForwardRef = forwardRef(SvgArrowUp);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ArrowUpSvgIcon from '@bloomreach/banana-theme/icons/arrow-up.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ArrowUpIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ArrowUpSvgIcon />\n </BrIcon>\n );\n});\n\nArrowUpIcon.displayName = 'ArrowUpIcon';\n\nexport default ArrowUpIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAxis = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.47.97a.748.748 0 0 1 1.06 0l1.5 1.5a.75.75 0 1 1-1.06 1.06l-.22-.22v10.44h4.44l-.22-.22a.75.75 0 1 1 1.06-1.06l1.5 1.5a.748.748 0 0 1 0 1.06l-1.5 1.5a.75.75 0 1 1-1.06-1.06l.22-.22H8.75v1.25a.75.75 0 0 1-1.5 0v-1.25H2.811l.22.22a.75.75 0 1 1-1.06 1.06l-1.5-1.5a.748.748 0 0 1 0-1.06l1.5-1.5a.75.75 0 0 1 1.06 1.06l-.22.22h4.44V3.31l-.22.22a.75.75 0 0 1-1.06-1.06l1.5-1.5Z\" }));\nconst ForwardRef = forwardRef(SvgAxis);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AxisSvgIcon from '@bloomreach/banana-theme/icons/axis.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AxisIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AxisSvgIcon />\n </BrIcon>\n );\n});\n\nAxisIcon.displayName = 'AxisIcon';\n\nexport default AxisIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgAxisLimt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1 .75A.75.75 0 0 1 1.75 0h3a.75.75 0 0 1 0 1.5h-3A.75.75 0 0 1 1 .75Zm2.78 2.47a.75.75 0 0 0-1.06 0l-1.5 1.5a.75.75 0 1 0 1.06 1.06l.22-.22V12H.75a.75.75 0 0 0 0 1.5H2.5v1.75a.75.75 0 0 0 1.5 0V13.5h6.44l-.22.22a.75.75 0 1 0 1.06 1.06l1.5-1.5a.75.75 0 0 0 0-1.06l-1.5-1.5a.75.75 0 1 0-1.06 1.06l.22.22H4V5.56l.22.22a.75.75 0 0 0 1.06-1.06l-1.5-1.5ZM16 11.25a.75.75 0 0 0-1.5 0v3a.75.75 0 0 0 1.5 0v-3Z\" }));\nconst ForwardRef = forwardRef(SvgAxisLimt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport AxisLimtSvgIcon from '@bloomreach/banana-theme/icons/axis-limt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst AxisLimtIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <AxisLimtSvgIcon />\n </BrIcon>\n );\n});\n\nAxisLimtIcon.displayName = 'AxisLimtIcon';\n\nexport default AxisLimtIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBarChart = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 .75A1.25 1.25 0 0 0 6.75 2v11.75h-.5V8A1.25 1.25 0 0 0 5 6.75H3A1.25 1.25 0 0 0 1.75 8v5.75H1.5a.75.75 0 0 0 0 1.5h15a.75.75 0 0 0 0-1.5h-.25V5A1.25 1.25 0 0 0 15 3.75h-2A1.25 1.25 0 0 0 11.75 5v8.75h-.5V2A1.25 1.25 0 0 0 10 .75H8Zm1.75 13h-1.5V2.25h1.5v11.5Zm3.5 0v-8.5h1.5v8.5h-1.5Zm-10 0v-5.5h1.5v5.5h-1.5Z\" }));\nconst ForwardRef = forwardRef(SvgBarChart);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BarChartSvgIcon from '@bloomreach/banana-theme/icons/bar-chart.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BarChartIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BarChartSvgIcon />\n </BrIcon>\n );\n});\n\nBarChartIcon.displayName = 'BarChartIcon';\n\nexport default BarChartIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBoolean = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5 7.797a.832.832 0 0 0-.562.219.754.754 0 0 0-.234.578v1a.85.85 0 0 0 .219.578.754.754 0 0 0 .578.234c.25 0 .442-.073.578-.219.146-.145.219-.343.219-.593v-1c-.053-.25-.152-.443-.297-.578a.656.656 0 0 0-.5-.22Zm1-3c-.322 0-.624.083-.906.25-.27.156-.49.375-.656.656a1.75 1.75 0 0 0-.234.89c0 .22.073.412.219.579a.754.754 0 0 0 .578.234c.25 0 .442-.073.578-.218.146-.146.219-.344.219-.594 0-.042.02-.084.062-.125a.194.194 0 0 1 .14-.063.782.782 0 0 0 .548-.218.779.779 0 0 0 .25-.594.73.73 0 0 0-.25-.578.776.776 0 0 0-.547-.22Zm3 0h-1a.832.832 0 0 0-.562.219c-.156.145-.234.343-.234.593 0 .24.067.433.203.579.146.145.344.218.594.218h1c.208 0 .39-.073.546-.218a.779.779 0 0 0 .25-.594.73.73 0 0 0-.25-.578.776.776 0 0 0-.546-.22Zm0 7h-1a.832.832 0 0 0-.562.219c-.156.146-.234.343-.234.593 0 .24.067.433.203.579.146.145.344.218.594.218h1c.208 0 .39-.073.546-.219a.779.779 0 0 0 .25-.593.73.73 0 0 0-.25-.578.776.776 0 0 0-.546-.22Zm6-7h-2.203V2.5c0-.323-.083-.62-.25-.89a1.657 1.657 0 0 0-.656-.657 1.667 1.667 0 0 0-.89-.25h-9c-.323 0-.625.083-.907.25a1.69 1.69 0 0 0-.64.656c-.167.271-.25.568-.25.891v9c0 .323.083.625.25.906.156.271.37.49.64.656.282.157.584.235.907.235h2.203V15.5c0 .323.078.625.234.906.167.271.386.485.656.64.282.168.584.25.907.25h9c.323 0 .62-.082.89-.25.282-.155.5-.369.657-.64.166-.281.25-.583.25-.906v-9c-.052-.5-.24-.906-.563-1.219-.323-.323-.734-.484-1.234-.484Zm.297 10.703a.19.19 0 0 1-.062.14.194.194 0 0 1-.14.063h-9c-.042 0-.084-.02-.126-.062a.194.194 0 0 1-.062-.141v-2.203h.187a.795.795 0 0 0 .563-.219.73.73 0 0 0 .25-.578c0-.25-.073-.443-.219-.578-.146-.146-.344-.219-.594-.219h-.39V11.5a.776.776 0 0 0-.219-.547.751.751 0 0 0-.594-.25c-.24 0-.432.073-.578.219-.146.135-.219.328-.219.578v.203H2.501a.194.194 0 0 1-.14-.062.194.194 0 0 1-.063-.141v-9a.19.19 0 0 1 .062-.14.194.194 0 0 1 .14-.063h9c.053 0 .1.02.141.062a.194.194 0 0 1 .063.141v2.203H11.5a.832.832 0 0 0-.563.219c-.156.146-.234.344-.234.594 0 .24.067.432.203.578.146.135.344.203.594.203h.203V6.5c0 .208.073.396.218.563a.754.754 0 0 0 .579.234c.25 0 .442-.068.578-.203.146-.146.218-.344.218-.594v-.297H15.5c.052 0 .099.021.14.063a.194.194 0 0 1 .063.14V15.5h.093Zm-3.296-4.703a.832.832 0 0 0-.563.219.754.754 0 0 0-.234.578.191.191 0 0 1-.063.14.195.195 0 0 1-.14.063.832.832 0 0 0-.563.219c-.156.146-.234.343-.234.593 0 .24.067.433.203.579.146.145.344.218.594.218.323 0 .62-.078.89-.234.281-.167.5-.386.656-.656.167-.282.25-.589.25-.922-.052-.25-.15-.443-.296-.578a.656.656 0 0 0-.5-.22Zm0-3a.832.832 0 0 0-.563.219.753.753 0 0 0-.234.578v1c0 .219.073.411.218.578a.754.754 0 0 0 .579.234c.25 0 .442-.073.578-.219.146-.145.218-.343.218-.593v-1c-.052-.25-.15-.443-.296-.578a.656.656 0 0 0-.5-.22Z\" }));\nconst ForwardRef = forwardRef(SvgBoolean);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BooleanSvgIcon from '@bloomreach/banana-theme/icons/boolean.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BooleanIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BooleanSvgIcon />\n </BrIcon>\n );\n});\n\nBooleanIcon.displayName = 'BooleanIcon';\n\nexport default BooleanIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBracketsCancel = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.501 2.25a.25.25 0 0 0-.25.25v13a.25.25 0 0 0 .25.25h2.5a.75.75 0 0 1 0 1.5H2.5A1.75 1.75 0 0 1 .75 15.5v-13A1.75 1.75 0 0 1 2.501.75h2.5a.75.75 0 0 1 0 1.5H2.5Zm9.749-.75A.75.75 0 0 1 13 .75h2.5a1.75 1.75 0 0 1 1.75 1.75v13a1.75 1.75 0 0 1-1.75 1.75H13a.75.75 0 0 1 0-1.5h2.5a.25.25 0 0 0 .25-.25v-13a.25.25 0 0 0-.25-.25H13a.75.75 0 0 1-.75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.97 5.97a.75.75 0 0 1 1.061 0l1.97 1.97 1.97-1.97a.75.75 0 1 1 1.06 1.06L10.061 9l1.97 1.97a.75.75 0 1 1-1.06 1.06L9 10.06l-1.97 1.97a.75.75 0 0 1-1.06-1.06L7.94 9 5.97 7.03a.75.75 0 0 1 0-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgBracketsCancel);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BracketsCancelSvgIcon from '@bloomreach/banana-theme/icons/brackets-cancel.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BracketsCancelIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BracketsCancelSvgIcon />\n </BrIcon>\n );\n});\n\nBracketsCancelIcon.displayName = 'BracketsCancelIcon';\n\nexport default BracketsCancelIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBrackets = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.501 2.25a.25.25 0 0 0-.25.25v13a.25.25 0 0 0 .25.25h2.5a.75.75 0 0 1 0 1.5H2.5A1.75 1.75 0 0 1 .75 15.5v-13A1.75 1.75 0 0 1 2.501.75h2.5a.75.75 0 0 1 0 1.5H2.5Zm9.75-.75A.75.75 0 0 1 13 .75h2.5a1.75 1.75 0 0 1 1.75 1.75v13a1.75 1.75 0 0 1-1.75 1.75H13a.75.75 0 0 1 0-1.5h2.5a.25.25 0 0 0 .25-.25v-13a.25.25 0 0 0-.25-.25H13a.75.75 0 0 1-.75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgBrackets);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BracketsSvgIcon from '@bloomreach/banana-theme/icons/brackets.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BracketsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BracketsSvgIcon />\n </BrIcon>\n );\n});\n\nBracketsIcon.displayName = 'BracketsIcon';\n\nexport default BracketsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBrowser = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.508.752a2.25 2.25 0 0 0-2.25 2.25v10a2.25 2.25 0 0 0 2.25 2.25h11a2.25 2.25 0 0 0 2.25-2.25v-10a2.25 2.25 0 0 0-2.25-2.25h-11Zm11.75 3h-12.5v-.75a.75.75 0 0 1 .75-.75h11a.75.75 0 0 1 .75.75v.75Zm-12.5 1.5h12.5v7.75a.75.75 0 0 1-.75.75h-11a.75.75 0 0 1-.75-.75v-7.75Z\" }));\nconst ForwardRef = forwardRef(SvgBrowser);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BrowserSvgIcon from '@bloomreach/banana-theme/icons/browser.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BrowserIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BrowserSvgIcon />\n </BrIcon>\n );\n});\n\nBrowserIcon.displayName = 'BrowserIcon';\n\nexport default BrowserIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgBrowserPush = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 17, fill: \"currentColor\", viewBox: \"0 0 17 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.572.75h11.855a1.83 1.83 0 0 1 1.824 1.825V6a.75.75 0 0 1-1.5 0v-.75h-12.5v7.672a.33.33 0 0 0 .328.328h2.922a.75.75 0 0 1 0 1.5H2.575a1.83 1.83 0 0 1-1.824-1.824V2.569A1.825 1.825 0 0 1 2.571.75h.001Zm-.32 3h12.5V2.578a.33.33 0 0 0-.33-.328H2.575a.325.325 0 0 0-.323.323V3.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M16.001 13.25a.25.25 0 0 1-.25-.25v-2a3.25 3.25 0 1 0-6.5 0v2a.25.25 0 0 1-.25.25.75.75 0 0 0 0 1.5h3.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2h3.5a.75.75 0 0 0 0-1.5Zm-3.5-4a1.75 1.75 0 0 1 1.75 1.75v2c0 .084.006.168.018.25h-3.536c.012-.082.018-.166.018-.25v-2a1.75 1.75 0 0 1 1.75-1.75Zm.098 6.99a.503.503 0 0 1-.56-.299.5.5 0 1 1 .56.3Z\" }));\nconst ForwardRef = forwardRef(SvgBrowserPush);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport BrowserPushSvgIcon from '@bloomreach/banana-theme/icons/browser-push.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst BrowserPushIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <BrowserPushSvgIcon />\n </BrIcon>\n );\n});\n\nBrowserPushIcon.displayName = 'BrowserPushIcon';\n\nexport default BrowserPushIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCalendarAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.751 10.25a1 1 0 1 1 2 0 1 1 0 0 1-2 0Zm1 2.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm3.25-2.5a1 1 0 1 1 2 0 1 1 0 0 1-2 0Zm1 2.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm3.25-2.5a1 1 0 1 1 2 0 1 1 0 0 1-2 0Zm1 2.5a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.501.75a.75.75 0 0 1 .75.75v1.25h5.5V1.5a.75.75 0 0 1 1.5 0v1.25h1.75A2.25 2.25 0 0 1 17.251 5v10a2.25 2.25 0 0 1-2.25 2.25h-12A2.25 2.25 0 0 1 .751 15V5a2.25 2.25 0 0 1 2.25-2.25h1.75V1.5a.75.75 0 0 1 .75-.75Zm6.25 3.5h-5.5V5a.75.75 0 1 1-1.5 0v-.75h-1.75a.75.75 0 0 0-.75.75v1.75h13.5V5a.75.75 0 0 0-.75-.75h-1.75V5a.75.75 0 0 1-1.5 0v-.75Zm-9.5 4V15c0 .414.336.75.75.75h12a.75.75 0 0 0 .75-.75V8.25h-13.5Z\" }));\nconst ForwardRef = forwardRef(SvgCalendarAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CalendarAltSvgIcon from '@bloomreach/banana-theme/icons/calendar-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CalendarAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CalendarAltSvgIcon />\n </BrIcon>\n );\n});\n\nCalendarAltIcon.displayName = 'CalendarAltIcon';\n\nexport default CalendarAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCalendar = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.503.75a.75.75 0 0 1 .75.75v1.25h5.5V1.5a.75.75 0 0 1 1.5 0v1.25h2.25c.966 0 1.75.784 1.75 1.75v11a1.75 1.75 0 0 1-1.75 1.75h-13a1.75 1.75 0 0 1-1.75-1.75v-11c0-.966.783-1.75 1.75-1.75h2.25V1.5a.75.75 0 0 1 .75-.75Zm6.25 3.5h-5.5V5a.75.75 0 1 1-1.5 0v-.75h-2.25a.25.25 0 0 0-.25.25v2.25h13.5V4.5a.25.25 0 0 0-.25-.25h-2.25V5a.75.75 0 0 1-1.5 0v-.75Zm4 4h-13.5v7.25c0 .138.111.25.25.25h13a.25.25 0 0 0 .25-.25V8.25Z\" }));\nconst ForwardRef = forwardRef(SvgCalendar);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CalendarSvgIcon from '@bloomreach/banana-theme/icons/calendar.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CalendarIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CalendarSvgIcon />\n </BrIcon>\n );\n});\n\nCalendarIcon.displayName = 'CalendarIcon';\n\nexport default CalendarIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCatalog = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.251 6a.75.75 0 0 1 .75-.75h6.667a.75.75 0 0 1 0 1.5H7.001a.75.75 0 0 1-.75-.75Zm-1.916-.75a.75.75 0 1 0 0 1.5H5a.75.75 0 1 0 0-1.5h-.666ZM3.585 9a.75.75 0 0 1 .75-.75H5a.75.75 0 1 1 0 1.5h-.666a.75.75 0 0 1-.75-.75Zm3.416-.75a.75.75 0 0 0 0 1.5h6.667a.75.75 0 0 0 0-1.5H7.001ZM6.251 12a.75.75 0 0 1 .75-.75h6.667a.75.75 0 0 1 0 1.5H7.001a.75.75 0 0 1-.75-.75Zm-1.916-.75a.75.75 0 0 0 0 1.5H5a.75.75 0 0 0 0-1.5h-.666Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 2.502c0-.967.784-1.75 1.75-1.75h13c.967 0 1.75.783 1.75 1.75v13a1.75 1.75 0 0 1-1.75 1.75h-13a1.75 1.75 0 0 1-1.75-1.75v-13Zm1.75-.25a.25.25 0 0 0-.25.25v13c0 .138.112.25.25.25h13a.25.25 0 0 0 .25-.25v-13a.25.25 0 0 0-.25-.25h-13Z\" }));\nconst ForwardRef = forwardRef(SvgCatalog);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CatalogSvgIcon from '@bloomreach/banana-theme/icons/catalog.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CatalogIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CatalogSvgIcon />\n </BrIcon>\n );\n});\n\nCatalogIcon.displayName = 'CatalogIcon';\n\nexport default CatalogIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChatAdd = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.25 3.75a.75.75 0 0 1 .75.75v2.25h2.25a.75.75 0 0 1 0 1.5H10v2.25a.75.75 0 1 1-1.5 0V8.25H6.25a.75.75 0 1 1 0-1.5H8.5V4.5a.75.75 0 0 1 .75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5.75A1.75 1.75 0 0 0 .75 2.5v10a1.75 1.75 0 0 0 1.75 1.75h1.25v2.25a.75.75 0 0 0 1.2.6l3.8-2.85h6.75a1.75 1.75 0 0 0 1.75-1.75v-10A1.75 1.75 0 0 0 15.5.75h-13Zm-.177 1.573A.25.25 0 0 1 2.5 2.25h13a.25.25 0 0 1 .25.25v10a.25.25 0 0 1-.25.25h-7a.75.75 0 0 0-.45.15L5.25 15v-1.5a.75.75 0 0 0-.75-.75h-2a.25.25 0 0 1-.25-.25v-10a.25.25 0 0 1 .073-.177Z\" }));\nconst ForwardRef = forwardRef(SvgChatAdd);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChatAddSvgIcon from '@bloomreach/banana-theme/icons/chat-add.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChatAddIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChatAddSvgIcon />\n </BrIcon>\n );\n});\n\nChatAddIcon.displayName = 'ChatAddIcon';\n\nexport default ChatAddIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChat = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.751 6a.75.75 0 0 1 .75-.75h9a.75.75 0 0 1 0 1.5h-9a.75.75 0 0 1-.75-.75Zm.75 2.25a.75.75 0 0 0 0 1.5h7a.75.75 0 0 0 0-1.5h-7Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.264 1.263A1.75 1.75 0 0 1 2.501.75h13a1.75 1.75 0 0 1 1.75 1.75v10a1.75 1.75 0 0 1-1.75 1.75h-6.75l-3.8 2.85a.75.75 0 0 1-1.2-.6v-2.25h-1.25a1.75 1.75 0 0 1-1.75-1.75v-10c0-.464.185-.91.513-1.237Zm1.237.987a.25.25 0 0 0-.25.25v10a.25.25 0 0 0 .25.25h2a.75.75 0 0 1 .75.75V15l2.8-2.1a.75.75 0 0 1 .45-.15h7a.25.25 0 0 0 .25-.25v-10a.25.25 0 0 0-.25-.25h-13Z\" }));\nconst ForwardRef = forwardRef(SvgChat);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChatSvgIcon from '@bloomreach/banana-theme/icons/chat.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChatIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChatSvgIcon />\n </BrIcon>\n );\n});\n\nChatIcon.displayName = 'ChatIcon';\n\nexport default ChatIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChats = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.28 2.29a.15.15 0 0 1 .104-.04h11.491a.15.15 0 0 1 .104.04.75.75 0 0 0 1.042-1.079 1.65 1.65 0 0 0-1.146-.46H2.384a1.65 1.65 0 0 0-1.146.46A1.59 1.59 0 0 0 .75 2.354v8.542c0 .434.179.845.488 1.144a.75.75 0 0 0 1.042-1.08.09.09 0 0 1-.03-.064V2.354a.09.09 0 0 1 .03-.064Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.255 3.75A1.505 1.505 0 0 0 3.75 5.255v8.07a1.505 1.505 0 0 0 1.505 1.505h.916v1.722a.698.698 0 0 0 1.117.559l3.041-2.281h5.416a1.505 1.505 0 0 0 1.505-1.506V5.255a1.505 1.505 0 0 0-1.505-1.505H5.255Zm-.077 1.43a.109.109 0 0 1 .077-.032h10.49a.108.108 0 0 1 .109.108v8.07a.109.109 0 0 1-.11.108h-5.647a.698.698 0 0 0-.42.14l-2.11 1.582v-1.024a.698.698 0 0 0-.698-.698H5.255a.108.108 0 0 1-.108-.109v-8.07c0-.028.011-.056.031-.076Z\" }));\nconst ForwardRef = forwardRef(SvgChats);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChatsSvgIcon from '@bloomreach/banana-theme/icons/chats.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChatsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChatsSvgIcon />\n </BrIcon>\n );\n});\n\nChatsIcon.displayName = 'ChatsIcon';\n\nexport default ChatsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCheckCircle = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 1.75a6.25 6.25 0 1 0 0 12.5 6.25 6.25 0 0 0 0-12.5ZM.25 8a7.75 7.75 0 1 1 15.5 0A7.75 7.75 0 0 1 .25 8Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.461 5.408a.75.75 0 0 1 .131 1.053l-3.71 4.767a1.327 1.327 0 0 1-1.699.355 1.329 1.329 0 0 1-.454-.416l-1.343-1.92a.75.75 0 1 1 1.229-.86l1.22 1.743 3.573-4.59a.75.75 0 0 1 1.053-.132Zm-4.489 4.92-.002-.004.002.003Z\" }));\nconst ForwardRef = forwardRef(SvgCheckCircle);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CheckCircleSvgIcon from '@bloomreach/banana-theme/icons/check-circle.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CheckCircleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CheckCircleSvgIcon />\n </BrIcon>\n );\n});\n\nCheckCircleIcon.displayName = 'CheckCircleIcon';\n\nexport default CheckCircleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCheckFilled = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0Zm-4.408-1.539a.75.75 0 1 0-1.184-.921l-3.573 4.59-1.22-1.743a.75.75 0 1 0-1.23.86l1.344 1.92a1.328 1.328 0 0 0 1.672.453c.19-.091.354-.226.48-.392l3.711-4.767Z\" }));\nconst ForwardRef = forwardRef(SvgCheckFilled);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CheckFilledSvgIcon from '@bloomreach/banana-theme/icons/check-filled.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CheckFilledIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CheckFilledSvgIcon />\n </BrIcon>\n );\n});\n\nCheckFilledIcon.displayName = 'CheckFilledIcon';\n\nexport default CheckFilledIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCheck = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.439 3.392a.75.75 0 0 1 .17 1.047l-6.186 8.583a1.732 1.732 0 0 1-.617.542 1.646 1.646 0 0 1-1.613-.052 1.747 1.747 0 0 1-.58-.574L2.37 9.478a.75.75 0 1 1 1.258-.815l2.247 3.465.009.015c.025.04.054.067.082.084a.154.154 0 0 0 .074.023.147.147 0 0 0 .073-.017.234.234 0 0 0 .083-.075l.006-.01 6.189-8.586a.75.75 0 0 1 1.047-.17Z\" }));\nconst ForwardRef = forwardRef(SvgCheck);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CheckSvgIcon from '@bloomreach/banana-theme/icons/check.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CheckIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CheckSvgIcon />\n </BrIcon>\n );\n});\n\nCheckIcon.displayName = 'CheckIcon';\n\nexport default CheckIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCheckSmall = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.461 5.408a.75.75 0 0 1 .131 1.053l-3.71 4.767a1.328 1.328 0 0 1-1.699.355 1.328 1.328 0 0 1-.453-.416l-1.344-1.92a.75.75 0 0 1 1.229-.86l1.22 1.743 3.574-4.59a.75.75 0 0 1 1.052-.132Zm-4.488 4.92-.003-.004.003.003Z\" }));\nconst ForwardRef = forwardRef(SvgCheckSmall);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CheckSmallSvgIcon from '@bloomreach/banana-theme/icons/check-small.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CheckSmallIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CheckSmallSvgIcon />\n </BrIcon>\n );\n});\n\nCheckSmallIcon.displayName = 'CheckSmallIcon';\n\nexport default CheckSmallIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronDownFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.415 5c-.891 0-1.337 1.077-.707 1.707l2.586 2.586a1 1 0 0 0 1.414 0l2.586-2.586c.63-.63.183-1.707-.708-1.707H5.415Z\" }));\nconst ForwardRef = forwardRef(SvgChevronDownFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronDownFillSvgIcon from '@bloomreach/banana-theme/icons/chevron-down-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronDownFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronDownFillSvgIcon />\n </BrIcon>\n );\n});\n\nChevronDownFillIcon.displayName = 'ChevronDownFillIcon';\n\nexport default ChevronDownFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronDown = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.47 6.47a.75.75 0 0 1 1.06 0L8 8.94l2.47-2.47a.75.75 0 0 1 1.06 1.06l-3 3a.75.75 0 0 1-1.06 0l-3-3a.75.75 0 0 1 0-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgChevronDown);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronDownSvgIcon from '@bloomreach/banana-theme/icons/chevron-down.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronDownIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronDownSvgIcon />\n </BrIcon>\n );\n});\n\nChevronDownIcon.displayName = 'ChevronDownIcon';\n\nexport default ChevronDownIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronLeftFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10 5.414c0-.89-1.076-1.337-1.706-.707L5.708 7.293a1 1 0 0 0 0 1.414l2.586 2.586c.63.63 1.707.184 1.707-.707V5.414Z\" }));\nconst ForwardRef = forwardRef(SvgChevronLeftFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronLeftFillSvgIcon from '@bloomreach/banana-theme/icons/chevron-left-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronLeftFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronLeftFillSvgIcon />\n </BrIcon>\n );\n});\n\nChevronLeftFillIcon.displayName = 'ChevronLeftFillIcon';\n\nexport default ChevronLeftFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronLeft = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.531 4.47a.75.75 0 0 1 0 1.06L7.061 8l2.47 2.47a.75.75 0 0 1-1.06 1.06l-3-3a.75.75 0 0 1 0-1.06l3-3a.75.75 0 0 1 1.06 0Z\" }));\nconst ForwardRef = forwardRef(SvgChevronLeft);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronLeftSvgIcon from '@bloomreach/banana-theme/icons/chevron-left.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronLeftIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronLeftSvgIcon />\n </BrIcon>\n );\n});\n\nChevronLeftIcon.displayName = 'ChevronLeftIcon';\n\nexport default ChevronLeftIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronRightFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.001 10.586c0 .89 1.077 1.337 1.707.707l2.586-2.586a1 1 0 0 0 0-1.414L7.708 4.707c-.63-.63-1.707-.184-1.707.707v5.172Z\" }));\nconst ForwardRef = forwardRef(SvgChevronRightFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronRightFillSvgIcon from '@bloomreach/banana-theme/icons/chevron-right-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronRightFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronRightFillSvgIcon />\n </BrIcon>\n );\n});\n\nChevronRightFillIcon.displayName = 'ChevronRightFillIcon';\n\nexport default ChevronRightFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronRight = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.47 11.53a.75.75 0 0 1 0-1.06L8.94 8 6.47 5.53a.75.75 0 1 1 1.061-1.06l3 3a.75.75 0 0 1 0 1.06l-3 3a.75.75 0 0 1-1.06 0Z\" }));\nconst ForwardRef = forwardRef(SvgChevronRight);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronRightSvgIcon from '@bloomreach/banana-theme/icons/chevron-right.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronRightIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronRightSvgIcon />\n </BrIcon>\n );\n});\n\nChevronRightIcon.displayName = 'ChevronRightIcon';\n\nexport default ChevronRightIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronUpFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.416 10c-.891 0-1.338-1.077-.708-1.707l2.586-2.586a1 1 0 0 1 1.414 0l2.586 2.586c.63.63.184 1.707-.707 1.707H5.416Z\" }));\nconst ForwardRef = forwardRef(SvgChevronUpFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronUpFillSvgIcon from '@bloomreach/banana-theme/icons/chevron-up-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronUpFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronUpFillSvgIcon />\n </BrIcon>\n );\n});\n\nChevronUpFillIcon.displayName = 'ChevronUpFillIcon';\n\nexport default ChevronUpFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgChevronUp = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.47 5.47a.75.75 0 0 1 1.061 0l3 3a.75.75 0 1 1-1.06 1.06L8 7.06 5.53 9.53a.75.75 0 1 1-1.06-1.06l3-3Z\" }));\nconst ForwardRef = forwardRef(SvgChevronUp);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ChevronUpSvgIcon from '@bloomreach/banana-theme/icons/chevron-up.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ChevronUpIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ChevronUpSvgIcon />\n </BrIcon>\n );\n});\n\nChevronUpIcon.displayName = 'ChevronUpIcon';\n\nexport default ChevronUpIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClearFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.66 2.343a7.996 7.996 0 1 0 0 11.314 8.01 8.01 0 0 0 0-11.314Zm-2.52 7.843a.666.666 0 0 1-.939.944L8.128 9.056a.168.168 0 0 0-.236 0L5.82 11.13a.68.68 0 0 1-.943 0 .667.667 0 0 1 0-.944L6.95 8.113a.166.166 0 0 0 0-.235L4.876 5.805a.667.667 0 0 1 .94-.944L7.89 6.935a.167.167 0 0 0 .236 0l2.073-2.074a.667.667 0 0 1 .943.944L9.067 7.878a.167.167 0 0 0 0 .235l2.074 2.073Z\" }));\nconst ForwardRef = forwardRef(SvgClearFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ClearFillSvgIcon from '@bloomreach/banana-theme/icons/clear-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ClearFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ClearFillSvgIcon />\n </BrIcon>\n );\n});\n\nClearFillIcon.displayName = 'ClearFillIcon';\n\nexport default ClearFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClear = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.53 5.47a.75.75 0 0 1 0 1.06L10.06 9l2.47 2.47a.75.75 0 0 1-1.06 1.06L9 10.06l-2.47 2.47a.75.75 0 1 1-1.06-1.06L7.939 9l-2.47-2.47a.75.75 0 1 1 1.06-1.06L9 7.94l2.47-2.47a.75.75 0 0 1 1.06 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.75 9a8.25 8.25 0 1 1 16.5 0A8.25 8.25 0 0 1 .75 9ZM9 2.25a6.75 6.75 0 1 0 0 13.5 6.75 6.75 0 0 0 0-13.5Z\" }));\nconst ForwardRef = forwardRef(SvgClear);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ClearSvgIcon from '@bloomreach/banana-theme/icons/clear.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ClearIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ClearSvgIcon />\n </BrIcon>\n );\n});\n\nClearIcon.displayName = 'ClearIcon';\n\nexport default ClearIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClipboardAdd = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.703 2h-1.11c-.051-.312-.181-.557-.39-.734-.198-.177-.463-.266-.797-.266H10a2.034 2.034 0 0 0-.86-.719A2.463 2.463 0 0 0 8 .001a2.34 2.34 0 0 0-1.11.28 2.77 2.77 0 0 0-.89.72h-.406c-.177 0-.308.01-.39.03a1.01 1.01 0 0 0-.407.266c-.104.104-.214.287-.328.547L4.406 2H3.203c-.302 0-.594.073-.875.219-.27.146-.495.349-.672.61a1.59 1.59 0 0 0-.25.874v10.704c0 .49.172.895.516 1.218.344.313.77.469 1.281.469h9.5c.302 0 .589-.073.86-.219.28-.146.505-.349.671-.61.178-.26.266-.546.266-.859V3.704c0-.5-.177-.906-.531-1.218-.344-.323-.766-.485-1.266-.485Zm-6.906.406h.5a.83.83 0 0 0 .375-.078c.114-.052.224-.13.328-.234.094-.188.23-.333.406-.438A1.21 1.21 0 0 1 8 1.5c.208 0 .401.052.578.156.188.105.328.25.422.438.104.104.208.182.313.234a.934.934 0 0 0 .39.078h.5v1.5H5.797v-1.5Zm7.297 11.891c0 .052-.026.1-.078.14a.342.342 0 0 1-.22.063H3.204c-.198 0-.297-.099-.297-.297V3.594c0-.052.026-.094.078-.125a.342.342 0 0 1 .22-.063h1.202v.688c0 .354.11.646.328.875.23.219.516.328.86.328h4.812c.344 0 .625-.11.844-.328.23-.23.344-.52.344-.875v-.688h1.203c.198 0 .297.1.297.297v10.594ZM9.906 9.203H8.703V8a.68.68 0 0 0-.203-.5.68.68 0 0 0-.5-.203.68.68 0 0 0-.5.203.68.68 0 0 0-.203.5v1.203H6.094a.68.68 0 0 0-.5.203.676.676 0 0 0-.188.5.71.71 0 0 0 .188.5.71.71 0 0 0 .5.188h1.203v1.203a.68.68 0 0 0 .203.5.68.68 0 0 0 .5.203.68.68 0 0 0 .5-.203.68.68 0 0 0 .203-.5v-1.203h1.203c.198 0 .36-.063.485-.188a.68.68 0 0 0 .203-.5.648.648 0 0 0-.203-.5.63.63 0 0 0-.485-.203Z\" }));\nconst ForwardRef = forwardRef(SvgClipboardAdd);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ClipboardAddSvgIcon from '@bloomreach/banana-theme/icons/clipboard-add.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ClipboardAddIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ClipboardAddSvgIcon />\n </BrIcon>\n );\n});\n\nClipboardAddIcon.displayName = 'ClipboardAddIcon';\n\nexport default ClipboardAddIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClockCircle = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 4.75a.75.75 0 0 1 .75.75v2.19l2.905 2.905a.75.75 0 0 1-1.06 1.06L7.47 8.532A.748.748 0 0 1 7.25 8V5.5A.75.75 0 0 1 8 4.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.25 8a7.75 7.75 0 1 1 15.5 0A7.75 7.75 0 0 1 .25 8ZM8 1.75a6.25 6.25 0 1 0 0 12.5 6.25 6.25 0 0 0 0-12.5Z\" }));\nconst ForwardRef = forwardRef(SvgClockCircle);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ClockCircleSvgIcon from '@bloomreach/banana-theme/icons/clock-circle.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ClockCircleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ClockCircleSvgIcon />\n </BrIcon>\n );\n});\n\nClockCircleIcon.displayName = 'ClockCircleIcon';\n\nexport default ClockCircleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClone = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.395 1.84a3.669 3.669 0 0 1 6.263 2.595c0 1.025-.504 1.837-.887 2.454l-.036.057c-.423.682-.698 1.16-.698 1.728 0 .41.085.673.199.82.087.112.265.256.737.256h1.989c.954 0 1.713.311 2.265.828.539.506.828 1.16.95 1.777.121.61.09 1.24-.074 1.75a1.975 1.975 0 0 1-.402.73 1.297 1.297 0 0 1-.497.342v.323a1.75 1.75 0 0 1-1.741 1.75H3.516a1.75 1.75 0 0 1-1.74-1.75v-.322a1.275 1.275 0 0 1-.504-.352 1.942 1.942 0 0 1-.388-.737c-.15-.504-.172-1.122-.073-1.713.1-.592.334-1.232.768-1.739A2.49 2.49 0 0 1 3.52 9.75h2.486c.472 0 .65-.144.737-.256.115-.147.2-.41.2-.82 0-.569-.276-1.046-.699-1.728L6.21 6.89c-.384-.617-.888-1.429-.888-2.454 0-.973.386-1.906 1.074-2.594ZM2.353 13.75h13.282a.917.917 0 0 0 .04-.104 2.1 2.1 0 0 0 .03-1c-.075-.384-.244-.73-.505-.974-.248-.232-.63-.422-1.238-.422h-1.989c-.826 0-1.49-.28-1.922-.836-.404-.521-.514-1.171-.514-1.74 0-1.032.506-1.847.89-2.466l.033-.052c.424-.684.698-1.158.698-1.721a2.169 2.169 0 0 0-4.337 0c0 .563.274 1.037.698 1.72.01.018.022.035.033.053.384.619.89 1.434.89 2.466 0 .569-.11 1.219-.514 1.74-.431.556-1.096.836-1.922.836H3.52a.992.992 0 0 0-.802.363c-.208.244-.359.604-.427 1.012-.07.409-.043.79.03 1.036.01.035.022.065.032.09Zm.923 1.5v.25a.25.25 0 0 0 .247.25h10.933a.25.25 0 0 0 .248-.25v-.25H3.276Z\" }));\nconst ForwardRef = forwardRef(SvgClone);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CloneSvgIcon from '@bloomreach/banana-theme/icons/clone.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CloneIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CloneSvgIcon />\n </BrIcon>\n );\n});\n\nCloneIcon.displayName = 'CloneIcon';\n\nexport default CloneIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgClose = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.529 2.47a.75.75 0 1 0-1.06 1.06L6.938 8l-4.47 4.47a.75.75 0 0 0 1.06 1.06L8 9.06l4.47 4.47a.75.75 0 1 0 1.06-1.06L9.06 8l4.47-4.47a.75.75 0 1 0-1.061-1.06l-4.47 4.47-4.47-4.47Z\" }));\nconst ForwardRef = forwardRef(SvgClose);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CloseSvgIcon from '@bloomreach/banana-theme/icons/close.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CloseIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CloseSvgIcon />\n </BrIcon>\n );\n});\n\nCloseIcon.displayName = 'CloseIcon';\n\nexport default CloseIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCloseSmall = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.83 10.79a.7.7 0 0 0 .5.21l.01.02a.71.71 0 0 0 .49-1.2L9.008 7.996 10.83 6.18a.707.707 0 0 0-1-1L8.004 6.994 6.18 5.17a.707.707 0 0 0-1 1l1.827 1.815L5.18 9.8a.71.71 0 0 0 .49 1.2.7.7 0 0 0 .5-.18l1.844-1.835L9.83 10.79Z\" }));\nconst ForwardRef = forwardRef(SvgCloseSmall);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CloseSmallSvgIcon from '@bloomreach/banana-theme/icons/close-small.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CloseSmallIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CloseSmallSvgIcon />\n </BrIcon>\n );\n});\n\nCloseSmallIcon.displayName = 'CloseSmallIcon';\n\nexport default CloseSmallIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCloudCheck = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.78.795a5.751 5.751 0 0 1 6.102 3.698 3.997 3.997 0 0 1 5.245 2.76.75.75 0 0 1-1.453.373 2.497 2.497 0 0 0-3.84-1.432.75.75 0 0 1-1.164-.478A4.25 4.25 0 1 0 6.5 10.75a.75.75 0 0 1 .002 1.5A5.75 5.75 0 0 1 5.78.795Zm8.952 9.942a.75.75 0 0 1 .151 1.05l-1.934 2.584a1.25 1.25 0 0 1-1.883.133l-1-1a.75.75 0 1 1 1.06-1.06l.796.795 1.76-2.35a.75.75 0 0 1 1.05-.152Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.75 12.501a4.75 4.75 0 1 1 9.5 0 4.75 4.75 0 0 1-9.5 0Zm4.75-3.25a3.25 3.25 0 1 0 0 6.5 3.25 3.25 0 0 0 0-6.5Z\" }));\nconst ForwardRef = forwardRef(SvgCloudCheck);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CloudCheckSvgIcon from '@bloomreach/banana-theme/icons/cloud-check.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CloudCheckIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CloudCheckSvgIcon />\n </BrIcon>\n );\n});\n\nCloudCheckIcon.displayName = 'CloudCheckIcon';\n\nexport default CloudCheckIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCloudDownload = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.982.773a5.751 5.751 0 0 1 5.901 3.72 3.997 3.997 0 0 1 3.776.56 3.997 3.997 0 0 1 .143 6.283 4.001 4.001 0 0 1-1.63.808c-.344.081-.696.106-2.171.106a.75.75 0 0 1 0-1.5c1.525 0 1.688-.033 1.828-.066a2.5 2.5 0 1 0-1.995-4.49.75.75 0 0 1-1.163-.478 4.25 4.25 0 1 0-4.618 5.011.75.75 0 0 1-.155 1.492A5.75 5.75 0 0 1 5.982.773Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9 9.75a.75.75 0 0 1 .75.75v4.19l1.22-1.22a.75.75 0 0 1 1.061 1.06l-2.5 2.5a.748.748 0 0 1-1.06 0l-2.5-2.5a.75.75 0 0 1 1.06-1.06l1.22 1.22V10.5A.75.75 0 0 1 9 9.75Z\" }));\nconst ForwardRef = forwardRef(SvgCloudDownload);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CloudDownloadSvgIcon from '@bloomreach/banana-theme/icons/cloud-download.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CloudDownloadIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CloudDownloadSvgIcon />\n </BrIcon>\n );\n});\n\nCloudDownloadIcon.displayName = 'CloudDownloadIcon';\n\nexport default CloudDownloadIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCode = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.617 3.53a.75.75 0 1 0-1.06-1.06L1.263 6.763a1.75 1.75 0 0 0 0 2.474l4.294 4.294a.75.75 0 1 0 1.06-1.061L2.324 8.177a.25.25 0 0 1 0-.354l4.293-4.292Zm5.828-1.06a.75.75 0 1 0-1.06 1.06l4.293 4.293a.25.25 0 0 1 0 .354l-4.294 4.293a.75.75 0 0 0 1.061 1.06l4.294-4.293a1.75 1.75 0 0 0 0-2.474L12.444 2.47Z\" }));\nconst ForwardRef = forwardRef(SvgCode);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CodeSvgIcon from '@bloomreach/banana-theme/icons/code.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CodeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CodeSvgIcon />\n </BrIcon>\n );\n});\n\nCodeIcon.displayName = 'CodeIcon';\n\nexport default CodeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgColorPickerAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.28 8.782a.75.75 0 1 0-1.06-1.06l-4.032 4.03a.75.75 0 1 0 1.06 1.061l4.032-4.031Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.563 1.898a3.917 3.917 0 1 1 5.54 5.54L14.842 8.7l1.261 1.261a.75.75 0 1 1-1.06 1.06l-1.262-1.26-4.397 4.398a4.554 4.554 0 0 1-2.574 1.288l-1.633.231-1.167 1.167a1.385 1.385 0 0 1-1.957 0l-.896-.896a1.385 1.385 0 0 1 0-1.956l1.169-1.168.232-1.634a4.554 4.554 0 0 1 1.287-2.574L8.241 4.22 6.979 2.96A.75.75 0 0 1 8.04 1.897L9.302 3.16l1.261-1.262Zm4.48 4.48a2.417 2.417 0 1 0-3.419-3.42L10.362 4.22l3.42 3.42 1.26-1.263Zm-10.138 3.3a3.054 3.054 0 0 0-.863 1.725l-.267 1.881a.75.75 0 0 1-.213.426L2.3 14.97l.731.732 1.262-1.261a.75.75 0 0 1 .425-.213l1.88-.266a3.057 3.057 0 0 0 1.726-.863l4.398-4.4L9.3 5.282 4.906 9.678Z\" }));\nconst ForwardRef = forwardRef(SvgColorPickerAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ColorPickerAltSvgIcon from '@bloomreach/banana-theme/icons/color-picker-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ColorPickerAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ColorPickerAltSvgIcon />\n </BrIcon>\n );\n});\n\nColorPickerAltIcon.displayName = 'ColorPickerAltIcon';\n\nexport default ColorPickerAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgColorPicker = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.333.75a3.917 3.917 0 0 0-2.77 1.148L9.302 3.159 8.04 1.898a.75.75 0 0 0-1.06 1.06L8.24 4.22 3.845 8.617a4.554 4.554 0 0 0-1.288 2.574l-.231 1.634-1.17 1.168a1.384 1.384 0 0 0 0 1.956l.897.897a1.384 1.384 0 0 0 1.956 0l1.167-1.168 1.634-.231a4.554 4.554 0 0 0 2.575-1.288L13.78 9.76l1.262 1.262a.75.75 0 1 0 1.06-1.06L14.842 8.7l1.261-1.262A3.917 3.917 0 0 0 13.333.75Zm.448 6.889L10.362 4.22l1.262-1.261a2.417 2.417 0 1 1 3.418 3.418L13.781 7.64Zm-4.48-2.358 3.42 3.419-4.398 4.399a3.057 3.057 0 0 1-1.726.863l-1.88.266a.75.75 0 0 0-.425.213l-1.262 1.26-.731-.731 1.263-1.261a.75.75 0 0 0 .213-.426l.266-1.88a3.054 3.054 0 0 1 .864-1.726L9.302 5.28Z\" }));\nconst ForwardRef = forwardRef(SvgColorPicker);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ColorPickerSvgIcon from '@bloomreach/banana-theme/icons/color-picker.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ColorPickerIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ColorPickerSvgIcon />\n </BrIcon>\n );\n});\n\nColorPickerIcon.displayName = 'ColorPickerIcon';\n\nexport default ColorPickerIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgColumns = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 2.498c0-.966.784-1.75 1.75-1.75h1c.967 0 1.75.784 1.75 1.75v13a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-13Zm1.75-.25a.25.25 0 0 0-.25.25v13c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-13a.25.25 0 0 0-.25-.25h-1Zm4.251 5.25c0-.966.783-1.75 1.75-1.75h1c.966 0 1.75.784 1.75 1.75v8a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-8Zm1.75-.25a.25.25 0 0 0-.25.25v8c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-8a.25.25 0 0 0-.25-.25h-1Zm5.999 3.5a1.75 1.75 0 0 0-1.75 1.75v3c0 .967.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-3a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v3a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-3Z\" }));\nconst ForwardRef = forwardRef(SvgColumns);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ColumnsSvgIcon from '@bloomreach/banana-theme/icons/columns.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ColumnsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ColumnsSvgIcon />\n </BrIcon>\n );\n});\n\nColumnsIcon.displayName = 'ColumnsIcon';\n\nexport default ColumnsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgConditionAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 17, fill: \"currentColor\", viewBox: \"0 0 17 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001.25a.75.75 0 0 1 .75.75v5.25h4.94l-.72-.72a.75.75 0 1 1 1.06-1.06l2 2a.747.747 0 0 1 0 1.06l-2 2a.75.75 0 0 1-1.06-1.06l.72-.72H8.75v5.94l.72-.72a.75.75 0 1 1 1.06 1.06l-2 2a.748.748 0 0 1-1.06 0l-2-2a.75.75 0 0 1 1.06-1.06l.72.72V1A.75.75 0 0 1 8 .25Z\" }));\nconst ForwardRef = forwardRef(SvgConditionAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ConditionAltSvgIcon from '@bloomreach/banana-theme/icons/condition-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ConditionAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ConditionAltSvgIcon />\n </BrIcon>\n );\n});\n\nConditionAltIcon.displayName = 'ConditionAltIcon';\n\nexport default ConditionAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCondition = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.173 6.875c-.052.073-.11.146-.172.219L7.095 12a1.163 1.163 0 0 1-.125.11v3.015a.723.723 0 0 1-.219.531.723.723 0 0 1-.531.22.723.723 0 0 1-.531-.22.723.723 0 0 1-.219-.53v-2.97L5.283 12 .376 7.094a1.235 1.235 0 0 1-.375-.906c0-.354.125-.657.375-.907L5.283.375c.25-.25.552-.375.906-.375s.656.125.906.375l4.906 4.906.078.094h3.047c.209 0 .386.073.532.219a.723.723 0 0 1 .218.531.723.723 0 0 1-.218.531.723.723 0 0 1-.532.22h-2.953ZM1.595 6.188l4.594 4.593 4.594-4.593-4.594-4.594-4.594 4.594Z\" }));\nconst ForwardRef = forwardRef(SvgCondition);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ConditionSvgIcon from '@bloomreach/banana-theme/icons/condition.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ConditionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ConditionSvgIcon />\n </BrIcon>\n );\n});\n\nConditionIcon.displayName = 'ConditionIcon';\n\nexport default ConditionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgConsole = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.471 5.47a.75.75 0 0 1 1.06 0l2 2a.75.75 0 0 1 0 1.06l-2 2a.75.75 0 1 1-1.06-1.06L4.941 8 3.47 6.53a.75.75 0 0 1 0-1.06Zm5.03 1.78a.75.75 0 0 0 0 1.5h3.5a.75.75 0 0 0 0-1.5h-3.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.251 4.5c0-.966.784-1.75 1.75-1.75h12c.967 0 1.75.784 1.75 1.75v7a1.75 1.75 0 0 1-1.75 1.75h-12a1.75 1.75 0 0 1-1.75-1.75v-7Zm1.75-.25a.25.25 0 0 0-.25.25v7c0 .138.112.25.25.25h12a.25.25 0 0 0 .25-.25v-7a.25.25 0 0 0-.25-.25h-12Z\" }));\nconst ForwardRef = forwardRef(SvgConsole);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ConsoleSvgIcon from '@bloomreach/banana-theme/icons/console.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ConsoleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ConsoleSvgIcon />\n </BrIcon>\n );\n});\n\nConsoleIcon.displayName = 'ConsoleIcon';\n\nexport default ConsoleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgConstantAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.004.73H2.26a1.5 1.5 0 0 0-1.5 1.5v.75a.75.75 0 0 0 1.5 0v-.75h3v12.477a.75.75 0 0 0 1.5 0V2.23h2.49v12.01a1.5 1.5 0 0 0 1.5 1.5h.75a.75.75 0 0 0 0-1.5h-.75V2.23h3.75a.75.75 0 0 0 0-1.5H6.016a.777.777 0 0 0-.012 0Z\" }));\nconst ForwardRef = forwardRef(SvgConstantAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ConstantAltSvgIcon from '@bloomreach/banana-theme/icons/constant-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ConstantAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ConstantAltSvgIcon />\n </BrIcon>\n );\n});\n\nConstantAltIcon.displayName = 'ConstantAltIcon';\n\nexport default ConstantAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgConstant = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.675 1.177c.224-.116.474-.176.726-.177h7.196a1.573 1.573 0 0 1 1.279.659l2.84 3.796a1.514 1.514 0 0 1 .277 1.036l-.001.003a1.524 1.524 0 0 1-.443.923l-7.002 7.347a.747.747 0 0 1-.54.237H8a.722.722 0 0 1-.282-.056.746.746 0 0 1-.264-.182L.451 7.418a1.524 1.524 0 0 1-.442-.904l-.002-.021a1.514 1.514 0 0 1 .276-1.036L3.121 1.66c.144-.203.334-.368.553-.482Zm5.075 11.2 4.945-5.189H8.75v5.189Zm-1.5-5.189H2.305l4.945 5.188V7.188Zm1.5-1.5h5.266l-2.35-3.14a.788.788 0 0 1-.017-.025.047.047 0 0 0-.017-.014.075.075 0 0 0-.035-.009H8.75v3.188ZM7.25 2.5H4.4a.076.076 0 0 0-.034.009.048.048 0 0 0-.017.014.767.767 0 0 1-.018.024L1.983 5.688H7.25V2.5Z\" }));\nconst ForwardRef = forwardRef(SvgConstant);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ConstantSvgIcon from '@bloomreach/banana-theme/icons/constant.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ConstantIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ConstantSvgIcon />\n </BrIcon>\n );\n});\n\nConstantIcon.displayName = 'ConstantIcon';\n\nexport default ConstantIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgContextualPersonalization = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.334.25a3.967 3.967 0 0 0-.778 7.858 6.724 6.724 0 0 0-5.225 3.65.75.75 0 0 0 1.339.675 5.222 5.222 0 0 1 7.287-2.164.75.75 0 1 0 .753-1.297 6.725 6.725 0 0 0-2.598-.864A3.968 3.968 0 0 0 6.334.25Zm-1.78 2.258a2.468 2.468 0 0 1 4.073.8c-.887.196-1.64.179-2.301.022-.63-.148-1.211-.43-1.771-.822ZM3.892 3.87c.63.414 1.32.739 2.09.92.842.199 1.75.22 2.746.029A2.468 2.468 0 0 1 3.89 3.87ZM13 5.584c-1.15 0-2.083.933-2.083 2.083v.667c0 1.15.933 2.083 2.083 2.083h.667c1.15 0 2.083-.933 2.083-2.083v-.667c0-1.15-.932-2.083-2.083-2.083H13Zm-.583 2.083c0-.322.261-.583.583-.583h.667c.322 0 .583.261.583.583v.667a.583.583 0 0 1-.583.583H13a.583.583 0 0 1-.583-.583v-.667ZM10.917 13c0-1.15.933-2.083 2.083-2.083h.667c1.15 0 2.083.933 2.083 2.084v.666c0 1.15-.932 2.084-2.083 2.084H13a2.083 2.083 0 0 1-2.083-2.084v-.666ZM13 12.418a.583.583 0 0 0-.583.584v.666c0 .322.261.584.583.584h.667a.583.583 0 0 0 .583-.584v-.666a.583.583 0 0 0-.583-.584H13Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.667 10.917c-1.15 0-2.084.933-2.084 2.084v.666c0 1.15.933 2.084 2.084 2.084h.666a2.084 2.084 0 0 0 2.084-2.084v-.666a2.084 2.084 0 0 0-2.084-2.084h-.666Zm-.584 2.084c0-.323.262-.584.584-.584h.666c.323 0 .584.261.584.584v.666a.583.583 0 0 1-.584.584h-.666a.583.583 0 0 1-.584-.584v-.666Z\" }));\nconst ForwardRef = forwardRef(SvgContextualPersonalization);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ContextualPersonalizationSvgIcon from '@bloomreach/banana-theme/icons/contextual-personalization.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ContextualPersonalizationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ContextualPersonalizationSvgIcon />\n </BrIcon>\n );\n});\n\nContextualPersonalizationIcon.displayName = 'ContextualPersonalizationIcon';\n\nexport default ContextualPersonalizationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCopy = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.324 2.324A.25.25 0 0 1 2.5 2.25h10a.25.25 0 0 1 .25.25.75.75 0 0 0 1.5 0A1.75 1.75 0 0 0 12.5.75h-10A1.75 1.75 0 0 0 .75 2.5v10a1.75 1.75 0 0 0 1.75 1.75.75.75 0 0 0 0-1.5.25.25 0 0 1-.25-.25v-10a.25.25 0 0 1 .074-.176Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5 3.75A1.75 1.75 0 0 0 3.75 5.5v10c0 .967.784 1.75 1.75 1.75h10a1.75 1.75 0 0 0 1.75-1.75v-10a1.75 1.75 0 0 0-1.75-1.75h-10ZM5.25 5.5a.25.25 0 0 1 .25-.25h10a.25.25 0 0 1 .25.25v10a.25.25 0 0 1-.25.25h-10a.25.25 0 0 1-.25-.25v-10Z\" }));\nconst ForwardRef = forwardRef(SvgCopy);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CopySvgIcon from '@bloomreach/banana-theme/icons/copy.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CopyIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CopySvgIcon />\n </BrIcon>\n );\n});\n\nCopyIcon.displayName = 'CopyIcon';\n\nexport default CopyIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCopyToDashboard = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5 2.25a.25.25 0 0 0-.25.25v10a.25.25 0 0 0 .25.25.75.75 0 0 1 0 1.5A1.75 1.75 0 0 1 .75 12.5v-10A1.75 1.75 0 0 1 2.5.75h10a1.75 1.75 0 0 1 1.75 1.75.75.75 0 0 1-1.5 0 .25.25 0 0 0-.25-.25h-10Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5 5.25a.25.25 0 0 0-.25.25v10c0 .139.112.25.25.25h10a.25.25 0 0 0 .25-.25v-10a.25.25 0 0 0-.25-.25h-10Zm-1.75.25c0-.966.784-1.75 1.75-1.75h10c.967 0 1.75.784 1.75 1.75v10a1.75 1.75 0 0 1-1.75 1.75h-10a1.75 1.75 0 0 1-1.75-1.75v-10Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"m13.594 8.291-.691-.29-.29-.692a.75.75 0 0 1 .981.982Zm-2.17 1.189c-.159.336-.321.667-.47.946-.09.168-.17.31-.239.42-.07.11-.107.155-.111.16 0 .001 0 0 0 0a.5.5 0 1 1-.707-.708c.006-.004.05-.041.16-.11.11-.07.252-.15.42-.24.28-.148.61-.31.946-.468ZM12.902 8l-.29-.691-.01.004-.027.011-.1.043a53.705 53.705 0 0 0-1.473.654c-.417.193-.858.405-1.23.603a8.441 8.441 0 0 0-.513.293c-.14.088-.3.198-.424.321a2 2 0 1 0 2.829 2.829 2.42 2.42 0 0 0 .32-.424c.096-.15.195-.327.294-.513.198-.372.41-.813.603-1.23a53.95 53.95 0 0 0 .655-1.473l.042-.1.015-.036-.691-.29Z\" }));\nconst ForwardRef = forwardRef(SvgCopyToDashboard);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CopyToDashboardSvgIcon from '@bloomreach/banana-theme/icons/copy-to-dashboard.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CopyToDashboardIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CopyToDashboardSvgIcon />\n </BrIcon>\n );\n});\n\nCopyToDashboardIcon.displayName = 'CopyToDashboardIcon';\n\nexport default CopyToDashboardIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCsv = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.032 7.25A2.75 2.75 0 0 0 3.282 10v1a2.75 2.75 0 0 0 2.75 2.75.75.75 0 0 0 0-1.5A1.25 1.25 0 0 1 4.782 11v-1a1.25 1.25 0 0 1 1.25-1.25.75.75 0 0 0 0-1.5Zm3 0A1.75 1.75 0 0 0 7.282 9c0 1.13.78 1.712 1.25 2.063l.05.037c.538.404.7.571.7.9a.25.25 0 0 1-.25.25h-1a.75.75 0 0 0 0 1.5h1a1.75 1.75 0 0 0 1.75-1.75c0-1.129-.78-1.711-1.25-2.062l-.05-.038c-.538-.403-.7-.57-.7-.9a.25.25 0 0 1 .25-.25h1a.75.75 0 0 0 0-1.5h-1Zm3.75.75a.75.75 0 0 0-1.5 0v1.697a6.71 6.71 0 0 0 1.126 3.72.75.75 0 0 0 1.248 0 6.707 6.707 0 0 0 1.126-3.72V8a.75.75 0 0 0-1.5 0v1.697a5.21 5.21 0 0 1-.25 1.594 5.205 5.205 0 0 1-.25-1.594V8Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.502.752a1.75 1.75 0 0 0-1.75 1.75v13c0 .967.783 1.75 1.75 1.75h13a1.75 1.75 0 0 0 1.75-1.75v-13a1.75 1.75 0 0 0-1.75-1.75h-13Zm-.25 1.75a.25.25 0 0 1 .25-.25h13a.25.25 0 0 1 .25.25v13a.25.25 0 0 1-.25.25h-13a.25.25 0 0 1-.25-.25v-13Z\" }));\nconst ForwardRef = forwardRef(SvgCsv);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CsvSvgIcon from '@bloomreach/banana-theme/icons/csv.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CsvIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CsvSvgIcon />\n </BrIcon>\n );\n});\n\nCsvIcon.displayName = 'CsvIcon';\n\nexport default CsvIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCustomRow = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3 2a.75.75 0 0 1 .75-.75h8.5a.75.75 0 0 1 0 1.5h-8.5A.75.75 0 0 1 3 2ZM.25 6.5c0-.966.784-1.75 1.75-1.75h12c.967 0 1.75.784 1.75 1.75v3A1.75 1.75 0 0 1 14 11.25H2A1.75 1.75 0 0 1 .25 9.5v-3ZM2 6.25a.25.25 0 0 0-.25.25v3c0 .139.113.25.25.25h12a.25.25 0 0 0 .25-.25v-3a.25.25 0 0 0-.25-.25H2ZM3 14a.75.75 0 0 1 .75-.75h8.5a.75.75 0 0 1 0 1.5h-8.5A.75.75 0 0 1 3 14Z\" }));\nconst ForwardRef = forwardRef(SvgCustomRow);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CustomRowSvgIcon from '@bloomreach/banana-theme/icons/custom-row.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CustomRowIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CustomRowSvgIcon />\n </BrIcon>\n );\n});\n\nCustomRowIcon.displayName = 'CustomRowIcon';\n\nexport default CustomRowIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCustomer = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.75 5a4.23 4.23 0 0 1 .6-2.176A4.25 4.25 0 1 1 3.75 5ZM8 2.25c-.794 0-1.51.338-2.012.877a5.057 5.057 0 0 0 4.594.923A2.751 2.751 0 0 0 8 2.25ZM6.603 5.228a6.557 6.557 0 0 1-1.304-.74 2.75 2.75 0 0 0 5.393 1.083 6.567 6.567 0 0 1-4.09-.343Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 9.25a7.25 7.25 0 0 1 7.25 7.25.75.75 0 0 1-1.5 0 5.75 5.75 0 0 0-11.5 0 .75.75 0 0 1-1.5 0A7.25 7.25 0 0 1 8 9.25Z\" }));\nconst ForwardRef = forwardRef(SvgCustomer);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CustomerSvgIcon from '@bloomreach/banana-theme/icons/customer-.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CustomerIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CustomerSvgIcon />\n </BrIcon>\n );\n});\n\nCustomerIcon.displayName = 'CustomerIcon';\n\nexport default CustomerIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCustomersFilter = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.25 3.5a2.75 2.75 0 1 1 3.423 2.668.75.75 0 0 1-.672 1.083A2.75 2.75 0 0 0 6.25 10v.75H7a.75.75 0 0 1 .746.675l.433 4.325H9.5a.75.75 0 0 1 0 1.5h-2a.75.75 0 0 1-.745-.676l-.433-4.324h-.821a.75.75 0 0 1-.75-.75V10a4.25 4.25 0 0 1 2.985-4.058A2.75 2.75 0 0 1 6.251 3.5ZM9 2.25a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.75 5a2.25 2.25 0 1 1 2.915 2.151.75.75 0 0 1-.664 1.1A1.75 1.75 0 0 0 2.25 10v.75h.25a.75.75 0 0 1 .744.657l.418 3.343H5a.75.75 0 0 1 0 1.5H3a.75.75 0 0 1-.744-.658l-.418-3.342H1.5a.75.75 0 0 1-.75-.75V10a3.25 3.25 0 0 1 2.127-3.05A2.25 2.25 0 0 1 1.75 5ZM4 4.25a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm10-1.5a2.25 2.25 0 1 0 0 4.5 2.25 2.25 0 0 0 0-4.5ZM13.25 5a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0Zm-5.5 4a.75.75 0 0 1 .75-.75h8a.75.75 0 0 1 .75.75 4.752 4.752 0 0 1-3.75 4.645V16a.75.75 0 0 1-.219.53l-.5.5a.75.75 0 0 1-1.28-.53v-2.855A4.752 4.752 0 0 1 7.75 9Zm1.588.75a3.251 3.251 0 0 0 6.326 0H9.338Z\" }));\nconst ForwardRef = forwardRef(SvgCustomersFilter);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CustomersFilterSvgIcon from '@bloomreach/banana-theme/icons/customers-filter.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CustomersFilterIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CustomersFilterSvgIcon />\n </BrIcon>\n );\n});\n\nCustomersFilterIcon.displayName = 'CustomersFilterIcon';\n\nexport default CustomersFilterIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgCustomersSegmentation = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.25 3.5a2.75 2.75 0 1 1 4.016 2.443 4.25 4.25 0 0 1 2.985 4.058v1.5a.75.75 0 0 1-.75.75h-.821l-.433 4.324a.75.75 0 0 1-.746.675h-3a.75.75 0 0 1-.746-.675l-.433-4.324h-.821a.75.75 0 0 1-.75-.75V10a4.25 4.25 0 0 1 2.985-4.058A2.75 2.75 0 0 1 6.251 3.5ZM9 2.25a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5ZM7.057 8.056A2.75 2.75 0 0 0 6.251 10v.75H7a.75.75 0 0 1 .746.675l.433 4.325h1.642l.433-4.325A.75.75 0 0 1 11 10.75h.75V10a2.75 2.75 0 0 0-4.695-1.945Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M4 2.75a2.25 2.25 0 0 0-1.122 4.2A3.25 3.25 0 0 0 .75 10v1.5c0 .415.336.75.75.75h.338l.418 3.344A.75.75 0 0 0 3 16.25h2a.75.75 0 0 0 0-1.5H3.663l-.418-3.342a.75.75 0 0 0-.744-.657h-.25V10A1.75 1.75 0 0 1 4 8.25a.75.75 0 0 0 .664-1.1A2.251 2.251 0 0 0 4 2.751ZM3.25 5a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0Zm8.5 0a2.25 2.25 0 1 1 3.374 1.95A3.25 3.25 0 0 1 17.25 10v1.5a.75.75 0 0 1-.75.75h-.338l-.418 3.344a.75.75 0 0 1-.744.656h-2a.75.75 0 0 1 0-1.5h1.338l.418-3.342a.75.75 0 0 1 .744-.657h.25V10A1.75 1.75 0 0 0 14 8.25a.75.75 0 0 1-.664-1.1A2.251 2.251 0 0 1 11.75 5ZM14 4.25a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Z\" }));\nconst ForwardRef = forwardRef(SvgCustomersSegmentation);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport CustomersSegmentationSvgIcon from '@bloomreach/banana-theme/icons/customers-segmentation.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst CustomersSegmentationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <CustomersSegmentationSvgIcon />\n </BrIcon>\n );\n});\n\nCustomersSegmentationIcon.displayName = 'CustomersSegmentationIcon';\n\nexport default CustomersSegmentationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDateTime = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.502.75a.75.75 0 0 1 .75.75v1.25h3.5V1.5a.75.75 0 1 1 1.5 0v1.25h2.25c.967 0 1.75.784 1.75 1.75V6a.75.75 0 0 1-1.5 0V4.5a.25.25 0 0 0-.25-.25h-2.25V5a.75.75 0 0 1-1.5 0v-.75h-3.5V5a.75.75 0 0 1-1.5 0v-.75h-2.25a.25.25 0 0 0-.25.25v9c0 .139.112.25.25.25h3.499a.75.75 0 0 1 0 1.5H2.502a1.75 1.75 0 0 1-1.75-1.75v-9c0-.966.784-1.75 1.75-1.75h2.25V1.5a.75.75 0 0 1 .75-.75Zm6.874 9.313a.75.75 0 0 1 .75.75l-1.28 2.093-.002-.002a.748.748 0 0 1-.218-.528v-1.563a.75.75 0 0 1 .75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"m13.126 10.813-1.28 2.093 1.953 1.953a.75.75 0 0 0 1.06-1.06l-1.733-1.734v-1.252Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.251 12.376a5.125 5.125 0 1 1 10.25 0 5.125 5.125 0 0 1-10.25 0Zm5.125-3.626a3.625 3.625 0 1 0 0 7.25 3.625 3.625 0 0 0 0-7.25Z\" }));\nconst ForwardRef = forwardRef(SvgDateTime);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DateTimeSvgIcon from '@bloomreach/banana-theme/icons/date-time.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DateTimeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DateTimeSvgIcon />\n </BrIcon>\n );\n});\n\nDateTimeIcon.displayName = 'DateTimeIcon';\n\nexport default DateTimeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDescription = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.751 5.5a.75.75 0 0 1 .75-.75h8a.75.75 0 0 1 0 1.5h-8a.75.75 0 0 1-.75-.75Zm.75 2.25a.75.75 0 1 0 0 1.5h3.5a.75.75 0 0 0 0-1.5h-3.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"m10.804 17.097.014-.007c.186-.085.358-.204.506-.352l5.415-5.415c.146-.146.264-.316.35-.5l.01-.025c.1-.222.152-.464.152-.711V2.5a1.75 1.75 0 0 0-1.75-1.75h-13A1.75 1.75 0 0 0 .751 2.5v13a1.75 1.75 0 0 0 1.75 1.75h7.586c.25 0 .494-.053.717-.153ZM2.324 2.324a.25.25 0 0 1 .177-.074h13a.25.25 0 0 1 .25.25v7.25h-4.25a1.75 1.75 0 0 0-1.75 1.75v4.25h-7.25a.25.25 0 0 1-.25-.25v-13a.25.25 0 0 1 .073-.176ZM14.69 11.25l-3.439 3.439V11.5a.25.25 0 0 1 .25-.25h3.19Z\" }));\nconst ForwardRef = forwardRef(SvgDescription);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DescriptionSvgIcon from '@bloomreach/banana-theme/icons/description.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DescriptionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DescriptionSvgIcon />\n </BrIcon>\n );\n});\n\nDescriptionIcon.displayName = 'DescriptionIcon';\n\nexport default DescriptionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDesktop = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 11.5v-8A2.75 2.75 0 0 1 3.501.75h11a2.75 2.75 0 0 1 2.75 2.75v8a2.75 2.75 0 0 1-2.75 2.75h-2.614l.25 1.5H13a.75.75 0 0 1 0 1.5H5a.75.75 0 0 1 0-1.5h.865l.25-1.5H3.5A2.75 2.75 0 0 1 .75 11.5Zm1.5-8v7.25h13.5V3.5c0-.69-.56-1.25-1.25-1.25h-11c-.69 0-1.25.56-1.25 1.25Zm12.25 9.25c.41 0 .772-.196 1-.5h-13c.228.304.591.5 1 .5h11Zm-6.864 1.5-.25 1.5h3.229l-.25-1.5h-2.73Z\" }));\nconst ForwardRef = forwardRef(SvgDesktop);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DesktopSvgIcon from '@bloomreach/banana-theme/icons/desktop.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DesktopIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DesktopSvgIcon />\n </BrIcon>\n );\n});\n\nDesktopIcon.displayName = 'DesktopIcon';\n\nexport default DesktopIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDisabled = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"m3.16 14.826.008.008.008.008A8.25 8.25 0 0 0 14.839 3.171l-.004-.004-.004-.004A8.25 8.25 0 0 0 3.16 14.826ZM2.25 9a6.75 6.75 0 0 1 10.964-5.273l-9.488 9.487A6.722 6.722 0 0 1 2.251 9Zm12.024-4.213a6.75 6.75 0 0 1-9.487 9.487l9.487-9.487Z\" }));\nconst ForwardRef = forwardRef(SvgDisabled);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DisabledSvgIcon from '@bloomreach/banana-theme/icons/disabled.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DisabledIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DisabledSvgIcon />\n </BrIcon>\n );\n});\n\nDisabledIcon.displayName = 'DisabledIcon';\n\nexport default DisabledIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDivide = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.251 4.25a1.25 1.25 0 1 1-2.5 0 1.25 1.25 0 0 1 2.5 0Zm-7 3.75a.75.75 0 0 1 .75-.75h10a.75.75 0 1 1 0 1.5h-10a.75.75 0 0 1-.75-.75Zm5.75 5a1.25 1.25 0 1 0 0-2.5 1.25 1.25 0 0 0 0 2.5Z\" }));\nconst ForwardRef = forwardRef(SvgDivide);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DivideSvgIcon from '@bloomreach/banana-theme/icons/divide.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DivideIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DivideSvgIcon />\n </BrIcon>\n );\n});\n\nDivideIcon.displayName = 'DivideIcon';\n\nexport default DivideIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDocumentation = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001 8.25a.75.75 0 1 0 0-1.5.75.75 0 0 0 0 1.5Zm-1.5.5a.75.75 0 0 0 0 1.5h.75V12h-.75a.75.75 0 0 0 0 1.5h3a.75.75 0 1 0 0-1.5h-.75V9.5a.75.75 0 0 0-.75-.75h-1.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.251 0a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h8.75a.75.75 0 0 0 .75-.75v-10a.75.75 0 0 0-.75-.75h-8.75a1.5 1.5 0 0 1 0-3h8.75a.75.75 0 0 0 0-1.5h-8.75Zm-1.5 13V5.6c.442.254.954.4 1.5.4h8v8.5h-8a1.5 1.5 0 0 1-1.5-1.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.501 3a.75.75 0 0 1 .75-.75h8a.75.75 0 0 1 0 1.5h-8a.75.75 0 0 1-.75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgDocumentation);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DocumentationSvgIcon from '@bloomreach/banana-theme/icons/documentation.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DocumentationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DocumentationSvgIcon />\n </BrIcon>\n );\n});\n\nDocumentationIcon.displayName = 'DocumentationIcon';\n\nexport default DocumentationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDownload = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9 1.75a.75.75 0 0 1 .75.75v6.19l1.72-1.72a.75.75 0 1 1 1.06 1.06l-3 3-.006.007a.748.748 0 0 1-1.047 0l-.007-.006-3-3a.75.75 0 0 1 1.06-1.06L8.25 8.69V2.5A.75.75 0 0 1 9 1.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25 10.5a.75.75 0 0 0-1.5 0v1a2.75 2.75 0 0 0 2.75 2.75h11a2.75 2.75 0 0 0 2.75-2.75v-1a.75.75 0 0 0-1.5 0v1a1.25 1.25 0 0 1-1.25 1.25h-11a1.25 1.25 0 0 1-1.25-1.25v-1Z\" }));\nconst ForwardRef = forwardRef(SvgDownload);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DownloadSvgIcon from '@bloomreach/banana-theme/icons/download.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DownloadIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DownloadSvgIcon />\n </BrIcon>\n );\n});\n\nDownloadIcon.displayName = 'DownloadIcon';\n\nexport default DownloadIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDragHorizontal = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.587 3.57a1.41 1.41 0 0 0-.64.39 1.455 1.455 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44.28-.28.438-.654.438-1.04a1.52 1.52 0 0 0-1.109-1.437 1.873 1.873 0 0 0-.796.008Zm6 0a1.41 1.41 0 0 0-.64.39 1.455 1.455 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44a1.454 1.454 0 0 0 0-2.08 1.38 1.38 0 0 0-1.07-.437c-.134 0-.267.016-.397.048Zm6 0a1.41 1.41 0 0 0-.64.39 1.455 1.455 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44a1.454 1.454 0 0 0 0-2.08 1.38 1.38 0 0 0-1.07-.437c-.134 0-.267.016-.397.048Zm-12 6a1.41 1.41 0 0 0-.64.39 1.456 1.456 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44.458-.457.564-1.12.274-1.713a1.566 1.566 0 0 0-.945-.764 1.873 1.873 0 0 0-.796.008Zm6 0a1.41 1.41 0 0 0-.64.39 1.455 1.455 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44a1.454 1.454 0 0 0 0-2.08 1.38 1.38 0 0 0-1.07-.437c-.134 0-.267.016-.397.048Zm6 0a1.41 1.41 0 0 0-.64.39 1.455 1.455 0 0 0 0 2.08c.303.305.63.44 1.053.44.424 0 .75-.135 1.054-.44a1.454 1.454 0 0 0 0-2.08 1.38 1.38 0 0 0-1.07-.437c-.134 0-.267.016-.397.048Z\" }));\nconst ForwardRef = forwardRef(SvgDragHorizontal);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DragHorizontalSvgIcon from '@bloomreach/banana-theme/icons/drag-horizontal.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DragHorizontalIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DragHorizontalSvgIcon />\n </BrIcon>\n );\n});\n\nDragHorizontalIcon.displayName = 'DragHorizontalIcon';\n\nexport default DragHorizontalIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgDragVerical = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5 3.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm0 6a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM6.5 14a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0ZM11 3.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3ZM12.5 8a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0ZM11 15.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Z\" }));\nconst ForwardRef = forwardRef(SvgDragVerical);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport DragVericalSvgIcon from '@bloomreach/banana-theme/icons/drag-verical.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst DragVericalIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <DragVericalSvgIcon />\n </BrIcon>\n );\n});\n\nDragVericalIcon.displayName = 'DragVericalIcon';\n\nexport default DragVericalIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEdit = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.593 2.177a1.75 1.75 0 0 0-2.474 0L1.38 9.914a.75.75 0 0 0-.196.344l-.912 3.556a.75.75 0 0 0 .913.912l3.556-.912a.75.75 0 0 0 .344-.196l7.737-7.737a1.75 1.75 0 0 0 0-2.475l-1.23-1.23Zm-1.414 1.06a.25.25 0 0 1 .354 0l1.23 1.23a.25.25 0 0 1 0 .353l-.752.751-1.583-1.583.751-.75ZM8.368 5.05 9.95 6.632l-5.78 5.78-2.13.547.546-2.13 5.78-5.78Z\" }));\nconst ForwardRef = forwardRef(SvgEdit);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EditSvgIcon from '@bloomreach/banana-theme/icons/edit.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EditIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EditSvgIcon />\n </BrIcon>\n );\n});\n\nEditIcon.displayName = 'EditIcon';\n\nexport default EditIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEducationHub = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.326.825a.75.75 0 0 0-.652 0l-7.25 3.5A.75.75 0 0 0 0 5v4a.75.75 0 0 0 1.5 0V6.195l1.25.604V11.5c0 .162.053.32.15.45l.6-.45-.6.45h.001l.001.002.003.004.007.008.02.027.07.082c.057.069.14.16.25.27.216.216.535.499.957.78A6.758 6.758 0 0 0 8 14.252a6.751 6.751 0 0 0 3.791-1.127c.423-.281.742-.564.958-.78a4.816 4.816 0 0 0 .32-.352l.02-.027.007-.008.002-.004.001-.001s.001-.002-.599-.451l.6.45a.75.75 0 0 0 .15-.45V6.799l2.326-1.123a.75.75 0 0 0 0-1.35l-7.25-3.5Zm3.424 6.698v3.697l-.061.063a4.823 4.823 0 0 1-.73.594c-.652.434-1.634.873-2.959.873-1.324 0-2.307-.439-2.959-.873a4.822 4.822 0 0 1-.79-.657V7.523l3.423 1.653c.206.1.446.1.652 0l3.424-1.653ZM8 7.668 2.475 5 8 2.333 13.525 5 8 7.668Z\" }));\nconst ForwardRef = forwardRef(SvgEducationHub);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EducationHubSvgIcon from '@bloomreach/banana-theme/icons/education-hub.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EducationHubIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EducationHubSvgIcon />\n </BrIcon>\n );\n});\n\nEducationHubIcon.displayName = 'EducationHubIcon';\n\nexport default EducationHubIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEllipsisVertical = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.492 3.252a2.5 2.5 0 1 1 5 0 2.5 2.5 0 0 1-5 0Zm2.5-1a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm-2.5 12.5a2.5 2.5 0 1 1 5 0 2.5 2.5 0 0 1-5 0Zm2.5-1a1 1 0 1 0 0 2 1 1 0 0 0 0-2Zm0-7.25a2.5 2.5 0 1 0 0 5 2.5 2.5 0 0 0 0-5Zm-1 2.5a1 1 0 1 1 2 0 1 1 0 0 1-2 0Z\" }));\nconst ForwardRef = forwardRef(SvgEllipsisVertical);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EllipsisVerticalSvgIcon from '@bloomreach/banana-theme/icons/ellipsis-vertical.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EllipsisVerticalIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EllipsisVerticalSvgIcon />\n </BrIcon>\n );\n});\n\nEllipsisVerticalIcon.displayName = 'EllipsisVerticalIcon';\n\nexport default EllipsisVerticalIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEllipsissHorizontal = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2 10a2 2 0 1 0 0-4 2 2 0 0 0 0 4Zm0-1.5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1ZM8 10a2 2 0 1 0 0-4 2 2 0 0 0 0 4Zm0-1.5a.5.5 0 1 1 0-1 .5.5 0 0 1 0 1Zm8-.5a2 2 0 1 1-4 0 2 2 0 0 1 4 0Zm-1.5 0a.5.5 0 1 0-1 0 .5.5 0 0 0 1 0Z\" }));\nconst ForwardRef = forwardRef(SvgEllipsissHorizontal);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EllipsissHorizontalSvgIcon from '@bloomreach/banana-theme/icons/ellipsiss-horizontal.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EllipsissHorizontalIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EllipsissHorizontalSvgIcon />\n </BrIcon>\n );\n});\n\nEllipsissHorizontalIcon.displayName = 'EllipsissHorizontalIcon';\n\nexport default EllipsissHorizontalIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEmail = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.656 3.047c.32-.385.804-.63 1.345-.63h12a1.746 1.746 0 0 1 1.75 1.75v8a1.75 1.75 0 0 1-1.75 1.75H2a1.75 1.75 0 0 1-1.75-1.75v-8a1.743 1.743 0 0 1 .405-1.12ZM1.75 4.883v7.284c0 .138.112.25.25.25h12a.25.25 0 0 0 .25-.25V4.883L9.803 8.304a2.955 2.955 0 0 1-3.604 0L1.75 4.884Zm11.295-.966H2.956l4.157 3.198a1.456 1.456 0 0 0 1.775 0l4.158-3.198Z\" }));\nconst ForwardRef = forwardRef(SvgEmail);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EmailSvgIcon from '@bloomreach/banana-theme/icons/email.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EmailIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EmailSvgIcon />\n </BrIcon>\n );\n});\n\nEmailIcon.displayName = 'EmailIcon';\n\nexport default EmailIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEmojiPicker = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.25 7.5a7.25 7.25 0 0 1 14.437-.965c.084.63.08 1.256 0 1.864A.75.75 0 0 1 13.2 8.2a5.55 5.55 0 0 0 0-1.468A5.751 5.751 0 0 0 1.75 7.5a5.75 5.75 0 0 0 6.34 5.72.75.75 0 0 1 .152 1.493A7.25 7.25 0 0 1 .252 7.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.334 4.584a.967.967 0 1 0 0 1.933.967.967 0 0 0 0-1.933ZM8.7 5.55a.967.967 0 1 1 1.934 0 .967.967 0 0 1-1.933 0ZM3.852 7.64a.75.75 0 0 1 .91.545c.332 1.33 1.534 2.032 2.739 2.032.169 0 .336-.017.5-.05a.75.75 0 1 1 .302 1.468c-.262.054-.53.082-.802.082-1.737 0-3.66-1.03-4.195-3.168a.75.75 0 0 1 .546-.91Zm9.926 3.25a.667.667 0 0 0-1.333 0v1.555H10.89a.667.667 0 0 0 0 1.333h1.555v1.556a.667.667 0 0 0 1.333 0v-1.556h1.556a.667.667 0 0 0 0-1.333h-1.556v-1.556Z\" }));\nconst ForwardRef = forwardRef(SvgEmojiPicker);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EmojiPickerSvgIcon from '@bloomreach/banana-theme/icons/emoji-picker.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EmojiPickerIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EmojiPickerSvgIcon />\n </BrIcon>\n );\n});\n\nEmojiPickerIcon.displayName = 'EmojiPickerIcon';\n\nexport default EmojiPickerIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgErrorFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.333 7.057 8.943.667a1.333 1.333 0 0 0-1.886 0L.667 7.058a1.333 1.333 0 0 0 0 1.885l6.39 6.39a1.333 1.333 0 0 0 1.886 0l6.39-6.39a1.334 1.334 0 0 0 0-1.886ZM7.38 4.278a.667.667 0 0 1 1.333 0v4a.667.667 0 0 1-1.333 0v-4Zm.7 7.673h-.018a1.02 1.02 0 0 1-1.015-.98.983.983 0 0 1 .965-1.02h.019a1.018 1.018 0 0 1 .952 1.364.984.984 0 0 1-.903.636Z\" }));\nconst ForwardRef = forwardRef(SvgErrorFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ErrorFillSvgIcon from '@bloomreach/banana-theme/icons/error-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ErrorFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ErrorFillSvgIcon />\n </BrIcon>\n );\n});\n\nErrorFillIcon.displayName = 'ErrorFillIcon';\n\nexport default ErrorFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEvent = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.017 0h8.484a1.75 1.75 0 0 1 1.75 1.75v2.5a.75.75 0 0 1-.75.75h-15a.75.75 0 0 1-.75-.75v-2.5A1.75 1.75 0 0 1 2.5 0h4.516Zm.55 1.5-.572 2h3.44l.571-2h-3.44Zm8.184 2V1.75a.25.25 0 0 0-.25-.25h-2.934l-.572 2h3.756Zm-9.744-2H2.5a.25.25 0 0 0-.25.25V3.5h3.184l.572-2ZM2.25 6.25a.75.75 0 1 0-1.5 0v8.5A1.75 1.75 0 0 0 2.5 16.5h13a1.75 1.75 0 0 0 1.75-1.75v-8.5a.75.75 0 0 0-1.5 0v8.5a.25.25 0 0 1-.25.25h-13a.25.25 0 0 1-.25-.25v-8.5Zm5 2.362v3.278l3.277-1.64L7.25 8.612Zm3.6 1.8Zm-3.84-3.41c.225-.01.448.037.65.138l3.86 1.93a1.321 1.321 0 0 1 0 2.361l-3.86 1.93a1.324 1.324 0 0 1-1.743-.538 1.321 1.321 0 0 1-.167-.643V8.321a1.32 1.32 0 0 1 1.26-1.319Z\" }));\nconst ForwardRef = forwardRef(SvgEvent);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EventSvgIcon from '@bloomreach/banana-theme/icons/event.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EventIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EventSvgIcon />\n </BrIcon>\n );\n});\n\nEventIcon.displayName = 'EventIcon';\n\nexport default EventIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEventsSegmentation = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.236.782c-.37.049-.682.212-.974.508a1.74 1.74 0 0 0-.441.736c-.052.172-.055.42-.055 5.475 0 5.054.003 5.302.055 5.474.087.286.229.521.44.736.308.312.61.463 1.017.508.269.032.546-.006.685-.092a.69.69 0 0 0 .18-.202c.075-.126.083-.168.083-.425s-.008-.299-.082-.425a.708.708 0 0 0-.187-.204c-.088-.053-.363-.117-.52-.12-.021 0-.072-.034-.112-.074l-.074-.073V2.398l.074-.073.073-.074h10.206l.073.074c.04.04.074.09.075.112.002.157.066.432.119.52a.708.708 0 0 0 .205.187c.126.074.168.082.425.082s.299-.008.425-.082a.69.69 0 0 0 .2-.181c.133-.215.138-.73.01-1.066-.19-.5-.613-.898-1.145-1.075-.157-.053-.402-.056-5.37-.06C4.758.76 2.335.769 2.236.782Zm3 3c-.37.049-.682.212-.974.508a1.74 1.74 0 0 0-.441.736c-.052.172-.055.42-.055 5.475s.003 5.303.055 5.475c.09.291.23.524.456.748.224.226.457.366.749.456.172.053.42.055 5.475.055s5.303-.002 5.475-.055a1.73 1.73 0 0 0 .749-.456 1.73 1.73 0 0 0 .456-.748c.052-.173.055-.42.055-5.476 0-5.054-.003-5.302-.055-5.474a1.852 1.852 0 0 0-1.19-1.204c-.157-.053-.402-.056-5.37-.06-2.863-.002-5.286.007-5.385.02Zm10.44 1.543.075.073v10.206l-.074.073-.073.074H5.398l-.073-.074-.074-.073V5.398l.074-.073.073-.074h10.206l.073.074ZM8.687 7.79c-.38.084-.725.4-.852.782-.061.18-.063.242-.063 1.928s.002 1.748.063 1.928c.2.601.854.935 1.469.753.089-.027.89-.412 1.78-.857 1.806-.904 1.85-.933 2.036-1.311.09-.184.097-.217.097-.513 0-.296-.006-.33-.097-.513-.186-.378-.23-.407-2.036-1.311-.89-.445-1.691-.831-1.78-.858a1.72 1.72 0 0 0-.617-.028Zm2.685 2.71c0 .008-.48.255-1.065.548l-1.065.532V9.42l1.065.532c.586.293 1.065.54 1.065.548Z\" }));\nconst ForwardRef = forwardRef(SvgEventsSegmentation);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EventsSegmentationSvgIcon from '@bloomreach/banana-theme/icons/events-segmentation.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EventsSegmentationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EventsSegmentationSvgIcon />\n </BrIcon>\n );\n});\n\nEventsSegmentationIcon.displayName = 'EventsSegmentationIcon';\n\nexport default EventsSegmentationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgExperiment = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.735 2.25h-.25a.75.75 0 1 1 0-1.5h7a.75.75 0 0 1 0 1.5h-.25v4.028l1.823 2.805a.662.662 0 0 1 .012.018l2.535 3.9a2.75 2.75 0 0 1-2.305 4.25H3.667A2.75 2.75 0 0 1 1.365 13l2.531-3.893a.753.753 0 0 1 .02-.03l1.819-2.8V2.25Zm5.121 4.66a.75.75 0 0 1-.121-.41V2.25h-3.5V6.5a.75.75 0 0 1-.121.41L5.917 8.75h6.136l-1.197-1.84Zm-7.214 5.34h3.793a.75.75 0 0 1 0 1.5H2.667l-.044.07a1.25 1.25 0 0 0 1.045 1.93H14.3a1.25 1.25 0 0 0 1.047-1.93l-2.32-3.57H4.943l-1.3 2Z\" }));\nconst ForwardRef = forwardRef(SvgExperiment);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ExperimentSvgIcon from '@bloomreach/banana-theme/icons/experiment.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ExperimentIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ExperimentSvgIcon />\n </BrIcon>\n );\n});\n\nExperimentIcon.displayName = 'ExperimentIcon';\n\nexport default ExperimentIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgExpose = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.366.74a5.75 5.75 0 0 1 5.518 3.75 3.997 3.997 0 0 1 3.974.719 4 4 0 0 1-1.629 6.92.75.75 0 0 1-.364-1.456 2.5 2.5 0 1 0-2.03-4.481.75.75 0 0 1-1.164-.48 4.25 4.25 0 1 0-7.14 3.825.75.75 0 1 1-1.045 1.075A5.75 5.75 0 0 1 6.366.74Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.214 8.807a.748.748 0 0 0-.243.163l-2 2a.75.75 0 0 0 1.06 1.06l.72-.719v5.19a.75.75 0 0 0 1.5 0v-5.19l.72.72a.75.75 0 1 0 1.06-1.06l-2-2a.748.748 0 0 0-.817-.164Zm5.287-.057a.75.75 0 0 1 .75.75v5.19l.72-.72a.75.75 0 0 1 1.06 1.06l-2 2a.748.748 0 0 1-1.06 0l-2-2a.75.75 0 0 1 1.06-1.06l.72.72V9.5a.75.75 0 0 1 .75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgExpose);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ExposeSvgIcon from '@bloomreach/banana-theme/icons/expose.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ExposeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ExposeSvgIcon />\n </BrIcon>\n );\n});\n\nExposeIcon.displayName = 'ExposeIcon';\n\nexport default ExposeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgExpression = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.751 3.501a.75.75 0 0 0-1.5 0v1.25h-1.25a.75.75 0 0 0 0 1.5h1.25v1.25a.75.75 0 0 0 1.5 0v-1.25h1.25a.75.75 0 0 0 0-1.5h-1.25v-1.25Zm7.28 3.969a.75.75 0 0 1 0 1.062l-.97.97.97.969a.75.75 0 0 1-1.06 1.06l-.97-.97-.97.97a.75.75 0 0 1-1.06-1.06l.97-.97-.97-.97a.75.75 0 0 1 1.06-1.06l.97.97.97-.97a.75.75 0 0 1 1.06 0Zm-10.28 5.031a.75.75 0 0 1 .75-.75h3.5a.75.75 0 0 1 0 1.5H5.288a1 1 0 1 1-.074 0H3.501a.75.75 0 0 1-.75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.251 10.75a1 1 0 1 1-2 0 1 1 0 0 1 2 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.025.751c.457 0 .896.179 1.223.498l1.975 1.921a1.751 1.751 0 0 1 .528 1.253v11.078a1.75 1.75 0 0 1-1.75 1.75h-12a1.75 1.75 0 0 1-1.75-1.75v-13a1.75 1.75 0 0 1 1.75-1.75h10.024Zm0 1.5H2.002a.25.25 0 0 0-.25.25v13a.25.25 0 0 0 .25.25h12a.25.25 0 0 0 .25-.25V4.423a.251.251 0 0 0-.075-.178L12.2 2.323a.25.25 0 0 0-.175-.072Z\" }));\nconst ForwardRef = forwardRef(SvgExpression);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ExpressionSvgIcon from '@bloomreach/banana-theme/icons/expression.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ExpressionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ExpressionSvgIcon />\n </BrIcon>\n );\n});\n\nExpressionIcon.displayName = 'ExpressionIcon';\n\nexport default ExpressionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgExternalLink = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.97 2.532a.723.723 0 0 0 .531.218h2.688L7.47 7.47a.752.752 0 0 0-.203.53c.01.198.083.37.219.516A.798.798 0 0 0 8 8.735a.752.752 0 0 0 .532-.203l4.718-4.719V6.5c0 .209.073.386.219.532A.723.723 0 0 0 14 7.25a.723.723 0 0 0 .532-.218.723.723 0 0 0 .218-.532V2a.723.723 0 0 0-.218-.53.723.723 0 0 0-.532-.22H9.5a.723.723 0 0 0-.531.22.723.723 0 0 0-.219.53c0 .209.073.386.219.532Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.533 1.47A.723.723 0 0 0 6 1.25H3c-.312 0-.604.079-.875.235-.27.156-.484.37-.64.64A1.717 1.717 0 0 0 1.25 3v10c0 .313.078.605.235.876.156.27.37.484.64.64.271.156.563.235.875.235h10c.313 0 .604-.079.875-.235a1.71 1.71 0 0 0 .64-.64c.157-.271.235-.563.235-.875v-3a.723.723 0 0 0-.218-.532A.723.723 0 0 0 14 9.25a.723.723 0 0 0-.531.22.723.723 0 0 0-.219.53v3a.256.256 0 0 1-.078.188.232.232 0 0 1-.172.063H3a.29.29 0 0 1-.187-.063A.29.29 0 0 1 2.75 13V3a.23.23 0 0 1 .063-.171A.256.256 0 0 1 3 2.75h3a.723.723 0 0 0 .532-.218A.723.723 0 0 0 6.75 2a.723.723 0 0 0-.218-.53Z\" }));\nconst ForwardRef = forwardRef(SvgExternalLink);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ExternalLinkSvgIcon from '@bloomreach/banana-theme/icons/external-link.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ExternalLinkIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ExternalLinkSvgIcon />\n </BrIcon>\n );\n});\n\nExternalLinkIcon.displayName = 'ExternalLinkIcon';\n\nexport default ExternalLinkIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEyeCrossed = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.868 6.384c-.617 0-1.117.5-1.117 1.116a.75.75 0 0 1-1.5 0 2.617 2.617 0 0 1 2.617-2.616.75.75 0 1 1 0 1.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.532 2.53a.75.75 0 1 0-1.06-1.06l-1.817 1.817a8.468 8.468 0 0 0-2.07-.846A6.116 6.116 0 0 0 8 2.251a6.107 6.107 0 0 0-1.584.19c-2.254.566-4.347 2.29-5.729 3.98l-.009.011a1.994 1.994 0 0 0 0 2.466l.01.012a13.977 13.977 0 0 0 2.766 2.577L1.471 13.47a.75.75 0 1 0 1.06 1.06l2.553-2.551a.745.745 0 0 0 .188-.188L7.42 9.643a.75.75 0 0 0 .716.973A2.617 2.617 0 0 0 10.752 8a.75.75 0 0 0-.974-.716l4.754-4.753ZM9.285 7.778A.75.75 0 0 0 9.251 8c0 .617-.5 1.117-1.116 1.117a.75.75 0 0 0-.223.034l1.373-1.374Zm-4.75 2.63C3.51 9.734 2.577 8.85 1.853 7.967a.494.494 0 0 1 0-.603c1.272-1.553 3.108-3.011 4.929-3.468h.004c.393-.102.798-.15 1.204-.145h.02c.405-.005.81.043 1.203.144h.004a6.71 6.71 0 0 1 1.327.5l-6.01 6.012Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.953 4.99a.75.75 0 0 1 1.06-.038c.443.413.851.915 1.183 1.322l.12.147.009.011a1.994 1.994 0 0 1 0 2.466l-.009.011c-1.356 1.66-3.447 3.416-5.732 3.986A6.141 6.141 0 0 1 8 13.084a6.139 6.139 0 0 1-1.426-.152.75.75 0 0 1 .332-1.463c.356.081.72.12 1.085.115h.02a4.64 4.64 0 0 0 1.204-.143l.004-.001c1.845-.46 3.678-1.943 4.93-3.473a.495.495 0 0 0 0-.603l-.115-.142c-.341-.418-.681-.835-1.044-1.173a.75.75 0 0 1-.037-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgEyeCrossed);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EyeCrossedSvgIcon from '@bloomreach/banana-theme/icons/eye-crossed.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EyeCrossedIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EyeCrossedSvgIcon />\n </BrIcon>\n );\n});\n\nEyeCrossedIcon.displayName = 'EyeCrossedIcon';\n\nexport default EyeCrossedIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgEye = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 5.05a2.617 2.617 0 1 0 0 5.234A2.617 2.617 0 0 0 8 5.05ZM6.884 7.668a1.117 1.117 0 1 1 2.233 0 1.117 1.117 0 0 1-2.233 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.585 2.441A6.116 6.116 0 0 0 8 2.251a6.107 6.107 0 0 0-1.584.19c-2.254.566-4.347 2.29-5.729 3.98l-.009.011a1.994 1.994 0 0 0 0 2.466l.01.012c1.358 1.658 3.446 3.413 5.731 3.985A6.135 6.135 0 0 0 8 13.084a6.141 6.141 0 0 0 1.583-.189c2.286-.57 4.377-2.326 5.733-3.986l.008-.01a1.994 1.994 0 0 0 0-2.467l-.008-.011c-1.383-1.69-3.48-3.414-5.731-3.98ZM8.01 3.751c.406-.005.81.043 1.204.144h.004c1.819.457 3.659 1.916 4.93 3.469a.494.494 0 0 1 0 .603c-1.25 1.53-3.084 3.014-4.929 3.473h-.004a4.64 4.64 0 0 1-1.205.144h-.02a4.641 4.641 0 0 1-1.202-.143h-.003c-1.845-.462-3.677-1.945-4.931-3.475a.494.494 0 0 1 0-.602c1.272-1.553 3.108-3.011 4.929-3.468h.004c.393-.102.798-.15 1.204-.145h.019Z\" }));\nconst ForwardRef = forwardRef(SvgEye);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport EyeSvgIcon from '@bloomreach/banana-theme/icons/eye.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst EyeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <EyeSvgIcon />\n </BrIcon>\n );\n});\n\nEyeIcon.displayName = 'EyeIcon';\n\nexport default EyeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFastForward = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.69 1.378A1.25 1.25 0 0 0 .75 2.42v11.16M2.69 1.378l4.06 2.523V2.42a1.25 1.25 0 0 1 1.958-1.03l.004.003 7.999 5.58a1.25 1.25 0 0 1 0 2.056L8.708 14.61a1.25 1.25 0 0 1-1.958-1.03V12.1l-4.06 2.523a1.249 1.249 0 0 1-1.94-1.042m1.5-10.71v10.26l4.854-3.017a.75.75 0 0 1 1.146.637v2.351l7.313-5.101L8.25 2.899v2.352a.75.75 0 0 1-1.146.637L2.25 2.87Z\" }));\nconst ForwardRef = forwardRef(SvgFastForward);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FastForwardSvgIcon from '@bloomreach/banana-theme/icons/fast-forward.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FastForwardIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FastForwardSvgIcon />\n </BrIcon>\n );\n});\n\nFastForwardIcon.displayName = 'FastForwardIcon';\n\nexport default FastForwardIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFile = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15 4.516c0-.219-.042-.432-.125-.64a1.738 1.738 0 0 0-.344-.547L11.844.5a1.653 1.653 0 0 0-.531-.359 1.443 1.443 0 0 0-.625-.14h-7.61a1.89 1.89 0 0 0-.797.171c-.25.105-.474.26-.672.47a2.158 2.158 0 0 0-.453.718c-.104.26-.156.536-.156.828v11.625c0 .292.052.573.156.844.105.27.256.51.453.719.198.197.422.354.672.468.25.104.516.156.797.156h9.844c.281 0 .547-.052.797-.156.25-.114.474-.276.672-.484.198-.208.349-.443.453-.703a2.33 2.33 0 0 0 .156-.844V4.516Zm-12.187-3a.586.586 0 0 1 .265-.062h6.844V3.64c0 .219.042.432.125.64.083.21.198.397.344.563.156.156.333.276.531.36.198.083.401.125.61.125h2.078v8.484c0 .198-.068.37-.204.516a.608.608 0 0 1-.484.218H3.078a.68.68 0 0 1-.5-.203.698.698 0 0 1-.187-.531V2.188c0-.198.067-.37.203-.516a.532.532 0 0 1 .219-.156Zm8.5.484 1.78 1.875h-1.562a.212.212 0 0 1-.156-.062.269.269 0 0 1-.062-.172v-1.64Z\" }));\nconst ForwardRef = forwardRef(SvgFile);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FileSvgIcon from '@bloomreach/banana-theme/icons/file.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FileIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FileSvgIcon />\n </BrIcon>\n );\n});\n\nFileIcon.displayName = 'FileIcon';\n\nexport default FileIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFilter = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.75 2.75v.94l4.252 4.251c.265.266.415.626.415 1.002v3.805l1.167.292V8.944c0-.376.148-.736.413-1.002L13.25 3.69v-.94H2.75Zm10.525.915Zm-11.61-2a1.417 1.417 0 0 1 1.002-.415h10.667a1.417 1.417 0 0 1 1.416 1.417v1.057c0 .376-.15.737-.415 1.002l-4.252 4.251v4.17a1.417 1.417 0 0 1-1.76 1.374l-1.333-.334a1.417 1.417 0 0 1-1.073-1.374V8.978L1.664 4.725a1.417 1.417 0 0 1-.414-1V2.666c0-.376.15-.736.415-1.002Zm8.419 7.278Z\" }));\nconst ForwardRef = forwardRef(SvgFilter);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FilterSvgIcon from '@bloomreach/banana-theme/icons/filter.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FilterIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FilterSvgIcon />\n </BrIcon>\n );\n});\n\nFilterIcon.displayName = 'FilterIcon';\n\nexport default FilterIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFire = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.386 7.424a.332.332 0 0 0-.534-.158c-.393.334-.83.614-1.298.832a.166.166 0 0 1-.236-.14A8.767 8.767 0 0 0 5.172.004a.333.333 0 0 0-.339.498c.547.965.835 2.055.834 3.164a6.04 6.04 0 0 1-.42 2.215.167.167 0 0 1-.295.03 5.85 5.85 0 0 1-.698-1.525.333.333 0 0 0-.534-.162 6.643 6.643 0 0 0-2.386 5.109 6.667 6.667 0 1 0 13.333 0 6.61 6.61 0 0 0-.281-1.91ZM8 14.167a2.68 2.68 0 0 1-2.666-2.742 5.04 5.04 0 0 1 3.1-4.59.167.167 0 0 1 .194.258 2.853 2.853 0 0 0-.313 2.774.17.17 0 0 0 .118.092.167.167 0 0 0 .144-.04c.227-.183.397-.427.49-.704a.163.163 0 0 1 .092-.105.167.167 0 0 1 .14 0 2.467 2.467 0 0 1 1.368 2.39A2.616 2.616 0 0 1 8 14.168Z\" }));\nconst ForwardRef = forwardRef(SvgFire);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FireSvgIcon from '@bloomreach/banana-theme/icons/fire.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FireIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FireSvgIcon />\n </BrIcon>\n );\n});\n\nFireIcon.displayName = 'FireIcon';\n\nexport default FireIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFolderEmpty = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.263.763A1.75 1.75 0 0 1 2.5.25H6a1.75 1.75 0 0 1 1.4.7l.975 1.3H15.5A1.75 1.75 0 0 1 17.25 4v10a1.75 1.75 0 0 1-1.75 1.75h-13A1.75 1.75 0 0 1 .75 14V2c0-.464.185-.909.513-1.237ZM2.5 1.75a.25.25 0 0 0-.25.25v12a.25.25 0 0 0 .25.25h13a.25.25 0 0 0 .25-.25V4a.25.25 0 0 0-.25-.25H8a.75.75 0 0 1-.6-.3l-1.2-1.6a.25.25 0 0 0-.2-.1H2.5Z\" }));\nconst ForwardRef = forwardRef(SvgFolderEmpty);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FolderEmptySvgIcon from '@bloomreach/banana-theme/icons/folder-empty.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FolderEmptyIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FolderEmptySvgIcon />\n </BrIcon>\n );\n});\n\nFolderEmptyIcon.displayName = 'FolderEmptyIcon';\n\nexport default FolderEmptyIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFolderFull = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5.25c-.482 0-.933.208-1.256.556A1.87 1.87 0 0 0 .75 2.077v11.847c0 .467.172.925.494 1.271.323.348.774.556 1.256.556h13c.483 0 .934-.208 1.257-.556a1.87 1.87 0 0 0 .493-1.271V4.23a1.87 1.87 0 0 0-.493-1.272 1.715 1.715 0 0 0-1.257-.555H8.393l-.976-1.401a1.771 1.771 0 0 0-.613-.55A1.692 1.692 0 0 0 6 .25H2.5Z\" }));\nconst ForwardRef = forwardRef(SvgFolderFull);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FolderFullSvgIcon from '@bloomreach/banana-theme/icons/folder-full.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FolderFullIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FolderFullSvgIcon />\n </BrIcon>\n );\n});\n\nFolderFullIcon.displayName = 'FolderFullIcon';\n\nexport default FolderFullIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFormulaExpression = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.376 3.5a.75.75 0 1 0-1.5 0v.375H3.5a.75.75 0 1 0 0 1.5h.375v.375a.75.75 0 0 0 1.5 0v-.375h.375a.75.75 0 1 0 0-1.5h-.375V3.5Zm.905 7.28a.75.75 0 1 0-1.06-1.06l-.595.595-.595-.595a.75.75 0 0 0-1.06 1.06l.594.596-.595.594a.75.75 0 1 0 1.061 1.06l.595-.594.594.595a.75.75 0 0 0 1.061-1.06l-.595-.595.595-.595Zm3.219-.53a.75.75 0 0 1 .75-.75h2.25a.75.75 0 0 1 0 1.5h-2.25a.75.75 0 0 1-.75-.75Zm.75 1.5a.75.75 0 1 0 0 1.5h2.25a.75.75 0 0 0 0-1.5h-2.25Zm0-7.875a.75.75 0 1 0 0 1.5h2.25a.75.75 0 0 0 0-1.5h-2.25Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.5 2.257v11.487c0 .97.787 1.757 1.757 1.757h11.487c.97 0 1.757-.787 1.757-1.757V2.257c0-.97-.787-1.757-1.757-1.757H2.257C1.287.5.501 1.287.501 2.257Zm1.5 0C2 2.115 2.117 2 2.258 2h4.994v5.25H2V2.257Zm0 11.487V8.75h5.25V14H2.258a.257.257 0 0 1-.256-.256Zm12 0a.257.257 0 0 1-.256.257H8.751V8.75H14v4.993ZM8.75 7.25V2h4.994c.142 0 .257.115.257.257V7.25H8.75Z\" }));\nconst ForwardRef = forwardRef(SvgFormulaExpression);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FormulaExpressionSvgIcon from '@bloomreach/banana-theme/icons/formula-expression-.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FormulaExpressionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FormulaExpressionSvgIcon />\n </BrIcon>\n );\n});\n\nFormulaExpressionIcon.displayName = 'FormulaExpressionIcon';\n\nexport default FormulaExpressionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFormula = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.324 2.324a.25.25 0 0 1 .177-.074h2.5a.75.75 0 1 0 0-1.5H2.5A1.75 1.75 0 0 0 .751 2.5v13a1.75 1.75 0 0 0 1.75 1.75h2.5a.75.75 0 0 0 0-1.5H2.5a.25.25 0 0 1-.25-.25v-13a.25.25 0 0 1 .073-.176ZM13 .75a.75.75 0 0 0 0 1.5h2.5a.25.25 0 0 1 .25.25v13a.25.25 0 0 1-.25.25H13a.75.75 0 0 0 0 1.5h2.5a1.75 1.75 0 0 0 1.75-1.75v-13A1.75 1.75 0 0 0 15.5.75H13ZM7.652 5.628A.75.75 0 0 0 6.25 6v7a.75.75 0 0 0 1.5 0V8.826l.598 1.048a.75.75 0 0 0 1.303 0l.599-1.048V13a.75.75 0 0 0 1.5 0V6a.75.75 0 0 0-1.402-.373L9 7.987l-1.35-2.36Z\" }));\nconst ForwardRef = forwardRef(SvgFormula);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FormulaSvgIcon from '@bloomreach/banana-theme/icons/formula.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FormulaIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FormulaSvgIcon />\n </BrIcon>\n );\n});\n\nFormulaIcon.displayName = 'FormulaIcon';\n\nexport default FormulaIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFromStartAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.251.667a.75.75 0 0 1 .75.75v15a.75.75 0 0 1-1.5 0v-15a.75.75 0 0 1 .75-.75Zm14.162 2.397a.75.75 0 0 1-.309 1.015L6.037 8.917l9.069 4.838a.75.75 0 1 1-.707 1.324L4.752 9.932a.75.75 0 0 1-.177-.13 1.25 1.25 0 0 1 0-1.769.75.75 0 0 1 .177-.13l9.646-5.147a.75.75 0 0 1 1.015.308Z\" }));\nconst ForwardRef = forwardRef(SvgFromStartAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FromStartAltSvgIcon from '@bloomreach/banana-theme/icons/from-start-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FromStartAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FromStartAltSvgIcon />\n </BrIcon>\n );\n});\n\nFromStartAltIcon.displayName = 'FromStartAltIcon';\n\nexport default FromStartAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgFullscreen = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.25 2.499a.75.75 0 0 1 .75-.75h4.5a.749.749 0 0 1 .75.75v4.5a.75.75 0 0 1-1.5 0v-2.69l-8.438 8.44H7a.75.75 0 0 1 0 1.5H2.514a.748.748 0 0 1-.763-.75v-4.5a.75.75 0 1 1 1.5 0v2.69l8.44-8.44H9a.75.75 0 0 1-.75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgFullscreen);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport FullscreenSvgIcon from '@bloomreach/banana-theme/icons/fullscreen.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst FullscreenIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <FullscreenSvgIcon />\n </BrIcon>\n );\n});\n\nFullscreenIcon.displayName = 'FullscreenIcon';\n\nexport default FullscreenIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgGift = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.001.75a.75.75 0 0 0-.75.75c0 1.294.63 2.43 1.517 3.25H2.501A1.75 1.75 0 0 0 .751 6.5V8a1.25 1.25 0 0 0 1 1.225v6.276a1.75 1.75 0 0 0 1.75 1.75h11a1.75 1.75 0 0 0 1.75-1.75V9.225a1.25 1.25 0 0 0 1-1.225V6.5a1.75 1.75 0 0 0-1.75-1.75h-2.267c.886-.82 1.517-1.956 1.517-3.25a.75.75 0 0 0-.75-.75c-1.298 0-2.593.522-3.565 1.351C9.809 2.636 9.29 3.322 9 4.11c-.29-.788-.808-1.474-1.435-2.009C6.594 1.272 5.3.751 4.001.751Zm7.25 15v-6.5h3.5v6.25a.25.25 0 0 1-.25.25h-3.25Zm0-8v-1.5h4.25a.25.25 0 0 1 .25.25v1.25h-4.5Zm-1.5-1.5v1.5h-1.5v-1.5h1.5Zm-3 0v1.5h-4.5V6.5a.25.25 0 0 1 .25-.25h4.25Zm0 3v6.5h-3.25a.25.25 0 0 1-.25-.25V9.25h3.5Zm1.5 6.5v-6.5h1.5v6.5h-1.5Zm3.158-12.507a4.247 4.247 0 0 1 1.686-.875c-.187.513-.534.991-1.002 1.39a4.246 4.246 0 0 1-1.686.875c.187-.513.534-.991 1.002-1.39Zm-5.5.515c-.468-.399-.815-.877-1.002-1.39.61.156 1.2.46 1.686.875.468.399.815.877 1.002 1.39-.61-.156-1.2-.46-1.686-.875Z\" }));\nconst ForwardRef = forwardRef(SvgGift);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport GiftSvgIcon from '@bloomreach/banana-theme/icons/gift.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst GiftIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <GiftSvgIcon />\n </BrIcon>\n );\n});\n\nGiftIcon.displayName = 'GiftIcon';\n\nexport default GiftIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgGoTo = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.451.503a7.75 7.75 0 0 0-8.788 3.85.75.75 0 0 0 1.323.706 6.25 6.25 0 1 1-.107 5.68.75.75 0 0 0-1.348.656A7.75 7.75 0 1 0 11.45.503Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.97 4.973a.75.75 0 0 1 1.061 0l2.5 2.5a.748.748 0 0 1 0 1.06l-2.5 2.5a.75.75 0 1 1-1.06-1.06l1.22-1.22H1.5a.75.75 0 1 1 0-1.5h8.69l-1.22-1.22a.75.75 0 0 1 0-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgGoTo);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport GoToSvgIcon from '@bloomreach/banana-theme/icons/go-to.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst GoToIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <GoToSvgIcon />\n </BrIcon>\n );\n});\n\nGoToIcon.displayName = 'GoToIcon';\n\nexport default GoToIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgGraphStats = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.919 4.053 5.449 7.51a1.75 1.75 0 0 1-1.615 1.074H1.501a.75.75 0 0 1 0-1.5h2.333a.25.25 0 0 0 .232-.154l.002-.005L5.8 2.848a1.25 1.25 0 0 1 2.333.085l.005.013 2.934 9.127 1.47-3.889a1.75 1.75 0 0 1 1.625-1.1H16.5a.75.75 0 0 1 0 1.5h-2.333a.25.25 0 0 0-.227.146l-1.725 4.562a1.25 1.25 0 0 1-2.345-.057l-.004-.013L6.92 4.053Z\" }));\nconst ForwardRef = forwardRef(SvgGraphStats);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport GraphStatsSvgIcon from '@bloomreach/banana-theme/icons/graph-stats.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst GraphStatsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <GraphStatsSvgIcon />\n </BrIcon>\n );\n});\n\nGraphStatsIcon.displayName = 'GraphStatsIcon';\n\nexport default GraphStatsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgGridAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.501.749a1.75 1.75 0 0 0-1.75 1.75v4c0 .966.784 1.75 1.75 1.75h4a1.75 1.75 0 0 0 1.75-1.75v-4a1.75 1.75 0 0 0-1.75-1.75h-4Zm-.25 1.75a.25.25 0 0 1 .25-.25h4a.25.25 0 0 1 .25.25v4a.25.25 0 0 1-.25.25h-4a.25.25 0 0 1-.25-.25v-4Zm.25 7.25a1.75 1.75 0 0 0-1.75 1.75v4c0 .966.784 1.75 1.75 1.75h4a1.75 1.75 0 0 0 1.75-1.75v-4a1.75 1.75 0 0 0-1.75-1.75h-4Zm-.25 1.75a.25.25 0 0 1 .25-.25h4a.25.25 0 0 1 .25.25v4a.25.25 0 0 1-.25.25h-4a.25.25 0 0 1-.25-.25v-4Zm7.5-9c0-.967.784-1.75 1.75-1.75h4c.967 0 1.75.783 1.75 1.75v4a1.75 1.75 0 0 1-1.75 1.75h-4a1.75 1.75 0 0 1-1.75-1.75v-4Zm1.75-.25a.25.25 0 0 0-.25.25v4c0 .138.112.25.25.25h4a.25.25 0 0 0 .25-.25v-4a.25.25 0 0 0-.25-.25h-4Zm0 7.5a1.75 1.75 0 0 0-1.75 1.75v4c0 .966.784 1.75 1.75 1.75h4a1.75 1.75 0 0 0 1.75-1.75v-4a1.75 1.75 0 0 0-1.75-1.75h-4Zm-.25 1.75a.25.25 0 0 1 .25-.25h4a.25.25 0 0 1 .25.25v4a.25.25 0 0 1-.25.25h-4a.25.25 0 0 1-.25-.25v-4Z\" }));\nconst ForwardRef = forwardRef(SvgGridAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport GridAltSvgIcon from '@bloomreach/banana-theme/icons/grid-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst GridAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <GridAltSvgIcon />\n </BrIcon>\n );\n});\n\nGridAltIcon.displayName = 'GridAltIcon';\n\nexport default GridAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgGrid = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 2.499c0-.967.784-1.75 1.75-1.75h1c.967 0 1.75.783 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm4.25.25c0-.967.784-1.75 1.75-1.75h1c.967 0 1.75.783 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm6-1.5a1.75 1.75 0 0 0-1.75 1.75v1c0 .966.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Zm-13.5 6c0-.967.784-1.75 1.75-1.75h1c.967 0 1.75.783 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm6-1.5a1.75 1.75 0 0 0-1.75 1.75v1c0 .966.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Zm4.5 0c0-.967.784-1.75 1.75-1.75h1c.967 0 1.75.783 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm-12 4.499a1.75 1.75 0 0 0-1.75 1.75v1c0 .967.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Zm4.5 0c0-.966.784-1.75 1.75-1.75h1c.967 0 1.75.784 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .139.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm6-1.5a1.75 1.75 0 0 0-1.75 1.75v1c0 .967.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Z\" }));\nconst ForwardRef = forwardRef(SvgGrid);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport GridSvgIcon from '@bloomreach/banana-theme/icons/grid.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst GridIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <GridSvgIcon />\n </BrIcon>\n );\n});\n\nGridIcon.displayName = 'GridIcon';\n\nexport default GridIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgHelp = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.092 4.753a1.42 1.42 0 0 0-.69.13 1.189 1.189 0 0 0-.486.408.947.947 0 0 0-.165.528.75.75 0 1 1-1.5 0c0-.487.148-.958.419-1.363.27-.403.65-.723 1.093-.93a2.92 2.92 0 0 1 2.799.177c.41.264.743.632.952 1.07.21.44.283.928.21 1.409a2.49 2.49 0 0 1-.615 1.287 2.76 2.76 0 0 1-1.211.778.248.248 0 0 0-.121.079.105.105 0 0 0-.026.064V9a.75.75 0 1 1-1.5 0v-.609c0-.36.124-.705.342-.986.217-.279.515-.48.846-.586a1.26 1.26 0 0 0 .554-.352.991.991 0 0 0 .248-.511.919.919 0 0 0-.081-.537 1.115 1.115 0 0 0-.41-.454 1.38 1.38 0 0 0-.658-.212ZM8.001 11a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001.25a7.75 7.75 0 1 0 0 15.5 7.75 7.75 0 0 0 0-15.5ZM1.751 8a6.25 6.25 0 1 1 12.5 0 6.25 6.25 0 0 1-12.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgHelp);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport HelpSvgIcon from '@bloomreach/banana-theme/icons/help.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst HelpIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <HelpSvgIcon />\n </BrIcon>\n );\n});\n\nHelpIcon.displayName = 'HelpIcon';\n\nexport default HelpIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgHistory = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.226 1.47A7.25 7.25 0 1 1 10 15.416a.75.75 0 0 1 0-1.5A5.75 5.75 0 1 0 4.454 6.65l.516-.516a.75.75 0 0 1 1.06 1.06L4.062 9.165a.748.748 0 0 1-1.124 0L.97 7.196a.75.75 0 0 1 1.06-1.06l.822.82A7.25 7.25 0 0 1 7.226 1.47Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.25 4.165a.75.75 0 0 0-1.5 0v4.5c0 .415.336.75.75.75H13a.75.75 0 0 0 0-1.5h-2.75v-3.75Z\" }));\nconst ForwardRef = forwardRef(SvgHistory);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport HistorySvgIcon from '@bloomreach/banana-theme/icons/history.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst HistoryIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <HistorySvgIcon />\n </BrIcon>\n );\n});\n\nHistoryIcon.displayName = 'HistoryIcon';\n\nexport default HistoryIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgHome = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.72 9.243c0-.208.073-.386.219-.531a.723.723 0 0 1 .531-.22c.208 0 .385.074.531.22a.723.723 0 0 1 .219.53v5.5a.724.724 0 0 1-.219.532.723.723 0 0 1-.531.219h-4a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.531v-4a.208.208 0 0 0-.078-.172.208.208 0 0 0-.172-.078h-1a.24.24 0 0 0-.172.078.208.208 0 0 0-.078.172v4a.723.723 0 0 1-.219.531.723.723 0 0 1-.531.219h-4a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.531v-5.5c0-.208.073-.386.219-.531a.723.723 0 0 1 .531-.22c.208 0 .385.074.531.22a.723.723 0 0 1 .219.53v4.75h2.5v-3.25c0-.312.078-.603.234-.874.157-.27.37-.484.641-.64.27-.157.562-.235.875-.235h1c.323 0 .614.078.875.234.27.157.484.37.64.64.157.272.235.563.235.876v3.25h2.5v-4.75ZM2.001 8.774A.737.737 0 0 1 .97 8.758a.705.705 0 0 1-.219-.515.698.698 0 0 1 .188-.531L7.736.915c.166-.156.354-.281.562-.375a1.69 1.69 0 0 1 1.344 0c.219.094.406.219.562.375l6.797 6.797a.752.752 0 0 1 .203.53c0 .199-.073.37-.218.517a.815.815 0 0 1-.532.218.733.733 0 0 1-.515-.203L9.142 1.977A.208.208 0 0 0 8.97 1.9a.208.208 0 0 0-.172.078L2.001 8.774Z\" }));\nconst ForwardRef = forwardRef(SvgHome);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport HomeSvgIcon from '@bloomreach/banana-theme/icons/home.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst HomeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <HomeSvgIcon />\n </BrIcon>\n );\n});\n\nHomeIcon.displayName = 'HomeIcon';\n\nexport default HomeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgHtml = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.257 11.503a.75.75 0 0 1 .75-.75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1-.75-.75Zm-1.72-4.531a.75.75 0 1 0-1.06 1.061l1.47 1.47-1.47 1.47a.75.75 0 1 0 1.06 1.06l2-2a.75.75 0 0 0 0-1.06l-2-2Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.257 2.503c0-.967.783-1.75 1.75-1.75h12c.966 0 1.75.783 1.75 1.75v11a1.75 1.75 0 0 1-1.75 1.75h-12a1.75 1.75 0 0 1-1.75-1.75v-11Zm1.5 0v1.25h12.5v-1.25a.25.25 0 0 0-.25-.25h-12a.25.25 0 0 0-.25.25Zm12.5 2.75h-12.5v8.25c0 .138.112.25.25.25h12a.25.25 0 0 0 .25-.25v-8.25Z\" }));\nconst ForwardRef = forwardRef(SvgHtml);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport HtmlSvgIcon from '@bloomreach/banana-theme/icons/html.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst HtmlIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <HtmlSvgIcon />\n </BrIcon>\n );\n});\n\nHtmlIcon.displayName = 'HtmlIcon';\n\nexport default HtmlIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgImages = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.792 4.918a.75.75 0 0 1 .949-.475l2.654.885a1.252 1.252 0 0 1 .79 1.581l-3.161 9.487a1.252 1.252 0 0 1-1.582.79l-7.176-2.392a.75.75 0 0 1 .475-1.423l6.939 2.313 3.004-9.012-2.417-.806a.75.75 0 0 1-.475-.948Zm2.97 1.517ZM4.376 2.5a1.875 1.875 0 1 0 0 3.751 1.875 1.875 0 0 0 0-3.75ZM4 4.377a.375.375 0 1 1 .751 0 .375.375 0 0 1-.75 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.75 2C.75 1.31 1.31.75 2 .75h9c.69 0 1.25.56 1.25 1.25v10c0 .691-.56 1.25-1.25 1.25H2A1.25 1.25 0 0 1 .75 12V2Zm1.5 6.75h1.86l2.542-3.633a1.752 1.752 0 0 1 2.753-.15l1.345 1.538V2.25h-8.5v6.5Zm6.026-2.795a.254.254 0 0 0-.203-.086.25.25 0 0 0-.191.106L5.94 8.751h4.782L8.276 5.955ZM2.25 10.25v1.5h8.5v-1.5h-8.5Z\" }));\nconst ForwardRef = forwardRef(SvgImages);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ImagesSvgIcon from '@bloomreach/banana-theme/icons/images.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ImagesIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ImagesSvgIcon />\n </BrIcon>\n );\n});\n\nImagesIcon.displayName = 'ImagesIcon';\n\nexport default ImagesIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgInfoFilled = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15 8A7 7 0 1 1 1 8a7 7 0 0 1 14 0ZM7.8 6a1 1 0 1 0 0-2 1 1 0 0 0 0 2Zm1.4 4.69h-.3v-3a.7.7 0 0 0-.7-.7h-1a.7.7 0 1 0 0 1.4h.3v2.35h-.3a.7.7 0 1 0 0 1.4h2a.7.7 0 1 0 0-1.4v-.05Z\" }));\nconst ForwardRef = forwardRef(SvgInfoFilled);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport InfoFilledSvgIcon from '@bloomreach/banana-theme/icons/info-filled.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst InfoFilledIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <InfoFilledSvgIcon />\n </BrIcon>\n );\n});\n\nInfoFilledIcon.displayName = 'InfoFilledIcon';\n\nexport default InfoFilledIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgInfo = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.8 6a1 1 0 1 0 0-2 1 1 0 0 0 0 2Zm1.4 4.69h-.3v-3a.7.7 0 0 0-.7-.7h-1a.7.7 0 1 0 0 1.4h.3v2.35h-.3a.7.7 0 1 0 0 1.4h2a.7.7 0 1 0 0-1.4v-.05Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 .25a7.75 7.75 0 1 0 0 15.5A7.75 7.75 0 0 0 8 .25ZM1.75 8a6.25 6.25 0 1 1 12.5 0 6.25 6.25 0 0 1-12.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgInfo);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport InfoSvgIcon from '@bloomreach/banana-theme/icons/info.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst InfoIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <InfoSvgIcon />\n </BrIcon>\n );\n});\n\nInfoIcon.displayName = 'InfoIcon';\n\nexport default InfoIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgInfoSmall = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14 8A6 6 0 1 1 2 8a6 6 0 0 1 12 0ZM7.83 6.286a.857.857 0 1 0 0-1.714.857.857 0 0 0 0 1.714Zm1.2 4.02h-.257V7.734a.6.6 0 0 0-.6-.6h-.858a.6.6 0 0 0 0 1.2h.258v2.015h-.258a.6.6 0 1 0 0 1.2H9.03a.6.6 0 0 0 0-1.2v-.043Z\" }));\nconst ForwardRef = forwardRef(SvgInfoSmall);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport InfoSmallSvgIcon from '@bloomreach/banana-theme/icons/info-small.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst InfoSmallIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <InfoSmallSvgIcon />\n </BrIcon>\n );\n});\n\nInfoSmallIcon.displayName = 'InfoSmallIcon';\n\nexport default InfoSmallIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgInternet = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.755 6.065a8.754 8.754 0 0 1 16.503.035c.319.908.492 1.884.492 2.9a8.736 8.736 0 0 1-.503 2.934A8.76 8.76 0 0 1 9 17.75a8.754 8.754 0 0 1-8.258-5.852A8.736 8.736 0 0 1 .25 9.001a8.736 8.736 0 0 1 .505-2.936Zm10.506 9.826a7.271 7.271 0 0 0 4.135-3.473h-3.325a26.486 26.486 0 0 1-.81 3.473Zm-.71-3.473H7.455c.224 1.288.549 2.563.974 3.81a7.318 7.318 0 0 0 1.146 0c.425-1.244.75-2.518.974-3.81Zm1.721-1.5h3.722c.167-.61.256-1.254.256-1.917 0-.664-.089-1.307-.256-1.917h-3.596c.013.342.02.685.019 1.028.002.939-.047 1.875-.145 2.806Zm-1.375-3.834H7.105a25.165 25.165 0 0 0 .136 3.834h3.523c.103-.93.155-1.866.153-2.805v-.002c0-.343-.006-.685-.02-1.027Zm1.402-1.5h3.097a7.278 7.278 0 0 0-3.618-3.282c.242 1.082.416 2.178.52 3.282Zm-2.175-3.747a7.306 7.306 0 0 0-2.246 0 25.158 25.158 0 0 0-.667 3.747h3.58a25.017 25.017 0 0 0-.668-3.747ZM2.006 7.084A7.258 7.258 0 0 0 1.75 9c0 .663.09 1.306.257 1.917h3.725a26.664 26.664 0 0 1-.129-3.834H2.007Zm.598 5.334a7.271 7.271 0 0 0 4.14 3.475 26.654 26.654 0 0 1-.81-3.475h-3.33Zm0-6.834h3.098c.105-1.1.278-2.197.52-3.282a7.278 7.278 0 0 0-3.618 3.282Z\" }));\nconst ForwardRef = forwardRef(SvgInternet);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport InternetSvgIcon from '@bloomreach/banana-theme/icons/internet.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst InternetIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <InternetSvgIcon />\n </BrIcon>\n );\n});\n\nInternetIcon.displayName = 'InternetIcon';\n\nexport default InternetIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgKey = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.5 3a1.5 1.5 0 1 1 0 3 1.5 1.5 0 0 1 0-3Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.9 15.101a2.216 2.216 0 0 1 0-3.134l5.725-5.725A4.66 4.66 0 1 1 9.76 9.376l-.941.941.18.673a1.728 1.728 0 0 1-2.115 2.115l-.502-.135.134.502A1.728 1.728 0 0 1 4.4 15.588l-.726-.194c-.86.559-2.02.461-2.775-.293Zm1.06-2.073a.716.716 0 1 0 1.013 1.013.75.75 0 0 1 .724-.194l1.09.292a.228.228 0 0 0 .28-.279l-.293-1.09a.75.75 0 0 1 .194-.724l.488-.488a.75.75 0 0 1 .725-.194l1.089.292a.228.228 0 0 0 .279-.28l-.292-1.088a.75.75 0 0 1 .194-.725l1.583-1.584a.75.75 0 0 1 .823-.16 3.16 3.16 0 1 0-1.675-1.675.75.75 0 0 1-.16.823L1.96 13.028Z\" }));\nconst ForwardRef = forwardRef(SvgKey);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport KeySvgIcon from '@bloomreach/banana-theme/icons/key.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst KeyIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <KeySvgIcon />\n </BrIcon>\n );\n});\n\nKeyIcon.displayName = 'KeyIcon';\n\nexport default KeyIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLayout = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.75 15.834c0 .782.635 1.417 1.417 1.417h13.667c.782 0 1.417-.635 1.417-1.417V2.167c0-.782-.635-1.416-1.417-1.416H2.167A1.415 1.415 0 0 0 .751 2.167v13.667Zm1.5-8.583h3.5v8.5h-3.5v-8.5Zm0-1.5v-3.5h3.5v3.5h-3.5Zm5 1.5h8.5v8.5h-8.5v-8.5Zm8.5-1.5h-8.5v-3.5h8.5v3.5Z\" }));\nconst ForwardRef = forwardRef(SvgLayout);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LayoutSvgIcon from '@bloomreach/banana-theme/icons/layout.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LayoutIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LayoutSvgIcon />\n </BrIcon>\n );\n});\n\nLayoutIcon.displayName = 'LayoutIcon';\n\nexport default LayoutIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLike = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.49 16.251a.75.75 0 0 1-.74-.75V9.037a.75.75 0 0 1 .75-.75 4.25 4.25 0 0 0 4.25-4.25V3a2.25 2.25 0 0 1 4.5 0v2.254c0 .115.079.215.17.238l.992.218a3.752 3.752 0 0 1 2.833 3.834l-.202 3.43a4.75 4.75 0 0 1-4.726 4.276H9.06c-.441 0-.88-.062-1.304-.183l-2.423-.692a3.252 3.252 0 0 0-.844-.125Zm1.255-1.317 2.423.692c.29.083.59.125.892.125h3.257c1.669 0 3.066-1.264 3.231-2.894l.2-3.394A2.245 2.245 0 0 0 14.07 7.17l-.99-.217a1.75 1.75 0 0 1-1.33-1.699V3.001a.75.75 0 0 0-1.5 0v1.036a5.751 5.751 0 0 1-5 5.701v5.082c.167.03.332.067.495.114ZM2.251 8.25v7.5h1.5v-7.5h-1.5Zm-.75-1.5h3a.75.75 0 0 1 .75.75v9a.75.75 0 0 1-.75.75h-3a.75.75 0 0 1-.75-.75v-9a.75.75 0 0 1 .75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgLike);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LikeSvgIcon from '@bloomreach/banana-theme/icons/like.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LikeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LikeSvgIcon />\n </BrIcon>\n );\n});\n\nLikeIcon.displayName = 'LikeIcon';\n\nexport default LikeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLineChart = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25 1.5a.75.75 0 1 0-1.5 0v15.001c0 .414.337.75.75.75h14.996a.75.75 0 0 0 0-1.5H2.251v-2.826l4.16-2.496c.194-.117.417-.178.644-.178h3.513c.392 0 .78-.085 1.138-.247l5.105-2.32a.75.75 0 1 0-.62-1.366l-5.106 2.32c-.163.074-.34.113-.518.113H7.055c-.499 0-.988.135-1.415.391l-3.39 2.034V1.501Z\" }));\nconst ForwardRef = forwardRef(SvgLineChart);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LineChartSvgIcon from '@bloomreach/banana-theme/icons/line-chart.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LineChartIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LineChartSvgIcon />\n </BrIcon>\n );\n});\n\nLineChartIcon.displayName = 'LineChartIcon';\n\nexport default LineChartIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLink = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.5 4.584a3.729 3.729 0 0 0-2.781 1.252.75.75 0 0 0 1.121.996 2.23 2.23 0 0 1 1.662-.748h.999a2.25 2.25 0 0 1 0 4.5h-1a2.231 2.231 0 0 1-1.661-.748.75.75 0 0 0-1.12.996 3.732 3.732 0 0 0 2.78 1.252h1a3.75 3.75 0 0 0 0-7.5h-1Zm-8 0a3.75 3.75 0 1 0 0 7.5h1.003a3.733 3.733 0 0 0 2.78-1.252.75.75 0 1 0-1.121-.997 2.233 2.233 0 0 1-1.662.749h-1a2.25 2.25 0 0 1 0-4.5h1a2.23 2.23 0 0 1 1.662.748.75.75 0 0 0 1.12-.996 3.73 3.73 0 0 0-2.78-1.252H4.501Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5 7.583a.75.75 0 1 0 0 1.5h7a.75.75 0 0 0 0-1.5h-7Z\" }));\nconst ForwardRef = forwardRef(SvgLink);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LinkSvgIcon from '@bloomreach/banana-theme/icons/link.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LinkIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LinkSvgIcon />\n </BrIcon>\n );\n});\n\nLinkIcon.displayName = 'LinkIcon';\n\nexport default LinkIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgList = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.001 2.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0Zm0 6a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0Zm-1.5 7.5a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm4-14.25a.75.75 0 1 0 0 1.5h10a.75.75 0 0 0 0-1.5h-10Zm-.75 6.75a.75.75 0 0 1 .75-.75h10a.75.75 0 0 1 0 1.5h-10a.75.75 0 0 1-.75-.75Zm.75 5.25a.75.75 0 0 0 0 1.5h10a.75.75 0 0 0 0-1.5h-10Z\" }));\nconst ForwardRef = forwardRef(SvgList);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ListSvgIcon from '@bloomreach/banana-theme/icons/list.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ListIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ListSvgIcon />\n </BrIcon>\n );\n});\n\nListIcon.displayName = 'ListIcon';\n\nexport default ListIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLoader = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.801 8c.663 0 1.21-.54 1.11-1.195a8 8 0 1 0-9.105 9.106C7.46 16.01 8 15.464 8 14.8s-.543-1.187-1.19-1.328a5.602 5.602 0 0 1-4.302-6.565 5.6 5.6 0 0 1 10.964-.098c.14.647.665 1.19 1.328 1.19Z\" }));\nconst ForwardRef = forwardRef(SvgLoader);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LoaderSvgIcon from '@bloomreach/banana-theme/icons/loader.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LoaderIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LoaderSvgIcon />\n </BrIcon>\n );\n});\n\nLoaderIcon.displayName = 'LoaderIcon';\n\nexport default LoaderIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgLock = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.751 11a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.751 5v1.75h-.25a1.75 1.75 0 0 0-1.75 1.75v7c0 .967.784 1.75 1.75 1.75h9a1.75 1.75 0 0 0 1.75-1.75v-7a1.75 1.75 0 0 0-1.75-1.75h-.25V5a4.25 4.25 0 0 0-8.5 0Zm4.25-2.75A2.75 2.75 0 0 1 10.751 5v1.75h-5.5V5a2.75 2.75 0 0 1 2.75-2.75Zm-4.5 6h9a.25.25 0 0 1 .25.25v7a.25.25 0 0 1-.25.25h-9a.25.25 0 0 1-.25-.25v-7a.25.25 0 0 1 .25-.25Z\" }));\nconst ForwardRef = forwardRef(SvgLock);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport LockSvgIcon from '@bloomreach/banana-theme/icons/lock.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst LockIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <LockSvgIcon />\n </BrIcon>\n );\n});\n\nLockIcon.displayName = 'LockIcon';\n\nexport default LockIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMap = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.116 1.123c-.083.02-1.136.43-2.34.912-1.205.482-2.228.876-2.273.876-.045 0-.963-.353-2.039-.784-2.153-.861-2.066-.83-2.313-.866-.499-.075-1.024.212-1.258.687l-.097.197-.008 5.083c-.008 5.608-.02 5.227.181 5.636.116.237.446.584.667.702.167.089 4.298 1.744 4.44 1.779.05.012.17.033.268.047.356.052.484.01 2.868-.944 1.221-.488 2.25-.887 2.287-.887.036 0 .978.364 2.092.809 1.391.555 2.09.819 2.23.843.39.066.77-.066 1.056-.366.092-.096.203-.252.248-.348l.081-.173.008-5.07c.006-3.586-.002-5.116-.025-5.23-.09-.435-.455-.911-.86-1.124-.29-.151-4.236-1.724-4.458-1.776a1.847 1.847 0 0 0-.755-.003ZM4.06 3.563l1.702.68v4.689c0 2.579-.01 4.689-.023 4.689-.012 0-.77-.3-1.687-.663-1.154-.46-1.686-.686-1.733-.737l-.067-.073V7.496c0-4.417.003-4.65.052-4.632.03.01.82.325 1.756.699Zm6.712 3.964c0 3.706-.008 4.683-.038 4.706-.045.035-3.429 1.388-3.472 1.388-.02 0-.028-1.57-.023-4.688l.008-4.687 1.725-.695a75.81 75.81 0 0 1 1.762-.697c.03-.002.038.95.038 4.673Zm3.196-3.998c1.173.47 1.71.698 1.74.742.038.055.044.655.044 4.707 0 2.554-.01 4.643-.023 4.643-.012 0-.802-.312-1.754-.693l-1.733-.693V7.543c0-2.581.007-4.692.015-4.692s.778.305 1.711.678Z\" }));\nconst ForwardRef = forwardRef(SvgMap);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MapSvgIcon from '@bloomreach/banana-theme/icons/map.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MapIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MapSvgIcon />\n </BrIcon>\n );\n});\n\nMapIcon.displayName = 'MapIcon';\n\nexport default MapIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMetricAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.809 2.276a.75.75 0 0 1 .844.353L8 6.739l2.35-4.11a.75.75 0 0 1 1.4.372v10.5a.75.75 0 1 1-1.5 0V5.825L8.653 8.623a.75.75 0 0 1-1.303 0L5.751 5.825v7.676a.75.75 0 0 1-1.5 0V3a.75.75 0 0 1 .558-.725Z\" }));\nconst ForwardRef = forwardRef(SvgMetricAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MetricAltSvgIcon from '@bloomreach/banana-theme/icons/metric-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MetricAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MetricAltSvgIcon />\n </BrIcon>\n );\n});\n\nMetricAltIcon.displayName = 'MetricAltIcon';\n\nexport default MetricAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMinus = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.251 8a.75.75 0 0 1 .75-.75h8a.75.75 0 0 1 0 1.5h-8a.75.75 0 0 1-.75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgMinus);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MinusSvgIcon from '@bloomreach/banana-theme/icons/minus.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MinusIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MinusSvgIcon />\n </BrIcon>\n );\n});\n\nMinusIcon.displayName = 'MinusIcon';\n\nexport default MinusIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobileAppInbox = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.75 1.75C4.75.785 5.534 0 6.5 0h7c.966 0 1.75.784 1.75 1.75v4A1.75 1.75 0 0 1 13.5 7.5h-7a1.75 1.75 0 0 1-1.75-1.75v-4Zm2.53-.25 2.293 1.647a.735.735 0 0 0 .427.134c.16 0 .31-.05.427-.134l2.293-1.646H7.28Zm6.47 1.108-2.448 1.758A2.235 2.235 0 0 1 10 4.78c-.465 0-.923-.144-1.302-.415L6.25 2.608v3.143c0 .138.112.25.25.25h7a.25.25 0 0 0 .25-.25V2.608Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25 3.5c0-.69.56-1.25 1.25-1.25a.75.75 0 1 0 0-1.5A2.75 2.75 0 0 0 .75 3.5v10a2.75 2.75 0 0 0 2.75 2.75h4a2.75 2.75 0 0 0 2.75-2.75V9a.75.75 0 1 0-1.5 0v2.75h-6.5V3.5Zm0 9.75h6.5v.25a1.25 1.25 0 0 1-1.25 1.25h-4a1.25 1.25 0 0 1-1.25-1.25v-.25Z\" }));\nconst ForwardRef = forwardRef(SvgMobileAppInbox);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobileAppInboxSvgIcon from '@bloomreach/banana-theme/icons/mobile-app-inbox.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobileAppInboxIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobileAppInboxSvgIcon />\n </BrIcon>\n );\n});\n\nMobileAppInboxIcon.displayName = 'MobileAppInboxIcon';\n\nexport default MobileAppInboxIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobileImageMessage = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.375 2.75a1.875 1.875 0 1 0 0 3.751 1.875 1.875 0 0 0 0-3.75ZM11 4.627a.375.375 0 1 1 .75 0 .375.375 0 0 1-.75 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5.75a.75.75 0 0 0-.75.75v9c0 .415.336.75.75.75h9a.75.75 0 0 0 .75-.75v-9a.75.75 0 0 0-.75-.75h-9Zm.75 9V8.326a.753.753 0 0 0 .153-.075c.43-.273.9-.437 1.381-.485a3.04 3.04 0 0 1 1.427.204c.46.182.886.477 1.247.868.246.267.457.575.625.914H6.25Zm1.386-3.477c-.478.047-.945.17-1.386.364V2.25h7.5v7.5h-1.043a5.531 5.531 0 0 0-1.146-1.93 4.913 4.913 0 0 0-1.797-1.246 4.54 4.54 0 0 0-2.128-.302Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.5 3.25c-.69 0-1.25.56-1.25 1.25v8.25h6.5v-.25a.75.75 0 0 1 1.5 0v2a2.75 2.75 0 0 1-2.75 2.75h-4A2.75 2.75 0 0 1 .75 14.5v-10A2.75 2.75 0 0 1 3.5 1.75a.75.75 0 0 1 0 1.5ZM2.25 14.5c0 .691.56 1.25 1.25 1.25h4a1.25 1.25 0 0 0 1.25-1.25v-.25h-6.5v.25Z\" }));\nconst ForwardRef = forwardRef(SvgMobileImageMessage);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobileImageMessageSvgIcon from '@bloomreach/banana-theme/icons/mobile-image-message.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobileImageMessageIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobileImageMessageSvgIcon />\n </BrIcon>\n );\n});\n\nMobileImageMessageIcon.displayName = 'MobileImageMessageIcon';\n\nexport default MobileImageMessageIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobilePhoneLandscape = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.5 2.75a2.75 2.75 0 0 1 2.75 2.75v5a2.75 2.75 0 0 1-2.75 2.75h-11A2.75 2.75 0 0 1 .75 10.5v-5A2.75 2.75 0 0 1 3.5 2.75h11Zm0 1.5H5.25v7.5h9.25a1.25 1.25 0 0 0 1.25-1.25v-5c0-.69-.559-1.25-1.25-1.25Zm-10.75 7.5v-7.5H3.5c-.69 0-1.25.56-1.25 1.25v5c0 .691.56 1.25 1.25 1.25h.25Z\" }));\nconst ForwardRef = forwardRef(SvgMobilePhoneLandscape);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobilePhoneLandscapeSvgIcon from '@bloomreach/banana-theme/icons/mobile-phone-landscape.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobilePhoneLandscapeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobilePhoneLandscapeSvgIcon />\n </BrIcon>\n );\n});\n\nMobilePhoneLandscapeIcon.displayName = 'MobilePhoneLandscapeIcon';\n\nexport default MobilePhoneLandscapeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobilePhonePortrait = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.75 3.5A2.75 2.75 0 0 1 5.5.75h5a2.75 2.75 0 0 1 2.75 2.75v11a2.75 2.75 0 0 1-2.75 2.75h-5a2.75 2.75 0 0 1-2.75-2.75v-11Zm1.5 0v9.25h7.5V3.5c0-.69-.559-1.25-1.25-1.25h-5c-.69 0-1.25.56-1.25 1.25Zm7.5 10.75h-7.5v.25c0 .691.56 1.25 1.25 1.25h5a1.25 1.25 0 0 0 1.25-1.25v-.25Z\" }));\nconst ForwardRef = forwardRef(SvgMobilePhonePortrait);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobilePhonePortraitSvgIcon from '@bloomreach/banana-theme/icons/mobile-phone-portrait.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobilePhonePortraitIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobilePhonePortraitSvgIcon />\n </BrIcon>\n );\n});\n\nMobilePhonePortraitIcon.displayName = 'MobilePhonePortraitIcon';\n\nexport default MobilePhonePortraitIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobilePush = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.505.027a3.254 3.254 0 0 0-2.802 2.618c-.034.175-.047.508-.059 1.466L7.63 5.349l-.066.066c-.049.05-.122.074-.3.1-.29.042-.428.128-.533.33-.062.122-.072.179-.072.398 0 .22.01.277.072.398.097.188.266.293.527.326.107.014.952.027 1.88.029 1.393.003 1.66.009 1.53.037a.911.911 0 0 0-.602.422.9.9 0 0 0-.157.61.971.971 0 0 0 1.054.906c.462-.037.815-.366.898-.838.087-.491-.292-1.032-.775-1.106-.066-.01.695-.026 1.692-.035 1.374-.012 1.841-.024 1.927-.052.15-.05.34-.241.38-.385.038-.14.04-.477.003-.606-.072-.254-.287-.408-.618-.443-.127-.014-.202-.04-.255-.085l-.077-.065-.016-1.3c-.019-1.45-.025-1.495-.227-2.003A3.224 3.224 0 0 0 11.24.028a2.55 2.55 0 0 0-.735-.001ZM2.13.536C1.154.699.387 1.385.078 2.37L0 2.617v11.248l.078.247c.28.892.88 1.492 1.772 1.772l.247.078H4.69c2.871 0 2.735.008 3.208-.187.633-.26 1.192-.848 1.41-1.482.135-.394.145-.515.146-1.901.001-.915-.009-1.346-.032-1.434-.069-.26-.27-.416-.569-.443-.573-.052-.837.17-.869.73l-.015.254H1.46V7.227c0-4.737-.01-4.456.187-4.754a1.18 1.18 0 0 1 .205-.233c.345-.264.32-.261 2.064-.261 1.618 0 1.657-.003 1.833-.165.27-.248.282-.864.024-1.122-.185-.185-.2-.186-1.946-.183C2.97.51 2.205.523 2.13.536Zm9.26 1.023c.527.15 1.001.614 1.183 1.157.06.176.062.238.072 1.48l.01 1.297H9.123l.01-1.254c.008-1.394.013-1.438.196-1.806.194-.391.648-.77 1.055-.88.33-.091.678-.09 1.006.006Zm-.31 5.97c.396.18.416.738.032.912a.506.506 0 0 1-.633-.161c-.067-.088-.08-.132-.08-.28 0-.22.09-.373.273-.462.153-.073.26-.076.408-.01Zm-3.109 5.805c-.009.298-.022.385-.074.5-.14.308-.418.546-.732.626-.152.039-.468.043-2.522.036l-2.348-.008-.19-.09a1.114 1.114 0 0 1-.54-.54c-.077-.164-.089-.226-.1-.493a2.076 2.076 0 0 1 .004-.348c.015-.04.357-.044 3.265-.044h3.248l-.01.36Z\" }));\nconst ForwardRef = forwardRef(SvgMobilePush);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobilePushSvgIcon from '@bloomreach/banana-theme/icons/mobile-push.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobilePushIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobilePushSvgIcon />\n </BrIcon>\n );\n});\n\nMobilePushIcon.displayName = 'MobilePushIcon';\n\nexport default MobilePushIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobileSms = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.234 3.284a.983.983 0 1 0 0 1.967.983.983 0 0 0 0-1.967Zm1.35.983a.983.983 0 1 1 1.966 0 .983.983 0 0 1-1.966 0Zm3.316-.983a.983.983 0 1 0 0 1.967.983.983 0 0 0 0-1.967Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.384 2.867A2.617 2.617 0 0 1 8 .251h5.134a2.617 2.617 0 0 1 2.617 2.616v2.8a2.617 2.617 0 0 1-2.617 2.617h-.156l-2.114 2.114a.75.75 0 0 1-1.28-.53V8.283H8a2.617 2.617 0 0 1-2.616-2.617v-2.8ZM8 1.751c-.616 0-1.116.5-1.116 1.116v2.8c0 .617.5 1.117 1.116 1.117h2.334a.75.75 0 0 1 .75.75v.523l1.053-1.053a.75.75 0 0 1 .53-.22h.467c.617 0 1.117-.5 1.117-1.117v-2.8c0-.616-.5-1.116-1.117-1.116H8Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.267 1.184H2.701a2.452 2.452 0 0 0-2.45 2.45v9.667a2.45 2.45 0 0 0 2.45 2.45h4.066a2.45 2.45 0 0 0 2.45-2.45V9.4a.75.75 0 0 0-1.5 0v2.05H1.75V3.635a.95.95 0 0 1 .951-.95h1.566a.75.75 0 1 0 0-1.5ZM1.75 12.951h5.967v.35a.95.95 0 0 1-.95.95H2.701a.95.95 0 0 1-.95-.95v-.35Z\" }));\nconst ForwardRef = forwardRef(SvgMobileSms);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobileSmsSvgIcon from '@bloomreach/banana-theme/icons/mobile-sms.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobileSmsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobileSmsSvgIcon />\n </BrIcon>\n );\n});\n\nMobileSmsIcon.displayName = 'MobileSmsIcon';\n\nexport default MobileSmsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMobileTextMessage = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.75 3.5a.75.75 0 0 1 .75-.75h5a.75.75 0 0 1 0 1.5h-5a.75.75 0 0 1-.75-.75Zm.75 1.25a.75.75 0 0 0 0 1.5h5a.75.75 0 0 0 0-1.5h-5ZM6.75 7.5a.75.75 0 0 1 .75-.75h3a.75.75 0 0 1 0 1.5h-3a.75.75 0 0 1-.75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.5.75A2.75 2.75 0 0 0 4.75 3.5v4a2.75 2.75 0 0 0 2.75 2.75h5a2.75 2.75 0 0 0 2.75-2.75v-4A2.75 2.75 0 0 0 12.5.75h-5ZM6.25 3.5c0-.69.56-1.25 1.25-1.25h5c.69 0 1.25.56 1.25 1.25v4c0 .691-.56 1.25-1.25 1.25h-5A1.25 1.25 0 0 1 6.25 7.5v-4Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.251 4.5c0-.69.56-1.25 1.25-1.25a.75.75 0 1 0 0-1.5A2.75 2.75 0 0 0 .751 4.5v10a2.75 2.75 0 0 0 2.75 2.75h4a2.75 2.75 0 0 0 2.75-2.75v-3a.75.75 0 1 0-1.5 0v1.25h-6.5V4.5Zm0 9.75h6.5v.25c0 .691-.56 1.25-1.25 1.25h-4a1.25 1.25 0 0 1-1.25-1.25v-.25Z\" }));\nconst ForwardRef = forwardRef(SvgMobileTextMessage);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MobileTextMessageSvgIcon from '@bloomreach/banana-theme/icons/mobile-text-message.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MobileTextMessageIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MobileTextMessageSvgIcon />\n </BrIcon>\n );\n});\n\nMobileTextMessageIcon.displayName = 'MobileTextMessageIcon';\n\nexport default MobileTextMessageIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgMove = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.47.969a.748.748 0 0 1 .244-.163L9 .75c.207 0 .394.084.53.22l2 2a.75.75 0 1 1-1.06 1.06l-.72-.72v4.94h4.939l-.72-.72a.75.75 0 1 1 1.061-1.06l2 2a.748.748 0 0 1 0 1.06l-2 2a.75.75 0 0 1-1.06-1.06l.719-.72H9.75v4.94l.72-.72a.75.75 0 0 1 1.061 1.06l-2 2a.748.748 0 0 1-1.06 0l-2-2a.75.75 0 0 1 1.06-1.06l.72.72V9.75H3.31l.72.72a.75.75 0 0 1-1.06 1.06l-2-2a.748.748 0 0 1 0-1.06l2-2a.75.75 0 1 1 1.06 1.06l-.72.72h4.94V3.31l-.72.72a.75.75 0 0 1-1.06-1.06l2-2Z\" }));\nconst ForwardRef = forwardRef(SvgMove);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport MoveSvgIcon from '@bloomreach/banana-theme/icons/move.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst MoveIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <MoveSvgIcon />\n </BrIcon>\n );\n});\n\nMoveIcon.displayName = 'MoveIcon';\n\nexport default MoveIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgNegation = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.546 2.667a1.13 1.13 0 0 0-.363-.848 1.13 1.13 0 0 0-.849-.364H2.667a1.18 1.18 0 0 0-.863.364 1.155 1.155 0 0 0-.349.848v10.667c0 .333.116.621.349.864.242.232.53.348.863.348h10.667c.334 0 .616-.116.849-.348a1.18 1.18 0 0 0 .363-.864V2.667Zm1.455 0v10.667c0 .485-.121.934-.364 1.349A2.628 2.628 0 0 1 13.334 16H2.667a2.71 2.71 0 0 1-1.348-.349 2.785 2.785 0 0 1-.97-.97 2.71 2.71 0 0 1-.348-1.348V2.667A2.627 2.627 0 0 1 1.319.364 2.623 2.623 0 0 1 2.667.001h10.667c.485 0 .93.12 1.334.363.414.233.737.556.97.97.242.404.363.849.363 1.333ZM5.819 6.304v5.575a.7.7 0 0 1-.212.516.701.701 0 0 1-.515.212.701.701 0 0 1-.515-.212.701.701 0 0 1-.213-.515V4.122c0-.222.081-.399.243-.53a.747.747 0 0 1 .545-.197c.212.01.384.106.515.288l4.516 6.015V4.122c0-.202.07-.374.212-.515a.701.701 0 0 1 .515-.212c.202 0 .374.07.515.212a.701.701 0 0 1 .212.515v7.758c0 .222-.08.404-.242.545a.8.8 0 0 1-.56.182.637.637 0 0 1-.5-.288L5.818 6.304Z\" }));\nconst ForwardRef = forwardRef(SvgNegation);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport NegationSvgIcon from '@bloomreach/banana-theme/icons/negation.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst NegationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <NegationSvgIcon />\n </BrIcon>\n );\n});\n\nNegationIcon.displayName = 'NegationIcon';\n\nexport default NegationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgNotification = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 .75a.75.75 0 0 1 .75.75v.8a5.75 5.75 0 0 1 5 5.7c0 2.302.247 3.595.466 4.285.109.344.209.53.263.617.018.028.03.046.037.054a.75.75 0 0 1-.515 1.295H2a.75.75 0 0 1-.59-1.215c.013-.022.04-.067.077-.139a4.77 4.77 0 0 0 .294-.775c.226-.766.469-2.068.469-4.121a5.75 5.75 0 0 1 5-5.701v-.8A.75.75 0 0 1 8 .75ZM4.997 4.997A4.25 4.25 0 0 0 3.75 8c0 2.17-.257 3.617-.53 4.546l-.064.204h9.633l-.004-.012c-.28-.885-.535-2.342-.535-4.738a4.25 4.25 0 0 0-7.255-3.005Zm1.459 9.784a.75.75 0 0 1 .931.508.641.641 0 0 0 1.231 0 .75.75 0 1 1 1.44.423 2.141 2.141 0 0 1-4.11 0 .75.75 0 0 1 .508-.93Z\" }));\nconst ForwardRef = forwardRef(SvgNotification);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport NotificationSvgIcon from '@bloomreach/banana-theme/icons/notification.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst NotificationIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <NotificationSvgIcon />\n </BrIcon>\n );\n});\n\nNotificationIcon.displayName = 'NotificationIcon';\n\nexport default NotificationIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgNumber = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.238.788a.75.75 0 0 1 .474.949L8.375 5.749h3.419l1.495-4.487a.75.75 0 1 1 1.423.475l-1.337 4.012H16.5a.75.75 0 0 1 0 1.5h-3.626l-1.5 4.5H14.5a.75.75 0 0 1 0 1.5h-3.626l-1.163 3.488a.75.75 0 1 1-1.423-.475l1.005-3.013h-3.42l-1.162 3.488a.75.75 0 1 1-1.423-.475l1.005-3.013H1.5a.75.75 0 0 1 0-1.5h3.293l1.5-4.5H3.5a.75.75 0 1 1 0-1.5h3.293l1.495-4.487a.75.75 0 0 1 .95-.474Zm.556 10.961 1.5-4.5h-3.42l-1.5 4.5h3.42Z\" }));\nconst ForwardRef = forwardRef(SvgNumber);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport NumberSvgIcon from '@bloomreach/banana-theme/icons/number.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst NumberIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <NumberSvgIcon />\n </BrIcon>\n );\n});\n\nNumberIcon.displayName = 'NumberIcon';\n\nexport default NumberIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgOfflineFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 9a8.25 8.25 0 1 1 16.5 0 8.25 8.25 0 0 1-16.5 0Zm4.5 0c0 .415.336.75.75.75h6a.75.75 0 0 0 0-1.5h-6a.75.75 0 0 0-.75.75Z\" }));\nconst ForwardRef = forwardRef(SvgOfflineFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport OfflineFillSvgIcon from '@bloomreach/banana-theme/icons/offline-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst OfflineFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <OfflineFillSvgIcon />\n </BrIcon>\n );\n});\n\nOfflineFillIcon.displayName = 'OfflineFillIcon';\n\nexport default OfflineFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgOffline = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.001 8.25a.75.75 0 1 0 0 1.5h6a.75.75 0 0 0 0-1.5h-6Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.001.75a8.25 8.25 0 1 0 0 16.5 8.25 8.25 0 0 0 0-16.5ZM2.251 9a6.75 6.75 0 1 1 13.5 0 6.75 6.75 0 0 1-13.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgOffline);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport OfflineSvgIcon from '@bloomreach/banana-theme/icons/offline.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst OfflineIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <OfflineSvgIcon />\n </BrIcon>\n );\n});\n\nOfflineIcon.displayName = 'OfflineIcon';\n\nexport default OfflineIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPaint = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.479 3.506v3.419L1.467 7.937a3.217 3.217 0 0 0 0 4.551l2.326 2.327a3.217 3.217 0 0 0 4.552 0l3.595-3.595 1.506-.168a1.161 1.161 0 0 0 .692-1.975L8.344 3.282a1.572 1.572 0 0 0-.415-.298 2.75 2.75 0 0 0-5.45.522Zm2.75-1.25a1.25 1.25 0 0 1 1.168.805c-.1.063-.192.136-.277.22L3.98 5.425V3.506a1.25 1.25 0 0 1 1.25-1.25Zm1.25 6.75a.75.75 0 1 0 1.5 0V5.038l4.6 4.601-1.067.119a.75.75 0 0 0-.447.215l-3.782 3.782a1.717 1.717 0 0 1-2.43 0l-2.326-2.328a1.717 1.717 0 0 1 0-2.43L6.48 5.046v3.961Zm7.688 3.164a.75.75 0 0 0-1.342 0l-1.102 2.206a1.982 1.982 0 1 0 3.546 0l-1.102-2.205Zm-1.147 3.17a.478.478 0 0 1 .044-.293l.432-.864.432.864a.482.482 0 0 1-.772.557h-.001a.482.482 0 0 1-.135-.264Z\" }));\nconst ForwardRef = forwardRef(SvgPaint);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PaintSvgIcon from '@bloomreach/banana-theme/icons/paint.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PaintIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PaintSvgIcon />\n </BrIcon>\n );\n});\n\nPaintIcon.displayName = 'PaintIcon';\n\nexport default PaintIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgParagraphCenterAlign = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.745 2a.75.75 0 0 1 .75-.75h13a.75.75 0 0 1 0 1.5h-13a.75.75 0 0 1-.75-.75Zm2 3a.75.75 0 0 1 .75-.75h9a.75.75 0 0 1 0 1.5h-9a.75.75 0 0 1-.75-.75Zm-2.25 2.25a.75.75 0 0 0 0 1.5h15a.75.75 0 0 0 0-1.5h-15ZM3.745 11a.75.75 0 0 1 .75-.75h9a.75.75 0 0 1 0 1.5h-9a.75.75 0 0 1-.75-.75Zm-1.25 2.25a.75.75 0 0 0 0 1.5h13a.75.75 0 0 0 0-1.5h-13Z\" }));\nconst ForwardRef = forwardRef(SvgParagraphCenterAlign);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ParagraphCenterAlignSvgIcon from '@bloomreach/banana-theme/icons/paragraph-center-align.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ParagraphCenterAlignIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ParagraphCenterAlignSvgIcon />\n </BrIcon>\n );\n});\n\nParagraphCenterAlignIcon.displayName = 'ParagraphCenterAlignIcon';\n\nexport default ParagraphCenterAlignIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgParagraphLeftAlign = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.751 2a.75.75 0 0 1 .75-.75h14a.75.75 0 0 1 0 1.5h-14A.75.75 0 0 1 .751 2Zm0 3a.75.75 0 0 1 .75-.75h12a.75.75 0 0 1 0 1.5h-12A.75.75 0 0 1 .751 5Zm.75 2.25a.75.75 0 0 0 0 1.5h15a.75.75 0 0 0 0-1.5h-15ZM.751 11a.75.75 0 0 1 .75-.75h12a.75.75 0 0 1 0 1.5h-12a.75.75 0 0 1-.75-.75Zm.75 2.25a.75.75 0 0 0 0 1.5h14a.75.75 0 0 0 0-1.5h-14Z\" }));\nconst ForwardRef = forwardRef(SvgParagraphLeftAlign);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ParagraphLeftAlignSvgIcon from '@bloomreach/banana-theme/icons/paragraph-left-align.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ParagraphLeftAlignIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ParagraphLeftAlignSvgIcon />\n </BrIcon>\n );\n});\n\nParagraphLeftAlignIcon.displayName = 'ParagraphLeftAlignIcon';\n\nexport default ParagraphLeftAlignIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgParagraphRightAlign = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.583 2a.75.75 0 0 1 .75-.75h14a.75.75 0 0 1 0 1.5h-14a.75.75 0 0 1-.75-.75Zm2 3a.75.75 0 0 1 .75-.75h12a.75.75 0 0 1 0 1.5h-12a.75.75 0 0 1-.75-.75Zm-2.25 2.25a.75.75 0 1 0 0 1.5h15a.75.75 0 0 0 0-1.5h-15ZM3.583 11a.75.75 0 0 1 .75-.75h12a.75.75 0 1 1 0 1.5h-12a.75.75 0 0 1-.75-.75Zm-1.25 2.25a.75.75 0 1 0 0 1.5h14a.75.75 0 0 0 0-1.5h-14Z\" }));\nconst ForwardRef = forwardRef(SvgParagraphRightAlign);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ParagraphRightAlignSvgIcon from '@bloomreach/banana-theme/icons/paragraph-right-align.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ParagraphRightAlignIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ParagraphRightAlignSvgIcon />\n </BrIcon>\n );\n});\n\nParagraphRightAlignIcon.displayName = 'ParagraphRightAlignIcon';\n\nexport default ParagraphRightAlignIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPercentage = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.03.97a.75.75 0 0 1 0 1.061l-13 13a.75.75 0 1 1-1.06-1.06l13-13a.75.75 0 0 1 1.06 0ZM9.75 12.501a2.75 2.75 0 1 1 5.5 0 2.75 2.75 0 0 1-5.5 0Zm2.75-1.25a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5Zm-9-10.5a2.75 2.75 0 1 0 0 5.5 2.75 2.75 0 0 0 0-5.5Zm-1.25 2.75a1.25 1.25 0 1 1 2.5 0 1.25 1.25 0 0 1-2.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgPercentage);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PercentageSvgIcon from '@bloomreach/banana-theme/icons/percentage.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PercentageIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PercentageSvgIcon />\n </BrIcon>\n );\n});\n\nPercentageIcon.displayName = 'PercentageIcon';\n\nexport default PercentageIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPersAlt1 = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.478 2.755H12a.75.75 0 0 1 0-1.5h.46c.655-.058 1.12.4 1.365.82.266.456.402 1.04.425 1.615v1.676c.004.229.038.441.092.614a.817.817 0 0 0 .168.322l1.055 1.206a.75.75 0 0 1 0 .988L14.51 9.7a.82.82 0 0 0-.168.323 2.22 2.22 0 0 0-.092.614v1.677c-.023.574-.16 1.158-.425 1.613-.245.42-.71.878-1.365.82H12a.75.75 0 0 1 0-1.5h.478a.616.616 0 0 0 .052-.077c.107-.184.202-.504.22-.902V10.62c.005-.358.058-.718.16-1.045a2.28 2.28 0 0 1 .48-.873l.613-.7-.613-.702a2.275 2.275 0 0 1-.48-.873 3.71 3.71 0 0 1-.16-1.046V3.735c-.018-.398-.113-.719-.22-.903a.628.628 0 0 0-.052-.077Zm-8.938-1.5H4a.75.75 0 1 1 0 1.5h-.477a.628.628 0 0 0-.052.077c-.108.185-.203.505-.22.903v1.646a3.713 3.713 0 0 1-.16 1.046 2.275 2.275 0 0 1-.48.873l-.614.701.614.7c.227.246.38.559.48.874.102.327.154.687.16 1.045v1.648c.017.398.112.718.22.902.02.034.037.059.051.077H4a.75.75 0 0 1 0 1.5h-.46c-.655.058-1.12-.4-1.365-.82-.265-.455-.401-1.039-.424-1.613v-1.678a2.219 2.219 0 0 0-.092-.613.82.82 0 0 0-.168-.323L.436 8.496a.75.75 0 0 1 0-.988L1.49 6.302a.817.817 0 0 0 .168-.323c.054-.171.089-.384.092-.613V3.689c.024-.574.16-1.158.425-1.613.246-.42.71-.879 1.365-.82Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.25 5.001a2.75 2.75 0 1 1 3.945 2.478A3.25 3.25 0 0 1 11.25 10.5V12a.75.75 0 0 1-.75.75h-5a.75.75 0 0 1-.75-.75v-1.5a3.25 3.25 0 0 1 2.055-3.022A2.75 2.75 0 0 1 5.25 5ZM8 3.751a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5ZM6.763 9.264A1.75 1.75 0 0 0 6.25 10.5v.75h3.5v-.75a1.75 1.75 0 0 0-2.987-1.237Z\" }));\nconst ForwardRef = forwardRef(SvgPersAlt1);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PersAlt1SvgIcon from '@bloomreach/banana-theme/icons/pers-alt-1.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PersAlt1Icon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PersAlt1SvgIcon />\n </BrIcon>\n );\n});\n\nPersAlt1Icon.displayName = 'PersAlt1Icon';\n\nexport default PersAlt1Icon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPersAlt2 = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.478 2.755H12a.75.75 0 0 1 0-1.5h.46c.655-.058 1.12.4 1.365.82.266.456.402 1.04.425 1.615v1.676c.004.229.038.441.092.614a.817.817 0 0 0 .168.322l1.055 1.206a.75.75 0 0 1 0 .988L14.51 9.7a.82.82 0 0 0-.168.323 2.22 2.22 0 0 0-.092.614v1.677c-.023.574-.16 1.158-.425 1.613-.245.42-.71.878-1.365.82H12a.75.75 0 0 1 0-1.5h.478a.616.616 0 0 0 .052-.077c.107-.184.202-.504.22-.902V10.62c.005-.358.058-.718.16-1.045a2.28 2.28 0 0 1 .48-.873l.614-.7-.614-.702a2.275 2.275 0 0 1-.48-.873 3.71 3.71 0 0 1-.16-1.046V3.735c-.017-.398-.113-.719-.22-.903a.628.628 0 0 0-.052-.077Zm-8.938-1.5H4a.75.75 0 1 1 0 1.5h-.477a.627.627 0 0 0-.052.077c-.108.185-.203.505-.22.903v1.646a3.713 3.713 0 0 1-.16 1.046 2.275 2.275 0 0 1-.48.873l-.614.701.614.7c.227.246.38.559.48.874.102.327.154.687.16 1.045v1.648c.017.398.112.718.22.902.02.034.037.059.051.077H4a.75.75 0 0 1 0 1.5h-.46c-.655.058-1.119-.4-1.365-.82-.265-.455-.401-1.039-.424-1.613v-1.678a2.219 2.219 0 0 0-.092-.613.82.82 0 0 0-.168-.323L.436 8.496a.75.75 0 0 1 0-.988L1.49 6.302a.817.817 0 0 0 .168-.323c.054-.171.088-.384.091-.613V3.689c.024-.574.16-1.158.425-1.613.246-.42.71-.879 1.365-.82Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.25 4.001a2.75 2.75 0 1 1 3.945 2.478A3.25 3.25 0 0 1 11.25 9.5V11a.75.75 0 0 1-.75.75h-.338l-.418 3.343A.75.75 0 0 1 9 15.75H7a.75.75 0 0 1-.744-.657l-.418-3.343H5.5a.75.75 0 0 1-.75-.75V9.5a3.25 3.25 0 0 1 2.056-3.022A2.75 2.75 0 0 1 5.25 4ZM8 2.751a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5ZM6.763 8.264A1.75 1.75 0 0 0 6.25 9.5v.75h.25a.75.75 0 0 1 .745.657l.417 3.343h.676l.418-3.343a.75.75 0 0 1 .744-.657h.25V9.5a1.75 1.75 0 0 0-2.987-1.237Z\" }));\nconst ForwardRef = forwardRef(SvgPersAlt2);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PersAlt2SvgIcon from '@bloomreach/banana-theme/icons/pers-alt-2.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PersAlt2Icon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PersAlt2SvgIcon />\n </BrIcon>\n );\n});\n\nPersAlt2Icon.displayName = 'PersAlt2Icon';\n\nexport default PersAlt2Icon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPersAlt3 = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"m13.751 1.751.021.01c.034.02.099.07.174.184.154.232.28.614.304 1.079v1.92c.007.417.077.835.212 1.212.13.367.33.716.611.98L15.94 8l-.866.866c-.28.263-.48.612-.611.98a3.816 3.816 0 0 0-.211 1.21v1.923c-.024.464-.15.846-.305 1.077a.583.583 0 0 1-.174.183.107.107 0 0 1-.02.01.762.762 0 0 0-.085-.004H13a.75.75 0 0 0 0 1.5h.63c.685.058 1.23-.357 1.564-.857.343-.514.525-1.186.556-1.857v-1.956c.005-.269.051-.52.124-.725.076-.212.166-.336.229-.393a.877.877 0 0 0 .021-.021l1.406-1.405a.75.75 0 0 0 0-1.06l-1.405-1.407a.895.895 0 0 0-.023-.021 1.013 1.013 0 0 1-.228-.393 2.312 2.312 0 0 1-.124-.725v-1.92a.77.77 0 0 0 0-.034c-.03-.672-.212-1.344-.556-1.859-.333-.5-.879-.916-1.564-.857H13a.75.75 0 0 0 0 1.5h.667a.751.751 0 0 0 .084-.005Zm-.003 12.5h.002-.002ZM4.37.256H5a.75.75 0 0 1 0 1.5h-.666a.75.75 0 0 1-.084-.005.115.115 0 0 0-.021.01.584.584 0 0 0-.174.185c-.154.23-.28.614-.305 1.078v1.92a3.812 3.812 0 0 1-.21 1.212c-.132.367-.332.716-.613.98L2.061 8l.866.865c.28.264.48.613.612.98.135.377.205.794.211 1.211v1.922c.024.465.15.847.305 1.078.075.113.14.164.173.183.011.007.018.01.022.01a.764.764 0 0 1 .084-.004H5a.75.75 0 0 1 0 1.5h-.629c-.685.058-1.231-.357-1.564-.857-.343-.514-.525-1.186-.556-1.857v-1.956a2.316 2.316 0 0 0-.125-.725c-.075-.212-.165-.336-.228-.393a.755.755 0 0 1-.021-.021L.47 8.532a.75.75 0 0 1 0-1.06l1.406-1.407a.751.751 0 0 1 .023-.022c.062-.057.152-.18.228-.392.073-.205.119-.456.123-.725v-1.92l.001-.035c.03-.67.213-1.343.556-1.857.333-.5.878-.916 1.564-.858ZM4.254 14.25H4.25h.002Zm0-12.5h-.001.002Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6 9a1 1 0 1 0 0-2 1 1 0 0 0 0 2Zm4-1a1 1 0 1 1-2 0 1 1 0 0 1 2 0Zm2 1a1 1 0 1 0 0-2 1 1 0 0 0 0 2Z\" }));\nconst ForwardRef = forwardRef(SvgPersAlt3);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PersAlt3SvgIcon from '@bloomreach/banana-theme/icons/pers-alt-3.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PersAlt3Icon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PersAlt3SvgIcon />\n </BrIcon>\n );\n});\n\nPersAlt3Icon.displayName = 'PersAlt3Icon';\n\nexport default PersAlt3Icon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPersAlt4 = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.773 1.761a.117.117 0 0 0-.022-.01.751.751 0 0 1-.084.005h-.666a.75.75 0 0 1 0-1.5h.629c.685-.059 1.231.358 1.564.857.344.515.525 1.187.556 1.859a.77.77 0 0 1 0 .034v1.92c.005.269.05.52.124.725.076.212.166.335.228.393a.895.895 0 0 1 .023.021l1.406 1.406a.75.75 0 0 1 0 1.061l-1.407 1.405a.877.877 0 0 1-.021.02c-.063.058-.153.182-.228.394-.074.205-.12.456-.124.725v1.922l-.001.034c-.031.671-.213 1.343-.556 1.857-.333.5-.88.915-1.564.857H11a.75.75 0 0 1 0-1.5h.667c.028 0 .056.001.084.005a.107.107 0 0 0 .022-.01.583.583 0 0 0 .173-.184c.154-.231.28-.613.305-1.077v-1.923a3.8 3.8 0 0 1 .21-1.21c.132-.368.332-.717.612-.98L13.94 8l-.866-.866c-.281-.263-.481-.612-.612-.98a3.812 3.812 0 0 1-.211-1.21V3.022c-.024-.464-.15-.846-.305-1.078a.582.582 0 0 0-.173-.184Zm-.025-.01h.002-.002Zm0 12.5h.002-.002ZM5 .256h-.63c-.684-.058-1.23.358-1.563.858-.343.514-.525 1.186-.556 1.857v1.955c-.005.269-.05.52-.124.725-.076.212-.166.335-.228.392a.764.764 0 0 0-.023.022L.47 7.471a.75.75 0 0 0 0 1.061l1.407 1.405a.755.755 0 0 0 .021.02c.063.058.153.182.228.394.074.205.12.456.124.724v1.923l.001.034c.031.671.213 1.343.556 1.857.333.5.88.915 1.564.857h.63a.75.75 0 0 0 0-1.5h-.667a.764.764 0 0 0-.084.005.108.108 0 0 1-.022-.01.583.583 0 0 1-.173-.184c-.154-.231-.28-.613-.305-1.077v-1.923a3.815 3.815 0 0 0-.21-1.21c-.132-.368-.332-.717-.612-.98L2.06 8l.866-.866c.281-.263.481-.612.612-.98.135-.376.205-.794.211-1.21V3.023c.024-.464.15-.847.305-1.078a.584.584 0 0 1 .174-.184.115.115 0 0 1 .021-.01.75.75 0 0 0 .084.004H5a.75.75 0 1 0 0-1.5ZM4.253 14.25H4.25h.002Zm0-12.5h-.001.002Z\" }));\nconst ForwardRef = forwardRef(SvgPersAlt4);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PersAlt4SvgIcon from '@bloomreach/banana-theme/icons/pers-alt-4.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PersAlt4Icon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PersAlt4SvgIcon />\n </BrIcon>\n );\n});\n\nPersAlt4Icon.displayName = 'PersAlt4Icon';\n\nexport default PersAlt4Icon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPictureAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.75 2.501v9.5c0 .966.784 1.75 1.75 1.75H12a1.75 1.75 0 0 0 1.75-1.75v-9.5A1.75 1.75 0 0 0 12 .751H2.5a1.75 1.75 0 0 0-1.75 1.75Zm1.75-.25H12a.25.25 0 0 1 .25.25v6.75h-10v-6.75a.25.25 0 0 1 .25-.25Zm9.75 9.75a.25.25 0 0 1-.25.25H2.5a.25.25 0 0 1-.25-.25v-1.25h10v1.25Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.278 3.636a.75.75 0 1 0-.281 1.474l.255.048a.614.614 0 0 1 .487.718l-1.789 9.376a.614.614 0 0 1-.718.488L6.216 14.4a.75.75 0 0 0-.281 1.474l7.016 1.339a2.114 2.114 0 0 0 2.472-1.68l1.79-9.375a2.114 2.114 0 0 0-1.68-2.473l-.255-.049Z\" }));\nconst ForwardRef = forwardRef(SvgPictureAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PictureAltSvgIcon from '@bloomreach/banana-theme/icons/picture-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PictureAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PictureAltSvgIcon />\n </BrIcon>\n );\n});\n\nPictureAltIcon.displayName = 'PictureAltIcon';\n\nexport default PictureAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPicture = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12 3.251a2.75 2.75 0 1 0 0 5.5 2.75 2.75 0 0 0 0-5.5Zm-1.25 2.75a1.25 1.25 0 1 1 2.5 0 1.25 1.25 0 0 1-2.5 0Zm-2.828 5.277a4.712 4.712 0 0 0-3.91.347.75.75 0 1 1-.742-1.303 6.213 6.213 0 0 1 7.419.955 3.716 3.716 0 0 1 4.281.344.75.75 0 0 1-.962 1.15 2.216 2.216 0 0 0-2.368-.303c.194.317.36.651.496 1a.75.75 0 0 1-1.398.543 4.714 4.714 0 0 0-2.816-2.733Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5.751a1.75 1.75 0 0 0-1.75 1.75v13c0 .967.784 1.75 1.75 1.75h13a1.75 1.75 0 0 0 1.75-1.75v-13A1.75 1.75 0 0 0 15.5.751h-13Zm-.25 1.75a.25.25 0 0 1 .25-.25h13a.25.25 0 0 1 .25.25v13a.25.25 0 0 1-.25.25h-13a.25.25 0 0 1-.25-.25v-13Z\" }));\nconst ForwardRef = forwardRef(SvgPicture);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PictureSvgIcon from '@bloomreach/banana-theme/icons/picture.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PictureIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PictureSvgIcon />\n </BrIcon>\n );\n});\n\nPictureIcon.displayName = 'PictureIcon';\n\nexport default PictureIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPin = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.134.828a5.817 5.817 0 0 0-2.082.748 6.003 6.003 0 0 0-1.99 2c-.62 1.039-.914 2.4-.753 3.486.216 1.45 1.243 3.824 2.96 6.837.776 1.36 1.619 2.714 1.839 2.95.238.258.522.378.893.378.37 0 .655-.12.893-.377.22-.237 1.063-1.59 1.838-2.951 1.718-3.013 2.745-5.386 2.96-6.837.162-1.084-.133-2.448-.752-3.486a5.979 5.979 0 0 0-2.024-2.02A5.775 5.775 0 0 0 8.78.817a7.425 7.425 0 0 0-1.646.012Zm1.287 1.44a4.174 4.174 0 0 1 1.527.456 4.263 4.263 0 0 1 2.224 2.937c.057.275.1.824.08 1.007-.133 1.245-1.131 3.546-2.832 6.533-.496.869-1.39 2.346-1.42 2.346-.028 0-.86-1.372-1.372-2.266-1.554-2.713-2.546-4.91-2.83-6.267-.055-.264-.06-.775-.011-1.106a4.23 4.23 0 0 1 1.182-2.384A4.225 4.225 0 0 1 8.42 2.268ZM7.668 3.28a3.238 3.238 0 0 0-2.855 2.667c-.065.37-.041 1.016.05 1.346.14.51.282.798.593 1.2 1.148 1.487 3.346 1.664 4.742.384.358-.328.71-.867.865-1.32a3.592 3.592 0 0 0 .123-1.627 3.244 3.244 0 0 0-2.133-2.492 3.501 3.501 0 0 0-1.385-.158Zm.77 1.519a1.75 1.75 0 0 1 1.138 2.468c-.181.367-.456.64-.815.812-.277.133-.45.172-.76.172s-.483-.04-.76-.172a1.774 1.774 0 0 1-1-1.563A1.78 1.78 0 0 1 7.553 4.8c.263-.068.619-.07.885-.001Z\" }));\nconst ForwardRef = forwardRef(SvgPin);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PinSvgIcon from '@bloomreach/banana-theme/icons/pin.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PinIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PinSvgIcon />\n </BrIcon>\n );\n});\n\nPinIcon.displayName = 'PinIcon';\n\nexport default PinIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPlugplay = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.143 6.913c-.4-.25-.746-.466-1.036-.61-.293-.145-.653-.284-1.053-.235a1.75 1.75 0 0 0-1.146.635c-.254.314-.327.692-.359 1.018-.031.322-.031.73-.031 1.202v.073c0 .471 0 .88.031 1.202.032.325.105.704.359 1.017.285.352.696.58 1.146.635.4.05.76-.089 1.053-.234.29-.145.636-.361 1.036-.61l.06-.039c.36-.224.673-.42.91-.602.242-.187.502-.43.636-.781a1.75 1.75 0 0 0 0-1.249c-.134-.352-.394-.595-.636-.781-.237-.182-.55-.378-.91-.602l-.06-.039Zm-2.06.724a.25.25 0 0 1 .14-.078c.018.004.082.02.216.087.217.108.5.284.94.559.397.248.648.406.82.538.104.08.142.125.152.138a.25.25 0 0 1 0 .157.889.889 0 0 1-.153.138c-.171.132-.422.29-.82.538-.44.275-.722.45-.939.558a.992.992 0 0 1-.216.087.25.25 0 0 1-.14-.077.996.996 0 0 1-.041-.23c-.024-.24-.024-.574-.024-1.093 0-.518 0-.852.024-1.093a.994.994 0 0 1 .04-.23Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"m13.313 3.336-3.062-1.768a4.5 4.5 0 0 0-4.5 0L2.689 3.336a4.5 4.5 0 0 0-2.25 3.897v3.536a4.5 4.5 0 0 0 2.25 3.897l3.062 1.768a4.5 4.5 0 0 0 4.5 0l3.062-1.768a4.5 4.5 0 0 0 2.25-3.897V7.233a4.5 4.5 0 0 0-2.25-3.897Zm-6.812-.469a3 3 0 0 1 3 0l3.062 1.768a3 3 0 0 1 1.5 2.598v3.536a3 3 0 0 1-1.5 2.598l-3.062 1.768a3 3 0 0 1-3 0l-3.062-1.768a3 3 0 0 1-1.5-2.598V7.233a3 3 0 0 1 1.5-2.598L6.5 2.867Z\" }));\nconst ForwardRef = forwardRef(SvgPlugplay);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PlugPlaySvgIcon from '@bloomreach/banana-theme/icons/plug&play.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PlugPlayIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PlugPlaySvgIcon />\n </BrIcon>\n );\n});\n\nPlugPlayIcon.displayName = 'PlugPlayIcon';\n\nexport default PlugPlayIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPlusCircleFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001 15.668A7.667 7.667 0 1 0 .335 8 7.675 7.675 0 0 0 8 15.668Zm-4-8.334h3.167a.167.167 0 0 0 .167-.166V4a.667.667 0 0 1 1.333 0v3.167a.167.167 0 0 0 .167.166H12a.667.667 0 1 1 0 1.334H8.835a.167.167 0 0 0-.167.166V12a.667.667 0 1 1-1.333 0V8.834a.167.167 0 0 0-.167-.166H4a.667.667 0 1 1 0-1.334Z\" }));\nconst ForwardRef = forwardRef(SvgPlusCircleFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PlusCircleFillSvgIcon from '@bloomreach/banana-theme/icons/plus-circle-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PlusCircleFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PlusCircleFillSvgIcon />\n </BrIcon>\n );\n});\n\nPlusCircleFillIcon.displayName = 'PlusCircleFillIcon';\n\nexport default PlusCircleFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPlusCircle = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.001 5.251a.75.75 0 0 1 .75.75v2.25h2.25a.75.75 0 0 1 0 1.5h-2.25v2.25a.75.75 0 0 1-1.5 0v-2.25h-2.25a.75.75 0 1 1 0-1.5h2.25v-2.25a.75.75 0 0 1 .75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.001.751a8.25 8.25 0 1 0 0 16.5 8.25 8.25 0 0 0 0-16.5Zm-6.75 8.25a6.75 6.75 0 1 1 13.5 0 6.75 6.75 0 0 1-13.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgPlusCircle);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PlusCircleSvgIcon from '@bloomreach/banana-theme/icons/plus-circle.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PlusCircleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PlusCircleSvgIcon />\n </BrIcon>\n );\n});\n\nPlusCircleIcon.displayName = 'PlusCircleIcon';\n\nexport default PlusCircleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPlus = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.751 3.001a.75.75 0 1 0-1.5 0v4.25h-4.25a.75.75 0 1 0 0 1.5h4.25v4.25a.75.75 0 0 0 1.5 0v-4.25h4.25a.75.75 0 0 0 0-1.5h-4.25v-4.25Z\" }));\nconst ForwardRef = forwardRef(SvgPlus);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PlusSvgIcon from '@bloomreach/banana-theme/icons/plus.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PlusIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PlusSvgIcon />\n </BrIcon>\n );\n});\n\nPlusIcon.displayName = 'PlusIcon';\n\nexport default PlusIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgPoverButton = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.751 1a.75.75 0 0 0-1.5 0v6.5a.75.75 0 0 0 1.5 0V1Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.251 4.049a.75.75 0 0 0-.5-1.414 6.75 6.75 0 1 0 4.5 0 .75.75 0 1 0-.5 1.414 5.25 5.25 0 1 1-3.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgPoverButton);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport PoverButtonSvgIcon from '@bloomreach/banana-theme/icons/pover-button.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst PoverButtonIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <PoverButtonSvgIcon />\n </BrIcon>\n );\n});\n\nPoverButtonIcon.displayName = 'PoverButtonIcon';\n\nexport default PoverButtonIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRefresh = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.374 2.49a5.752 5.752 0 0 1 3.842.204.75.75 0 1 0 .576-1.386A7.252 7.252 0 0 0 2.799 11.75H1.5a.75.75 0 0 0 0 1.5h2.757a.752.752 0 0 0 .11 0H4.5a.75.75 0 0 0 .75-.75v-3a.75.75 0 1 0-1.5 0v.837a5.752 5.752 0 0 1 3.623-7.846Zm6.877 3.166V6.5a.75.75 0 1 1-1.5 0v-3a.75.75 0 0 1 .75-.75h.133a.755.755 0 0 1 .11 0h2.757a.75.75 0 1 1 0 1.5h-1.296A7.25 7.25 0 0 1 6.21 14.693a.75.75 0 0 1 .577-1.384 5.751 5.751 0 0 0 7.464-7.653Z\" }));\nconst ForwardRef = forwardRef(SvgRefresh);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RefreshSvgIcon from '@bloomreach/banana-theme/icons/refresh.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RefreshIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RefreshSvgIcon />\n </BrIcon>\n );\n});\n\nRefreshIcon.displayName = 'RefreshIcon';\n\nexport default RefreshIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgReleaseNotes = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.251 1.501a.75.75 0 1 0-1.5 0v.25H2.475A1.787 1.787 0 0 0 .752 3.583v9.91a1.726 1.726 0 0 0 1.758 1.758h3.992a.75.75 0 0 0 0-1.5h-4.02a.225.225 0 0 1-.23-.231V3.547a.287.287 0 0 1 .267-.296h1.232v1.25a.75.75 0 0 0 1.5 0v-1.25h1.5v1.25a.75.75 0 0 0 1.5 0v-1.25h1.5v1.25a.75.75 0 0 0 1.5 0v-1.25h1.233a.287.287 0 0 1 .268.296v2.954a.75.75 0 1 0 1.5 0V3.583a1.787 1.787 0 0 0-1.75-1.832h-1.25v-.25a.75.75 0 0 0-1.5 0v.25h-1.5v-.25a.75.75 0 1 0-1.5 0v.25h-1.5v-.25Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.88 7.623a7.75 7.75 0 0 1 1.654 0 .75.75 0 0 1 .665.661c.351 3.093-1.104 5.38-2.849 6.671-.865.64-1.823 1.054-2.7 1.198-.589.096-1.228.081-1.77-.149l-1.027 1.027a.75.75 0 0 1-1.061-1.06l1.028-1.029a2.845 2.845 0 0 1-.204-1.104c0-.632.166-1.324.46-1.997a7.244 7.244 0 0 1 3.401-3.551.75.75 0 0 1 .991.318l.21.39.647-1.028a.75.75 0 0 1 .555-.347Zm-3.473 7.05c.613-.1 1.352-.406 2.05-.924 1.267-.937 2.334-2.514 2.293-4.67-.118 0-.237.002-.355.008l-1.133 1.801a.75.75 0 0 1-1.296-.044l-.454-.847a5.765 5.765 0 0 0-2.061 2.444c-.192.439-.296.85-.326 1.196l1.555-1.556a.75.75 0 1 1 1.061 1.06l-1.558 1.56c.07-.007.145-.016.224-.029Z\" }));\nconst ForwardRef = forwardRef(SvgReleaseNotes);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ReleaseNotesSvgIcon from '@bloomreach/banana-theme/icons/release-notes.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ReleaseNotesIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ReleaseNotesSvgIcon />\n </BrIcon>\n );\n});\n\nReleaseNotesIcon.displayName = 'ReleaseNotesIcon';\n\nexport default ReleaseNotesIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRenameAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.5.75a.75.75 0 1 0 0 1.5 2.25 2.25 0 0 1 2.25 2.25v.25H2.5A1.75 1.75 0 0 0 .75 6.5v5c0 .966.784 1.75 1.75 1.75h9.25v.25a2.25 2.25 0 0 1-2.25 2.25.75.75 0 0 0 0 1.5 3.75 3.75 0 0 0 3-1.5 3.75 3.75 0 0 0 3 1.5.75.75 0 0 0 0-1.5 2.25 2.25 0 0 1-2.25-2.25v-.25h2.25a1.75 1.75 0 0 0 1.75-1.75v-5a1.75 1.75 0 0 0-1.75-1.75h-2.25V4.5a2.25 2.25 0 0 1 2.25-2.25.75.75 0 0 0 0-1.5 3.75 3.75 0 0 0-3 1.5 3.745 3.745 0 0 0-3-1.5Zm-7 5.5h9.25v5.5H2.5a.25.25 0 0 1-.25-.25v-5a.25.25 0 0 1 .25-.25Zm10.75 0h2.25a.25.25 0 0 1 .25.25v5a.25.25 0 0 1-.25.25h-2.25v-5.5Z\" }));\nconst ForwardRef = forwardRef(SvgRenameAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RenameAltSvgIcon from '@bloomreach/banana-theme/icons/rename-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RenameAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RenameAltSvgIcon />\n </BrIcon>\n );\n});\n\nRenameAltIcon.displayName = 'RenameAltIcon';\n\nexport default RenameAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRename = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.119 2.178a1.75 1.75 0 0 1 2.474 0l1.23 1.23a1.75 1.75 0 0 1 0 2.474L6.086 13.62a.75.75 0 0 1-.344.196l-3.556.912a.75.75 0 0 1-.913-.912l.912-3.556a.75.75 0 0 1 .196-.344l7.738-7.737Zm1.414 1.06a.25.25 0 0 0-.354 0l-.75.751 1.582 1.583.752-.75a.25.25 0 0 0 0-.354l-1.23-1.23ZM3.587 10.83l-.546 2.13 2.13-.547 5.78-5.78L9.368 5.05l-5.781 5.78Zm5.148 2.617a.735.735 0 0 0 0 1.47h6.035a.735.735 0 1 0 0-1.47H8.735Z\" }));\nconst ForwardRef = forwardRef(SvgRename);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RenameSvgIcon from '@bloomreach/banana-theme/icons/rename.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RenameIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RenameSvgIcon />\n </BrIcon>\n );\n});\n\nRenameIcon.displayName = 'RenameIcon';\n\nexport default RenameIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgReorder = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5 1.749a.75.75 0 0 1 .75.75v9.19l1.22-1.22a.75.75 0 1 1 1.06 1.06l-2.5 2.5a.748.748 0 0 1-1.06 0l-2.5-2.5a.75.75 0 0 1 1.06-1.06l1.22 1.22v-9.19a.75.75 0 0 1 .75-.75Zm5.713.057a.747.747 0 0 0-.243.163l-2.5 2.5a.75.75 0 0 0 1.06 1.06l1.22-1.22v9.19a.75.75 0 0 0 1.5 0v-9.19l1.22 1.22a.75.75 0 1 0 1.06-1.06l-2.5-2.5a.748.748 0 0 0-.817-.163Z\" }));\nconst ForwardRef = forwardRef(SvgReorder);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ReorderSvgIcon from '@bloomreach/banana-theme/icons/reorder.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ReorderIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ReorderSvgIcon />\n </BrIcon>\n );\n});\n\nReorderIcon.displayName = 'ReorderIcon';\n\nexport default ReorderIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgReport = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5 8.751a.723.723 0 0 1-.531-.219.705.705 0 0 1-.219-.515c0-.209.073-.386.219-.532A.7.7 0 0 1 5 7.251h6a.7.7 0 0 1 .531.234.723.723 0 0 1 .22.532c0 .198-.074.37-.22.515a.723.723 0 0 1-.53.219H5Zm0 2.5a.723.723 0 0 1-.531-.219.705.705 0 0 1-.219-.515c0-.209.073-.386.219-.532A.7.7 0 0 1 5 9.751h6a.7.7 0 0 1 .531.234.723.723 0 0 1 .22.532c0 .197-.074.37-.22.515a.723.723 0 0 1-.53.219H5Zm0 2.5a.723.723 0 0 1-.531-.219.705.705 0 0 1-.219-.515c0-.209.073-.386.219-.532A.7.7 0 0 1 5 12.251h6a.7.7 0 0 1 .531.234.723.723 0 0 1 .22.532c0 .197-.074.37-.22.515a.723.723 0 0 1-.53.219H5Zm5.5-9a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.531 1.64 1.64 0 0 0-.234-.86 1.719 1.719 0 0 0-.64-.64A1.64 1.64 0 0 0 8 2.251a1.64 1.64 0 0 0-.875.25c-.27.156-.484.37-.64.64a1.64 1.64 0 0 0-.235.86.723.723 0 0 1-.218.531.723.723 0 0 1-.532.219H3a.256.256 0 0 0-.187.078.269.269 0 0 0-.063.172v10.5c0 .073.021.135.063.188A.291.291 0 0 0 3 15.75h10c.073 0 .13-.02.172-.063a.256.256 0 0 0 .078-.187V5a.24.24 0 0 0-.078-.172A.208.208 0 0 0 13 4.75h-2.5Zm2.5-1.5c.313 0 .604.083.875.25.271.156.485.37.64.64.157.261.235.547.235.86v10.5c0 .323-.078.62-.234.89-.156.261-.37.47-.64.626a1.727 1.727 0 0 1-.876.234H3c-.312 0-.604-.078-.875-.234a1.756 1.756 0 0 1-.64-.625 1.75 1.75 0 0 1-.235-.891v-10.5c0-.313.078-.599.235-.86.156-.27.37-.484.64-.64.271-.167.563-.25.875-.25h1.844c.115-.48.323-.906.625-1.281a3.211 3.211 0 0 1 1.125-.89A3.101 3.101 0 0 1 8 .75c.5 0 .969.11 1.407.328a3.07 3.07 0 0 1 1.109.89 3.1 3.1 0 0 1 .64 1.282H13Zm-5.75.25c0-.198.073-.37.219-.516A.7.7 0 0 1 8 2.751c.282 0 .516.099.703.297A.979.979 0 0 1 9 3.767c0 .27-.099.505-.297.703A.954.954 0 0 1 8 4.75c-.281 0-.52-.094-.718-.281A.988.988 0 0 1 7 3.767c0-.282.094-.521.282-.72A.979.979 0 0 1 8 2.752a.7.7 0 0 1 .532.234.723.723 0 0 1 .218.532c0 .198-.073.37-.218.515A.723.723 0 0 1 8 4.251a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.531Z\" }));\nconst ForwardRef = forwardRef(SvgReport);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ReportSvgIcon from '@bloomreach/banana-theme/icons/report.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ReportIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ReportSvgIcon />\n </BrIcon>\n );\n});\n\nReportIcon.displayName = 'ReportIcon';\n\nexport default ReportIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRetention = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5.749a1.75 1.75 0 0 0-1.75 1.75v1c0 .967.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1A1.75 1.75 0 0 0 3.5.749h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1ZM8.5.749a1.75 1.75 0 0 0-1.75 1.75v1c0 .967.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1A1.75 1.75 0 0 0 9.5.749h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Zm4.5 0c0-.966.784-1.75 1.75-1.75h1c.967 0 1.75.784 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm-12 4.5a1.75 1.75 0 0 0-1.75 1.75v1c0 .966.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Zm4.5 0c0-.966.784-1.75 1.75-1.75h1c.967 0 1.75.784 1.75 1.75v1a1.75 1.75 0 0 1-1.75 1.75h-1a1.75 1.75 0 0 1-1.75-1.75v-1Zm1.75-.25a.25.25 0 0 0-.25.25v1c0 .138.112.25.25.25h1a.25.25 0 0 0 .25-.25v-1a.25.25 0 0 0-.25-.25h-1Zm-6 4.5a1.75 1.75 0 0 0-1.75 1.75v1c0 .966.784 1.75 1.75 1.75h1a1.75 1.75 0 0 0 1.75-1.75v-1a1.75 1.75 0 0 0-1.75-1.75h-1Zm-.25 1.75a.25.25 0 0 1 .25-.25h1a.25.25 0 0 1 .25.25v1a.25.25 0 0 1-.25.25h-1a.25.25 0 0 1-.25-.25v-1Z\" }));\nconst ForwardRef = forwardRef(SvgRetention);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RetentionSvgIcon from '@bloomreach/banana-theme/icons/retention.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RetentionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RetentionSvgIcon />\n </BrIcon>\n );\n});\n\nRetentionIcon.displayName = 'RetentionIcon';\n\nexport default RetentionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRewertLeft = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12.286 1.43A8.25 8.25 0 0 0 2.25 4.262V1.5a.75.75 0 1 0-1.5 0v5c0 .414.336.75.75.75h5.001a.75.75 0 0 0 0-1.5H3.088A6.75 6.75 0 1 1 9 15.75a.75.75 0 0 0 0 1.5 8.25 8.25 0 0 0 3.286-15.82Z\" }));\nconst ForwardRef = forwardRef(SvgRewertLeft);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RewertLeftSvgIcon from '@bloomreach/banana-theme/icons/rewert-left.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RewertLeftIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RewertLeftSvgIcon />\n </BrIcon>\n );\n});\n\nRewertLeftIcon.displayName = 'RewertLeftIcon';\n\nexport default RewertLeftIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRewertRight = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.72 1.43a8.25 8.25 0 0 1 10.035 2.832V1.5a.75.75 0 0 1 1.5 0v5a.75.75 0 0 1-.75.75h-5a.75.75 0 0 1 0-1.5h3.412a6.75 6.75 0 1 0-5.912 10 .75.75 0 0 1 0 1.5A8.25 8.25 0 0 1 5.72 1.43Z\" }));\nconst ForwardRef = forwardRef(SvgRewertRight);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RewertRightSvgIcon from '@bloomreach/banana-theme/icons/rewert-right.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RewertRightIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RewertRightSvgIcon />\n </BrIcon>\n );\n});\n\nRewertRightIcon.displayName = 'RewertRightIcon';\n\nexport default RewertRightIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRibbon = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M3.5 2.251h9a.25.25 0 0 1 .25.25v13.008l-3.72-2.706a1.75 1.75 0 0 0-2.058 0L3.25 15.51V2.501a.25.25 0 0 1 .25-.25Zm8.766 14.76a1.25 1.25 0 0 0 1.985-1.008V2.5A1.75 1.75 0 0 0 12.5.751h-9a1.75 1.75 0 0 0-1.75 1.75v13.502a1.25 1.25 0 0 0 1.985 1.008l4.118-2.995a.25.25 0 0 1 .294 0l4.118 2.995Z\" }));\nconst ForwardRef = forwardRef(SvgRibbon);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RibbonSvgIcon from '@bloomreach/banana-theme/icons/ribbon.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RibbonIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RibbonSvgIcon />\n </BrIcon>\n );\n});\n\nRibbonIcon.displayName = 'RibbonIcon';\n\nexport default RibbonIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRoadmap = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M0 2.751a2.75 2.75 0 0 1 5.397-.75h7.229a3.375 3.375 0 1 1 0 6.75h-1.979a2.751 2.751 0 0 1-5.293 0H3.376a1.875 1.875 0 0 0 0 3.75H10.5c.034 0 .068.002.101.007a2.751 2.751 0 1 1 0 1.486.773.773 0 0 1-.101.007H3.376a3.375 3.375 0 0 1 0-6.75h1.978a2.751 2.751 0 0 1 5.293 0h1.979a1.875 1.875 0 0 0 0-3.75H5.397a2.751 2.751 0 0 1-5.396-.75Zm2.75-1.25a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5Zm6.5 6.5a1.25 1.25 0 1 0-2.5 0 1.25 1.25 0 0 0 2.5 0Zm2.75 5.25a1.25 1.25 0 1 0 2.5 0 1.25 1.25 0 0 0-2.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgRoadmap);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RoadmapSvgIcon from '@bloomreach/banana-theme/icons/roadmap.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RoadmapIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RoadmapSvgIcon />\n </BrIcon>\n );\n});\n\nRoadmapIcon.displayName = 'RoadmapIcon';\n\nexport default RoadmapIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRobot = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.25 2.251a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0ZM8 .001a2.25 2.25 0 0 0-.887 4.318 5.751 5.751 0 0 0-4.862 5.682v3.25A2.75 2.75 0 0 0 5 16.001h6a2.75 2.75 0 0 0 2.75-2.75v-3.25a5.751 5.751 0 0 0-4.862-5.682A2.25 2.25 0 0 0 8 .001Zm4.25 10v1.75h-8.5v-1.75a4.25 4.25 0 1 1 8.5 0ZM5 14.501c-.69 0-1.25-.56-1.25-1.25h8.5c0 .69-.559 1.25-1.25 1.25H5Zm10.25-5.25a.75.75 0 0 1 .75.75v3a.75.75 0 0 1-1.5 0v-3a.75.75 0 0 1 .75-.75Zm-13.75.75a.75.75 0 1 0-1.5 0v3a.75.75 0 0 0 1.5 0v-3Zm4.5 1a1.5 1.5 0 1 0 0-3 1.5 1.5 0 0 0 0 3Zm5.5-1.5a1.5 1.5 0 1 1-3 0 1.5 1.5 0 0 1 3 0Z\" }));\nconst ForwardRef = forwardRef(SvgRobot);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RobotSvgIcon from '@bloomreach/banana-theme/icons/robot.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RobotIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RobotSvgIcon />\n </BrIcon>\n );\n});\n\nRobotIcon.displayName = 'RobotIcon';\n\nexport default RobotIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgRunningAggregate = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.001 1.251a.75.75 0 0 0-.6 1.2l4.162 5.55-4.162 5.55a.75.75 0 0 0 .6 1.2h10a.75.75 0 0 0 0-1.5h-8.5l3.6-4.8a.75.75 0 0 0 0-.9l-3.6-4.8h8.5a.75.75 0 0 0 0-1.5h-10Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.476 4.984a.983.983 0 0 0-.705-.23 1.007 1.007 0 0 0-.646.31c-.145.15-.237.327-.292.492a1.634 1.634 0 0 0-.082.516V9.93c0 .171.026.348.082.516.055.165.147.342.292.492.148.152.367.289.646.31a.984.984 0 0 0 .705-.23l2.316-1.93c.183-.153.295-.35.361-.526a1.61 1.61 0 0 0 .098-.561c0-.186-.03-.38-.098-.56a1.244 1.244 0 0 0-.362-.527l-2.315-1.93ZM2.25 9.252V6.75L3.751 8v.002l-1.5 1.25Z\" }));\nconst ForwardRef = forwardRef(SvgRunningAggregate);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport RunningAggregateSvgIcon from '@bloomreach/banana-theme/icons/running-aggregate.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst RunningAggregateIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <RunningAggregateSvgIcon />\n </BrIcon>\n );\n});\n\nRunningAggregateIcon.displayName = 'RunningAggregateIcon';\n\nexport default RunningAggregateIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSave = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.551.781a2.791 2.791 0 0 0-1.245.444c-.15.098-.589.515-1.549 1.474-.736.735-1.393 1.411-1.46 1.502a3.246 3.246 0 0 0-.45.956l-.08.289v5.175c0 4.938.002 5.183.054 5.355.09.292.231.525.456.749.224.225.457.366.75.456.171.053.463.055 6.974.055s6.803-.002 6.975-.055a1.73 1.73 0 0 0 .75-.456 1.73 1.73 0 0 0 .455-.749c.053-.172.055-.464.055-6.975 0-6.511-.002-6.803-.055-6.975a1.85 1.85 0 0 0-1.19-1.204c-.157-.053-.397-.056-5.19-.059C8.037.76 5.675.769 5.551.781Zm.211 3.187c0 1.911.005 1.97.193 2.326.203.385.541.688.942.844l.2.078 2.811.008c3.1.009 3.012.014 3.391-.177.245-.123.641-.517.754-.75.181-.374.178-.334.19-2.269l.012-1.777h1.35l.072.074.074.073v13.206l-.074.073-.073.074h-1.35l-.009-2.588-.009-2.587-.07-.193a1.743 1.743 0 0 0-1.208-1.066c-.289-.068-7.625-.068-7.914 0a1.742 1.742 0 0 0-1.208 1.066l-.07.193-.009 2.587-.008 2.588H2.4l-.075-.074-.074-.074.008-5.048.008-5.049.1-.21c.091-.195.19-.301 1.41-1.519.898-.899 1.352-1.331 1.443-1.376.168-.084.352-.143.46-.147l.082-.003.001 1.717Zm6.988-.045c0 1.766.002 1.728-.14 1.803-.089.048-5.144.05-5.234.003-.14-.076-.145-.13-.145-1.857V2.251h5.52v1.672Zm-.088 6.864.09.046v4.438h-7.5v-4.438l.081-.045c.072-.039.548-.045 3.662-.046 3.151-.001 3.59.004 3.667.045Z\" }));\nconst ForwardRef = forwardRef(SvgSave);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SaveSvgIcon from '@bloomreach/banana-theme/icons/save.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SaveIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SaveSvgIcon />\n </BrIcon>\n );\n});\n\nSaveIcon.displayName = 'SaveIcon';\n\nexport default SaveIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgScenario = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.751 5.121a2.251 2.251 0 1 0-1.5 0V8.75h-.75a4.75 4.75 0 0 0-4.707 4.113 2.25 2.25 0 1 0 1.513.035 3.25 3.25 0 0 1 3.194-2.649h.75v2.628a2.251 2.251 0 1 0 1.5 0V10.25h.75a3.25 3.25 0 0 1 3.194 2.65 2.25 2.25 0 1 0 1.513-.036A4.75 4.75 0 0 0 9.501 8.75h-.75V5.12ZM7.251 3a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0Zm0 12a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0Zm-4.75-.75a.75.75 0 1 1 0 1.5.75.75 0 0 1 0-1.5Zm10.25.75a.75.75 0 1 1 1.5 0 .75.75 0 0 1-1.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgScenario);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ScenarioSvgIcon from '@bloomreach/banana-theme/icons/scenario.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ScenarioIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ScenarioSvgIcon />\n </BrIcon>\n );\n});\n\nScenarioIcon.displayName = 'ScenarioIcon';\n\nexport default ScenarioIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSearch = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.543.752a6.791 6.791 0 1 0 4.243 12.094l4.185 4.185a.75.75 0 0 0 1.06-1.06l-4.184-4.185A6.791 6.791 0 0 0 7.544.752ZM2.252 7.543a5.291 5.291 0 1 1 10.583 0 5.291 5.291 0 0 1-10.583 0Z\" }));\nconst ForwardRef = forwardRef(SvgSearch);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SearchSvgIcon from '@bloomreach/banana-theme/icons/search.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SearchIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SearchSvgIcon />\n </BrIcon>\n );\n});\n\nSearchIcon.displayName = 'SearchIcon';\n\nexport default SearchIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSecurityShield = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.667.149H1.306A1.307 1.307 0 0 0 .008 1.454L0 5.981a.333.333 0 0 0 .333.334h6.334A.333.333 0 0 0 7 5.982v-5.5a.333.333 0 0 0-.333-.333Zm0 8.166H.423a.167.167 0 0 0-.162.204 10.143 10.143 0 0 0 6.519 7.305.165.165 0 0 0 .15-.022.167.167 0 0 0 .07-.136V8.649a.333.333 0 0 0-.333-.334Zm8.904 0H9.333A.333.333 0 0 0 9 8.65v7.036a.167.167 0 0 0 .22.158 10.14 10.14 0 0 0 6.513-7.324.165.165 0 0 0-.032-.14.166.166 0 0 0-.058-.047.316.316 0 0 0-.072-.017Zm.421-6.861A1.307 1.307 0 0 0 14.694.149h-5.36A.333.333 0 0 0 9 .482v5.5a.333.333 0 0 0 .333.333h6.334A.333.333 0 0 0 16 5.981l-.008-4.527Z\" }));\nconst ForwardRef = forwardRef(SvgSecurityShield);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SecurityShieldSvgIcon from '@bloomreach/banana-theme/icons/security-shield.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SecurityShieldIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SecurityShieldSvgIcon />\n </BrIcon>\n );\n});\n\nSecurityShieldIcon.displayName = 'SecurityShieldIcon';\n\nexport default SecurityShieldIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSend = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 16, fill: \"currentColor\", viewBox: \"0 0 17 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.906 1.352a.858.858 0 0 1 .246.506.867.867 0 0 1-.069.547l-3.76 11.73c-.09.3-.277.552-.56.752a1.582 1.582 0 0 1-.93.287c-.319 0-.61-.1-.875-.3a1.46 1.46 0 0 1-.52-.835l-1.23-5.072-5.072-1.23c-.355-.082-.633-.246-.834-.493-.2-.255-.3-.551-.3-.888 0-.347.095-.652.286-.916a1.75 1.75 0 0 1 .752-.588l11.73-3.76a.79.79 0 0 1 .561-.068c.21.045.402.155.575.328l-.069-.068.069.068ZM7.468 7.737l4.908-4.895-9.898 3.322c-.037 0-.073.019-.11.055a.17.17 0 0 0-.054.123.17.17 0 0 0 .055.123c.036.037.072.055.109.055l4.99 1.217Zm2.625 6.043 3.24-9.98L8.44 8.611l1.31 5.169a.17.17 0 0 0 .055.123c.036.036.073.054.11.054a.17.17 0 0 0 .123-.054.17.17 0 0 0 .054-.123Z\" }));\nconst ForwardRef = forwardRef(SvgSend);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SendSvgIcon from '@bloomreach/banana-theme/icons/send.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SendIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SendSvgIcon />\n </BrIcon>\n );\n});\n\nSendIcon.displayName = 'SendIcon';\n\nexport default SendIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSettingsAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.88 10.751H4.5a.75.75 0 0 0 0 1.5h1.38a2.25 2.25 0 0 0 4.242 0h3.379a.75.75 0 0 0 0-1.5h-3.379a2.251 2.251 0 0 0-4.243 0Zm2.87.75a.75.75 0 1 1-1.499 0 .75.75 0 0 1 1.5 0Zm-5-5a.75.75 0 0 1 .75-.75h5.38a2.25 2.25 0 1 1 0 1.5H4.5a.75.75 0 0 1-.75-.75Zm8.874-.417a.75.75 0 1 0-1.247.834.75.75 0 0 0 1.247-.834Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5.751a1.75 1.75 0 0 0-1.75 1.75v13c0 .967.784 1.75 1.75 1.75h13a1.75 1.75 0 0 0 1.75-1.75v-13A1.75 1.75 0 0 0 15.5.751h-13Zm-.25 1.75a.25.25 0 0 1 .25-.25h13a.25.25 0 0 1 .25.25v13a.25.25 0 0 1-.25.25h-13a.25.25 0 0 1-.25-.25v-13Z\" }));\nconst ForwardRef = forwardRef(SvgSettingsAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SettingsAltSvgIcon from '@bloomreach/banana-theme/icons/settings-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SettingsAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SettingsAltSvgIcon />\n </BrIcon>\n );\n});\n\nSettingsAltIcon.displayName = 'SettingsAltIcon';\n\nexport default SettingsAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSettings = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.335.783c-.22.025-.336.057-.606.169-.301.126-.423.232-1.186 1.035-.263.278-.37.336-.589.318-.203-.017-.283-.078-.69-.527-.527-.581-.75-.75-1.21-.914-.24-.085-.82-.108-1.083-.042-.568.143-1.099.565-1.345 1.069-.21.43-.226.537-.205 1.369l.018.723-.074.15a.465.465 0 0 1-.228.233l-.154.083-.589-.03a7.485 7.485 0 0 0-.82-.003c-.782.083-1.43.614-1.707 1.397-.075.21-.108.754-.06 1.004.054.29.208.633.383.853.09.113.354.38.587.595.233.215.448.438.48.496a.563.563 0 0 1-.013.504c-.038.068-.233.273-.439.459-.644.583-.766.743-.94 1.227-.087.239-.109.817-.042 1.08.218.857.873 1.449 1.728 1.559.148.019.423.018.802-.002.633-.035.716-.024.883.117.193.162.206.236.185 1.04-.02.829-.005.936.205 1.366.161.33.531.71.851.877.36.186.627.243 1.05.225.702-.031 1.044-.226 1.751-1.003.406-.444.474-.496.681-.513.25-.021.363.054.761.496.19.21.422.452.518.536.607.54 1.54.648 2.283.26.324-.168.692-.546.855-.878.069-.14.146-.336.17-.435.053-.202.063-.641.03-1.223-.027-.444.01-.588.181-.74.17-.147.264-.161.886-.127.327.018.646.02.78.005.859-.097 1.539-.701 1.757-1.56.076-.298.046-.841-.063-1.14-.152-.42-.326-.644-.9-1.158-.476-.426-.51-.475-.51-.732s.034-.306.51-.732c.574-.514.748-.74.9-1.158.108-.3.139-.842.063-1.14-.218-.86-.898-1.463-1.756-1.56a6.01 6.01 0 0 0-.78.006c-.617.035-.716.02-.885-.128-.19-.167-.206-.257-.168-.944.035-.633.02-.862-.08-1.17A2.043 2.043 0 0 0 11.335.784ZM6.66 2.299c.088.035.228.167.528.496.224.247.477.503.561.57.707.559 1.796.559 2.503 0 .084-.066.338-.323.563-.57.437-.477.532-.544.769-.544.135 0 .31.079.409.185.111.12.133.228.123.61-.005.198-.008.556-.008.795.002.394.01.458.085.675a2.038 2.038 0 0 0 1.274 1.287l.26.093.803-.007c.739-.007.814-.003.915.049a.554.554 0 0 1 .26.72c-.036.086-.171.23-.498.529-.513.469-.655.634-.795.929a1.81 1.81 0 0 0-.194.885c0 .373.049.58.212.915.14.286.316.486.838.956.406.366.483.478.483.696a.68.68 0 0 1-.143.383.7.7 0 0 1-.162.113c-.1.05-.18.055-.93.049l-.82-.007-.22.08c-.328.12-.533.253-.8.52a1.6 1.6 0 0 0-.367.495c-.207.42-.226.558-.204 1.41l.02.735-.088.138a.583.583 0 0 1-.47.267c-.206 0-.345-.097-.69-.481-.478-.531-.667-.697-.953-.837a1.791 1.791 0 0 0-.923-.214 1.95 1.95 0 0 0-1.252.418 8.17 8.17 0 0 0-.562.57c-.327.36-.436.46-.542.5a.556.556 0 0 1-.702-.267c-.064-.132-.065-.156-.046-.865.018-.677.015-.746-.043-.965a2.092 2.092 0 0 0-1.334-1.421l-.244-.083-.803.008c-.74.007-.812.003-.915-.05a.554.554 0 0 1-.259-.721c.034-.085.151-.212.414-.448.54-.485.715-.683.856-.971.166-.34.214-.547.214-.923a1.95 1.95 0 0 0-.415-1.248 8.072 8.072 0 0 0-.57-.562c-.472-.43-.547-.534-.547-.757a.68.68 0 0 1 .144-.383.707.707 0 0 1 .166-.115c.11-.056.158-.058.855-.04.688.019.756.016.976-.042.365-.096.626-.25.92-.543.207-.206.28-.304.38-.51.211-.434.23-.562.206-1.41l-.02-.735.087-.137a.556.556 0 0 1 .695-.22Zm2.003 2.985c-1.789.147-3.224 1.59-3.379 3.395a3.732 3.732 0 0 0 4.495 3.975 3.732 3.732 0 0 0 1.861-1.014 3.652 3.652 0 0 0 1.079-2.317c.157-1.831-1.005-3.47-2.794-3.94-.234-.061-.37-.08-.834-.114a3.745 3.745 0 0 0-.428.015Zm1.043 1.569c.34.115.625.294.888.556.26.26.439.544.558.887.077.222.083.274.083.705 0 .43-.006.483-.083.705a2.347 2.347 0 0 1-1.453 1.449c-.21.07-.277.078-.698.078-.42 0-.487-.007-.698-.078a2.274 2.274 0 0 1-.894-.562 2.255 2.255 0 0 1-.558-.887c-.077-.222-.083-.274-.083-.705 0-.431.006-.483.083-.705.22-.63.718-1.161 1.31-1.396.3-.118.5-.15.915-.138.328.009.428.023.63.09Z\" }));\nconst ForwardRef = forwardRef(SvgSettings);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SettingsSvgIcon from '@bloomreach/banana-theme/icons/settings.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SettingsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SettingsSvgIcon />\n </BrIcon>\n );\n});\n\nSettingsIcon.displayName = 'SettingsIcon';\n\nexport default SettingsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgShare = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.53 4.531a.75.75 0 0 1-1.06 0l-1.72-1.72v7.19a.75.75 0 0 1-1.5 0v-7.19l-1.72 1.72a.75.75 0 0 1-1.06-1.06l3-3a.75.75 0 0 1 1.06 0l3 3a.75.75 0 0 1 0 1.06Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.5 6.751H3.75v7.5h8.5v-7.5H10.5a.75.75 0 0 1 0-1.5h1.833c.707 0 1.417.532 1.417 1.35v7.8c0 .818-.71 1.35-1.417 1.35H3.667c-.706 0-1.417-.532-1.417-1.35v-7.8c0-.818.71-1.35 1.417-1.35H5.5a.75.75 0 1 1 0 1.5Z\" }));\nconst ForwardRef = forwardRef(SvgShare);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ShareSvgIcon from '@bloomreach/banana-theme/icons/share.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ShareIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ShareSvgIcon />\n </BrIcon>\n );\n});\n\nShareIcon.displayName = 'ShareIcon';\n\nexport default ShareIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgShop = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.088.001a.571.571 0 0 0-.553.457L.5 5.25C.5 6.216 1.261 7 2.2 7c.223 0 .435-.044.63-.124A1.75 1.75 0 0 0 3.9 5.25a1.75 1.75 0 0 0 1.07 1.626 1.653 1.653 0 0 0 1.26 0A1.75 1.75 0 0 0 7.3 5.25a1.75 1.75 0 0 0 1.07 1.626 1.653 1.653 0 0 0 1.26 0A1.75 1.75 0 0 0 10.7 5.25a1.75 1.75 0 0 0 1.07 1.626 1.653 1.653 0 0 0 1.26 0A1.75 1.75 0 0 0 14.1 5.25a1.75 1.75 0 0 0 1.07 1.626c.195.08.408.124.63.124.94 0 1.7-.784 1.7-1.75L16.465.458A.57.57 0 0 0 15.912 0H2.088Zm13.898 5.345c-.036.11-.13.155-.186.155-.07 0-.2-.07-.2-.25a1.5 1.5 0 0 0-3 0c0 .18-.13.25-.2.25s-.2-.07-.2-.25a1.5 1.5 0 0 0-3 0c0 .18-.13.25-.2.25s-.2-.07-.2-.25a1.5 1.5 0 1 0-3 0c0 .18-.13.25-.2.25s-.2-.07-.2-.25a1.5 1.5 0 1 0-3 0c0 .18-.13.25-.2.25-.056 0-.15-.045-.186-.155l.83-3.845h12.312l.83 3.845ZM2.5 7.751a.75.75 0 0 1 .75.75v5c0 .138.112.25.25.25h1.75v-2.75A2.75 2.75 0 0 1 8 8.251h2a2.75 2.75 0 0 1 2.75 2.75v2.75h1.75a.25.25 0 0 0 .25-.25v-5a.75.75 0 0 1 1.5 0v5a1.75 1.75 0 0 1-1.75 1.75h-11a1.75 1.75 0 0 1-1.75-1.75v-5a.75.75 0 0 1 .75-.75Zm8.75 6v-2.75c0-.69-.56-1.25-1.25-1.25H8c-.69 0-1.25.56-1.25 1.25v2.75h4.5Z\" }));\nconst ForwardRef = forwardRef(SvgShop);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ShopSvgIcon from '@bloomreach/banana-theme/icons/shop.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ShopIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ShopSvgIcon />\n </BrIcon>\n );\n});\n\nShopIcon.displayName = 'ShopIcon';\n\nexport default ShopIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgShrink = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.8 1.201a.71.71 0 0 1 1 0 .71.71 0 0 1 0 .99l-3.64 3.64h1.76a.7.7 0 1 1 0 1.4H9.47a.7.7 0 0 1-.7-.7v-3.45a.7.7 0 1 1 1.4 0v1.76l3.63-3.64Zm-7 7.62a.71.71 0 0 1 .38.38c.01.04.05.1.05.1a.965.965 0 0 1 0 .17v3.45a.7.7 0 1 1-1.4 0v-1.76l-3.63 3.63a.7.7 0 0 1-.5.21.67.67 0 0 1-.49-.2.69.69 0 0 1 0-1l3.63-3.58H3.08a.7.7 0 1 1 0-1.4h3.45a.965.965 0 0 1 .17 0h.1Z\" }));\nconst ForwardRef = forwardRef(SvgShrink);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport ShrinkSvgIcon from '@bloomreach/banana-theme/icons/shrink.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst ShrinkIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <ShrinkSvgIcon />\n </BrIcon>\n );\n});\n\nShrinkIcon.displayName = 'ShrinkIcon';\n\nexport default ShrinkIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSort = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.323.779c-.21.028-.37.126-.462.283l-.074.126-.007 6.753c-.004 3.714-.016 6.753-.026 6.753-.01 0-.44-.419-.954-.932-.692-.691-.964-.946-1.053-.986-.258-.116-.514-.047-.768.207-.244.244-.318.519-.205.766.032.072.533.592 1.563 1.626.834.837 1.516 1.534 1.516 1.549 0 .066.204.226.375.293a.606.606 0 0 0 .313.058c.194-.018.462-.153.554-.278.041-.056.75-.781 1.572-1.609 1.165-1.173 1.51-1.535 1.555-1.633.122-.267.046-.538-.222-.792-.176-.166-.33-.241-.5-.241-.25-.002-.31.047-1.32 1.049l-.94.934v-6.68c0-7.503.018-6.871-.198-7.079-.159-.153-.403-.21-.719-.167Zm6.157.047a2.078 2.078 0 0 0-.902.45c-.39.328-.66.776-.768 1.274-.049.24-.05.37-.044 2.738.008 2.756-.004 2.578.183 2.764.116.116.243.164.48.181.35.026.602-.085.72-.316.077-.152.103-.417.104-1.083v-.593h1.517l.01.78c.006.753.01.784.067.894.17.316.682.426 1.067.229.131-.067.163-.099.232-.235l.081-.158.007-2.475c.007-2.355.005-2.487-.044-2.727a2.275 2.275 0 0 0-1.393-1.64c-.38-.141-.95-.177-1.317-.083Zm.846 1.494c.163.084.294.22.372.385.06.132.061.163.07 1.089l.01.954h-1.525l.001-.967c0-.915.003-.973.055-1.087a.807.807 0 0 1 .481-.424.905.905 0 0 1 .536.05Zm-2.073 7.467a.567.567 0 0 0-.303.161c-.115.115-.165.243-.182.469-.028.348.087.613.318.737.113.06.13.06 1.314.074.782.008 1.197.022 1.191.04-.005.014-.599.907-1.32 1.984a150.85 150.85 0 0 0-1.37 2.067c-.127.235-.17.55-.114.845.092.483.53.936 1.002 1.037.087.019.627.026 1.572.021l1.44-.008.113-.06c.231-.124.346-.389.318-.737-.017-.225-.067-.354-.18-.467-.176-.176-.157-.174-1.472-.189l-1.193-.013 1.383-2.067c1.328-1.984 1.385-2.074 1.427-2.259.023-.105.043-.256.043-.334 0-.603-.466-1.173-1.06-1.298-.164-.033-2.796-.037-2.927-.003Z\" }));\nconst ForwardRef = forwardRef(SvgSort);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SortSvgIcon from '@bloomreach/banana-theme/icons/sort.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SortIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SortSvgIcon />\n </BrIcon>\n );\n});\n\nSortIcon.displayName = 'SortIcon';\n\nexport default SortIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSplitFlow = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.03 1.47a.75.75 0 1 0-1.06 1.06l.721.72h-1.69c-.829 0-1.57.332-2.187.76-.617.43-1.151.987-1.583 1.518A13.053 13.053 0 0 0 8.056 7.25H1.5a.75.75 0 1 0 0 1.5h6.555a13.264 13.264 0 0 0 1.176 1.724c.432.531.966 1.088 1.583 1.518.616.428 1.358.759 2.186.759h1.688l-.718.718a.75.75 0 1 0 1.06 1.06l1.974-1.972a.748.748 0 0 0 .027-1.088l-2-2a.75.75 0 1 0-1.06 1.06l.72.722h-1.69c-.422 0-.868-.17-1.33-.49-.461-.322-.895-.764-1.276-1.233A11.563 11.563 0 0 1 9.355 8a11.736 11.736 0 0 1 1.04-1.527c.38-.469.815-.912 1.276-1.232.462-.322.908-.491 1.33-.491h1.688l-.719.718a.75.75 0 0 0 1.06 1.06l1.974-1.972a.748.748 0 0 0 .027-1.088l-2-2Z\" }));\nconst ForwardRef = forwardRef(SvgSplitFlow);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SplitFlowSvgIcon from '@bloomreach/banana-theme/icons/split-flow.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SplitFlowIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SplitFlowSvgIcon />\n </BrIcon>\n );\n});\n\nSplitFlowIcon.displayName = 'SplitFlowIcon';\n\nexport default SplitFlowIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSql = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M12 7.251a.75.75 0 0 1 .75.75v4a.25.25 0 0 0 .25.25h1a.75.75 0 1 1 0 1.5h-1a1.75 1.75 0 0 1-1.75-1.75v-4a.75.75 0 0 1 .75-.75Zm-7 0a1.75 1.75 0 0 0-1.75 1.75c0 1.13.78 1.712 1.25 2.062l.05.038c.539.404.7.57.7.9a.25.25 0 0 1-.25.25H4a.75.75 0 1 0 0 1.5h1a1.75 1.75 0 0 0 1.75-1.75c0-1.13-.78-1.712-1.25-2.062L5.45 9.9c-.538-.404-.7-.57-.7-.9A.25.25 0 0 1 5 8.75h1a.75.75 0 0 0 0-1.5H5Zm2.763.513A1.75 1.75 0 0 1 10.751 9v3c0 .45-.174.883-.484 1.208l.264.264a.75.75 0 0 1-1.06 1.061l-.819-.818A1.75 1.75 0 0 1 7.251 12V9c0-.464.184-.91.512-1.237Zm1.238.987a.25.25 0 0 0-.25.25v3a.25.25 0 1 0 .5 0v-3a.25.25 0 0 0-.25-.25Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M.75 2.504c0-.967.784-1.75 1.75-1.75h13c.967 0 1.75.783 1.75 1.75v13a1.75 1.75 0 0 1-1.75 1.75h-13a1.75 1.75 0 0 1-1.75-1.75v-13Zm1.75-.25a.25.25 0 0 0-.25.25v13c0 .138.113.25.25.25h13a.25.25 0 0 0 .25-.25v-13a.25.25 0 0 0-.25-.25h-13Z\" }));\nconst ForwardRef = forwardRef(SvgSql);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SqlSvgIcon from '@bloomreach/banana-theme/icons/sql.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SqlIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SqlSvgIcon />\n </BrIcon>\n );\n});\n\nSqlIcon.displayName = 'SqlIcon';\n\nexport default SqlIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStarFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.704 5.82a1.003 1.003 0 0 0-.937-.653h-4.058a.333.333 0 0 1-.315-.223L8.937.816a1 1 0 0 0-1.873 0l-.003.01-1.454 4.118a.333.333 0 0 1-.314.223H1.234a1 1 0 0 0-.642 1.767l3.456 2.867a.333.333 0 0 1 .103.362L2.7 14.517a1 1 0 0 0 1.54 1.123l3.564-2.614a.333.333 0 0 1 .394 0l3.563 2.613a1 1 0 0 0 1.542-1.122L11.85 10.16a.333.333 0 0 1 .103-.362l3.463-2.87a1 1 0 0 0 .288-1.108Z\" }));\nconst ForwardRef = forwardRef(SvgStarFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StarFillSvgIcon from '@bloomreach/banana-theme/icons/star-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StarFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StarFillSvgIcon />\n </BrIcon>\n );\n});\n\nStarFillIcon.displayName = 'StarFillIcon';\n\nexport default StarFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStar = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.704 5.82a1.003 1.003 0 0 0-.937-.653h-4.058a.333.333 0 0 1-.315-.223L8.937.816a1 1 0 0 0-1.873 0l-.003.01-1.454 4.118a.333.333 0 0 1-.314.223H1.234a1 1 0 0 0-.642 1.767l3.456 2.867a.333.333 0 0 1 .103.362L2.7 14.517a1 1 0 0 0 1.54 1.123l3.564-2.614a.333.333 0 0 1 .394 0l3.563 2.613a1 1 0 0 0 1.541-1.122L11.85 10.16a.334.334 0 0 1 .104-.362l3.462-2.87a1 1 0 0 0 .289-1.108Zm-2.325.847-2.384 1.977a1.833 1.833 0 0 0-.569 1.99l.956 2.867-2.298-1.685a1.833 1.833 0 0 0-2.168 0L4.62 13.502l.955-2.864a1.833 1.833 0 0 0-.568-1.99L2.62 6.668h2.675a1.833 1.833 0 0 0 1.727-1.225l.979-2.773.978 2.773v.001a1.833 1.833 0 0 0 1.73 1.224h2.67Z\" }));\nconst ForwardRef = forwardRef(SvgStar);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StarSvgIcon from '@bloomreach/banana-theme/icons/star.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StarIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StarSvgIcon />\n </BrIcon>\n );\n});\n\nStarIcon.displayName = 'StarIcon';\n\nexport default StarIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStartFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001.001a8 8 0 1 0 8 8 8.009 8.009 0 0 0-8-8Zm3.219 8.596-4.921 2.46a.667.667 0 0 1-.965-.596V5.54a.667.667 0 0 1 .964-.597l4.922 2.458a.667.667 0 0 1 0 1.195v.001Z\" }));\nconst ForwardRef = forwardRef(SvgStartFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StartFillSvgIcon from '@bloomreach/banana-theme/icons/start-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StartFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StartFillSvgIcon />\n </BrIcon>\n );\n});\n\nStartFillIcon.displayName = 'StartFillIcon';\n\nexport default StartFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStart = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.36 4.77a1.84 1.84 0 0 0-2.11 1.82v4.82a1.84 1.84 0 0 0 3.053 1.385l3.692-3.23a.75.75 0 0 0 0-1.128L9.303 5.205a1.84 1.84 0 0 0-.944-.436Zm-.41 1.51a.34.34 0 0 1 .365.054l3.047 2.667-3.047 2.665a.34.34 0 0 1-.564-.257V6.59a.34.34 0 0 1 .2-.309Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9 .75a8.25 8.25 0 1 0 0 16.5A8.25 8.25 0 0 0 9 .75ZM2.25 9a6.75 6.75 0 1 1 13.5 0 6.75 6.75 0 0 1-13.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgStart);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StartSvgIcon from '@bloomreach/banana-theme/icons/start.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StartIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StartSvgIcon />\n </BrIcon>\n );\n});\n\nStartIcon.displayName = 'StartIcon';\n\nexport default StartIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStatusDot = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M13.001 8.001a5 5 0 1 1-10 0 5 5 0 0 1 10 0Z\" }));\nconst ForwardRef = forwardRef(SvgStatusDot);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StatusDotSvgIcon from '@bloomreach/banana-theme/icons/status-dot.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StatusDotIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StatusDotSvgIcon />\n </BrIcon>\n );\n});\n\nStatusDotIcon.displayName = 'StatusDotIcon';\n\nexport default StatusDotIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStop = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.001 5.75c-.69 0-1.25.56-1.25 1.25v4c0 .69.56 1.25 1.25 1.25h4c.69 0 1.25-.56 1.25-1.25V7c0-.69-.56-1.25-1.25-1.25h-4Zm.25 5v-3.5h3.5v3.5h-3.5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M9.001.75a8.25 8.25 0 1 0 0 16.5 8.25 8.25 0 0 0 0-16.5ZM2.251 9a6.75 6.75 0 1 1 13.5 0 6.75 6.75 0 0 1-13.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgStop);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StopSvgIcon from '@bloomreach/banana-theme/icons/stop.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StopIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StopSvgIcon />\n </BrIcon>\n );\n});\n\nStopIcon.displayName = 'StopIcon';\n\nexport default StopIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStopwatch = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.058 7.73a.75.75 0 1 0-1.113 1.006l2.5 2.768a.75.75 0 0 0 1.113-1.006l-2.5-2.767Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.251 3.792V2.251h-.75a.75.75 0 0 1 0-1.5h3a.75.75 0 1 1 0 1.5h-.75v1.541a6.713 6.713 0 0 1 3.18 1.22l.34-.341a.75.75 0 0 1 1.26-.7l.25.25.25.25a.75.75 0 0 1-.7 1.26l-.285.286a6.75 6.75 0 1 1-5.795-2.224Zm.75 1.459a5.25 5.25 0 1 0 0 10.5 5.25 5.25 0 0 0 0-10.5Z\" }));\nconst ForwardRef = forwardRef(SvgStopwatch);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StopwatchSvgIcon from '@bloomreach/banana-theme/icons/stopwatch.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StopwatchIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StopwatchSvgIcon />\n </BrIcon>\n );\n});\n\nStopwatchIcon.displayName = 'StopwatchIcon';\n\nexport default StopwatchIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgStringComponent = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 16, fill: \"currentColor\", viewBox: \"0 0 18 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.703.752a.762.762 0 0 0-.086 0H2.399c-1.185 0-2.146.96-2.148 2.146a.75.75 0 0 0 1.5.001c0-.357.29-.647.648-.647H4.91v11.543H3.797a.75.75 0 0 0 0 1.5h3.726a.75.75 0 0 0 0-1.5H6.41V2.252h2.511c.358 0 .648.29.648.647a.75.75 0 0 0 1.5-.001A2.148 2.148 0 0 0 8.92.752H5.703Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.127 7.29c0-.297.24-.538.538-.538h1.399v7.092h-.987a.75.75 0 0 0 0 1.5h3.437a.75.75 0 0 0 0-1.5h-.95V6.752h1.398a.54.54 0 0 1 .539.54.75.75 0 0 0 1.5 0 2.039 2.039 0 0 0-2.04-2.04h-2.104a.764.764 0 0 0-.087 0h-2.105A2.039 2.039 0 0 0 8.626 7.29a.75.75 0 0 0 1.5.002Z\" }));\nconst ForwardRef = forwardRef(SvgStringComponent);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StringComponentSvgIcon from '@bloomreach/banana-theme/icons/string-component.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StringComponentIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StringComponentSvgIcon />\n </BrIcon>\n );\n});\n\nStringComponentIcon.displayName = 'StringComponentIcon';\n\nexport default StringComponentIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgString = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 18, fill: \"currentColor\", viewBox: \"0 0 17 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.271.777A2.236 2.236 0 0 0 .296 2.618C.262 2.827.26 3.629.293 3.772c.037.159.157.31.308.386.115.059.17.068.387.069.36.001.527-.076.658-.299.07-.118.073-.144.088-.605.015-.441.022-.494.084-.629a.769.769 0 0 1 .368-.38l.122-.06 2.473-.007 2.473-.007v13.521H6.045c-1.287 0-1.359.006-1.535.132-.149.106-.22.268-.236.535-.017.294.034.474.175.62.184.19 0 .181 3.552.181 3.523 0 3.372.007 3.538-.167.157-.165.182-.245.182-.568 0-.272-.005-.302-.073-.418a.713.713 0 0 0-.156-.183c-.176-.126-.248-.132-1.535-.132H8.748V2.24l2.473.007 2.473.007.122.06c.164.08.294.214.368.38.062.135.07.188.084.629.015.464.018.487.09.607.134.229.388.332.747.302.245-.02.404-.102.514-.266.11-.162.125-.293.11-.906-.013-.437-.02-.508-.087-.712A2.223 2.223 0 0 0 13.686.775C13.343.742 2.61.744 2.271.777Z\" }));\nconst ForwardRef = forwardRef(SvgString);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport StringSvgIcon from '@bloomreach/banana-theme/icons/string.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst StringIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <StringSvgIcon />\n </BrIcon>\n );\n});\n\nStringIcon.displayName = 'StringIcon';\n\nexport default StringIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSuggestion = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25 6.501a5.75 5.75 0 1 0 11.5 0 5.75 5.75 0 0 0-11.5 0Zm1.5 0a4.25 4.25 0 1 1 5 4.184V9.312l1.28-1.28A.75.75 0 1 0 8.97 6.97L8 7.94l-.97-.97a.75.75 0 0 0-1.06 1.06l1.28 1.28v1.374A4.251 4.251 0 0 1 3.75 6.5ZM6 12.751a.75.75 0 0 0 0 1.5h4a.75.75 0 0 0 0-1.5H6Zm-.75 2.75a.75.75 0 0 1 .75-.75h4a.75.75 0 0 1 0 1.5H8.75v.25a.75.75 0 0 1-1.5 0v-.25H6a.75.75 0 0 1-.75-.75Z\" }));\nconst ForwardRef = forwardRef(SvgSuggestion);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SuggestionSvgIcon from '@bloomreach/banana-theme/icons/suggestion.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SuggestionIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SuggestionSvgIcon />\n </BrIcon>\n );\n});\n\nSuggestionIcon.displayName = 'SuggestionIcon';\n\nexport default SuggestionIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSurvey = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.625 2.251a.362.362 0 0 0-.266.11.362.362 0 0 0-.109.265v12.75c0 .104.037.193.11.266.072.073.16.11.265.11h12.75a.361.361 0 0 0 .266-.11.362.362 0 0 0 .11-.266V2.626a.362.362 0 0 0-.11-.265.361.361 0 0 0-.266-.11H2.625Zm0-1.5h12.75c.344 0 .656.084.938.25.291.167.52.396.687.688.167.281.25.593.25.937v12.75c0 .344-.083.662-.25.953a1.85 1.85 0 0 1-.687.672c-.282.167-.594.25-.938.25H2.625a1.881 1.881 0 0 1-1.328-.547 1.88 1.88 0 0 1-.547-1.328V2.626c0-.344.083-.656.25-.937a1.85 1.85 0 0 1 .672-.688c.292-.166.61-.25.953-.25Zm3.297 6.11 2.484-3.313a.673.673 0 0 1 .485-.281.723.723 0 0 1 .562.14c.167.115.26.277.281.485a.723.723 0 0 1-.14.562l-3 4a.743.743 0 0 1-1.125.078l-2-2a.733.733 0 0 1-.203-.515.815.815 0 0 1 .218-.531.705.705 0 0 1 .516-.22c.208 0 .386.069.531.204l1.391 1.39Zm4.578.39a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.53c0-.21.073-.386.219-.532a.723.723 0 0 1 .531-.219h3c.208 0 .386.073.531.219a.723.723 0 0 1 .22.531.723.723 0 0 1-.22.531.723.723 0 0 1-.53.22h-3ZM8.406 9.548a.673.673 0 0 1 .485-.281.723.723 0 0 1 .562.14c.167.115.26.277.281.485a.723.723 0 0 1-.14.562l-3 4a.743.743 0 0 1-1.125.079l-2-2a.733.733 0 0 1-.203-.516.815.815 0 0 1 .218-.531.706.706 0 0 1 .516-.22c.208 0 .386.069.531.204l1.391 1.39 2.484-3.312Zm2.094 3.703a.77.77 0 0 1-.375-.093.906.906 0 0 1-.281-.282.77.77 0 0 1-.094-.375.77.77 0 0 1 .094-.375.762.762 0 0 1 .281-.265.685.685 0 0 1 .375-.11h3c.208 0 .386.073.531.219a.723.723 0 0 1 .22.531.723.723 0 0 1-.22.532.723.723 0 0 1-.53.218h-3Z\" }));\nconst ForwardRef = forwardRef(SvgSurvey);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SurveySvgIcon from '@bloomreach/banana-theme/icons/survey.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SurveyIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SurveySvgIcon />\n </BrIcon>\n );\n});\n\nSurveyIcon.displayName = 'SurveyIcon';\n\nexport default SurveyIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgSwap = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"m3.25 8.814-1.219 1.219a.723.723 0 0 1-.53.218.723.723 0 0 1-.532-.218A.723.723 0 0 1 .75 9.5c0-.208.073-.385.219-.531l2.5-2.5A.723.723 0 0 1 4 6.251a.72.72 0 0 1 .531.219l2.5 2.5a.723.723 0 0 1 .22.531.723.723 0 0 1-.22.532.723.723 0 0 1-.53.218.723.723 0 0 1-.532-.218L4.75 8.813v2.688c0 .344.12.64.36.89.25.24.546.36.89.36h5.5a.72.72 0 0 1 .531.219.723.723 0 0 1 .22.531.723.723 0 0 1-.22.532.723.723 0 0 1-.53.218H6c-.5 0-.964-.12-1.391-.36a2.872 2.872 0 0 1-1-1c-.24-.426-.36-.89-.36-1.39V8.814Zm11.5-1.625 1.22-1.219a.724.724 0 0 1 .531-.219.72.72 0 0 1 .531.219.723.723 0 0 1 .22.531.723.723 0 0 1-.22.531l-2.468 2.47a.713.713 0 0 1-.563.25.713.713 0 0 1-.562-.25l-2.47-2.47a.723.723 0 0 1-.218-.53c0-.21.073-.386.219-.532a.724.724 0 0 1 .531-.219.72.72 0 0 1 .531.219l1.22 1.219V4.5c0-.344-.126-.635-.376-.875A1.166 1.166 0 0 0 12 3.251H6.5a.723.723 0 0 1-.531-.219.723.723 0 0 1-.219-.53c0-.21.073-.386.219-.532a.723.723 0 0 1 .531-.219H12c.5 0 .959.125 1.375.375.427.24.76.573 1 1 .25.417.375.875.375 1.375V7.19Z\" }));\nconst ForwardRef = forwardRef(SvgSwap);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport SwapSvgIcon from '@bloomreach/banana-theme/icons/swap.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst SwapIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <SwapSvgIcon />\n </BrIcon>\n );\n});\n\nSwapIcon.displayName = 'SwapIcon';\n\nexport default SwapIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTabletLangscape = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.441 1.752H2.497a1.75 1.75 0 0 0-1.75 1.75v9c0 .967.784 1.75 1.75 1.75h13a1.75 1.75 0 0 0 1.75-1.75v-9a1.75 1.75 0 0 0-1.75-1.75H4.554a.758.758 0 0 0-.113 0Zm11.056 1.5a.25.25 0 0 1 .25.25v9a.25.25 0 0 1-.25.25H5.247v-9.5h10.25Zm-11.75 0v9.5h-1.25a.25.25 0 0 1-.25-.25v-9a.25.25 0 0 1 .25-.25h1.25Z\" }));\nconst ForwardRef = forwardRef(SvgTabletLangscape);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TabletLangscapeSvgIcon from '@bloomreach/banana-theme/icons/tablet-langscape.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TabletLangscapeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TabletLangscapeSvgIcon />\n </BrIcon>\n );\n});\n\nTabletLangscapeIcon.displayName = 'TabletLangscapeIcon';\n\nexport default TabletLangscapeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTabletPortrait = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M1.748 13.557v1.944c0 .967.784 1.75 1.75 1.75h9a1.75 1.75 0 0 0 1.75-1.75v-13a1.75 1.75 0 0 0-1.75-1.75h-9a1.75 1.75 0 0 0-1.75 1.75v10.944a.759.759 0 0 0 0 .112Zm1.5-11.056a.25.25 0 0 1 .25-.25h9a.25.25 0 0 1 .25.25v10.25h-9.5V2.501Zm0 11.75h9.5v1.25a.25.25 0 0 1-.25.25h-9a.25.25 0 0 1-.25-.25v-1.25Z\" }));\nconst ForwardRef = forwardRef(SvgTabletPortrait);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TabletPortraitSvgIcon from '@bloomreach/banana-theme/icons/tablet-portrait.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TabletPortraitIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TabletPortraitSvgIcon />\n </BrIcon>\n );\n});\n\nTabletPortraitIcon.displayName = 'TabletPortraitIcon';\n\nexport default TabletPortraitIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTagAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.037.251h4.004a1.71 1.71 0 0 1 1.71 1.71v4.004a2.67 2.67 0 0 1-.782 1.887l-7.398 7.399a1.71 1.71 0 0 1-2.417 0L.75 10.849a1.71 1.71 0 0 1 0-2.418l7.4-7.398c.5-.5 1.18-.782 1.887-.782ZM9.21 2.094 1.812 9.49a.21.21 0 0 0 0 .297l4.402 4.402a.21.21 0 0 0 .297 0l7.397-7.398c.22-.22.343-.517.343-.827V1.961a.21.21 0 0 0-.21-.21h-4.004c-.31 0-.608.123-.827.343Zm2.431 2.057a.21.21 0 1 0 0 .42.21.21 0 0 0 0-.42Zm-1.71.21a1.71 1.71 0 1 1 3.42 0 1.71 1.71 0 0 1-3.42 0Z\" }));\nconst ForwardRef = forwardRef(SvgTagAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TagAltSvgIcon from '@bloomreach/banana-theme/icons/tag-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TagAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TagAltSvgIcon />\n </BrIcon>\n );\n});\n\nTagAltIcon.displayName = 'TagAltIcon';\n\nexport default TagAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTag = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.53 10.884a.25.25 0 0 1 0-.353l7.708-7.707a1.25 1.25 0 0 1 .883-.366m0 0h4.172a.25.25 0 0 1 .25.25v4.171c0 .332-.132.65-.366.884L7.47 15.47a.25.25 0 0 1-.354 0L2.53 10.884M11.121.958c-.729 0-1.428.29-1.944.805L1.47 9.47a1.75 1.75 0 0 0 0 2.475l4.586 4.586a1.75 1.75 0 0 0 2.474 0l7.708-7.708a2.75 2.75 0 0 0 .805-1.944V2.708a1.75 1.75 0 0 0-1.75-1.75H11.12Zm-.078 4.25a1.75 1.75 0 1 0 3.5 0 1.75 1.75 0 0 0-3.5 0Zm1.75-.25a.25.25 0 1 1 0 .5.25.25 0 0 1 0-.5Z\" }));\nconst ForwardRef = forwardRef(SvgTag);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TagSvgIcon from '@bloomreach/banana-theme/icons/tag.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TagIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TagSvgIcon />\n </BrIcon>\n );\n});\n\nTagIcon.displayName = 'TagIcon';\n\nexport default TagIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTemplate = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.5 3.251a.75.75 0 0 1 .75-.75h9.5a.75.75 0 0 1 .75.75v4.5a.75.75 0 0 1-.75.75H8.5v4.25a.75.75 0 0 1-.75.75h-4.5a.75.75 0 0 1-.75-.75v-9.5Zm4.5.75H4v8h3v-8Zm1.5 3H12v-3H8.5v3Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M0 1.751C0 .785.785.001 1.75.001h12.5c.967 0 1.75.784 1.75 1.75v8.5a.75.75 0 0 1-.219.53l-5 5a.75.75 0 0 1-.53.22h-8.5A1.75 1.75 0 0 1 0 14.251v-12.5Zm1.75-.25a.25.25 0 0 0-.25.25v12.5c0 .138.113.25.25.25H9.5v-3.25c0-.966.784-1.75 1.75-1.75h3.25v-7.75a.25.25 0 0 0-.25-.25H1.75Zm11.69 9.5h-2.19a.25.25 0 0 0-.25.25v2.19L13.44 11Z\" }));\nconst ForwardRef = forwardRef(SvgTemplate);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TemplateSvgIcon from '@bloomreach/banana-theme/icons/template.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TemplateIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TemplateSvgIcon />\n </BrIcon>\n );\n});\n\nTemplateIcon.displayName = 'TemplateIcon';\n\nexport default TemplateIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTextBold = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.119 1.001a.75.75 0 0 1 .75-.75H9.4a3.55 3.55 0 0 1 2.17 6.359 4.949 4.949 0 0 1-2.636 9.139H2.869a.75.75 0 0 1 0-1.5h1.116V1.75H2.869a.75.75 0 0 1-.75-.75Zm3.366 6.35v6.897h3.449a3.45 3.45 0 0 0 .008-6.898H5.484Zm3.44-1.5H9.4a2.05 2.05 0 0 0 0-4.1H5.485v4.1h3.44Z\" }));\nconst ForwardRef = forwardRef(SvgTextBold);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TextBoldSvgIcon from '@bloomreach/banana-theme/icons/text-bold.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TextBoldIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TextBoldSvgIcon />\n </BrIcon>\n );\n});\n\nTextBoldIcon.displayName = 'TextBoldIcon';\n\nexport default TextBoldIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTextItalic = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.887.251h3.364a.75.75 0 0 1 0 1.5h-2.942l-6.9 12.401h2.109a.75.75 0 0 1 0 1.5H.75a.75.75 0 0 1 0-1.5h2.942l6.899-12.4H8.484a.75.75 0 0 1 0-1.5h3.403Z\" }));\nconst ForwardRef = forwardRef(SvgTextItalic);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TextItalicSvgIcon from '@bloomreach/banana-theme/icons/text-italic.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TextItalicIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TextItalicSvgIcon />\n </BrIcon>\n );\n});\n\nTextItalicIcon.displayName = 'TextItalicIcon';\n\nexport default TextItalicIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTextStyle = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M.251 2.751a2.25 2.25 0 0 1 2.25-2.25h11a2.25 2.25 0 0 1 2.25 2.25v.25a.75.75 0 0 1-1.5 0v-.25a.75.75 0 0 0-.75-.75h-4.75v11.905h2.25a.75.75 0 0 1 0 1.5h-6a.75.75 0 0 1 0-1.5h2.25V2h-4.75a.75.75 0 0 0-.75.75V3a.75.75 0 0 1-1.5 0v-.25Z\" }));\nconst ForwardRef = forwardRef(SvgTextStyle);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TextStyleSvgIcon from '@bloomreach/banana-theme/icons/text-style.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TextStyleIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TextStyleSvgIcon />\n </BrIcon>\n );\n});\n\nTextStyleIcon.displayName = 'TextStyleIcon';\n\nexport default TextStyleIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTraget = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.668 8.001a2.667 2.667 0 1 1-5.334 0 2.667 2.667 0 0 1 5.334 0Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.252 7.335h1.082a.667.667 0 1 1 0 1.333h-1.082a.333.333 0 0 0-.328.28 6.011 6.011 0 0 1-4.976 4.976.333.333 0 0 0-.28.329v1.082a.667.667 0 0 1-1.334 0v-1.082a.333.333 0 0 0-.28-.33A6.011 6.011 0 0 1 2.078 8.95a.333.333 0 0 0-.328-.281H.668a.667.667 0 0 1 0-1.333H1.75a.333.333 0 0 0 .328-.281A6.011 6.011 0 0 1 7.054 2.08a.333.333 0 0 0 .28-.33V.669a.667.667 0 0 1 1.334 0V1.75a.333.333 0 0 0 .28.329 6.011 6.011 0 0 1 4.976 4.975.333.333 0 0 0 .328.28ZM5.408 11.88a4.667 4.667 0 1 0 5.186-7.76 4.667 4.667 0 0 0-5.186 7.76Z\" }));\nconst ForwardRef = forwardRef(SvgTraget);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TragetSvgIcon from '@bloomreach/banana-theme/icons/traget.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TragetIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TragetSvgIcon />\n </BrIcon>\n );\n});\n\nTragetIcon.displayName = 'TragetIcon';\n\nexport default TragetIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTransfer = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 17, fill: \"currentColor\", viewBox: \"0 0 17 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.001 1.75a.75.75 0 0 0-.75.75v9.189l-1.22-1.22a.75.75 0 1 0-1.06 1.06l2.5 2.5a.748.748 0 0 0 1.06 0l2.5-2.5a.75.75 0 0 0-1.06-1.06l-1.22 1.22v-9.19a.75.75 0 0 0-.75-.75Zm5.469.219a.747.747 0 0 1 1.061 0l2.5 2.5a.75.75 0 1 1-1.06 1.06l-1.22-1.22v9.19a.75.75 0 0 1-1.5 0V4.31l-1.22 1.22a.75.75 0 0 1-1.06-1.06l2.5-2.5Z\" }));\nconst ForwardRef = forwardRef(SvgTransfer);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TransferSvgIcon from '@bloomreach/banana-theme/icons/transfer.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TransferIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TransferSvgIcon />\n </BrIcon>\n );\n});\n\nTransferIcon.displayName = 'TransferIcon';\n\nexport default TransferIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTrash = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 17, fill: \"currentColor\", viewBox: \"0 0 17 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.094.307C5.542.431 5.05.875 4.851 1.432c-.04.11-.06.253-.073.49l-.017.332-2.027.014c-1.913.012-2.032.016-2.12.063a.612.612 0 0 0-.276.27c-.048.091-.057.151-.057.4 0 .316.038.437.177.564.16.145.212.155.802.165l.552.008.014.112c.01.061.208 2.433.443 5.271.261 3.14.444 5.223.47 5.32.154.607.688 1.128 1.286 1.255.262.056 7.69.056 7.952 0 .598-.127 1.132-.648 1.287-1.255.025-.097.208-2.18.47-5.32.234-2.838.433-5.21.442-5.27l.014-.113.552-.008c.505-.008.561-.014.66-.066a.612.612 0 0 0 .27-.276c.04-.075.05-.152.05-.387 0-.235-.01-.312-.05-.387a.612.612 0 0 0-.27-.276c-.107-.057-.118-.057-2.125-.064l-2.018-.008-.019-.286c-.022-.34-.103-.639-.228-.846a1.887 1.887 0 0 0-.932-.78L9.881.281 8.068.276C6.63.272 6.221.278 6.094.307ZM9.672 1.82c.061.061.075.101.084.247l.011.174H6.241v-.158c0-.13.012-.172.068-.238a.293.293 0 0 1 .126-.092 54.48 54.48 0 0 1 1.612-.009l1.553.004.072.072Zm3.011 2.094c-.009.085-.202 2.39-.43 5.124a666.922 666.922 0 0 1-.428 5.031.319.319 0 0 1-.082.123l-.066.062H4.325l-.066-.062a.319.319 0 0 1-.082-.123 668.49 668.49 0 0 1-.428-5.03c-.228-2.735-.42-5.04-.43-5.125l-.017-.153H12.7l-.017.153ZM6.254 5.787a.615.615 0 0 0-.434.344c-.042.09-.046.304-.046 2.87 0 2.566.004 2.781.046 2.87.06.127.19.255.311.306.152.066.472.08.65.027.275-.08.403-.247.447-.583.014-.108.025-1.26.025-2.62 0-1.359-.01-2.512-.025-2.62-.043-.33-.17-.502-.433-.579a1.27 1.27 0 0 0-.54-.015Zm2.926.023a.546.546 0 0 0-.335.284l-.057.107v5.6l.058.11c.128.24.374.348.727.322.236-.017.363-.065.48-.18.187-.188.175.027.175-3.052s.012-2.864-.176-3.05c-.12-.122-.247-.167-.504-.18-.177-.009-.258 0-.368.04Z\" }));\nconst ForwardRef = forwardRef(SvgTrash);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TrashSvgIcon from '@bloomreach/banana-theme/icons/trash.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TrashIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TrashSvgIcon />\n </BrIcon>\n );\n});\n\nTrashIcon.displayName = 'TrashIcon';\n\nexport default TrashIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgTrend = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M17.194 3.714a.748.748 0 0 0-.693-.463h-4.5a.75.75 0 0 0 0 1.5h2.69l-4.013 4.013a.25.25 0 0 1-.354 0L8.24 6.678a1.75 1.75 0 0 0-2.475 0L.97 11.471a.75.75 0 0 0 1.06 1.06L6.826 7.74a.25.25 0 0 1 .353 0l2.086 2.085a1.75 1.75 0 0 0 2.475 0l4.012-4.012v2.69a.75.75 0 0 0 1.5 0v-4.5a.747.747 0 0 0-.057-.288Z\" }));\nconst ForwardRef = forwardRef(SvgTrend);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport TrendSvgIcon from '@bloomreach/banana-theme/icons/trend.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst TrendIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <TrendSvgIcon />\n </BrIcon>\n );\n});\n\nTrendIcon.displayName = 'TrendIcon';\n\nexport default TrendIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUnExpose = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.366.74a5.75 5.75 0 0 1 5.519 3.752 3.997 3.997 0 0 1 3.974.717 4 4 0 0 1-1.63 6.92.75.75 0 1 1-.364-1.455 2.498 2.498 0 0 0 1.67-3.457 2.5 2.5 0 0 0-3.7-1.024.75.75 0 0 1-1.164-.48 4.25 4.25 0 1 0-7.14 3.824.75.75 0 0 1-1.045 1.076A5.75 5.75 0 0 1 6.366.74Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M5.471 8.996a.75.75 0 0 1 1.06 0l2.47 2.47 2.47-2.47a.75.75 0 0 1 1.06 1.06l-2.469 2.47 2.42 2.42a.75.75 0 1 1-1.061 1.06L9 13.587l-2.419 2.42a.75.75 0 0 1-1.06-1.061l2.419-2.42-2.47-2.47a.75.75 0 0 1 0-1.06Z\" }));\nconst ForwardRef = forwardRef(SvgUnExpose);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UnExposeSvgIcon from '@bloomreach/banana-theme/icons/un-expose.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UnExposeIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UnExposeSvgIcon />\n </BrIcon>\n );\n});\n\nUnExposeIcon.displayName = 'UnExposeIcon';\n\nexport default UnExposeIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUnarchiveAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M11.469.416a.75.75 0 1 0-.938 1.17l.83.665H11a4.75 4.75 0 0 0-4.75 4.75v1a.75.75 0 0 0 1.5 0v-1A3.25 3.25 0 0 1 11 3.751h.362l-.83.665a.75.75 0 0 0 .937 1.17l2.496-1.996a.749.749 0 0 0 0-1.177L11.47.416ZM2 9.251a1.75 1.75 0 0 0-1.75 1.75v3A1.75 1.75 0 0 0 2 15.751h12a1.75 1.75 0 0 0 1.75-1.75v-3A1.75 1.75 0 0 0 14 9.251h-2.555a.75.75 0 0 0-.651.378 3.217 3.217 0 0 1-5.588 0 .75.75 0 0 0-.651-.378H2Zm-.177 1.574A.25.25 0 0 1 2 10.75h2.144a4.718 4.718 0 0 0 7.712 0H14a.25.25 0 0 1 .25.25v3a.25.25 0 0 1-.25.25H2a.25.25 0 0 1-.25-.25v-3a.25.25 0 0 1 .073-.176Z\" }));\nconst ForwardRef = forwardRef(SvgUnarchiveAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UnarchiveAltSvgIcon from '@bloomreach/banana-theme/icons/unarchive-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UnarchiveAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UnarchiveAltSvgIcon />\n </BrIcon>\n );\n});\n\nUnarchiveAltIcon.displayName = 'UnarchiveAltIcon';\n\nexport default UnarchiveAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUndo = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.25 5.143v6.192a.25.25 0 0 0 .25.25h6.19L6.987 9.883a.75.75 0 0 1-.074-.974A5.694 5.694 0 0 1 11.5 6.584c.618 0 1.214.098 1.772.279a7.23 7.23 0 0 0-8.898-.473.75.75 0 0 1-.96-.084L2.25 5.143Zm-.729-1.758a1.25 1.25 0 0 1 1.362.27l1.162 1.162a8.73 8.73 0 0 1 13.205 7.52.75.75 0 0 1-1.5-.002 4.25 4.25 0 0 0-4.25-4.25 4.186 4.186 0 0 0-2.961 1.228l1.638 1.638a1.25 1.25 0 0 1-.884 2.133H2.5a1.75 1.75 0 0 1-1.75-1.75V4.54c0-.505.304-.961.771-1.155Z\" }));\nconst ForwardRef = forwardRef(SvgUndo);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UndoSvgIcon from '@bloomreach/banana-theme/icons/undo.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UndoIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UndoSvgIcon />\n </BrIcon>\n );\n});\n\nUndoIcon.displayName = 'UndoIcon';\n\nexport default UndoIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUnlink = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8 .75a.75.75 0 0 1 .75.75v3a.75.75 0 1 1-1.5 0v-3A.75.75 0 0 1 8 .75ZM3.718 10.751a1.892 1.892 0 0 1-1.966-1.75 1.892 1.892 0 0 1 1.998-1.75H5a.75.75 0 0 0 0-1.5H3.765a3.392 3.392 0 0 0-3.514 3.21.758.758 0 0 0 0 .092 3.392 3.392 0 0 0 3.514 3.197H5a.75.75 0 0 0 0-1.5H3.75l-.032.001ZM15.75 8.962a3.391 3.391 0 0 0-3.515-3.21H11a.75.75 0 0 0 0 1.5h1.25l.032-.001A1.891 1.891 0 0 1 14.25 9a1.892 1.892 0 0 1-1.999 1.75H11a.75.75 0 1 0 0 1.5h1.235a3.392 3.392 0 0 0 3.514-3.198.772.772 0 0 0 0-.091ZM5.53 2.97a.75.75 0 1 0-1.06 1.06l1 1a.75.75 0 0 0 1.06-1.06l-1-1Zm6 0a.75.75 0 0 1 0 1.06l-1 1a.75.75 0 1 1-1.06-1.06l1-1a.75.75 0 0 1 1.06 0ZM8.75 13.5a.75.75 0 0 0-1.5 0v3a.75.75 0 0 0 1.5 0v-3Zm-2.22-.53a.75.75 0 0 1 0 1.06l-1 1a.75.75 0 0 1-1.06-1.06l1-1a.75.75 0 0 1 1.06 0Zm4 0a.75.75 0 1 0-1.06 1.06l1 1a.75.75 0 1 0 1.06-1.06l-1-1Z\" }));\nconst ForwardRef = forwardRef(SvgUnlink);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UnlinkSvgIcon from '@bloomreach/banana-theme/icons/unlink.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UnlinkIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UnlinkSvgIcon />\n </BrIcon>\n );\n});\n\nUnlinkIcon.displayName = 'UnlinkIcon';\n\nexport default UnlinkIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUnlock = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M10.75 10.001a.75.75 0 0 0-1.5 0v2a.75.75 0 0 0 1.5 0v-2Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M4.5 1.751a2.75 2.75 0 0 0-2.75 2.75v2.5a.75.75 0 0 1-1.5 0v-2.5a4.25 4.25 0 0 1 8.5 0v1.75H14c.967 0 1.75.784 1.75 1.75v6a1.75 1.75 0 0 1-1.75 1.75H6a1.75 1.75 0 0 1-1.75-1.75v-6c0-.966.784-1.75 1.75-1.75h1.25v-1.75a2.75 2.75 0 0 0-2.75-2.75Zm1.5 6a.25.25 0 0 0-.25.25v6c0 .138.112.25.25.25h8a.25.25 0 0 0 .25-.25v-6a.25.25 0 0 0-.25-.25H6Z\" }));\nconst ForwardRef = forwardRef(SvgUnlock);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UnlockSvgIcon from '@bloomreach/banana-theme/icons/unlock.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UnlockIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UnlockSvgIcon />\n </BrIcon>\n );\n});\n\nUnlockIcon.displayName = 'UnlockIcon';\n\nexport default UnlockIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUntilNowAlt = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 18, fill: \"currentColor\", viewBox: \"0 0 16 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.751.668a.75.75 0 0 1 .75.75v15a.75.75 0 0 1-1.5 0v-15a.75.75 0 0 1 .75-.75ZM.59 3.065a.75.75 0 0 1 1.015-.309l9.647 5.147a.75.75 0 0 1 .177.13 1.25 1.25 0 0 1 0 1.769.75.75 0 0 1-.177.131L1.604 15.08a.75.75 0 1 1-.706-1.324l9.069-4.838L.898 4.08a.75.75 0 0 1-.309-1.015Z\" }));\nconst ForwardRef = forwardRef(SvgUntilNowAlt);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UntilNowAltSvgIcon from '@bloomreach/banana-theme/icons/until-now-alt.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UntilNowAltIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UntilNowAltSvgIcon />\n </BrIcon>\n );\n});\n\nUntilNowAltIcon.displayName = 'UntilNowAltIcon';\n\nexport default UntilNowAltIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUpload = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.47 1.97a.748.748 0 0 1 1.062 0l3 3a.75.75 0 1 1-1.061 1.062l-1.72-1.72v6.19a.75.75 0 0 1-1.5 0v-6.19l-1.72 1.72a.75.75 0 0 1-1.06-1.061l3-3Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.251 10.501a.75.75 0 0 0-1.5 0v1a2.75 2.75 0 0 0 2.75 2.75h11a2.75 2.75 0 0 0 2.75-2.75v-1a.75.75 0 0 0-1.5 0v1c0 .69-.56 1.25-1.25 1.25h-11c-.69 0-1.25-.56-1.25-1.25v-1Z\" }));\nconst ForwardRef = forwardRef(SvgUpload);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UploadSvgIcon from '@bloomreach/banana-theme/icons/upload.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UploadIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UploadSvgIcon />\n </BrIcon>\n );\n});\n\nUploadIcon.displayName = 'UploadIcon';\n\nexport default UploadIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUsages = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M14.031 5.03a2.25 2.25 0 1 0-1.06-1.06l-1.264 1.263a3.235 3.235 0 0 0-1.706-.483 3.245 3.245 0 0 0-2.608 1.31L5.686 5.036a2.25 2.25 0 1 0-.824 1.255l1.935 1.161a3.272 3.272 0 0 0 .437 2.254l-3.263 3.263a2.25 2.25 0 1 0 1.06 1.06l3.264-3.262c.291.18.613.315.956.396v1.715a2.251 2.251 0 1 0 1.5 0v-1.715a3.245 3.245 0 0 0 1.517-.835l.565.565a2.253 2.253 0 0 0 2.168 2.857 2.25 2.25 0 1 0-1.286-4.097l-.63-.629a3.235 3.235 0 0 0-.318-2.73l1.264-1.263Zm.97-2.78a.75.75 0 1 1 0 1.5.75.75 0 0 1 0-1.5ZM8.358 7.394a1.75 1.75 0 1 1 .442 1.88.765.765 0 0 0-.073-.074 1.744 1.744 0 0 1-.369-1.806ZM4.125 4.916a.75.75 0 1 1-1.247-.83.75.75 0 0 1 1.247.83ZM3 14.25a.747.747 0 0 1 .75.75.75.75 0 1 1-.75-.75Zm11.25-2.75a.746.746 0 0 1 .75-.75.75.75 0 1 1-.75.75ZM10 14.25a.75.75 0 1 1 0 1.5.75.75 0 0 1 0-1.5Z\" }));\nconst ForwardRef = forwardRef(SvgUsages);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UsagesSvgIcon from '@bloomreach/banana-theme/icons/usages.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UsagesIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UsagesSvgIcon />\n </BrIcon>\n );\n});\n\nUsagesIcon.displayName = 'UsagesIcon';\n\nexport default UsagesIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgUsers = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M5 2.751a2.25 2.25 0 1 0 0 4.5 2.25 2.25 0 0 0 0-4.5Zm-3.75 2.25a3.75 3.75 0 1 1 7.5 0 3.75 3.75 0 0 1-7.5 0ZM12 7.751a.75.75 0 1 0 0 1.5.75.75 0 0 0 0-1.5Zm-2.25.75a2.25 2.25 0 1 1 4.5 0 2.25 2.25 0 0 1-4.5 0ZM6 10.751a4.25 4.25 0 0 0-4.25 4.25.75.75 0 0 1-1.5 0 5.75 5.75 0 0 1 8.05-5.27.75.75 0 1 1-.6 1.375 4.25 4.25 0 0 0-1.7-.355Zm6 2a2.25 2.25 0 0 0-2.25 2.25.75.75 0 0 1-1.5 0 3.75 3.75 0 0 1 7.5 0 .75.75 0 0 1-1.5 0 2.25 2.25 0 0 0-2.25-2.25Z\" }));\nconst ForwardRef = forwardRef(SvgUsers);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport UsersSvgIcon from '@bloomreach/banana-theme/icons/users.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst UsersIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <UsersSvgIcon />\n </BrIcon>\n );\n});\n\nUsersIcon.displayName = 'UsersIcon';\n\nexport default UsersIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgVisual = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.77.774a.75.75 0 0 1 .556.59c.11.594.212.913.365 1.103.101.125.298.284.897.284h.005a3.267 3.267 0 0 1 3.23 2.954l7.595 8.79a1.671 1.671 0 0 1-2.362 2.351l-.003-.002L4.296 9.24C2.428 9.108 1.301 7.697.914 6.117.513 4.475.844 2.48 2.003 1.033a.75.75 0 0 1 .768-.26Zm3.05 3.995a1.767 1.767 0 0 0-1.235-.518c-.899 0-1.593-.26-2.063-.844-.02-.025-.04-.05-.059-.077a4.625 4.625 0 0 0-.091 2.43c.27 1.108.94 1.851 1.923 1.974l2.017-2.018a1.767 1.767 0 0 0-.491-.947Zm-.132 3.693 8.346 7.246v.001a.171.171 0 0 0 .243-.24L7.048 7.102l-1.36 1.36Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"m13.995 7.896 1.6-1.6a1.405 1.405 0 0 1-.184 1.538L13.27 9.97a.75.75 0 0 0 1.06 1.062l2.16-2.156a2.902 2.902 0 0 0 .177-3.688 2.75 2.75 0 0 0-4.137-3.606l-3.6 3.6a.75.75 0 0 0-.03 1.029l2.665 2.992a.75.75 0 0 0 1.09.032l1.327-1.327.006-.006.006-.006Zm.48-5.62a1.25 1.25 0 0 1 .885 2.134l-1.901 1.901-1.768-1.768 1.9-1.9a1.25 1.25 0 0 1 .885-.367Zm-2.077 5.096-.24.24-1.666-1.87.138-.138 1.768 1.768Zm-8.608 2.95a.75.75 0 0 1 1.052-.008l2.876 2.781a.75.75 0 0 1 .008 1.07l-.888.888a1.75 1.75 0 0 1-1.825.41L4.01 16.468a.75.75 0 0 1-1.061 0l-.177-.177-.74.742A.75.75 0 1 1 .97 15.97l.74-.741-.176-.177a.75.75 0 0 1 0-1.061l1.003-1.004a1.75 1.75 0 0 1 .411-1.824l.841-.842Zm.043 4.2-.354-.353-.353.353.353.354.354-.354Zm1.768-.457a.25.25 0 0 0 .176-.073l.35-.349-1.797-1.738-.32.32a.25.25 0 0 0-.005.348l.005.005 1.414 1.414.005.005a.25.25 0 0 0 .172.068Z\" }));\nconst ForwardRef = forwardRef(SvgVisual);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport VisualSvgIcon from '@bloomreach/banana-theme/icons/visual.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst VisualIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <VisualSvgIcon />\n </BrIcon>\n );\n});\n\nVisualIcon.displayName = 'VisualIcon';\n\nexport default VisualIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgVoucher = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 17, fill: \"currentColor\", viewBox: \"0 0 18 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M6.501 4.251a1.75 1.75 0 1 0 0 3.5 1.75 1.75 0 0 0 0-3.5Zm-.25 1.75a.25.25 0 1 1 .5 0 .25.25 0 0 1-.5 0Zm4 4a1.75 1.75 0 1 1 3.5 0 1.75 1.75 0 0 1-3.5 0Zm1.75-.25a.25.25 0 1 0 0 .5.25.25 0 0 0 0-.5Zm.03-3.719a.75.75 0 1 0-1.06-1.061l-5 5a.75.75 0 0 0 1.06 1.06l5-5Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.501 2.251a1.75 1.75 0 0 0-1.75 1.75v2c0 .414.336.75.75.75a1.25 1.25 0 0 1 0 2.5.75.75 0 0 0-.75.75v2a1.75 1.75 0 0 0 1.75 1.75h13a1.75 1.75 0 0 0 1.75-1.75v-2a.75.75 0 0 0-.75-.75 1.25 1.25 0 0 1 0-2.5.75.75 0 0 0 .75-.75v-2a1.75 1.75 0 0 0-1.75-1.75h-13Zm-.177 1.573a.25.25 0 0 1 .177-.073h13a.25.25 0 0 1 .25.25v1.354a2.75 2.75 0 0 0 0 5.292v1.354a.25.25 0 0 1-.25.25h-13a.25.25 0 0 1-.25-.25v-1.354a2.75 2.75 0 0 0 0-5.292V4.001a.25.25 0 0 1 .073-.177Z\" }));\nconst ForwardRef = forwardRef(SvgVoucher);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport VoucherSvgIcon from '@bloomreach/banana-theme/icons/voucher.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst VoucherIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <VoucherSvgIcon />\n </BrIcon>\n );\n});\n\nVoucherIcon.displayName = 'VoucherIcon';\n\nexport default VoucherIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWait = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 17, fill: \"currentColor\", viewBox: \"0 0 16 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.751 4.751a.75.75 0 0 0-.75.75v2.5a.748.748 0 0 0 .22.53l3.124 3.126a.75.75 0 1 0 1.061-1.06L8.501 7.69V5.5a.75.75 0 0 0-.75-.75Z\" }), /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001.251a7.75 7.75 0 1 0 0 15.5 7.75 7.75 0 0 0 0-15.5Zm-6.25 7.75a6.25 6.25 0 1 1 12.5 0 6.25 6.25 0 0 1-12.5 0Z\" }));\nconst ForwardRef = forwardRef(SvgWait);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WaitSvgIcon from '@bloomreach/banana-theme/icons/wait.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WaitIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WaitSvgIcon />\n </BrIcon>\n );\n});\n\nWaitIcon.displayName = 'WaitIcon';\n\nexport default WaitIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWalkthroughs = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M7.501.751a.75.75 0 0 1 .75.75v1.25l4.328-.002a1.75 1.75 0 0 1 1.254.529l2.91 2.99a1.75 1.75 0 0 1 0 2.467l-2.91 2.988a1.751 1.751 0 0 1-1.254.528H8.25v4.25a.75.75 0 0 1-1.5 0v-4.25H2.5a1.75 1.75 0 0 1-1.75-1.75v-6a1.75 1.75 0 0 1 1.75-1.75h4.25V1.5A.75.75 0 0 1 7.5.75Zm0 3.5h-5a.25.25 0 0 0-.25.25v6a.25.25 0 0 0 .25.25H12.58a.253.253 0 0 0 .18-.075l2.92-2.998a.25.25 0 0 0 0-.354l-.008-.007-2.912-2.992a.252.252 0 0 0-.18-.076l-5.038.001a.762.762 0 0 1-.04.001Z\" }));\nconst ForwardRef = forwardRef(SvgWalkthroughs);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WalkthroughsSvgIcon from '@bloomreach/banana-theme/icons/walkthroughs.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WalkthroughsIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WalkthroughsSvgIcon />\n </BrIcon>\n );\n});\n\nWalkthroughsIcon.displayName = 'WalkthroughsIcon';\n\nexport default WalkthroughsIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWarningFill = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 16, height: 16, fill: \"currentColor\", viewBox: \"0 0 16 16\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M15.413 13.333 9.18 1.433a1.333 1.333 0 0 0-2.362 0l-6.232 11.9a1.333 1.333 0 0 0 1.182 1.952H14.23a1.333 1.333 0 0 0 1.182-1.952Zm-8.08-7.718a.667.667 0 0 1 1.334 0v4a.667.667 0 0 1-1.334 0v-4Zm.7 7.674h-.018A1.019 1.019 0 0 1 7 12.309a.984.984 0 0 1 .965-1.02h.019a1.018 1.018 0 0 1 .954 1.362.983.983 0 0 1-.905.638Z\" }));\nconst ForwardRef = forwardRef(SvgWarningFill);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WarningFillSvgIcon from '@bloomreach/banana-theme/icons/warning-fill.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WarningFillIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WarningFillSvgIcon />\n </BrIcon>\n );\n});\n\nWarningFillIcon.displayName = 'WarningFillIcon';\n\nexport default WarningFillIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWebhook = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 17, height: 17, fill: \"currentColor\", viewBox: \"0 0 17 17\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.001 1.751a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5Zm2.404 3.938a3.25 3.25 0 1 0-4.808 0l-1.6 3.6A3.25 3.25 0 1 0 6.713 13H9.29a3.25 3.25 0 1 0 2.715-3.712l-1.6-3.6Zm-1.261.856 1.47 3.31c-.56.4-.99.976-1.206 1.646H6.595a3.257 3.257 0 0 0-1.208-1.647l1.471-3.31a3.243 3.243 0 0 0 2.286 0ZM3.5 10.75a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5Zm9 0a1.75 1.75 0 1 1 0 3.5 1.75 1.75 0 0 1 0-3.5Z\" }));\nconst ForwardRef = forwardRef(SvgWebhook);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WebhookSvgIcon from '@bloomreach/banana-theme/icons/webhook.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WebhookIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WebhookSvgIcon />\n </BrIcon>\n );\n});\n\nWebhookIcon.displayName = 'WebhookIcon';\n\nexport default WebhookIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWeblayer = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M2.34.78c-.687.09-1.263.57-1.492 1.244l-.082.242v5.715c0 5.44.003 5.724.055 5.908.15.528.5.944.983 1.171.385.18.382.18 2.982.18 1.497.001 2.41-.01 2.48-.029.282-.079.444-.296.468-.628.028-.396-.14-.698-.433-.78-.077-.02-.892-.032-2.433-.032-2.494 0-2.459.002-2.568-.154-.045-.063-.049-.43-.049-4.218V5.251h13.496l.01 1.492c.01 1.374.014 1.503.065 1.62.111.255.32.368.68.368.368 0 .577-.118.68-.384.051-.133.054-.313.054-3.096V2.296l-.07-.225a1.862 1.862 0 0 0-1.19-1.223l-.24-.082L9.121.762C5.483.76 2.431.768 2.341.78Zm13.247 1.507c.15.068.164.146.164.833v.631h-13.5l.001-.638c.001-.68.013-.743.152-.82.101-.056 13.061-.062 13.183-.006Zm-5.533 7.031c-.62.167-1.12.687-1.25 1.3-.064.3-.062 4.964.002 5.268.123.586.597 1.092 1.2 1.283l.21.067h2.79c3.104 0 2.92.011 3.33-.205.23-.122.573-.466.695-.696.215-.406.205-.257.205-3.059 0-2.743.004-2.665-.173-3.045-.12-.258-.5-.643-.764-.776-.372-.188-.29-.183-3.323-.182-2.313.002-2.786.01-2.922.045Zm5.556 1.458c.144.076.14-.004.14 2.48l.001 2.348-.074.073-.073.074h-5.213l-.072-.077-.073-.078-.009-2.255c-.005-1.24 0-2.3.01-2.356a.374.374 0 0 1 .09-.172l.071-.072h2.57c1.894 0 2.584.01 2.632.035Z\" }));\nconst ForwardRef = forwardRef(SvgWeblayer);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WeblayerSvgIcon from '@bloomreach/banana-theme/icons/weblayer.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WeblayerIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WeblayerSvgIcon />\n </BrIcon>\n );\n});\n\nWeblayerIcon.displayName = 'WeblayerIcon';\n\nexport default WeblayerIcon;\n","import * as React from \"react\";\nimport { forwardRef } from \"react\";\nconst SvgWrench = (props, ref) => /* @__PURE__ */ React.createElement(\"svg\", { xmlns: \"http://www.w3.org/2000/svg\", width: 18, height: 18, fill: \"currentColor\", viewBox: \"0 0 18 18\", ref, ...props }, /* @__PURE__ */ React.createElement(\"path\", { d: \"M8.178 2.226a5.381 5.381 0 0 1 6.278-.815.75.75 0 0 1 .171 1.189l-2.4 2.4a.25.25 0 0 0 0 .353l.533.534a.25.25 0 0 0 .354 0l2.367-2.364a.75.75 0 0 1 1.2.194 5.383 5.383 0 0 1-6.63 7.479L4.514 16.73a1.778 1.778 0 0 1-2.517 0l-.727-.727a1.778 1.778 0 0 1 0-2.516L6.81 7.95a5.382 5.382 0 0 1 1.367-5.725Zm4.575.127a3.882 3.882 0 0 0-4.38 5.451.75.75 0 0 1-.146.854l-5.895 5.891a.278.278 0 0 0 0 .394l.727.728a.279.279 0 0 0 .395 0l5.89-5.89a.75.75 0 0 1 .854-.147 3.884 3.884 0 0 0 5.492-4.2l-1.516 1.514a1.75 1.75 0 0 1-2.474 0l-.533-.534a1.75 1.75 0 0 1 0-2.475l1.586-1.586Z\" }));\nconst ForwardRef = forwardRef(SvgWrench);\nexport default ForwardRef;\n","/* This file is autogenerated, see readme.md for instructions */\nimport { forwardRef, Ref, ReactNode } from 'react';\nimport WrenchSvgIcon from '@bloomreach/banana-theme/icons/wrench.svg?react';\nimport BrIcon, { BrIconInstanceProps } from '../icon';\n\nconst WrenchIcon = forwardRef((\n props: BrIconInstanceProps,\n forwardedRef: Ref<SVGSVGElement>,\n): ReactNode => {\n return (\n <BrIcon {...props} ref={forwardedRef}>\n <WrenchSvgIcon />\n </BrIcon>\n );\n});\n\nWrenchIcon.displayName = 'WrenchIcon';\n\nexport default WrenchIcon;\n","import { isShadowRoot, isHTMLElement } from '@floating-ui/utils/dom';\n\nfunction activeElement(doc) {\n let activeElement = doc.activeElement;\n while (((_activeElement = activeElement) == null || (_activeElement = _activeElement.shadowRoot) == null ? void 0 : _activeElement.activeElement) != null) {\n var _activeElement;\n activeElement = activeElement.shadowRoot.activeElement;\n }\n return activeElement;\n}\nfunction contains(parent, child) {\n if (!parent || !child) {\n return false;\n }\n const rootNode = child.getRootNode && child.getRootNode();\n\n // First, attempt with faster native method\n if (parent.contains(child)) {\n return true;\n }\n\n // then fallback to custom implementation with Shadow DOM support\n if (rootNode && isShadowRoot(rootNode)) {\n let next = child;\n while (next) {\n if (parent === next) {\n return true;\n }\n // @ts-ignore\n next = next.parentNode || next.host;\n }\n }\n\n // Give up, the result is false\n return false;\n}\n// Avoid Chrome DevTools blue warning.\nfunction getPlatform() {\n const uaData = navigator.userAgentData;\n if (uaData != null && uaData.platform) {\n return uaData.platform;\n }\n return navigator.platform;\n}\nfunction getUserAgent() {\n const uaData = navigator.userAgentData;\n if (uaData && Array.isArray(uaData.brands)) {\n return uaData.brands.map(_ref => {\n let {\n brand,\n version\n } = _ref;\n return brand + \"/\" + version;\n }).join(' ');\n }\n return navigator.userAgent;\n}\n\n// License: https://github.com/adobe/react-spectrum/blob/b35d5c02fe900badccd0cf1a8f23bb593419f238/packages/@react-aria/utils/src/isVirtualEvent.ts\nfunction isVirtualClick(event) {\n // FIXME: Firefox is now emitting a deprecation warning for `mozInputSource`.\n // Try to find a workaround for this. `react-aria` source still has the check.\n if (event.mozInputSource === 0 && event.isTrusted) {\n return true;\n }\n if (isAndroid() && event.pointerType) {\n return event.type === 'click' && event.buttons === 1;\n }\n return event.detail === 0 && !event.pointerType;\n}\nfunction isVirtualPointerEvent(event) {\n return !isAndroid() && event.width === 0 && event.height === 0 || event.width === 1 && event.height === 1 && event.pressure === 0 && event.detail === 0 && event.pointerType === 'mouse' ||\n // iOS VoiceOver returns 0.333• for width/height.\n event.width < 1 && event.height < 1 && event.pressure === 0 && event.detail === 0;\n}\nfunction isSafari() {\n // Chrome DevTools does not complain about navigator.vendor\n return /apple/i.test(navigator.vendor);\n}\nfunction isAndroid() {\n const re = /android/i;\n return re.test(getPlatform()) || re.test(getUserAgent());\n}\nfunction isMac() {\n return getPlatform().toLowerCase().startsWith('mac') && !navigator.maxTouchPoints;\n}\nfunction isMouseLikePointerType(pointerType, strict) {\n // On some Linux machines with Chromium, mouse inputs return a `pointerType`\n // of \"pen\": https://github.com/floating-ui/floating-ui/issues/2015\n const values = ['mouse', 'pen'];\n if (!strict) {\n values.push('', undefined);\n }\n return values.includes(pointerType);\n}\nfunction isReactEvent(event) {\n return 'nativeEvent' in event;\n}\nfunction isRootElement(element) {\n return element.matches('html,body');\n}\nfunction getDocument(node) {\n return (node == null ? void 0 : node.ownerDocument) || document;\n}\nfunction isEventTargetWithin(event, node) {\n if (node == null) {\n return false;\n }\n if ('composedPath' in event) {\n return event.composedPath().includes(node);\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support composedPath, but browsers without shadow dom don't\n const e = event;\n return e.target != null && node.contains(e.target);\n}\nfunction getTarget(event) {\n if ('composedPath' in event) {\n return event.composedPath()[0];\n }\n\n // TS thinks `event` is of type never as it assumes all browsers support\n // `composedPath()`, but browsers without shadow DOM don't.\n return event.target;\n}\nconst TYPEABLE_SELECTOR = \"input:not([type='hidden']):not([disabled]),\" + \"[contenteditable]:not([contenteditable='false']),textarea:not([disabled])\";\nfunction isTypeableElement(element) {\n return isHTMLElement(element) && element.matches(TYPEABLE_SELECTOR);\n}\nfunction stopEvent(event) {\n event.preventDefault();\n event.stopPropagation();\n}\nfunction isTypeableCombobox(element) {\n if (!element) return false;\n return element.getAttribute('role') === 'combobox' && isTypeableElement(element);\n}\n\nexport { TYPEABLE_SELECTOR, activeElement, contains, getDocument, getPlatform, getTarget, getUserAgent, isAndroid, isEventTargetWithin, isMac, isMouseLikePointerType, isReactEvent, isRootElement, isSafari, isTypeableCombobox, isTypeableElement, isVirtualClick, isVirtualPointerEvent, stopEvent };\n","/*!\n* tabbable 6.2.0\n* @license MIT, https://github.com/focus-trap/tabbable/blob/master/LICENSE\n*/\n// NOTE: separate `:not()` selectors has broader browser support than the newer\n// `:not([inert], [inert] *)` (Feb 2023)\n// CAREFUL: JSDom does not support `:not([inert] *)` as a selector; using it causes\n// the entire query to fail, resulting in no nodes found, which will break a lot\n// of things... so we have to rely on JS to identify nodes inside an inert container\nvar candidateSelectors = ['input:not([inert])', 'select:not([inert])', 'textarea:not([inert])', 'a[href]:not([inert])', 'button:not([inert])', '[tabindex]:not(slot):not([inert])', 'audio[controls]:not([inert])', 'video[controls]:not([inert])', '[contenteditable]:not([contenteditable=\"false\"]):not([inert])', 'details>summary:first-of-type:not([inert])', 'details:not([inert])'];\nvar candidateSelector = /* #__PURE__ */candidateSelectors.join(',');\nvar NoElement = typeof Element === 'undefined';\nvar matches = NoElement ? function () {} : Element.prototype.matches || Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;\nvar getRootNode = !NoElement && Element.prototype.getRootNode ? function (element) {\n var _element$getRootNode;\n return element === null || element === void 0 ? void 0 : (_element$getRootNode = element.getRootNode) === null || _element$getRootNode === void 0 ? void 0 : _element$getRootNode.call(element);\n} : function (element) {\n return element === null || element === void 0 ? void 0 : element.ownerDocument;\n};\n\n/**\n * Determines if a node is inert or in an inert ancestor.\n * @param {Element} [node]\n * @param {boolean} [lookUp] If true and `node` is not inert, looks up at ancestors to\n * see if any of them are inert. If false, only `node` itself is considered.\n * @returns {boolean} True if inert itself or by way of being in an inert ancestor.\n * False if `node` is falsy.\n */\nvar isInert = function isInert(node, lookUp) {\n var _node$getAttribute;\n if (lookUp === void 0) {\n lookUp = true;\n }\n // CAREFUL: JSDom does not support inert at all, so we can't use the `HTMLElement.inert`\n // JS API property; we have to check the attribute, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's an active element\n var inertAtt = node === null || node === void 0 ? void 0 : (_node$getAttribute = node.getAttribute) === null || _node$getAttribute === void 0 ? void 0 : _node$getAttribute.call(node, 'inert');\n var inert = inertAtt === '' || inertAtt === 'true';\n\n // NOTE: this could also be handled with `node.matches('[inert], :is([inert] *)')`\n // if it weren't for `matches()` not being a function on shadow roots; the following\n // code works for any kind of node\n // CAREFUL: JSDom does not appear to support certain selectors like `:not([inert] *)`\n // so it likely would not support `:is([inert] *)` either...\n var result = inert || lookUp && node && isInert(node.parentNode); // recursive\n\n return result;\n};\n\n/**\n * Determines if a node's content is editable.\n * @param {Element} [node]\n * @returns True if it's content-editable; false if it's not or `node` is falsy.\n */\nvar isContentEditable = function isContentEditable(node) {\n var _node$getAttribute2;\n // CAREFUL: JSDom does not support the `HTMLElement.isContentEditable` API so we have\n // to use the attribute directly to check for this, which can either be empty or 'true';\n // if it's `null` (not specified) or 'false', it's a non-editable element\n var attValue = node === null || node === void 0 ? void 0 : (_node$getAttribute2 = node.getAttribute) === null || _node$getAttribute2 === void 0 ? void 0 : _node$getAttribute2.call(node, 'contenteditable');\n return attValue === '' || attValue === 'true';\n};\n\n/**\n * @param {Element} el container to check in\n * @param {boolean} includeContainer add container to check\n * @param {(node: Element) => boolean} filter filter candidates\n * @returns {Element[]}\n */\nvar getCandidates = function getCandidates(el, includeContainer, filter) {\n // even if `includeContainer=false`, we still have to check it for inertness because\n // if it's inert, all its children are inert\n if (isInert(el)) {\n return [];\n }\n var candidates = Array.prototype.slice.apply(el.querySelectorAll(candidateSelector));\n if (includeContainer && matches.call(el, candidateSelector)) {\n candidates.unshift(el);\n }\n candidates = candidates.filter(filter);\n return candidates;\n};\n\n/**\n * @callback GetShadowRoot\n * @param {Element} element to check for shadow root\n * @returns {ShadowRoot|boolean} ShadowRoot if available or boolean indicating if a shadowRoot is attached but not available.\n */\n\n/**\n * @callback ShadowRootFilter\n * @param {Element} shadowHostNode the element which contains shadow content\n * @returns {boolean} true if a shadow root could potentially contain valid candidates.\n */\n\n/**\n * @typedef {Object} CandidateScope\n * @property {Element} scopeParent contains inner candidates\n * @property {Element[]} candidates list of candidates found in the scope parent\n */\n\n/**\n * @typedef {Object} IterativeOptions\n * @property {GetShadowRoot|boolean} getShadowRoot true if shadow support is enabled; falsy if not;\n * if a function, implies shadow support is enabled and either returns the shadow root of an element\n * or a boolean stating if it has an undisclosed shadow root\n * @property {(node: Element) => boolean} filter filter candidates\n * @property {boolean} flatten if true then result will flatten any CandidateScope into the returned list\n * @property {ShadowRootFilter} shadowRootFilter filter shadow roots;\n */\n\n/**\n * @param {Element[]} elements list of element containers to match candidates from\n * @param {boolean} includeContainer add container list to check\n * @param {IterativeOptions} options\n * @returns {Array.<Element|CandidateScope>}\n */\nvar getCandidatesIteratively = function getCandidatesIteratively(elements, includeContainer, options) {\n var candidates = [];\n var elementsToCheck = Array.from(elements);\n while (elementsToCheck.length) {\n var element = elementsToCheck.shift();\n if (isInert(element, false)) {\n // no need to look up since we're drilling down\n // anything inside this container will also be inert\n continue;\n }\n if (element.tagName === 'SLOT') {\n // add shadow dom slot scope (slot itself cannot be focusable)\n var assigned = element.assignedElements();\n var content = assigned.length ? assigned : element.children;\n var nestedCandidates = getCandidatesIteratively(content, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: nestedCandidates\n });\n }\n } else {\n // check candidate element\n var validCandidate = matches.call(element, candidateSelector);\n if (validCandidate && options.filter(element) && (includeContainer || !elements.includes(element))) {\n candidates.push(element);\n }\n\n // iterate over shadow content if possible\n var shadowRoot = element.shadowRoot ||\n // check for an undisclosed shadow\n typeof options.getShadowRoot === 'function' && options.getShadowRoot(element);\n\n // no inert look up because we're already drilling down and checking for inertness\n // on the way down, so all containers to this root node should have already been\n // vetted as non-inert\n var validShadowRoot = !isInert(shadowRoot, false) && (!options.shadowRootFilter || options.shadowRootFilter(element));\n if (shadowRoot && validShadowRoot) {\n // add shadow dom scope IIF a shadow root node was given; otherwise, an undisclosed\n // shadow exists, so look at light dom children as fallback BUT create a scope for any\n // child candidates found because they're likely slotted elements (elements that are\n // children of the web component element (which has the shadow), in the light dom, but\n // slotted somewhere _inside_ the undisclosed shadow) -- the scope is created below,\n // _after_ we return from this recursive call\n var _nestedCandidates = getCandidatesIteratively(shadowRoot === true ? element.children : shadowRoot.children, true, options);\n if (options.flatten) {\n candidates.push.apply(candidates, _nestedCandidates);\n } else {\n candidates.push({\n scopeParent: element,\n candidates: _nestedCandidates\n });\n }\n } else {\n // there's not shadow so just dig into the element's (light dom) children\n // __without__ giving the element special scope treatment\n elementsToCheck.unshift.apply(elementsToCheck, element.children);\n }\n }\n }\n return candidates;\n};\n\n/**\n * @private\n * Determines if the node has an explicitly specified `tabindex` attribute.\n * @param {HTMLElement} node\n * @returns {boolean} True if so; false if not.\n */\nvar hasTabIndex = function hasTabIndex(node) {\n return !isNaN(parseInt(node.getAttribute('tabindex'), 10));\n};\n\n/**\n * Determine the tab index of a given node.\n * @param {HTMLElement} node\n * @returns {number} Tab order (negative, 0, or positive number).\n * @throws {Error} If `node` is falsy.\n */\nvar getTabIndex = function getTabIndex(node) {\n if (!node) {\n throw new Error('No node provided');\n }\n if (node.tabIndex < 0) {\n // in Chrome, <details/>, <audio controls/> and <video controls/> elements get a default\n // `tabIndex` of -1 when the 'tabindex' attribute isn't specified in the DOM,\n // yet they are still part of the regular tab order; in FF, they get a default\n // `tabIndex` of 0; since Chrome still puts those elements in the regular tab\n // order, consider their tab index to be 0.\n // Also browsers do not return `tabIndex` correctly for contentEditable nodes;\n // so if they don't have a tabindex attribute specifically set, assume it's 0.\n if ((/^(AUDIO|VIDEO|DETAILS)$/.test(node.tagName) || isContentEditable(node)) && !hasTabIndex(node)) {\n return 0;\n }\n }\n return node.tabIndex;\n};\n\n/**\n * Determine the tab index of a given node __for sort order purposes__.\n * @param {HTMLElement} node\n * @param {boolean} [isScope] True for a custom element with shadow root or slot that, by default,\n * has tabIndex -1, but needs to be sorted by document order in order for its content to be\n * inserted into the correct sort position.\n * @returns {number} Tab order (negative, 0, or positive number).\n */\nvar getSortOrderTabIndex = function getSortOrderTabIndex(node, isScope) {\n var tabIndex = getTabIndex(node);\n if (tabIndex < 0 && isScope && !hasTabIndex(node)) {\n return 0;\n }\n return tabIndex;\n};\nvar sortOrderedTabbables = function sortOrderedTabbables(a, b) {\n return a.tabIndex === b.tabIndex ? a.documentOrder - b.documentOrder : a.tabIndex - b.tabIndex;\n};\nvar isInput = function isInput(node) {\n return node.tagName === 'INPUT';\n};\nvar isHiddenInput = function isHiddenInput(node) {\n return isInput(node) && node.type === 'hidden';\n};\nvar isDetailsWithSummary = function isDetailsWithSummary(node) {\n var r = node.tagName === 'DETAILS' && Array.prototype.slice.apply(node.children).some(function (child) {\n return child.tagName === 'SUMMARY';\n });\n return r;\n};\nvar getCheckedRadio = function getCheckedRadio(nodes, form) {\n for (var i = 0; i < nodes.length; i++) {\n if (nodes[i].checked && nodes[i].form === form) {\n return nodes[i];\n }\n }\n};\nvar isTabbableRadio = function isTabbableRadio(node) {\n if (!node.name) {\n return true;\n }\n var radioScope = node.form || getRootNode(node);\n var queryRadios = function queryRadios(name) {\n return radioScope.querySelectorAll('input[type=\"radio\"][name=\"' + name + '\"]');\n };\n var radioSet;\n if (typeof window !== 'undefined' && typeof window.CSS !== 'undefined' && typeof window.CSS.escape === 'function') {\n radioSet = queryRadios(window.CSS.escape(node.name));\n } else {\n try {\n radioSet = queryRadios(node.name);\n } catch (err) {\n // eslint-disable-next-line no-console\n console.error('Looks like you have a radio button with a name attribute containing invalid CSS selector characters and need the CSS.escape polyfill: %s', err.message);\n return false;\n }\n }\n var checked = getCheckedRadio(radioSet, node.form);\n return !checked || checked === node;\n};\nvar isRadio = function isRadio(node) {\n return isInput(node) && node.type === 'radio';\n};\nvar isNonTabbableRadio = function isNonTabbableRadio(node) {\n return isRadio(node) && !isTabbableRadio(node);\n};\n\n// determines if a node is ultimately attached to the window's document\nvar isNodeAttached = function isNodeAttached(node) {\n var _nodeRoot;\n // The root node is the shadow root if the node is in a shadow DOM; some document otherwise\n // (but NOT _the_ document; see second 'If' comment below for more).\n // If rootNode is shadow root, it'll have a host, which is the element to which the shadow\n // is attached, and the one we need to check if it's in the document or not (because the\n // shadow, and all nodes it contains, is never considered in the document since shadows\n // behave like self-contained DOMs; but if the shadow's HOST, which is part of the document,\n // is hidden, or is not in the document itself but is detached, it will affect the shadow's\n // visibility, including all the nodes it contains). The host could be any normal node,\n // or a custom element (i.e. web component). Either way, that's the one that is considered\n // part of the document, not the shadow root, nor any of its children (i.e. the node being\n // tested).\n // To further complicate things, we have to look all the way up until we find a shadow HOST\n // that is attached (or find none) because the node might be in nested shadows...\n // If rootNode is not a shadow root, it won't have a host, and so rootNode should be the\n // document (per the docs) and while it's a Document-type object, that document does not\n // appear to be the same as the node's `ownerDocument` for some reason, so it's safer\n // to ignore the rootNode at this point, and use `node.ownerDocument`. Otherwise,\n // using `rootNode.contains(node)` will _always_ be true we'll get false-positives when\n // node is actually detached.\n // NOTE: If `nodeRootHost` or `node` happens to be the `document` itself (which is possible\n // if a tabbable/focusable node was quickly added to the DOM, focused, and then removed\n // from the DOM as in https://github.com/focus-trap/focus-trap-react/issues/905), then\n // `ownerDocument` will be `null`, hence the optional chaining on it.\n var nodeRoot = node && getRootNode(node);\n var nodeRootHost = (_nodeRoot = nodeRoot) === null || _nodeRoot === void 0 ? void 0 : _nodeRoot.host;\n\n // in some cases, a detached node will return itself as the root instead of a document or\n // shadow root object, in which case, we shouldn't try to look further up the host chain\n var attached = false;\n if (nodeRoot && nodeRoot !== node) {\n var _nodeRootHost, _nodeRootHost$ownerDo, _node$ownerDocument;\n attached = !!((_nodeRootHost = nodeRootHost) !== null && _nodeRootHost !== void 0 && (_nodeRootHost$ownerDo = _nodeRootHost.ownerDocument) !== null && _nodeRootHost$ownerDo !== void 0 && _nodeRootHost$ownerDo.contains(nodeRootHost) || node !== null && node !== void 0 && (_node$ownerDocument = node.ownerDocument) !== null && _node$ownerDocument !== void 0 && _node$ownerDocument.contains(node));\n while (!attached && nodeRootHost) {\n var _nodeRoot2, _nodeRootHost2, _nodeRootHost2$ownerD;\n // since it's not attached and we have a root host, the node MUST be in a nested shadow DOM,\n // which means we need to get the host's host and check if that parent host is contained\n // in (i.e. attached to) the document\n nodeRoot = getRootNode(nodeRootHost);\n nodeRootHost = (_nodeRoot2 = nodeRoot) === null || _nodeRoot2 === void 0 ? void 0 : _nodeRoot2.host;\n attached = !!((_nodeRootHost2 = nodeRootHost) !== null && _nodeRootHost2 !== void 0 && (_nodeRootHost2$ownerD = _nodeRootHost2.ownerDocument) !== null && _nodeRootHost2$ownerD !== void 0 && _nodeRootHost2$ownerD.contains(nodeRootHost));\n }\n }\n return attached;\n};\nvar isZeroArea = function isZeroArea(node) {\n var _node$getBoundingClie = node.getBoundingClientRect(),\n width = _node$getBoundingClie.width,\n height = _node$getBoundingClie.height;\n return width === 0 && height === 0;\n};\nvar isHidden = function isHidden(node, _ref) {\n var displayCheck = _ref.displayCheck,\n getShadowRoot = _ref.getShadowRoot;\n // NOTE: visibility will be `undefined` if node is detached from the document\n // (see notes about this further down), which means we will consider it visible\n // (this is legacy behavior from a very long way back)\n // NOTE: we check this regardless of `displayCheck=\"none\"` because this is a\n // _visibility_ check, not a _display_ check\n if (getComputedStyle(node).visibility === 'hidden') {\n return true;\n }\n var isDirectSummary = matches.call(node, 'details>summary:first-of-type');\n var nodeUnderDetails = isDirectSummary ? node.parentElement : node;\n if (matches.call(nodeUnderDetails, 'details:not([open]) *')) {\n return true;\n }\n if (!displayCheck || displayCheck === 'full' || displayCheck === 'legacy-full') {\n if (typeof getShadowRoot === 'function') {\n // figure out if we should consider the node to be in an undisclosed shadow and use the\n // 'non-zero-area' fallback\n var originalNode = node;\n while (node) {\n var parentElement = node.parentElement;\n var rootNode = getRootNode(node);\n if (parentElement && !parentElement.shadowRoot && getShadowRoot(parentElement) === true // check if there's an undisclosed shadow\n ) {\n // node has an undisclosed shadow which means we can only treat it as a black box, so we\n // fall back to a non-zero-area test\n return isZeroArea(node);\n } else if (node.assignedSlot) {\n // iterate up slot\n node = node.assignedSlot;\n } else if (!parentElement && rootNode !== node.ownerDocument) {\n // cross shadow boundary\n node = rootNode.host;\n } else {\n // iterate up normal dom\n node = parentElement;\n }\n }\n node = originalNode;\n }\n // else, `getShadowRoot` might be true, but all that does is enable shadow DOM support\n // (i.e. it does not also presume that all nodes might have undisclosed shadows); or\n // it might be a falsy value, which means shadow DOM support is disabled\n\n // Since we didn't find it sitting in an undisclosed shadow (or shadows are disabled)\n // now we can just test to see if it would normally be visible or not, provided it's\n // attached to the main document.\n // NOTE: We must consider case where node is inside a shadow DOM and given directly to\n // `isTabbable()` or `isFocusable()` -- regardless of `getShadowRoot` option setting.\n\n if (isNodeAttached(node)) {\n // this works wherever the node is: if there's at least one client rect, it's\n // somehow displayed; it also covers the CSS 'display: contents' case where the\n // node itself is hidden in place of its contents; and there's no need to search\n // up the hierarchy either\n return !node.getClientRects().length;\n }\n\n // Else, the node isn't attached to the document, which means the `getClientRects()`\n // API will __always__ return zero rects (this can happen, for example, if React\n // is used to render nodes onto a detached tree, as confirmed in this thread:\n // https://github.com/facebook/react/issues/9117#issuecomment-284228870)\n //\n // It also means that even window.getComputedStyle(node).display will return `undefined`\n // because styles are only computed for nodes that are in the document.\n //\n // NOTE: THIS HAS BEEN THE CASE FOR YEARS. It is not new, nor is it caused by tabbable\n // somehow. Though it was never stated officially, anyone who has ever used tabbable\n // APIs on nodes in detached containers has actually implicitly used tabbable in what\n // was later (as of v5.2.0 on Apr 9, 2021) called `displayCheck=\"none\"` mode -- essentially\n // considering __everything__ to be visible because of the innability to determine styles.\n //\n // v6.0.0: As of this major release, the default 'full' option __no longer treats detached\n // nodes as visible with the 'none' fallback.__\n if (displayCheck !== 'legacy-full') {\n return true; // hidden\n }\n // else, fallback to 'none' mode and consider the node visible\n } else if (displayCheck === 'non-zero-area') {\n // NOTE: Even though this tests that the node's client rect is non-zero to determine\n // whether it's displayed, and that a detached node will __always__ have a zero-area\n // client rect, we don't special-case for whether the node is attached or not. In\n // this mode, we do want to consider nodes that have a zero area to be hidden at all\n // times, and that includes attached or not.\n return isZeroArea(node);\n }\n\n // visible, as far as we can tell, or per current `displayCheck=none` mode, we assume\n // it's visible\n return false;\n};\n\n// form fields (nested) inside a disabled fieldset are not focusable/tabbable\n// unless they are in the _first_ <legend> element of the top-most disabled\n// fieldset\nvar isDisabledFromFieldset = function isDisabledFromFieldset(node) {\n if (/^(INPUT|BUTTON|SELECT|TEXTAREA)$/.test(node.tagName)) {\n var parentNode = node.parentElement;\n // check if `node` is contained in a disabled <fieldset>\n while (parentNode) {\n if (parentNode.tagName === 'FIELDSET' && parentNode.disabled) {\n // look for the first <legend> among the children of the disabled <fieldset>\n for (var i = 0; i < parentNode.children.length; i++) {\n var child = parentNode.children.item(i);\n // when the first <legend> (in document order) is found\n if (child.tagName === 'LEGEND') {\n // if its parent <fieldset> is not nested in another disabled <fieldset>,\n // return whether `node` is a descendant of its first <legend>\n return matches.call(parentNode, 'fieldset[disabled] *') ? true : !child.contains(node);\n }\n }\n // the disabled <fieldset> containing `node` has no <legend>\n return true;\n }\n parentNode = parentNode.parentElement;\n }\n }\n\n // else, node's tabbable/focusable state should not be affected by a fieldset's\n // enabled/disabled state\n return false;\n};\nvar isNodeMatchingSelectorFocusable = function isNodeMatchingSelectorFocusable(options, node) {\n if (node.disabled ||\n // we must do an inert look up to filter out any elements inside an inert ancestor\n // because we're limited in the type of selectors we can use in JSDom (see related\n // note related to `candidateSelectors`)\n isInert(node) || isHiddenInput(node) || isHidden(node, options) ||\n // For a details element with a summary, the summary element gets the focus\n isDetailsWithSummary(node) || isDisabledFromFieldset(node)) {\n return false;\n }\n return true;\n};\nvar isNodeMatchingSelectorTabbable = function isNodeMatchingSelectorTabbable(options, node) {\n if (isNonTabbableRadio(node) || getTabIndex(node) < 0 || !isNodeMatchingSelectorFocusable(options, node)) {\n return false;\n }\n return true;\n};\nvar isValidShadowRootTabbable = function isValidShadowRootTabbable(shadowHostNode) {\n var tabIndex = parseInt(shadowHostNode.getAttribute('tabindex'), 10);\n if (isNaN(tabIndex) || tabIndex >= 0) {\n return true;\n }\n // If a custom element has an explicit negative tabindex,\n // browsers will not allow tab targeting said element's children.\n return false;\n};\n\n/**\n * @param {Array.<Element|CandidateScope>} candidates\n * @returns Element[]\n */\nvar sortByOrder = function sortByOrder(candidates) {\n var regularTabbables = [];\n var orderedTabbables = [];\n candidates.forEach(function (item, i) {\n var isScope = !!item.scopeParent;\n var element = isScope ? item.scopeParent : item;\n var candidateTabindex = getSortOrderTabIndex(element, isScope);\n var elements = isScope ? sortByOrder(item.candidates) : element;\n if (candidateTabindex === 0) {\n isScope ? regularTabbables.push.apply(regularTabbables, elements) : regularTabbables.push(element);\n } else {\n orderedTabbables.push({\n documentOrder: i,\n tabIndex: candidateTabindex,\n item: item,\n isScope: isScope,\n content: elements\n });\n }\n });\n return orderedTabbables.sort(sortOrderedTabbables).reduce(function (acc, sortable) {\n sortable.isScope ? acc.push.apply(acc, sortable.content) : acc.push(sortable.content);\n return acc;\n }, []).concat(regularTabbables);\n};\nvar tabbable = function tabbable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorTabbable.bind(null, options),\n flatten: false,\n getShadowRoot: options.getShadowRoot,\n shadowRootFilter: isValidShadowRootTabbable\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorTabbable.bind(null, options));\n }\n return sortByOrder(candidates);\n};\nvar focusable = function focusable(container, options) {\n options = options || {};\n var candidates;\n if (options.getShadowRoot) {\n candidates = getCandidatesIteratively([container], options.includeContainer, {\n filter: isNodeMatchingSelectorFocusable.bind(null, options),\n flatten: true,\n getShadowRoot: options.getShadowRoot\n });\n } else {\n candidates = getCandidates(container, options.includeContainer, isNodeMatchingSelectorFocusable.bind(null, options));\n }\n return candidates;\n};\nvar isTabbable = function isTabbable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, candidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorTabbable(options, node);\n};\nvar focusableCandidateSelector = /* #__PURE__ */candidateSelectors.concat('iframe').join(',');\nvar isFocusable = function isFocusable(node, options) {\n options = options || {};\n if (!node) {\n throw new Error('No node provided');\n }\n if (matches.call(node, focusableCandidateSelector) === false) {\n return false;\n }\n return isNodeMatchingSelectorFocusable(options, node);\n};\n\nexport { focusable, getTabIndex, isFocusable, isTabbable, tabbable };\n//# sourceMappingURL=index.esm.js.map\n","import * as React from 'react';\nimport { useLayoutEffect, useEffect, useRef } from 'react';\nimport { stopEvent, getDocument, isMouseLikePointerType, contains, activeElement, isSafari, isTypeableCombobox, isVirtualClick, isVirtualPointerEvent, getTarget, getPlatform, isTypeableElement, isReactEvent, isRootElement, isEventTargetWithin, isMac, getUserAgent } from '@floating-ui/react/utils';\nimport { floor } from '@floating-ui/utils';\nimport { platform, getOverflowAncestors, useFloating as useFloating$1, offset, detectOverflow } from '@floating-ui/react-dom';\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/react-dom';\nimport { isElement, isHTMLElement, getNodeName, getWindow, isLastTraversableNode, getParentNode, getComputedStyle } from '@floating-ui/utils/dom';\nimport { tabbable } from 'tabbable';\nimport { createPortal, flushSync } from 'react-dom';\n\n/**\n * Merges an array of refs into a single memoized callback ref or `null`.\n * @see https://floating-ui.com/docs/useMergeRefs\n */\nfunction useMergeRefs(refs) {\n return React.useMemo(() => {\n if (refs.every(ref => ref == null)) {\n return null;\n }\n return value => {\n refs.forEach(ref => {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref != null) {\n ref.current = value;\n }\n });\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}\n\n// `toString()` prevents bundlers from trying to `import { useInsertionEffect } from 'react'`\nconst useInsertionEffect = React[/*#__PURE__*/'useInsertionEffect'.toString()];\nconst useSafeInsertionEffect = useInsertionEffect || (fn => fn());\nfunction useEffectEvent(callback) {\n const ref = React.useRef(() => {\n if (process.env.NODE_ENV !== \"production\") {\n throw new Error('Cannot call an event handler while rendering.');\n }\n });\n useSafeInsertionEffect(() => {\n ref.current = callback;\n });\n return React.useCallback(function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return ref.current == null ? void 0 : ref.current(...args);\n }, []);\n}\n\nconst ARROW_UP = 'ArrowUp';\nconst ARROW_DOWN = 'ArrowDown';\nconst ARROW_LEFT = 'ArrowLeft';\nconst ARROW_RIGHT = 'ArrowRight';\nfunction isDifferentRow(index, cols, prevRow) {\n return Math.floor(index / cols) !== prevRow;\n}\nfunction isIndexOutOfBounds(listRef, index) {\n return index < 0 || index >= listRef.current.length;\n}\nfunction getMinIndex(listRef, disabledIndices) {\n return findNonDisabledIndex(listRef, {\n disabledIndices\n });\n}\nfunction getMaxIndex(listRef, disabledIndices) {\n return findNonDisabledIndex(listRef, {\n decrement: true,\n startingIndex: listRef.current.length,\n disabledIndices\n });\n}\nfunction findNonDisabledIndex(listRef, _temp) {\n let {\n startingIndex = -1,\n decrement = false,\n disabledIndices,\n amount = 1\n } = _temp === void 0 ? {} : _temp;\n const list = listRef.current;\n const isDisabledIndex = disabledIndices ? index => disabledIndices.includes(index) : index => {\n const element = list[index];\n return element == null || element.hasAttribute('disabled') || element.getAttribute('aria-disabled') === 'true';\n };\n let index = startingIndex;\n do {\n index += decrement ? -amount : amount;\n } while (index >= 0 && index <= list.length - 1 && isDisabledIndex(index));\n return index;\n}\nfunction getGridNavigatedIndex(elementsRef, _ref) {\n let {\n event,\n orientation,\n loop,\n cols,\n disabledIndices,\n minIndex,\n maxIndex,\n prevIndex,\n stopEvent: stop = false\n } = _ref;\n let nextIndex = prevIndex;\n if (event.key === ARROW_UP) {\n stop && stopEvent(event);\n if (prevIndex === -1) {\n nextIndex = maxIndex;\n } else {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: nextIndex,\n amount: cols,\n decrement: true,\n disabledIndices\n });\n if (loop && (prevIndex - cols < minIndex || nextIndex < 0)) {\n const col = prevIndex % cols;\n const maxCol = maxIndex % cols;\n const offset = maxIndex - (maxCol - col);\n if (maxCol === col) {\n nextIndex = maxIndex;\n } else {\n nextIndex = maxCol > col ? offset : offset - cols;\n }\n }\n }\n if (isIndexOutOfBounds(elementsRef, nextIndex)) {\n nextIndex = prevIndex;\n }\n }\n if (event.key === ARROW_DOWN) {\n stop && stopEvent(event);\n if (prevIndex === -1) {\n nextIndex = minIndex;\n } else {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex,\n amount: cols,\n disabledIndices\n });\n if (loop && prevIndex + cols > maxIndex) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex % cols - cols,\n amount: cols,\n disabledIndices\n });\n }\n }\n if (isIndexOutOfBounds(elementsRef, nextIndex)) {\n nextIndex = prevIndex;\n }\n }\n\n // Remains on the same row/column.\n if (orientation === 'both') {\n const prevRow = floor(prevIndex / cols);\n if (event.key === ARROW_RIGHT) {\n stop && stopEvent(event);\n if (prevIndex % cols !== cols - 1) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex,\n disabledIndices\n });\n if (loop && isDifferentRow(nextIndex, cols, prevRow)) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n }\n } else if (loop) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n }\n if (isDifferentRow(nextIndex, cols, prevRow)) {\n nextIndex = prevIndex;\n }\n }\n if (event.key === ARROW_LEFT) {\n stop && stopEvent(event);\n if (prevIndex % cols !== 0) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex,\n disabledIndices,\n decrement: true\n });\n if (loop && isDifferentRow(nextIndex, cols, prevRow)) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex + (cols - prevIndex % cols),\n decrement: true,\n disabledIndices\n });\n }\n } else if (loop) {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex + (cols - prevIndex % cols),\n decrement: true,\n disabledIndices\n });\n }\n if (isDifferentRow(nextIndex, cols, prevRow)) {\n nextIndex = prevIndex;\n }\n }\n const lastRow = floor(maxIndex / cols) === prevRow;\n if (isIndexOutOfBounds(elementsRef, nextIndex)) {\n if (loop && lastRow) {\n nextIndex = event.key === ARROW_LEFT ? maxIndex : findNonDisabledIndex(elementsRef, {\n startingIndex: prevIndex - prevIndex % cols - 1,\n disabledIndices\n });\n } else {\n nextIndex = prevIndex;\n }\n }\n }\n return nextIndex;\n}\n\nlet rafId = 0;\nfunction enqueueFocus(el, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n preventScroll = false,\n cancelPrevious = true,\n sync = false\n } = options;\n cancelPrevious && cancelAnimationFrame(rafId);\n const exec = () => el == null ? void 0 : el.focus({\n preventScroll\n });\n if (sync) {\n exec();\n } else {\n rafId = requestAnimationFrame(exec);\n }\n}\n\nvar index = typeof document !== 'undefined' ? useLayoutEffect : useEffect;\n\nfunction sortByDocumentPosition(a, b) {\n const position = a.compareDocumentPosition(b);\n if (position & Node.DOCUMENT_POSITION_FOLLOWING || position & Node.DOCUMENT_POSITION_CONTAINED_BY) {\n return -1;\n }\n if (position & Node.DOCUMENT_POSITION_PRECEDING || position & Node.DOCUMENT_POSITION_CONTAINS) {\n return 1;\n }\n return 0;\n}\nfunction areMapsEqual(map1, map2) {\n if (map1.size !== map2.size) {\n return false;\n }\n for (const [key, value] of map1.entries()) {\n if (value !== map2.get(key)) {\n return false;\n }\n }\n return true;\n}\nconst FloatingListContext = /*#__PURE__*/React.createContext({\n register: () => {},\n unregister: () => {},\n map: /*#__PURE__*/new Map(),\n elementsRef: {\n current: []\n }\n});\n/**\n * Provides context for a list of items within the floating element.\n * @see https://floating-ui.com/docs/FloatingList\n */\nfunction FloatingList(_ref) {\n let {\n children,\n elementsRef,\n labelsRef\n } = _ref;\n const [map, setMap] = React.useState(() => new Map());\n const register = React.useCallback(node => {\n setMap(prevMap => new Map(prevMap).set(node, null));\n }, []);\n const unregister = React.useCallback(node => {\n setMap(prevMap => {\n const map = new Map(prevMap);\n map.delete(node);\n return map;\n });\n }, []);\n index(() => {\n const newMap = new Map(map);\n const nodes = Array.from(newMap.keys()).sort(sortByDocumentPosition);\n nodes.forEach((node, index) => {\n newMap.set(node, index);\n });\n if (!areMapsEqual(map, newMap)) {\n setMap(newMap);\n }\n }, [map]);\n return /*#__PURE__*/React.createElement(FloatingListContext.Provider, {\n value: React.useMemo(() => ({\n register,\n unregister,\n map,\n elementsRef,\n labelsRef\n }), [register, unregister, map, elementsRef, labelsRef])\n }, children);\n}\nfunction useListItem(_temp) {\n let {\n label\n } = _temp === void 0 ? {} : _temp;\n const [index$1, setIndex] = React.useState(null);\n const componentRef = React.useRef(null);\n const {\n register,\n unregister,\n map,\n elementsRef,\n labelsRef\n } = React.useContext(FloatingListContext);\n const ref = React.useCallback(node => {\n componentRef.current = node;\n if (index$1 !== null) {\n elementsRef.current[index$1] = node;\n if (labelsRef) {\n var _node$textContent;\n const isLabelDefined = label !== undefined;\n labelsRef.current[index$1] = isLabelDefined ? label : (_node$textContent = node == null ? void 0 : node.textContent) != null ? _node$textContent : null;\n }\n }\n }, [index$1, elementsRef, labelsRef, label]);\n index(() => {\n const node = componentRef.current;\n if (node) {\n register(node);\n return () => {\n unregister(node);\n };\n }\n }, [register, unregister]);\n index(() => {\n const index = componentRef.current ? map.get(componentRef.current) : null;\n if (index != null) {\n setIndex(index);\n }\n }, [map]);\n return React.useMemo(() => ({\n ref,\n index: index$1 == null ? -1 : index$1\n }), [index$1, ref]);\n}\n\nfunction renderJsx(render, computedProps) {\n if (typeof render === 'function') {\n return render(computedProps);\n } else if (render) {\n return /*#__PURE__*/React.cloneElement(render, computedProps);\n }\n return /*#__PURE__*/React.createElement(\"div\", computedProps);\n}\nconst CompositeContext = /*#__PURE__*/React.createContext({\n activeIndex: 0,\n onNavigate: () => {}\n});\nconst horizontalKeys = [ARROW_LEFT, ARROW_RIGHT];\nconst verticalKeys = [ARROW_UP, ARROW_DOWN];\nconst allKeys = [...horizontalKeys, ...verticalKeys];\nconst Composite = /*#__PURE__*/React.forwardRef(function Composite(_ref, forwardedRef) {\n let {\n render,\n orientation = 'both',\n loop = true,\n cols = 1,\n disabledIndices,\n activeIndex: externalActiveIndex,\n onNavigate: externalSetActiveIndex,\n ...props\n } = _ref;\n const [internalActiveIndex, internalSetActiveIndex] = React.useState(0);\n const activeIndex = externalActiveIndex != null ? externalActiveIndex : internalActiveIndex;\n const onNavigate = useEffectEvent(externalSetActiveIndex != null ? externalSetActiveIndex : internalSetActiveIndex);\n const elementsRef = React.useRef([]);\n const renderElementProps = render && typeof render !== 'function' ? render.props : {};\n const contextValue = React.useMemo(() => ({\n activeIndex,\n onNavigate\n }), [activeIndex, onNavigate]);\n const isGrid = cols > 1;\n function handleKeyDown(event) {\n if (!allKeys.includes(event.key)) return;\n const minIndex = getMinIndex(elementsRef, disabledIndices);\n const maxIndex = getMaxIndex(elementsRef, disabledIndices);\n const prevIndex = activeIndex;\n let nextIndex = activeIndex;\n if (isGrid) {\n nextIndex = getGridNavigatedIndex(elementsRef, {\n event,\n orientation,\n loop,\n cols,\n disabledIndices,\n minIndex,\n maxIndex,\n prevIndex\n });\n }\n const toEndKeys = {\n horizontal: [ARROW_RIGHT],\n vertical: [ARROW_DOWN],\n both: [ARROW_RIGHT, ARROW_DOWN]\n }[orientation];\n const toStartKeys = {\n horizontal: [ARROW_LEFT],\n vertical: [ARROW_UP],\n both: [ARROW_LEFT, ARROW_UP]\n }[orientation];\n const preventedKeys = isGrid ? allKeys : {\n horizontal: horizontalKeys,\n vertical: verticalKeys,\n both: allKeys\n }[orientation];\n if (nextIndex === activeIndex && [...toEndKeys, ...toStartKeys].includes(event.key)) {\n if (loop && nextIndex === maxIndex && toEndKeys.includes(event.key)) {\n nextIndex = minIndex;\n } else if (loop && nextIndex === minIndex && toStartKeys.includes(event.key)) {\n nextIndex = maxIndex;\n } else {\n nextIndex = findNonDisabledIndex(elementsRef, {\n startingIndex: nextIndex,\n decrement: toStartKeys.includes(event.key),\n disabledIndices\n });\n }\n }\n if (nextIndex !== activeIndex && !isIndexOutOfBounds(elementsRef, nextIndex)) {\n event.stopPropagation();\n if (preventedKeys.includes(event.key)) {\n event.preventDefault();\n }\n onNavigate(nextIndex);\n\n // Wait for FocusManager `returnFocus` to execute.\n queueMicrotask(() => {\n enqueueFocus(elementsRef.current[nextIndex]);\n });\n }\n }\n const computedProps = {\n ...props,\n ...renderElementProps,\n ref: forwardedRef,\n 'aria-orientation': orientation === 'both' ? undefined : orientation,\n onKeyDown(e) {\n props.onKeyDown == null || props.onKeyDown(e);\n renderElementProps.onKeyDown == null || renderElementProps.onKeyDown(e);\n handleKeyDown(e);\n }\n };\n return /*#__PURE__*/React.createElement(CompositeContext.Provider, {\n value: contextValue\n }, /*#__PURE__*/React.createElement(FloatingList, {\n elementsRef: elementsRef\n }, renderJsx(render, computedProps)));\n});\nconst CompositeItem = /*#__PURE__*/React.forwardRef(function CompositeItem(_ref2, forwardedRef) {\n let {\n render,\n ...props\n } = _ref2;\n const renderElementProps = render && typeof render !== 'function' ? render.props : {};\n const {\n activeIndex,\n onNavigate\n } = React.useContext(CompositeContext);\n const {\n ref,\n index\n } = useListItem();\n const mergedRef = useMergeRefs([ref, forwardedRef, renderElementProps.ref]);\n const isActive = activeIndex === index;\n const computedProps = {\n ...props,\n ...renderElementProps,\n ref: mergedRef,\n tabIndex: isActive ? 0 : -1,\n 'data-active': isActive ? '' : undefined,\n onFocus(e) {\n props.onFocus == null || props.onFocus(e);\n renderElementProps.onFocus == null || renderElementProps.onFocus(e);\n onNavigate(index);\n }\n };\n return renderJsx(render, computedProps);\n});\n\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\n\nlet serverHandoffComplete = false;\nlet count = 0;\nconst genId = () => \"floating-ui-\" + count++;\nfunction useFloatingId() {\n const [id, setId] = React.useState(() => serverHandoffComplete ? genId() : undefined);\n index(() => {\n if (id == null) {\n setId(genId());\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, []);\n React.useEffect(() => {\n if (!serverHandoffComplete) {\n serverHandoffComplete = true;\n }\n }, []);\n return id;\n}\n\n// `toString()` prevents bundlers from trying to `import { useId } from 'react'`\nconst useReactId = React[/*#__PURE__*/'useId'.toString()];\n\n/**\n * Uses React 18's built-in `useId()` when available, or falls back to a\n * slightly less performant (requiring a double render) implementation for\n * earlier React versions.\n * @see https://floating-ui.com/docs/useId\n */\nconst useId = useReactId || useFloatingId;\n\n/**\n * Renders a pointing arrow triangle.\n * @see https://floating-ui.com/docs/FloatingArrow\n */\nconst FloatingArrow = /*#__PURE__*/React.forwardRef(function FloatingArrow(_ref, ref) {\n let {\n context: {\n placement,\n elements: {\n floating\n },\n middlewareData: {\n arrow\n }\n },\n width = 14,\n height = 7,\n tipRadius = 0,\n strokeWidth = 0,\n staticOffset,\n stroke,\n d,\n style: {\n transform,\n ...restStyle\n } = {},\n ...rest\n } = _ref;\n if (process.env.NODE_ENV !== \"production\") {\n if (!ref) {\n console.warn('Floating UI: The `ref` prop is required for the `FloatingArrow`', 'component.');\n }\n }\n const clipPathId = useId();\n if (!floating) {\n return null;\n }\n\n // Strokes must be double the border width, this ensures the stroke's width\n // works as you'd expect.\n strokeWidth *= 2;\n const halfStrokeWidth = strokeWidth / 2;\n const svgX = width / 2 * (tipRadius / -8 + 1);\n const svgY = height / 2 * tipRadius / 4;\n const [side, alignment] = placement.split('-');\n const isRTL = platform.isRTL(floating);\n const isCustomShape = !!d;\n const isVerticalSide = side === 'top' || side === 'bottom';\n const yOffsetProp = staticOffset && alignment === 'end' ? 'bottom' : 'top';\n let xOffsetProp = staticOffset && alignment === 'end' ? 'right' : 'left';\n if (staticOffset && isRTL) {\n xOffsetProp = alignment === 'end' ? 'left' : 'right';\n }\n const arrowX = (arrow == null ? void 0 : arrow.x) != null ? staticOffset || arrow.x : '';\n const arrowY = (arrow == null ? void 0 : arrow.y) != null ? staticOffset || arrow.y : '';\n const dValue = d || 'M0,0' + (\" H\" + width) + (\" L\" + (width - svgX) + \",\" + (height - svgY)) + (\" Q\" + width / 2 + \",\" + height + \" \" + svgX + \",\" + (height - svgY)) + ' Z';\n const rotation = {\n top: isCustomShape ? 'rotate(180deg)' : '',\n left: isCustomShape ? 'rotate(90deg)' : 'rotate(-90deg)',\n bottom: isCustomShape ? '' : 'rotate(180deg)',\n right: isCustomShape ? 'rotate(-90deg)' : 'rotate(90deg)'\n }[side];\n return /*#__PURE__*/React.createElement(\"svg\", _extends({}, rest, {\n \"aria-hidden\": true,\n ref: ref,\n width: isCustomShape ? width : width + strokeWidth,\n height: width,\n viewBox: \"0 0 \" + width + \" \" + (height > width ? height : width),\n style: {\n position: 'absolute',\n pointerEvents: 'none',\n [xOffsetProp]: arrowX,\n [yOffsetProp]: arrowY,\n [side]: isVerticalSide || isCustomShape ? '100%' : \"calc(100% - \" + strokeWidth / 2 + \"px)\",\n transform: \"\" + rotation + (transform != null ? transform : ''),\n ...restStyle\n }\n }), strokeWidth > 0 && /*#__PURE__*/React.createElement(\"path\", {\n clipPath: \"url(#\" + clipPathId + \")\",\n fill: \"none\",\n stroke: stroke\n // Account for the stroke on the fill path rendered below.\n ,\n strokeWidth: strokeWidth + (d ? 0 : 1),\n d: dValue\n }), /*#__PURE__*/React.createElement(\"path\", {\n stroke: strokeWidth && !d ? rest.fill : 'none',\n d: dValue\n }), /*#__PURE__*/React.createElement(\"clipPath\", {\n id: clipPathId\n }, /*#__PURE__*/React.createElement(\"rect\", {\n x: -halfStrokeWidth,\n y: halfStrokeWidth * (isCustomShape ? -1 : 1),\n width: width + strokeWidth,\n height: width\n })));\n});\n\nfunction createPubSub() {\n const map = new Map();\n return {\n emit(event, data) {\n var _map$get;\n (_map$get = map.get(event)) == null || _map$get.forEach(handler => handler(data));\n },\n on(event, listener) {\n map.set(event, [...(map.get(event) || []), listener]);\n },\n off(event, listener) {\n var _map$get2;\n map.set(event, ((_map$get2 = map.get(event)) == null ? void 0 : _map$get2.filter(l => l !== listener)) || []);\n }\n };\n}\n\nconst FloatingNodeContext = /*#__PURE__*/React.createContext(null);\nconst FloatingTreeContext = /*#__PURE__*/React.createContext(null);\nconst useFloatingParentNodeId = () => {\n var _React$useContext;\n return ((_React$useContext = React.useContext(FloatingNodeContext)) == null ? void 0 : _React$useContext.id) || null;\n};\nconst useFloatingTree = () => React.useContext(FloatingTreeContext);\n\n/**\n * Registers a node into the floating tree, returning its id.\n */\nfunction useFloatingNodeId(customParentId) {\n const id = useId();\n const tree = useFloatingTree();\n const reactParentId = useFloatingParentNodeId();\n const parentId = customParentId || reactParentId;\n index(() => {\n const node = {\n id,\n parentId\n };\n tree == null || tree.addNode(node);\n return () => {\n tree == null || tree.removeNode(node);\n };\n }, [tree, id, parentId]);\n return id;\n}\n\n/**\n * Provides parent node context for nested floating elements.\n * @see https://floating-ui.com/docs/FloatingTree\n */\nfunction FloatingNode(_ref) {\n let {\n children,\n id\n } = _ref;\n const parentId = useFloatingParentNodeId();\n return /*#__PURE__*/React.createElement(FloatingNodeContext.Provider, {\n value: React.useMemo(() => ({\n id,\n parentId\n }), [id, parentId])\n }, children);\n}\n\n/**\n * Provides context for nested floating elements when they are not children of\n * each other on the DOM (i.e. portalled to a common node, rather than their\n * respective parent).\n * @see https://floating-ui.com/docs/FloatingTree\n */\nfunction FloatingTree(_ref2) {\n let {\n children\n } = _ref2;\n const nodesRef = React.useRef([]);\n const addNode = React.useCallback(node => {\n nodesRef.current = [...nodesRef.current, node];\n }, []);\n const removeNode = React.useCallback(node => {\n nodesRef.current = nodesRef.current.filter(n => n !== node);\n }, []);\n const events = React.useState(() => createPubSub())[0];\n return /*#__PURE__*/React.createElement(FloatingTreeContext.Provider, {\n value: React.useMemo(() => ({\n nodesRef,\n addNode,\n removeNode,\n events\n }), [nodesRef, addNode, removeNode, events])\n }, children);\n}\n\nfunction createAttribute(name) {\n return \"data-floating-ui-\" + name;\n}\n\nfunction useLatestRef(value) {\n const ref = useRef(value);\n index(() => {\n ref.current = value;\n });\n return ref;\n}\n\nconst safePolygonIdentifier = /*#__PURE__*/createAttribute('safe-polygon');\nfunction getDelay(value, prop, pointerType) {\n if (pointerType && !isMouseLikePointerType(pointerType)) {\n return 0;\n }\n if (typeof value === 'number') {\n return value;\n }\n return value == null ? void 0 : value[prop];\n}\n/**\n * Opens the floating element while hovering over the reference element, like\n * CSS `:hover`.\n * @see https://floating-ui.com/docs/useHover\n */\nfunction useHover(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n dataRef,\n events,\n elements: {\n domReference,\n floating\n },\n refs\n } = context;\n const {\n enabled = true,\n delay = 0,\n handleClose = null,\n mouseOnly = false,\n restMs = 0,\n move = true\n } = props;\n const tree = useFloatingTree();\n const parentId = useFloatingParentNodeId();\n const handleCloseRef = useLatestRef(handleClose);\n const delayRef = useLatestRef(delay);\n const pointerTypeRef = React.useRef();\n const timeoutRef = React.useRef();\n const handlerRef = React.useRef();\n const restTimeoutRef = React.useRef();\n const blockMouseMoveRef = React.useRef(true);\n const performedPointerEventsMutationRef = React.useRef(false);\n const unbindMouseMoveRef = React.useRef(() => {});\n const isHoverOpen = React.useCallback(() => {\n var _dataRef$current$open;\n const type = (_dataRef$current$open = dataRef.current.openEvent) == null ? void 0 : _dataRef$current$open.type;\n return (type == null ? void 0 : type.includes('mouse')) && type !== 'mousedown';\n }, [dataRef]);\n\n // When closing before opening, clear the delay timeouts to cancel it\n // from showing.\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n function onOpenChange(_ref) {\n let {\n open\n } = _ref;\n if (!open) {\n clearTimeout(timeoutRef.current);\n clearTimeout(restTimeoutRef.current);\n blockMouseMoveRef.current = true;\n }\n }\n events.on('openchange', onOpenChange);\n return () => {\n events.off('openchange', onOpenChange);\n };\n }, [enabled, events]);\n React.useEffect(() => {\n if (!enabled || !handleCloseRef.current || !open) {\n return;\n }\n function onLeave(event) {\n if (isHoverOpen()) {\n onOpenChange(false, event, 'hover');\n }\n }\n const html = getDocument(floating).documentElement;\n html.addEventListener('mouseleave', onLeave);\n return () => {\n html.removeEventListener('mouseleave', onLeave);\n };\n }, [floating, open, onOpenChange, enabled, handleCloseRef, dataRef, isHoverOpen]);\n const closeWithDelay = React.useCallback(function (event, runElseBranch, reason) {\n if (runElseBranch === void 0) {\n runElseBranch = true;\n }\n if (reason === void 0) {\n reason = 'hover';\n }\n const closeDelay = getDelay(delayRef.current, 'close', pointerTypeRef.current);\n if (closeDelay && !handlerRef.current) {\n clearTimeout(timeoutRef.current);\n timeoutRef.current = setTimeout(() => onOpenChange(false, event, reason), closeDelay);\n } else if (runElseBranch) {\n clearTimeout(timeoutRef.current);\n onOpenChange(false, event, reason);\n }\n }, [delayRef, onOpenChange]);\n const cleanupMouseMoveHandler = React.useCallback(() => {\n unbindMouseMoveRef.current();\n handlerRef.current = undefined;\n }, []);\n const clearPointerEvents = React.useCallback(() => {\n if (performedPointerEventsMutationRef.current) {\n const body = getDocument(refs.floating.current).body;\n body.style.pointerEvents = '';\n body.removeAttribute(safePolygonIdentifier);\n performedPointerEventsMutationRef.current = false;\n }\n }, [refs]);\n\n // Registering the mouse events on the reference directly to bypass React's\n // delegation system. If the cursor was on a disabled element and then entered\n // the reference (no gap), `mouseenter` doesn't fire in the delegation system.\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n function isClickLikeOpenEvent() {\n return dataRef.current.openEvent ? ['click', 'mousedown'].includes(dataRef.current.openEvent.type) : false;\n }\n function onMouseEnter(event) {\n clearTimeout(timeoutRef.current);\n blockMouseMoveRef.current = false;\n if (mouseOnly && !isMouseLikePointerType(pointerTypeRef.current) || restMs > 0 && getDelay(delayRef.current, 'open') === 0) {\n return;\n }\n const openDelay = getDelay(delayRef.current, 'open', pointerTypeRef.current);\n if (openDelay) {\n timeoutRef.current = setTimeout(() => {\n onOpenChange(true, event, 'hover');\n }, openDelay);\n } else {\n onOpenChange(true, event, 'hover');\n }\n }\n function onMouseLeave(event) {\n if (isClickLikeOpenEvent()) {\n return;\n }\n unbindMouseMoveRef.current();\n const doc = getDocument(floating);\n clearTimeout(restTimeoutRef.current);\n if (handleCloseRef.current) {\n // Prevent clearing `onScrollMouseLeave` timeout.\n if (!open) {\n clearTimeout(timeoutRef.current);\n }\n handlerRef.current = handleCloseRef.current({\n ...context,\n tree,\n x: event.clientX,\n y: event.clientY,\n onClose() {\n clearPointerEvents();\n cleanupMouseMoveHandler();\n closeWithDelay(event, true, 'safe-polygon');\n }\n });\n const handler = handlerRef.current;\n doc.addEventListener('mousemove', handler);\n unbindMouseMoveRef.current = () => {\n doc.removeEventListener('mousemove', handler);\n };\n return;\n }\n\n // Allow interactivity without `safePolygon` on touch devices. With a\n // pointer, a short close delay is an alternative, so it should work\n // consistently.\n const shouldClose = pointerTypeRef.current === 'touch' ? !contains(floating, event.relatedTarget) : true;\n if (shouldClose) {\n closeWithDelay(event);\n }\n }\n\n // Ensure the floating element closes after scrolling even if the pointer\n // did not move.\n // https://github.com/floating-ui/floating-ui/discussions/1692\n function onScrollMouseLeave(event) {\n if (isClickLikeOpenEvent()) {\n return;\n }\n handleCloseRef.current == null || handleCloseRef.current({\n ...context,\n tree,\n x: event.clientX,\n y: event.clientY,\n onClose() {\n clearPointerEvents();\n cleanupMouseMoveHandler();\n closeWithDelay(event);\n }\n })(event);\n }\n if (isElement(domReference)) {\n const ref = domReference;\n open && ref.addEventListener('mouseleave', onScrollMouseLeave);\n floating == null || floating.addEventListener('mouseleave', onScrollMouseLeave);\n move && ref.addEventListener('mousemove', onMouseEnter, {\n once: true\n });\n ref.addEventListener('mouseenter', onMouseEnter);\n ref.addEventListener('mouseleave', onMouseLeave);\n return () => {\n open && ref.removeEventListener('mouseleave', onScrollMouseLeave);\n floating == null || floating.removeEventListener('mouseleave', onScrollMouseLeave);\n move && ref.removeEventListener('mousemove', onMouseEnter);\n ref.removeEventListener('mouseenter', onMouseEnter);\n ref.removeEventListener('mouseleave', onMouseLeave);\n };\n }\n }, [domReference, floating, enabled, context, mouseOnly, restMs, move, closeWithDelay, cleanupMouseMoveHandler, clearPointerEvents, onOpenChange, open, tree, delayRef, handleCloseRef, dataRef]);\n\n // Block pointer-events of every element other than the reference and floating\n // while the floating element is open and has a `handleClose` handler. Also\n // handles nested floating elements.\n // https://github.com/floating-ui/floating-ui/issues/1722\n index(() => {\n var _handleCloseRef$curre;\n if (!enabled) {\n return;\n }\n if (open && (_handleCloseRef$curre = handleCloseRef.current) != null && _handleCloseRef$curre.__options.blockPointerEvents && isHoverOpen()) {\n const body = getDocument(floating).body;\n body.setAttribute(safePolygonIdentifier, '');\n body.style.pointerEvents = 'none';\n performedPointerEventsMutationRef.current = true;\n if (isElement(domReference) && floating) {\n var _tree$nodesRef$curren;\n const ref = domReference;\n const parentFloating = tree == null || (_tree$nodesRef$curren = tree.nodesRef.current.find(node => node.id === parentId)) == null || (_tree$nodesRef$curren = _tree$nodesRef$curren.context) == null ? void 0 : _tree$nodesRef$curren.elements.floating;\n if (parentFloating) {\n parentFloating.style.pointerEvents = '';\n }\n ref.style.pointerEvents = 'auto';\n floating.style.pointerEvents = 'auto';\n return () => {\n ref.style.pointerEvents = '';\n floating.style.pointerEvents = '';\n };\n }\n }\n }, [enabled, open, parentId, floating, domReference, tree, handleCloseRef, dataRef, isHoverOpen]);\n index(() => {\n if (!open) {\n pointerTypeRef.current = undefined;\n cleanupMouseMoveHandler();\n clearPointerEvents();\n }\n }, [open, cleanupMouseMoveHandler, clearPointerEvents]);\n React.useEffect(() => {\n return () => {\n cleanupMouseMoveHandler();\n clearTimeout(timeoutRef.current);\n clearTimeout(restTimeoutRef.current);\n clearPointerEvents();\n };\n }, [enabled, domReference, cleanupMouseMoveHandler, clearPointerEvents]);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n function setPointerRef(event) {\n pointerTypeRef.current = event.pointerType;\n }\n return {\n reference: {\n onPointerDown: setPointerRef,\n onPointerEnter: setPointerRef,\n onMouseMove(event) {\n if (open || restMs === 0) {\n return;\n }\n clearTimeout(restTimeoutRef.current);\n restTimeoutRef.current = setTimeout(() => {\n if (!blockMouseMoveRef.current) {\n onOpenChange(true, event.nativeEvent, 'hover');\n }\n }, restMs);\n }\n },\n floating: {\n onMouseEnter() {\n clearTimeout(timeoutRef.current);\n },\n onMouseLeave(event) {\n closeWithDelay(event.nativeEvent, false);\n }\n }\n };\n }, [enabled, restMs, open, onOpenChange, closeWithDelay]);\n}\n\nconst FloatingDelayGroupContext = /*#__PURE__*/React.createContext({\n delay: 0,\n initialDelay: 0,\n timeoutMs: 0,\n currentId: null,\n setCurrentId: () => {},\n setState: () => {},\n isInstantPhase: false\n});\nconst useDelayGroupContext = () => React.useContext(FloatingDelayGroupContext);\n/**\n * Provides context for a group of floating elements that should share a\n * `delay`.\n * @see https://floating-ui.com/docs/FloatingDelayGroup\n */\nconst FloatingDelayGroup = _ref => {\n let {\n children,\n delay,\n timeoutMs = 0\n } = _ref;\n const [state, setState] = React.useReducer((prev, next) => ({\n ...prev,\n ...next\n }), {\n delay,\n timeoutMs,\n initialDelay: delay,\n currentId: null,\n isInstantPhase: false\n });\n const initialCurrentIdRef = React.useRef(null);\n const setCurrentId = React.useCallback(currentId => {\n setState({\n currentId\n });\n }, []);\n index(() => {\n if (state.currentId) {\n if (initialCurrentIdRef.current === null) {\n initialCurrentIdRef.current = state.currentId;\n } else {\n setState({\n isInstantPhase: true\n });\n }\n } else {\n setState({\n isInstantPhase: false\n });\n initialCurrentIdRef.current = null;\n }\n }, [state.currentId]);\n return /*#__PURE__*/React.createElement(FloatingDelayGroupContext.Provider, {\n value: React.useMemo(() => ({\n ...state,\n setState,\n setCurrentId\n }), [state, setState, setCurrentId])\n }, children);\n};\nconst useDelayGroup = (_ref2, _ref3) => {\n let {\n open,\n onOpenChange\n } = _ref2;\n let {\n id\n } = _ref3;\n const {\n currentId,\n setCurrentId,\n initialDelay,\n setState,\n timeoutMs\n } = useDelayGroupContext();\n index(() => {\n if (currentId) {\n setState({\n delay: {\n open: 1,\n close: getDelay(initialDelay, 'close')\n }\n });\n if (currentId !== id) {\n onOpenChange(false);\n }\n }\n }, [id, onOpenChange, setState, currentId, initialDelay]);\n index(() => {\n function unset() {\n onOpenChange(false);\n setState({\n delay: initialDelay,\n currentId: null\n });\n }\n if (!open && currentId === id) {\n if (timeoutMs) {\n const timeout = window.setTimeout(unset, timeoutMs);\n return () => {\n clearTimeout(timeout);\n };\n } else {\n unset();\n }\n }\n }, [open, setState, currentId, id, onOpenChange, initialDelay, timeoutMs]);\n index(() => {\n if (open) {\n setCurrentId(id);\n }\n }, [open, setCurrentId, id]);\n};\n\nfunction getAncestors(nodes, id) {\n var _nodes$find;\n let allAncestors = [];\n let currentParentId = (_nodes$find = nodes.find(node => node.id === id)) == null ? void 0 : _nodes$find.parentId;\n while (currentParentId) {\n const currentNode = nodes.find(node => node.id === currentParentId);\n currentParentId = currentNode == null ? void 0 : currentNode.parentId;\n if (currentNode) {\n allAncestors = allAncestors.concat(currentNode);\n }\n }\n return allAncestors;\n}\n\nfunction getChildren(nodes, id) {\n let allChildren = nodes.filter(node => {\n var _node$context;\n return node.parentId === id && ((_node$context = node.context) == null ? void 0 : _node$context.open);\n });\n let currentChildren = allChildren;\n while (currentChildren.length) {\n currentChildren = nodes.filter(node => {\n var _currentChildren;\n return (_currentChildren = currentChildren) == null ? void 0 : _currentChildren.some(n => {\n var _node$context2;\n return node.parentId === n.id && ((_node$context2 = node.context) == null ? void 0 : _node$context2.open);\n });\n });\n allChildren = allChildren.concat(currentChildren);\n }\n return allChildren;\n}\nfunction getDeepestNode(nodes, id) {\n let deepestNodeId;\n let maxDepth = -1;\n function findDeepest(nodeId, depth) {\n if (depth > maxDepth) {\n deepestNodeId = nodeId;\n maxDepth = depth;\n }\n const children = getChildren(nodes, nodeId);\n children.forEach(child => {\n findDeepest(child.id, depth + 1);\n });\n }\n findDeepest(id, 0);\n return nodes.find(node => node.id === deepestNodeId);\n}\n\n// Modified to add conditional `aria-hidden` support:\n// https://github.com/theKashey/aria-hidden/blob/9220c8f4a4fd35f63bee5510a9f41a37264382d4/src/index.ts\nlet counterMap = /*#__PURE__*/new WeakMap();\nlet uncontrolledElementsSet = /*#__PURE__*/new WeakSet();\nlet markerMap = {};\nlet lockCount = 0;\nconst supportsInert = () => typeof HTMLElement !== 'undefined' && 'inert' in HTMLElement.prototype;\nconst unwrapHost = node => node && (node.host || unwrapHost(node.parentNode));\nconst correctElements = (parent, targets) => targets.map(target => {\n if (parent.contains(target)) {\n return target;\n }\n const correctedTarget = unwrapHost(target);\n if (parent.contains(correctedTarget)) {\n return correctedTarget;\n }\n return null;\n}).filter(x => x != null);\nfunction applyAttributeToOthers(uncorrectedAvoidElements, body, ariaHidden, inert) {\n const markerName = 'data-floating-ui-inert';\n const controlAttribute = inert ? 'inert' : ariaHidden ? 'aria-hidden' : null;\n const avoidElements = correctElements(body, uncorrectedAvoidElements);\n const elementsToKeep = new Set();\n const elementsToStop = new Set(avoidElements);\n const hiddenElements = [];\n if (!markerMap[markerName]) {\n markerMap[markerName] = new WeakMap();\n }\n const markerCounter = markerMap[markerName];\n avoidElements.forEach(keep);\n deep(body);\n elementsToKeep.clear();\n function keep(el) {\n if (!el || elementsToKeep.has(el)) {\n return;\n }\n elementsToKeep.add(el);\n el.parentNode && keep(el.parentNode);\n }\n function deep(parent) {\n if (!parent || elementsToStop.has(parent)) {\n return;\n }\n Array.prototype.forEach.call(parent.children, node => {\n if (elementsToKeep.has(node)) {\n deep(node);\n } else {\n const attr = controlAttribute ? node.getAttribute(controlAttribute) : null;\n const alreadyHidden = attr !== null && attr !== 'false';\n const counterValue = (counterMap.get(node) || 0) + 1;\n const markerValue = (markerCounter.get(node) || 0) + 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n hiddenElements.push(node);\n if (counterValue === 1 && alreadyHidden) {\n uncontrolledElementsSet.add(node);\n }\n if (markerValue === 1) {\n node.setAttribute(markerName, '');\n }\n if (!alreadyHidden && controlAttribute) {\n node.setAttribute(controlAttribute, 'true');\n }\n }\n });\n }\n lockCount++;\n return () => {\n hiddenElements.forEach(element => {\n const counterValue = (counterMap.get(element) || 0) - 1;\n const markerValue = (markerCounter.get(element) || 0) - 1;\n counterMap.set(element, counterValue);\n markerCounter.set(element, markerValue);\n if (!counterValue) {\n if (!uncontrolledElementsSet.has(element) && controlAttribute) {\n element.removeAttribute(controlAttribute);\n }\n uncontrolledElementsSet.delete(element);\n }\n if (!markerValue) {\n element.removeAttribute(markerName);\n }\n });\n lockCount--;\n if (!lockCount) {\n counterMap = new WeakMap();\n counterMap = new WeakMap();\n uncontrolledElementsSet = new WeakSet();\n markerMap = {};\n }\n };\n}\nfunction markOthers(avoidElements, ariaHidden, inert) {\n if (ariaHidden === void 0) {\n ariaHidden = false;\n }\n if (inert === void 0) {\n inert = false;\n }\n const body = getDocument(avoidElements[0]).body;\n return applyAttributeToOthers(avoidElements.concat(Array.from(body.querySelectorAll('[aria-live]'))), body, ariaHidden, inert);\n}\n\nconst getTabbableOptions = () => ({\n getShadowRoot: true,\n displayCheck:\n // JSDOM does not support the `tabbable` library. To solve this we can\n // check if `ResizeObserver` is a real function (not polyfilled), which\n // determines if the current environment is JSDOM-like.\n typeof ResizeObserver === 'function' && ResizeObserver.toString().includes('[native code]') ? 'full' : 'none'\n});\nfunction getTabbableIn(container, direction) {\n const allTabbable = tabbable(container, getTabbableOptions());\n if (direction === 'prev') {\n allTabbable.reverse();\n }\n const activeIndex = allTabbable.indexOf(activeElement(getDocument(container)));\n const nextTabbableElements = allTabbable.slice(activeIndex + 1);\n return nextTabbableElements[0];\n}\nfunction getNextTabbable() {\n return getTabbableIn(document.body, 'next');\n}\nfunction getPreviousTabbable() {\n return getTabbableIn(document.body, 'prev');\n}\nfunction isOutsideEvent(event, container) {\n const containerElement = container || event.currentTarget;\n const relatedTarget = event.relatedTarget;\n return !relatedTarget || !contains(containerElement, relatedTarget);\n}\nfunction disableFocusInside(container) {\n const tabbableElements = tabbable(container, getTabbableOptions());\n tabbableElements.forEach(element => {\n element.dataset.tabindex = element.getAttribute('tabindex') || '';\n element.setAttribute('tabindex', '-1');\n });\n}\nfunction enableFocusInside(container) {\n const elements = container.querySelectorAll('[data-tabindex]');\n elements.forEach(element => {\n const tabindex = element.dataset.tabindex;\n delete element.dataset.tabindex;\n if (tabindex) {\n element.setAttribute('tabindex', tabindex);\n } else {\n element.removeAttribute('tabindex');\n }\n });\n}\n\n// See Diego Haz's Sandbox for making this logic work well on Safari/iOS:\n// https://codesandbox.io/s/tabbable-portal-f4tng?file=/src/FocusTrap.tsx\n\nconst HIDDEN_STYLES = {\n border: 0,\n clip: 'rect(0 0 0 0)',\n height: '1px',\n margin: '-1px',\n overflow: 'hidden',\n padding: 0,\n position: 'fixed',\n whiteSpace: 'nowrap',\n width: '1px',\n top: 0,\n left: 0\n};\nlet timeoutId;\nfunction setActiveElementOnTab(event) {\n if (event.key === 'Tab') {\n event.target;\n clearTimeout(timeoutId);\n }\n}\nconst FocusGuard = /*#__PURE__*/React.forwardRef(function FocusGuard(props, ref) {\n const [role, setRole] = React.useState();\n index(() => {\n if (isSafari()) {\n // Unlike other screen readers such as NVDA and JAWS, the virtual cursor\n // on VoiceOver does trigger the onFocus event, so we can use the focus\n // trap element. On Safari, only buttons trigger the onFocus event.\n // NB: \"group\" role in the Sandbox no longer appears to work, must be a\n // button role.\n setRole('button');\n }\n document.addEventListener('keydown', setActiveElementOnTab);\n return () => {\n document.removeEventListener('keydown', setActiveElementOnTab);\n };\n }, []);\n const restProps = {\n ref,\n tabIndex: 0,\n // Role is only for VoiceOver\n role,\n 'aria-hidden': role ? undefined : true,\n [createAttribute('focus-guard')]: '',\n style: HIDDEN_STYLES\n };\n return /*#__PURE__*/React.createElement(\"span\", _extends({}, props, restProps));\n});\n\nconst PortalContext = /*#__PURE__*/React.createContext(null);\nfunction useFloatingPortalNode(_temp) {\n let {\n id,\n root\n } = _temp === void 0 ? {} : _temp;\n const [portalNode, setPortalNode] = React.useState(null);\n const uniqueId = useId();\n const portalContext = usePortalContext();\n const data = React.useMemo(() => ({\n id,\n root,\n portalContext,\n uniqueId\n }), [id, root, portalContext, uniqueId]);\n const dataRef = React.useRef();\n index(() => {\n return () => {\n portalNode == null || portalNode.remove();\n };\n }, [portalNode, data]);\n index(() => {\n if (dataRef.current === data) return;\n dataRef.current = data;\n const {\n id,\n root,\n portalContext,\n uniqueId\n } = data;\n const existingIdRoot = id ? document.getElementById(id) : null;\n const attr = createAttribute('portal');\n if (existingIdRoot) {\n const subRoot = document.createElement('div');\n subRoot.id = uniqueId;\n subRoot.setAttribute(attr, '');\n existingIdRoot.appendChild(subRoot);\n setPortalNode(subRoot);\n } else {\n let container = root || (portalContext == null ? void 0 : portalContext.portalNode);\n if (container && !isElement(container)) container = container.current;\n container = container || document.body;\n let idWrapper = null;\n if (id) {\n idWrapper = document.createElement('div');\n idWrapper.id = id;\n container.appendChild(idWrapper);\n }\n const subRoot = document.createElement('div');\n subRoot.id = uniqueId;\n subRoot.setAttribute(attr, '');\n container = idWrapper || container;\n container.appendChild(subRoot);\n setPortalNode(subRoot);\n }\n }, [data]);\n return portalNode;\n}\n/**\n * Portals the floating element into a given container element — by default,\n * outside of the app root and into the body.\n * @see https://floating-ui.com/docs/FloatingPortal\n */\nfunction FloatingPortal(_ref) {\n let {\n children,\n id,\n root = null,\n preserveTabOrder = true\n } = _ref;\n const portalNode = useFloatingPortalNode({\n id,\n root\n });\n const [focusManagerState, setFocusManagerState] = React.useState(null);\n const beforeOutsideRef = React.useRef(null);\n const afterOutsideRef = React.useRef(null);\n const beforeInsideRef = React.useRef(null);\n const afterInsideRef = React.useRef(null);\n const shouldRenderGuards =\n // The FocusManager and therefore floating element are currently open/\n // rendered.\n !!focusManagerState &&\n // Guards are only for non-modal focus management.\n !focusManagerState.modal &&\n // Don't render if unmount is transitioning.\n focusManagerState.open && preserveTabOrder && !!(root || portalNode);\n\n // https://codesandbox.io/s/tabbable-portal-f4tng?file=/src/TabbablePortal.tsx\n React.useEffect(() => {\n if (!portalNode || !preserveTabOrder || focusManagerState != null && focusManagerState.modal) {\n return;\n }\n\n // Make sure elements inside the portal element are tabbable only when the\n // portal has already been focused, either by tabbing into a focus trap\n // element outside or using the mouse.\n function onFocus(event) {\n if (portalNode && isOutsideEvent(event)) {\n const focusing = event.type === 'focusin';\n const manageFocus = focusing ? enableFocusInside : disableFocusInside;\n manageFocus(portalNode);\n }\n }\n // Listen to the event on the capture phase so they run before the focus\n // trap elements onFocus prop is called.\n portalNode.addEventListener('focusin', onFocus, true);\n portalNode.addEventListener('focusout', onFocus, true);\n return () => {\n portalNode.removeEventListener('focusin', onFocus, true);\n portalNode.removeEventListener('focusout', onFocus, true);\n };\n }, [portalNode, preserveTabOrder, focusManagerState == null ? void 0 : focusManagerState.modal]);\n return /*#__PURE__*/React.createElement(PortalContext.Provider, {\n value: React.useMemo(() => ({\n preserveTabOrder,\n beforeOutsideRef,\n afterOutsideRef,\n beforeInsideRef,\n afterInsideRef,\n portalNode,\n setFocusManagerState\n }), [preserveTabOrder, portalNode])\n }, shouldRenderGuards && portalNode && /*#__PURE__*/React.createElement(FocusGuard, {\n \"data-type\": \"outside\",\n ref: beforeOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n var _beforeInsideRef$curr;\n (_beforeInsideRef$curr = beforeInsideRef.current) == null || _beforeInsideRef$curr.focus();\n } else {\n const prevTabbable = getPreviousTabbable() || (focusManagerState == null ? void 0 : focusManagerState.refs.domReference.current);\n prevTabbable == null || prevTabbable.focus();\n }\n }\n }), shouldRenderGuards && portalNode && /*#__PURE__*/React.createElement(\"span\", {\n \"aria-owns\": portalNode.id,\n style: HIDDEN_STYLES\n }), portalNode && /*#__PURE__*/createPortal(children, portalNode), shouldRenderGuards && portalNode && /*#__PURE__*/React.createElement(FocusGuard, {\n \"data-type\": \"outside\",\n ref: afterOutsideRef,\n onFocus: event => {\n if (isOutsideEvent(event, portalNode)) {\n var _afterInsideRef$curre;\n (_afterInsideRef$curre = afterInsideRef.current) == null || _afterInsideRef$curre.focus();\n } else {\n const nextTabbable = getNextTabbable() || (focusManagerState == null ? void 0 : focusManagerState.refs.domReference.current);\n nextTabbable == null || nextTabbable.focus();\n (focusManagerState == null ? void 0 : focusManagerState.closeOnFocusOut) && (focusManagerState == null ? void 0 : focusManagerState.onOpenChange(false, event.nativeEvent));\n }\n }\n }));\n}\nconst usePortalContext = () => React.useContext(PortalContext);\n\nconst LIST_LIMIT = 20;\nlet previouslyFocusedElements = [];\nfunction addPreviouslyFocusedElement(element) {\n previouslyFocusedElements = previouslyFocusedElements.filter(el => el.isConnected);\n if (element && getNodeName(element) !== 'body') {\n previouslyFocusedElements.push(element);\n if (previouslyFocusedElements.length > LIST_LIMIT) {\n previouslyFocusedElements = previouslyFocusedElements.slice(-LIST_LIMIT);\n }\n }\n}\nfunction getPreviouslyFocusedElement() {\n return previouslyFocusedElements.slice().reverse().find(el => el.isConnected);\n}\nconst VisuallyHiddenDismiss = /*#__PURE__*/React.forwardRef(function VisuallyHiddenDismiss(props, ref) {\n return /*#__PURE__*/React.createElement(\"button\", _extends({}, props, {\n type: \"button\",\n ref: ref,\n tabIndex: -1,\n style: HIDDEN_STYLES\n }));\n});\n/**\n * Provides focus management for the floating element.\n * @see https://floating-ui.com/docs/FloatingFocusManager\n */\nfunction FloatingFocusManager(props) {\n const {\n context,\n children,\n disabled = false,\n order = ['content'],\n guards: _guards = true,\n initialFocus = 0,\n returnFocus = true,\n modal = true,\n visuallyHiddenDismiss = false,\n closeOnFocusOut = true\n } = props;\n const {\n open,\n refs,\n nodeId,\n onOpenChange,\n events,\n dataRef,\n elements: {\n domReference,\n floating\n }\n } = context;\n const ignoreInitialFocus = typeof initialFocus === 'number' && initialFocus < 0;\n // If the reference is a combobox and is typeable (e.g. input/textarea),\n // there are different focus semantics. The guards should not be rendered, but\n // aria-hidden should be applied to all nodes still. Further, the visually\n // hidden dismiss button should only appear at the end of the list, not the\n // start.\n const isUntrappedTypeableCombobox = isTypeableCombobox(domReference) && ignoreInitialFocus;\n\n // Force the guards to be rendered if the `inert` attribute is not supported.\n const guards = supportsInert() ? _guards : true;\n const orderRef = useLatestRef(order);\n const initialFocusRef = useLatestRef(initialFocus);\n const returnFocusRef = useLatestRef(returnFocus);\n const tree = useFloatingTree();\n const portalContext = usePortalContext();\n const startDismissButtonRef = React.useRef(null);\n const endDismissButtonRef = React.useRef(null);\n const preventReturnFocusRef = React.useRef(false);\n const isPointerDownRef = React.useRef(false);\n const isInsidePortal = portalContext != null;\n const getTabbableContent = React.useCallback(function (container) {\n if (container === void 0) {\n container = floating;\n }\n return container ? tabbable(container, getTabbableOptions()) : [];\n }, [floating]);\n const getTabbableElements = React.useCallback(container => {\n const content = getTabbableContent(container);\n return orderRef.current.map(type => {\n if (domReference && type === 'reference') {\n return domReference;\n }\n if (floating && type === 'floating') {\n return floating;\n }\n return content;\n }).filter(Boolean).flat();\n }, [domReference, floating, orderRef, getTabbableContent]);\n React.useEffect(() => {\n if (disabled || !modal) return;\n function onKeyDown(event) {\n if (event.key === 'Tab') {\n // The focus guards have nothing to focus, so we need to stop the event.\n if (contains(floating, activeElement(getDocument(floating))) && getTabbableContent().length === 0 && !isUntrappedTypeableCombobox) {\n stopEvent(event);\n }\n const els = getTabbableElements();\n const target = getTarget(event);\n if (orderRef.current[0] === 'reference' && target === domReference) {\n stopEvent(event);\n if (event.shiftKey) {\n enqueueFocus(els[els.length - 1]);\n } else {\n enqueueFocus(els[1]);\n }\n }\n if (orderRef.current[1] === 'floating' && target === floating && event.shiftKey) {\n stopEvent(event);\n enqueueFocus(els[0]);\n }\n }\n }\n const doc = getDocument(floating);\n doc.addEventListener('keydown', onKeyDown);\n return () => {\n doc.removeEventListener('keydown', onKeyDown);\n };\n }, [disabled, domReference, floating, modal, orderRef, refs, isUntrappedTypeableCombobox, getTabbableContent, getTabbableElements]);\n React.useEffect(() => {\n if (disabled || !closeOnFocusOut) return;\n\n // In Safari, buttons lose focus when pressing them.\n function handlePointerDown() {\n isPointerDownRef.current = true;\n setTimeout(() => {\n isPointerDownRef.current = false;\n });\n }\n function handleFocusOutside(event) {\n const relatedTarget = event.relatedTarget;\n queueMicrotask(() => {\n const movedToUnrelatedNode = !(contains(domReference, relatedTarget) || contains(floating, relatedTarget) || contains(relatedTarget, floating) || contains(portalContext == null ? void 0 : portalContext.portalNode, relatedTarget) || relatedTarget != null && relatedTarget.hasAttribute(createAttribute('focus-guard')) || tree && (getChildren(tree.nodesRef.current, nodeId).find(node => {\n var _node$context, _node$context2;\n return contains((_node$context = node.context) == null ? void 0 : _node$context.elements.floating, relatedTarget) || contains((_node$context2 = node.context) == null ? void 0 : _node$context2.elements.domReference, relatedTarget);\n }) || getAncestors(tree.nodesRef.current, nodeId).find(node => {\n var _node$context3, _node$context4;\n return ((_node$context3 = node.context) == null ? void 0 : _node$context3.elements.floating) === relatedTarget || ((_node$context4 = node.context) == null ? void 0 : _node$context4.elements.domReference) === relatedTarget;\n })));\n\n // Focus did not move inside the floating tree, and there are no tabbable\n // portal guards to handle closing.\n if (relatedTarget && movedToUnrelatedNode && !isPointerDownRef.current &&\n // Fix React 18 Strict Mode returnFocus due to double rendering.\n relatedTarget !== getPreviouslyFocusedElement()) {\n preventReturnFocusRef.current = true;\n onOpenChange(false, event);\n }\n });\n }\n if (floating && isHTMLElement(domReference)) {\n domReference.addEventListener('focusout', handleFocusOutside);\n domReference.addEventListener('pointerdown', handlePointerDown);\n !modal && floating.addEventListener('focusout', handleFocusOutside);\n return () => {\n domReference.removeEventListener('focusout', handleFocusOutside);\n domReference.removeEventListener('pointerdown', handlePointerDown);\n !modal && floating.removeEventListener('focusout', handleFocusOutside);\n };\n }\n }, [disabled, domReference, floating, modal, nodeId, tree, portalContext, onOpenChange, closeOnFocusOut]);\n React.useEffect(() => {\n var _portalContext$portal;\n if (disabled) return;\n\n // Don't hide portals nested within the parent portal.\n const portalNodes = Array.from((portalContext == null || (_portalContext$portal = portalContext.portalNode) == null ? void 0 : _portalContext$portal.querySelectorAll(\"[\" + createAttribute('portal') + \"]\")) || []);\n if (floating) {\n const insideElements = [floating, ...portalNodes, startDismissButtonRef.current, endDismissButtonRef.current, orderRef.current.includes('reference') || isUntrappedTypeableCombobox ? domReference : null].filter(x => x != null);\n const cleanup = modal || isUntrappedTypeableCombobox ? markOthers(insideElements, guards, !guards) : markOthers(insideElements);\n return () => {\n cleanup();\n };\n }\n }, [disabled, domReference, floating, modal, orderRef, portalContext, isUntrappedTypeableCombobox, guards]);\n index(() => {\n if (disabled || !floating) return;\n const doc = getDocument(floating);\n const previouslyFocusedElement = activeElement(doc);\n\n // Wait for any layout effect state setters to execute to set `tabIndex`.\n queueMicrotask(() => {\n const focusableElements = getTabbableElements(floating);\n const initialFocusValue = initialFocusRef.current;\n const elToFocus = (typeof initialFocusValue === 'number' ? focusableElements[initialFocusValue] : initialFocusValue.current) || floating;\n const focusAlreadyInsideFloatingEl = contains(floating, previouslyFocusedElement);\n if (!ignoreInitialFocus && !focusAlreadyInsideFloatingEl && open) {\n enqueueFocus(elToFocus, {\n preventScroll: elToFocus === floating\n });\n }\n });\n }, [disabled, open, floating, ignoreInitialFocus, getTabbableElements, initialFocusRef]);\n index(() => {\n if (disabled || !floating) return;\n let preventReturnFocusScroll = false;\n const doc = getDocument(floating);\n const previouslyFocusedElement = activeElement(doc);\n const contextData = dataRef.current;\n addPreviouslyFocusedElement(previouslyFocusedElement);\n\n // Dismissing via outside press should always ignore `returnFocus` to\n // prevent unwanted scrolling.\n function onOpenChange(_ref) {\n let {\n reason,\n event,\n nested\n } = _ref;\n if (reason === 'escape-key' && refs.domReference.current) {\n addPreviouslyFocusedElement(refs.domReference.current);\n }\n if (reason === 'hover' && event.type === 'mouseleave') {\n preventReturnFocusRef.current = true;\n }\n if (reason !== 'outside-press') return;\n if (nested) {\n preventReturnFocusRef.current = false;\n preventReturnFocusScroll = true;\n } else {\n preventReturnFocusRef.current = !(isVirtualClick(event) || isVirtualPointerEvent(event));\n }\n }\n events.on('openchange', onOpenChange);\n return () => {\n events.off('openchange', onOpenChange);\n const activeEl = activeElement(doc);\n const isFocusInsideFloatingTree = contains(floating, activeEl) || tree && getChildren(tree.nodesRef.current, nodeId).some(node => {\n var _node$context5;\n return contains((_node$context5 = node.context) == null ? void 0 : _node$context5.elements.floating, activeEl);\n });\n const shouldFocusReference = isFocusInsideFloatingTree || contextData.openEvent && ['click', 'mousedown'].includes(contextData.openEvent.type);\n if (shouldFocusReference && refs.domReference.current) {\n addPreviouslyFocusedElement(refs.domReference.current);\n }\n const returnElement = getPreviouslyFocusedElement();\n if (\n // eslint-disable-next-line react-hooks/exhaustive-deps\n returnFocusRef.current && !preventReturnFocusRef.current && isHTMLElement(returnElement) && (\n // If the focus moved somewhere else after mount, avoid returning focus\n // since it likely entered a different element which should be\n // respected: https://github.com/floating-ui/floating-ui/issues/2607\n returnElement !== activeEl && activeEl !== doc.body ? isFocusInsideFloatingTree : true)) {\n enqueueFocus(returnElement, {\n // When dismissing nested floating elements, by the time the rAF has\n // executed, the menus will all have been unmounted. When they try\n // to get focused, the calls get ignored — leaving the root\n // reference focused as desired.\n cancelPrevious: false,\n preventScroll: preventReturnFocusScroll\n });\n }\n };\n }, [disabled, floating, returnFocusRef, dataRef, refs, events, tree, nodeId]);\n\n // Synchronize the `context` & `modal` value to the FloatingPortal context.\n // It will decide whether or not it needs to render its own guards.\n index(() => {\n if (disabled || !portalContext) return;\n portalContext.setFocusManagerState({\n modal,\n closeOnFocusOut,\n open,\n onOpenChange,\n refs\n });\n return () => {\n portalContext.setFocusManagerState(null);\n };\n }, [disabled, portalContext, modal, open, onOpenChange, refs, closeOnFocusOut]);\n index(() => {\n if (disabled || !floating || typeof MutationObserver !== 'function' || ignoreInitialFocus) {\n return;\n }\n const handleMutation = () => {\n const tabIndex = floating.getAttribute('tabindex');\n if (orderRef.current.includes('floating') || activeElement(getDocument(floating)) !== refs.domReference.current && getTabbableContent().length === 0) {\n if (tabIndex !== '0') {\n floating.setAttribute('tabindex', '0');\n }\n } else if (tabIndex !== '-1') {\n floating.setAttribute('tabindex', '-1');\n }\n };\n handleMutation();\n const observer = new MutationObserver(handleMutation);\n observer.observe(floating, {\n childList: true,\n subtree: true,\n attributes: true\n });\n return () => {\n observer.disconnect();\n };\n }, [disabled, floating, refs, orderRef, getTabbableContent, ignoreInitialFocus]);\n function renderDismissButton(location) {\n if (disabled || !visuallyHiddenDismiss || !modal) {\n return null;\n }\n return /*#__PURE__*/React.createElement(VisuallyHiddenDismiss, {\n ref: location === 'start' ? startDismissButtonRef : endDismissButtonRef,\n onClick: event => onOpenChange(false, event.nativeEvent)\n }, typeof visuallyHiddenDismiss === 'string' ? visuallyHiddenDismiss : 'Dismiss');\n }\n const shouldRenderGuards = !disabled && guards && (isInsidePortal || modal);\n return /*#__PURE__*/React.createElement(React.Fragment, null, shouldRenderGuards && /*#__PURE__*/React.createElement(FocusGuard, {\n \"data-type\": \"inside\",\n ref: portalContext == null ? void 0 : portalContext.beforeInsideRef,\n onFocus: event => {\n if (modal) {\n const els = getTabbableElements();\n enqueueFocus(order[0] === 'reference' ? els[0] : els[els.length - 1]);\n } else if (portalContext != null && portalContext.preserveTabOrder && portalContext.portalNode) {\n preventReturnFocusRef.current = false;\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const nextTabbable = getNextTabbable() || domReference;\n nextTabbable == null || nextTabbable.focus();\n } else {\n var _portalContext$before;\n (_portalContext$before = portalContext.beforeOutsideRef.current) == null || _portalContext$before.focus();\n }\n }\n }\n }), !isUntrappedTypeableCombobox && renderDismissButton('start'), children, renderDismissButton('end'), shouldRenderGuards && /*#__PURE__*/React.createElement(FocusGuard, {\n \"data-type\": \"inside\",\n ref: portalContext == null ? void 0 : portalContext.afterInsideRef,\n onFocus: event => {\n if (modal) {\n enqueueFocus(getTabbableElements()[0]);\n } else if (portalContext != null && portalContext.preserveTabOrder && portalContext.portalNode) {\n if (closeOnFocusOut) {\n preventReturnFocusRef.current = true;\n }\n if (isOutsideEvent(event, portalContext.portalNode)) {\n const prevTabbable = getPreviousTabbable() || domReference;\n prevTabbable == null || prevTabbable.focus();\n } else {\n var _portalContext$afterO;\n (_portalContext$afterO = portalContext.afterOutsideRef.current) == null || _portalContext$afterO.focus();\n }\n }\n }\n }));\n}\n\nconst activeLocks = /*#__PURE__*/new Set();\n\n/**\n * Provides base styling for a fixed overlay element to dim content or block\n * pointer events behind a floating element.\n * It's a regular `<div>`, so it can be styled via any CSS solution you prefer.\n * @see https://floating-ui.com/docs/FloatingOverlay\n */\nconst FloatingOverlay = /*#__PURE__*/React.forwardRef(function FloatingOverlay(_ref, ref) {\n let {\n lockScroll = false,\n ...rest\n } = _ref;\n const lockId = useId();\n index(() => {\n if (!lockScroll) return;\n activeLocks.add(lockId);\n const isIOS = /iP(hone|ad|od)|iOS/.test(getPlatform());\n const bodyStyle = document.body.style;\n // RTL <body> scrollbar\n const scrollbarX = Math.round(document.documentElement.getBoundingClientRect().left) + document.documentElement.scrollLeft;\n const paddingProp = scrollbarX ? 'paddingLeft' : 'paddingRight';\n const scrollbarWidth = window.innerWidth - document.documentElement.clientWidth;\n const scrollX = bodyStyle.left ? parseFloat(bodyStyle.left) : window.pageXOffset;\n const scrollY = bodyStyle.top ? parseFloat(bodyStyle.top) : window.pageYOffset;\n bodyStyle.overflow = 'hidden';\n if (scrollbarWidth) {\n bodyStyle[paddingProp] = scrollbarWidth + \"px\";\n }\n\n // Only iOS doesn't respect `overflow: hidden` on document.body, and this\n // technique has fewer side effects.\n if (isIOS) {\n var _window$visualViewpor, _window$visualViewpor2;\n // iOS 12 does not support `visualViewport`.\n const offsetLeft = ((_window$visualViewpor = window.visualViewport) == null ? void 0 : _window$visualViewpor.offsetLeft) || 0;\n const offsetTop = ((_window$visualViewpor2 = window.visualViewport) == null ? void 0 : _window$visualViewpor2.offsetTop) || 0;\n Object.assign(bodyStyle, {\n position: 'fixed',\n top: -(scrollY - Math.floor(offsetTop)) + \"px\",\n left: -(scrollX - Math.floor(offsetLeft)) + \"px\",\n right: '0'\n });\n }\n return () => {\n activeLocks.delete(lockId);\n if (activeLocks.size === 0) {\n Object.assign(bodyStyle, {\n overflow: '',\n [paddingProp]: ''\n });\n if (isIOS) {\n Object.assign(bodyStyle, {\n position: '',\n top: '',\n left: '',\n right: ''\n });\n window.scrollTo(scrollX, scrollY);\n }\n }\n };\n }, [lockId, lockScroll]);\n return /*#__PURE__*/React.createElement(\"div\", _extends({\n ref: ref\n }, rest, {\n style: {\n position: 'fixed',\n overflow: 'auto',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...rest.style\n }\n }));\n});\n\nfunction isButtonTarget(event) {\n return isHTMLElement(event.target) && event.target.tagName === 'BUTTON';\n}\nfunction isSpaceIgnored(element) {\n return isTypeableElement(element);\n}\n/**\n * Opens or closes the floating element when clicking the reference element.\n * @see https://floating-ui.com/docs/useClick\n */\nfunction useClick(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n dataRef,\n elements: {\n domReference\n }\n } = context;\n const {\n enabled = true,\n event: eventOption = 'click',\n toggle = true,\n ignoreMouse = false,\n keyboardHandlers = true\n } = props;\n const pointerTypeRef = React.useRef();\n const didKeyDownRef = React.useRef(false);\n return React.useMemo(() => {\n if (!enabled) return {};\n return {\n reference: {\n onPointerDown(event) {\n pointerTypeRef.current = event.pointerType;\n },\n onMouseDown(event) {\n // Ignore all buttons except for the \"main\" button.\n // https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/button\n if (event.button !== 0) {\n return;\n }\n if (isMouseLikePointerType(pointerTypeRef.current, true) && ignoreMouse) {\n return;\n }\n if (eventOption === 'click') {\n return;\n }\n if (open && toggle && (dataRef.current.openEvent ? dataRef.current.openEvent.type === 'mousedown' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n // Prevent stealing focus from the floating element\n event.preventDefault();\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onClick(event) {\n if (eventOption === 'mousedown' && pointerTypeRef.current) {\n pointerTypeRef.current = undefined;\n return;\n }\n if (isMouseLikePointerType(pointerTypeRef.current, true) && ignoreMouse) {\n return;\n }\n if (open && toggle && (dataRef.current.openEvent ? dataRef.current.openEvent.type === 'click' : true)) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n },\n onKeyDown(event) {\n pointerTypeRef.current = undefined;\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event)) {\n return;\n }\n if (event.key === ' ' && !isSpaceIgnored(domReference)) {\n // Prevent scrolling\n event.preventDefault();\n didKeyDownRef.current = true;\n }\n if (event.key === 'Enter') {\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n },\n onKeyUp(event) {\n if (event.defaultPrevented || !keyboardHandlers || isButtonTarget(event) || isSpaceIgnored(domReference)) {\n return;\n }\n if (event.key === ' ' && didKeyDownRef.current) {\n didKeyDownRef.current = false;\n if (open && toggle) {\n onOpenChange(false, event.nativeEvent, 'click');\n } else {\n onOpenChange(true, event.nativeEvent, 'click');\n }\n }\n }\n }\n };\n }, [enabled, dataRef, eventOption, ignoreMouse, keyboardHandlers, domReference, toggle, open, onOpenChange]);\n}\n\nfunction createVirtualElement(domRef, data) {\n let offsetX = null;\n let offsetY = null;\n let isAutoUpdateEvent = false;\n return {\n contextElement: domRef.current || undefined,\n getBoundingClientRect() {\n var _domRef$current, _data$dataRef$current;\n const domRect = ((_domRef$current = domRef.current) == null ? void 0 : _domRef$current.getBoundingClientRect()) || {\n width: 0,\n height: 0,\n x: 0,\n y: 0\n };\n const isXAxis = data.axis === 'x' || data.axis === 'both';\n const isYAxis = data.axis === 'y' || data.axis === 'both';\n const canTrackCursorOnAutoUpdate = ['mouseenter', 'mousemove'].includes(((_data$dataRef$current = data.dataRef.current.openEvent) == null ? void 0 : _data$dataRef$current.type) || '') && data.pointerType !== 'touch';\n let width = domRect.width;\n let height = domRect.height;\n let x = domRect.x;\n let y = domRect.y;\n if (offsetX == null && data.x && isXAxis) {\n offsetX = domRect.x - data.x;\n }\n if (offsetY == null && data.y && isYAxis) {\n offsetY = domRect.y - data.y;\n }\n x -= offsetX || 0;\n y -= offsetY || 0;\n width = 0;\n height = 0;\n if (!isAutoUpdateEvent || canTrackCursorOnAutoUpdate) {\n width = data.axis === 'y' ? domRect.width : 0;\n height = data.axis === 'x' ? domRect.height : 0;\n x = isXAxis && data.x != null ? data.x : x;\n y = isYAxis && data.y != null ? data.y : y;\n } else if (isAutoUpdateEvent && !canTrackCursorOnAutoUpdate) {\n height = data.axis === 'x' ? domRect.height : height;\n width = data.axis === 'y' ? domRect.width : width;\n }\n isAutoUpdateEvent = true;\n return {\n width,\n height,\n x,\n y,\n top: y,\n right: x + width,\n bottom: y + height,\n left: x\n };\n }\n };\n}\nfunction isMouseBasedEvent(event) {\n return event != null && event.clientX != null;\n}\n/**\n * Positions the floating element relative to a client point (in the viewport),\n * such as the mouse position. By default, it follows the mouse cursor.\n * @see https://floating-ui.com/docs/useClientPoint\n */\nfunction useClientPoint(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n refs,\n dataRef,\n elements: {\n floating\n }\n } = context;\n const {\n enabled = true,\n axis = 'both',\n x = null,\n y = null\n } = props;\n const initialRef = React.useRef(false);\n const cleanupListenerRef = React.useRef(null);\n const [pointerType, setPointerType] = React.useState();\n const [reactive, setReactive] = React.useState([]);\n const setReference = useEffectEvent((x, y) => {\n if (initialRef.current) return;\n\n // Prevent setting if the open event was not a mouse-like one\n // (e.g. focus to open, then hover over the reference element).\n // Only apply if the event exists.\n if (dataRef.current.openEvent && !isMouseBasedEvent(dataRef.current.openEvent)) {\n return;\n }\n refs.setPositionReference(createVirtualElement(refs.domReference, {\n x,\n y,\n axis,\n dataRef,\n pointerType\n }));\n });\n const handleReferenceEnterOrMove = useEffectEvent(event => {\n if (x != null || y != null) return;\n if (!open) {\n setReference(event.clientX, event.clientY);\n } else if (!cleanupListenerRef.current) {\n // If there's no cleanup, there's no listener, but we want to ensure\n // we add the listener if the cursor landed on the floating element and\n // then back on the reference (i.e. it's interactive).\n setReactive([]);\n }\n });\n\n // If the pointer is a mouse-like pointer, we want to continue following the\n // mouse even if the floating element is transitioning out. On touch\n // devices, this is undesirable because the floating element will move to\n // the dismissal touch point.\n const openCheck = isMouseLikePointerType(pointerType) ? floating : open;\n const addListener = React.useCallback(() => {\n // Explicitly specified `x`/`y` coordinates shouldn't add a listener.\n if (!openCheck || !enabled || x != null || y != null) return;\n const win = getWindow(refs.floating.current);\n function handleMouseMove(event) {\n const target = getTarget(event);\n if (!contains(refs.floating.current, target)) {\n setReference(event.clientX, event.clientY);\n } else {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n }\n }\n if (!dataRef.current.openEvent || isMouseBasedEvent(dataRef.current.openEvent)) {\n win.addEventListener('mousemove', handleMouseMove);\n const cleanup = () => {\n win.removeEventListener('mousemove', handleMouseMove);\n cleanupListenerRef.current = null;\n };\n cleanupListenerRef.current = cleanup;\n return cleanup;\n }\n refs.setPositionReference(refs.domReference.current);\n }, [dataRef, enabled, openCheck, refs, setReference, x, y]);\n React.useEffect(() => {\n return addListener();\n }, [addListener, reactive]);\n React.useEffect(() => {\n if (enabled && !floating) {\n initialRef.current = false;\n }\n }, [enabled, floating]);\n React.useEffect(() => {\n if (!enabled && open) {\n initialRef.current = true;\n }\n }, [enabled, open]);\n index(() => {\n if (enabled && (x != null || y != null)) {\n initialRef.current = false;\n setReference(x, y);\n }\n }, [enabled, x, y, setReference]);\n return React.useMemo(() => {\n if (!enabled) return {};\n function setPointerTypeRef(_ref) {\n let {\n pointerType\n } = _ref;\n setPointerType(pointerType);\n }\n return {\n reference: {\n onPointerDown: setPointerTypeRef,\n onPointerEnter: setPointerTypeRef,\n onMouseMove: handleReferenceEnterOrMove,\n onMouseEnter: handleReferenceEnterOrMove\n }\n };\n }, [enabled, handleReferenceEnterOrMove]);\n}\n\nconst bubbleHandlerKeys = {\n pointerdown: 'onPointerDown',\n mousedown: 'onMouseDown',\n click: 'onClick'\n};\nconst captureHandlerKeys = {\n pointerdown: 'onPointerDownCapture',\n mousedown: 'onMouseDownCapture',\n click: 'onClickCapture'\n};\nconst normalizeProp = normalizable => {\n var _normalizable$escapeK, _normalizable$outside;\n return {\n escapeKey: typeof normalizable === 'boolean' ? normalizable : (_normalizable$escapeK = normalizable == null ? void 0 : normalizable.escapeKey) != null ? _normalizable$escapeK : false,\n outsidePress: typeof normalizable === 'boolean' ? normalizable : (_normalizable$outside = normalizable == null ? void 0 : normalizable.outsidePress) != null ? _normalizable$outside : true\n };\n};\n/**\n * Closes the floating element when a dismissal is requested — by default, when\n * the user presses the `escape` key or outside of the floating element.\n * @see https://floating-ui.com/docs/useDismiss\n */\nfunction useDismiss(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n nodeId,\n elements: {\n reference,\n domReference,\n floating\n },\n dataRef\n } = context;\n const {\n enabled = true,\n escapeKey = true,\n outsidePress: unstable_outsidePress = true,\n outsidePressEvent = 'pointerdown',\n referencePress = false,\n referencePressEvent = 'pointerdown',\n ancestorScroll = false,\n bubbles,\n capture\n } = props;\n const tree = useFloatingTree();\n const outsidePressFn = useEffectEvent(typeof unstable_outsidePress === 'function' ? unstable_outsidePress : () => false);\n const outsidePress = typeof unstable_outsidePress === 'function' ? outsidePressFn : unstable_outsidePress;\n const insideReactTreeRef = React.useRef(false);\n const endedOrStartedInsideRef = React.useRef(false);\n const {\n escapeKey: escapeKeyBubbles,\n outsidePress: outsidePressBubbles\n } = normalizeProp(bubbles);\n const {\n escapeKey: escapeKeyCapture,\n outsidePress: outsidePressCapture\n } = normalizeProp(capture);\n const closeOnEscapeKeyDown = useEffectEvent(event => {\n if (!open || !enabled || !escapeKey || event.key !== 'Escape') {\n return;\n }\n const children = tree ? getChildren(tree.nodesRef.current, nodeId) : [];\n if (!escapeKeyBubbles) {\n event.stopPropagation();\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n var _child$context;\n if ((_child$context = child.context) != null && _child$context.open && !child.context.dataRef.current.__escapeKeyBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n }\n onOpenChange(false, isReactEvent(event) ? event.nativeEvent : event, 'escape-key');\n });\n const closeOnEscapeKeyDownCapture = useEffectEvent(event => {\n var _getTarget2;\n const callback = () => {\n var _getTarget;\n closeOnEscapeKeyDown(event);\n (_getTarget = getTarget(event)) == null || _getTarget.removeEventListener('keydown', callback);\n };\n (_getTarget2 = getTarget(event)) == null || _getTarget2.addEventListener('keydown', callback);\n });\n const closeOnPressOutside = useEffectEvent(event => {\n // Given developers can stop the propagation of the synthetic event,\n // we can only be confident with a positive value.\n const insideReactTree = insideReactTreeRef.current;\n insideReactTreeRef.current = false;\n\n // When click outside is lazy (`click` event), handle dragging.\n // Don't close if:\n // - The click started inside the floating element.\n // - The click ended inside the floating element.\n const endedOrStartedInside = endedOrStartedInsideRef.current;\n endedOrStartedInsideRef.current = false;\n if (outsidePressEvent === 'click' && endedOrStartedInside) {\n return;\n }\n if (insideReactTree) {\n return;\n }\n if (typeof outsidePress === 'function' && !outsidePress(event)) {\n return;\n }\n const target = getTarget(event);\n const inertSelector = \"[\" + createAttribute('inert') + \"]\";\n const markers = getDocument(floating).querySelectorAll(inertSelector);\n let targetRootAncestor = isElement(target) ? target : null;\n while (targetRootAncestor && !isLastTraversableNode(targetRootAncestor)) {\n const nextParent = getParentNode(targetRootAncestor);\n if (isLastTraversableNode(nextParent) || !isElement(nextParent)) {\n break;\n } else {\n targetRootAncestor = nextParent;\n }\n }\n\n // Check if the click occurred on a third-party element injected after the\n // floating element rendered.\n if (markers.length && isElement(target) && !isRootElement(target) &&\n // Clicked on a direct ancestor (e.g. FloatingOverlay).\n !contains(target, floating) &&\n // If the target root element contains none of the markers, then the\n // element was injected after the floating element rendered.\n Array.from(markers).every(marker => !contains(targetRootAncestor, marker))) {\n return;\n }\n\n // Check if the click occurred on the scrollbar\n if (isHTMLElement(target) && floating) {\n // In Firefox, `target.scrollWidth > target.clientWidth` for inline\n // elements.\n const canScrollX = target.clientWidth > 0 && target.scrollWidth > target.clientWidth;\n const canScrollY = target.clientHeight > 0 && target.scrollHeight > target.clientHeight;\n let xCond = canScrollY && event.offsetX > target.clientWidth;\n\n // In some browsers it is possible to change the <body> (or window)\n // scrollbar to the left side, but is very rare and is difficult to\n // check for. Plus, for modal dialogs with backdrops, it is more\n // important that the backdrop is checked but not so much the window.\n if (canScrollY) {\n const isRTL = getComputedStyle(target).direction === 'rtl';\n if (isRTL) {\n xCond = event.offsetX <= target.offsetWidth - target.clientWidth;\n }\n }\n if (xCond || canScrollX && event.offsetY > target.clientHeight) {\n return;\n }\n }\n const targetIsInsideChildren = tree && getChildren(tree.nodesRef.current, nodeId).some(node => {\n var _node$context;\n return isEventTargetWithin(event, (_node$context = node.context) == null ? void 0 : _node$context.elements.floating);\n });\n if (isEventTargetWithin(event, floating) || isEventTargetWithin(event, domReference) || targetIsInsideChildren) {\n return;\n }\n const children = tree ? getChildren(tree.nodesRef.current, nodeId) : [];\n if (children.length > 0) {\n let shouldDismiss = true;\n children.forEach(child => {\n var _child$context2;\n if ((_child$context2 = child.context) != null && _child$context2.open && !child.context.dataRef.current.__outsidePressBubbles) {\n shouldDismiss = false;\n return;\n }\n });\n if (!shouldDismiss) {\n return;\n }\n }\n onOpenChange(false, event, 'outside-press');\n });\n const closeOnPressOutsideCapture = useEffectEvent(event => {\n var _getTarget4;\n const callback = () => {\n var _getTarget3;\n closeOnPressOutside(event);\n (_getTarget3 = getTarget(event)) == null || _getTarget3.removeEventListener(outsidePressEvent, callback);\n };\n (_getTarget4 = getTarget(event)) == null || _getTarget4.addEventListener(outsidePressEvent, callback);\n });\n React.useEffect(() => {\n if (!open || !enabled) {\n return;\n }\n dataRef.current.__escapeKeyBubbles = escapeKeyBubbles;\n dataRef.current.__outsidePressBubbles = outsidePressBubbles;\n function onScroll(event) {\n onOpenChange(false, event, 'ancestor-scroll');\n }\n const doc = getDocument(floating);\n escapeKey && doc.addEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n outsidePress && doc.addEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n let ancestors = [];\n if (ancestorScroll) {\n if (isElement(domReference)) {\n ancestors = getOverflowAncestors(domReference);\n }\n if (isElement(floating)) {\n ancestors = ancestors.concat(getOverflowAncestors(floating));\n }\n if (!isElement(reference) && reference && reference.contextElement) {\n ancestors = ancestors.concat(getOverflowAncestors(reference.contextElement));\n }\n }\n\n // Ignore the visual viewport for scrolling dismissal (allow pinch-zoom)\n ancestors = ancestors.filter(ancestor => {\n var _doc$defaultView;\n return ancestor !== ((_doc$defaultView = doc.defaultView) == null ? void 0 : _doc$defaultView.visualViewport);\n });\n ancestors.forEach(ancestor => {\n ancestor.addEventListener('scroll', onScroll, {\n passive: true\n });\n });\n return () => {\n escapeKey && doc.removeEventListener('keydown', escapeKeyCapture ? closeOnEscapeKeyDownCapture : closeOnEscapeKeyDown, escapeKeyCapture);\n outsidePress && doc.removeEventListener(outsidePressEvent, outsidePressCapture ? closeOnPressOutsideCapture : closeOnPressOutside, outsidePressCapture);\n ancestors.forEach(ancestor => {\n ancestor.removeEventListener('scroll', onScroll);\n });\n };\n }, [dataRef, floating, domReference, reference, escapeKey, outsidePress, outsidePressEvent, open, onOpenChange, ancestorScroll, enabled, escapeKeyBubbles, outsidePressBubbles, closeOnEscapeKeyDown, escapeKeyCapture, closeOnEscapeKeyDownCapture, closeOnPressOutside, outsidePressCapture, closeOnPressOutsideCapture]);\n React.useEffect(() => {\n insideReactTreeRef.current = false;\n }, [outsidePress, outsidePressEvent]);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n return {\n reference: {\n onKeyDown: closeOnEscapeKeyDown,\n [bubbleHandlerKeys[referencePressEvent]]: event => {\n if (referencePress) {\n onOpenChange(false, event.nativeEvent, 'reference-press');\n }\n }\n },\n floating: {\n onKeyDown: closeOnEscapeKeyDown,\n onMouseDown() {\n endedOrStartedInsideRef.current = true;\n },\n onMouseUp() {\n endedOrStartedInsideRef.current = true;\n },\n [captureHandlerKeys[outsidePressEvent]]: () => {\n insideReactTreeRef.current = true;\n }\n }\n };\n }, [enabled, referencePress, outsidePressEvent, referencePressEvent, onOpenChange, closeOnEscapeKeyDown]);\n}\n\nlet devMessageSet;\nif (process.env.NODE_ENV !== \"production\") {\n devMessageSet = /*#__PURE__*/new Set();\n}\n\n/**\n * Provides data to position a floating element and context to add interactions.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n var _options$elements2;\n if (options === void 0) {\n options = {};\n }\n const {\n open = false,\n onOpenChange: unstable_onOpenChange,\n nodeId\n } = options;\n if (process.env.NODE_ENV !== \"production\") {\n var _options$elements;\n const err = 'Floating UI: Cannot pass a virtual element to the ' + '`elements.reference` option, as it must be a real DOM element. ' + 'Use `refs.setPositionReference` instead.';\n if ((_options$elements = options.elements) != null && _options$elements.reference && !isElement(options.elements.reference)) {\n var _devMessageSet;\n if (!((_devMessageSet = devMessageSet) != null && _devMessageSet.has(err))) {\n var _devMessageSet2;\n (_devMessageSet2 = devMessageSet) == null || _devMessageSet2.add(err);\n console.error(err);\n }\n }\n }\n const [_domReference, setDomReference] = React.useState(null);\n const domReference = ((_options$elements2 = options.elements) == null ? void 0 : _options$elements2.reference) || _domReference;\n const position = useFloating$1(options);\n const tree = useFloatingTree();\n const nested = useFloatingParentNodeId() != null;\n const onOpenChange = useEffectEvent((open, event, reason) => {\n if (open) {\n dataRef.current.openEvent = event;\n }\n events.emit('openchange', {\n open,\n event,\n reason,\n nested\n });\n unstable_onOpenChange == null || unstable_onOpenChange(open, event, reason);\n });\n const domReferenceRef = React.useRef(null);\n const dataRef = React.useRef({});\n const events = React.useState(() => createPubSub())[0];\n const floatingId = useId();\n const setPositionReference = React.useCallback(node => {\n const positionReference = isElement(node) ? {\n getBoundingClientRect: () => node.getBoundingClientRect(),\n contextElement: node\n } : node;\n position.refs.setReference(positionReference);\n }, [position.refs]);\n const setReference = React.useCallback(node => {\n if (isElement(node) || node === null) {\n domReferenceRef.current = node;\n setDomReference(node);\n }\n\n // Backwards-compatibility for passing a virtual element to `reference`\n // after it has set the DOM reference.\n if (isElement(position.refs.reference.current) || position.refs.reference.current === null ||\n // Don't allow setting virtual elements using the old technique back to\n // `null` to support `positionReference` + an unstable `reference`\n // callback ref.\n node !== null && !isElement(node)) {\n position.refs.setReference(node);\n }\n }, [position.refs]);\n const refs = React.useMemo(() => ({\n ...position.refs,\n setReference,\n setPositionReference,\n domReference: domReferenceRef\n }), [position.refs, setReference, setPositionReference]);\n const elements = React.useMemo(() => ({\n ...position.elements,\n domReference: domReference\n }), [position.elements, domReference]);\n const context = React.useMemo(() => ({\n ...position,\n refs,\n elements,\n dataRef,\n nodeId,\n floatingId,\n events,\n open,\n onOpenChange\n }), [position, nodeId, floatingId, events, open, onOpenChange, refs, elements]);\n index(() => {\n const node = tree == null ? void 0 : tree.nodesRef.current.find(node => node.id === nodeId);\n if (node) {\n node.context = context;\n }\n });\n return React.useMemo(() => ({\n ...position,\n context,\n refs,\n elements\n }), [position, refs, elements, context]);\n}\n\n/**\n * Opens the floating element while the reference element has focus, like CSS\n * `:focus`.\n * @see https://floating-ui.com/docs/useFocus\n */\nfunction useFocus(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n onOpenChange,\n events,\n refs,\n elements: {\n floating,\n domReference\n }\n } = context;\n const {\n enabled = true,\n visibleOnly = true\n } = props;\n const blockFocusRef = React.useRef(false);\n const timeoutRef = React.useRef();\n const keyboardModalityRef = React.useRef(true);\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n const win = getWindow(domReference);\n\n // If the reference was focused and the user left the tab/window, and the\n // floating element was not open, the focus should be blocked when they\n // return to the tab/window.\n function onBlur() {\n if (!open && isHTMLElement(domReference) && domReference === activeElement(getDocument(domReference))) {\n blockFocusRef.current = true;\n }\n }\n function onKeyDown() {\n keyboardModalityRef.current = true;\n }\n win.addEventListener('blur', onBlur);\n win.addEventListener('keydown', onKeyDown, true);\n return () => {\n win.removeEventListener('blur', onBlur);\n win.removeEventListener('keydown', onKeyDown, true);\n };\n }, [floating, domReference, open, enabled]);\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n function onOpenChange(_ref) {\n let {\n reason\n } = _ref;\n if (reason === 'reference-press' || reason === 'escape-key') {\n blockFocusRef.current = true;\n }\n }\n events.on('openchange', onOpenChange);\n return () => {\n events.off('openchange', onOpenChange);\n };\n }, [events, enabled]);\n React.useEffect(() => {\n return () => {\n clearTimeout(timeoutRef.current);\n };\n }, []);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n return {\n reference: {\n onPointerDown(event) {\n if (isVirtualPointerEvent(event.nativeEvent)) return;\n keyboardModalityRef.current = false;\n },\n onMouseLeave() {\n blockFocusRef.current = false;\n },\n onFocus(event) {\n if (blockFocusRef.current) return;\n const target = getTarget(event.nativeEvent);\n if (visibleOnly && isElement(target)) {\n try {\n // Mac Safari unreliably matches `:focus-visible` on the reference\n // if focus was outside the page initially - use the fallback\n // instead.\n if (isSafari() && isMac()) throw Error();\n if (!target.matches(':focus-visible')) return;\n } catch (e) {\n // Old browsers will throw an error when using `:focus-visible`.\n if (!keyboardModalityRef.current && !isTypeableElement(target)) {\n return;\n }\n }\n }\n onOpenChange(true, event.nativeEvent, 'focus');\n },\n onBlur(event) {\n blockFocusRef.current = false;\n const relatedTarget = event.relatedTarget;\n\n // Hit the non-modal focus management portal guard. Focus will be\n // moved into the floating element immediately after.\n const movedToFocusGuard = isElement(relatedTarget) && relatedTarget.hasAttribute(createAttribute('focus-guard')) && relatedTarget.getAttribute('data-type') === 'outside';\n\n // Wait for the window blur listener to fire.\n timeoutRef.current = window.setTimeout(() => {\n const activeEl = activeElement(domReference ? domReference.ownerDocument : document);\n\n // Focus left the page, keep it open.\n if (!relatedTarget && activeEl === domReference) return;\n\n // When focusing the reference element (e.g. regular click), then\n // clicking into the floating element, prevent it from hiding.\n // Note: it must be focusable, e.g. `tabindex=\"-1\"`.\n if (contains(refs.floating.current, relatedTarget) || contains(domReference, relatedTarget) || movedToFocusGuard) {\n return;\n }\n onOpenChange(false, event.nativeEvent, 'focus');\n });\n }\n }\n };\n }, [enabled, visibleOnly, domReference, refs, onOpenChange]);\n}\n\nconst ACTIVE_KEY = 'active';\nconst SELECTED_KEY = 'selected';\nfunction mergeProps(userProps, propsList, elementKey) {\n const map = new Map();\n const isItem = elementKey === 'item';\n let domUserProps = userProps;\n if (isItem && userProps) {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const {\n [ACTIVE_KEY]: _,\n [SELECTED_KEY]: __,\n ...validProps\n } = userProps;\n domUserProps = validProps;\n }\n return {\n ...(elementKey === 'floating' && {\n tabIndex: -1\n }),\n ...domUserProps,\n ...propsList.map(value => {\n const propsOrGetProps = value ? value[elementKey] : null;\n if (typeof propsOrGetProps === 'function') {\n return userProps ? propsOrGetProps(userProps) : null;\n }\n return propsOrGetProps;\n }).concat(userProps).reduce((acc, props) => {\n if (!props) {\n return acc;\n }\n Object.entries(props).forEach(_ref => {\n let [key, value] = _ref;\n if (isItem && [ACTIVE_KEY, SELECTED_KEY].includes(key)) {\n return;\n }\n if (key.indexOf('on') === 0) {\n if (!map.has(key)) {\n map.set(key, []);\n }\n if (typeof value === 'function') {\n var _map$get;\n (_map$get = map.get(key)) == null || _map$get.push(value);\n acc[key] = function () {\n var _map$get2;\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return (_map$get2 = map.get(key)) == null ? void 0 : _map$get2.map(fn => fn(...args)).find(val => val !== undefined);\n };\n }\n } else {\n acc[key] = value;\n }\n });\n return acc;\n }, {})\n };\n}\n\n/**\n * Merges an array of interaction hooks' props into prop getters, allowing\n * event handler functions to be composed together without overwriting one\n * another.\n * @see https://floating-ui.com/docs/useInteractions\n */\nfunction useInteractions(propsList) {\n if (propsList === void 0) {\n propsList = [];\n }\n // The dependencies are a dynamic array, so we can't use the linter's\n // suggestion to add it to the deps array.\n const deps = propsList;\n const getReferenceProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'reference'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n deps);\n const getFloatingProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'floating'),\n // eslint-disable-next-line react-hooks/exhaustive-deps\n deps);\n const getItemProps = React.useCallback(userProps => mergeProps(userProps, propsList, 'item'),\n // Granularly check for `item` changes, because the `getItemProps` getter\n // should be as referentially stable as possible since it may be passed as\n // a prop to many components. All `item` key values must therefore be\n // memoized.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n propsList.map(key => key == null ? void 0 : key.item));\n return React.useMemo(() => ({\n getReferenceProps,\n getFloatingProps,\n getItemProps\n }), [getReferenceProps, getFloatingProps, getItemProps]);\n}\n\nlet isPreventScrollSupported = false;\nfunction doSwitch(orientation, vertical, horizontal) {\n switch (orientation) {\n case 'vertical':\n return vertical;\n case 'horizontal':\n return horizontal;\n default:\n return vertical || horizontal;\n }\n}\nfunction isMainOrientationKey(key, orientation) {\n const vertical = key === ARROW_UP || key === ARROW_DOWN;\n const horizontal = key === ARROW_LEFT || key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isMainOrientationToEndKey(key, orientation, rtl) {\n const vertical = key === ARROW_DOWN;\n const horizontal = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n return doSwitch(orientation, vertical, horizontal) || key === 'Enter' || key == ' ' || key === '';\n}\nfunction isCrossOrientationOpenKey(key, orientation, rtl) {\n const vertical = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;\n const horizontal = key === ARROW_DOWN;\n return doSwitch(orientation, vertical, horizontal);\n}\nfunction isCrossOrientationCloseKey(key, orientation, rtl) {\n const vertical = rtl ? key === ARROW_RIGHT : key === ARROW_LEFT;\n const horizontal = key === ARROW_UP;\n return doSwitch(orientation, vertical, horizontal);\n}\n/**\n * Adds arrow key-based navigation of a list of items, either using real DOM\n * focus or virtual focus.\n * @see https://floating-ui.com/docs/useListNavigation\n */\nfunction useListNavigation(context, props) {\n const {\n open,\n onOpenChange,\n refs,\n elements: {\n domReference,\n floating\n }\n } = context;\n const {\n listRef,\n activeIndex,\n onNavigate: unstable_onNavigate = () => {},\n enabled = true,\n selectedIndex = null,\n allowEscape = false,\n loop = false,\n nested = false,\n rtl = false,\n virtual = false,\n focusItemOnOpen = 'auto',\n focusItemOnHover = true,\n openOnArrowKeyDown = true,\n disabledIndices = undefined,\n orientation = 'vertical',\n cols = 1,\n scrollItemIntoView = true,\n virtualItemRef\n } = props;\n if (process.env.NODE_ENV !== \"production\") {\n if (allowEscape) {\n if (!loop) {\n console.warn(['Floating UI: `useListNavigation` looping must be enabled to allow', 'escaping.'].join(' '));\n }\n if (!virtual) {\n console.warn(['Floating UI: `useListNavigation` must be virtual to allow', 'escaping.'].join(' '));\n }\n }\n if (orientation === 'vertical' && cols > 1) {\n console.warn(['Floating UI: In grid list navigation mode (`cols` > 1), the', '`orientation` should be either \"horizontal\" or \"both\".'].join(' '));\n }\n }\n const parentId = useFloatingParentNodeId();\n const tree = useFloatingTree();\n const onNavigate = useEffectEvent(unstable_onNavigate);\n const focusItemOnOpenRef = React.useRef(focusItemOnOpen);\n const indexRef = React.useRef(selectedIndex != null ? selectedIndex : -1);\n const keyRef = React.useRef(null);\n const isPointerModalityRef = React.useRef(true);\n const previousOnNavigateRef = React.useRef(onNavigate);\n const previousMountedRef = React.useRef(!!floating);\n const forceSyncFocus = React.useRef(false);\n const forceScrollIntoViewRef = React.useRef(false);\n const disabledIndicesRef = useLatestRef(disabledIndices);\n const latestOpenRef = useLatestRef(open);\n const scrollItemIntoViewRef = useLatestRef(scrollItemIntoView);\n const [activeId, setActiveId] = React.useState();\n const [virtualId, setVirtualId] = React.useState();\n const focusItem = useEffectEvent(function (listRef, indexRef, forceScrollIntoView) {\n if (forceScrollIntoView === void 0) {\n forceScrollIntoView = false;\n }\n const item = listRef.current[indexRef.current];\n if (!item) return;\n if (virtual) {\n setActiveId(item.id);\n tree == null || tree.events.emit('virtualfocus', item);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n } else {\n enqueueFocus(item, {\n preventScroll: true,\n // Mac Safari does not move the virtual cursor unless the focus call\n // is sync. However, for the very first focus call, we need to wait\n // for the position to be ready in order to prevent unwanted\n // scrolling. This means the virtual cursor will not move to the first\n // item when first opening the floating element, but will on\n // subsequent calls. `preventScroll` is supported in modern Safari,\n // so we can use that instead.\n // iOS Safari must be async or the first item will not be focused.\n sync: isMac() && isSafari() ? isPreventScrollSupported || forceSyncFocus.current : false\n });\n }\n requestAnimationFrame(() => {\n const scrollIntoViewOptions = scrollItemIntoViewRef.current;\n const shouldScrollIntoView = scrollIntoViewOptions && item && (forceScrollIntoView || !isPointerModalityRef.current);\n if (shouldScrollIntoView) {\n // JSDOM doesn't support `.scrollIntoView()` but it's widely supported\n // by all browsers.\n item.scrollIntoView == null || item.scrollIntoView(typeof scrollIntoViewOptions === 'boolean' ? {\n block: 'nearest',\n inline: 'nearest'\n } : scrollIntoViewOptions);\n }\n });\n });\n index(() => {\n document.createElement('div').focus({\n get preventScroll() {\n isPreventScrollSupported = true;\n return false;\n }\n });\n }, []);\n\n // Sync `selectedIndex` to be the `activeIndex` upon opening the floating\n // element. Also, reset `activeIndex` upon closing the floating element.\n index(() => {\n if (!enabled) {\n return;\n }\n if (open && floating) {\n if (focusItemOnOpenRef.current && selectedIndex != null) {\n // Regardless of the pointer modality, we want to ensure the selected\n // item comes into view when the floating element is opened.\n forceScrollIntoViewRef.current = true;\n onNavigate(selectedIndex);\n }\n } else if (previousMountedRef.current) {\n // Since the user can specify `onNavigate` conditionally\n // (onNavigate: open ? setActiveIndex : setSelectedIndex),\n // we store and call the previous function.\n indexRef.current = -1;\n previousOnNavigateRef.current(null);\n }\n }, [enabled, open, floating, selectedIndex, onNavigate]);\n\n // Sync `activeIndex` to be the focused item while the floating element is\n // open.\n index(() => {\n if (!enabled) {\n return;\n }\n if (open && floating) {\n if (activeIndex == null) {\n forceSyncFocus.current = false;\n if (selectedIndex != null) {\n return;\n }\n\n // Reset while the floating element was open (e.g. the list changed).\n if (previousMountedRef.current) {\n indexRef.current = -1;\n focusItem(listRef, indexRef);\n }\n\n // Initial sync.\n if (!previousMountedRef.current && focusItemOnOpenRef.current && (keyRef.current != null || focusItemOnOpenRef.current === true && keyRef.current == null)) {\n let runs = 0;\n const waitForListPopulated = () => {\n if (listRef.current[0] == null) {\n // Avoid letting the browser paint if possible on the first try,\n // otherwise use rAF. Don't try more than twice, since something\n // is wrong otherwise.\n if (runs < 2) {\n const scheduler = runs ? requestAnimationFrame : queueMicrotask;\n scheduler(waitForListPopulated);\n }\n runs++;\n } else {\n indexRef.current = keyRef.current == null || isMainOrientationToEndKey(keyRef.current, orientation, rtl) || nested ? getMinIndex(listRef, disabledIndicesRef.current) : getMaxIndex(listRef, disabledIndicesRef.current);\n keyRef.current = null;\n onNavigate(indexRef.current);\n }\n };\n waitForListPopulated();\n }\n } else if (!isIndexOutOfBounds(listRef, activeIndex)) {\n indexRef.current = activeIndex;\n focusItem(listRef, indexRef, forceScrollIntoViewRef.current);\n forceScrollIntoViewRef.current = false;\n }\n }\n }, [enabled, open, floating, activeIndex, selectedIndex, nested, listRef, orientation, rtl, onNavigate, focusItem, disabledIndicesRef]);\n\n // Ensure the parent floating element has focus when a nested child closes\n // to allow arrow key navigation to work after the pointer leaves the child.\n index(() => {\n var _nodes$find;\n if (!enabled || floating || !tree || virtual || !previousMountedRef.current) {\n return;\n }\n const nodes = tree.nodesRef.current;\n const parent = (_nodes$find = nodes.find(node => node.id === parentId)) == null || (_nodes$find = _nodes$find.context) == null ? void 0 : _nodes$find.elements.floating;\n const activeEl = activeElement(getDocument(floating));\n const treeContainsActiveEl = nodes.some(node => node.context && contains(node.context.elements.floating, activeEl));\n if (parent && !treeContainsActiveEl && isPointerModalityRef.current) {\n parent.focus({\n preventScroll: true\n });\n }\n }, [enabled, floating, tree, parentId, virtual]);\n index(() => {\n if (!enabled || !tree || !virtual || parentId) return;\n function handleVirtualFocus(item) {\n setVirtualId(item.id);\n if (virtualItemRef) {\n virtualItemRef.current = item;\n }\n }\n tree.events.on('virtualfocus', handleVirtualFocus);\n return () => {\n tree.events.off('virtualfocus', handleVirtualFocus);\n };\n }, [enabled, tree, virtual, parentId, virtualItemRef]);\n index(() => {\n previousOnNavigateRef.current = onNavigate;\n previousMountedRef.current = !!floating;\n });\n index(() => {\n if (!open) {\n keyRef.current = null;\n }\n }, [open]);\n const hasActiveIndex = activeIndex != null;\n const item = React.useMemo(() => {\n function syncCurrentTarget(currentTarget) {\n if (!open) return;\n const index = listRef.current.indexOf(currentTarget);\n if (index !== -1) {\n onNavigate(index);\n }\n }\n const props = {\n onFocus(_ref) {\n let {\n currentTarget\n } = _ref;\n syncCurrentTarget(currentTarget);\n },\n onClick: _ref2 => {\n let {\n currentTarget\n } = _ref2;\n return currentTarget.focus({\n preventScroll: true\n });\n },\n // Safari\n ...(focusItemOnHover && {\n onMouseMove(_ref3) {\n let {\n currentTarget\n } = _ref3;\n syncCurrentTarget(currentTarget);\n },\n onPointerLeave(_ref4) {\n let {\n pointerType\n } = _ref4;\n if (!isPointerModalityRef.current || pointerType === 'touch') {\n return;\n }\n indexRef.current = -1;\n focusItem(listRef, indexRef);\n onNavigate(null);\n if (!virtual) {\n enqueueFocus(refs.floating.current, {\n preventScroll: true\n });\n }\n }\n })\n };\n return props;\n }, [open, refs, focusItem, focusItemOnHover, listRef, onNavigate, virtual]);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n const disabledIndices = disabledIndicesRef.current;\n function onKeyDown(event) {\n isPointerModalityRef.current = false;\n forceSyncFocus.current = true;\n\n // If the floating element is animating out, ignore navigation. Otherwise,\n // the `activeIndex` gets set to 0 despite not being open so the next time\n // the user ArrowDowns, the first item won't be focused.\n if (!latestOpenRef.current && event.currentTarget === refs.floating.current) {\n return;\n }\n if (nested && isCrossOrientationCloseKey(event.key, orientation, rtl)) {\n stopEvent(event);\n onOpenChange(false, event.nativeEvent, 'list-navigation');\n if (isHTMLElement(domReference) && !virtual) {\n domReference.focus();\n }\n return;\n }\n const currentIndex = indexRef.current;\n const minIndex = getMinIndex(listRef, disabledIndices);\n const maxIndex = getMaxIndex(listRef, disabledIndices);\n if (event.key === 'Home') {\n stopEvent(event);\n indexRef.current = minIndex;\n onNavigate(indexRef.current);\n }\n if (event.key === 'End') {\n stopEvent(event);\n indexRef.current = maxIndex;\n onNavigate(indexRef.current);\n }\n\n // Grid navigation.\n if (cols > 1) {\n indexRef.current = getGridNavigatedIndex(listRef, {\n event,\n orientation,\n loop,\n cols,\n disabledIndices,\n minIndex,\n maxIndex,\n prevIndex: indexRef.current,\n stopEvent: true\n });\n onNavigate(indexRef.current);\n if (orientation === 'both') {\n return;\n }\n }\n if (isMainOrientationKey(event.key, orientation)) {\n stopEvent(event);\n\n // Reset the index if no item is focused.\n if (open && !virtual && activeElement(event.currentTarget.ownerDocument) === event.currentTarget) {\n indexRef.current = isMainOrientationToEndKey(event.key, orientation, rtl) ? minIndex : maxIndex;\n onNavigate(indexRef.current);\n return;\n }\n if (isMainOrientationToEndKey(event.key, orientation, rtl)) {\n if (loop) {\n indexRef.current = currentIndex >= maxIndex ? allowEscape && currentIndex !== listRef.current.length ? -1 : minIndex : findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices\n });\n } else {\n indexRef.current = Math.min(maxIndex, findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n disabledIndices\n }));\n }\n } else {\n if (loop) {\n indexRef.current = currentIndex <= minIndex ? allowEscape && currentIndex !== -1 ? listRef.current.length : maxIndex : findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices\n });\n } else {\n indexRef.current = Math.max(minIndex, findNonDisabledIndex(listRef, {\n startingIndex: currentIndex,\n decrement: true,\n disabledIndices\n }));\n }\n }\n if (isIndexOutOfBounds(listRef, indexRef.current)) {\n onNavigate(null);\n } else {\n onNavigate(indexRef.current);\n }\n }\n }\n function checkVirtualMouse(event) {\n if (focusItemOnOpen === 'auto' && isVirtualClick(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n function checkVirtualPointer(event) {\n // `pointerdown` fires first, reset the state then perform the checks.\n focusItemOnOpenRef.current = focusItemOnOpen;\n if (focusItemOnOpen === 'auto' && isVirtualPointerEvent(event.nativeEvent)) {\n focusItemOnOpenRef.current = true;\n }\n }\n const ariaActiveDescendantProp = virtual && open && hasActiveIndex && {\n 'aria-activedescendant': virtualId || activeId\n };\n const activeItem = listRef.current.find(item => (item == null ? void 0 : item.id) === activeId);\n return {\n reference: {\n ...ariaActiveDescendantProp,\n onKeyDown(event) {\n isPointerModalityRef.current = false;\n const isArrowKey = event.key.indexOf('Arrow') === 0;\n const isCrossOpenKey = isCrossOrientationOpenKey(event.key, orientation, rtl);\n const isCrossCloseKey = isCrossOrientationCloseKey(event.key, orientation, rtl);\n const isMainKey = isMainOrientationKey(event.key, orientation);\n const isNavigationKey = (nested ? isCrossOpenKey : isMainKey) || event.key === 'Enter' || event.key.trim() === '';\n if (virtual && open) {\n const rootNode = tree == null ? void 0 : tree.nodesRef.current.find(node => node.parentId == null);\n const deepestNode = tree && rootNode ? getDeepestNode(tree.nodesRef.current, rootNode.id) : null;\n if (isArrowKey && deepestNode && virtualItemRef) {\n const eventObject = new KeyboardEvent('keydown', {\n key: event.key,\n bubbles: true\n });\n if (isCrossOpenKey || isCrossCloseKey) {\n var _deepestNode$context, _deepestNode$context2;\n const isCurrentTarget = ((_deepestNode$context = deepestNode.context) == null ? void 0 : _deepestNode$context.elements.domReference) === event.currentTarget;\n const dispatchItem = isCrossCloseKey && !isCurrentTarget ? (_deepestNode$context2 = deepestNode.context) == null ? void 0 : _deepestNode$context2.elements.domReference : isCrossOpenKey ? activeItem : null;\n if (dispatchItem) {\n stopEvent(event);\n dispatchItem.dispatchEvent(eventObject);\n setVirtualId(undefined);\n }\n }\n if (isMainKey && deepestNode.context) {\n if (deepestNode.context.open && deepestNode.parentId && event.currentTarget !== deepestNode.context.elements.domReference) {\n var _deepestNode$context$;\n stopEvent(event);\n (_deepestNode$context$ = deepestNode.context.elements.domReference) == null || _deepestNode$context$.dispatchEvent(eventObject);\n return;\n }\n }\n }\n return onKeyDown(event);\n }\n\n // If a floating element should not open on arrow key down, avoid\n // setting `activeIndex` while it's closed.\n if (!open && !openOnArrowKeyDown && isArrowKey) {\n return;\n }\n if (isNavigationKey) {\n keyRef.current = nested && isMainKey ? null : event.key;\n }\n if (nested) {\n if (isCrossOpenKey) {\n stopEvent(event);\n if (open) {\n indexRef.current = getMinIndex(listRef, disabledIndices);\n onNavigate(indexRef.current);\n } else {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n }\n }\n return;\n }\n if (isMainKey) {\n if (selectedIndex != null) {\n indexRef.current = selectedIndex;\n }\n stopEvent(event);\n if (!open && openOnArrowKeyDown) {\n onOpenChange(true, event.nativeEvent, 'list-navigation');\n } else {\n onKeyDown(event);\n }\n if (open) {\n onNavigate(indexRef.current);\n }\n }\n },\n onFocus() {\n if (open) {\n onNavigate(null);\n }\n },\n onPointerDown: checkVirtualPointer,\n onMouseDown: checkVirtualMouse,\n onClick: checkVirtualMouse\n },\n floating: {\n 'aria-orientation': orientation === 'both' ? undefined : orientation,\n ...(!isTypeableCombobox(domReference) && ariaActiveDescendantProp),\n onKeyDown,\n onPointerMove() {\n isPointerModalityRef.current = true;\n }\n },\n item\n };\n }, [domReference, refs, activeId, virtualId, disabledIndicesRef, latestOpenRef, listRef, enabled, orientation, rtl, virtual, open, hasActiveIndex, nested, selectedIndex, openOnArrowKeyDown, allowEscape, cols, loop, focusItemOnOpen, onNavigate, onOpenChange, item, tree, virtualItemRef]);\n}\n\nconst componentRoleToAriaRoleMap = /*#__PURE__*/new Map([['select', 'listbox'], ['combobox', 'listbox'], ['label', false]]);\n\n/**\n * Adds base screen reader props to the reference and floating elements for a\n * given floating element `role`.\n * @see https://floating-ui.com/docs/useRole\n */\nfunction useRole(context, props) {\n var _componentRoleToAriaR;\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n floatingId\n } = context;\n const {\n enabled = true,\n role = 'dialog'\n } = props;\n const ariaRole = (_componentRoleToAriaR = componentRoleToAriaRoleMap.get(role)) != null ? _componentRoleToAriaR : role;\n const referenceId = useId();\n const parentId = useFloatingParentNodeId();\n const isNested = parentId != null;\n return React.useMemo(() => {\n if (!enabled) return {};\n const floatingProps = {\n id: floatingId,\n ...(ariaRole && {\n role: ariaRole\n })\n };\n if (ariaRole === 'tooltip' || role === 'label') {\n return {\n reference: {\n [\"aria-\" + (role === 'label' ? 'labelledby' : 'describedby')]: open ? floatingId : undefined\n },\n floating: floatingProps\n };\n }\n return {\n reference: {\n 'aria-expanded': open ? 'true' : 'false',\n 'aria-haspopup': ariaRole === 'alertdialog' ? 'dialog' : ariaRole,\n 'aria-controls': open ? floatingId : undefined,\n ...(ariaRole === 'listbox' && {\n role: 'combobox'\n }),\n ...(ariaRole === 'menu' && {\n id: referenceId\n }),\n ...(ariaRole === 'menu' && isNested && {\n role: 'menuitem'\n }),\n ...(role === 'select' && {\n 'aria-autocomplete': 'none'\n }),\n ...(role === 'combobox' && {\n 'aria-autocomplete': 'list'\n })\n },\n floating: {\n ...floatingProps,\n ...(ariaRole === 'menu' && {\n 'aria-labelledby': referenceId\n })\n },\n item(_ref) {\n let {\n active,\n selected\n } = _ref;\n const commonProps = {\n role: 'option',\n ...(active && {\n id: floatingId + \"-option\"\n })\n };\n\n // For `menu`, we are unable to tell if the item is a `menuitemradio`\n // or `menuitemcheckbox`. For backwards-compatibility reasons, also\n // avoid defaulting to `menuitem` as it may overwrite custom role props.\n switch (role) {\n case 'select':\n return {\n ...commonProps,\n 'aria-selected': active && selected\n };\n case 'combobox':\n {\n return {\n ...commonProps,\n ...(active && {\n 'aria-selected': true\n })\n };\n }\n }\n return {};\n }\n };\n }, [enabled, role, ariaRole, open, floatingId, referenceId, isNested]);\n}\n\n// Converts a JS style key like `backgroundColor` to a CSS transition-property\n// like `background-color`.\nconst camelCaseToKebabCase = str => str.replace(/[A-Z]+(?![a-z])|[A-Z]/g, ($, ofs) => (ofs ? '-' : '') + $.toLowerCase());\nfunction execWithArgsOrReturn(valueOrFn, args) {\n return typeof valueOrFn === 'function' ? valueOrFn(args) : valueOrFn;\n}\nfunction useDelayUnmount(open, durationMs) {\n const [isMounted, setIsMounted] = React.useState(open);\n if (open && !isMounted) {\n setIsMounted(true);\n }\n React.useEffect(() => {\n if (!open) {\n const timeout = setTimeout(() => setIsMounted(false), durationMs);\n return () => clearTimeout(timeout);\n }\n }, [open, durationMs]);\n return isMounted;\n}\n/**\n * Provides a status string to apply CSS transitions to a floating element,\n * correctly handling placement-aware transitions.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstatus\n */\nfunction useTransitionStatus(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n open,\n elements: {\n floating\n }\n } = context;\n const {\n duration = 250\n } = props;\n const isNumberDuration = typeof duration === 'number';\n const closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n const [initiated, setInitiated] = React.useState(false);\n const [status, setStatus] = React.useState('unmounted');\n const isMounted = useDelayUnmount(open, closeDuration);\n\n // `initiated` check prevents this `setState` call from breaking\n // <FloatingPortal />. This call is necessary to ensure subsequent opens\n // after the initial one allows the correct side animation to play when the\n // placement has changed.\n index(() => {\n if (initiated && !isMounted) {\n setStatus('unmounted');\n }\n }, [initiated, isMounted]);\n index(() => {\n if (!floating) return;\n if (open) {\n setStatus('initial');\n const frame = requestAnimationFrame(() => {\n setStatus('open');\n });\n return () => {\n cancelAnimationFrame(frame);\n };\n } else {\n setInitiated(true);\n setStatus('close');\n }\n }, [open, floating]);\n return {\n isMounted,\n status\n };\n}\n/**\n * Provides styles to apply CSS transitions to a floating element, correctly\n * handling placement-aware transitions. Wrapper around `useTransitionStatus`.\n * @see https://floating-ui.com/docs/useTransition#usetransitionstyles\n */\nfunction useTransitionStyles(context, props) {\n if (props === void 0) {\n props = {};\n }\n const {\n initial: unstable_initial = {\n opacity: 0\n },\n open: unstable_open,\n close: unstable_close,\n common: unstable_common,\n duration = 250\n } = props;\n const placement = context.placement;\n const side = placement.split('-')[0];\n const fnArgs = React.useMemo(() => ({\n side,\n placement\n }), [side, placement]);\n const isNumberDuration = typeof duration === 'number';\n const openDuration = (isNumberDuration ? duration : duration.open) || 0;\n const closeDuration = (isNumberDuration ? duration : duration.close) || 0;\n const [styles, setStyles] = React.useState(() => ({\n ...execWithArgsOrReturn(unstable_common, fnArgs),\n ...execWithArgsOrReturn(unstable_initial, fnArgs)\n }));\n const {\n isMounted,\n status\n } = useTransitionStatus(context, {\n duration\n });\n const initialRef = useLatestRef(unstable_initial);\n const openRef = useLatestRef(unstable_open);\n const closeRef = useLatestRef(unstable_close);\n const commonRef = useLatestRef(unstable_common);\n index(() => {\n const initialStyles = execWithArgsOrReturn(initialRef.current, fnArgs);\n const closeStyles = execWithArgsOrReturn(closeRef.current, fnArgs);\n const commonStyles = execWithArgsOrReturn(commonRef.current, fnArgs);\n const openStyles = execWithArgsOrReturn(openRef.current, fnArgs) || Object.keys(initialStyles).reduce((acc, key) => {\n acc[key] = '';\n return acc;\n }, {});\n if (status === 'initial') {\n setStyles(styles => ({\n transitionProperty: styles.transitionProperty,\n ...commonStyles,\n ...initialStyles\n }));\n }\n if (status === 'open') {\n setStyles({\n transitionProperty: Object.keys(openStyles).map(camelCaseToKebabCase).join(','),\n transitionDuration: openDuration + \"ms\",\n ...commonStyles,\n ...openStyles\n });\n }\n if (status === 'close') {\n const styles = closeStyles || initialStyles;\n setStyles({\n transitionProperty: Object.keys(styles).map(camelCaseToKebabCase).join(','),\n transitionDuration: closeDuration + \"ms\",\n ...commonStyles,\n ...styles\n });\n }\n }, [closeDuration, closeRef, initialRef, openRef, commonRef, openDuration, status, fnArgs]);\n return {\n isMounted,\n styles\n };\n}\n\n/**\n * Provides a matching callback that can be used to focus an item as the user\n * types, often used in tandem with `useListNavigation()`.\n * @see https://floating-ui.com/docs/useTypeahead\n */\nfunction useTypeahead(context, props) {\n var _ref;\n const {\n open,\n dataRef\n } = context;\n const {\n listRef,\n activeIndex,\n onMatch: unstable_onMatch,\n onTypingChange: unstable_onTypingChange,\n enabled = true,\n findMatch = null,\n resetMs = 750,\n ignoreKeys = [],\n selectedIndex = null\n } = props;\n const timeoutIdRef = React.useRef();\n const stringRef = React.useRef('');\n const prevIndexRef = React.useRef((_ref = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref : -1);\n const matchIndexRef = React.useRef(null);\n const onMatch = useEffectEvent(unstable_onMatch);\n const onTypingChange = useEffectEvent(unstable_onTypingChange);\n const findMatchRef = useLatestRef(findMatch);\n const ignoreKeysRef = useLatestRef(ignoreKeys);\n index(() => {\n if (open) {\n clearTimeout(timeoutIdRef.current);\n matchIndexRef.current = null;\n stringRef.current = '';\n }\n }, [open]);\n index(() => {\n // Sync arrow key navigation but not typeahead navigation.\n if (open && stringRef.current === '') {\n var _ref2;\n prevIndexRef.current = (_ref2 = selectedIndex != null ? selectedIndex : activeIndex) != null ? _ref2 : -1;\n }\n }, [open, selectedIndex, activeIndex]);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n function setTypingChange(value) {\n if (value) {\n if (!dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n } else {\n if (dataRef.current.typing) {\n dataRef.current.typing = value;\n onTypingChange(value);\n }\n }\n }\n function getMatchingIndex(list, orderedList, string) {\n const str = findMatchRef.current ? findMatchRef.current(orderedList, string) : orderedList.find(text => (text == null ? void 0 : text.toLocaleLowerCase().indexOf(string.toLocaleLowerCase())) === 0);\n return str ? list.indexOf(str) : -1;\n }\n function onKeyDown(event) {\n const listContent = listRef.current;\n if (stringRef.current.length > 0 && stringRef.current[0] !== ' ') {\n if (getMatchingIndex(listContent, listContent, stringRef.current) === -1) {\n setTypingChange(false);\n } else if (event.key === ' ') {\n stopEvent(event);\n }\n }\n if (listContent == null || ignoreKeysRef.current.includes(event.key) ||\n // Character key.\n event.key.length !== 1 ||\n // Modifier key.\n event.ctrlKey || event.metaKey || event.altKey) {\n return;\n }\n if (open && event.key !== ' ') {\n stopEvent(event);\n setTypingChange(true);\n }\n\n // Bail out if the list contains a word like \"llama\" or \"aaron\". TODO:\n // allow it in this case, too.\n const allowRapidSuccessionOfFirstLetter = listContent.every(text => {\n var _text$, _text$2;\n return text ? ((_text$ = text[0]) == null ? void 0 : _text$.toLocaleLowerCase()) !== ((_text$2 = text[1]) == null ? void 0 : _text$2.toLocaleLowerCase()) : true;\n });\n\n // Allows the user to cycle through items that start with the same letter\n // in rapid succession.\n if (allowRapidSuccessionOfFirstLetter && stringRef.current === event.key) {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n }\n stringRef.current += event.key;\n clearTimeout(timeoutIdRef.current);\n timeoutIdRef.current = setTimeout(() => {\n stringRef.current = '';\n prevIndexRef.current = matchIndexRef.current;\n setTypingChange(false);\n }, resetMs);\n const prevIndex = prevIndexRef.current;\n const index = getMatchingIndex(listContent, [...listContent.slice((prevIndex || 0) + 1), ...listContent.slice(0, (prevIndex || 0) + 1)], stringRef.current);\n if (index !== -1) {\n onMatch(index);\n matchIndexRef.current = index;\n } else if (event.key !== ' ') {\n stringRef.current = '';\n setTypingChange(false);\n }\n }\n return {\n reference: {\n onKeyDown\n },\n floating: {\n onKeyDown,\n onKeyUp(event) {\n if (event.key === ' ') {\n setTypingChange(false);\n }\n }\n }\n };\n }, [enabled, open, dataRef, listRef, resetMs, ignoreKeysRef, findMatchRef, onMatch, onTypingChange]);\n}\n\nfunction getArgsWithCustomFloatingHeight(state, height) {\n return {\n ...state,\n rects: {\n ...state.rects,\n floating: {\n ...state.rects.floating,\n height\n }\n }\n };\n}\n/**\n * Positions the floating element such that an inner element inside\n * of it is anchored to the reference element.\n * @see https://floating-ui.com/docs/inner\n */\nconst inner = props => ({\n name: 'inner',\n options: props,\n async fn(state) {\n const {\n listRef,\n overflowRef,\n onFallbackChange,\n offset: innerOffset = 0,\n index = 0,\n minItemsVisible = 4,\n referenceOverflowThreshold = 0,\n scrollRef,\n ...detectOverflowOptions\n } = props;\n const {\n rects,\n elements: {\n floating\n }\n } = state;\n const item = listRef.current[index];\n if (process.env.NODE_ENV !== \"production\") {\n if (!state.placement.startsWith('bottom')) {\n console.warn(['Floating UI: `placement` side must be \"bottom\" when using the', '`inner` middleware.'].join(' '));\n }\n }\n if (!item) {\n return {};\n }\n const nextArgs = {\n ...state,\n ...(await offset(-item.offsetTop - floating.clientTop - rects.reference.height / 2 - item.offsetHeight / 2 - innerOffset).fn(state))\n };\n const el = (scrollRef == null ? void 0 : scrollRef.current) || floating;\n const overflow = await detectOverflow(getArgsWithCustomFloatingHeight(nextArgs, el.scrollHeight), detectOverflowOptions);\n const refOverflow = await detectOverflow(nextArgs, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const diffY = Math.max(0, overflow.top);\n const nextY = nextArgs.y + diffY;\n const maxHeight = Math.max(0, el.scrollHeight - diffY - Math.max(0, overflow.bottom));\n el.style.maxHeight = maxHeight + \"px\";\n el.scrollTop = diffY;\n\n // There is not enough space, fallback to standard anchored positioning\n if (onFallbackChange) {\n if (el.offsetHeight < item.offsetHeight * Math.min(minItemsVisible, listRef.current.length - 1) - 1 || refOverflow.top >= -referenceOverflowThreshold || refOverflow.bottom >= -referenceOverflowThreshold) {\n flushSync(() => onFallbackChange(true));\n } else {\n flushSync(() => onFallbackChange(false));\n }\n }\n if (overflowRef) {\n overflowRef.current = await detectOverflow(getArgsWithCustomFloatingHeight({\n ...nextArgs,\n y: nextY\n }, el.offsetHeight), detectOverflowOptions);\n }\n return {\n y: nextY\n };\n }\n});\n/**\n * Changes the `inner` middleware's `offset` upon a `wheel` event to\n * expand the floating element's height, revealing more list items.\n * @see https://floating-ui.com/docs/inner\n */\nfunction useInnerOffset(context, props) {\n const {\n open,\n elements\n } = context;\n const {\n enabled = true,\n overflowRef,\n scrollRef,\n onChange: unstable_onChange\n } = props;\n const onChange = useEffectEvent(unstable_onChange);\n const controlledScrollingRef = React.useRef(false);\n const prevScrollTopRef = React.useRef(null);\n const initialOverflowRef = React.useRef(null);\n React.useEffect(() => {\n if (!enabled) {\n return;\n }\n function onWheel(e) {\n if (e.ctrlKey || !el || overflowRef.current == null) {\n return;\n }\n const dY = e.deltaY;\n const isAtTop = overflowRef.current.top >= -0.5;\n const isAtBottom = overflowRef.current.bottom >= -0.5;\n const remainingScroll = el.scrollHeight - el.clientHeight;\n const sign = dY < 0 ? -1 : 1;\n const method = dY < 0 ? 'max' : 'min';\n if (el.scrollHeight <= el.clientHeight) {\n return;\n }\n if (!isAtTop && dY > 0 || !isAtBottom && dY < 0) {\n e.preventDefault();\n flushSync(() => {\n onChange(d => d + Math[method](dY, remainingScroll * sign));\n });\n } else if (/firefox/i.test(getUserAgent())) {\n // Needed to propagate scrolling during momentum scrolling phase once\n // it gets limited by the boundary. UX improvement, not critical.\n el.scrollTop += dY;\n }\n }\n const el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (open && el) {\n el.addEventListener('wheel', onWheel);\n\n // Wait for the position to be ready.\n requestAnimationFrame(() => {\n prevScrollTopRef.current = el.scrollTop;\n if (overflowRef.current != null) {\n initialOverflowRef.current = {\n ...overflowRef.current\n };\n }\n });\n return () => {\n prevScrollTopRef.current = null;\n initialOverflowRef.current = null;\n el.removeEventListener('wheel', onWheel);\n };\n }\n }, [enabled, open, elements.floating, overflowRef, scrollRef, onChange]);\n return React.useMemo(() => {\n if (!enabled) {\n return {};\n }\n return {\n floating: {\n onKeyDown() {\n controlledScrollingRef.current = true;\n },\n onWheel() {\n controlledScrollingRef.current = false;\n },\n onPointerMove() {\n controlledScrollingRef.current = false;\n },\n onScroll() {\n const el = (scrollRef == null ? void 0 : scrollRef.current) || elements.floating;\n if (!overflowRef.current || !el || !controlledScrollingRef.current) {\n return;\n }\n if (prevScrollTopRef.current !== null) {\n const scrollDiff = el.scrollTop - prevScrollTopRef.current;\n if (overflowRef.current.bottom < -0.5 && scrollDiff < -1 || overflowRef.current.top < -0.5 && scrollDiff > 1) {\n flushSync(() => onChange(d => d + scrollDiff));\n }\n }\n\n // [Firefox] Wait for the height change to have been applied.\n requestAnimationFrame(() => {\n prevScrollTopRef.current = el.scrollTop;\n });\n }\n }\n };\n }, [enabled, overflowRef, elements.floating, scrollRef, onChange]);\n}\n\nfunction isPointInPolygon(point, polygon) {\n const [x, y] = point;\n let isInside = false;\n const length = polygon.length;\n for (let i = 0, j = length - 1; i < length; j = i++) {\n const [xi, yi] = polygon[i] || [0, 0];\n const [xj, yj] = polygon[j] || [0, 0];\n const intersect = yi >= y !== yj >= y && x <= (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) {\n isInside = !isInside;\n }\n }\n return isInside;\n}\nfunction isInside(point, rect) {\n return point[0] >= rect.x && point[0] <= rect.x + rect.width && point[1] >= rect.y && point[1] <= rect.y + rect.height;\n}\n/**\n * Generates a safe polygon area that the user can traverse without closing the\n * floating element once leaving the reference element.\n * @see https://floating-ui.com/docs/useHover#safePolygon\n */\nfunction safePolygon(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n buffer = 0.5,\n blockPointerEvents = false,\n requireIntent = true\n } = options;\n let timeoutId;\n let hasLanded = false;\n let lastX = null;\n let lastY = null;\n let lastCursorTime = performance.now();\n function getCursorSpeed(x, y) {\n const currentTime = performance.now();\n const elapsedTime = currentTime - lastCursorTime;\n if (lastX === null || lastY === null || elapsedTime === 0) {\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return null;\n }\n const deltaX = x - lastX;\n const deltaY = y - lastY;\n const distance = Math.sqrt(deltaX * deltaX + deltaY * deltaY);\n const speed = distance / elapsedTime; // px / ms\n\n lastX = x;\n lastY = y;\n lastCursorTime = currentTime;\n return speed;\n }\n const fn = _ref => {\n let {\n x,\n y,\n placement,\n elements,\n onClose,\n nodeId,\n tree\n } = _ref;\n return function onMouseMove(event) {\n function close() {\n clearTimeout(timeoutId);\n onClose();\n }\n clearTimeout(timeoutId);\n if (!elements.domReference || !elements.floating || placement == null || x == null || y == null) {\n return;\n }\n const {\n clientX,\n clientY\n } = event;\n const clientPoint = [clientX, clientY];\n const target = getTarget(event);\n const isLeave = event.type === 'mouseleave';\n const isOverFloatingEl = contains(elements.floating, target);\n const isOverReferenceEl = contains(elements.domReference, target);\n const refRect = elements.domReference.getBoundingClientRect();\n const rect = elements.floating.getBoundingClientRect();\n const side = placement.split('-')[0];\n const cursorLeaveFromRight = x > rect.right - rect.width / 2;\n const cursorLeaveFromBottom = y > rect.bottom - rect.height / 2;\n const isOverReferenceRect = isInside(clientPoint, refRect);\n const isFloatingWider = rect.width > refRect.width;\n const isFloatingTaller = rect.height > refRect.height;\n const left = (isFloatingWider ? refRect : rect).left;\n const right = (isFloatingWider ? refRect : rect).right;\n const top = (isFloatingTaller ? refRect : rect).top;\n const bottom = (isFloatingTaller ? refRect : rect).bottom;\n if (isOverFloatingEl) {\n hasLanded = true;\n if (!isLeave) {\n return;\n }\n }\n if (isOverReferenceEl) {\n hasLanded = false;\n }\n if (isOverReferenceEl && !isLeave) {\n hasLanded = true;\n return;\n }\n\n // Prevent overlapping floating element from being stuck in an open-close\n // loop: https://github.com/floating-ui/floating-ui/issues/1910\n if (isLeave && isElement(event.relatedTarget) && contains(elements.floating, event.relatedTarget)) {\n return;\n }\n\n // If any nested child is open, abort.\n if (tree && getChildren(tree.nodesRef.current, nodeId).some(_ref2 => {\n let {\n context\n } = _ref2;\n return context == null ? void 0 : context.open;\n })) {\n return;\n }\n\n // If the pointer is leaving from the opposite side, the \"buffer\" logic\n // creates a point where the floating element remains open, but should be\n // ignored.\n // A constant of 1 handles floating point rounding errors.\n if (side === 'top' && y >= refRect.bottom - 1 || side === 'bottom' && y <= refRect.top + 1 || side === 'left' && x >= refRect.right - 1 || side === 'right' && x <= refRect.left + 1) {\n return close();\n }\n\n // Ignore when the cursor is within the rectangular trough between the\n // two elements. Since the triangle is created from the cursor point,\n // which can start beyond the ref element's edge, traversing back and\n // forth from the ref to the floating element can cause it to close. This\n // ensures it always remains open in that case.\n let rectPoly = [];\n switch (side) {\n case 'top':\n rectPoly = [[left, refRect.top + 1], [left, rect.bottom - 1], [right, rect.bottom - 1], [right, refRect.top + 1]];\n break;\n case 'bottom':\n rectPoly = [[left, rect.top + 1], [left, refRect.bottom - 1], [right, refRect.bottom - 1], [right, rect.top + 1]];\n break;\n case 'left':\n rectPoly = [[rect.right - 1, bottom], [rect.right - 1, top], [refRect.left + 1, top], [refRect.left + 1, bottom]];\n break;\n case 'right':\n rectPoly = [[refRect.right - 1, bottom], [refRect.right - 1, top], [rect.left + 1, top], [rect.left + 1, bottom]];\n break;\n }\n function getPolygon(_ref3) {\n let [x, y] = _ref3;\n switch (side) {\n case 'top':\n {\n const cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n const cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y + buffer + 1];\n const commonPoints = [[rect.left, cursorLeaveFromRight ? rect.bottom - buffer : isFloatingWider ? rect.bottom - buffer : rect.top], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.bottom - buffer : rect.top : rect.bottom - buffer]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n case 'bottom':\n {\n const cursorPointOne = [isFloatingWider ? x + buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n const cursorPointTwo = [isFloatingWider ? x - buffer / 2 : cursorLeaveFromRight ? x + buffer * 4 : x - buffer * 4, y - buffer];\n const commonPoints = [[rect.left, cursorLeaveFromRight ? rect.top + buffer : isFloatingWider ? rect.top + buffer : rect.bottom], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.top + buffer : rect.bottom : rect.top + buffer]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n case 'left':\n {\n const cursorPointOne = [x + buffer + 1, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const cursorPointTwo = [x + buffer + 1, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const commonPoints = [[cursorLeaveFromBottom ? rect.right - buffer : isFloatingTaller ? rect.right - buffer : rect.left, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.right - buffer : rect.left : rect.right - buffer, rect.bottom]];\n return [...commonPoints, cursorPointOne, cursorPointTwo];\n }\n case 'right':\n {\n const cursorPointOne = [x - buffer, isFloatingTaller ? y + buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const cursorPointTwo = [x - buffer, isFloatingTaller ? y - buffer / 2 : cursorLeaveFromBottom ? y + buffer * 4 : y - buffer * 4];\n const commonPoints = [[cursorLeaveFromBottom ? rect.left + buffer : isFloatingTaller ? rect.left + buffer : rect.right, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.left + buffer : rect.right : rect.left + buffer, rect.bottom]];\n return [cursorPointOne, cursorPointTwo, ...commonPoints];\n }\n }\n }\n if (isPointInPolygon([clientX, clientY], rectPoly)) {\n return;\n } else if (hasLanded && !isOverReferenceRect) {\n return close();\n }\n if (!isLeave && requireIntent) {\n const cursorSpeed = getCursorSpeed(event.clientX, event.clientY);\n const cursorSpeedThreshold = 0.1;\n if (cursorSpeed !== null && cursorSpeed < cursorSpeedThreshold) {\n return close();\n }\n }\n if (!isPointInPolygon([clientX, clientY], getPolygon([x, y]))) {\n close();\n } else if (!hasLanded && requireIntent) {\n timeoutId = window.setTimeout(close, 40);\n }\n };\n };\n fn.__options = {\n blockPointerEvents\n };\n return fn;\n}\n\nexport { Composite, CompositeItem, FloatingArrow, FloatingDelayGroup, FloatingFocusManager, FloatingList, FloatingNode, FloatingOverlay, FloatingPortal, FloatingTree, inner, safePolygon, useClick, useClientPoint, useDelayGroup, useDelayGroupContext, useDismiss, useFloating, useFloatingNodeId, useFloatingParentNodeId, useFloatingPortalNode, useFloatingTree, useFocus, useHover, useId, useInnerOffset, useInteractions, useListItem, useListNavigation, useMergeRefs, useRole, useTransitionStatus, useTransitionStyles, useTypeahead };\n","function o(f){return r=>{f.forEach(n=>{typeof n==\"function\"?n(r):n!=null&&(n.current=r)})}}export{o as mergeRefs};\n//# sourceMappingURL=index.mjs.map\n","export const TOOLTIP_OPEN_DELAY = 50;\n\nexport const TOOLTIP_CLOSE_DELAY = 200;\n","import {\n useFloating,\n useHover,\n useFocus,\n useInteractions,\n useRole,\n useTransitionStatus,\n offset,\n flip,\n shift,\n arrow,\n FloatingArrow,\n FloatingPortal,\n Placement,\n autoUpdate,\n} from '@floating-ui/react';\nimport cn from 'classnames';\nimport React, {\n useRef,\n useState,\n useMemo,\n forwardRef,\n ForwardedRef,\n ReactNode,\n ReactElement,\n HTMLAttributes,\n} from 'react';\nimport { mergeRefs } from 'react-merge-refs';\n\nimport { TOOLTIP_CLOSE_DELAY, TOOLTIP_OPEN_DELAY } from './tooltip-config';\nimport './tooltip.scss';\n\nexport interface BrTooltipProps extends Omit<HTMLAttributes<HTMLDivElement>, 'title'> {\n /**\n * Custom class name for the tooltip container\n */\n className?: string;\n /**\n * The tooltip child has to be a valid React element\n */\n children: ReactElement;\n /**\n * The tooltip message, it can be string or any valid React node\n */\n title: ReactNode;\n /**\n * Location of the tooltip, default is 'top'. The placement automatically adjusts if there is not enough space\n * to render in the specified direction\n */\n placement?: Placement;\n /**\n * By default the tooltip container is attached to the body, turning on this flag will attach it to the container\n * where the tooltip component is used\n */\n disablePortal?: boolean;\n /**\n * Specify a custom container (using id or ref) to attach the tooltip to. The tooltip will also use this container to\n * determine the placement of the tooltip\n */\n portalRoot?: string | HTMLElement | React.MutableRefObject<HTMLElement | null>\n}\n\n/**\n * The tooltip component is supposed to display informative text when users hover over or tap an element\n *\n * ### Usage\n *\n * ```tsx\n * import { BrTooltip } from '@bloomreach/react-banana-ui';\n *\n * export default function MyElementWithTooltip() {\n * return (\n * <BrTooltip title=\"My tooltip\">\n * <span>Hover over me</span>\n * </BrTooltip>\n * );\n * }\n * ```\n */\nconst BrTooltip = forwardRef((\n props: BrTooltipProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactNode => {\n const { children, className, title, placement = 'top', disablePortal = false, portalRoot, ...rest } = props;\n\n const arrowRef = useRef(null);\n const [visible, setVisible] = useState(false);\n const { refs, floatingStyles, context } = useFloating({\n whileElementsMounted: autoUpdate,\n placement,\n open: visible,\n onOpenChange: setVisible,\n middleware: [\n offset(10),\n flip(),\n shift(),\n arrow({ element: arrowRef }),\n ],\n });\n\n const hover = useHover(context, { delay: { open: TOOLTIP_OPEN_DELAY, close: TOOLTIP_CLOSE_DELAY } });\n const focus = useFocus(context);\n const role = useRole(context, { role: 'tooltip' });\n const { isMounted, status } = useTransitionStatus(context);\n\n const { getReferenceProps, getFloatingProps } = useInteractions([\n role,\n hover,\n focus,\n ]);\n\n const ref = useMemo(() => mergeRefs([refs.setReference, children.props.ref]), [\n refs.setReference,\n children,\n ]);\n\n const containerRef = useMemo(() => mergeRefs([refs.setFloating, forwardedRef]), [\n refs.setFloating,\n forwardedRef,\n ]);\n\n if (!title) {\n return children;\n }\n\n const childWithProps = React.cloneElement(children, getReferenceProps({ ref, ...children.props }));\n\n const tooltipContent = (\n <div\n {...rest}\n {...getFloatingProps()}\n ref={containerRef}\n style={{ ...floatingStyles }}\n className={cn('br-tooltip', className)}\n >\n {isMounted && (\n <div className={cn('br-tooltip__inner', `br-tooltip__inner--${status}`)}>\n {title}\n <FloatingArrow ref={arrowRef} context={context} className=\"br-tooltip__arrow\" />\n </div>\n )}\n </div>\n );\n\n const portalId = typeof portalRoot === 'string' ? portalRoot : undefined;\n const portalRef = typeof portalRoot !== 'string' ? portalRoot : undefined;\n\n return (\n <>\n {childWithProps}\n {visible && (disablePortal\n ? tooltipContent\n : (\n <FloatingPortal id={portalId} root={portalRef}>\n {tooltipContent}\n </FloatingPortal>\n ))}\n </>\n );\n});\n\nBrTooltip.displayName = 'BrTooltip';\n\nexport default BrTooltip;\n","import { useButton } from '@mui/base';\nimport cn from 'classnames';\nimport { ButtonHTMLAttributes, ReactNode, SyntheticEvent, forwardRef, ForwardedRef } from 'react';\nimport { LoaderIcon } from '../../foundations/icon/icons';\n\nimport { BrTooltip } from '../../popovers/tooltip';\n\nimport './button.scss';\n\nexport interface BrButtonProps extends Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'type'> {\n /**\n * The content of the component.\n */\n children?: ReactNode;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * The color of the component.\n * @default 'default'\n */\n color?: 'default' | 'alternative' | 'danger';\n /**\n * If `true`, the button will be disabled.\n * @default false\n */\n disabled?: boolean;\n /**\n * Icon displayed after the children.\n */\n endIcon?: ReactNode;\n /**\n * Set the original html type of button,\n * see: [MDN](https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#attr-type)\n * @default 'button'\n */\n htmlType?: ButtonHTMLAttributes<HTMLButtonElement>['type'];\n /**\n * If `true`, the button will be in a loading state.\n * @default false\n */\n loading?: boolean;\n /**\n * Text to display when the button is in a loading state.\n */\n loadingText?: string;\n /**\n * Callback fired when the component is clicked.\n */\n onClick?: (event: SyntheticEvent<HTMLButtonElement>) => void;\n /**\n * Icon displayed before the children.\n */\n startIcon?: ReactNode;\n /**\n * Tooltip to display when the button is hovered or focused.\n */\n tooltip?: ReactNode;\n /**\n * The button type.\n * @default 'secondary'\n */\n type?: 'primary' | 'secondary' | 'tertiary';\n}\n\nconst getTypeBasedClasses = ({ type, color, active, disabled, loading, hasIcons }: {\n type: BrButtonProps['type'];\n color: BrButtonProps['color'];\n active: boolean;\n disabled: boolean;\n loading: boolean;\n hasIcons: boolean;\n}): string[] => {\n if (type === 'primary' && (color === 'default' || color === 'alternative')) {\n return [\n 'br-button-primary',\n ...(active ? ['br-button-primary--active'] : []),\n ...(disabled ? ['br-button-primary--disabled'] : []),\n ...(loading ? ['br-button-primary--loading'] : []),\n ];\n }\n\n if (type === 'primary' && color === 'danger') {\n return [\n 'br-button-primary-danger',\n ...(active ? ['br-button-primary-danger--active'] : []),\n ...(disabled ? ['br-button-primary-danger--disabled'] : []),\n ...(loading ? ['br-button-primary-danger--loading'] : []),\n ];\n }\n\n if (type === 'secondary' && (color === 'default' || color === 'alternative')) {\n return [\n 'br-button-secondary',\n ...(active ? ['br-button-secondary--active'] : []),\n ...(disabled ? ['br-button-secondary--disabled'] : []),\n ...(loading ? ['br-button-secondary--loading'] : []),\n ];\n }\n\n if (type === 'secondary' && color === 'danger') {\n return [\n 'br-button-secondary-danger',\n ...(active ? ['br-button-secondary-danger--active'] : []),\n ...(disabled ? ['br-button-secondary-danger--disabled'] : []),\n ...(loading ? ['br-button-secondary-danger--loading'] : []),\n ];\n }\n\n if (type === 'tertiary' && color === 'default') {\n return [\n 'br-button-tertiary',\n ...(active ? ['br-button-tertiary--active'] : []),\n ...(disabled ? ['br-button-tertiary--disabled'] : []),\n ...(loading ? ['br-button-tertiary--loading'] : []),\n ...(hasIcons ? ['br-button-tertiary--has-icons'] : []),\n ];\n }\n\n if (type === 'tertiary' && color === 'danger') {\n return [\n 'br-button-tertiary-danger',\n ...(active ? ['br-button-tertiary-danger--active'] : []),\n ...(disabled ? ['br-button-tertiary-danger--disabled'] : []),\n ...(loading ? ['br-button-tertiary-danger--loading'] : []),\n ...(hasIcons ? ['br-button-tertiary-danger--has-icons'] : []),\n ];\n }\n\n if (type === 'tertiary' && color === 'alternative') {\n return [\n 'br-button-tertiary-alternative',\n ...(active ? ['br-button-tertiary-alternative--active'] : []),\n ...(disabled ? ['br-button-tertiary-alternative--disabled'] : []),\n ...(loading ? ['br-button-tertiary-alternative--loading'] : []),\n ...(hasIcons ? ['br-button-tertiary-alternative--has-icons'] : []),\n ];\n }\n\n return [];\n};\n\n/**\n * The button allow users to take actions, and make choices, with a single tap.\n *\n * ## Usage\n * ```jsx\n * import { BrButton } from '@bloomreach/react-banana-ui';\n *\n * export default function MyComponent() {\n * return <BrButton onClick={() => console.log('click')}>Button</BrButton>;\n * }\n * ```\n */\nconst BrButton = forwardRef((props: BrButtonProps, forwardedRef: ForwardedRef<HTMLButtonElement>) => {\n const {\n children,\n className,\n color = 'default',\n disabled = false,\n endIcon,\n htmlType = 'button',\n loading = false,\n loadingText,\n onClick,\n startIcon,\n tooltip,\n type = 'secondary',\n ...reset\n } = props;\n\n const { getRootProps, active, focusVisible } = useButton({\n ...props,\n type: htmlType,\n rootRef: forwardedRef,\n });\n\n function handleOnClick(event: SyntheticEvent<HTMLButtonElement>): void {\n if (loading || disabled) {\n return;\n }\n\n onClick?.(event);\n }\n\n const rootProps = getRootProps({\n onClick: handleOnClick,\n ...reset,\n });\n\n const hasIcons = !!startIcon || !!endIcon;\n const iconOnly = !children && ((startIcon && !endIcon) || (endIcon && !startIcon));\n\n const classes = cn('br-button', className, {\n 'br-button--focus-visible': focusVisible,\n 'br-button--disabled': disabled,\n 'br-button--icon-only': iconOnly && !(loading && loadingText),\n 'br-button--loading': loading,\n }, getTypeBasedClasses({ type, color, active, disabled, loading, hasIcons }));\n\n const loaderClasses = cn('br-button__loader', {\n 'br-button__loader--short': loadingText || iconOnly,\n });\n\n return (\n <BrTooltip title={tooltip}>\n {/* eslint-disable-next-line react/button-has-type -- `type` is set by rootProps */}\n <button {...rootProps} className={classes}>\n {\n startIcon && !loading && (\n <span role=\"img\" className=\"br-button__start-icon\">\n {startIcon}\n </span>\n )\n }\n {\n loading && (\n <span role=\"progressbar\" className={loaderClasses}>\n <LoaderIcon className=\"br-button__spinner\" />\n </span>\n )\n }\n {loading && loadingText}\n {!loading && children}\n {\n endIcon && !loading && (\n <span role=\"img\" className=\"br-button__end-icon\">\n {endIcon}\n </span>\n )\n }\n </button>\n </BrTooltip>\n );\n});\n\nBrButton.displayName = 'BrButton';\n\nexport default BrButton;\n","import cn from 'classnames';\nimport { cloneElement, forwardRef, isValidElement, Children, HTMLAttributes, ReactNode, ForwardedRef } from 'react';\nimport { BrButtonProps } from '../button/button';\nimport './button-group.scss';\n\nexport interface BrButtonGroupProps extends Omit<HTMLAttributes<HTMLDivElement>, 'onChange'> {\n /**\n * The content of the component.\n */\n children: ReactNode;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * If `true`, the group and all children will be disabled.\n * @default false\n */\n disabled?: boolean;\n /**\n * The button type.\n * @default 'secondary'\n */\n type?: BrButtonProps['type'];\n}\n\nconst getGroupClasses = (type: BrButtonGroupProps['type']): string => {\n if (type === 'primary') {\n return 'br-button-group--primary';\n }\n\n if (type === 'tertiary') {\n return 'br-button-group--tertiary';\n }\n\n return 'br-button-group--secondary';\n};\n\nconst getGroupButtonPositionClass = (first: boolean, last: boolean): string => {\n if (first && last) {\n return '';\n }\n\n if (first) {\n return 'br-button-group__button--first';\n }\n\n if (last) {\n return 'br-button-group__button--last';\n }\n\n return 'br-button-group__button--middle';\n};\n\n/**\n * The button group component can be used to group related buttons.\n *\n * ## Usage\n * ```jsx\n * import { BrButton, BrButtonGroup } from '@bloomreach/react-banana-ui';\n *\n * function MyButtonGroup() {\n * return (\n * <BrButtonGroup>\n * <BrButton>One</BrButton>\n * <BrButton>Two</BrButton>\n * </BrButtonGroup>\n * );\n * }\n * ```\n */\nconst BrButtonGroup = forwardRef((\n props: BrButtonGroupProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): JSX.Element => {\n const { children, className, disabled, type = 'secondary', ...rest } = props;\n\n const classes = cn(className, 'br-button-group', getGroupClasses(type), { 'br-button-group--disabled': disabled });\n const childrenCount = Children.count(children);\n\n return (\n <div role=\"group\" className={classes} aria-disabled={disabled} ref={forwardedRef} {...rest}>\n {\n Children.map(children, (button, index) => {\n if (!isValidElement(button)) {\n return undefined;\n }\n\n const first = index === 0;\n const last = index === childrenCount - 1;\n const buttonDisabled = button.props.disabled ?? disabled;\n const buttonClasses = cn(\n 'br-button-group__button',\n { 'br-button-group__button--disabled': buttonDisabled },\n getGroupButtonPositionClass(first, last),\n button.props.className,\n );\n\n return cloneElement(button as React.ReactElement, {\n key: button.key ?? index,\n type: button.props.type ?? type,\n disabled: buttonDisabled,\n className: buttonClasses,\n });\n })?.filter(Boolean)\n }\n </div>\n );\n});\n\nBrButtonGroup.displayName = 'BrButtonGroup';\n\nexport default BrButtonGroup;\n","import cn from 'classnames';\nimport { forwardRef, ReactElement, ForwardedRef, ReactNode, SyntheticEvent } from 'react';\n\nimport BrButton, { BrButtonProps } from '../button/button';\nimport './toggle-button.scss';\n\nexport interface BrToggleButtonProps<T extends string | number = string> extends Omit<BrButtonProps, 'onClick'> {\n /**\n * The content of the component.\n */\n children: ReactNode;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * If `true`, the button will be disabled.\n * @default false\n */\n disabled?: boolean;\n /**\n * Callback fired when the button is clicked.\n */\n onClick?: (event: SyntheticEvent<HTMLButtonElement>, value: T) => void;\n /**\n * If `true`, the button will be selected.\n * @default false\n */\n selected?: boolean;\n /**\n * The value to associate with the button when selected in a toggle button group.\n */\n value: T;\n}\n\n/**\n * The current component is used as an argument for the `forwardRef` function to forward ref.\n * However, to keep the generic interface of the `BrToggleButton` component we have to cast type\n * after wrapping this component with the `forwardRef` function.\n */\nfunction BrToggleButtonInner<T extends string | number = string>(\n props: BrToggleButtonProps<T>,\n forwardedRef: ForwardedRef<HTMLButtonElement>,\n): ReactElement {\n const {\n children,\n className,\n color = 'default',\n disabled,\n onClick,\n selected,\n type = 'secondary',\n value,\n ...restProps\n } = props;\n\n const classes = cn('br-toggle-button', {\n 'br-toggle-button--disabled': disabled,\n 'br-toggle-button--selected': selected,\n }, className);\n\n return (\n <BrButton\n {...restProps}\n className={classes}\n type={type}\n color={color}\n disabled={disabled}\n aria-pressed={selected}\n onClick={(event) => onClick?.(event, value)}\n ref={forwardedRef}\n >\n {children}\n </BrButton>\n );\n}\n\nconst BrToggleButton = forwardRef(BrToggleButtonInner);\n\nBrToggleButton.displayName = 'BrToggleButton';\n\n/**\n * The `BrToggleButton` component can be used to group related options.\n *\n * ## Usage\n *\n * ### Basic\n * ```tsx\n * import { BrToggleButton, BrToggleButtonGroup } from '@bloomreach/react-banana-ui`;\n *\n * export default BasicToggleGroup() {\n * const [value, setValue] = useState('mobile');\n *\n * return (\n * <BrToggleButtonGroup\n * value={value}\n * onChange={(event, value) => { setValue(value); }}\n * >\n * <BrToggleButton value=\"web\">Web</BrToggleButton>\n * <BrToggleButton value=\"mobile\">Mobile</BrToggleButton>\n * <BrToggleButton value=\"desktop\">Desktop</BrToggleButton>\n * </BrToggleButtonGroup>\n * );\n * };\n * ```\n *\n * ### Defined value type\n * The `BrToggleButton` is generic component and determinate value type\n * based on `value` or it might be explicitly defined like\n *\n * ```tsx\n * type MyValue = 'one' | 'two' | 'three';\n * <BrToggleButton<MyValue> value=\"two\">...</BrToggleButton>\n * ```\n * by default `value` has a `string` type.\n */\nexport default BrToggleButton as <T extends string | number = string>(\n props: BrToggleButtonProps<T> & { ref?: ForwardedRef<HTMLButtonElement> },\n) => ReturnType<typeof BrToggleButtonInner>; // Check the comment for `BrToggleButtonInner` to get a reason.\n","import cn from 'classnames';\nimport { Children, cloneElement, ForwardedRef, forwardRef, isValidElement, ReactElement, SyntheticEvent } from 'react';\n\nimport BrButtonGroup, { type BrButtonGroupProps } from '../button-group/button-group';\nimport type { BrToggleButtonProps } from '../toggle-button/toggle-button';\n\ninterface BrToggleButtonGroupBaseProps extends Omit<BrButtonGroupProps, 'onChange'> {\n /**\n * If `true`, allow multiple items to be selected (checkbox behavior).\n */\n multiple?: boolean;\n}\n\nexport interface BrToggleButtonGroupSingleProps<T extends string | number = string>\n extends BrToggleButtonGroupBaseProps {\n multiple?: false;\n /**\n * Callback fired when the component is clicked. Value is a single value of the toggle button.\n * If no value is selected the value is a `null`.\n */\n onChange?: (event: SyntheticEvent<HTMLButtonElement>, value: T) => void;\n /**\n * The currently selected value within the group is an array of selected values.\n * The value must have reference equality with the option in order to be selected.\n */\n value?: T;\n}\n\nexport interface BrToggleButtonGroupMultipleProps<T extends string | number = string>\n extends BrToggleButtonGroupBaseProps {\n multiple: true;\n /**\n * Callback fired when the component is clicked. Value is an array of selected values.\n * If no value is selected the value is an empty array.\n */\n onChange?: (event: SyntheticEvent<HTMLButtonElement>, value: T[]) => void;\n /**\n * The currently selected an array of values.\n * The value must have reference equality with the option in order to be selected.\n */\n value?: T[];\n}\n\nfunction isValueSelected<T>(value: T | undefined, candidate: T | T[] | undefined): boolean {\n if (candidate === undefined || value === undefined) {\n return false;\n }\n\n if (Array.isArray(candidate)) {\n return candidate.indexOf(value) >= 0;\n }\n\n return value === candidate;\n}\n\n/**\n * The current component is used as an argument for the `forwardRef` function to forward ref.\n * However, to keep the generic interface of the `BrToggleButtonGroup` component we have to cast type\n * after wrapping this component with the `forwardRef` function.\n */\nfunction BrToggleButtonGroupInner<T extends string | number = string>(\n props: BrToggleButtonGroupSingleProps<T>,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement;\nfunction BrToggleButtonGroupInner<T extends string | number = string>(\n props: BrToggleButtonGroupMultipleProps<T>,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement;\nfunction BrToggleButtonGroupInner<T extends string | number = string>(\n props: BrToggleButtonGroupSingleProps<T> | BrToggleButtonGroupMultipleProps<T>,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement {\n const { children, className, disabled, onChange, value, multiple = false } = props;\n\n const handleChange = (event: SyntheticEvent<HTMLButtonElement>, buttonValue: T): void => {\n if (isValueSelected(buttonValue, value)) {\n return;\n }\n\n (onChange as BrToggleButtonGroupSingleProps<T>['onChange'])?.(event, buttonValue);\n };\n\n const handleMultipleChange = (event: SyntheticEvent<HTMLButtonElement>, buttonValue: T): void => {\n let newValue: T[] = [];\n\n if (Array.isArray(value)) {\n newValue = [...value];\n }\n\n const index = newValue.indexOf(buttonValue);\n\n if (index >= 0) {\n newValue.splice(index, 1);\n } else {\n newValue.push(buttonValue);\n }\n\n (onChange as BrToggleButtonGroupMultipleProps<T>['onChange'])?.(event, newValue);\n };\n\n const classes = cn(className, 'br-toggle-button-group');\n\n const childrenWithProps = Children.map(children, (child) => {\n if (isValidElement(child)) {\n return cloneElement(child as ReactElement<BrToggleButtonProps<T>>, {\n disabled: disabled || child.props.disabled,\n selected: isValueSelected<T>(child.props.value, value),\n onClick: multiple ? handleMultipleChange : handleChange,\n });\n }\n\n return child;\n });\n\n return (\n <BrButtonGroup className={classes} ref={forwardedRef} {...props}>\n {childrenWithProps}\n </BrButtonGroup>\n );\n}\n\nconst BrToggleButtonGroup = forwardRef(BrToggleButtonGroupInner);\n\nBrToggleButtonGroup.displayName = 'BrToggleButtonGroup';\n\n/**\n * The `BrToggleButtonGroup` controls the selected state of its child buttons when given its own `value` prop.\n * To emphasize groups of related toggle buttons, a group should share a common container.\n *\n * ## Usage\n *\n * ### Basic\n * ```tsx\n * import { BrToggleButton, BrToggleButtonGroup } from '@bloomreach/react-banana-ui`;\n *\n * export default BasicToggleGroup() {\n * const [value, setValue] = useState('mobile');\n *\n * return (\n * <BrToggleButtonGroup\n * value={value}\n * onChange={(event, value) => { setValue(value); }}\n * >\n * <BrToggleButton value=\"web\">Web</BrToggleButton>\n * <BrToggleButton value=\"mobile\">Mobile</BrToggleButton>\n * <BrToggleButton value=\"desktop\">Desktop</BrToggleButton>\n * </BrToggleButtonGroup>\n * );\n * };\n * ```\n * The toggle group might be used as a radio button when selecting one option deselects any other\n * it is the default behavior also as multiple selections by passing the `multiple` prop\n * it allows to have multiple options selected.\n *\n * The toggle button group `value` is the currently selected value within the group or\n * an array of selected values when `multiple` is `true`.\n * The value must have reference equality with the option in order to be selected.\n *\n * The `onChange` callback is fired on the value change and has a different signature for the `value` argument.\n * When `multiple` is `true` this is an array of selected values; when `false` is a single value.\n * If no value is selected and `multiple` is `true` the value is an empty array.\n * In case when `multiple` is `false` then `onChange` the callback doesn't fire\n * if the user clicks on the already selected value.\n *\n * The `BrToggleButtonGroup` is generic component and determinate value type\n * based on `value` or it might be explicitly defined like\n *\n * ### Defined value type\n * ```tsx\n * type MyValue = 'one' | 'two' | 'three';\n * <BrToggleButtonGroup<MyValue>>...</BrToggleButtonGroup>\n * ```\n * by default `value` has a `string` type and `string[]` for `multiple` mode.\n */\nexport default BrToggleButtonGroup as <T extends string | number = string>(\n props: BrToggleButtonGroupSingleProps<T> | BrToggleButtonGroupMultipleProps<T> & {\n ref?: ForwardedRef<HTMLDivElement>\n },\n) => ReturnType<typeof BrToggleButtonGroupInner<T>>; // Check the comment for `BrToggleButtonGroupInner` to get a reason\n","import SuccessIcon from '@bloomreach/banana-theme/icons/check-filled.svg?react';\nimport CloseIcon from '@bloomreach/banana-theme/icons/close.svg?react';\nimport ErrorIcon from '@bloomreach/banana-theme/icons/error-fill.svg?react';\nimport InfoIcon from '@bloomreach/banana-theme/icons/info-filled.svg?react';\nimport WarningIcon from '@bloomreach/banana-theme/icons/warning-fill.svg?react';\nimport classnames from 'classnames';\nimport { ReactNode } from 'react';\n\nimport { BrButton } from '../../buttons';\n\nimport './alert.scss';\n\nexport type AlertType = 'error' | 'info' | 'success' | 'warning';\n\ninterface BrAlertProps {\n /**\n * Actions to be displayed at the bottom of the message. Typically used for buttons.\n */\n actions?: ReactNode;\n /**\n * The content of the component.\n */\n children?: ReactNode;\n /**\n * Custom class name for the container of this component\n */\n className?: string;\n /**\n * Override the icon displayed before the children.\n * Unless provided, the icon is mapped to the value of the `type` prop.\n * Set to `false` to remove the icon.\n */\n icon?: ReactNode | false;\n /**\n * Callback when the close button is clicked.\n * When provided a close icon button is displayed that triggers the callback when clicked.\n */\n onClose?: () => void;\n /**\n * The type of alert to display.\n * This determines the icon displayed before the children.\n * @default 'info'\n */\n type?: AlertType;\n /**\n * The ARIA role attribute of the element.\n * @default 'alert'\n * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/Alert_Role\n */\n role?: string\n}\n\nconst defaultIconMapping: {\n [key in AlertType]: (\n props?: React.SVGProps<SVGSVGElement> & { title?: string | undefined; }\n ) => JSX.Element;\n} = {\n error: (props) => <ErrorIcon {...props} />,\n info: (props) => <InfoIcon {...props} />,\n success: (props) => <SuccessIcon {...props} />,\n warning: (props) => <WarningIcon {...props} />,\n};\n\nfunction BrAlert(props: BrAlertProps): JSX.Element {\n const {\n actions,\n children,\n className,\n icon,\n onClose,\n role = 'alert',\n type = 'info',\n } = props;\n\n return (\n <div className={classnames(`br-alert br-alert--${type}`, className)} role={role}>\n {icon !== false ? (\n <div className={`br-alert__icon br-alert__icon--${type}`}>\n {icon || defaultIconMapping[type]()}\n </div>\n ) : null}\n <div className=\"br-alert__content\">\n {children}\n {actions\n ? (\n <div className=\"br-alert__actions\">\n {actions}\n </div>\n ) : null}\n </div>\n {onClose\n ? (\n // TODO: Replace current button with the BrButton component, see BR-49. Clean up styles as well.\n <BrButton\n type=\"tertiary\"\n aria-label=\"Close\"\n className=\"br-alert__close\"\n startIcon={<CloseIcon />}\n onClick={() => onClose()}\n />\n ) : null}\n </div>\n );\n}\n\nexport default BrAlert;\n","import classnames from 'classnames';\nimport { ReactNode } from 'react';\n\nimport './alert-title.scss';\n\ninterface BrMessageTitle {\n /**\n * The content of the component.\n */\n children?: ReactNode;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n}\n\nfunction BrMessageTitle(props: BrMessageTitle): JSX.Element {\n const { children, className } = props;\n\n return (\n <div className={classnames('br-alert-title', className)}>\n {children}\n </div>\n );\n}\n\nexport default BrMessageTitle;\n","import { createContext, useContext } from 'react';\nimport { BrModalProps } from './modal-types';\n\nconst ModalContext = createContext<BrModalProps | null>(null);\n\nexport function useModalContext(): BrModalProps | null {\n return useContext(ModalContext);\n}\n\nexport default ModalContext;\n","import { Modal } from '@mui/base/Modal';\nimport { prepareForSlot } from '@mui/base/utils';\nimport cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\nimport { BrModalProps } from './modal-types';\nimport ModalContext from './modal-context';\n\nimport './modal.scss';\n\nconst Backdrop = forwardRef<\n HTMLDivElement,\n { open?: boolean; className: string }\n>((props, ref) => {\n const { open, className, ...rest } = props;\n return (\n <div\n className={cn({ 'br-modal__backdrop': open }, className)}\n ref={ref}\n {...rest}\n />\n );\n});\n\n/**\n * Modal component lets you create dialogs that force the user to take action before continuing\n *\n * ## Usage\n *\n * ```tsx\n * <BrModal open>\n * <BrModalHeader>\n * <BrModalHeaderTitle>\n * Modal header\n * </BrModalHeaderTitle>\n * </BrModalHeader>\n * <BrModalBody>\n * Design systems bridge the gap between creativity and consistency, ensuring a harmonious user experience\n * across platforms. By establishing a set of guidelines and components, they empower designers to craft\n * cohesive digital environments.\n * </BrModalBody>\n * <BrModalFooter>\n * <BrModalFooterActions>\n * <BrModalCloseButton>\n * Cancel\n * </BrModalCloseButton>\n * <BrButton\n * onClick={() => {}}\n * type=\"primary\"\n * >\n * Primary\n * </BrButton>\n * </BrModalFooterActions>\n * </BrModalFooter>\n * </BrModal>\n * ```\n */\nconst BrModal = forwardRef((\n props: BrModalProps,\n forwardedRef: ForwardedRef<HTMLDivElement> | null,\n): ReactElement => {\n const {\n open,\n children,\n width = 'sm',\n role = 'dialog',\n className,\n onClose,\n ...rest\n } = props;\n\n const handleOnClose = (): void => {\n onClose?.();\n };\n\n return (\n <ModalContext.Provider value={props}>\n <Modal\n ref={forwardedRef}\n role={role}\n aria-modal=\"true\"\n className={cn('br-modal', className)}\n open={open}\n onClose={handleOnClose}\n slots={{ backdrop: prepareForSlot(Backdrop) }}\n {...rest}\n >\n <div className={cn('br-modal__wrapper', `br-modal__wrapper--${width}`)}>\n {children}\n </div>\n </Modal>\n </ModalContext.Provider>\n );\n});\n\nBrModal.displayName = 'BrModal';\n\nexport default BrModal;\n","import { ReactElement } from 'react';\nimport { BrButton } from '../../buttons';\nimport { BrButtonProps } from '../../buttons/button/button';\nimport { useModalContext } from './modal-context';\n\n/**\n * This button is a convenience component that applies the recommended styling for the Cancel button in the\n * modal footer. It wraps the BrButton and sets the type to tertiary and attaches the Modal's onClose handler\n * to the button's onClick event handler, so the developer does not have to manually attach the modal dialog close\n * handler to the onClose handler of the Modal and again to the BrButton for the cancel button in the footer.\n */\nfunction BrModalCloseButton(props: BrButtonProps): ReactElement {\n const {\n className,\n children,\n ...rest\n } = props;\n\n const modalCtx = useModalContext();\n\n if (modalCtx === null) {\n throw new Error('BrModalCloseButton must be used within a ModalContext.Provider');\n }\n\n const { onClose } = modalCtx;\n\n const handleOnClose = (): void => {\n onClose?.();\n };\n\n return (\n <BrButton {...rest} type=\"tertiary\" onClick={handleOnClose} className={className}>\n {children}\n </BrButton>\n );\n}\n\nBrModalCloseButton.displayName = 'BrModalCloseButton';\n\nexport default BrModalCloseButton;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\nimport { CloseIcon } from '../../foundations';\nimport BrModalCloseButton from './modal-close-button';\nimport { useModalContext } from './modal-context';\nimport { BrModalChildProps } from './modal-types';\n\n/**\n * Modal header component is used to render the header section of the modal dialog.\n * If `onClose` is provided to the `BrModal` component, then a close button is rendered in the header section.\n * Use `BrModalHeaderTitle` component to render the title in the header section.\n */\nconst BrModalHeader = forwardRef((\n props: BrModalChildProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement => {\n const {\n children,\n className,\n ...rest\n } = props;\n\n const modalCtx = useModalContext();\n\n if (modalCtx === null) {\n throw new Error('BrModalHeader must be used within a ModalContext.Provider');\n }\n\n const { onClose } = modalCtx;\n\n return (\n <div {...rest} ref={forwardedRef} className={cn('br-modal__header', className)}>\n <div className=\"br-modal__header-section\">\n {children}\n </div>\n {onClose && (\n <BrModalCloseButton className=\"br-modal__header-close\" startIcon={<CloseIcon />} />\n )}\n </div>\n );\n});\n\nBrModalHeader.displayName = 'BrModalHeader';\n\nexport default BrModalHeader;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\nimport { BrModalChildProps } from './modal-types';\n\n/**\n * Modal header title is used to render the title in the header section of the modal dialog.\n */\nconst BrModalHeaderTitle = forwardRef((\n props: BrModalChildProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement => {\n const {\n className,\n children,\n ...rest\n } = props;\n\n return (\n <div {...rest} ref={forwardedRef} className={cn('br-modal__header-title', className)}>\n {children}\n </div>\n );\n});\n\nBrModalHeaderTitle.displayName = 'BrModalHeaderTitle';\n\nexport default BrModalHeaderTitle;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\n\nimport { BrModalBodyProps } from './modal-types';\n\nimport './modal.scss';\n\n/**\n * Modal body component is used to render the body section of the modal dialog.\n * Use the `padding` prop to control the padding of the body section, the default is `narrow`.\n */\nconst BrModalBody = forwardRef((\n props: BrModalBodyProps,\n forwardedRef: ForwardedRef<HTMLDivElement> | null,\n): ReactElement => {\n const {\n children,\n padding = 'narrow',\n className,\n ...rest\n } = props;\n\n return (\n <div {...rest} ref={forwardedRef} className={cn('br-modal__body', `br-modal__body--${padding}`, className)}>\n {children}\n </div>\n );\n});\n\nBrModalBody.displayName = 'BrModalBody';\n\nexport default BrModalBody;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\nimport { BrModalChildProps } from './modal-types';\n\n/**\n * Modal footer component is used to render the footer section of the modal dialog and it is recommended to use\n * the `BrModalFooterActions` component to render the actions in the footer section.\n * All content inside the `BrModalFooter` component is justified to the left. The `BrModalFooterActions`\n * component is justified to the right.\n */\nconst BrModalFooter = forwardRef((\n props: BrModalChildProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement => {\n const {\n children,\n className,\n ...rest\n } = props;\n\n return (\n <div {...rest} ref={forwardedRef} className={cn('br-modal__footer', className)}>\n {children}\n </div>\n );\n});\n\nBrModalFooter.displayName = 'BrModalFooter';\n\nexport default BrModalFooter;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactElement } from 'react';\nimport { BrModalChildProps } from './modal-types';\n\n/**\n * Modal footer actions component is used to render the actions section of the modal dialog footer.\n * You can use `BrModalCloseButton` component to render the cancel button which is call `onClose` by default.\n */\nconst BrModalFooterActions = forwardRef((\n props: BrModalChildProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): ReactElement => {\n const {\n className,\n children,\n ...rest\n } = props;\n\n return (\n <div {...rest} ref={forwardedRef} className={cn('br-modal__footer--actions', className)}>\n {children}\n </div>\n );\n});\n\nBrModalFooterActions.displayName = 'BrModalFooterActions';\n\nexport default BrModalFooterActions;\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef, ReactNode } from 'react';\n\nimport { InfoFilledIcon as InfoIcon } from '../../foundations/icon/icons';\nimport { BrTooltip } from '../../popovers';\n\nimport './base-field.scss';\n\nexport interface BrBaseFieldProps {\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * The control element to render as the main content of the field.\n */\n control: ReactNode;\n /**\n * The `id` of the `control` element to connect it with `label` in the field.\n */\n controlId: string;\n /**\n * If `true`, the field will indicate an error.\n */\n error?: boolean;\n /**\n * If `true`, the field will take up the full width of its container.\n */\n fullWidth?: boolean;\n /**\n * The helper text content.\n */\n helperText?: ReactNode;\n /**\n * The label content.\n */\n label? : ReactNode;\n /**\n * The metadata content.\n */\n metadata?: ReactNode;\n /**\n * Tooltip to display when the field has label.\n */\n tooltip?: ReactNode;\n}\n\nconst getZeroSpace = (): JSX.Element => <span>&nbsp;</span>;\n\n/**\n * @internal\n * Base component provides the layout for the field which includes:\n * label (with or without tooltip), helper text and control.\n * It also provides the `error` and `full width` states for the field.\n * Should be used as a base for all other field components and should not be exposed to the end users.\n */\nconst BrBaseField = forwardRef((props: BrBaseFieldProps, ref: ForwardedRef<HTMLDivElement>) => {\n const { className, control, controlId, error, fullWidth, helperText, label, metadata, tooltip, ...rest } = props;\n\n return (\n <div\n {...rest}\n className={cn('br-base-field', className, {\n 'br-base-field--error': error,\n 'br-base-field--full-width': fullWidth,\n })}\n ref={ref}\n >\n {(label || metadata) && (\n <div className=\"br-base-field__label-row\">\n {label && (\n <label className=\"br-base-field__label\" htmlFor={controlId}>\n {label === ' ' ? getZeroSpace() : label}\n {tooltip && (\n <BrTooltip title={tooltip}>\n <InfoIcon className=\"br-base-field__icon\" />\n </BrTooltip>\n )}\n </label>\n )}\n {metadata && (\n <span className=\"br-base-field__metadata\">\n {metadata}\n </span>\n )}\n </div>\n )}\n {control}\n {helperText && (\n <span className=\"br-base-field__helper\">\n {helperText === ' ' ? getZeroSpace() : helperText}\n </span>\n )}\n </div>\n );\n});\n\nexport default BrBaseField;\n","import { useCallback, useState } from 'react';\n\nexport default function useHover({\n onEnter,\n onLeave,\n}: {\n onEnter?: () => void;\n onLeave?: () => void;\n} | undefined = {}): { hovered: boolean, handlers: { onMouseEnter: () => void, onMouseLeave: () => void } } {\n const [hovered, setHovered] = useState(false);\n\n const handleMouseEnter = useCallback(() => {\n setHovered(true);\n onEnter?.();\n }, [onEnter]);\n\n const handleMouseLeave = useCallback(() => {\n setHovered(false);\n onLeave?.();\n }, [onLeave]);\n\n return {\n hovered,\n handlers: {\n onMouseEnter: handleMouseEnter,\n onMouseLeave: handleMouseLeave,\n },\n };\n}\n","import { useInput, TextareaAutosize } from '@mui/base';\nimport cn from 'classnames';\nimport React, {\n ChangeEventHandler,\n FocusEventHandler,\n ForwardedRef,\n forwardRef,\n InputHTMLAttributes,\n ReactElement,\n ReactNode,\n useEffect,\n useRef,\n useState,\n} from 'react';\n\nimport { BrButton } from '../../buttons';\nimport { CloseIcon } from '../../foundations/icon/icons';\nimport { useHover } from '../../../utils/hooks';\n\nimport './base-input.scss';\n\nexport interface BrBaseInputProps {\n /**\n * Automatically adjusts textarea height to match the length of the content within.\n * When `multiline` is `false`, this prop is ignored.\n */\n autoSize?: boolean;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * Allow to remove `input` content with clear icon.\n * When `multiline` is `true`, this prop is ignored.\n */\n clearable?: boolean;\n /**\n * The default value. Use when the component is not controlled.\n */\n defaultValue?: string;\n /**\n * If `true`, the field is disabled.\n */\n disabled?: boolean;\n /**\n * If `true`, the `field` will indicate an error and set the `aria-invalid` attribute for `input` or `textarea`.\n */\n error?: boolean;\n /**\n * The `id` of the `input` or `textarea` element.\n */\n id?: string;\n /**\n * Attributes applied to the `input` or `textarea` element, check the link below for more details.\n * @link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes\n * @link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea#Attributes\n */\n inputProps?: InputHTMLAttributes<HTMLInputElement | HTMLTextAreaElement>;\n /**\n * Icon or any element displayed at the end of the `input` or `textarea`.\n */\n leftElement?: ReactNode;\n /**\n * The maximum number of text lines to grow when `autoSize` and `multiline` are `true`.\n */\n maxRows?: number;\n /**\n * The number of visible text lines for the field.\n * When `autoSize` is `false`, this prop behaves as `rows` for `textarea`.\n * Works only when `multiline` is `true`.\n */\n minRows?: number;\n /**\n * If `true`, a `textarea` element is rendered.\n */\n multiline?: boolean;\n /**\n * The `name` attribute of the `input` or `textarea` element.\n */\n name?: string;\n /**\n * Callback fired when the `input` or `textarea` is blurred.\n */\n onBlur?: FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n /**\n * Callback fired when the value is changed.\n */\n onChange?: ChangeEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n /**\n * Callback fired when the `input` or `textarea` value length is changed.\n */\n onCountChange?: (count: number) => void;\n /**\n * Callback fired when the `input` or `textarea` is focused.\n */\n onFocus?: FocusEventHandler<HTMLInputElement | HTMLTextAreaElement>;\n /**\n * The short hint displayed in the `input` or `textarea` before the user enters a value.\n */\n placeholder?: string;\n /**\n * If `true`, the `input` or `textarea` will be read-only.\n */\n readOnly?: boolean;\n /**\n * If `true`, the `input` or `textarea` will be required.\n */\n required?: boolean;\n /**\n * Icon or any element displayed at the start of the `input` or `textarea`.\n */\n rightElement?: ReactNode;\n /**\n * The `value` of the `input` or `textarea` element, required for a controlled component.\n */\n value?: string;\n}\n\nfunction setRef<T>(\n ref: React.MutableRefObject<T | null> | ((instance: T | null) => void) | null | undefined,\n value: T | null,\n): void {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref) {\n ref.current = value;\n }\n}\n\nfunction useForkRefs<Instance>(\n ...refs: (React.Ref<Instance> | React.MutableRefObject<Instance> | undefined)[]\n): React.RefCallback<Instance> | null {\n /**\n * This will create a new function if the refs passed to this hook change and are all defined.\n * This means react will call the old forkRef with `null` and the new forkRef\n * with the ref. Cleanup naturally emerges from this behavior.\n */\n return React.useMemo(() => {\n if (refs.every((ref) => ref == null)) {\n return null;\n }\n\n return (instance) => {\n refs.forEach((ref) => {\n setRef(ref, instance);\n });\n };\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, refs);\n}\n\n/**\n * @internal\n * The base input component to enter and edit text.\n * Should be used only by other components and not exposed to the end users.\n */\nconst BrBaseInput = forwardRef((\n props: BrBaseInputProps,\n forwardedRef: ForwardedRef<HTMLInputElement | HTMLTextAreaElement>,\n) => {\n const {\n autoSize,\n className,\n clearable,\n defaultValue,\n disabled,\n error,\n inputProps: inInputProps = {},\n leftElement,\n maxRows,\n minRows,\n multiline,\n onBlur,\n onChange,\n onCountChange,\n onFocus,\n readOnly,\n required,\n rightElement,\n value,\n ...rest\n } = props;\n const uncontrolled = value === undefined || value === null;\n\n const inputRef = useRef<HTMLInputElement | HTMLTextAreaElement>(null);\n const forkRef = useForkRefs(inputRef, forwardedRef);\n\n const [internalValue, setInternalValue] = useState(uncontrolled ? defaultValue : '');\n const inputValue = uncontrolled ? internalValue : value;\n\n useEffect(() => {\n onCountChange?.(inputValue?.length ?? 0);\n }, [inputValue, onCountChange]);\n\n const handleOnChange = (e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>): void => {\n setInternalValue(e.target.value);\n\n onChange?.(e);\n };\n\n const { hovered, handlers: hoverHandlers } = useHover();\n\n const { getInputProps, getRootProps, focused } = useInput({\n defaultValue,\n disabled,\n error,\n inputRef: forkRef,\n onBlur,\n onChange: handleOnChange,\n onFocus,\n required,\n value: uncontrolled ? undefined : inputValue,\n });\n\n const handleReset = (e: React.SyntheticEvent<HTMLButtonElement>): void => {\n if (!inputRef.current) {\n return;\n }\n\n inputRef.current.value = '';\n setInternalValue('');\n\n const event = Object.create(e, {\n target: { value: inputRef.current },\n currentTarget: { value: inputRef.current },\n });\n\n onChange?.(event);\n };\n\n const getClearButton = (): ReactElement | null => {\n const hideClear = disabled || readOnly || !inputValue;\n\n return (\n <BrButton\n aria-label=\"Clear\"\n type=\"tertiary\"\n className={cn('br-base-input__clear-button', {\n 'br-base-input__clear-button--hidden': hideClear,\n })}\n // Do not trigger onBlur when clear input\n onMouseDown={(e) => e.preventDefault()}\n startIcon={<CloseIcon />}\n onClick={handleReset}\n />\n );\n };\n\n const inputContainerClasses = cn('br-base-input', className, {\n 'br-base-input--disabled': disabled,\n 'br-base-input--error': error,\n 'br-base-input--focused': focused,\n 'br-base-input--hovered': hovered,\n 'br-base-input--readonly': readOnly,\n 'br-base-input--required': required,\n });\n\n const inputProps = getInputProps({\n ...inInputProps,\n className: cn('br-base-input__input', inInputProps.className, {\n 'br-base-input__input--multiline': multiline,\n 'br-base-input__input--has-right': clearable || rightElement,\n 'br-base-input__input--has-left': leftElement,\n }),\n ...rest,\n readOnly,\n });\n\n return (\n <div className={inputContainerClasses} {...getRootProps()} {...hoverHandlers}>\n {leftElement && (\n <span className=\"br-base-input__element\">{leftElement}</span>\n )}\n {multiline && (\n autoSize\n ? <TextareaAutosize {...inputProps} minRows={minRows} maxRows={maxRows} />\n : <textarea {...inputProps} rows={minRows} />\n )}\n {!multiline && <input {...inputProps} />}\n {(rightElement || clearable) && (\n <span className=\"br-base-input__element\">\n {clearable && getClearButton()}\n {rightElement}\n </span>\n )}\n </div>\n );\n});\n\nBrBaseInput.displayName = 'BrBaseInput';\n\nexport default BrBaseInput;\n","/**\n * Generate a unique id based on the field name\n */\nexport const generateFieldId = (fieldName: string): string => {\n return `${fieldName}-${Math.round(Math.random() * 1000)}`;\n};\n","import { ReactNode, forwardRef } from 'react';\nimport cn from 'classnames';\n\nimport { BrBaseField, BrBaseInput, BrBaseInputProps } from '../../internal';\nimport { generateFieldId } from '../base-field/generate-field-id';\n\nexport interface BrInputFieldProps {\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * Allow to remove `input` content with clear icon.\n */\n clearable?: boolean;\n /**\n * The default value. Use when the component is not controlled.\n */\n defaultValue?: string;\n /**\n * If `true`, the field is disabled.\n */\n disabled?: boolean;\n /**\n * If `true`, the ``field` will indicate an error and set the `aria-invalid` attribute for `input`.\n */\n error?: boolean;\n /**\n * If `true`, the field will take up the full width of its container.\n */\n fullWidth?: boolean;\n /**\n * The helper text content.\n */\n helperText?: ReactNode;\n /**\n * The `id` of the `input` element.\n */\n id?: string;\n /**\n * Attributes applied to the `input` element, check the link below for more details.\n * @link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input#Attributes\n */\n inputProps?: React.InputHTMLAttributes<HTMLInputElement>;\n /**\n * The label content.\n */\n label?: ReactNode;\n /**\n * Icon or any element displayed at the end of the `input`.\n */\n leftElement?: React.ReactNode;\n /**\n * The `name` attribute of the `input` element.\n */\n name?: string;\n /**\n * Callback fired when the `input` is blurred.\n */\n onBlur?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * Callback fired when the value is changed.\n */\n onChange?: React.ChangeEventHandler<HTMLInputElement>;\n /**\n * Callback fired when the `input` is focused.\n */\n onFocus?: React.FocusEventHandler<HTMLInputElement>;\n /**\n * The short hint displayed in the `input` before the user enters a value.\n */\n placeholder?: string;\n /**\n * If `true`, the `input` element will be read-only.\n */\n readOnly?: boolean;\n /**\n * If `true`, the `input` element will be required.\n */\n required?: boolean;\n /**\n * Icon or any element displayed at the start of the `input`.\n */\n rightElement?: React.ReactNode;\n /**\n * Tooltip to display when the field has label.\n */\n tooltip?: ReactNode;\n /**\n * The `value` of the `input` element, required for a controlled component.\n */\n value?: string;\n}\n\n/**\n * The input field includes a label, a helper text and an input field where users can type one line of text.\n * The input field component typically appears in forms and dialogs.\n *\n * ## Usage\n *\n * ### Basic\n * ```jsx\n * import { BrInputField } from '@bloomreach/react-banana-ui';\n *\n * export default function MyComponent() {\n * return <BrInputField placeholder=\"Placeholder...\" />;\n * }\n * ```\n *\n * ### With label and helper text\n * ```jsx\n * import { BrInputField } from '@bloomreach/react-banana-ui';\n *\n * export default function MyComponent() {\n * return (\n * <BrInputField\n * label=\"Field with a label\"\n * helperText=\"This is helper text\"\n * />\n * );\n * }\n * ```\n */\nconst BrInputField = forwardRef((props: BrInputFieldProps, ref: React.ForwardedRef<HTMLInputElement>) => {\n const {\n className,\n clearable,\n defaultValue,\n disabled,\n error,\n helperText,\n inputProps,\n label,\n leftElement,\n name,\n onBlur,\n onChange,\n onFocus,\n placeholder,\n readOnly,\n required,\n rightElement,\n tooltip,\n value,\n id,\n ...rest\n } = props;\n\n const controlId = id ?? inputProps?.id ?? generateFieldId('br-input-field-id');\n\n const baseInputProps: BrBaseInputProps = {\n clearable,\n defaultValue,\n disabled,\n error,\n id: controlId,\n inputProps,\n leftElement,\n name,\n onBlur,\n onChange,\n onFocus,\n placeholder,\n readOnly,\n required,\n rightElement,\n value,\n };\n\n return (\n <BrBaseField\n {...rest}\n className={cn('br-input-field', className)}\n control={(\n <BrBaseInput\n {...baseInputProps}\n ref={ref}\n />\n )}\n controlId={controlId}\n error={error}\n helperText={helperText}\n label={label}\n tooltip={tooltip}\n />\n );\n});\n\nBrInputField.displayName = 'BrInputField';\n\nexport default BrInputField;\n","import cn from 'classnames';\nimport {\n ChangeEventHandler,\n FocusEventHandler,\n ForwardedRef,\n forwardRef,\n ReactNode,\n TextareaHTMLAttributes,\n useState,\n} from 'react';\n\nimport { BrBaseField, BrBaseInput, BrBaseInputProps } from '../../internal';\nimport { generateFieldId } from '../base-field/generate-field-id';\n\nimport './text-field.scss';\n\nexport interface BrTextFieldProps {\n /**\n * Automatically adjusts `textarea` height to match the length of the content within.\n */\n autoSize?: boolean;\n /**\n * Custom class name for the container of this component.\n */\n className?: string;\n /**\n * If `true`, the field will display a character counter.\n * When the `maxCount` is also specified, the counter will be displayed like `x/y`,\n * where `x` is the current number of characters entered and `y` is the maximum number of characters allowed.\n */\n counter?: boolean;\n /**\n * The default value. Use when the component is not controlled.\n */\n defaultValue?: string;\n /**\n * If `true`, the `field is disabled.\n */\n disabled?: boolean;\n /**\n * If `true`, the ``field` will indicate an error and set the `aria-invalid` attribute for `textarea`.\n */\n error?: boolean;\n /**\n * If `true`, the `field will take up the full width of its container.\n */\n fullWidth?: boolean;\n /**\n * The helper text content.\n */\n helperText?: ReactNode;\n /**\n * The `id` of the `textarea` element.\n */\n id?: string;\n /**\n * The label content.\n */\n label?: ReactNode;\n /**\n * The maximum number of characters allowed in the field to display in the counter.\n * It doesn't prevent the user from typing more characters.\n * To do that, set the `maxLength` attribute via `textareaProps`.\n */\n maxCount?: number;\n /**\n * The maximum number of text lines to grow when `autoSize` is `true`.\n */\n maxRows?: number;\n /**\n * The number of visible text lines for the field.\n * When `autoSize` is `false`, this prop behaves as `rows` for `textarea`.\n * @default 3\n */\n minRows?: number;\n /**\n * The `name` attribute of the `textarea` element.\n */\n name?: string;\n /**\n * Callback fired when the `textarea` is blurred.\n */\n onBlur?: FocusEventHandler<HTMLTextAreaElement>;\n /**\n * Callback fired when the value is changed.\n */\n onChange?: ChangeEventHandler<HTMLTextAreaElement>;\n /**\n * Callback fired when the `textarea` is focused.\n */\n onFocus?: FocusEventHandler<HTMLTextAreaElement>;\n /**\n * The short hint displayed in the `textarea` before the user enters a value.\n */\n placeholder?: string;\n /**\n * If `true`, the `textarea` will be read-only.\n */\n readOnly?: boolean;\n /**\n * If `true`, the `textarea` is required.\n */\n required?: boolean;\n /**\n * If `true`, the `textarea` will be manually resizable.\n */\n resizable?: boolean;\n /**\n * Attributes applied to the `textarea` element, check the link below for more details.\n * @link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/textarea#Attributes\n */\n textareaProps?: TextareaHTMLAttributes<HTMLTextAreaElement>;\n /**\n * Tooltip to display when the field has label.\n */\n tooltip?: ReactNode;\n /**\n * The `value` of the `textarea` element, required for a controlled component.\n */\n value?: string;\n}\n\n/**\n * The text field includes a label, a helper text and a textarea field where users can type multiline of text.\n * The text field component typically appears in forms and dialogs.\n *\n * ## Usage\n *\n * ### Basic\n *\n * ```jsx\n * import { BrTextField } from '@bloomreach/react-banana-ui';\n *\n * export default function TextFieldExample() {\n * return <BrTextField placeholder=\"Placeholder...\" />;\n * }\n * ```\n *\n * ### With label and helper text\n * ```jsx\n * import { BrTextField } from '@bloomreach/react-banana-ui';\n *\n * export default function TextFieldExample() {\n * return (\n * <BrTextField\n * label=\"Field with a label\"\n * helperText=\"This is helper text\"\n * />\n * );\n * }\n * ```\n */\nconst BrTextField = forwardRef((props: BrTextFieldProps, ref: ForwardedRef<HTMLTextAreaElement>) => {\n const {\n autoSize,\n className,\n counter,\n defaultValue,\n disabled,\n error,\n helperText,\n id,\n label,\n maxCount,\n maxRows,\n minRows = 3,\n name,\n onBlur,\n onChange,\n onFocus,\n placeholder,\n readOnly,\n required,\n resizable,\n textareaProps,\n tooltip,\n value,\n ...rest\n } = props;\n\n const controlId = id ?? textareaProps?.id ?? generateFieldId('br-text-field-id');\n\n const baseInputProps: BrBaseInputProps = {\n autoSize,\n defaultValue,\n disabled,\n error,\n id: controlId,\n inputProps: {\n ...textareaProps,\n className: cn('br-text-field__textarea', textareaProps?.className, {\n 'br-text-field__textarea--resizable': resizable,\n }),\n },\n maxRows,\n minRows,\n name,\n onBlur,\n onChange,\n onFocus,\n placeholder,\n readOnly,\n required,\n value,\n };\n\n const [count, setCount] = useState(0);\n\n return (\n <BrBaseField\n {...rest}\n className={cn('br-text-field', className)}\n control={(\n <BrBaseInput\n {...baseInputProps}\n multiline\n onCountChange={setCount}\n ref={ref}\n />\n )}\n controlId={controlId}\n error={error}\n helperText={helperText}\n label={label}\n metadata={counter && (\n <span className=\"br-text-field__counter\">\n {`${count}${maxCount ? `/${maxCount}` : ''}`}\n </span>\n )}\n tooltip={tooltip}\n />\n );\n});\n\nBrTextField.displayName = 'BrTextField';\n\nexport default BrTextField;\n","import { createContext, useContext } from 'react';\nimport { BrPaginationProps } from './pagination-types';\n\nconst PaginationContext = createContext<BrPaginationProps | null>(null);\n\nexport function usePaginationContext(): BrPaginationProps | null {\n return useContext(PaginationContext);\n}\n\nexport default PaginationContext;\n","import { ItemsPerPageOptionsType } from './pagination-types';\n\nexport const DEFAULT_ITEMS_PER_PAGE_OPTIONS: ItemsPerPageOptionsType = [10, 20, 50];\n\nexport const PAGINATION_PAGES_LIMIT = 9;\n\nexport const PAGINATION_PAGES_BUFFER = 2;\n","/**\n * A method that does nothing. Useful for defaulting callbacks or placing stubs.\n */\nexport const NOOP = (): void => {\n /** Does nothing by design */\n};\n","export function wait(t: number): Promise<void> {\n return new Promise((r) => { setTimeout(r, t); });\n}\n","'use strict';\n\nvar m = require('react-dom');\nif (process.env.NODE_ENV === 'production') {\n exports.createRoot = m.createRoot;\n exports.hydrateRoot = m.hydrateRoot;\n} else {\n var i = m.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n exports.createRoot = function(c, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.createRoot(c, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n exports.hydrateRoot = function(c, h, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.hydrateRoot(c, h, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n}\n","/**\n * This takes several arguments and concatenates them into a single css class\n * name compatible string. It will remove any falsy values and will trim any\n * whitespace.\n */\nexport function classnames(...str: (string | undefined | null)[]): string {\n return str.filter(Boolean).join(' ').trim();\n}\n","/**\n * Padding values to grow a client rect during a client rect cloning operation.\n */\nexport type DOMRectPadding = {\n left?: number;\n top?: number;\n bottom?: number;\n right?: number;\n};\n\nexport type DOMRectBounds = {\n x: number;\n y: number;\n top: number;\n left: number;\n bottom: number;\n right: number;\n width: number;\n height: number;\n};\n\n/**\n * ClientRects are a bit annoying to work around their immutability if needed.\n * This properly makes a Mutable clone without altering the original (unless\n * padding is specified to do a one time change of the bounds. The padding\n * expands/contracts the box on the indicated sides).\n */\nexport function cloneClientRect(\n box?: DOMRectBounds,\n padding?: DOMRectPadding,\n): DOMRectBounds {\n if (!box) {\n return {\n x: 0,\n y: 0,\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n width: 0,\n height: 0,\n };\n }\n\n let { top, right, bottom, left, width, height } = box;\n\n if (padding) {\n if (padding.left) {\n left -= padding.left;\n width += padding.left;\n }\n\n if (padding.right) {\n right += padding.right;\n width += padding.right;\n }\n\n if (padding.top) {\n top -= padding.top;\n height += padding.top;\n }\n\n if (padding.bottom) {\n bottom += padding.bottom;\n height += padding.bottom;\n }\n }\n\n return { x: left, y: top, top, right, bottom, left, width, height };\n}\n","/** This is the id to be used to specify the modal root. */\nconst modalRootId = '__modal_root__';\n\n/**\n * This guarantees the modal root to exist at the body root level\n */\nexport function ensureModalRoot(customId?: string): HTMLDivElement {\n let modalRoot: HTMLDivElement | null = null;\n const root = document.getElementById(customId || modalRootId);\n\n if (root instanceof HTMLDivElement) {\n modalRoot = root;\n } else {\n // eslint-disable-next-line prefer-destructuring\n const body = document.getElementsByTagName('body')[0];\n modalRoot = document.createElement('div');\n\n if (body && modalRoot) {\n body.appendChild(modalRoot);\n }\n }\n\n if (modalRoot) {\n modalRoot.setAttribute(\n 'style',\n `\n position: fixed;\n top: 0px;\n left: 0px;\n width: 100%;\n z-index: 999999;\n `,\n );\n\n // Allows make sure the ensured modal is on top. THis helps with layering\n // modal roots for things like tooltips/dropdowns on top of modals etc.\n if (document.body.lastChild !== modalRoot) {\n document.body.appendChild(modalRoot);\n }\n\n modalRoot.id = customId || modalRootId;\n }\n\n return modalRoot;\n}\n","/**\n * Interface for declaring a generic JSON valid object\n */\nexport interface IJson {\n [x: string]: string | number | boolean | Date | IJson | IJsonArray;\n}\n\n/**\n * Interface for declaring a generic JSON valid object\n */\nexport interface IJsonType {\n [x: string]:\n | string\n | number\n | boolean\n | Date\n | IJsonType\n | IJsonArray\n | undefined\n | null;\n}\n\n/**\n * Part of the IJson declaration to make a valid JSON type.\n */\nexport type IJsonArray = (\n | string\n | number\n | boolean\n | Date\n | IJson\n | IJsonArray\n)[];\n\n/**\n * This is to help establish a custom child pattern for React. The props for your react component simply needs to extend\n * this interface.\n */\nexport type IChildren<T extends object> = T & {\n children?: Partial<T>;\n};\n\n/**\n * This lets you define children for a component and forces the children to be declared in the props as opposed to\n * nesting the children.\n */\nexport type IPropsChildren<T extends object> = T & {\n children: never;\n};\n\n/**\n * This lets you define children for a component and forces the children to be nested as opposed to\n * being declared in the props.\n */\nexport type INestedChildren<T> = {\n children?: T;\n};\n\n/**\n * A slightly stronger type for indicating \"Function\". This has greater\n * flexibility to fit into generic callbacks.\n */\nexport type GenericFunction<T> = (...args: any[]) => T;\n\n/**\n * This type is intended for the async operation of a \"flow\". A flow can have\n * several yield statements, but are NOT for the intention of returning values\n * to the caller, but rather for the intent of performing a mobx action that has\n * asynchronous properties.\n */\nexport type FlowType = Generator<unknown, unknown, unknown> | undefined;\n\n/**\n * Typeguard for strings\n */\nexport function isString(val: any): val is string {\n return val && val.charCodeAt !== void 0;\n}\n\n/**\n * Typeguard for numbers\n */\nexport function isNumber(val: any): val is number {\n return val !== void 0 && val.toExponential;\n}\n\n/**\n * Typeguard for booleans\n */\nexport function isBoolean(val: any): val is boolean {\n return val === true || val === false;\n}\n\n/**\n * Typeguard for functions\n */\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function isFunction(val: any): val is Function {\n return typeof val === 'function';\n}\n\n/**\n * Typegaurd for ensuring an element is non-null and not undefined.\n */\nexport function isDefined<T>(val: T | undefined | null): val is T {\n return val !== void 0 && val !== null;\n}\n","/**\n * Searches up the DOM tree for the first instance of a given class to be\n * located. If none exists no result will be returned.\n */\nexport function getFirstWithClass(element: HTMLElement, className: string): HTMLElement | null {\n // Extract the element that is a row from the target\n let next: HTMLElement | null = element;\n\n while (next && !next.classList.contains(className)) {\n next = next.parentElement;\n }\n\n return next;\n}\n","/**\n * This checks to see if the specified child IS a child of the indicated parent.\n */\nexport function hasChild(\n parent: HTMLElement | null,\n child: HTMLElement | null,\n): boolean {\n if (!parent || !child) { return false; }\n let next: any = child;\n\n while (next) {\n if (next === parent) { return true; }\n next = next.parentNode;\n }\n\n return false;\n}\n","/* eslint-disable */\n/**\n BSD License\n\n Copyright (c) 2015, Facebook, Inc. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without modification,\n are permitted provided that the following conditions are met:\n\n * Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n * Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n * Neither the name Facebook nor the names of its contributors may be used to\n endorse or promote products derived from this software without specific\n prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n\"use strict\";\n\nvar canUseDOM = !!(\n typeof window !== \"undefined\" &&\n window.document &&\n window.document.createElement\n);\n\n/**\n * Simple, lightweight module assisting with the detection and context of\n * Worker. Helps avoid circular dependencies and allows code to reason about\n * whether or not they are in a Worker, even if they never include the main\n * `ReactWorker` dependency.\n */\nvar ExecutionEnvironment: any = {\n canUseDOM: canUseDOM,\n\n canUseWorkers: typeof Worker !== \"undefined\",\n\n canUseEventListeners:\n canUseDOM && !!(window.addEventListener || (window as any).attachEvent),\n\n canUseViewport: canUseDOM && !!window.screen,\n\n isInWorker: !canUseDOM, // For now, this is true - might change in the future.\n};\n\nexport default ExecutionEnvironment;\n","/* eslint-disable */\n/**\n BSD License\n\n Copyright (c) 2015, Facebook, Inc. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without modification,\n are permitted provided that the following conditions are met:\n\n * Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n * Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n * Neither the name Facebook nor the names of its contributors may be used to\n endorse or promote products derived from this software without specific\n prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n\"use strict\";\n\nimport ExecutionEnvironment from \"./ExecutionEnvironment\";\n\nvar useHasFeature: any;\nif (ExecutionEnvironment.canUseDOM) {\n useHasFeature =\n document.implementation &&\n document.implementation.hasFeature &&\n // always returns true in newer browsers as per the standard.\n // @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature\n document.implementation.hasFeature(\"\", \"\") !== true;\n}\n\n/**\n * Checks if an event is supported in the current execution environment.\n *\n * NOTE: This will not work correctly for non-generic events such as `change`,\n * `reset`, `load`, `error`, and `select`.\n *\n * Borrows from Modernizr.\n *\n * @param {string} eventNameSuffix Event name, e.g. \"click\".\n * @param {?boolean} capture Check if the capture phase is supported.\n * @return {boolean} True if the event is supported.\n * @internal\n * @license Modernizr 3.0.0pre (Custom Build) | MIT\n */\nfunction isEventSupported(eventNameSuffix: any, capture?: any) {\n if (\n !ExecutionEnvironment.canUseDOM ||\n (capture && !(\"addEventListener\" in document))\n ) {\n return false;\n }\n\n var eventName = \"on\" + eventNameSuffix;\n var isSupported = eventName in document;\n\n if (!isSupported) {\n var element: any = document.createElement(\"div\");\n element.setAttribute(eventName, \"return;\");\n isSupported = typeof element[eventName] === \"function\";\n }\n\n if (!isSupported && useHasFeature && eventNameSuffix === \"wheel\") {\n // This is the only way to test support for the `wheel` event in IE9+.\n isSupported = document.implementation.hasFeature(\"Events.wheel\", \"3.0\");\n }\n\n return isSupported;\n}\n\nexport default isEventSupported;\n","/* eslint-disable */\n/**\n BSD License\n\n Copyright (c) 2015, Facebook, Inc. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without modification,\n are permitted provided that the following conditions are met:\n\n * Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n * Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n * Neither the name Facebook nor the names of its contributors may be used to\n endorse or promote products derived from this software without specific\n prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\n/**\n * Provides entirely client-side User Agent and OS detection. You should prefer\n * the non-deprecated UserAgent module when possible, which exposes our\n * authoritative server-side PHP-based detection to the client.\n *\n * Usage is straightforward:\n *\n * if (UserAgent_DEPRECATED.ie()) {\n * // IE\n * }\n *\n * You can also do version checks:\n *\n * if (UserAgent_DEPRECATED.ie() >= 7) {\n * // IE7 or better\n * }\n *\n * The browser functions will return NaN if the browser does not match, so\n * you can also do version compares the other way:\n *\n * if (UserAgent_DEPRECATED.ie() < 7) {\n * // IE6 or worse\n * }\n *\n * Note that the version is a float and may include a minor version number,\n * so you should always use range operators to perform comparisons, not\n * strict equality.\n *\n * **Note:** You should **strongly** prefer capability detection to browser\n * version detection where it's reasonable:\n *\n * http://www.quirksmode.org/js/support.html\n *\n * Further, we have a large number of mature wrapper functions and classes\n * which abstract away many browser irregularities. Check the documentation,\n * grep for things, or ask on javascript@lists.facebook.com before writing yet\n * another copy of \"event || window.event\".\n *\n */\n\nvar _populated = false;\n\n// Browsers\nvar _ie: any, _firefox: any, _opera: any, _webkit: any, _chrome: any;\n\n// Actual IE browser for compatibility mode\nvar _ie_real_version: any;\n\n// Platforms\nvar _osx: any, _windows: any, _linux: any, _android: any;\n\n// Architectures\nvar _win64: any;\n\n// Devices\nvar _iphone: any, _ipad: any, _native: any;\n\nvar _mobile: any;\n\nfunction _populate(): any {\n if (_populated) {\n return;\n }\n\n _populated = true;\n\n // To work around buggy JS libraries that can't handle multi-digit\n // version numbers, Opera 10's user agent string claims it's Opera\n // 9, then later includes a Version/X.Y field:\n //\n // Opera/9.80 (foo) Presto/2.2.15 Version/10.10\n var uas = navigator.userAgent;\n var agent =\n /(?:MSIE.(\\d+\\.\\d+))|(?:(?:Firefox|GranParadiso|Iceweasel).(\\d+\\.\\d+))|(?:Opera(?:.+Version.|.)(\\d+\\.\\d+))|(?:AppleWebKit.(\\d+(?:\\.\\d+)?))|(?:Trident\\/\\d+\\.\\d+.*rv:(\\d+\\.\\d+))/.exec(\n uas\n );\n var os = /(Mac OS X)|(Windows)|(Linux)/.exec(uas);\n\n _iphone = /\\b(iPhone|iP[ao]d)/.exec(uas);\n _ipad = /\\b(iP[ao]d)/.exec(uas);\n _android = /Android/i.exec(uas);\n _native = /FBAN\\/\\w+;/i.exec(uas);\n _mobile = /Mobile/i.exec(uas);\n\n // Note that the IE team blog would have you believe you should be checking\n // for 'Win64; x64'. But MSDN then reveals that you can actually be coming\n // from either x64 or ia64; so ultimately, you should just check for Win64\n // as in indicator of whether you're in 64-bit IE. 32-bit IE on 64-bit\n // Windows will send 'WOW64' instead.\n _win64 = !!/Win64/.exec(uas);\n\n if (agent) {\n _ie = agent[1]\n ? parseFloat(agent[1])\n : agent[5]\n ? parseFloat(agent[5])\n : NaN;\n // IE compatibility mode\n if (_ie && document && (document as any).documentMode) {\n _ie = (document as any).documentMode;\n }\n // grab the \"true\" ie version from the trident token if available\n var trident = /(?:Trident\\/(\\d+.\\d+))/.exec(uas);\n _ie_real_version = trident ? parseFloat(trident[1]) + 4 : _ie;\n\n _firefox = agent[2] ? parseFloat(agent[2]) : NaN;\n _opera = agent[3] ? parseFloat(agent[3]) : NaN;\n _webkit = agent[4] ? parseFloat(agent[4]) : NaN;\n if (_webkit) {\n // We do not add the regexp to the above test, because it will always\n // match 'safari' only since 'AppleWebKit' appears before 'Chrome' in\n // the userAgent string.\n agent = /(?:Chrome\\/(\\d+\\.\\d+))/.exec(uas);\n _chrome = agent && agent[1] ? parseFloat(agent[1]) : NaN;\n } else {\n _chrome = NaN;\n }\n } else {\n _ie = _firefox = _opera = _chrome = _webkit = NaN;\n }\n\n if (os) {\n if (os[1]) {\n // Detect OS X version. If no version number matches, set _osx to true.\n // Version examples: 10, 10_6_1, 10.7\n // Parses version number as a float, taking only first two sets of\n // digits. If only one set of digits is found, returns just the major\n // version number.\n var ver = /(?:Mac OS X (\\d+(?:[._]\\d+)?))/.exec(uas);\n\n _osx = ver ? parseFloat(ver[1].replace(\"_\", \".\")) : true;\n } else {\n _osx = false;\n }\n _windows = !!os[2];\n _linux = !!os[3];\n } else {\n _osx = _windows = _linux = false;\n }\n}\n\nvar UserAgent_DEPRECATED = {\n /**\n * Check if the UA is Internet Explorer.\n *\n *\n * @return float|NaN Version number (if match) or NaN.\n */\n ie: function () {\n return _populate() || _ie;\n },\n\n /**\n * Check if we're in Internet Explorer compatibility mode.\n *\n * @return bool true if in compatibility mode, false if\n * not compatibility mode or not ie\n */\n ieCompatibilityMode: function () {\n return _populate() || _ie_real_version > _ie;\n },\n\n /**\n * Whether the browser is 64-bit IE. Really, this is kind of weak sauce; we\n * only need this because Skype can't handle 64-bit IE yet. We need to remove\n * this when we don't need it -- tracked by #601957.\n */\n ie64: function () {\n return UserAgent_DEPRECATED.ie() && _win64;\n },\n\n /**\n * Check if the UA is Firefox.\n *\n *\n * @return float|NaN Version number (if match) or NaN.\n */\n firefox: function () {\n return _populate() || _firefox;\n },\n\n /**\n * Check if the UA is Opera.\n *\n *\n * @return float|NaN Version number (if match) or NaN.\n */\n opera: function () {\n return _populate() || _opera;\n },\n\n /**\n * Check if the UA is WebKit.\n *\n *\n * @return float|NaN Version number (if match) or NaN.\n */\n webkit: function () {\n return _populate() || _webkit;\n },\n\n /**\n * For Push\n * WILL BE REMOVED VERY SOON. Use UserAgent_DEPRECATED.webkit\n */\n safari: function () {\n return UserAgent_DEPRECATED.webkit();\n },\n\n /**\n * Check if the UA is a Chrome browser.\n *\n *\n * @return float|NaN Version number (if match) or NaN.\n */\n chrome: function () {\n return _populate() || _chrome;\n },\n\n /**\n * Check if the user is running Windows.\n *\n * @return bool `true' if the user's OS is Windows.\n */\n windows: function () {\n return _populate() || _windows;\n },\n\n /**\n * Check if the user is running Mac OS X.\n *\n * @return float|bool Returns a float if a version number is detected,\n * otherwise true/false.\n */\n osx: function () {\n return _populate() || _osx;\n },\n\n /**\n * Check if the user is running Linux.\n *\n * @return bool `true' if the user's OS is some flavor of Linux.\n */\n linux: function () {\n return _populate() || _linux;\n },\n\n /**\n * Check if the user is running on an iPhone or iPod platform.\n *\n * @return bool `true' if the user is running some flavor of the\n * iPhone OS.\n */\n iphone: function () {\n return _populate() || _iphone;\n },\n\n mobile: function () {\n return _populate() || _iphone || _ipad || _android || _mobile;\n },\n\n nativeApp: function () {\n // webviews inside of the native apps\n return _populate() || _native;\n },\n\n android: function () {\n return _populate() || _android;\n },\n\n ipad: function () {\n return _populate() || _ipad;\n },\n};\n\nexport default UserAgent_DEPRECATED;\n","/**\n BSD License\n\n Copyright (c) 2015, Facebook, Inc. All rights reserved.\n\n Redistribution and use in source and binary forms, with or without modification,\n are permitted provided that the following conditions are met:\n\n * Redistributions of source code must retain the above copyright notice, this\n list of conditions and the following disclaimer.\n\n * Redistributions in binary form must reproduce the above copyright notice,\n this list of conditions and the following disclaimer in the documentation\n and/or other materials provided with the distribution.\n\n * Neither the name Facebook nor the names of its contributors may be used to\n endorse or promote products derived from this software without specific\n prior written permission.\n\n THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\n ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\n DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR\n ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES\n (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;\n LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON\n ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT\n (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS\n SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n*/\n\nimport isEventSupported from './isEventSupported';\n// eslint-disable-next-line camelcase\nimport UserAgent_DEPRECATED from './UserAgent_DEPRECATED';\n\n// Reasonable defaults\nconst PIXEL_STEP = 10;\nconst LINE_HEIGHT = 40;\nconst PAGE_HEIGHT = 800;\n\n/**\n * Mouse wheel (and 2-finger trackpad) support on the web sucks. It is\n * complicated, thus this doc is long and (hopefully) detailed enough to answer\n * your questions.\n *\n * If you need to react to the mouse wheel in a predictable way, this code is\n * like your bestest friend. * hugs *\n *\n * As of today, there are 4 DOM event types you can listen to:\n *\n * 'wheel' -- Chrome(31+), FF(17+), IE(9+)\n * 'mousewheel' -- Chrome, IE(6+), Opera, Safari\n * 'MozMousePixelScroll' -- FF(3.5 only!) (2010-2013) -- don't bother!\n * 'DOMMouseScroll' -- FF(0.9.7+) since 2003\n *\n * So what to do? The is the best:\n *\n * normalizeWheel.getEventType();\n *\n * In your event callback, use this code to get sane interpretation of the\n * deltas. This code will return an object with properties:\n *\n * spinX -- normalized spin speed (use for zoom) - x plane\n * spinY -- \" - y plane\n * pixelX -- normalized distance (to pixels) - x plane\n * pixelY -- \" - y plane\n *\n * Wheel values are provided by the browser assuming you are using the wheel to\n * scroll a web page by a number of lines or pixels (or pages). Values can vary\n * significantly on different platforms and browsers, forgetting that you can\n * scroll at different speeds. Some devices (like trackpads) emit more events\n * at smaller increments with fine granularity, and some emit massive jumps with\n * linear speed or acceleration.\n *\n * This code does its best to normalize the deltas for you:\n *\n * - spin is trying to normalize how far the wheel was spun (or trackpad\n * dragged). This is super useful for zoom support where you want to\n * throw away the chunky scroll steps on the PC and make those equal to\n * the slow and smooth tiny steps on the Mac. Key data: This code tries to\n * resolve a single slow step on a wheel to 1.\n *\n * - pixel is normalizing the desired scroll delta in pixel units. You'll\n * get the crazy differences between browsers, but at least it'll be in\n * pixels!\n *\n * - positive value indicates scrolling DOWN/RIGHT, negative UP/LEFT. This\n * should translate to positive value zooming IN, negative zooming OUT.\n * This matches the newer 'wheel' event.\n *\n * Why are there spinX, spinY (or pixels)?\n *\n * - spinX is a 2-finger side drag on the trackpad, and a shift + wheel turn\n * with a mouse. It results in side-scrolling in the browser by default.\n *\n * - spinY is what you expect -- it's the classic axis of a mouse wheel.\n *\n * - I dropped spinZ/pixelZ. It is supported by the DOM 3 'wheel' event and\n * probably is by browsers in conjunction with fancy 3D controllers .. but\n * you know.\n *\n * Implementation info:\n *\n * Examples of 'wheel' event if you scroll slowly (down) by one step with an\n * average mouse:\n *\n * OS X + Chrome (mouse) - 4 pixel delta (wheelDelta -120)\n * OS X + Safari (mouse) - N/A pixel delta (wheelDelta -12)\n * OS X + Firefox (mouse) - 0.1 line delta (wheelDelta N/A)\n * Win8 + Chrome (mouse) - 100 pixel delta (wheelDelta -120)\n * Win8 + Firefox (mouse) - 3 line delta (wheelDelta -120)\n *\n * On the trackpad:\n *\n * OS X + Chrome (trackpad) - 2 pixel delta (wheelDelta -6)\n * OS X + Firefox (trackpad) - 1 pixel delta (wheelDelta N/A)\n *\n * On other/older browsers.. it's more complicated as there can be multiple and\n * also missing delta values.\n *\n * The 'wheel' event is more standard:\n *\n * http://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents\n *\n * The basics is that it includes a unit, deltaMode (pixels, lines, pages), and\n * deltaX, deltaY and deltaZ. Some browsers provide other values to maintain\n * backward compatibility with older events. Those other values help us\n * better normalize spin speed. Example of what the browsers provide:\n *\n * | event.wheelDelta | event.detail\n * ------------------+------------------+--------------\n * Safari v5/OS X | -120 | 0\n * Safari v5/Win7 | -120 | 0\n * Chrome v17/OS X | -120 | 0\n * Chrome v17/Win7 | -120 | 0\n * IE9/Win7 | -120 | undefined\n * Firefox v4/OS X | undefined | 1\n * Firefox v4/Win7 | undefined | 3\n *\n */\nexport function normalizeWheel(/* object*/ event: any): {\n spinX: number;\n spinY: number;\n pixelX: number;\n pixelY: number;\n} {\n let sX = 0;\n let sY = 0; // spinX, spinY\n let pX = 0;\n let pY = 0; // pixelX, pixelY\n\n // Legacy\n if ('detail' in event) {\n sY = event.detail;\n }\n if ('wheelDelta' in event) {\n sY = -event.wheelDelta / 120;\n }\n if ('wheelDeltaY' in event) {\n sY = -event.wheelDeltaY / 120;\n }\n if ('wheelDeltaX' in event) {\n sX = -event.wheelDeltaX / 120;\n }\n\n // side scrolling on FF with DOMMouseScroll\n if ('axis' in event && event.axis === event.HORIZONTAL_AXIS) {\n sX = sY;\n sY = 0;\n }\n\n pX = sX * PIXEL_STEP;\n pY = sY * PIXEL_STEP;\n\n if ('deltaY' in event) {\n pY = event.deltaY;\n }\n if ('deltaX' in event) {\n pX = event.deltaX;\n }\n\n if ((pX || pY) && event.deltaMode) {\n if (event.deltaMode === 1) {\n // delta in LINE units\n pX *= LINE_HEIGHT;\n pY *= LINE_HEIGHT;\n } else {\n // delta in PAGE units\n pX *= PAGE_HEIGHT;\n pY *= PAGE_HEIGHT;\n }\n }\n\n // Fall-back if spin cannot be determined\n if (pX && !sX) {\n sX = pX < 1 ? -1 : 1;\n }\n if (pY && !sY) {\n sY = pY < 1 ? -1 : 1;\n }\n\n return {\n spinX: sX,\n spinY: -sY,\n pixelX: pX,\n pixelY: -pY,\n };\n}\n\n/**\n * The best combination if you prefer spinX + spinY normalization. It favors\n * the older DOMMouseScroll for Firefox, as FF does not include wheelDelta with\n * 'wheel' event, making spin speed determination impossible.\n */\n// eslint-disable-next-line func-names\nnormalizeWheel.getEventType = function (): 'DOMMouseScroll' | 'wheel' | 'mousewheel' {\n // eslint-disable-next-line camelcase, no-nested-ternary\n return UserAgent_DEPRECATED.firefox()\n ? 'DOMMouseScroll'\n : isEventSupported('wheel')\n ? 'wheel'\n : 'mousewheel';\n};\n","import * as React from 'react';\nimport { hasChild } from './has-child';\n\ninterface IHoverState {\n hovered: boolean;\n}\n\ninterface IFocusState {\n focused: boolean;\n}\n\ninterface IMosueDownState {\n mousedown: boolean;\n}\n\nexport function controlHover<TState extends IHoverState>(\n component: React.Component<any, TState> & {\n container?: React.RefObject<HTMLDivElement>;\n },\n over?: (e: React.MouseEvent) => void | boolean,\n out?: (e: React.MouseEvent) => void | boolean,\n): {\n onMouseOver: (e: React.MouseEvent) => void;\n onMouseLeave: (e: React.MouseEvent) => void;\n} {\n return {\n onMouseOver: (e: React.MouseEvent) => {\n component.setState({ hovered: true });\n over?.(e);\n },\n onMouseLeave: (e: React.MouseEvent) => {\n // If the component has a declared div container, then we assess that the\n // mouse leaving event is truly related to the parent or some other event\n // bubbled up.\n\n if (component.container && component.container.current) {\n if (\n !hasChild(component.container.current, e.nativeEvent.target as any)\n ) {\n out?.(e);\n return;\n }\n }\n\n component.setState({ hovered: false });\n out?.(e);\n },\n };\n}\n\nexport function controlMouseDown<TState extends IMosueDownState>(\n component: React.Component<any, TState> & {\n container?: React.RefObject<HTMLDivElement>;\n },\n): {\n onMouseDown: () => void;\n onMouseUp: () => void;\n onMouseOut: (e: React.MouseEvent) => void;\n} {\n return {\n onMouseDown: () => component.setState({ mousedown: true }),\n onMouseUp: () => component.setState({ mousedown: false }),\n onMouseOut: (e: React.MouseEvent) => {\n // If the component has a declared div container, then we assess that the\n // mouse leaving event is truly related to the parent or some other event\n // bubbled up.\n if (component.container && component.container.current) {\n if (\n !hasChild(component.container.current, e.nativeEvent.target as any)\n ) {\n return;\n }\n }\n\n component.setState({ mousedown: false });\n },\n };\n}\n\nexport function controlFocus<TState extends IFocusState>(\n component: React.Component<any, TState>,\n): {\n onFocus: () => void;\n onBlur: () => void;\n} {\n return {\n onFocus: () => component.setState({ focused: true }),\n onBlur: () => component.setState({ focused: false }),\n };\n}\n","import * as React from 'react';\n\n/**\n * This is a VERY thorough event propogation halt. This prevents defaults\n * and propogation and handles native and React events.\n */\nexport function stopPropagation(\n e:\n | React.MouseEvent\n | React.ChangeEvent\n | (MouseEvent & { nativeEvent?: any })\n | Event,\n): boolean {\n try {\n const anyEvent = e as any;\n anyEvent.stopPropagation?.();\n anyEvent.preventDefault?.();\n\n if (anyEvent.nativeEvent) {\n anyEvent.nativeEvent.stopImmediatePropagation?.();\n anyEvent.nativeEvent.stopPropagation?.();\n anyEvent.nativeEvent.preventDefault?.();\n }\n return false;\n } catch (err) {\n // no - op\n return false;\n }\n}\n","// eslint-disable-next-line @typescript-eslint/ban-types\nfunction isFunction(val: any): val is Function {\n return typeof val === 'function';\n}\n\nexport function when<TTest, T, U>(\n condition: TTest | null | undefined,\n value: ((condition: TTest) => T) | T\n): T | U | undefined;\nexport function when<TTest, T, U>(\n condition: TTest | null | undefined,\n value: ((condition: TTest) => T) | T,\n otherwise: (() => U) | U\n): T | U;\n\n/**\n * Cleans up ternary operators in JSX with a when statement. First argument is\n * any truthy value and the value is either the value directly or a callback\n * returning the value.\n *\n * Use a callback to prevent evaluation of the value if the condition does not\n * return. Use a value and not a callback if there is no evaluation when the\n * value is returned.\n *\n * An example of when it's better to not evaluate the returned value is when the\n * value is JSX where inherent React.createElements will be called if just a\n * value was returned.\n */\nexport function when<TTest, T, U>(\n condition: TTest | null | undefined,\n value: ((condition: TTest) => T) | T,\n otherwise?: (() => U) | U,\n): T | U | undefined {\n if (condition) {\n if (isFunction(value)) {\n return value(condition);\n }\n return value;\n } if (otherwise) {\n if (isFunction(otherwise)) {\n return otherwise();\n }\n return otherwise;\n }\n\n return undefined;\n}\n","/**\n * ID used for the Toast modal. Helpful for keeping the modals sorted to a\n * degree.\n */\nexport const ToastModalID = '__yeah_toast__';\n\n/**\n * ID used for the tooltip modal. Helpful for keeping the modals sorted to a\n * degree.\n */\nexport const TooltipModalID = '__tooltip__';\n\n/**\n * ID used for the generic dropdown modal. Helpful for keeping the modals sorted\n * to a degree.\n */\nexport const DropdownModalID = '__dropdown__';\n\n/**\n * Date type format. Strings are expected to be in an appropriate ISO format.\n */\nexport type DateType = string | number | Date;\n","import * as ReactDOM from 'react-dom';\nimport * as React from 'react';\nimport { classnames, DOMRectBounds, ensureModalRoot, hasChild, stopPropagation } from '../../../utils';\nimport { DropdownModalID, TooltipModalID } from '../../types';\nimport './dropdown.scss';\n\nexport interface IDropdown {\n /** Allows children */\n children?: React.ReactNode;\n /**\n * When this is provided, it will open the menu relative to these provided\n * bounds\n */\n bounds?: DOMRectBounds | null;\n /** Provides a custom class name to the container of this component. */\n className?: string;\n /** Props to apply directly to the container div of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n /**\n * If there is already a modal root in the document, you can specify one here.\n * Otherwise, one will automatically be made\n */\n customModalRoot?: HTMLElement;\n /**\n * Provide a custom modal root by ID instead of element so this component will\n * ensure the modal itself\n */\n customModalRootId?: string;\n /**\n * Will inline the contents of this dropdown if there are no bounds provided\n */\n showWithNoBounds?: boolean;\n /**\n * This makes the dropdown region cover the reference bounds IFF the dropdown\n * can fit dropping down\n */\n coverBounds?: boolean;\n /**\n * When set, this renders this dropdown inline in the DOM where it is\n * rendered. This lets you render the dropdown in a \"relative\" context easily.\n */\n inline?: boolean;\n /**\n * This is the suggested height of the region. This may not always be the true\n * height as this region positions itself as good as possible relative to the\n * reference bounds.\n *\n * If this is omitted, the height of the region is allowed to flex, but may\n * cause a slight flicker while the region gets computed.\n */\n height?: number;\n /**\n * When provided this sets a manual width for the menu instead of utilizing\n * the reference bound;\n */\n width?: number;\n /**\n * Does not let the modal's width exceed this amount.\n */\n maxWidth?: number;\n /**\n * If this is set, this will prioritize positioning itself above the bounds\n * instead of below the bounds.\n */\n dropUp?: boolean;\n /**\n * If this is set, this will prioritize positioning itself left of the bounds\n * instead of below the bounds.\n */\n dropLeft?: boolean;\n /**\n * If this is set, this will prioritize positioning itself right of the bounds\n * instead of below the bounds.\n */\n dropRight?: boolean;\n /**\n * If this is set, this will prioritize positioning itself center of the bounds\n * instead of below the bounds. Mainly used to center the tooltip component.\n */\n dropCenter?: boolean;\n /**\n * If this is set, this will perform a middling procedure to attempt to align\n * the middle of the dropdown to its reference. This is specifically NOT\n * called \"centering\" because it \"can\" be used to center the dropdown if the\n * reference space is sufficiently small, but otherwise will NOT actually\n * center the dropdown.\n */\n shiftToMiddle?: boolean;\n /**\n * Populates a ref object that points to this object\n */\n ref?: React.RefObject<Dropdown>;\n /**\n * This is a very advanced usage of the dropdown to help resolve overlapping\n * drop down dismissals. When this is set, the dropdown will test to see if\n * the event happened on the container instead of the modal root. This helps\n * resolve nuances when dropdowns share the same modal root.\n */\n dismissTestOnContainer?: boolean;\n\n /**\n * Event fires when there is a typical user interaction that suggests this\n * dropdown should be dismissed, such as clicking outside of these dropdowns\n * rendered region.\n */\n onClose?(e: MouseEvent): void;\n}\n\n/**\n * The document body needs to have a modal root object to display the menu and\n * modals\n */\nlet modalRoot: HTMLDivElement | null = null;\n/**\n * This takes in the modals by their ID. To allow dismissal of the modal, the\n * modal must be the last item in the queue. For duplicate ids, this will add\n * itself to the set for the current id layered in.\n */\nconst dismissDropdownQueue: [string, Set<Dropdown>][] = [];\n\ninterface IState {\n dropdownWidth?: number;\n dropdownHeight?: number;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * Less opinionated dropdown region that offers a region to render within but\n * does not have contents of its own.\n */\nexport class Dropdown extends React.Component<IDropdown> {\n container = React.createRef<HTMLDivElement>();\n state: IState = {};\n\n componentDidMount(): void {\n const { customModalRoot } = this.props;\n document.addEventListener('mousedown', this.handleDocumentDown);\n // We must ensure the body document has the modal root available for us to\n // render the dropdown\n if (!customModalRoot) {\n modalRoot = ensureModalRoot(this.modalId);\n }\n\n ensureModalRoot(TooltipModalID);\n\n if (!modalRoot && !customModalRoot) {\n // eslint-disable-next-line no-console\n console.warn(\n 'Could not establish the modal root for the document to display Menus and modals',\n );\n }\n\n if (this.isOpen) { this.addQueueId(); }\n this.componentDidUpdate();\n }\n\n componentDidUpdate(): void {\n if (!this.container.current) { return; }\n\n const { dropdownWidth } = this.state;\n\n // Make sure we are queued for dismissal if the dropdown is open\n if (this.isOpen) { this.addQueueId(); }\n\n if (dropdownWidth === void 0) {\n const box = this.container.current.getBoundingClientRect();\n\n this.setState({\n dropdownWidth: box.width,\n dropdownHeight: box.height,\n });\n }\n }\n\n componentWillUnmount(): void {\n // Ensure this item is removed\n this.removeQueueId();\n document.removeEventListener('mousedown', this.handleDocumentDown);\n }\n\n get isOpen(): boolean {\n const { bounds } = this.props;\n\n return Boolean(bounds);\n }\n\n private get modalId(): string | '__dropdown__' {\n const { customModalRootId } = this.props;\n\n return customModalRootId || DropdownModalID;\n }\n\n // eslint-disable-next-line class-methods-use-this\n private get topQueuedItem(): [string, Set<any>] | undefined {\n return dismissDropdownQueue[dismissDropdownQueue.length - 1];\n }\n\n private get isTopQueuedId(): boolean {\n return this.topQueuedItem?.[0] === this.modalId;\n }\n\n private get isTopQueued(): boolean {\n const topItem = this.topQueuedItem;\n return topItem?.[0] === this.modalId && topItem?.[1].has(this);\n }\n\n private get isQueued(): boolean {\n return Boolean(dismissDropdownQueue.find((item) => item[1].has(this)));\n }\n\n addQueueId = (): void => {\n // If queued already, don't queue it again\n if (this.isQueued) { return; }\n\n // If this matches the top queue, queue within the top item\n if (this.isTopQueuedId) {\n this.topQueuedItem?.[1].add(this);\n } else { // If no match, then we layer in a new Queue.\n dismissDropdownQueue.push([this.modalId, new Set([this])]);\n }\n };\n\n removeQueueId = (): void => {\n const toRemove = new Set<number>();\n\n dismissDropdownQueue.forEach((item, i) => {\n item[1].delete(this);\n\n if (item[1].size === 0) {\n toRemove.add(i);\n }\n });\n\n Array.from(toRemove.values())\n .sort()\n .reverse()\n .forEach((index) => dismissDropdownQueue.splice(index, 1));\n };\n\n private handleDocumentDown = (e: MouseEvent): void => {\n if (!this.props.bounds) { return; }\n\n if (this.isTopQueued) {\n const { customModalRootId } = this.props;\n let { customModalRoot = modalRoot } = this.props;\n if (customModalRootId) {\n customModalRoot = document.getElementById(customModalRootId);\n }\n\n // Test to see if the target is a child of this menu. If not, this menu is\n // closed. If yes, we let the event proceed naturally.\n if (this.props.dismissTestOnContainer) {\n if (\n hasChild(this.container.current, e.target as any)\n && e.target !== this.container.current\n ) {\n return;\n }\n } else if (\n hasChild(customModalRoot, e.target as any)\n && e.target !== this.container.current\n ) {\n return;\n }\n\n if ((this.topQueuedItem?.[1].size || 0) <= 1) { stopPropagation(e); }\n this.props.onClose?.(e);\n\n this.removeQueueId();\n }\n };\n\n renderContent(style?: React.CSSProperties): JSX.Element {\n const { className, containerProps = {}, children } = this.props;\n\n return (\n <div\n className={classnames('Dropdown', className)}\n style={style}\n ref={this.container}\n {...containerProps}\n >\n {children}\n </div>\n );\n }\n\n render(): JSX.Element | null {\n const { dropdownWidth, dropdownHeight: computedHeight } = this.state;\n const {\n bounds,\n customModalRoot = modalRoot,\n coverBounds,\n width: manualWidth = 0,\n maxWidth,\n height,\n dropUp,\n dropLeft,\n dropRight,\n dropCenter,\n showWithNoBounds,\n shiftToMiddle,\n inline,\n } = this.props;\n\n if (bounds) {\n if (!customModalRoot) {\n setTimeout(() => this.forceUpdate(), 200);\n return null;\n }\n\n let width = Math.max(manualWidth || 0, 0) || dropdownWidth || 0;\n\n // When total height comes out negative, we simply use all the\n // available space from top to bottom of the area available to the\n // dropdown depending on the direction the dropdown extends.\n let totalHeight = height || computedHeight || Number.NaN;\n\n const checkWidth = dropdownWidth || 0;\n let isDown; let isUp; let isRight; let\n isLeft;\n\n if (inline) {\n if (dropUp) {\n isUp = true;\n } else if (dropLeft) {\n isLeft = true;\n } else if (dropRight) {\n isRight = true;\n } else {\n isDown = true;\n }\n } else if (dropUp) {\n // Fill total height will be from the top of the screen to the top of\n // the reference bounds\n if (totalHeight < 0) {\n totalHeight = bounds.top - 1;\n }\n\n if (manualWidth < 0) {\n width = bounds.width;\n }\n\n isUp = bounds.top + (coverBounds ? bounds.height : 0) > totalHeight;\n isDown = !isUp\n && window.innerHeight\n - bounds.bottom\n + (coverBounds ? bounds.height : 0)\n > totalHeight;\n isRight = !isDown && !isUp && checkWidth < window.innerWidth - bounds.right;\n isLeft = !isDown && !isUp && !isRight && checkWidth < bounds.left;\n } else if (dropLeft) {\n // Fill total height will be from the top of the screen to the bottom of\n // the screen\n if (totalHeight < 0) {\n totalHeight = window.innerHeight - 1;\n }\n\n if (manualWidth < 0) {\n width = bounds.left - 1;\n }\n\n isLeft = !isDown && !isUp && !isRight && checkWidth < bounds.left;\n isUp = !isLeft\n && bounds.top + (coverBounds ? bounds.height : 0) > totalHeight;\n isDown = !isLeft\n && !isUp\n && window.innerHeight\n - bounds.bottom\n + (coverBounds ? bounds.height : 0)\n > totalHeight;\n isRight = !isLeft\n && !isDown\n && !isUp\n && checkWidth < window.innerWidth - bounds.right;\n } else if (dropRight) {\n // Fill total height will be from the top of the screen to the bottom of\n // the screen\n if (totalHeight < 0) {\n totalHeight = window.innerHeight - 1;\n }\n\n if (manualWidth < 0) {\n width = window.innerWidth - bounds.right - 1;\n }\n\n isRight = !isDown\n && !isUp\n && !isLeft\n && checkWidth < window.innerWidth - bounds.right;\n isLeft = !isDown && !isUp && !isRight && checkWidth < bounds.left;\n isDown = !isLeft\n && !isRight\n && !isUp\n && window.innerHeight\n - bounds.bottom\n + (coverBounds ? bounds.height : 0)\n > totalHeight;\n isUp = !isLeft\n && !isRight\n && !isDown\n && bounds.top + (coverBounds ? bounds.height : 0) > totalHeight;\n } else {\n // Fill total height will be from the bottom of the reference bounds to\n // the bottom of the screen\n if (totalHeight < 0) {\n totalHeight = window.innerHeight - bounds.bottom - 1;\n }\n\n if (manualWidth < 0) {\n width = bounds.width;\n }\n\n isDown = window.innerHeight\n - bounds.bottom\n + (coverBounds ? bounds.height : 0)\n > totalHeight;\n isUp = !isDown\n && bounds.top + (coverBounds ? bounds.height : 0) > totalHeight;\n isRight = !isDown && !isUp && checkWidth < window.innerWidth - bounds.right;\n isLeft = !isDown && !isUp && !isRight && checkWidth < bounds.left;\n }\n\n let shiftLeft = (isDown || isUp) && bounds.left > window.innerWidth / 2;\n\n if (shiftToMiddle) {\n shiftLeft = false;\n }\n\n if (width) {\n width = Math.min(width || 0, window.innerWidth);\n }\n\n if (coverBounds && !manualWidth) {\n width = Math.min(0 || 0, window.innerWidth);\n }\n\n if (maxWidth) {\n width = Math.min(width, maxWidth);\n }\n\n const dropdownHeight = Math.min(totalHeight, window.innerHeight) + 1 || 0;\n\n // eslint-disable-next-line no-nested-ternary\n const topValue = isDown\n ? coverBounds\n ? Math.max(bounds.top, 0)\n : Math.max(bounds.bottom, 0)\n // eslint-disable-next-line no-nested-ternary\n : isUp\n ? Math.min(\n bounds.top - dropdownHeight + (coverBounds ? bounds.height : 0),\n window.innerHeight - dropdownHeight,\n )\n : dropLeft || dropRight\n ? bounds.top\n : 0;\n\n const leftValue = Math.max(\n // eslint-disable-next-line no-nested-ternary\n shiftLeft\n ? bounds.right - checkWidth\n // eslint-disable-next-line no-nested-ternary\n : isRight\n ? bounds.right - (coverBounds ? bounds.width : 0)\n : isLeft\n ? bounds.left - checkWidth + (coverBounds ? bounds.width : 0)\n : bounds.left,\n 0,\n ) - (shiftToMiddle ? width / 2 : 0);\n\n const layout = {\n top: Math.max(topValue, inline ? topValue : 0),\n left: dropCenter\n ? bounds.left + (bounds.width - checkWidth) / 2\n : leftValue,\n width: width || void 0,\n // We do not constrain the height until a height is computed or\n // provided\n height: dropdownHeight || void 0,\n };\n\n if (!dropdownWidth) {\n layout.left -= maxWidth || (dropCenter ? 4 : 0);\n }\n\n // Do absolute final corrections to attempt to keep the box within view\n // We can only do this when the box has established dimensions\n if (width !== void 0 && !inline) {\n // Shift from right side window escape\n if (layout.left + width > window.innerWidth) {\n const adjust = window.innerWidth - (layout.left + width);\n layout.left += adjust;\n }\n\n // Shift from left side window escape\n if (layout.left < 0) {\n layout.left = dropCenter ? 4 : 0;\n }\n\n // If right side escape again, we just need a thinner window\n if (layout.left + width >= window.innerWidth) {\n if (dropCenter) {\n layout.left = window.innerWidth - (width + 4);\n } else if (layout.left + width > window.innerWidth) {\n layout.left = 0;\n layout.width = window.innerWidth;\n }\n }\n }\n\n // Do absolute final corrections to attempt to keep the box within view\n // We can only do this when the box has established dimensions\n if (dropdownHeight !== void 0 && !inline) {\n // Shift from right side window escape\n if (layout.top + dropdownHeight > window.innerHeight) {\n const adjust = window.innerHeight - (layout.top + dropdownHeight);\n layout.top += adjust;\n }\n\n // Shift from left side window escape\n if (layout.top < 0) {\n layout.top = 0;\n }\n\n // If right side escape again, we just need a thinner window\n if (layout.top + dropdownHeight > window.innerHeight) {\n layout.top = 0;\n layout.height = window.innerHeight;\n }\n }\n\n if (inline) {\n return this.renderContent(layout);\n }\n\n return ReactDOM.createPortal(this.renderContent(layout), customModalRoot);\n }\n\n if (showWithNoBounds) {\n return this.renderContent();\n }\n return null;\n }\n}\n","import * as React from 'react';\nimport {\n classnames,\n DOMRectBounds,\n INestedChildren,\n normalizeWheel,\n stopPropagation,\n wait,\n when,\n} from '../../../utils';\nimport './scroll-region.scss';\n\nconst { min, max } = Math;\n\nfunction clamp(x: number, minVal: number, maxVal: number): number {\n return min(max(x, minVal), maxVal);\n}\n\nfunction easeInOutCubic(start: number, end: number, t: number): number {\n t = clamp(t, 0, 1);\n const time = t < 0.5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;\n return (end - start) * time + start;\n}\n\nexport const ScrollRegionMode = {\n LIGHT: 'ScrollRegion--light',\n DARK: 'ScrollRegion--dark',\n} as const;\n\nexport type ScrollRegionModeType =\n (typeof ScrollRegionMode)[keyof typeof ScrollRegionMode];\n\nexport interface IScrollRegion extends INestedChildren<React.ReactNode> {\n /** When set, the scroll will have some inertia for touch controls */\n allowTouchInertia?: boolean;\n /** Provides a custom class name to the container of this component */\n className?: string;\n /** Applies a custom class to the content portion of the scroll region */\n contentClassName?: string;\n /** Rendering mode of this scrollRegion */\n mode?: ScrollRegionModeType;\n /** Props to apply directly to the container div of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n /** Props to apply directly to the scrollRegion content panel container */\n contentProps?: React.HTMLProps<HTMLDivElement>;\n /**\n * When true, scroll events will stop being absorbed by this scroll region when\n * the user tries to scroll beyond the max bounds of the scroll region.\n */\n allowScrollFlowThrough?: boolean;\n /** This forces a maximum amount of scroll room */\n scrollHeight?: number;\n /** Sets this scroll region to the given scroll location */\n scrollToOnce?: [number, number];\n /**\n * Sets how quick the scrollTopOnce settles to the new position. Set to 1 to\n * be essentially instant.\n */\n autoScrollDuration?: number;\n /**\n * When set to true, this will always show the scroll bar as visible as long\n * as the space can be scrolled. If the space is not scrollable, the scroll\n * bar will be hidden.\n */\n alwaysShowScroll?: boolean;\n /**\n * Disables using the wheel to scroll this view.\n */\n preventWheel?: boolean;\n\n /**\n * When this view changes the scroll top or left value it provides it in this\n * callback\n *\n * isAutomated is true when the system is scrolling the view and not the user.\n */\n onScroll?(\n scroll: [number, number],\n scrollMax: [number, number],\n viewBounds: DOMRectBounds,\n contentBounds: DOMRectBounds,\n isAutomated?: boolean\n ): void;\n}\n\ninterface IState {\n isOpen: boolean;\n isDragging: boolean;\n top: [number, number];\n bounds?: DOMRectBounds;\n contentBounds?: DOMRectBounds;\n /**\n * This is the computed region width by examining all immediate children of\n * the content wrapper.\n */\n regionWidth?: number;\n /**\n * This is set to true when the scroll is supposed to self animate. This will\n * only happen temporarily for automation and can not remain active while the\n * user interacts with the scrolling manually.\n */\n animating?: boolean;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * This is a custom scroller for rendering a custom scrollbar for an X and Y\n * axis scrolling.\n */\nexport class ScrollRegion extends React.Component<IScrollRegion, IState> {\n state: IState = {\n isOpen: false,\n isDragging: false,\n top: [0, 0],\n };\n\n container = React.createRef<HTMLDivElement>();\n private wrapper = React.createRef<HTMLDivElement>();\n private content = React.createRef<HTMLDivElement>();\n private scrolledToOnce?: [number, number];\n private currentScrollHeight?: number;\n private initialized = false;\n private childrenChanged = false;\n private isUpdatingChildren = false;\n private animateScrollId = -1;\n private touch = {\n id: 0,\n position: [0, 0],\n inertia: [0, 0],\n animation: -1,\n };\n\n getSnapshotBeforeUpdate(prevProps: Readonly<IScrollRegion>): null {\n const { children } = this.props;\n\n if (!this.isUpdatingChildren) {\n this.childrenChanged = prevProps.children === children;\n }\n\n this.isUpdatingChildren = false;\n return null;\n }\n\n // eslint-disable-next-line react/sort-comp, react/no-unused-class-component-methods\n init = (): void => {\n const { bounds, contentBounds } = this.state;\n\n // Don't trigger an initial scroll event until there is something able to\n // scroll\n if (\n !bounds?.width\n || !contentBounds?.width\n || bounds.width >= contentBounds.width\n ) {\n return;\n }\n\n if (\n !bounds?.height\n || !contentBounds?.height\n || bounds.height >= contentBounds.height\n ) {\n return;\n }\n\n if (!this.initialized && bounds && contentBounds && this.content.current) {\n this.initialized = true;\n\n if (this.props.onScroll) {\n const metrics = this.getScrollMetrics();\n this.props.onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n }\n };\n\n componentDidMount(): void {\n this.componentDidUpdate();\n window.addEventListener('resize', this.handleResize);\n\n // Initial scroll broadcast to indicate initial scroll position\n setTimeout(() => this.componentDidUpdate(), 10);\n\n // We HAVE to manually add the event to get around the React + Chrome issues that exists\n // with passive event listeners.\n if (this.container.current) {\n this.container.current.addEventListener('wheel', this.handleWheel, {\n passive: false,\n });\n\n this.container.current.addEventListener(\n 'touchmove',\n this.handleTouchMove,\n {\n passive: false,\n },\n );\n\n this.container.current.addEventListener(\n 'touchstart',\n this.handleTouchStart,\n );\n\n this.container.current.addEventListener('touchend', this.handleTouchEnd);\n }\n\n this.updateRegionWidth();\n }\n\n componentDidUpdate(): void {\n const { bounds, contentBounds } = this.state;\n const { onScroll, autoScrollDuration, scrollHeight } = this.props;\n\n if (\n (!bounds || this.childrenChanged)\n && this.wrapper.current\n && this.content.current\n && this.container.current\n ) {\n this.childrenChanged = false;\n this.isUpdatingChildren = true;\n const newBounds = this.container.current.getBoundingClientRect();\n const newContentBounds = this.wrapper.current.getBoundingClientRect();\n\n if (onScroll) {\n const metrics = this.getScrollMetrics();\n\n onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n newBounds,\n newContentBounds,\n );\n }\n\n this.setState({\n bounds: newBounds,\n contentBounds: newContentBounds,\n });\n }\n\n // Handle bounds and content bounds changes\n if (\n bounds\n && contentBounds\n && this.wrapper.current\n && this.container.current\n ) {\n const checkContainer = this.container.current.getBoundingClientRect();\n const checkContent = this.wrapper.current.getBoundingClientRect();\n\n if (\n checkContainer.width !== bounds.width\n || checkContainer.height !== bounds.height\n || checkContent.width !== contentBounds.width\n || checkContent.height !== contentBounds.height\n ) {\n this.setState({\n bounds: checkContainer,\n contentBounds: checkContent,\n });\n }\n }\n\n // Handle scrollToOnce application\n const { scrollToOnce } = this.props;\n\n if (\n scrollToOnce !== void 0\n && Number.isNaN(scrollToOnce[0])\n && Number.isNaN(scrollToOnce[1])\n ) {\n scrollToOnce[0] = 0;\n scrollToOnce[1] = 0;\n }\n\n if (\n bounds\n && contentBounds\n && this.content.current\n && this.container.current\n && this.scrolledToOnce !== scrollToOnce\n ) {\n const newBounds = this.container.current.getBoundingClientRect();\n const newContentBounds = this.wrapper.current?.getBoundingClientRect();\n\n this.scrolledToOnce = scrollToOnce || [0, 0];\n const scrollTo = this.scrolledToOnce;\n let startValue: [number, number] = [\n this.content.current.scrollLeft,\n this.content.current.scrollTop,\n ];\n\n // Handle instantaneous scroll changes\n if (autoScrollDuration === 0) {\n startValue = this.scrolledToOnce;\n\n this.content.current.scrollLeft = startValue[0];\n this.content.current.scrollTop = startValue[1];\n }\n\n this.setState({\n top: startValue,\n bounds: newBounds,\n contentBounds: newContentBounds,\n animating: true,\n });\n\n window.cancelAnimationFrame(this.animateScrollId);\n\n if (autoScrollDuration !== 0) {\n this.animateScrollId = requestAnimationFrame(\n this.animateScrollOnce(startValue, scrollTo),\n );\n }\n\n // Broadcast for initial scroll change\n if (\n onScroll\n && newBounds\n && newContentBounds\n && this.container.current\n ) {\n const metrics = this.getScrollMetrics(newBounds, newContentBounds);\n onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n newBounds,\n newContentBounds,\n );\n }\n } else if (\n bounds\n && contentBounds\n && this.content.current\n && this.currentScrollHeight !== scrollHeight\n && onScroll\n ) { // Broadcast scroll metrics when the scroll height changes\n this.currentScrollHeight = scrollHeight;\n const metrics = this.getScrollMetrics();\n onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n this.updateRegionWidth();\n }\n\n componentWillUnmount(): void {\n window.removeEventListener('resize', this.handleResize);\n\n if (this.container.current) {\n this.container.current.removeEventListener('wheel', this.handleWheel);\n this.container.current.removeEventListener(\n 'touchmove',\n this.handleTouchMove,\n );\n this.container.current.removeEventListener(\n 'touchstart',\n this.handleTouchStart,\n );\n this.container.current.removeEventListener(\n 'touchend',\n this.handleTouchEnd,\n );\n }\n }\n\n private updateRegionWidth = async (): Promise<void> => {\n const wrapper = this.wrapper.current;\n if (!wrapper) { return; }\n await wait(1);\n const children = Array.from(wrapper.children);\n let maxWidth = -1;\n\n children.forEach((child) => {\n const { width } = child.getBoundingClientRect();\n if (width > maxWidth) { maxWidth = width; }\n });\n\n if (this.state.regionWidth !== maxWidth) {\n this.setState({ regionWidth: maxWidth });\n }\n };\n\n private animateScrollOnce = (\n startValue: [number, number],\n scrollTo: [number, number],\n ): (t: number) => void => {\n let start = 0;\n const duration = this.props.autoScrollDuration || 170;\n\n const doAnimate = (t: number): void => {\n if (!this.container.current) { return; }\n if (!this.content.current) { return; }\n if (!this.wrapper.current) { return; }\n\n const bounds = this.container.current.getBoundingClientRect();\n const contentBounds = this.wrapper.current?.getBoundingClientRect();\n const metrics = this.getScrollMetrics(bounds, contentBounds);\n\n if (!this.container.current) { return; }\n if (!start) { start = t; }\n const time = (t - start) / duration;\n const scroll = [\n easeInOutCubic(startValue[0], scrollTo[0], time),\n easeInOutCubic(startValue[1], scrollTo[1], time),\n ];\n\n this.content.current.scrollLeft = Math.max(\n Math.min(scroll[0] || 0, metrics.scrollSpace[0]),\n 0,\n );\n\n this.content.current.scrollTop = Math.max(\n Math.min(scroll[1] || 0, metrics.scrollSpace[1]),\n 0,\n );\n\n this.setState({\n top: [this.content.current.scrollLeft, this.content.current.scrollTop],\n bounds,\n contentBounds,\n });\n\n if (\n this.props.onScroll\n && bounds\n && contentBounds\n && this.container.current\n ) {\n this.props.onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n true,\n );\n }\n\n if (this.state.animating && time < 1) {\n this.animateScrollId = requestAnimationFrame(doAnimate);\n }\n };\n\n return doAnimate;\n };\n\n private getScrollMetrics(\n forceBounds?: DOMRectBounds,\n forceContentBounds?: DOMRectBounds,\n ): {\n barSizes: [number, number];\n barRatio: [number, number];\n barSpace: [number, number];\n scrollSpace: [number, number];\n } {\n let { bounds, contentBounds } = this.state;\n bounds = forceBounds || bounds;\n contentBounds = forceContentBounds || contentBounds;\n\n const barSizes: [number, number] = [0, 0];\n const barRatio: [number, number] = [1, 1];\n const barSpace: [number, number] = [0, 0];\n const scrollSpace: [number, number] = [0, 0];\n\n if (bounds && contentBounds) {\n barRatio[0] = bounds.width / contentBounds.width;\n barSizes[0] = barRatio[0] * bounds.width;\n barSizes[0] = Math.max(barSizes[0], 30);\n barSizes[0] = Math.min(barSizes[0], bounds.width);\n }\n\n if (barRatio[0] < 1 && bounds && contentBounds) {\n barSpace[0] = bounds.width - barSizes[0];\n scrollSpace[0] = contentBounds.width - bounds.width;\n }\n\n if (bounds && contentBounds) {\n barRatio[1] = bounds.height / contentBounds.height;\n barSizes[1] = barRatio[1] * bounds.height;\n barSizes[1] = Math.max(barSizes[1], 30);\n barSizes[1] = Math.min(barSizes[1], bounds.height);\n }\n\n if (barRatio[1] < 1 && bounds && contentBounds) {\n barSpace[1] = bounds.height - barSizes[1];\n scrollSpace[1] = contentBounds.height - bounds.height;\n }\n\n const out = {\n barSizes,\n barRatio,\n barSpace,\n scrollSpace,\n };\n\n return out;\n }\n\n handleResize = (): void => {\n this.setState({\n bounds: undefined,\n contentBounds: undefined,\n });\n\n this.updateRegionWidth();\n };\n\n handleTouchStart = (e: TouchEvent): void => {\n let touch: Touch | null = null;\n\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n break;\n }\n }\n\n if (touch) {\n this.touch.position = [touch.pageX, touch.pageY];\n this.touch.id = touch.identifier;\n }\n\n this.setState((prevState) => ({ top: prevState.top, isOpen: true, animating: false }));\n cancelAnimationFrame(this.touch.animation);\n this.touch.animation = -1;\n };\n\n handleTouchEnd = (e: TouchEvent): void => {\n let touch: Touch | null = null;\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n\n if (!touch) {\n for (let i = 0, iMax = e.targetTouches.length; i < iMax; ++i) {\n touch = e.targetTouches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n }\n\n if (!touch) {\n for (let i = 0, iMax = e.changedTouches.length; i < iMax; ++i) {\n touch = e.changedTouches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n }\n\n if (!touch) { return; }\n this.setState((prevState) => ({ top: prevState.top, isOpen: false }));\n\n if (\n (Math.abs(this.touch.inertia[0]) > 0\n || Math.abs(this.touch.inertia[1]) > 0)\n && this.content.current\n ) {\n const { bounds, contentBounds } = this.state;\n const { current } = this.content;\n cancelAnimationFrame(this.touch.animation);\n\n const animateInertia = (): void => {\n current.scrollLeft += this.touch.inertia[0];\n current.scrollTop += this.touch.inertia[1];\n const metrics = this.getScrollMetrics();\n current.scrollLeft = Math.min(\n current.scrollLeft,\n metrics.scrollSpace[0],\n );\n current.scrollTop = Math.min(current.scrollTop, metrics.scrollSpace[1]);\n\n this.setState({\n top: [current.scrollLeft, current.scrollTop],\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n [current.scrollLeft, current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n this.touch.inertia[0] *= 0.95;\n this.touch.inertia[1] *= 0.95;\n if (\n Math.abs(this.touch.inertia[0]) > 0.001\n || Math.abs(this.touch.inertia[1]) > 0.001\n ) {\n requestAnimationFrame(animateInertia);\n } else { this.touch.animation = -1; }\n };\n\n this.touch.animation = requestAnimationFrame(animateInertia);\n }\n };\n\n handleTouchMove = (e: TouchEvent): void => {\n if (!(e.currentTarget instanceof HTMLDivElement)) { return; }\n if (!this.content.current) { return; }\n const { bounds, contentBounds, isOpen } = this.state;\n\n let touch: Touch | null = null;\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n }\n }\n\n if (!touch) { return; }\n\n this.content.current.scrollLeft += this.touch.position[0] - touch.pageX;\n this.content.current.scrollTop += this.touch.position[1] - touch.pageY;\n this.touch.inertia[0] = this.touch.position[0] - touch.pageX;\n this.touch.inertia[1] = this.touch.position[1] - touch.pageY;\n\n if (!this.props.allowTouchInertia) {\n this.touch.inertia = [0, 0];\n }\n\n this.touch.position = [touch.pageX, touch.pageY];\n const metrics = this.getScrollMetrics();\n\n this.content.current.scrollLeft = Math.min(\n this.content.current.scrollLeft,\n metrics.scrollSpace[0],\n );\n\n this.content.current.scrollTop = Math.min(\n this.content.current.scrollTop,\n metrics.scrollSpace[1],\n );\n\n this.setState({\n top: [this.content.current.scrollLeft, this.content.current.scrollTop],\n animating: false,\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n if (\n isOpen\n && bounds\n && (metrics.barRatio[0] < 1 || metrics.barRatio[1] < 1)\n ) {\n stopPropagation(e);\n }\n\n cancelAnimationFrame(this.touch.animation);\n };\n\n handleWheel = (e: WheelEvent): boolean => {\n if (!(e.currentTarget instanceof HTMLDivElement)) { return false; }\n if (this.props.preventWheel) { return false; }\n if (!this.content.current) { return false; }\n\n const { bounds, contentBounds, isOpen } = this.state;\n const wheel = normalizeWheel(e);\n\n const newLeft = this.content.current.scrollLeft + wheel.pixelX;\n const newTop = this.content.current.scrollTop - wheel.pixelY;\n\n const metrics = this.getScrollMetrics();\n\n const appliedLeft = Math.min(newLeft, metrics.scrollSpace[0]);\n\n const appliedTop = Math.min(newTop, metrics.scrollSpace[1]);\n\n this.content.current.scrollLeft = appliedLeft;\n this.content.current.scrollTop = appliedTop;\n\n this.setState({\n top: [appliedLeft, appliedTop],\n animating: false,\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n [appliedLeft, appliedTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n if (\n isOpen\n && bounds\n && (metrics.barRatio[0] < 1 || metrics.barRatio[1] < 1)\n ) {\n if (this.props.allowScrollFlowThrough) {\n if (\n (Math.floor(appliedLeft) < Math.floor(metrics.scrollSpace[0])\n && Math.floor(appliedLeft) > 0)\n || (Math.floor(appliedTop) < Math.floor(metrics.scrollSpace[1])\n && Math.floor(appliedTop) > 0)\n ) {\n e.preventDefault();\n stopPropagation(e);\n return false;\n }\n } else {\n e.preventDefault();\n stopPropagation(e);\n return false;\n }\n }\n\n e.preventDefault();\n return false;\n };\n\n handleHorizontalBarDown = (e: React.PointerEvent<HTMLDivElement>): void => {\n const { bounds, contentBounds } = this.state;\n // Once the bar is mouse downed, we begin to start the dragging process which\n // should be registered across the whole document\n const metrics = this.getScrollMetrics();\n\n // We must calculate how much one pixel of movement would scroll the content\n const pixelScroll = [\n metrics.scrollSpace[0] / metrics.barSpace[0],\n metrics.scrollSpace[1] / metrics.barSpace[1],\n ];\n let startPos = [e.nativeEvent.clientX, e.nativeEvent.clientY];\n\n this.setState({\n isDragging: true,\n animating: false,\n });\n\n const { pointerId, currentTarget: target } = e;\n\n target.setPointerCapture(pointerId);\n\n const mousemove = (moveEvent: MouseEvent): void => {\n // See if our mouse left click for drag button is still down (it can be\n // lifted off document thus be missed in the event)\n if ('which' in moveEvent) {\n if (!(moveEvent.which && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n } else if (!((moveEvent as any).buttons && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n\n const newPos = [moveEvent.clientX, moveEvent.clientY];\n const deltaPos = [newPos[0] - startPos[0], newPos[1] - startPos[1]];\n startPos = newPos;\n\n if (this.content.current) {\n const newLeft = this.content.current.scrollLeft + deltaPos[0] * pixelScroll[0];\n\n this.content.current.scrollLeft = Math.min(\n newLeft,\n metrics.scrollSpace[0],\n );\n\n this.setState({\n top: [\n this.content.current.scrollLeft,\n this.content.current.scrollTop,\n ],\n });\n }\n\n // Prevent any event bubbling to prevent any default dragging behaviorss\n if (moveEvent.stopPropagation) { moveEvent.stopPropagation(); }\n if (moveEvent.preventDefault) { moveEvent.preventDefault(); }\n moveEvent.cancelBubble = true;\n moveEvent.returnValue = false;\n\n // Make sure the scroll info is broadcast still\n if (\n this.props.onScroll\n && bounds\n && contentBounds\n && this.content.current\n ) {\n this.props.onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n };\n\n const mouseup = (): void => {\n document.removeEventListener('mousemove', mousemove);\n document.removeEventListener('mouseup', mouseup);\n target.removeEventListener('mouseup', mouseup);\n target.releasePointerCapture(pointerId);\n\n this.setState({\n isDragging: false,\n });\n };\n\n document.addEventListener('mousemove', mousemove);\n document.addEventListener('mouseup', mouseup);\n target.addEventListener('mouseup', mouseup);\n };\n\n handleVerticalBarDown = (e: React.PointerEvent<HTMLDivElement>): void => {\n const { bounds, contentBounds } = this.state;\n // Once the bar is mouse downed, we begin to start the dragging process which\n // should be registered across the whole document\n const metrics = this.getScrollMetrics();\n\n // We must calculate how much one pixel of movement would scroll the content\n const pixelScroll = [\n metrics.scrollSpace[0] / metrics.barSpace[0],\n metrics.scrollSpace[1] / metrics.barSpace[1],\n ];\n let startPos = [e.nativeEvent.clientX, e.nativeEvent.clientY];\n\n this.setState({\n isDragging: true,\n animating: false,\n });\n\n const { pointerId, currentTarget: target } = e;\n target.setPointerCapture(pointerId);\n\n const mousemove = (moveEvent: MouseEvent): void => {\n // See if our mouse left click for drag button is still down (it can be\n // lifted off document thus be missed in the event)\n if ('which' in moveEvent) {\n if (!(moveEvent.which && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n } else if (!((moveEvent as any).buttons && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n\n const newPos = [moveEvent.clientX, moveEvent.clientY];\n const deltaPos = [newPos[0] - startPos[0], newPos[1] - startPos[1]];\n startPos = newPos;\n\n if (this.content.current) {\n const newTop = this.content.current.scrollTop + deltaPos[1] * pixelScroll[1];\n\n this.content.current.scrollTop = Math.min(\n newTop,\n metrics.scrollSpace[1],\n );\n\n this.setState({\n top: [\n this.content.current.scrollLeft,\n this.content.current.scrollTop,\n ],\n });\n }\n\n // Prevent any event bubbling to prevent any default dragging behaviorss\n if (moveEvent.stopPropagation) { moveEvent.stopPropagation(); }\n if (moveEvent.preventDefault) { moveEvent.preventDefault(); }\n moveEvent.cancelBubble = true;\n moveEvent.returnValue = false;\n\n // Make sure the scroll info is broadcast still\n if (\n this.props.onScroll\n && bounds\n && contentBounds\n && this.content.current\n ) {\n this.props.onScroll(\n [this.content.current.scrollLeft, this.content.current.scrollTop],\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n };\n\n const mouseup = (): void => {\n document.removeEventListener('mousemove', mousemove);\n document.removeEventListener('mouseup', mouseup);\n target.removeEventListener('mouseup', mouseup);\n target.releasePointerCapture(pointerId);\n\n this.setState({\n isDragging: false,\n });\n };\n\n document.addEventListener('mousemove', mousemove);\n document.addEventListener('mouseup', mouseup);\n target.addEventListener('mouseup', mouseup);\n };\n\n render(): JSX.Element {\n const { isOpen, isDragging, bounds, top, regionWidth } = this.state;\n\n const {\n className,\n contentClassName,\n containerProps,\n contentProps,\n children,\n scrollHeight,\n alwaysShowScroll,\n mode = ScrollRegionMode.DARK,\n } = this.props;\n\n const barTop = [\n this.content?.current?.scrollLeft || 0,\n this.content?.current?.scrollTop || 0,\n ];\n const metrics = this.getScrollMetrics();\n barTop[0] = (top[0] / metrics.scrollSpace[0]) * metrics.barSpace[0];\n barTop[1] = (top[1] / metrics.scrollSpace[1]) * metrics.barSpace[1];\n\n if (Number.isNaN(barTop[0])) { barTop[0] = 0; }\n if (Number.isNaN(barTop[1])) { barTop[1] = 0; }\n\n const barStyle = [\n {\n left: barTop[0],\n width: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio[0] < 1)\n || (isDragging && metrics.barRatio[0] < 1),\n metrics.barSizes[0],\n 0,\n ),\n opacity: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio[0] < 1)\n || (isDragging && metrics.barRatio[0] < 1),\n 1,\n 0,\n ),\n bottom: '0px',\n },\n\n {\n top: barTop[1],\n height: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio[1] < 1)\n || (isDragging && metrics.barRatio[1] < 1),\n metrics.barSizes[1],\n 0,\n ),\n opacity: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio[1] < 1)\n || (isDragging && metrics.barRatio[1] < 1),\n 1,\n 0,\n ),\n right: '0px',\n },\n ];\n\n return (\n // eslint-disable-next-line jsx-a11y/mouse-events-have-key-events\n <div\n className={classnames('ScrollRegion', mode, className)}\n {...containerProps}\n ref={this.container}\n style={containerProps?.style}\n onMouseOver={() => {\n this.setState({ top, isOpen: true });\n this.forceUpdate();\n }}\n onMouseLeave={(e) => {\n const event = e.nativeEvent;\n let node: Element | null = (event as any).toElement || event.relatedTarget;\n\n while (node) {\n if (\n node.parentNode === this.container.current\n || node === this.container.current\n ) {\n return;\n }\n\n node = node.parentElement;\n }\n\n this.setState({ top, isOpen: false });\n }}\n >\n <div\n ref={this.content}\n className={classnames('ScrollRegion__Content', contentClassName)}\n style={{}}\n {...contentProps}\n >\n <div\n ref={this.wrapper}\n className=\"ScrollRegion__Wrapper\"\n style={{\n minWidth: Math.max(\n regionWidth || 0,\n this.content.current?.getBoundingClientRect().width || 0,\n ),\n height: scrollHeight,\n flex: `1 1 ${scrollHeight}px`,\n minHeight: scrollHeight,\n }}\n >\n {children}\n </div>\n </div>\n <div\n className={classnames(\n 'ScrollRegion__Bar',\n 'ScrollRegion--horizontal',\n )}\n style={barStyle[0]}\n onPointerDown={this.handleHorizontalBarDown}\n />\n <div\n className={classnames('ScrollRegion__Bar')}\n style={barStyle[1]}\n onPointerDown={this.handleVerticalBarDown}\n />\n </div>\n );\n }\n}\n","/* eslint-disable react/sort-comp */\nimport * as React from 'react';\nimport { classnames, DOMRectBounds, INestedChildren, normalizeWheel, stopPropagation, when } from '../../../utils';\nimport './scroll-view.scss';\n\nconst { min, max } = Math;\n\nfunction clamp(x: number, minVal: number, maxVal: number): number {\n return min(max(x, minVal), maxVal);\n}\n\nfunction easeInOutCubic(start: number, end: number, t: number): number {\n t = clamp(t, 0, 1);\n const time = t < 0.5 ? 4 * t * t * t : (t - 1) * (2 * t - 2) * (2 * t - 2) + 1;\n return (end - start) * time + start;\n}\n\nexport enum ScrollBarSide {\n RIGHT,\n LEFT,\n}\n\nexport const ScrollViewMode = {\n LIGHT: 'ScrollView--light',\n DARK: 'ScrollView--dark',\n} as const;\n\nexport type ScrollViewModeType =\n (typeof ScrollViewMode)[keyof typeof ScrollViewMode];\n\nexport interface IScrollView extends INestedChildren<React.ReactNode> {\n /** When set, the scroll will have some inertia for touch controls */\n allowTouchInertia?: boolean;\n /** Provides a custom class name to the container of this component */\n className?: string;\n /** Applies a custom class to the content portion of the scroll view */\n contentClassName?: string;\n /** Rendering mode of this scrollview */\n mode?: ScrollViewModeType;\n /** Props to apply directly to the container div of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n /** Props to apply directly to the scrollview content panel container */\n contentProps?: React.HTMLProps<HTMLDivElement>;\n /**\n * When true, scroll events will stop being absorbed by this scroll view when\n * the user tries to scroll beyond the max bounds of the scroll region.\n */\n allowScrollFlowThrough?: boolean;\n /** This forces a maximum amount of scroll room */\n scrollHeight?: number;\n /** Sets this scroll view to the given scroll top value */\n scrollTopOnce?: number;\n /**\n * Sets how quick the scrollTopOnce settles to the new position. Set to 1 to\n * be essentially instant.\n */\n autoScrollDuration?: number;\n /** Determines which side the scroll bar should appear on */\n side?: ScrollBarSide;\n /**\n * Set to make this view manage horizontal scrolling instead of vertical.\n * ALl of the \"top\" and \"height\" related properties will be applied\n * horizontally instead of vertically.\n */\n horizontal?: boolean;\n /**\n * Causes wheel events that are more biased to horizontal scrolling to be\n * absorbed and used by this view.\n */\n onlyHorizontalWheel?: boolean;\n /**\n * When set to true, this will always show the scroll bar as visible as long\n * as the space can be scrolled. If the space is not scrollable, the scroll\n * bar will be hidden.\n */\n alwaysShowScroll?: boolean;\n /**\n * Disables using the wheel to scroll this view.\n */\n preventWheel?: boolean;\n\n /**\n * When this view changes the scroll top value it provides it in this callback\n *\n * isAutomated is true when the system is scrolling the view and not the user.\n */\n onScroll?(\n scrollTop: number,\n scrollMax: number,\n viewBounds: DOMRectBounds,\n contentBounds: DOMRectBounds,\n isAutomated?: boolean\n ): void;\n}\n\ninterface IState {\n isOpen: boolean;\n isDragging: boolean;\n top: number;\n bounds?: DOMRectBounds;\n contentBounds?: DOMRectBounds;\n /**\n * This is set to true when the scroll is supposed to self animate. This will\n * only happen temporarily for automation and can not remain active while the\n * user interacts with the scrolling manually.\n */\n animating?: boolean;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * This is a custom scroller for rendering a custom scrollbar\n */\nexport class ScrollView extends React.Component<IScrollView, IState> {\n state: IState = {\n isOpen: false,\n isDragging: false,\n top: 0,\n };\n\n container = React.createRef<HTMLDivElement>();\n scrollBarRef = React.createRef<HTMLDivElement>();\n private content = React.createRef<HTMLDivElement>();\n private scrolledToOnce?: number;\n private currentScrollHeight?: number;\n private initialized = false;\n private childrenChanged = false;\n private isUpdatingChildren = false;\n private animateScrollId = -1;\n private touch = {\n id: 0,\n y: 0,\n inertia: 0,\n animation: -1,\n };\n\n getSnapshotBeforeUpdate(prevProps: Readonly<IScrollView>): null {\n const { children } = this.props;\n\n if (!this.isUpdatingChildren) {\n this.childrenChanged = prevProps.children === children;\n }\n\n this.isUpdatingChildren = false;\n return null;\n }\n\n // eslint-disable-next-line react/no-unused-class-component-methods\n init = (): void => {\n const { horizontal } = this.props;\n const { bounds, contentBounds } = this.state;\n\n // Don't trigger an initial scroll event until there is something able to\n // scroll\n if (horizontal) {\n if (\n !bounds?.width\n || !contentBounds?.width\n || bounds.width >= contentBounds.width\n ) {\n return;\n }\n } else if (\n !bounds?.height\n || !contentBounds?.height\n || bounds.height >= contentBounds.height\n ) {\n return;\n }\n\n if (\n !this.initialized\n && bounds\n && contentBounds\n && this.container.current\n ) {\n this.initialized = true;\n\n if (this.props.onScroll) {\n const metrics = this.getScrollMetrics();\n this.props.onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n }\n };\n\n componentDidMount(): void {\n this.componentDidUpdate();\n window.addEventListener('resize', this.handleResize);\n\n // Initial scroll broadcast to indicate initial scroll position\n setTimeout(() => this.componentDidUpdate(), 10);\n\n // We HAVE to manually add the event to get around the React + Chrome issues that exists\n // with passive event listeners.\n if (this.container.current) {\n this.container.current.addEventListener('wheel', this.handleWheel, {\n passive: false,\n });\n\n this.container.current.addEventListener(\n 'touchmove',\n this.handleTouchMove,\n {\n passive: false,\n },\n );\n\n this.container.current.addEventListener(\n 'touchstart',\n this.handleTouchStart,\n );\n\n this.container.current.addEventListener('touchend', this.handleTouchEnd);\n }\n }\n\n componentDidUpdate(): void {\n const { horizontal, onScroll, autoScrollDuration, scrollHeight } = this.props;\n const { bounds, contentBounds } = this.state;\n\n if (\n (!bounds || this.childrenChanged)\n && this.content.current\n && this.container.current\n ) {\n this.childrenChanged = false;\n this.isUpdatingChildren = true;\n const newBounds = this.container.current.getBoundingClientRect();\n const newContentBounds = this.content.current.getBoundingClientRect();\n\n if (onScroll) {\n const metrics = this.getScrollMetrics();\n\n onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n newBounds,\n newContentBounds,\n );\n }\n\n this.setState({\n bounds: newBounds,\n contentBounds: newContentBounds,\n });\n }\n\n // Handle bounds and content bounds changes\n if (\n bounds\n && contentBounds\n && this.content.current\n && this.container.current\n ) {\n const checkContainer = this.container.current.getBoundingClientRect();\n const checkContent = this.content.current.getBoundingClientRect();\n\n if (\n checkContainer.width !== bounds.width\n || checkContainer.height !== bounds.height\n || checkContent.width !== contentBounds.width\n || checkContent.height !== contentBounds.height\n ) {\n this.setState({\n bounds: checkContainer,\n contentBounds: checkContent,\n });\n }\n }\n\n // Handle scrollToOnce application\n let { scrollTopOnce } = this.props;\n if (scrollTopOnce !== void 0 && Number.isNaN(scrollTopOnce)) { scrollTopOnce = 0; }\n\n if (\n bounds\n && contentBounds\n && this.container.current\n && this.scrolledToOnce !== scrollTopOnce\n ) {\n const newBounds = this.container.current.getBoundingClientRect();\n const newContentBounds = this.content.current?.getBoundingClientRect();\n\n this.scrolledToOnce = scrollTopOnce || 0;\n const scrollTo = this.scrolledToOnce;\n let startValue = horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop;\n\n // Handle instantaneous scroll changes\n if (autoScrollDuration === 0) {\n startValue = this.scrolledToOnce;\n\n if (horizontal) {\n this.container.current.scrollLeft = startValue;\n } else {\n this.container.current.scrollTop = startValue;\n }\n }\n\n this.positionScrollBar(startValue);\n\n this.setState({\n top: startValue,\n bounds: newBounds,\n contentBounds: newContentBounds,\n animating: true,\n });\n\n window.cancelAnimationFrame(this.animateScrollId);\n\n if (autoScrollDuration !== 0) {\n this.animateScrollId = requestAnimationFrame(\n this.animateScrollOnce(startValue, scrollTo),\n );\n }\n\n // Broadcast for initial scroll change\n if (\n onScroll\n && newBounds\n && newContentBounds\n && this.container.current\n ) {\n const metrics = this.getScrollMetrics(newBounds, newContentBounds);\n onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n newBounds,\n newContentBounds,\n );\n }\n } else if (\n bounds\n && contentBounds\n && this.container.current\n && this.currentScrollHeight !== scrollHeight\n && onScroll\n ) { // Broadcast scroll metrics when the scroll height changes\n this.currentScrollHeight = scrollHeight;\n const metrics = this.getScrollMetrics();\n onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n }\n\n componentWillUnmount(): void {\n window.removeEventListener('resize', this.handleResize);\n\n if (this.container.current) {\n this.container.current.removeEventListener('wheel', this.handleWheel);\n this.container.current.removeEventListener(\n 'touchmove',\n this.handleTouchMove,\n );\n this.container.current.removeEventListener(\n 'touchstart',\n this.handleTouchStart,\n );\n this.container.current.removeEventListener(\n 'touchend',\n this.handleTouchEnd,\n );\n }\n }\n\n private animateScrollOnce = (startValue: number, scrollTo: number): (t: number) => void => {\n let start = 0;\n const duration = this.props.autoScrollDuration || 170;\n\n const doAnimate = (t: number): void => {\n if (!this.container.current) { return; }\n if (!this.content.current) { return; }\n const { horizontal } = this.props;\n\n const bounds = this.container.current.getBoundingClientRect();\n const contentBounds = this.content.current?.getBoundingClientRect();\n const metrics = this.getScrollMetrics(bounds, contentBounds);\n\n if (!this.container.current) { return; }\n if (!start) { start = t; }\n const time = (t - start) / duration;\n const scroll = easeInOutCubic(startValue, scrollTo, time);\n\n if (horizontal) {\n this.container.current.scrollLeft = Math.max(\n Math.min(scroll || 0, metrics.scrollSpace),\n 0,\n );\n } else {\n this.container.current.scrollTop = Math.max(\n Math.min(scroll || 0, metrics.scrollSpace),\n 0,\n );\n }\n\n this.positionScrollBar(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n );\n\n this.setState({\n top: horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n bounds,\n contentBounds,\n });\n\n if (\n this.props.onScroll\n && bounds\n && contentBounds\n && this.container.current\n ) {\n this.props.onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n true,\n );\n }\n\n if (this.state.animating && time < 1) {\n this.animateScrollId = requestAnimationFrame(doAnimate);\n }\n };\n\n return doAnimate;\n };\n\n private getScrollMetrics(\n forceBounds?: DOMRectBounds,\n forceContentBounds?: DOMRectBounds,\n ): {\n barHeight: number;\n barRatio: number;\n barSpace: number;\n scrollSpace: number;\n } {\n const { horizontal } = this.props;\n let { bounds, contentBounds } = this.state;\n bounds = forceBounds || bounds;\n contentBounds = forceContentBounds || contentBounds;\n\n let barHeight = 0;\n let barRatio = 1;\n let barSpace = 0;\n let scrollSpace = 0;\n\n if (horizontal) {\n if (bounds && contentBounds) {\n barRatio = bounds.width / contentBounds.width;\n barHeight = barRatio * bounds.width;\n barHeight = Math.max(barHeight, 30);\n barHeight = Math.min(barHeight, bounds.width);\n }\n\n if (barRatio < 1 && bounds && contentBounds) {\n barSpace = bounds.width - barHeight;\n scrollSpace = contentBounds.width - bounds.width;\n }\n } else {\n if (bounds && contentBounds) {\n barRatio = bounds.height / contentBounds.height;\n barHeight = barRatio * bounds.height;\n barHeight = Math.max(barHeight, 30);\n barHeight = Math.min(barHeight, bounds.height);\n }\n\n if (barRatio < 1 && bounds && contentBounds) {\n barSpace = bounds.height - barHeight;\n scrollSpace = contentBounds.height - bounds.height;\n }\n }\n\n return {\n barHeight,\n barRatio,\n barSpace,\n scrollSpace,\n };\n }\n\n positionScrollBar(top: number): void {\n const scrollBar = this.scrollBarRef.current;\n if (!scrollBar) { return; }\n\n const { side = ScrollBarSide.RIGHT, horizontal } = this.props;\n\n let barTop = top;\n const metrics = this.getScrollMetrics();\n barTop += (top / metrics.scrollSpace) * metrics.barSpace;\n\n if (horizontal) {\n scrollBar.style.left = `${barTop}px`;\n scrollBar.style.top = when(\n side === ScrollBarSide.LEFT,\n '0px',\n scrollBar.style.top,\n );\n scrollBar.style.bottom = when(\n side === ScrollBarSide.RIGHT,\n '0px',\n scrollBar.style.bottom,\n );\n } else {\n scrollBar.style.top = `${barTop}px`;\n scrollBar.style.left = when(\n side === ScrollBarSide.LEFT,\n '0px',\n scrollBar.style.left,\n );\n scrollBar.style.right = when(\n side === ScrollBarSide.RIGHT,\n '0px',\n scrollBar.style.right,\n );\n }\n }\n\n handleResize = (): void => {\n this.setState({\n bounds: undefined,\n contentBounds: undefined,\n });\n };\n\n handleTouchStart = (e: TouchEvent): void => {\n let touch: Touch | null = null;\n\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n break;\n }\n }\n\n if (touch) {\n this.touch.y = touch.pageY;\n this.touch.id = touch.identifier;\n }\n\n this.setState((prevState) => ({ top: prevState.top, isOpen: true, animating: false }));\n cancelAnimationFrame(this.touch.animation);\n this.touch.animation = -1;\n };\n\n handleTouchEnd = (e: TouchEvent): void => {\n const { horizontal } = this.props;\n\n let touch: Touch | null = null;\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n\n if (!touch) {\n for (let i = 0, iMax = e.targetTouches.length; i < iMax; ++i) {\n touch = e.targetTouches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n }\n\n if (!touch) {\n for (let i = 0, iMax = e.changedTouches.length; i < iMax; ++i) {\n touch = e.changedTouches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n touch = null;\n }\n }\n }\n\n if (!touch) { return; }\n this.setState((prevState) => ({ top: prevState.top, isOpen: false }));\n\n if (Math.abs(this.touch.inertia) > 0 && this.container.current) {\n const { bounds, contentBounds } = this.state;\n const { current } = this.container;\n cancelAnimationFrame(this.touch.animation);\n\n const animateInertia = (): void => {\n if (horizontal) { current.scrollLeft += this.touch.inertia; } else { current.scrollTop += this.touch.inertia; }\n const metrics = this.getScrollMetrics();\n if (horizontal) {\n current.scrollLeft = Math.min(\n current.scrollLeft,\n metrics.scrollSpace,\n );\n } else {\n current.scrollTop = Math.min(current.scrollTop, metrics.scrollSpace);\n }\n\n this.positionScrollBar(\n horizontal ? current.scrollLeft : current.scrollTop,\n );\n\n this.setState({\n top: horizontal ? current.scrollLeft : current.scrollTop,\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n horizontal ? current.scrollLeft : current.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n this.touch.inertia *= 0.95;\n if (Math.abs(this.touch.inertia) > 0.001) {\n requestAnimationFrame(animateInertia);\n } else { this.touch.animation = -1; }\n };\n\n this.touch.animation = requestAnimationFrame(animateInertia);\n }\n };\n\n handleTouchMove = (e: TouchEvent): void => {\n if (!(e.currentTarget instanceof HTMLDivElement)) { return; }\n\n const { horizontal } = this.props;\n const { bounds, contentBounds, isOpen } = this.state;\n\n let touch: Touch | null = null;\n for (let i = 0, iMax = e.touches.length; i < iMax; ++i) {\n touch = e.touches.item(i);\n if (touch) {\n if (touch.identifier === this.touch.id) { break; }\n }\n }\n\n if (!touch) { return; }\n\n if (horizontal) {\n e.currentTarget.scrollLeft += this.touch.y - touch.pageX;\n } else {\n e.currentTarget.scrollTop += this.touch.y - touch.pageY;\n }\n\n this.touch.inertia = this.touch.y - touch.pageY;\n if (!this.props.allowTouchInertia) { this.touch.inertia = 0; }\n this.touch.y = horizontal ? touch.pageX : touch.pageY;\n const metrics = this.getScrollMetrics();\n\n if (horizontal) {\n e.currentTarget.scrollLeft = Math.min(\n e.currentTarget.scrollLeft,\n metrics.scrollSpace,\n );\n } else {\n e.currentTarget.scrollTop = Math.min(\n e.currentTarget.scrollTop,\n metrics.scrollSpace,\n );\n }\n\n this.positionScrollBar(\n horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n );\n\n this.setState({\n top: horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n animating: false,\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n if (isOpen && bounds && metrics.barRatio < 1) {\n stopPropagation(e);\n }\n\n cancelAnimationFrame(this.touch.animation);\n };\n\n handleWheel = (e: WheelEvent): void => {\n if (!(e.currentTarget instanceof HTMLDivElement)) { return; }\n if (this.props.preventWheel) { return; }\n\n const { horizontal } = this.props;\n const { bounds, contentBounds, isOpen } = this.state;\n const wheel = normalizeWheel(e);\n\n if (horizontal) {\n // Check to see if the horizontal scrolling is greater than vertical\n // scrolling to allow this horizontal scroll view to operate.\n if (this.props.onlyHorizontalWheel) {\n if (Math.abs(wheel.pixelX) < Math.abs(wheel.pixelY)) { return; }\n }\n\n e.currentTarget.scrollLeft += wheel.pixelX;\n e.currentTarget.scrollLeft -= wheel.pixelY;\n } else { e.currentTarget.scrollTop -= wheel.pixelY; }\n\n const metrics = this.getScrollMetrics();\n\n if (horizontal) {\n e.currentTarget.scrollLeft = Math.min(\n e.currentTarget.scrollLeft,\n metrics.scrollSpace,\n );\n } else {\n e.currentTarget.scrollTop = Math.min(\n e.currentTarget.scrollTop,\n metrics.scrollSpace,\n );\n }\n\n this.positionScrollBar(\n horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n );\n\n this.setState({\n top: horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n animating: false,\n });\n\n if (this.props.onScroll && bounds && contentBounds) {\n this.props.onScroll(\n horizontal ? e.currentTarget.scrollLeft : e.currentTarget.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n\n if (isOpen && bounds && metrics.barRatio < 1) {\n if (this.props.allowScrollFlowThrough) {\n if (\n Math.floor(e.currentTarget.scrollTop)\n < Math.floor(metrics.scrollSpace)\n && Math.floor(e.currentTarget.scrollTop) > 0\n ) {\n stopPropagation(e);\n }\n } else {\n stopPropagation(e);\n }\n }\n };\n\n handleBarDown = (e: React.PointerEvent<HTMLDivElement>): void => {\n const { horizontal } = this.props;\n const { bounds, contentBounds } = this.state;\n // Once the bar is mouse downed, we begin to start the dragging process which\n // should be registered across the whole document\n const metrics = this.getScrollMetrics();\n\n // We must calculate how much one pixel of movement would scroll the content\n const pixelScroll = metrics.scrollSpace / metrics.barSpace;\n let startY = horizontal ? e.nativeEvent.clientX : e.nativeEvent.clientY;\n\n this.setState({\n isDragging: true,\n animating: false,\n });\n\n const { pointerId, currentTarget: target } = e;\n target.setPointerCapture(pointerId);\n\n const mousemove = (moveEvent: MouseEvent): void => {\n // See if our mouse left click for drag button is still down (it can be\n // lifted off document thus be missed in the event)\n if ('which' in moveEvent) {\n if (!(moveEvent.which && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n } else if (!((moveEvent as any)?.buttons && 0b01)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n mouseup();\n return;\n }\n\n const newY = horizontal ? moveEvent.clientX : moveEvent.clientY;\n const deltaY = newY - startY;\n startY = newY;\n\n if (this.container.current) {\n if (horizontal) {\n this.container.current.scrollLeft += deltaY * pixelScroll;\n } else { this.container.current.scrollTop += deltaY * pixelScroll; }\n\n if (horizontal) {\n this.container.current.scrollLeft = Math.min(\n this.container.current.scrollLeft,\n metrics.scrollSpace,\n );\n } else {\n this.container.current.scrollTop = Math.min(\n this.container.current.scrollTop,\n metrics.scrollSpace,\n );\n }\n\n this.positionScrollBar(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n );\n\n this.setState({\n top: horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n });\n }\n\n // Prevent any event bubbling to prevent any default dragging behaviorss\n if (moveEvent.stopPropagation) { moveEvent.stopPropagation(); }\n if (moveEvent.preventDefault) { moveEvent.preventDefault(); }\n moveEvent.cancelBubble = true;\n moveEvent.returnValue = false;\n\n // Make sure the scroll info is broadcast still\n if (\n this.props.onScroll\n && bounds\n && contentBounds\n && this.container.current\n ) {\n this.props.onScroll(\n horizontal\n ? this.container.current.scrollLeft\n : this.container.current.scrollTop,\n metrics.scrollSpace,\n bounds,\n contentBounds,\n );\n }\n };\n\n const mouseup = (): void => {\n document.removeEventListener('mousemove', mousemove);\n document.removeEventListener('mouseup', mouseup);\n target.removeEventListener('mouseup', mouseup);\n target.releasePointerCapture(pointerId);\n\n this.setState({\n isDragging: false,\n });\n };\n\n document.addEventListener('mousemove', mousemove);\n document.addEventListener('mouseup', mouseup);\n target.addEventListener('mouseup', mouseup);\n };\n\n render(): JSX.Element {\n const { isOpen, isDragging, bounds, top } = this.state;\n\n const {\n className,\n contentClassName,\n containerProps,\n contentProps,\n children,\n scrollHeight,\n side = ScrollBarSide.RIGHT,\n horizontal,\n alwaysShowScroll,\n mode = ScrollViewMode.DARK,\n } = this.props;\n\n let barTop = top;\n const metrics = this.getScrollMetrics();\n barTop += (top / metrics.scrollSpace) * metrics.barSpace;\n\n if (Number.isNaN(barTop)) {\n barTop = 0;\n }\n\n const barStyle = (): React.CSSProperties => {\n if (horizontal) {\n return {\n left: barTop,\n width: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio < 1)\n || isDragging,\n metrics.barHeight,\n 0,\n ),\n opacity: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio < 1)\n || isDragging,\n 1,\n 0,\n ),\n top: when(side === ScrollBarSide.LEFT, '0px'),\n bottom: when(side === ScrollBarSide.RIGHT, '0px'),\n };\n }\n return {\n top: barTop,\n height: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio < 1)\n || isDragging,\n metrics.barHeight,\n 0,\n ),\n opacity: when(\n ((isOpen || alwaysShowScroll || this.touch.animation >= 0)\n && bounds\n && metrics.barRatio < 1)\n || isDragging,\n 1,\n 0,\n ),\n left: when(side === ScrollBarSide.LEFT, '0px'),\n right: when(side === ScrollBarSide.RIGHT, '0px'),\n };\n };\n\n return (\n // eslint-disable-next-line jsx-a11y/mouse-events-have-key-events\n <div\n className={classnames('ScrollView', mode, className)}\n {...containerProps}\n ref={this.container}\n style={{\n ...containerProps?.style,\n flexDirection: horizontal ? 'row' : void 0,\n }}\n onMouseOver={() => {\n this.setState({ top, isOpen: true });\n this.forceUpdate();\n }}\n onMouseLeave={(e) => {\n const event = e.nativeEvent;\n let node: Element | null = (event as any).toElement || event.relatedTarget;\n\n while (node) {\n if (\n node.parentNode === this.container.current\n || node === this.container.current\n ) {\n return;\n }\n\n node = node.parentElement;\n }\n\n this.setState({ top, isOpen: false });\n }}\n >\n <div\n ref={this.content}\n className={classnames(\n 'ScrollView__Content',\n when(horizontal, 'ScrollView--horizontal-content'),\n contentClassName,\n )}\n style={{\n height: scrollHeight,\n flex: `1 1 ${scrollHeight}px`,\n minHeight: scrollHeight,\n }}\n {...contentProps}\n >\n {children}\n </div>\n <div\n ref={this.scrollBarRef}\n className={classnames(\n 'ScrollView__Bar',\n horizontal ? 'ScrollView--horizontal' : void 0,\n )}\n style={barStyle()}\n onPointerDown={this.handleBarDown}\n />\n </div>\n );\n }\n}\n","import * as React from 'react';\nimport { classnames, DOMRectBounds, INestedChildren, isNumber } from '../../../utils';\nimport { ScrollRegion } from '../../containers/scroll-region/scroll-region';\nimport { ScrollView } from '../../containers/scroll-view/scroll-view';\nimport './list-view.scss';\n\nexport interface IRowProps {\n /** The index of the row to be rendered. */\n index: number;\n /** A fairly mandatory style object you should apply to the top level item */\n style?: React.CSSProperties;\n /** Indicates this row is the last element to be rendered */\n isEnd: boolean;\n /**\n * Gives an opportunity to modify/override the style properties applied to\n * the generated row item\n */\n rowStyle: React.CSSProperties;\n}\n\nexport interface IListView\n extends INestedChildren<React.FunctionComponent<IRowProps>> {\n /** When set, causes inertia to occur with touch swiping */\n allowTouchInertia?: boolean;\n /**\n * A base size to associate with a list item. This helps give a realistic\n * scroll range. Use a negative value to indicate the row should be measured\n * to have a more dynamic row size. The absolute value of the negative value\n * provided will be the minimum size of the row. Use the rowGap property to\n * ensure spacing is provided between the row and it's next row if needed.\n */\n rowSize: number | ((index: number, isEnd: boolean) => number);\n /**\n * Place an incrementing number here. If the rows need recomputing due to a\n * size change, this value should change.\n */\n rowUpdate?: any;\n /** This is ONLY used for rows that get measured and automatically adjusted */\n rowGap?: number;\n /** Applies a class to the top level container of the pane */\n className?: string;\n /** Props to apply to the container of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n /** WHen the list is empty, this will render a centered label in it's place */\n emptyLabel?: string;\n /** Total number of items to render */\n total: number;\n /**\n * Scrolls to the provided location a single time for the given value. A\n * different value must be provided to trigger this a second time.\n */\n scrollToOnce?: number;\n /**\n * Sets how quick the scrollToOnce settles to the new position. Set to 1 to\n * be essentially instant.\n */\n autoScrollDuration?: number;\n /**\n * This limits the list to only display so many rows before forcing scroll.\n * NOTE: When rowSize is a method for varying row sizes, this will means\n * rowDisplayCount will display the number of rows with THE LARGEST AVAILABLE\n * SIZE. So, do not expect this to auto adjust for the varying row sizes\n * available and be super magical.\n */\n rowDisplayCount?: number;\n /**\n * When set to true, this will render the list within a ScrollRegion instead\n * of a ScrollView.\n */\n useScrollRegion?: boolean;\n\n /** Executes when the range of visible rows has changed */\n onRange?(start: number, end: number, total: number, isEnd: boolean): void;\n\n /** Executes on scroll events */\n onScroll?(\n scrollTop: number,\n maxScroll: number,\n viewBounds: DOMRectBounds,\n contentBounds: DOMRectBounds,\n isAutomated?: boolean\n ): void;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * This is a specialized scroll view that aids in recycling and rendering items\n */\nexport class ListView extends React.Component<IListView> {\n state = {\n startIndex: 0,\n endIndex: 0,\n };\n\n /**\n * This is the scrollview container this list uses for creating the scroll\n * space of the list.\n */\n container = React.createRef<ScrollView | ScrollRegion>();\n /**\n * When rowSize is a method, this is used to store the calculated row values.\n * This helps optimize the list to prevent deep looping in really large lists\n * of items.\n */\n rowTop: number[] = [];\n /**\n * This is a helper optimization. It stores the last row's most recently known\n * height. This helps speed up determining the total scroll area of the list.\n */\n lastRowHeight = 0;\n /** This tracks what row size is the largest row size */\n maxRowSize = -1;\n /**\n * This is the last row update context utilized to compute the row tops. If\n * this is different from the props rowUpdate value then it should trigger a\n * recalculation.\n */\n rowUpdateContext?: any;\n /** Used to indicate if this has been intiialized correctly yet. */\n mounted = false;\n /** Tracks the rows that will be measured when rendered */\n willMeasure = new Set<number>();\n /** Tracks the rows that are rendered and need immediate measuring for re-rendering */\n measuring = new Map<number, React.RefObject<HTMLDivElement> | undefined>();\n /**\n * This is set when the list detects rows that are auto calculated. Some\n * initialization behaviors need to be aware of this in order to perform the\n * initial render properly.\n */\n hasAutoHeightRows = false;\n /** Helps watch for mutations in the DOM to aid in dynamically sized rows */\n observer?: MutationObserver;\n\n constructor(props: IListView) {\n super(props);\n this.shouldComponentUpdate(this.props);\n }\n\n componentDidMount(): void {\n this.mounted = true;\n this.forceUpdate();\n window.addEventListener('resize', this.handleResize);\n }\n\n /**\n *\n * We will use this to process incoming props to determine if the row tops\n * should be recalculated.\n */\n shouldComponentUpdate(nextProps: IListView): boolean {\n const { total } = this.props;\n\n // If our rowSize prop is going to be a method, then we need to see if the\n // row top calculations need updating\n if (isNumber(nextProps.rowSize)) {\n this.rowTop = [];\n this.maxRowSize = nextProps.rowSize;\n return true;\n }\n\n // See if we need a row top recalculation\n if (\n nextProps.rowUpdate !== this.rowUpdateContext\n || nextProps.total !== total\n || !this.mounted\n ) {\n this.queueRemeasure(nextProps);\n // Perform an additional remeasure to account for animations settling.\n setTimeout(() => {\n this.queueRemeasure(nextProps);\n this.forceUpdate();\n }, 500);\n }\n\n return true;\n }\n\n componentDidUpdate(): void {\n const { rowGap } = this.props;\n\n if (this.measuring.size > 0) {\n const rows = Array.from(this.measuring.keys());\n const gap = rowGap || 0;\n rows.sort();\n // This will accumulate all of the row changes\n let rowDelta = 0;\n\n // We loop through the rows as they appear in order within the list. We\n // gather the changes in height to the rows and apply the changes to each\n // row as the measurement deviates from the suggested row height.\n for (let i = 0, iMax = rows.length; i < iMax; ++i) {\n const rowIndex = rows[i];\n const nextRowIndex = rows[i + 1] || this.rowTop.length - 1;\n\n // Final row does not need to adjust the row top of anything, but we use\n // the opportunity to ensure the last row's height is computed properly\n if (rowIndex === this.rowTop.length - 1) {\n const rowRef = this.measuring.get(rowIndex);\n if (!rowRef || !rowRef.current) { continue; }\n const rowBox = rowRef.current.getBoundingClientRect();\n this.lastRowHeight = rowBox.height + gap;\n this.willMeasure.delete(rowIndex);\n continue;\n }\n\n const rowTop = this.rowTop[rowIndex];\n const nextRowTop = this.rowTop[rowIndex + 1];\n // Measure the row\n const rowRef = this.measuring.get(rowIndex);\n // No row ref means nothing happens, but this shouldn't happen\n if (!rowRef || !rowRef.current) { continue; }\n const rowBox = rowRef.current.getBoundingClientRect();\n const newNextTop = rowTop + rowBox.height + gap;\n // Our change in row tops compounds as it travels through the rows that\n // need calculating, so we store it all up into a delta change.\n rowDelta = newNextTop - nextRowTop;\n // Successfully measured our row. We can now stop checking on it.\n this.willMeasure.delete(rowIndex);\n\n // Now apply the calculated change in row top to every row top up to the\n // next row that is changed.\n for (let k = rowIndex + 1; k <= nextRowIndex; ++k) {\n this.rowTop[k] += rowDelta;\n }\n }\n\n this.measuring.clear();\n\n // After recomputing all of the new row tops, we can re-render with our\n // new insight and thus shove everything to the appropriate positions.\n // This should also compute the new scroll area\n this.forceUpdate();\n }\n }\n\n componentWillUnmount(): void {\n if (this.observer) { this.observer.disconnect(); }\n window.removeEventListener('resize', this.handleResize);\n }\n\n /**\n * Gets the computed scroll height\n */\n get scrollHeight(): number {\n const { rowSize, total } = this.props;\n if (isNumber(rowSize)) { return total * rowSize; }\n\n // If we are computing each row, we just take the final row's top + that\n // row's height\n return (this.rowTop[total - 1] || 0) + Math.abs(this.lastRowHeight);\n }\n\n /**\n * Applies a calculated style object for the scroll view. This keeps the\n * integrity of the containerProps\n */\n get scrollStyle(): React.CSSProperties {\n const { containerProps = {}, rowDisplayCount = 0 } = this.props;\n const { style } = containerProps;\n const added: React.CSSProperties = {};\n\n if (rowDisplayCount > 0) {\n added.maxHeight = rowDisplayCount * this.maxRowSize;\n }\n\n return {\n ...added,\n ...style,\n };\n }\n\n handleResize = (): void => {\n const { total } = this.props;\n\n if (this.hasAutoHeightRows) {\n for (let i = 0; i < total; ++i) { this.willMeasure.add(i); }\n this.forceUpdate();\n }\n };\n\n handleScrollRegion = (\n scrollTop: [number, number],\n maxScroll: [number, number],\n viewBounds: DOMRectBounds,\n contentBounds: DOMRectBounds,\n ): void => {\n this.handleScroll(scrollTop[1], maxScroll[1], viewBounds, contentBounds);\n };\n\n handleScroll = (\n scrollTop: number,\n maxScroll: number,\n viewBounds: DOMRectBounds,\n contentBounds: DOMRectBounds,\n ): void => {\n const { rowSize, total, onScroll, onRange } = this.props;\n\n let startIndex = -1;\n let endIndex = -1;\n\n if (isNumber(rowSize)) {\n // We need to calculate the visible range of elements here. If that range changes\n // then we should trigger a re-render.\n startIndex = Math.floor(scrollTop / rowSize) - 1;\n endIndex = Math.floor((scrollTop + viewBounds.height) / rowSize) + 1;\n } else {\n startIndex = 0;\n endIndex = 0;\n let check = 0;\n let checkIndex = -1;\n const bottom = scrollTop + viewBounds.height;\n\n while (check < scrollTop && ++checkIndex < this.rowTop.length) {\n check = this.rowTop[checkIndex];\n }\n\n startIndex = checkIndex - 1;\n\n while (check < bottom && ++checkIndex < this.rowTop.length) {\n check = this.rowTop[checkIndex];\n }\n\n endIndex = checkIndex + 1;\n }\n\n // Clamp our values to a valid range\n startIndex = Math.min(Math.max(startIndex, 0), total - 1);\n endIndex = Math.min(Math.max(endIndex, 0), total - 1);\n\n const { startIndex: stateStartIndex, endIndex: stateEndIndex } = this.state;\n\n if (startIndex !== stateStartIndex || endIndex !== stateEndIndex) {\n onRange?.(startIndex, endIndex, total, endIndex === total - 1);\n this.setState({\n startIndex,\n endIndex,\n });\n }\n\n if (onScroll) {\n onScroll(scrollTop, maxScroll, viewBounds, contentBounds);\n }\n };\n\n /**\n * Resets all rowTop calculation assumptions and queues all rows for\n * recalculating.\n */\n queueRemeasure(props: IListView): void {\n if (isNumber(props.rowSize)) { return; }\n this.rowUpdateContext = props.rowUpdate;\n let top = 0;\n this.willMeasure.clear();\n this.rowTop = [];\n\n // Use the height of the row to calculate the top of the next row\n for (let i = 0; i < props.total; ++i) {\n // this.rowTop[i] = top;\n let nextSize = props.rowSize(i, i === props.total - 1);\n\n // If the size is negative, that means the value is a suggested size and\n // the row will be measured to provide a better fit.\n if (nextSize < 0) {\n nextSize *= -1;\n this.willMeasure.add(i);\n this.hasAutoHeightRows = true;\n\n // For dynamic row heights, we only acknowledge the new top if there\n // has not been a top established before. This keeps us able to only\n // assess new row heights on render of the row so the component can\n // adjust properly once we reach the row.\n if (!this.rowTop[i]) {\n this.rowTop[i] = top;\n }\n } else { // We acknowledge the new row top of this row for static row heights\n this.rowTop[i] = top;\n }\n\n if (i === props.total - 1) {\n this.lastRowHeight = nextSize;\n }\n\n this.maxRowSize = Math.max(this.maxRowSize, nextSize);\n top += nextSize;\n }\n }\n\n private renderListItems(renderMethod?: React.FunctionComponent<IRowProps>): React.ReactElement[] | null {\n const { startIndex, endIndex } = this.state;\n const { rowSize, total } = this.props;\n if (!renderMethod) { return null; }\n const rows: React.ReactElement<any, any>[] = [];\n\n // Figure out the means for computing the top value of the row\n let getTop;\n\n if (isNumber(rowSize)) {\n getTop = (i: number) => i * rowSize;\n } else {\n getTop = (i: number) => this.rowTop[i];\n }\n\n for (let i = startIndex; i <= endIndex && i < total; ++i) {\n const top = getTop(i);\n let ref: React.RefObject<HTMLDivElement> | undefined = void 0;\n\n if (this.willMeasure.has(i) && !this.measuring.has(i)) {\n ref = React.createRef<HTMLDivElement>();\n this.measuring.set(i, ref);\n }\n\n const style: React.CSSProperties = {\n position: 'absolute',\n width: '100%',\n left: 0,\n top,\n };\n\n // We pass the information for the row to the render function component so\n // it can apply the list row styles as needed to make the component comply\n // with the desired positioning within the list view space\n const row = renderMethod({\n index: i,\n style: {},\n isEnd: i === endIndex || i === total - 1,\n rowStyle: style,\n });\n\n if (!row || !React.isValidElement(row)) { return null; }\n\n // If the row is intended to be measured, the only reliable and reduced\n // complexity of use is to wrap the component for the row in an html\n // container. We do this because it's hard to make assumptions about what\n // gets rendered into a row (component, functional component, string, etc)\n // so it's hard to normalize getting an element that we can measure\n rows.push(\n <div key={i} className=\"ListView__Row\" ref={ref} style={style}>\n {row}\n </div>,\n );\n }\n\n return rows;\n }\n\n render(): JSX.Element {\n const {\n allowTouchInertia,\n children,\n className,\n containerProps,\n total,\n scrollToOnce,\n autoScrollDuration,\n useScrollRegion,\n emptyLabel,\n } = this.props;\n\n const isEmpty = total <= 0;\n\n if (isEmpty) {\n return (\n <div className={classnames('ListView', 'ListView--empty', className)}>\n <div className=\"ListView__Empty\">{emptyLabel}</div>\n </div>\n );\n }\n\n if (useScrollRegion) {\n return (\n <ScrollRegion\n ref={this.container as React.RefObject<ScrollRegion>}\n allowTouchInertia={allowTouchInertia}\n className={classnames('ListView', className)}\n scrollHeight={this.scrollHeight}\n containerProps={{\n ...containerProps,\n style: this.scrollStyle,\n }}\n autoScrollDuration={autoScrollDuration}\n onScroll={this.handleScrollRegion}\n >\n {this.renderListItems(children)}\n </ScrollRegion>\n );\n }\n\n return (\n <ScrollView\n ref={this.container as React.RefObject<ScrollView>}\n allowTouchInertia={allowTouchInertia}\n className={classnames('ListView', className)}\n scrollHeight={this.scrollHeight}\n containerProps={{\n ...containerProps,\n style: this.scrollStyle,\n }}\n scrollTopOnce={scrollToOnce}\n autoScrollDuration={autoScrollDuration}\n onScroll={this.handleScroll}\n >\n {this.renderListItems(children)}\n </ScrollView>\n );\n }\n}\n","import * as React from 'react';\nimport { classnames } from '../../../utils/classnames';\nimport './loader.scss';\n\nexport const LoaderSize = {\n NORMAL: 'Loader--medium',\n SMALL: 'Loader--small',\n TINY: 'Loader--tiny',\n} as const;\n\nexport type LoaderSizeType = (typeof LoaderSize)[keyof typeof LoaderSize];\n\n/**\n * Loader Props\n */\nexport interface ILoader {\n /** Provides a custom class name to the container of this component */\n className?: string;\n /** Props to apply directly to the container div of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n /** Rendering sie of the standard loader */\n size?: LoaderSizeType;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * Displays the common loader found throughout the application.\n */\nexport function Loader(props: ILoader): React.ReactElement {\n const {\n className,\n containerProps,\n size = LoaderSize.NORMAL,\n } = props;\n\n return (\n <div\n className={classnames('Loader', size, className)}\n {...containerProps}\n />\n );\n}\n","import * as React from 'react';\nimport { capitalCase } from 'change-case';\nimport {\n classnames,\n cloneClientRect,\n controlFocus,\n controlHover,\n DOMRectBounds,\n DOMRectPadding,\n getFirstWithClass,\n isString,\n NOOP,\n stopPropagation,\n when,\n} from '../../../utils';\nimport { Dropdown, IDropdown } from '../../containers/dropdown/dropdown';\nimport { SearchIcon, ChevronDownIcon, CheckIcon } from '../../foundations/icon/icons';\nimport { ListView } from '../../lists/list-view/list-view';\nimport { Loader, LoaderSize } from '../../loaders/loader/loader';\nimport './selection.scss';\n\n/**\n * Builds a selection's options from an object style enum.\n */\nexport function selectionOptionsFromEnum(\n obj: Record<string, any>,\n): ISelection['options'] {\n return Object.keys(obj).map((key) => ({\n label: capitalCase(key),\n value: obj[key],\n search: key,\n }));\n}\n\n/**\n * Available preformatted render modes\n */\nexport const SelectionMode = {\n /**\n * Render mode for the selection being placed within an existing field (such\n * as within a TextInput on the right).\n */\n FIELD_INLINE: 'Selection--field-inline',\n /**\n * Same as field_inline but with toned down colors.\n */\n FIELD_INLINE_SUBTLE: 'Selection--field-inline-subtle',\n /**\n * Style that typically shows up at the top of a page spanning table to filter\n * its contents.\n */\n FILTER_HEADER: 'Selection--filter-header',\n /**\n * Common style when the selection is within a table setting\n */\n TABLE: 'Selection-table',\n /**\n * Renders this mode as disabled. This mode is automatically used when the\n * disabled flag is set for this component.\n */\n DISABLED: 'Selection--disabled',\n} as const;\n\n/**\n * Available preformatted render sizes\n */\nexport const SelectionSize = {\n HEIGHT_30: 'Selection--height-30',\n HEIGHT_32: 'Selection--height-32',\n HEIGHT_36: 'Selection--height-36',\n HEIGHT_40: 'Selection--height-40',\n HEIGHT_60: 'Selection--height-60',\n} as const;\n\nexport type SelectionSizeType =\n (typeof SelectionSize)[keyof typeof SelectionSize];\n\nexport const SelectionDropdownMode = {\n PLAIN: 'Selection--dropdown-plain',\n};\n\nexport type SelectionModeType =\n (typeof SelectionMode)[keyof typeof SelectionMode];\n\n/**\n * Selection Props\n */\nexport interface ISelection {\n /** Allows children */\n children?: React.ReactNode;\n /** Provides a custom class name to the container of this component */\n className?: string;\n /** Props to apply directly to the container div of this component */\n containerProps?: React.HTMLProps<HTMLDivElement>;\n\n /**\n * This causes the selection to display a customized dropdown menu. This\n * essentially bypasses any \"options\" provided and will NOT manage any of the\n * values or callbacks.\n *\n * You can pass a <Dropdown> component to this prop, or you can pass a\n * component with a <Dropdown> as it's top level container and has a\n * containerProps: IDropdown prop.\n */\n customDropdown?: React.ReactNode;\n /** Optional decal to be injected on the left of displayed value */\n decal?: React.ReactNode;\n /**\n * When true, the drop arrow decal will render up instead of down\n */\n decalUp?: boolean;\n /** The initial displayed value within the selection menu */\n defaultValue?: any;\n /** Set to true to render this component as disabled and eliminate handlers */\n disabled?: boolean;\n /**\n * Set this to force a displayed value instead of the user selected value.\n * NOTE: This sets the display WITHOUT affecting the selection value in any\n * way.\n */\n displayValue?: React.ReactNode;\n /**\n * Provide this to force render the dropdown of the selection with custom\n * bounds.\n */\n dropdownBounds?: DOMRectBounds;\n /**\n * Pads the dropdown reference box with the provided padding to allow for a\n * larger dropdown region than just the width of the value box. This also\n * makes it easier to gap the dropdown from the value box.\n */\n dropdownPadding?: DOMRectPadding;\n /** Placeholder message if no value is selected yet */\n placeholder?: string;\n /** Error message */\n error?: string;\n /**\n * Indicate if the dropdown should include a Quick Search.\n *\n * NOTE: The quick search will ONLY work on options that have a string for\n * its label OR is provided a search term to compare against. A React Element\n * can not be searched against.\n */\n hasSearch?: boolean;\n /**\n * Set to true to indicate there are more options that can be loaded in when\n * the user scrolls to the bottom of the list.\n */\n hasMore?: boolean;\n /**\n * Set to true to indicate the dropdown items are being loaded.\n */\n isLoading?: boolean;\n /**\n * Displays a label adjacent to this dropdown.\n */\n label?: React.ReactNode;\n /** Render mode of the selection input */\n mode?: SelectionModeType;\n /** The options to offer in the selection menu */\n options: {\n /**\n * The label of the selection in the dropdown menu (and displayed as the\n * value when selected).\n */\n label: React.ReactNode;\n /** Value paired with the option */\n value: any;\n /** Provides the string the search compares against to find options */\n search?: string;\n /** When true, places a divider between this item and the next item */\n divider?: boolean;\n }[];\n /** Indicates how many rows for the dropdown should render at max */\n rowDisplayCount?: number;\n /** Render size of the selection input */\n size?: SelectionSizeType;\n /** Props to configure the select element to help work with forms */\n selectProps?: React.HTMLProps<HTMLSelectElement>;\n /** When set, this does a controlled component pattern. */\n value?: any;\n /** A label to display next to the current displayed value */\n valueLabel?: string;\n\n /**\n * Executes when the user changes the value of this field.\n */\n onChange?(value: any): void;\n /**\n * If hasMore is true and the user reaches the end of the list, this will\n * execute to indicate more data needs to be loaded for the user to view.\n */\n onLoadMore?(options: this['options']): Promise<void>;\n /**\n * Executes when the user opens the dropdown.\n */\n onOpen?(): void;\n /**\n * Executes when the dropdown is closed. Return false to prevent the dropdown\n * from closing.\n */\n onClose?(): boolean;\n /**\n * This executes when the user types in a search in the QuickSearch field.\n */\n onSearch?(searchTerm: string): void;\n /**\n * This hijacks the click event for the decal arrow. In some cases, the arrow\n * may cause a differing behavior, such as sort direction control.\n */\n onArrowClick?(e: React.MouseEvent): void;\n}\n\ninterface IState {\n dropdownBounds: DOMRectBounds | null;\n hovered: boolean;\n focused: boolean;\n internalValue: any;\n /** The current search term applied to the selection. */\n searchValue?: string;\n}\n\n/**\n * @internal This component exist to keep Pagination component works as before.\n * @deprecated Replace this component as new aligned with design will be added.\n * Displays a dropdown where the user picks an item from a list of items\n *\n * When this component has children, it will skip rendering the header default\n * header component and allow for a customized header which will be the\n * children; HOWEVER, this will still provide the dropdown for rendering for a\n * selection style dropdown menu that will render.\n */\nexport class Selection extends React.Component<ISelection, IState> {\n state: IState = {\n dropdownBounds: null,\n hovered: false,\n focused: false,\n internalValue: void 0,\n };\n\n container = React.createRef<HTMLDivElement>();\n private selectRef = React.createRef<HTMLSelectElement>();\n private headerRef = React.createRef<HTMLDivElement>();\n private searchRef = React.createRef<HTMLInputElement>();\n private stopBlur = false;\n private preventRefocus = false;\n private willLoadMore = false;\n private windowBlurred = false;\n\n componentDidMount(): void {\n document.addEventListener('focusin', this.handleFocus);\n document.addEventListener('focusout', this.handleBlur);\n window.addEventListener('blur', this.handleWindowBlur);\n }\n\n componentDidUpdate(_prevProps: this['props'], prevState: IState): void {\n const { dropdownBounds } = this.state;\n const { hasSearch } = this.props;\n\n // On open of dropdown, if we have a quick search, focus it immediately\n if (prevState.dropdownBounds !== dropdownBounds && dropdownBounds) {\n if (hasSearch) {\n this.stopBlur = true;\n this.preventRefocus = true;\n this.searchRef.current?.focus();\n }\n }\n }\n\n componentWillUnmount(): void {\n document.removeEventListener('focusin', this.handleFocus);\n document.removeEventListener('focusout', this.handleBlur);\n window.removeEventListener('blur', this.handleWindowBlur);\n }\n\n get valueLabel(): React.ReactNode | string {\n const {\n options,\n defaultValue,\n value: controlledValue,\n displayValue,\n } = this.props;\n\n // Display value override without overriding selected value\n if (displayValue !== void 0 && displayValue !== null) { return displayValue; }\n\n const { internalValue } = this.state;\n const value = controlledValue ?? internalValue ?? defaultValue;\n\n return options.find((option) => option.value === value)?.label || '';\n }\n\n get valueIndex(): number {\n const { options, defaultValue, value: controlledValue } = this.props;\n const { internalValue } = this.state;\n const value = controlledValue || internalValue || defaultValue;\n\n return options.findIndex((option) => option.value === value) || 0;\n }\n\n /**\n * Retrieves the list of options that should be displayed. This takes into\n * account the current search term the user may have entered.\n */\n get options(): ISelection['options'] {\n const { searchValue } = this.state;\n const { options } = this.props;\n\n const searchTerm = searchValue?.toLocaleLowerCase();\n\n if (searchTerm) {\n return options.filter((o) => {\n if (o.search) {\n return o.search.toLocaleLowerCase().indexOf(searchTerm) > -1;\n } if (isString(o.label)) {\n return o.label.toLocaleLowerCase().indexOf(searchTerm) > -1;\n }\n return false;\n });\n }\n\n return options;\n }\n\n handleWindowBlur = (): void => {\n this.windowBlurred = true;\n };\n\n handleClick = (e: React.SyntheticEvent): void => {\n const { disabled } = this.props;\n const { dropdownBounds } = this.state;\n\n this.windowBlurred = false;\n if (disabled) { return; }\n\n const content = getFirstWithClass(\n e.target as HTMLElement,\n 'Selection__Content',\n );\n if (!content) { return; }\n\n if (document.activeElement !== this.selectRef.current) {\n this.stopBlur = true;\n setTimeout(() => {\n this.stopBlur = false;\n }, 10);\n this.selectRef.current?.focus();\n } else if (dropdownBounds) {\n this.selectRef.current?.blur();\n } else {\n this.handleOpen();\n }\n };\n\n handleOpen = (): void => {\n const { disabled, dropdownPadding, onOpen } = this.props;\n\n if (!this.headerRef.current || disabled) { return; }\n\n const box = cloneClientRect(\n this.headerRef.current.getBoundingClientRect(),\n {\n bottom: 5,\n ...dropdownPadding,\n },\n );\n\n box.top -= 4;\n box.bottom += 4;\n box.height += 8;\n\n this.setState({\n dropdownBounds: box,\n });\n\n onOpen?.();\n };\n\n handleClose = (): void => {\n const { onClose } = this.props;\n\n if (onClose?.() === false) { return; }\n\n this.setState({\n dropdownBounds: null,\n searchValue: '',\n });\n };\n\n handleFocus = (e: FocusEvent): void => {\n const { disabled } = this.props;\n\n // Absorb window refocus event to prevent the dropdown from auto opening on\n // things like tab switches.\n if (this.windowBlurred) {\n this.windowBlurred = false;\n return;\n }\n\n if (disabled) { return; }\n if (e.target === this.selectRef.current) {\n this.handleOpen();\n }\n };\n\n handleBlur = (e: FocusEvent): void => {\n const { disabled } = this.props;\n\n if (disabled) { return; }\n if (e.target === this.selectRef.current) {\n if (this.stopBlur) {\n this.stopBlur = false;\n if (!this.preventRefocus) {\n this.selectRef.current?.focus();\n }\n return;\n }\n\n this.handleClose();\n }\n };\n\n handleSelect = (option: ISelection['options'][0]) => () => {\n const { disabled, onChange } = this.props;\n\n if (disabled) { return; }\n onChange?.(option.value);\n this.setState({\n dropdownBounds: null,\n internalValue: option.value,\n });\n };\n\n /**\n * Handles the user's input into the Quick Search bar\n */\n handleSearch = (e: React.ChangeEvent): void => {\n const { disabled, onSearch } = this.props;\n\n if (disabled) { return; }\n\n const searchTerm = (e.target as any)?.value?.toLocaleLowerCase();\n this.setState({\n searchValue: searchTerm,\n });\n onSearch?.(searchTerm);\n };\n\n preventBlur = (): void => {\n this.stopBlur = true;\n };\n\n handleRange = async (\n _start: number,\n _end: number,\n _total: number,\n isEnd: boolean,\n ): Promise<void> => {\n const { hasMore, onLoadMore, options } = this.props;\n\n if (isEnd && !this.willLoadMore && hasMore) {\n this.willLoadMore = true;\n await onLoadMore?.(options);\n this.willLoadMore = false;\n }\n };\n\n handleMouseDown = (e: React.MouseEvent): void => {\n const { dropdownBounds: stateDropdownBounds } = this.state;\n const { dropdownBounds } = this.props;\n\n // Prevent mosue down event from propagating ONLY when this is open and the\n // header of the selection is clicked. This prevents clicking on the title\n // from flicking back open instead of toggling when the user clicks the\n // header to close.\n if (stateDropdownBounds || dropdownBounds) {\n stopPropagation(e);\n }\n };\n\n renderHeader(): JSX.Element {\n const {\n decal,\n decalUp,\n disabled,\n error,\n label,\n mode = SelectionMode.FIELD_INLINE,\n placeholder,\n onArrowClick,\n valueLabel: valueLabelProps,\n } = this.props;\n const { hovered, focused, dropdownBounds } = this.state;\n const { valueLabel } = this;\n\n return (\n <>\n { /* eslint-disable-next-line jsx-a11y/no-static-element-interactions,\n jsx-a11y/click-events-have-key-events */ }\n <div\n className={classnames(\n 'Selection__Content',\n when(focused || dropdownBounds, 'Selection--focus'),\n when(hovered, 'Selection--hovered'),\n when(\n valueLabel && !hovered,\n 'Selection--filled',\n 'Selection--empty',\n ),\n when(error, 'Selection--error'),\n when(label, 'Selection--has-label'),\n 'Selection--single-row',\n mode,\n when(disabled, SelectionMode.DISABLED),\n )}\n ref={this.headerRef}\n {...controlHover(this)}\n {...controlFocus(this)}\n onMouseDown={this.handleMouseDown}\n onClick={this.handleClick}\n >\n {when(decal, <div className=\"Selection__Decal\">{decal}</div>)}\n {when(label, <div className=\"Selection__Label\">{label}</div>)}\n <div className=\"Selection__Left\">\n <div\n className={classnames(\n 'Selection__Value',\n when(valueLabel, '', 'Selection--placeholder'),\n )}\n >\n {when(valueLabelProps, (lbl) => (\n <b>{lbl}</b>\n ))}\n {valueLabel || placeholder}\n </div>\n </div>\n {/* eslint-disable-next-line jsx-a11y/click-events-have-key-events */}\n <div\n className={classnames(\n 'Selection__DecalRight',\n when(decalUp, 'Selection--up'),\n )}\n onClick={onArrowClick}\n role=\"button\"\n tabIndex={0}\n >\n <ChevronDownIcon />\n </div>\n </div>\n </>\n );\n }\n\n renderDropdown(): JSX.Element | null | undefined {\n const {\n customDropdown,\n defaultValue,\n dropdownBounds,\n hasMore,\n hasSearch,\n isLoading,\n mode = SelectionMode.FIELD_INLINE,\n rowDisplayCount = 5,\n value: controlledValue,\n } = this.props;\n const { internalValue } = this.state;\n const value = controlledValue ?? internalValue ?? defaultValue;\n const optionList = this.options;\n const { dropdownBounds: stateDropdownBounds } = this.state;\n\n return when(stateDropdownBounds || dropdownBounds, (bounds) => when(\n customDropdown,\n () => {\n if (React.isValidElement(customDropdown)) {\n // If it's a dropdown, then we pass the props directly to the\n // component.\n if (customDropdown.type === Dropdown) {\n return React.cloneElement(customDropdown, {\n ...customDropdown.props,\n ...({\n bounds,\n width: Math.max(200, bounds.width),\n onClose: this.handleClose,\n containerProps: { onMouseDown: this.preventBlur },\n } as IDropdown),\n });\n }\n\n // Otherwise, we assume it's a component with a top level Dropdown\n // thus we pass the props to containerProps.\n\n return React.cloneElement(customDropdown, {\n ...customDropdown.props,\n containerProps: {\n bounds,\n width: Math.max(200, bounds.width),\n onClose: this.handleClose,\n containerProps: { onMouseDown: this.preventBlur },\n } as IDropdown,\n });\n }\n\n // eslint-disable-next-line no-console\n console.warn('Custom dropdown menu is invalid');\n return null;\n },\n\n <Dropdown\n bounds={bounds}\n width={Math.max(200, bounds.width)}\n onClose={this.handleClose}\n containerProps={{ onMouseDown: this.preventBlur }}\n className={mode}\n >\n <div\n className={classnames(\n 'Selection__Panel',\n when(isLoading, 'Selection__Loader'),\n )}\n >\n {when(hasSearch, () => this.renderSearch())}\n {when(\n isLoading,\n <div className=\"Selection__LoaderContainer\">\n <Loader size={LoaderSize.SMALL} />\n </div>,\n\n <ListView\n className=\"Selection__List\"\n total={optionList.length + (hasMore ? 1 : 0)}\n rowSize={36}\n rowDisplayCount={rowDisplayCount}\n scrollToOnce={Math.max(this.valueIndex - 2, 0) * 36}\n onRange={hasMore ? this.handleRange : void 0}\n >\n {({ index, style, isEnd }) => {\n const option = optionList[index];\n\n if (isEnd && hasMore) {\n return (\n <div\n key={index}\n className={classnames('Selection__Option')}\n style={style}\n >\n <Loader size={LoaderSize.TINY} />\n </div>\n );\n }\n\n return (\n // eslint-disable-next-line jsx-a11y/click-events-have-key-events\n <div\n key={index}\n className={classnames(\n 'Selection__Option',\n when(option.value === value, 'Selection--selected'),\n when(option.divider, 'Selection--divider'),\n )}\n style={style}\n onClick={this.handleSelect(option)}\n role=\"option\"\n aria-selected={option.value === value}\n tabIndex={0}\n >\n <span>{option.label}</span>\n <CheckIcon className=\"Icon Selection__Check\" />\n </div>\n );\n }}\n </ListView>,\n )}\n </div>\n </Dropdown>,\n ));\n }\n\n renderSearch(): JSX.Element {\n const { searchValue } = this.state;\n\n return (\n <div className=\"Selection__Search\">\n <SearchIcon className=\"Selection__SearchIcon\" />\n <input\n value={searchValue}\n spellCheck=\"false\"\n autoCorrect=\"false\"\n ref={this.searchRef}\n type=\"text\"\n placeholder=\"Quick Search\"\n onMouseDown={() => {\n this.stopBlur = true;\n this.preventRefocus = true;\n this.searchRef.current?.focus();\n }}\n onChange={this.handleSearch}\n />\n </div>\n );\n }\n\n render(): JSX.Element {\n const {\n className,\n containerProps,\n defaultValue,\n value: controlledValue,\n options,\n mode = SelectionMode.FIELD_INLINE,\n size,\n children,\n disabled,\n selectProps,\n } = this.props;\n const { internalValue } = this.state;\n const value = controlledValue || internalValue || defaultValue;\n\n return (\n <div\n ref={this.container}\n className={classnames(\n 'Selection',\n mode,\n size,\n when(disabled, SelectionMode.DISABLED),\n className,\n )}\n {...containerProps}\n >\n <select\n ref={this.selectRef}\n value={value}\n onChange={NOOP}\n disabled={disabled}\n {...selectProps}\n >\n {options.map((opt) => (\n <option key={opt.value} value={opt.value} aria-label={opt.value} />\n ))}\n </select>\n {when(children === void 0, this.renderHeader())}\n {this.renderDropdown()}\n </div>\n );\n }\n}\n","import { DEFAULT_ITEMS_PER_PAGE_OPTIONS } from './pagination-config';\nimport { usePaginationContext } from './pagination-context';\n\nimport { Selection } from '../../inputs/selection/selection';\n\nexport function BrPaginationItemsPerPageSelector(): JSX.Element | null {\n const paginationCtx = usePaginationContext();\n\n if (!paginationCtx) {\n throw new Error('BrPaginationItemsPerPageSelector must be used within a PaginationContext.Provider');\n }\n\n const { itemsPerPage, itemsPerPageOptions, onItemsPerPageChange } = paginationCtx;\n\n const options = (itemsPerPageOptions || DEFAULT_ITEMS_PER_PAGE_OPTIONS).map((item) => {\n if (typeof item === 'number') {\n return {\n label: item.toString(),\n value: item,\n };\n }\n\n return item;\n });\n\n if (options.length < 2) {\n return null;\n }\n\n return (\n <Selection\n value={itemsPerPage}\n options={options}\n onChange={onItemsPerPageChange}\n aria-label=\"Items per page selector\"\n />\n );\n}\n","import { PAGINATION_PAGES_BUFFER, PAGINATION_PAGES_LIMIT } from './pagination-config';\nimport { PageNavigationItemsListType } from './pagination-types';\n\nexport const SEPARATOR = '...';\n\nexport function range(from: number, count: number): Array<number> {\n return Array(count).fill(0).map((_, index) => index + from);\n}\n\n/**\n * This function generates the pagination navigation links and separators.\n * The output is an array of numbers and separators\n * Eg., [1, 2, 3, 4, 5, 6, 7, '...', 10]\n * @param currentPageIndex, index of the current page\n * @param totalPages, total number of pages\n */\nexport function getNavItems(currentPageIndex: number, totalPages: number): PageNavigationItemsListType {\n const navItems: PageNavigationItemsListType = [];\n const lastPageIndex = totalPages - 1;\n\n if (totalPages <= PAGINATION_PAGES_LIMIT) {\n // If it is under the pages limit, just show all the pages\n range(0, totalPages).map((p) => navItems.push(p));\n } else {\n // If not, start by adding the first page, since the first and last will always be shown\n navItems.push(0);\n\n // On the left, we want to show one extra page after the selected page\n // Check if the current page index is under that threshold\n // If the page limit is 9, the currentPageIndex should be below 5 (page no 6), so we have space\n // to show pages 7, '...', <last page>, totalling the number of shown items to 9\n if (currentPageIndex <= PAGINATION_PAGES_LIMIT - (PAGINATION_PAGES_BUFFER * 2)) {\n range(\n 1,\n PAGINATION_PAGES_LIMIT - PAGINATION_PAGES_BUFFER - 1,\n ).map((p) => navItems.push(p));\n } else {\n navItems.push(SEPARATOR);\n }\n\n // If the current page is not close to the start or the end pages, then show the current page\n // and pages equal to the buffer on both sides\n if (currentPageIndex > PAGINATION_PAGES_LIMIT - (PAGINATION_PAGES_BUFFER * 2)\n && currentPageIndex < lastPageIndex - (PAGINATION_PAGES_BUFFER) - 1) {\n range(\n currentPageIndex - PAGINATION_PAGES_BUFFER,\n PAGINATION_PAGES_LIMIT - (PAGINATION_PAGES_BUFFER * 2),\n ).map((p) => navItems.push(p));\n }\n\n // On the right too, we want to show one extra page before the selected page\n if (currentPageIndex >= lastPageIndex - (PAGINATION_PAGES_BUFFER) - 1) {\n range(\n totalPages - (PAGINATION_PAGES_LIMIT - PAGINATION_PAGES_BUFFER),\n PAGINATION_PAGES_LIMIT - PAGINATION_PAGES_BUFFER - 1,\n ).map((p) => navItems.push(p));\n } else {\n navItems.push(SEPARATOR);\n }\n\n // End by adding the last page, since the first and last will always be shown\n navItems.push(lastPageIndex);\n }\n\n return navItems;\n}\n","import cn from 'classnames';\nimport { BrButton } from '../../buttons';\nimport { usePaginationContext } from './pagination-context';\nimport { SEPARATOR } from './pagination-navigation-helpers';\nimport { PageNavigationItemType } from './pagination-types';\n\nexport interface BrPaginationNavigationItemProps {\n value: PageNavigationItemType;\n}\n\nexport function BrPaginationNavigationItem({ value }: BrPaginationNavigationItemProps): JSX.Element {\n const paginationCtx = usePaginationContext();\n\n if (!paginationCtx) {\n throw new Error('BrPaginationNavigationItem must be used within a PaginationContext.Provider');\n }\n\n const { page, onPageChange } = paginationCtx;\n const isPage = typeof value === 'number';\n const label = isPage ? (value + 1).toLocaleString() : value;\n const disabled = value === SEPARATOR || page === value;\n const selected = page === value;\n\n const getAriaLabel = (): string | undefined => {\n if (!isPage) {\n return undefined;\n }\n\n if (selected) {\n return `Current page, page ${label}`;\n }\n\n return `Go to page ${label}`;\n };\n\n const handleOnClick = (): void => {\n if (typeof value === 'number') {\n onPageChange?.(value);\n }\n };\n\n return (\n <BrButton\n type=\"tertiary\"\n aria-current={selected ? true : undefined}\n aria-label={getAriaLabel()}\n className={cn('br-pagination__navigation-item', { 'br-pagination__navigation-item__selected': selected })}\n disabled={disabled}\n onClick={handleOnClick}\n >\n {label}\n </BrButton>\n );\n}\n","import { BrButton } from '../../buttons';\nimport { ChevronLeftIcon, ChevronRightIcon } from '../../foundations';\nimport { usePaginationContext } from './pagination-context';\nimport { getNavItems } from './pagination-navigation-helpers';\nimport { BrPaginationNavigationItem } from './pagination-navigation-item';\n\nexport function BrPaginationNavigation(): JSX.Element | null {\n const paginationCtx = usePaginationContext();\n\n if (!paginationCtx) {\n throw new Error('BrPaginationNavigation must be used within a PaginationContext.Provider');\n }\n\n const { count, page, itemsPerPage, onPageChange } = paginationCtx;\n\n if (count <= itemsPerPage) {\n return null;\n }\n\n const onNext = (): void => {\n onPageChange?.(page + 1);\n };\n\n const onPrev = (): void => {\n onPageChange?.(page - 1);\n };\n\n const navItems = getNavItems(page, Math.ceil(count / itemsPerPage));\n /* eslint-disable react/no-array-index-key */\n // Disabling the eslint rule, since there can be two separators (...) and the index is how we differentiate\n return (\n <nav role=\"navigation\" aria-label=\"Pagination Navigation\" className=\"br-pagination__navigation\">\n <ul>\n <li>\n <BrButton\n onClick={onPrev}\n type=\"tertiary\"\n aria-label=\"Go to previous page\"\n disabled={page === 0}\n >\n <ChevronLeftIcon />\n </BrButton>\n </li>\n {navItems.map((item, index) => (\n <li key={`br-pagination-${item}-${index}`}><BrPaginationNavigationItem value={item} /></li>\n ))}\n <li>\n <BrButton\n onClick={onNext}\n type=\"tertiary\"\n aria-label=\"Go to next page\"\n disabled={page >= Math.ceil(count / itemsPerPage) - 1}\n >\n <ChevronRightIcon />\n </BrButton>\n </li>\n </ul>\n </nav>\n );\n}\n","import { usePaginationContext } from './pagination-context';\n\nexport function BrPaginationSummary(): JSX.Element {\n const paginationCtx = usePaginationContext();\n\n if (!paginationCtx) {\n throw new Error('BrPaginationSummary must be used within a PaginationContext.Provider');\n }\n\n const { count, page, itemsPerPage } = paginationCtx;\n const start = (page * itemsPerPage) + 1;\n const end = Math.min((page + 1) * itemsPerPage, count);\n return (\n <div className=\"br-pagination__summary\">\n Showing\n {' '}\n {start.toLocaleString()}\n {' '}\n {start !== end ? (\n <>\n to\n {' '}\n {end.toLocaleString()}\n {' '}\n </>\n ) : null}\n of\n {' '}\n {count.toLocaleString()}\n </div>\n );\n}\n","import cn from 'classnames';\nimport { ForwardedRef, forwardRef } from 'react';\nimport PaginationContext from './pagination-context';\nimport { BrPaginationItemsPerPageSelector } from './pagination-items-per-page-selector';\nimport { BrPaginationNavigation } from './pagination-navigation';\nimport { BrPaginationSummary } from './pagination-summary';\nimport { BrPaginationProps } from './pagination-types';\nimport './pagination.scss';\n\n/**\n * Pagination component to display pagination links and manage the number of items per page\n *\n * ### Usage\n * ```tsx\n * import { BrPagination } from '@bloomreach/react-banana-ui'\n *\n * <BrPagination\n * count={100}\n * itemsPerPage={10}\n * page={0}\n * onPageChange={(page) => console.log(page)}\n * itemsPerPageOptions={[10, 25, 50]}\n * onItemsPerPageChange={(num) => console.log(num)}\n * />\n * ```\n */\nconst BrPagination = forwardRef((\n props: BrPaginationProps,\n forwardedRef: ForwardedRef<HTMLDivElement>,\n): JSX.Element | null => {\n const {\n count,\n className,\n page,\n itemsPerPage,\n itemsPerPageOptions,\n onPageChange,\n onItemsPerPageChange,\n ...rest\n } = props;\n\n if (count < 1) {\n return null;\n }\n\n return (\n <PaginationContext.Provider value={props}>\n <div {...rest} className={cn('br-pagination', className)} ref={forwardedRef}>\n <div className=\"br-pagination__left\">\n <BrPaginationItemsPerPageSelector />\n <BrPaginationSummary />\n </div>\n <BrPaginationNavigation />\n </div>\n </PaginationContext.Provider>\n );\n});\n\nBrPagination.displayName = 'BrPagination';\n\nexport default BrPagination;\n"],"names":["_extends","target","i","source","key","isHostComponent","element","appendOwnerState","elementType","otherProps","ownerState","defaultContextValue","ClassNameConfiguratorContext","React","useClassNamesOverride","generateUtilityClass","disableDefaultClasses","slot","extractEventHandlers","object","excludeKeys","result","prop","resolveComponentProps","componentProps","slotState","_objectWithoutPropertiesLoose","excluded","sourceKeys","chainPropTypes","propType1","propType2","args","b","c","d","e","f","g","h","k","l","m","n","p","q","r","t","v","w","x","y","z","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","type","typeOf","$$typeof","$$typeofType","AsyncMode","ConcurrentMode","ContextConsumer","ContextProvider","Element","ForwardRef","Fragment","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","getOwnPropertySymbols","hasOwnProperty","propIsEnumerable","toObject","val","shouldUseNative","test1","test2","order2","test3","letter","objectAssign","from","to","symbols","s","ReactPropTypesSecret","ReactPropTypesSecret_1","has","printWarning","loggedTypeFailures","text","message","checkPropTypes","typeSpecs","values","location","componentName","getStack","typeSpecName","error","err","ex","stack","checkPropTypes_1","ReactIs","assign","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","data","createChainableTypeChecker","validate","manualPropTypeCallCache","manualPropTypeWarningCount","checkType","isRequired","props","propName","propFullName","secret","cacheKey","chainedCheckType","expectedType","propValue","propType","getPropType","preciseType","getPreciseType","typeChecker","expectedClass","expectedClassName","actualClassName","getClassName","expectedValues","valuesString","value","arrayOfTypeCheckers","checker","getPostfixForTypeWarning","expectedTypes","checkerResult","expectedTypesMessage","isNode","invalidValidatorError","shapeTypes","allKeys","iterator","step","entry","isSymbol","emptyFunction","emptyFunctionWithReset","factoryWithThrowingShims","shim","getShim","propTypesModule","isClassComponent","prototype","acceptingRef","safePropName","warningHint","elementAcceptingRef","PropTypes","elementAcceptingRef$1","specialProperty","exactProp","propTypes","unsupportedProps","formatMuiErrorMessage","code","url","HTMLElementType","createChainedFunction","funcs","acc","func","debounce","wait","timeout","debounced","later","ownerDocument","node","ownerWindow","setRef","ref","useEnhancedEffect$1","useEventCallback","fn","useEnhancedEffect","useForkRef","refs","instance","hadKeyboardEvent","hadFocusVisibleRecently","hadFocusVisibleRecentlyTimeout","inputTypesWhitelist","focusTriggersKeyboardModality","tagName","handleKeyDown","event","handlePointerDown","handleVisibilityChange","prepare","doc","isFocusVisible","useIsFocusVisible","isFocusVisibleRef","handleBlurVisible","handleFocusVisible","getScrollbarSize","documentWidth","composeClasses","slots","getUtilityClass","classes","output","utilityClass","defaultGenerator","ClassNameGenerator$1","generate","generator","globalStateClassesMapping","globalStatePrefix","globalStateClass","ClassNameGenerator","generateUtilityClasses","clsx","omitEventHandlers","mergeSlotProps","parameters","getSlotProps","additionalProps","externalSlotProps","externalForwardedProps","className","joinedClasses","mergedStyle","eventHandlers","componentsPropsWithoutEventHandlers","otherPropsWithoutEventHandlers","internalSlotProps","_excluded","useSlotProps","_parameters$additiona","skipResolvingSlotProps","rest","resolvedComponentsProps","mergedProps","internalRef","prepareForSlot","Component","other","useButton","disabled","focusableWhenDisabled","href","externalRef","tabIndex","buttonRef","active","setActive","focusVisibleRef","focusVisible","setFocusVisible","hostElementName","setHostElementName","createHandleMouseLeave","otherHandlers","_otherHandlers$onMous","createHandleBlur","_otherHandlers$onBlur","createHandleFocus","_otherHandlers$onFocu2","_otherHandlers$onFocu","isNativeButton","button","createHandleClick","_otherHandlers$onClic","createHandleMouseDown","_otherHandlers$onMous2","createHandleKeyDown","_otherHandlers$onKeyD","_otherHandlers$onClic2","createHandleKeyUp","_otherHandlers$onKeyU","_otherHandlers$onClic3","updateHostElementName","_instance$tagName","handleRef","buttonProps","externalProps","externalEventHandlers","candidatesSelector","getTabIndex","tabindexAttr","isNonTabbableRadio","getRadio","selector","roving","isNodeMatchingSelectorFocusable","defaultGetTabbable","root","regularTabNodes","orderedTabNodes","nodeTabIndex","defaultIsEnabled","FocusTrap","children","disableAutoFocus","disableEnforceFocus","disableRestoreFocus","getTabbable","isEnabled","open","ignoreNextEnforceFocus","sentinelStart","sentinelEnd","nodeToRestore","reactFocusEventTarget","activated","rootRef","lastKeydown","loopFocus","nativeEvent","contain","rootElement","tabbable","_lastKeydown$current","_lastKeydown$current2","isShiftTab","focusNext","focusPrevious","interval","onFocus","childrenPropsHandler","handleFocusSentinel","_jsxs","_jsx","FormControlContext","useFormControlContext","useInput","defaultValueProp","disabledProp","errorProp","onBlur","onChange","requiredProp","valueProp","inputRefProp","formControlContext","defaultValue","required","_formControlContext$d","_formControlContext$e","_formControlContext$r","definedLocalProps","isControlled","handleInputRefWarning","inputRef","handleInputRef","focused","setFocused","handleFocus","_formControlContext$o","handleBlur","handleChange","_formControlContext$o2","_otherHandlers$onChan","_formatMuiErrorMessage","handleClick","mergedEventHandlers","propsEventHandlers","getContainer","container","forwardedRef","disablePortal","mountNode","setMountNode","newProps","ReactDOM","isOverflowing","ariaHidden","show","getPaddingRight","isAriaHiddenForbiddenOnElement","isForbiddenTagName","isInputHidden","ariaHiddenSiblings","mountElement","currentElement","elementsToExclude","blacklist","isNotExcludedElement","isNotForbiddenElement","findIndexOf","items","callback","idx","item","index","handleContainer","containerInfo","restoreStyle","scrollbarSize","fixedElements","scrollContainer","parent","containerWindow","el","property","getHiddenSiblings","hiddenSiblings","ModalManager","modal","modalIndex","containerIndex","ariaHiddenState","nextTop","getHasTransition","defaultManager","useModal","disableEscapeKeyDown","disableScrollLock","manager","closeAfterTransition","onTransitionEnter","onTransitionExited","onClose","mountNodeRef","modalRef","exited","setExited","hasTransition","ariaHiddenProp","getDoc","getModal","handleMounted","handleOpen","resolvedContainer","isTopModal","handlePortalRef","handleClose","createHandleBackdropClick","handleEnter","handleExited","getModalUtilityClass","useUtilityClasses","Modal","_slots$root","hideBackdrop","keepMounted","onBackdropClick","slotProps","propsWithDefaults","getRootProps","getBackdropProps","getTransitionProps","portalRef","childProps","onEnter","onExited","Root","rootProps","BackdropComponent","backdropProps","min","max","round","floor","createCoords","oppositeSideMap","oppositeAlignmentMap","clamp","start","end","evaluate","param","getSide","placement","getAlignment","getOppositeAxis","axis","getAxisLength","getSideAxis","getAlignmentAxis","getAlignmentSides","rects","rtl","alignment","alignmentAxis","length","mainAlignmentSide","getOppositePlacement","getExpandedPlacements","oppositePlacement","getOppositeAlignmentPlacement","getSideList","side","isStart","lr","rl","tb","bt","getOppositeAxisPlacements","flipAlignment","direction","list","expandPaddingObject","padding","getPaddingObject","rectToClientRect","rect","computeCoordsFromPlacement","_ref","reference","floating","sideAxis","alignLength","isVertical","commonX","commonY","commonAlign","coords","computePosition","config","strategy","middleware","platform","validMiddleware","statefulPlacement","middlewareData","resetCount","name","nextX","nextY","reset","detectOverflow","state","options","_await$platform$isEle","elements","boundary","rootBoundary","elementContext","altBoundary","paddingObject","clippingClientRect","offsetParent","offsetScale","elementClientRect","arrow","arrowDimensions","isYAxis","minProp","maxProp","clientProp","endDiff","startDiff","arrowOffsetParent","clientSize","centerToReference","largestPossiblePadding","minPadding","maxPadding","min$1","center","offset","shouldAddOffset","alignmentOffset","flip","_middlewareData$arrow","_middlewareData$flip","initialPlacement","checkMainAxis","checkCrossAxis","specifiedFallbackPlacements","fallbackStrategy","fallbackAxisSideDirection","detectOverflowOptions","isBasePlacement","fallbackPlacements","placements","overflow","overflows","overflowsData","sides","_middlewareData$flip2","_overflowsData$filter","nextIndex","nextPlacement","resetPlacement","_overflowsData$map$so","convertValueToCoords","mainAxisMulti","crossAxisMulti","rawValue","mainAxis","crossAxis","diffCoords","shift","limiter","mainAxisCoord","crossAxisCoord","minSide","maxSide","limitedCoords","getNodeName","getWindow","_node$ownerDocument","getDocumentElement","isHTMLElement","isShadowRoot","isOverflowElement","overflowX","overflowY","display","getComputedStyle","isTableElement","isContainingBlock","webkit","isWebKit","css","getContainingBlock","currentNode","getParentNode","isLastTraversableNode","getNodeScroll","getNearestOverflowAncestor","parentNode","getOverflowAncestors","traverseIframes","_node$ownerDocument2","scrollableAncestor","isBody","win","getCssDimensions","width","height","hasOffset","offsetWidth","offsetHeight","shouldFallback","unwrapElement","getScale","domElement","$","noOffsets","getVisualOffsets","shouldAddVisualOffsets","isFixed","floatingOffsetParent","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scale","visualOffsets","offsetWin","currentIFrame","iframeScale","iframeRect","left","top","convertOffsetParentRelativeRectToViewportRelativeRect","isOffsetParentAnElement","documentElement","scroll","offsets","offsetRect","getClientRects","getWindowScrollBarX","getDocumentRect","html","body","getViewportRect","visualViewport","visualViewportBased","getInnerBoundingClientRect","getClientRectFromClippingAncestor","clippingAncestor","hasFixedPositionAncestor","stopNode","getClippingElementAncestors","cache","cachedResult","currentContainingBlockComputedStyle","elementIsFixed","computedStyle","currentNodeIsContaining","ancestor","getClippingRect","clippingAncestors","firstClippingAncestor","clippingRect","accRect","getDimensions","getRectRelativeToOffsetParent","getTrueOffsetParent","polyfill","getOffsetParent","window","getElementRects","getOffsetParentFn","getDimensionsFn","isRTL","observeMove","onMove","io","timeoutId","cleanup","refresh","skip","threshold","insetTop","insetRight","insetBottom","insetLeft","isFirstUpdate","handleObserve","entries","ratio","autoUpdate","update","ancestorScroll","ancestorResize","elementResize","layoutShift","animationFrame","referenceEl","ancestors","cleanupIo","reobserveFrame","resizeObserver","firstEntry","frameId","prevRefRect","frameLoop","nextRefRect","mergedOptions","platformWithCache","computePosition$1","isRef","arrow$1","useLayoutEffect","useEffect","deepEqual","keys","getDPR","roundByDPR","dpr","useLatestRef","useFloating","externalReference","externalFloating","transform","whileElementsMounted","setData","latestMiddleware","setLatestMiddleware","_reference","_setReference","_floating","_setFloating","setReference","referenceRef","setFloating","floatingRef","floatingEl","dataRef","whileElementsMountedRef","platformRef","fullData","isMountedRef","floatingStyles","initialStyles","getStyleValue","styles","isEmpty","obj","TextareaAutosize","maxRows","minRows","style","shadowRef","renders","setState","getUpdatedState","input","inputShallow","boxSizing","border","innerHeight","singleRowHeight","outerHeight","outerHeightStyle","updateState","prevState","newState","syncHeight","syncHeightWithFlushSync","handleResize","rAF","rAFHandleResize","debounceHandleResize","hasOwn","classNames","arg","argType","inner","module","SvgAbTest","forwardRef","BrIcon","size","color","svgProps","cloneElement","AbTestIcon","jsx","AbTestSvgIcon","SvgAggregate","AggregateIcon","AggregateSvgIcon","SvgAnalytics","AnalyticsIcon","AnalyticsSvgIcon","SvgAndroid","AndroidIcon","AndroidSvgIcon","SvgAnonymize","AnonymizeIcon","AnonymizeSvgIcon","SvgApple","AppleIcon","AppleSvgIcon","SvgArchiveAlt","ArchiveAltIcon","ArchiveAltSvgIcon","SvgArchive","ArchiveIcon","ArchiveSvgIcon","SvgArrowCollapse","ArrowCollapseIcon","ArrowCollapseSvgIcon","SvgArrowDown","ArrowDownIcon","ArrowDownSvgIcon","SvgArrowExpand","ArrowExpandIcon","ArrowExpandSvgIcon","SvgArrowKeyboardNext","ArrowKeyboardNextIcon","ArrowKeyboardNextSvgIcon","SvgArrowKeyboardPrevious","ArrowKeyboardPreviousIcon","ArrowKeyboardPreviousSvgIcon","SvgArrowKeyboardUp","ArrowKeyboardUpIcon","ArrowKeyboardUpSvgIcon","SvgArrowLeft","ArrowLeftIcon","ArrowLeftSvgIcon","SvgArrowRight","ArrowRightIcon","ArrowRightSvgIcon","SvgArrowUp","ArrowUpIcon","ArrowUpSvgIcon","SvgAxis","AxisIcon","AxisSvgIcon","SvgAxisLimt","AxisLimtIcon","AxisLimtSvgIcon","SvgBarChart","BarChartIcon","BarChartSvgIcon","SvgBoolean","BooleanIcon","BooleanSvgIcon","SvgBracketsCancel","BracketsCancelIcon","BracketsCancelSvgIcon","SvgBrackets","BracketsIcon","BracketsSvgIcon","SvgBrowser","BrowserIcon","BrowserSvgIcon","SvgBrowserPush","BrowserPushIcon","BrowserPushSvgIcon","SvgCalendarAlt","CalendarAltIcon","CalendarAltSvgIcon","SvgCalendar","CalendarIcon","CalendarSvgIcon","SvgCatalog","CatalogIcon","CatalogSvgIcon","SvgChatAdd","ChatAddIcon","ChatAddSvgIcon","SvgChat","ChatIcon","ChatSvgIcon","SvgChats","ChatsIcon","ChatsSvgIcon","SvgCheckCircle","CheckCircleIcon","CheckCircleSvgIcon","SvgCheckFilled","CheckFilledIcon","CheckFilledSvgIcon","SvgCheck","CheckIcon","CheckSvgIcon","SvgCheckSmall","CheckSmallIcon","CheckSmallSvgIcon","SvgChevronDownFill","ChevronDownFillIcon","ChevronDownFillSvgIcon","SvgChevronDown","ChevronDownIcon","ChevronDownSvgIcon","SvgChevronLeftFill","ChevronLeftFillIcon","ChevronLeftFillSvgIcon","SvgChevronLeft","ChevronLeftIcon","ChevronLeftSvgIcon","SvgChevronRightFill","ChevronRightFillIcon","ChevronRightFillSvgIcon","SvgChevronRight","ChevronRightIcon","ChevronRightSvgIcon","SvgChevronUpFill","ChevronUpFillIcon","ChevronUpFillSvgIcon","SvgChevronUp","ChevronUpIcon","ChevronUpSvgIcon","SvgClearFill","ClearFillIcon","ClearFillSvgIcon","SvgClear","ClearIcon","ClearSvgIcon","SvgClipboardAdd","ClipboardAddIcon","ClipboardAddSvgIcon","SvgClockCircle","ClockCircleIcon","ClockCircleSvgIcon","SvgClone","CloneIcon","CloneSvgIcon","SvgClose","CloseIcon","CloseSvgIcon","SvgCloseSmall","CloseSmallIcon","CloseSmallSvgIcon","SvgCloudCheck","CloudCheckIcon","CloudCheckSvgIcon","SvgCloudDownload","CloudDownloadIcon","CloudDownloadSvgIcon","SvgCode","CodeIcon","CodeSvgIcon","SvgColorPickerAlt","ColorPickerAltIcon","ColorPickerAltSvgIcon","SvgColorPicker","ColorPickerIcon","ColorPickerSvgIcon","SvgColumns","ColumnsIcon","ColumnsSvgIcon","SvgConditionAlt","ConditionAltIcon","ConditionAltSvgIcon","SvgCondition","ConditionIcon","ConditionSvgIcon","SvgConsole","ConsoleIcon","ConsoleSvgIcon","SvgConstantAlt","ConstantAltIcon","ConstantAltSvgIcon","SvgConstant","ConstantIcon","ConstantSvgIcon","SvgContextualPersonalization","ContextualPersonalizationIcon","ContextualPersonalizationSvgIcon","SvgCopy","CopyIcon","CopySvgIcon","SvgCopyToDashboard","CopyToDashboardIcon","CopyToDashboardSvgIcon","SvgCsv","CsvIcon","CsvSvgIcon","SvgCustomRow","CustomRowIcon","CustomRowSvgIcon","SvgCustomer","CustomerIcon","CustomerSvgIcon","SvgCustomersFilter","CustomersFilterIcon","CustomersFilterSvgIcon","SvgCustomersSegmentation","CustomersSegmentationIcon","CustomersSegmentationSvgIcon","SvgDateTime","DateTimeIcon","DateTimeSvgIcon","SvgDescription","DescriptionIcon","DescriptionSvgIcon","SvgDesktop","DesktopIcon","DesktopSvgIcon","SvgDisabled","DisabledIcon","DisabledSvgIcon","SvgDivide","DivideIcon","DivideSvgIcon","SvgDocumentation","DocumentationIcon","DocumentationSvgIcon","SvgDownload","DownloadIcon","DownloadSvgIcon","SvgDragHorizontal","DragHorizontalIcon","DragHorizontalSvgIcon","SvgDragVerical","DragVericalIcon","DragVericalSvgIcon","SvgEdit","EditIcon","EditSvgIcon","SvgEducationHub","EducationHubIcon","EducationHubSvgIcon","SvgEllipsisVertical","EllipsisVerticalIcon","EllipsisVerticalSvgIcon","SvgEllipsissHorizontal","EllipsissHorizontalIcon","EllipsissHorizontalSvgIcon","SvgEmail","EmailIcon","EmailSvgIcon","SvgEmojiPicker","EmojiPickerIcon","EmojiPickerSvgIcon","SvgErrorFill","ErrorFillIcon","ErrorFillSvgIcon","SvgEvent","EventIcon","EventSvgIcon","SvgEventsSegmentation","EventsSegmentationIcon","EventsSegmentationSvgIcon","SvgExperiment","ExperimentIcon","ExperimentSvgIcon","SvgExpose","ExposeIcon","ExposeSvgIcon","SvgExpression","ExpressionIcon","ExpressionSvgIcon","SvgExternalLink","ExternalLinkIcon","ExternalLinkSvgIcon","SvgEyeCrossed","EyeCrossedIcon","EyeCrossedSvgIcon","SvgEye","EyeIcon","EyeSvgIcon","SvgFastForward","FastForwardIcon","FastForwardSvgIcon","SvgFile","FileIcon","FileSvgIcon","SvgFilter","FilterIcon","FilterSvgIcon","SvgFire","FireIcon","FireSvgIcon","SvgFolderEmpty","FolderEmptyIcon","FolderEmptySvgIcon","SvgFolderFull","FolderFullIcon","FolderFullSvgIcon","SvgFormulaExpression","FormulaExpressionIcon","FormulaExpressionSvgIcon","SvgFormula","FormulaIcon","FormulaSvgIcon","SvgFromStartAlt","FromStartAltIcon","FromStartAltSvgIcon","SvgFullscreen","FullscreenIcon","FullscreenSvgIcon","SvgGift","GiftIcon","GiftSvgIcon","SvgGoTo","GoToIcon","GoToSvgIcon","SvgGraphStats","GraphStatsIcon","GraphStatsSvgIcon","SvgGridAlt","GridAltIcon","GridAltSvgIcon","SvgGrid","GridIcon","GridSvgIcon","SvgHelp","HelpIcon","HelpSvgIcon","SvgHistory","HistoryIcon","HistorySvgIcon","SvgHome","HomeIcon","HomeSvgIcon","SvgHtml","HtmlIcon","HtmlSvgIcon","SvgImages","ImagesIcon","ImagesSvgIcon","SvgInfoFilled","InfoFilledIcon","InfoFilledSvgIcon","SvgInfo","InfoIcon","InfoSvgIcon","SvgInfoSmall","InfoSmallIcon","InfoSmallSvgIcon","SvgInternet","InternetIcon","InternetSvgIcon","SvgKey","KeyIcon","KeySvgIcon","SvgLayout","LayoutIcon","LayoutSvgIcon","SvgLike","LikeIcon","LikeSvgIcon","SvgLineChart","LineChartIcon","LineChartSvgIcon","SvgLink","LinkIcon","LinkSvgIcon","SvgList","ListIcon","ListSvgIcon","SvgLoader","LoaderIcon","LoaderSvgIcon","SvgLock","LockIcon","LockSvgIcon","SvgMap","MapIcon","MapSvgIcon","SvgMetricAlt","MetricAltIcon","MetricAltSvgIcon","SvgMinus","MinusIcon","MinusSvgIcon","SvgMobileAppInbox","MobileAppInboxIcon","MobileAppInboxSvgIcon","SvgMobileImageMessage","MobileImageMessageIcon","MobileImageMessageSvgIcon","SvgMobilePhoneLandscape","MobilePhoneLandscapeIcon","MobilePhoneLandscapeSvgIcon","SvgMobilePhonePortrait","MobilePhonePortraitIcon","MobilePhonePortraitSvgIcon","SvgMobilePush","MobilePushIcon","MobilePushSvgIcon","SvgMobileSms","MobileSmsIcon","MobileSmsSvgIcon","SvgMobileTextMessage","MobileTextMessageIcon","MobileTextMessageSvgIcon","SvgMove","MoveIcon","MoveSvgIcon","SvgNegation","NegationIcon","NegationSvgIcon","SvgNotification","NotificationIcon","NotificationSvgIcon","SvgNumber","NumberIcon","NumberSvgIcon","SvgOfflineFill","OfflineFillIcon","OfflineFillSvgIcon","SvgOffline","OfflineIcon","OfflineSvgIcon","SvgPaint","PaintIcon","PaintSvgIcon","SvgParagraphCenterAlign","ParagraphCenterAlignIcon","ParagraphCenterAlignSvgIcon","SvgParagraphLeftAlign","ParagraphLeftAlignIcon","ParagraphLeftAlignSvgIcon","SvgParagraphRightAlign","ParagraphRightAlignIcon","ParagraphRightAlignSvgIcon","SvgPercentage","PercentageIcon","PercentageSvgIcon","SvgPersAlt1","PersAlt1Icon","PersAlt1SvgIcon","SvgPersAlt2","PersAlt2Icon","PersAlt2SvgIcon","SvgPersAlt3","PersAlt3Icon","PersAlt3SvgIcon","SvgPersAlt4","PersAlt4Icon","PersAlt4SvgIcon","SvgPictureAlt","PictureAltIcon","PictureAltSvgIcon","SvgPicture","PictureIcon","PictureSvgIcon","SvgPin","PinIcon","PinSvgIcon","SvgPlugplay","PlugPlayIcon","PlugPlaySvgIcon","SvgPlusCircleFill","PlusCircleFillIcon","PlusCircleFillSvgIcon","SvgPlusCircle","PlusCircleIcon","PlusCircleSvgIcon","SvgPlus","PlusIcon","PlusSvgIcon","SvgPoverButton","PoverButtonIcon","PoverButtonSvgIcon","SvgRefresh","RefreshIcon","RefreshSvgIcon","SvgReleaseNotes","ReleaseNotesIcon","ReleaseNotesSvgIcon","SvgRenameAlt","RenameAltIcon","RenameAltSvgIcon","SvgRename","RenameIcon","RenameSvgIcon","SvgReorder","ReorderIcon","ReorderSvgIcon","SvgReport","ReportIcon","ReportSvgIcon","SvgRetention","RetentionIcon","RetentionSvgIcon","SvgRewertLeft","RewertLeftIcon","RewertLeftSvgIcon","SvgRewertRight","RewertRightIcon","RewertRightSvgIcon","SvgRibbon","RibbonIcon","RibbonSvgIcon","SvgRoadmap","RoadmapIcon","RoadmapSvgIcon","SvgRobot","RobotIcon","RobotSvgIcon","SvgRunningAggregate","RunningAggregateIcon","RunningAggregateSvgIcon","SvgSave","SaveIcon","SaveSvgIcon","SvgScenario","ScenarioIcon","ScenarioSvgIcon","SvgSearch","SearchIcon","SearchSvgIcon","SvgSecurityShield","SecurityShieldIcon","SecurityShieldSvgIcon","SvgSend","SendIcon","SendSvgIcon","SvgSettingsAlt","SettingsAltIcon","SettingsAltSvgIcon","SvgSettings","SettingsIcon","SettingsSvgIcon","SvgShare","ShareIcon","ShareSvgIcon","SvgShop","ShopIcon","ShopSvgIcon","SvgShrink","ShrinkIcon","ShrinkSvgIcon","SvgSort","SortIcon","SortSvgIcon","SvgSplitFlow","SplitFlowIcon","SplitFlowSvgIcon","SvgSql","SqlIcon","SqlSvgIcon","SvgStarFill","StarFillIcon","StarFillSvgIcon","SvgStar","StarIcon","StarSvgIcon","SvgStartFill","StartFillIcon","StartFillSvgIcon","SvgStart","StartIcon","StartSvgIcon","SvgStatusDot","StatusDotIcon","StatusDotSvgIcon","SvgStop","StopIcon","StopSvgIcon","SvgStopwatch","StopwatchIcon","StopwatchSvgIcon","SvgStringComponent","StringComponentIcon","StringComponentSvgIcon","SvgString","StringIcon","StringSvgIcon","SvgSuggestion","SuggestionIcon","SuggestionSvgIcon","SvgSurvey","SurveyIcon","SurveySvgIcon","SvgSwap","SwapIcon","SwapSvgIcon","SvgTabletLangscape","TabletLangscapeIcon","TabletLangscapeSvgIcon","SvgTabletPortrait","TabletPortraitIcon","TabletPortraitSvgIcon","SvgTagAlt","TagAltIcon","TagAltSvgIcon","SvgTag","TagIcon","TagSvgIcon","SvgTemplate","TemplateIcon","TemplateSvgIcon","SvgTextBold","TextBoldIcon","TextBoldSvgIcon","SvgTextItalic","TextItalicIcon","TextItalicSvgIcon","SvgTextStyle","TextStyleIcon","TextStyleSvgIcon","SvgTraget","TragetIcon","TragetSvgIcon","SvgTransfer","TransferIcon","TransferSvgIcon","SvgTrash","TrashIcon","TrashSvgIcon","SvgTrend","TrendIcon","TrendSvgIcon","SvgUnExpose","UnExposeIcon","UnExposeSvgIcon","SvgUnarchiveAlt","UnarchiveAltIcon","UnarchiveAltSvgIcon","SvgUndo","UndoIcon","UndoSvgIcon","SvgUnlink","UnlinkIcon","UnlinkSvgIcon","SvgUnlock","UnlockIcon","UnlockSvgIcon","SvgUntilNowAlt","UntilNowAltIcon","UntilNowAltSvgIcon","SvgUpload","UploadIcon","UploadSvgIcon","SvgUsages","UsagesIcon","UsagesSvgIcon","SvgUsers","UsersIcon","UsersSvgIcon","SvgVisual","VisualIcon","VisualSvgIcon","SvgVoucher","VoucherIcon","VoucherSvgIcon","SvgWait","WaitIcon","WaitSvgIcon","SvgWalkthroughs","WalkthroughsIcon","WalkthroughsSvgIcon","SvgWarningFill","WarningFillIcon","WarningFillSvgIcon","SvgWebhook","WebhookIcon","WebhookSvgIcon","SvgWeblayer","WeblayerIcon","WeblayerSvgIcon","SvgWrench","WrenchIcon","WrenchSvgIcon","activeElement","_activeElement","contains","child","rootNode","next","getPlatform","uaData","getUserAgent","brand","version","isVirtualPointerEvent","isAndroid","isSafari","re","isMac","isMouseLikePointerType","pointerType","strict","getDocument","getTarget","TYPEABLE_SELECTOR","isTypeableElement","candidateSelectors","candidateSelector","NoElement","matches","getRootNode","_element$getRootNode","isInert","lookUp","_node$getAttribute","inertAtt","inert","isContentEditable","_node$getAttribute2","attValue","getCandidates","includeContainer","filter","candidates","getCandidatesIteratively","elementsToCheck","assigned","content","nestedCandidates","validCandidate","shadowRoot","validShadowRoot","_nestedCandidates","hasTabIndex","getSortOrderTabIndex","isScope","sortOrderedTabbables","isInput","isHiddenInput","isDetailsWithSummary","getCheckedRadio","nodes","form","isTabbableRadio","radioScope","queryRadios","radioSet","checked","isRadio","isNodeAttached","_nodeRoot","nodeRoot","nodeRootHost","attached","_nodeRootHost","_nodeRootHost$ownerDo","_nodeRoot2","_nodeRootHost2","_nodeRootHost2$ownerD","isZeroArea","_node$getBoundingClie","isHidden","displayCheck","getShadowRoot","isDirectSummary","nodeUnderDetails","originalNode","parentElement","isDisabledFromFieldset","isNodeMatchingSelectorTabbable","isValidShadowRootTabbable","shadowHostNode","sortByOrder","regularTabbables","orderedTabbables","candidateTabindex","sortable","useSafeInsertionEffect","useEffectEvent","_len","_key","serverHandoffComplete","count","genId","useFloatingId","id","setId","useId","FloatingArrow","tipRadius","strokeWidth","staticOffset","stroke","restStyle","clipPathId","halfStrokeWidth","svgX","svgY","isCustomShape","isVerticalSide","yOffsetProp","xOffsetProp","arrowX","arrowY","dValue","rotation","createPubSub","map","_map$get","handler","listener","_map$get2","FloatingNodeContext","FloatingTreeContext","useFloatingParentNodeId","_React$useContext","useFloatingTree","createAttribute","useRef","safePolygonIdentifier","getDelay","useHover","context","onOpenChange","events","domReference","enabled","delay","mouseOnly","restMs","move","tree","parentId","handleCloseRef","delayRef","pointerTypeRef","timeoutRef","handlerRef","restTimeoutRef","blockMouseMoveRef","performedPointerEventsMutationRef","unbindMouseMoveRef","isHoverOpen","_dataRef$current$open","onLeave","closeWithDelay","runElseBranch","reason","closeDelay","cleanupMouseMoveHandler","clearPointerEvents","isClickLikeOpenEvent","onMouseEnter","openDelay","onMouseLeave","onScrollMouseLeave","_handleCloseRef$curre","_tree$nodesRef$curren","parentFloating","setPointerRef","getTabbableOptions","getTabbableIn","allTabbable","activeIndex","getNextTabbable","getPreviousTabbable","isOutsideEvent","containerElement","relatedTarget","disableFocusInside","enableFocusInside","tabindex","HIDDEN_STYLES","setActiveElementOnTab","FocusGuard","role","setRole","restProps","PortalContext","useFloatingPortalNode","_temp","portalNode","setPortalNode","uniqueId","portalContext","usePortalContext","existingIdRoot","attr","subRoot","idWrapper","FloatingPortal","preserveTabOrder","focusManagerState","setFocusManagerState","beforeOutsideRef","afterOutsideRef","beforeInsideRef","afterInsideRef","shouldRenderGuards","_beforeInsideRef$curr","prevTabbable","createPortal","_afterInsideRef$curre","nextTabbable","devMessageSet","_options$elements2","unstable_onOpenChange","nodeId","_options$elements","_devMessageSet","_devMessageSet2","_domReference","setDomReference","position","useFloating$1","nested","domReferenceRef","floatingId","setPositionReference","positionReference","useFocus","visibleOnly","blockFocusRef","keyboardModalityRef","onKeyDown","movedToFocusGuard","activeEl","ACTIVE_KEY","SELECTED_KEY","mergeProps","userProps","propsList","elementKey","isItem","domUserProps","_","__","validProps","propsOrGetProps","useInteractions","deps","getReferenceProps","getFloatingProps","getItemProps","componentRoleToAriaRoleMap","useRole","_componentRoleToAriaR","ariaRole","referenceId","isNested","floatingProps","selected","commonProps","useDelayUnmount","durationMs","isMounted","setIsMounted","useTransitionStatus","duration","closeDuration","initiated","setInitiated","status","setStatus","frame","o","TOOLTIP_OPEN_DELAY","TOOLTIP_CLOSE_DELAY","BrTooltip","title","portalRoot","arrowRef","visible","setVisible","useState","hover","focus","useMemo","mergeRefs","containerRef","childWithProps","tooltipContent","cn","portalId","jsxs","getTypeBasedClasses","loading","hasIcons","BrButton","endIcon","htmlType","loadingText","onClick","startIcon","tooltip","handleOnClick","iconOnly","loaderClasses","getGroupClasses","getGroupButtonPositionClass","first","last","BrButtonGroup","childrenCount","Children","buttonDisabled","buttonClasses","BrToggleButtonInner","BrToggleButton","isValueSelected","candidate","BrToggleButtonGroupInner","multiple","buttonValue","handleMultipleChange","newValue","childrenWithProps","BrToggleButtonGroup","defaultIconMapping","ErrorIcon","SuccessIcon","WarningIcon","BrAlert","actions","icon","classnames","BrMessageTitle","ModalContext","createContext","useModalContext","useContext","Backdrop","BrModal","handleOnClose","BrModalCloseButton","modalCtx","BrModalHeader","BrModalHeaderTitle","BrModalBody","BrModalFooter","BrModalFooterActions","getZeroSpace","BrBaseField","control","controlId","fullWidth","helperText","label","metadata","hovered","setHovered","handleMouseEnter","useCallback","handleMouseLeave","useForkRefs","BrBaseInput","autoSize","clearable","inInputProps","leftElement","multiline","onCountChange","readOnly","rightElement","uncontrolled","forkRef","internalValue","setInternalValue","inputValue","handleOnChange","hoverHandlers","getInputProps","handleReset","getClearButton","hideClear","inputContainerClasses","inputProps","generateFieldId","fieldName","BrInputField","placeholder","baseInputProps","BrTextField","counter","maxCount","resizable","textareaProps","setCount","PaginationContext","usePaginationContext","DEFAULT_ITEMS_PER_PAGE_OPTIONS","PAGINATION_PAGES_LIMIT","PAGINATION_PAGES_BUFFER","NOOP","str","cloneClientRect","box","right","bottom","modalRootId","ensureModalRoot","customId","modalRoot","isString","isNumber","getFirstWithClass","hasChild","canUseDOM","ExecutionEnvironment","useHasFeature","isEventSupported","eventNameSuffix","capture","eventName","isSupported","_populated","_ie","_firefox","_opera","_webkit","_chrome","_ie_real_version","_osx","_windows","_linux","_android","_win64","_iphone","_ipad","_native","_mobile","_populate","uas","agent","os","trident","ver","UserAgent_DEPRECATED","PIXEL_STEP","LINE_HEIGHT","PAGE_HEIGHT","normalizeWheel","sX","sY","pX","pY","controlHover","component","over","out","controlFocus","stopPropagation","anyEvent","_a","_b","_d","_c","_f","_e","_h","_g","isFunction","when","condition","otherwise","TooltipModalID","DropdownModalID","dismissDropdownQueue","Dropdown","__publicField","toRemove","customModalRootId","customModalRoot","dropdownWidth","bounds","topItem","containerProps","computedHeight","coverBounds","manualWidth","maxWidth","dropUp","dropLeft","dropRight","dropCenter","showWithNoBounds","shiftToMiddle","inline","totalHeight","checkWidth","isDown","isUp","isRight","isLeft","shiftLeft","dropdownHeight","topValue","leftValue","layout","adjust","minVal","maxVal","easeInOutCubic","time","ScrollRegionMode","ScrollRegion","contentBounds","metrics","wrapper","startValue","scrollTo","doAnimate","touch","iMax","current","animateInertia","isOpen","wheel","newLeft","newTop","appliedLeft","appliedTop","pixelScroll","startPos","pointerId","mousemove","moveEvent","mouseup","newPos","deltaPos","prevProps","onScroll","autoScrollDuration","scrollHeight","newBounds","newContentBounds","checkContainer","checkContent","scrollToOnce","forceBounds","forceContentBounds","barSizes","barRatio","barSpace","scrollSpace","isDragging","regionWidth","contentClassName","contentProps","alwaysShowScroll","mode","barTop","barStyle","ScrollViewMode","ScrollView","horizontal","startY","newY","deltaY","scrollTopOnce","barHeight","scrollBar","ListView","total","scrollTop","maxScroll","viewBounds","rowSize","onRange","startIndex","endIndex","check","checkIndex","stateStartIndex","stateEndIndex","nextProps","rowGap","rows","gap","rowDelta","rowIndex","nextRowIndex","rowRef","rowBox","rowTop","nextRowTop","rowDisplayCount","added","nextSize","renderMethod","getTop","row","allowTouchInertia","useScrollRegion","emptyLabel","LoaderSize","Loader","SelectionMode","Selection","dropdownBounds","dropdownPadding","onOpen","option","onSearch","searchTerm","_start","_end","_total","isEnd","hasMore","onLoadMore","stateDropdownBounds","_prevProps","hasSearch","controlledValue","displayValue","searchValue","decal","decalUp","onArrowClick","valueLabelProps","valueLabel","lbl","customDropdown","isLoading","optionList","selectProps","opt","BrPaginationItemsPerPageSelector","paginationCtx","itemsPerPage","itemsPerPageOptions","onItemsPerPageChange","SEPARATOR","range","getNavItems","currentPageIndex","totalPages","navItems","lastPageIndex","BrPaginationNavigationItem","page","onPageChange","isPage","getAriaLabel","BrPaginationNavigation","onNext","onPrev","BrPaginationSummary","BrPagination"],"mappings":"y2BAAe,SAASA,GAAW,CACjCA,OAAAA,EAAW,OAAO,OAAS,OAAO,OAAO,KAAI,EAAK,SAAUC,EAAQ,CAClE,QAASC,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CACzC,IAAIC,EAAS,UAAUD,CAAC,EACxB,QAASE,KAAOD,EACV,OAAO,UAAU,eAAe,KAAKA,EAAQC,CAAG,IAClDH,EAAOG,CAAG,EAAID,EAAOC,CAAG,EAG7B,CACD,OAAOH,CACX,EACSD,EAAS,MAAM,KAAM,SAAS,CACvC,CCVO,SAASK,GAAgBC,EAAS,CACvC,OAAO,OAAOA,GAAY,QAC5B,CCWO,SAASC,GAAiBC,EAAaC,EAAYC,EAAY,CACpE,OAAIF,IAAgB,QAAaH,GAAgBG,CAAW,EACnDC,EAEFT,EAAS,CAAE,EAAES,EAAY,CAC9B,WAAYT,EAAS,CAAA,EAAIS,EAAW,WAAYC,CAAU,CAC9D,CAAG,CACH,CCnBA,MAAMC,GAAsB,CAC1B,sBAAuB,EACzB,EACMC,GAA4CC,EAAM,cAAcF,EAAmB,EASlF,SAASG,GAAsBC,EAAsB,CAC1D,KAAM,CACJ,sBAAAC,CACJ,EAAMH,EAAM,WAAWD,EAA4B,EACjD,OAAOK,GACDD,EACK,GAEFD,EAAqBE,CAAI,CAEpC,CCnBO,SAASC,GAAqBC,EAAQC,EAAc,GAAI,CAC7D,GAAID,IAAW,OACb,MAAO,GAET,MAAME,EAAS,CAAA,EACf,cAAO,KAAKF,CAAM,EAAE,OAAOG,GAAQA,EAAK,MAAM,UAAU,GAAK,OAAOH,EAAOG,CAAI,GAAM,YAAc,CAACF,EAAY,SAASE,CAAI,CAAC,EAAE,QAAQA,GAAQ,CAC9ID,EAAOC,CAAI,EAAIH,EAAOG,CAAI,CAC9B,CAAG,EACMD,CACT,CCZO,SAASE,GAAsBC,EAAgBd,EAAYe,EAAW,CAC3E,OAAI,OAAOD,GAAmB,WACrBA,EAAed,EAAYe,CAAS,EAEtCD,CACT,CCTe,SAASE,GAA8BvB,EAAQwB,EAAU,CACtE,GAAIxB,GAAU,KAAM,MAAO,GAC3B,IAAIF,EAAS,CAAA,EACT2B,EAAa,OAAO,KAAKzB,CAAM,EAC/BC,EAAK,EACT,IAAK,EAAI,EAAG,EAAIwB,EAAW,OAAQ,IACjCxB,EAAMwB,EAAW,CAAC,EACd,EAAAD,EAAS,QAAQvB,CAAG,GAAK,KAC7BH,EAAOG,CAAG,EAAID,EAAOC,CAAG,GAE1B,OAAOH,CACT,CCXe,SAAS4B,GAAeC,EAAWC,EAAW,CAC3D,OAAI,QAAQ,IAAI,WAAa,aACpB,IAAM,KAER,YAAqBC,EAAM,CAChC,OAAOF,EAAU,GAAGE,CAAI,GAAKD,EAAU,GAAGC,CAAI,CAClD,CACA;;;;;;;6CCEa,IAAIC,EAAe,OAAO,QAApB,YAA4B,OAAO,IAAIC,EAAED,EAAE,OAAO,IAAI,eAAe,EAAE,MAAME,EAAEF,EAAE,OAAO,IAAI,cAAc,EAAE,MAAMG,EAAEH,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAMI,EAAEJ,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAMK,EAAEL,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAMM,EAAEN,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAMO,EAAEP,EAAE,OAAO,IAAI,eAAe,EAAE,MAAMQ,EAAER,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAMS,EAAET,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAMU,EAAEV,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAMW,EAAEX,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAMY,EAAEZ,EACpf,OAAO,IAAI,qBAAqB,EAAE,MAAMa,EAAEb,EAAE,OAAO,IAAI,YAAY,EAAE,MAAMc,EAAEd,EAAE,OAAO,IAAI,YAAY,EAAE,MAAMe,EAAEf,EAAE,OAAO,IAAI,aAAa,EAAE,MAAMgB,EAAEhB,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAMiB,EAAEjB,EAAE,OAAO,IAAI,iBAAiB,EAAE,MAAMkB,EAAElB,EAAE,OAAO,IAAI,aAAa,EAAE,MAClQ,SAASmB,EAAEC,EAAE,CAAC,GAAc,OAAOA,GAAlB,UAA4BA,IAAP,KAAS,CAAC,IAAIC,EAAED,EAAE,SAAS,OAAOC,EAAG,CAAA,KAAKpB,EAAE,OAAOmB,EAAEA,EAAE,KAAKA,EAAG,CAAA,KAAKZ,EAAE,KAAKC,EAAE,KAAKN,EAAE,KAAKE,EAAE,KAAKD,EAAE,KAAKO,EAAE,OAAOS,EAAE,QAAQ,OAAOA,EAAEA,GAAGA,EAAE,SAASA,EAAG,CAAA,KAAKb,EAAE,KAAKG,EAAE,KAAKI,EAAE,KAAKD,EAAE,KAAKP,EAAE,OAAOc,EAAE,QAAQ,OAAOC,CAAC,CAAC,CAAC,KAAKnB,EAAE,OAAOmB,CAAC,CAAC,CAAC,CAAC,SAASC,EAAEF,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIX,CAAC,CAAC,OAAAc,GAAA,UAAkBf,EAAEe,GAAsB,eAACd,EAAEc,mBAAwBhB,EAAEgB,GAAA,gBAAwBjB,EAAEiB,GAAe,QAACtB,EAAEsB,GAAA,WAAmBb,EAAEa,GAAgB,SAACpB,EAAEoB,QAAaT,EAAES,GAAA,KAAaV,EAAEU,GAAc,OAACrB,EAChfqB,GAAA,SAAiBlB,EAAEkB,GAAA,WAAmBnB,EAAEmB,GAAA,SAAiBZ,EAAEY,GAAA,YAAoB,SAASH,EAAE,CAAC,OAAOE,EAAEF,CAAC,GAAGD,EAAEC,CAAC,IAAIZ,CAAC,EAAEe,GAAA,iBAAyBD,EAAEC,GAAA,kBAA0B,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIb,CAAC,EAAEgB,GAAA,kBAA0B,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAId,CAAC,EAAEiB,GAAA,UAAkB,SAASH,EAAE,CAAC,OAAiB,OAAOA,GAAlB,UAA4BA,IAAP,MAAUA,EAAE,WAAWnB,CAAC,EAAEsB,GAAA,aAAqB,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIV,CAAC,EAAEa,GAAA,WAAmB,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIjB,CAAC,EAAEoB,GAAA,OAAe,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIN,CAAC,EAC1dS,GAAA,OAAe,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIP,CAAC,EAAEU,YAAiB,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIlB,CAAC,EAAEqB,GAAkB,WAAC,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIf,CAAC,EAAEkB,GAAA,aAAqB,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIhB,CAAC,EAAEmB,GAAA,WAAmB,SAASH,EAAE,CAAC,OAAOD,EAAEC,CAAC,IAAIT,CAAC,EAChNY,GAAA,mBAAC,SAASH,EAAE,CAAC,OAAiB,OAAOA,GAAlB,UAAkC,OAAOA,GAApB,YAAuBA,IAAIjB,GAAGiB,IAAIX,GAAGW,IAAIf,GAAGe,IAAIhB,GAAGgB,IAAIT,GAAGS,IAAIR,GAAc,OAAOQ,GAAlB,UAA4BA,IAAP,OAAWA,EAAE,WAAWN,GAAGM,EAAE,WAAWP,GAAGO,EAAE,WAAWd,GAAGc,EAAE,WAAWb,GAAGa,EAAE,WAAWV,GAAGU,EAAE,WAAWJ,GAAGI,EAAE,WAAWH,GAAGG,EAAE,WAAWF,GAAGE,EAAE,WAAWL,EAAE,EAAEQ,GAAc,OAACJ;;;;;;;yCCD/T,QAAQ,IAAI,WAAa,cAC1B,UAAW,CAKd,IAAIK,EAAY,OAAO,QAAW,YAAc,OAAO,IACnDC,EAAqBD,EAAY,OAAO,IAAI,eAAe,EAAI,MAC/DE,EAAoBF,EAAY,OAAO,IAAI,cAAc,EAAI,MAC7DG,EAAsBH,EAAY,OAAO,IAAI,gBAAgB,EAAI,MACjEI,EAAyBJ,EAAY,OAAO,IAAI,mBAAmB,EAAI,MACvEK,EAAsBL,EAAY,OAAO,IAAI,gBAAgB,EAAI,MACjEM,EAAsBN,EAAY,OAAO,IAAI,gBAAgB,EAAI,MACjEO,EAAqBP,EAAY,OAAO,IAAI,eAAe,EAAI,MAG/DQ,EAAwBR,EAAY,OAAO,IAAI,kBAAkB,EAAI,MACrES,EAA6BT,EAAY,OAAO,IAAI,uBAAuB,EAAI,MAC/EU,EAAyBV,EAAY,OAAO,IAAI,mBAAmB,EAAI,MACvEW,EAAsBX,EAAY,OAAO,IAAI,gBAAgB,EAAI,MACjEY,EAA2BZ,EAAY,OAAO,IAAI,qBAAqB,EAAI,MAC3Ea,EAAkBb,EAAY,OAAO,IAAI,YAAY,EAAI,MACzDc,EAAkBd,EAAY,OAAO,IAAI,YAAY,EAAI,MACzDe,EAAmBf,EAAY,OAAO,IAAI,aAAa,EAAI,MAC3DgB,EAAyBhB,EAAY,OAAO,IAAI,mBAAmB,EAAI,MACvEiB,EAAuBjB,EAAY,OAAO,IAAI,iBAAiB,EAAI,MACnEkB,EAAmBlB,EAAY,OAAO,IAAI,aAAa,EAAI,MAE/D,SAASmB,EAAmBC,EAAM,CAChC,OAAO,OAAOA,GAAS,UAAY,OAAOA,GAAS,YACnDA,IAASjB,GAAuBiB,IAASX,GAA8BW,IAASf,GAAuBe,IAAShB,GAA0BgB,IAAST,GAAuBS,IAASR,GAA4B,OAAOQ,GAAS,UAAYA,IAAS,OAASA,EAAK,WAAaN,GAAmBM,EAAK,WAAaP,GAAmBO,EAAK,WAAad,GAAuBc,EAAK,WAAab,GAAsBa,EAAK,WAAaV,GAA0BU,EAAK,WAAaJ,GAA0BI,EAAK,WAAaH,GAAwBG,EAAK,WAAaF,GAAoBE,EAAK,WAAaL,EACnlB,CAED,SAASM,EAAO3D,EAAQ,CACtB,GAAI,OAAOA,GAAW,UAAYA,IAAW,KAAM,CACjD,IAAI4D,GAAW5D,EAAO,SAEtB,OAAQ4D,GAAQ,CACd,KAAKrB,EACH,IAAImB,GAAO1D,EAAO,KAElB,OAAQ0D,GAAI,CACV,KAAKZ,EACL,KAAKC,EACL,KAAKN,EACL,KAAKE,EACL,KAAKD,EACL,KAAKO,EACH,OAAOS,GAET,QACE,IAAIG,GAAeH,IAAQA,GAAK,SAEhC,OAAQG,GAAY,CAClB,KAAKhB,EACL,KAAKG,EACL,KAAKI,EACL,KAAKD,EACL,KAAKP,EACH,OAAOiB,GAET,QACE,OAAOD,EACV,CAEJ,CAEH,KAAKpB,EACH,OAAOoB,EACV,CACF,CAGF,CAED,IAAIE,EAAYhB,EACZiB,EAAiBhB,EACjBiB,EAAkBnB,EAClBoB,EAAkBrB,EAClBsB,EAAU3B,EACV4B,EAAanB,EACboB,EAAW3B,EACX4B,EAAOjB,EACPkB,EAAOnB,EACPoB,EAAS/B,EACTgC,EAAW7B,EACX8B,EAAa/B,EACbgC,EAAWzB,EACX0B,EAAsC,GAE1C,SAASC,GAAY5E,EAAQ,CAEzB,OAAK2E,IACHA,EAAsC,GAEtC,QAAQ,KAAQ,+KAAyL,GAItME,EAAiB7E,CAAM,GAAK2D,EAAO3D,CAAM,IAAM8C,CACvD,CACD,SAAS+B,EAAiB7E,EAAQ,CAChC,OAAO2D,EAAO3D,CAAM,IAAM+C,CAC3B,CACD,SAAS+B,EAAkB9E,EAAQ,CACjC,OAAO2D,EAAO3D,CAAM,IAAM6C,CAC3B,CACD,SAASkC,EAAkB/E,EAAQ,CACjC,OAAO2D,EAAO3D,CAAM,IAAM4C,CAC3B,CACD,SAASoC,EAAUhF,EAAQ,CACzB,OAAO,OAAOA,GAAW,UAAYA,IAAW,MAAQA,EAAO,WAAauC,CAC7E,CACD,SAAS0C,EAAajF,EAAQ,CAC5B,OAAO2D,EAAO3D,CAAM,IAAMgD,CAC3B,CACD,SAASkC,EAAWlF,EAAQ,CAC1B,OAAO2D,EAAO3D,CAAM,IAAMyC,CAC3B,CACD,SAAS0C,EAAOnF,EAAQ,CACtB,OAAO2D,EAAO3D,CAAM,IAAMoD,CAC3B,CACD,SAASgC,EAAOpF,EAAQ,CACtB,OAAO2D,EAAO3D,CAAM,IAAMmD,CAC3B,CACD,SAASkC,EAASrF,EAAQ,CACxB,OAAO2D,EAAO3D,CAAM,IAAMwC,CAC3B,CACD,SAAS8C,GAAWtF,EAAQ,CAC1B,OAAO2D,EAAO3D,CAAM,IAAM2C,CAC3B,CACD,SAAS4C,GAAavF,EAAQ,CAC5B,OAAO2D,EAAO3D,CAAM,IAAM0C,CAC3B,CACD,SAAS8C,GAAWxF,EAAQ,CAC1B,OAAO2D,EAAO3D,CAAM,IAAMiD,CAC3B,CAEgBwC,GAAA,UAAG3B,EACE2B,GAAA,eAAG1B,EACF0B,GAAA,gBAAGzB,EACHyB,GAAA,gBAAGxB,EACXwB,GAAA,QAAGvB,EACAuB,GAAA,WAAGtB,EACLsB,GAAA,SAAGrB,EACPqB,GAAA,KAAGpB,EACHoB,GAAA,KAAGnB,EACDmB,GAAA,OAAGlB,EACDkB,GAAA,SAAGjB,EACDiB,GAAA,WAAGhB,EACLgB,GAAA,SAAGf,EACAe,GAAA,YAAGb,GACEa,GAAA,iBAAGZ,EACFY,GAAA,kBAAGX,EACHW,GAAA,kBAAGV,EACXU,GAAA,UAAGT,EACAS,GAAA,aAAGR,EACLQ,GAAA,WAAGP,EACPO,GAAA,OAAGN,EACHM,GAAA,OAAGL,EACDK,GAAA,SAAGJ,EACDI,GAAA,WAAGH,GACDG,GAAA,aAAGF,GACLE,GAAA,WAAGD,GACKC,GAAA,mBAAGhC,EACfgC,GAAA,OAAG9B,CACjB,8CCjLI,QAAQ,IAAI,WAAa,aAC3B+B,GAAA,QAAiBC,KAEjBD,GAAA,QAAiBE;;;;+CCGnB,IAAIC,EAAwB,OAAO,sBAC/BC,EAAiB,OAAO,UAAU,eAClCC,EAAmB,OAAO,UAAU,qBAExC,SAASC,EAASC,EAAK,CACtB,GAAIA,GAAQ,KACX,MAAM,IAAI,UAAU,uDAAuD,EAG5E,OAAO,OAAOA,CAAG,CACjB,CAED,SAASC,GAAkB,CAC1B,GAAI,CACH,GAAI,CAAC,OAAO,OACX,MAAO,GAMR,IAAIC,EAAQ,IAAI,OAAO,KAAK,EAE5B,GADAA,EAAM,CAAC,EAAI,KACP,OAAO,oBAAoBA,CAAK,EAAE,CAAC,IAAM,IAC5C,MAAO,GAKR,QADIC,EAAQ,CAAA,EACHrH,EAAI,EAAGA,EAAI,GAAIA,IACvBqH,EAAM,IAAM,OAAO,aAAarH,CAAC,CAAC,EAAIA,EAEvC,IAAIsH,EAAS,OAAO,oBAAoBD,CAAK,EAAE,IAAI,SAAU5E,EAAG,CAC/D,OAAO4E,EAAM5E,CAAC,CACjB,CAAG,EACD,GAAI6E,EAAO,KAAK,EAAE,IAAM,aACvB,MAAO,GAIR,IAAIC,EAAQ,CAAA,EAIZ,MAHA,uBAAuB,MAAM,EAAE,EAAE,QAAQ,SAAUC,EAAQ,CAC1DD,EAAMC,CAAM,EAAIA,CACnB,CAAG,EACG,OAAO,KAAK,OAAO,OAAO,CAAE,EAAED,CAAK,CAAC,EAAE,KAAK,EAAE,IAC/C,sBAKF,MAAa,CAEb,MAAO,EACP,CACD,CAED,OAAAE,GAAiBN,EAAe,EAAK,OAAO,OAAS,SAAUpH,EAAQE,EAAQ,CAK9E,QAJIyH,EACAC,EAAKV,EAASlH,CAAM,EACpB6H,EAEKC,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAC1CH,EAAO,OAAO,UAAUG,CAAC,CAAC,EAE1B,QAAS3H,KAAOwH,EACXX,EAAe,KAAKW,EAAMxH,CAAG,IAChCyH,EAAGzH,CAAG,EAAIwH,EAAKxH,CAAG,GAIpB,GAAI4G,EAAuB,CAC1Bc,EAAUd,EAAsBY,CAAI,EACpC,QAAS1H,EAAI,EAAGA,EAAI4H,EAAQ,OAAQ5H,IAC/BgH,EAAiB,KAAKU,EAAME,EAAQ5H,CAAC,CAAC,IACzC2H,EAAGC,EAAQ5H,CAAC,CAAC,EAAI0H,EAAKE,EAAQ5H,CAAC,CAAC,EAGlC,CACD,CAED,OAAO2H,mDC/ER,IAAIG,EAAuB,+CAE3B,OAAAC,GAAiBD,8CCXjBE,GAAiB,SAAS,KAAK,KAAK,OAAO,UAAU,cAAc,mDCSnE,IAAIC,EAAe,UAAW,GAE9B,GAAI,QAAQ,IAAI,WAAa,aAAc,CACzC,IAAIH,EAAuBlB,KACvBsB,EAAqB,CAAA,EACrBF,EAAMnB,KAEVoB,EAAe,SAASE,EAAM,CAC5B,IAAIC,EAAU,YAAcD,EACxB,OAAO,QAAY,KACrB,QAAQ,MAAMC,CAAO,EAEvB,GAAI,CAIF,MAAM,IAAI,MAAMA,CAAO,CAC7B,MAAgB,CAAQ,CACxB,CACC,CAaD,SAASC,EAAeC,EAAWC,EAAQC,EAAUC,EAAeC,EAAU,CAC5E,GAAI,QAAQ,IAAI,WAAa,cAC3B,QAASC,KAAgBL,EACvB,GAAIN,EAAIM,EAAWK,CAAY,EAAG,CAChC,IAAIC,EAIJ,GAAI,CAGF,GAAI,OAAON,EAAUK,CAAY,GAAM,WAAY,CACjD,IAAIE,EAAM,OACPJ,GAAiB,eAAiB,KAAOD,EAAW,UAAYG,EAAe,6FACC,OAAOL,EAAUK,CAAY,EAAI,iGAEhI,EACY,MAAAE,EAAI,KAAO,sBACLA,CACP,CACDD,EAAQN,EAAUK,CAAY,EAAEJ,EAAQI,EAAcF,EAAeD,EAAU,KAAMV,CAAoB,CAC1G,OAAQgB,EAAI,CACXF,EAAQE,CACT,CAWD,GAVIF,GAAS,EAAEA,aAAiB,QAC9BX,GACGQ,GAAiB,eAAiB,2BACnCD,EAAW,KAAOG,EAAe,2FAC6B,OAAOC,EAAQ,gKAIzF,EAEYA,aAAiB,OAAS,EAAEA,EAAM,WAAWV,GAAqB,CAGpEA,EAAmBU,EAAM,OAAO,EAAI,GAEpC,IAAIG,EAAQL,EAAWA,EAAQ,EAAK,GAEpCT,EACE,UAAYO,EAAW,UAAYI,EAAM,SAAWG,GAAwB,GACxF,CACS,CACF,EAGN,CAOD,OAAAV,EAAe,kBAAoB,UAAW,CACxC,QAAQ,IAAI,WAAa,eAC3BH,EAAqB,CAAA,EAExB,EAEDc,GAAiBX,kDC7FjB,IAAIY,EAAUrC,KACVsC,EAASrC,KAETiB,EAAuBqB,KACvBnB,EAAMoB,KACNf,EAAiBgB,KAEjBpB,EAAe,UAAW,GAE1B,QAAQ,IAAI,WAAa,eAC3BA,EAAe,SAASE,EAAM,CAC5B,IAAIC,EAAU,YAAcD,EACxB,OAAO,QAAY,KACrB,QAAQ,MAAMC,CAAO,EAEvB,GAAI,CAIF,MAAM,IAAI,MAAMA,CAAO,CAC7B,MAAgB,CAAE,CAClB,GAGA,SAASkB,GAA+B,CACtC,OAAO,IACR,CAED,OAAAC,GAAiB,SAASC,EAAgBC,EAAqB,CAE7D,IAAIC,EAAkB,OAAO,QAAW,YAAc,OAAO,SACzDC,EAAuB,aAgB3B,SAASC,EAAcC,EAAe,CACpC,IAAIC,EAAaD,IAAkBH,GAAmBG,EAAcH,CAAe,GAAKG,EAAcF,CAAoB,GAC1H,GAAI,OAAOG,GAAe,WACxB,OAAOA,CAEV,CAiDD,IAAIC,EAAY,gBAIZC,EAAiB,CACnB,MAAOC,EAA2B,OAAO,EACzC,OAAQA,EAA2B,QAAQ,EAC3C,KAAMA,EAA2B,SAAS,EAC1C,KAAMA,EAA2B,UAAU,EAC3C,OAAQA,EAA2B,QAAQ,EAC3C,OAAQA,EAA2B,QAAQ,EAC3C,OAAQA,EAA2B,QAAQ,EAC3C,OAAQA,EAA2B,QAAQ,EAE3C,IAAKC,EAAsB,EAC3B,QAASC,EACT,QAASC,EAA0B,EACnC,YAAaC,EAA8B,EAC3C,WAAYC,EACZ,KAAMC,EAAmB,EACzB,SAAUC,EACV,MAAOC,EACP,UAAWC,EACX,MAAOC,EACP,MAAOC,CACX,EAOE,SAASC,EAAG7H,EAAGC,EAAG,CAEhB,OAAID,IAAMC,EAGDD,IAAM,GAAK,EAAIA,IAAM,EAAIC,EAGzBD,IAAMA,GAAKC,IAAMA,CAE3B,CAUD,SAAS6H,EAAc1C,EAAS2C,EAAM,CACpC,KAAK,QAAU3C,EACf,KAAK,KAAO2C,GAAQ,OAAOA,GAAS,SAAWA,EAAM,GACrD,KAAK,MAAQ,EACd,CAEDD,EAAc,UAAY,MAAM,UAEhC,SAASE,EAA2BC,EAAU,CAC5C,GAAI,QAAQ,IAAI,WAAa,aAC3B,IAAIC,EAA0B,CAAA,EAC1BC,EAA6B,EAEnC,SAASC,EAAUC,EAAYC,EAAOC,EAAU9C,EAAeD,GAAUgD,GAAcC,GAAQ,CAI7F,GAHAhD,EAAgBA,GAAiBsB,EACjCyB,GAAeA,IAAgBD,EAE3BE,KAAW3D,GACb,GAAI2B,EAAqB,CAEvB,IAAIZ,EAAM,IAAI,MACZ,mLAGZ,EACU,MAAAA,EAAI,KAAO,sBACLA,CAChB,SAAmB,QAAQ,IAAI,WAAa,cAAgB,OAAO,QAAY,IAAa,CAElF,IAAI6C,GAAWjD,EAAgB,IAAM8C,EAEnC,CAACL,EAAwBQ,EAAQ,GAEjCP,EAA6B,IAE7BlD,EACE,2EACuBuD,GAAe,cAAgB/C,EAAgB,sNAIpF,EACYyC,EAAwBQ,EAAQ,EAAI,GACpCP,IAEH,EAEH,OAAIG,EAAMC,CAAQ,GAAK,KACjBF,EACEC,EAAMC,CAAQ,IAAM,KACf,IAAIT,EAAc,OAAStC,GAAW,KAAOgD,GAAe,4BAA8B,OAAS/C,EAAgB,8BAA8B,EAEnJ,IAAIqC,EAAc,OAAStC,GAAW,KAAOgD,GAAe,+BAAiC,IAAM/C,EAAgB,mCAAmC,EAExJ,KAEAwC,EAASK,EAAOC,EAAU9C,EAAeD,GAAUgD,EAAY,CAEzE,CAED,IAAIG,EAAmBP,EAAU,KAAK,KAAM,EAAK,EACjD,OAAAO,EAAiB,WAAaP,EAAU,KAAK,KAAM,EAAI,EAEhDO,CACR,CAED,SAAS1B,EAA2B2B,EAAc,CAChD,SAASX,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAcC,EAAQ,CAChF,IAAII,EAAYP,EAAMC,CAAQ,EAC1BO,GAAWC,EAAYF,CAAS,EACpC,GAAIC,KAAaF,EAAc,CAI7B,IAAII,GAAcC,EAAeJ,CAAS,EAE1C,OAAO,IAAIf,EACT,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMQ,GAAc,kBAAoBvD,EAAgB,iBAAmB,IAAMmD,EAAe,MAC9J,CAAC,aAAcA,CAAY,CACrC,CACO,CACD,OAAO,IACR,CACD,OAAOZ,EAA2BC,CAAQ,CAC3C,CAED,SAASf,GAAuB,CAC9B,OAAOc,EAA2B1B,CAA4B,CAC/D,CAED,SAASa,EAAyB+B,EAAa,CAC7C,SAASjB,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,GAAI,OAAOU,GAAgB,WACzB,OAAO,IAAIpB,EAAc,aAAeU,EAAe,mBAAqB/C,EAAgB,iDAAiD,EAE/I,IAAIoD,EAAYP,EAAMC,CAAQ,EAC9B,GAAI,CAAC,MAAM,QAAQM,CAAS,EAAG,CAC7B,IAAIC,EAAWC,EAAYF,CAAS,EACpC,OAAO,IAAIf,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMM,EAAW,kBAAoBrD,EAAgB,wBAAwB,CACrK,CACD,QAASzI,GAAI,EAAGA,GAAI6L,EAAU,OAAQ7L,KAAK,CACzC,IAAI4I,GAAQsD,EAAYL,EAAW7L,GAAGyI,EAAeD,EAAUgD,EAAe,IAAMxL,GAAI,IAAK8H,CAAoB,EACjH,GAAIc,cAAiB,MACnB,OAAOA,EAEV,CACD,OAAO,IACR,CACD,OAAOoC,EAA2BC,CAAQ,CAC3C,CAED,SAASb,GAA2B,CAClC,SAASa,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,IAAIK,EAAYP,EAAMC,CAAQ,EAC9B,GAAI,CAAC/B,EAAeqC,CAAS,EAAG,CAC9B,IAAIC,EAAWC,EAAYF,CAAS,EACpC,OAAO,IAAIf,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMM,EAAW,kBAAoBrD,EAAgB,qCAAqC,CAClL,CACD,OAAO,IACR,CACD,OAAOuC,EAA2BC,CAAQ,CAC3C,CAED,SAASZ,GAA+B,CACtC,SAASY,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,IAAIK,EAAYP,EAAMC,CAAQ,EAC9B,GAAI,CAACtC,EAAQ,mBAAmB4C,CAAS,EAAG,CAC1C,IAAIC,EAAWC,EAAYF,CAAS,EACpC,OAAO,IAAIf,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMM,EAAW,kBAAoBrD,EAAgB,0CAA0C,CACvL,CACD,OAAO,IACR,CACD,OAAOuC,EAA2BC,CAAQ,CAC3C,CAED,SAASX,EAA0B6B,EAAe,CAChD,SAASlB,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,GAAI,EAAEF,EAAMC,CAAQ,YAAaY,GAAgB,CAC/C,IAAIC,EAAoBD,EAAc,MAAQpC,EAC1CsC,EAAkBC,GAAahB,EAAMC,CAAQ,CAAC,EAClD,OAAO,IAAIT,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMa,EAAkB,kBAAoB5D,EAAgB,iBAAmB,gBAAkB2D,EAAoB,KAAK,CAClN,CACD,OAAO,IACR,CACD,OAAOpB,EAA2BC,CAAQ,CAC3C,CAED,SAASR,EAAsB8B,EAAgB,CAC7C,GAAI,CAAC,MAAM,QAAQA,CAAc,EAC/B,OAAI,QAAQ,IAAI,WAAa,eACvB,UAAU,OAAS,EACrBtE,EACE,+DAAiE,UAAU,OAAS,sFAEhG,EAEUA,EAAa,wDAAwD,GAGlEqB,EAGT,SAAS2B,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CAExE,QADIK,EAAYP,EAAMC,CAAQ,EACrBvL,EAAI,EAAGA,EAAIuM,EAAe,OAAQvM,IACzC,GAAI6K,EAAGgB,EAAWU,EAAevM,CAAC,CAAC,EACjC,OAAO,KAIX,IAAIwM,GAAe,KAAK,UAAUD,EAAgB,SAAkBrM,GAAKuM,EAAO,CAC9E,IAAI9H,GAAOsH,EAAeQ,CAAK,EAC/B,OAAI9H,KAAS,SACJ,OAAO8H,CAAK,EAEdA,CACf,CAAO,EACD,OAAO,IAAI3B,EAAc,WAAatC,EAAW,KAAOgD,EAAe,eAAiB,OAAOK,CAAS,EAAI,MAAQ,gBAAkBpD,EAAgB,sBAAwB+D,GAAe,IAAI,CAClM,CACD,OAAOxB,EAA2BC,CAAQ,CAC3C,CAED,SAAST,EAA0B0B,EAAa,CAC9C,SAASjB,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,GAAI,OAAOU,GAAgB,WACzB,OAAO,IAAIpB,EAAc,aAAeU,EAAe,mBAAqB/C,EAAgB,kDAAkD,EAEhJ,IAAIoD,EAAYP,EAAMC,CAAQ,EAC1BO,EAAWC,EAAYF,CAAS,EACpC,GAAIC,IAAa,SACf,OAAO,IAAIhB,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgB,IAAMM,EAAW,kBAAoBrD,EAAgB,yBAAyB,EAEvK,QAASvI,MAAO2L,EACd,GAAI7D,EAAI6D,EAAW3L,EAAG,EAAG,CACvB,IAAI0I,GAAQsD,EAAYL,EAAW3L,GAAKuI,EAAeD,EAAUgD,EAAe,IAAMtL,GAAK4H,CAAoB,EAC/G,GAAIc,cAAiB,MACnB,OAAOA,EAEV,CAEH,OAAO,IACR,CACD,OAAOoC,EAA2BC,CAAQ,CAC3C,CAED,SAASP,EAAuBgC,EAAqB,CACnD,GAAI,CAAC,MAAM,QAAQA,CAAmB,EACpC,eAAQ,IAAI,WAAa,cAAezE,EAAa,wEAAwE,EACtHqB,EAGT,QAAStJ,EAAI,EAAGA,EAAI0M,EAAoB,OAAQ1M,IAAK,CACnD,IAAI2M,EAAUD,EAAoB1M,CAAC,EACnC,GAAI,OAAO2M,GAAY,WACrB,OAAA1E,EACE,8FACc2E,EAAyBD,CAAO,EAAI,aAAe3M,EAAI,GAC/E,EACesJ,CAEV,CAED,SAAS2B,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CAExE,QADIqB,GAAgB,CAAA,EACX7M,GAAI,EAAGA,GAAI0M,EAAoB,OAAQ1M,KAAK,CACnD,IAAI2M,GAAUD,EAAoB1M,EAAC,EAC/B8M,EAAgBH,GAAQrB,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc1D,CAAoB,EACxG,GAAIgF,GAAiB,KACnB,OAAO,KAELA,EAAc,MAAQ9E,EAAI8E,EAAc,KAAM,cAAc,GAC9DD,GAAc,KAAKC,EAAc,KAAK,YAAY,CAErD,CACD,IAAIC,GAAwBF,GAAc,OAAS,EAAK,2BAA6BA,GAAc,KAAK,IAAI,EAAI,IAAK,GACrH,OAAO,IAAI/B,EAAc,WAAatC,EAAW,KAAOgD,EAAe,kBAAoB,IAAM/C,EAAgB,IAAMsE,GAAuB,IAAI,CACnJ,CACD,OAAO/B,EAA2BC,CAAQ,CAC3C,CAED,SAASV,GAAoB,CAC3B,SAASU,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,OAAKwB,EAAO1B,EAAMC,CAAQ,CAAC,EAGpB,KAFE,IAAIT,EAAc,WAAatC,EAAW,KAAOgD,EAAe,kBAAoB,IAAM/C,EAAgB,2BAA2B,CAG/I,CACD,OAAOuC,EAA2BC,CAAQ,CAC3C,CAED,SAASgC,EAAsBxE,EAAeD,EAAUgD,EAActL,EAAKyE,EAAM,CAC/E,OAAO,IAAImG,GACRrC,GAAiB,eAAiB,KAAOD,EAAW,UAAYgD,EAAe,IAAMtL,EAAM,6FACXyE,EAAO,IAC9F,CACG,CAED,SAASgG,EAAuBuC,EAAY,CAC1C,SAASjC,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,IAAIK,EAAYP,EAAMC,CAAQ,EAC1BO,EAAWC,EAAYF,CAAS,EACpC,GAAIC,IAAa,SACf,OAAO,IAAIhB,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgBM,EAAW,MAAQ,gBAAkBrD,EAAgB,wBAAwB,EAEtK,QAASvI,MAAOgN,EAAY,CAC1B,IAAIP,GAAUO,EAAWhN,EAAG,EAC5B,GAAI,OAAOyM,IAAY,WACrB,OAAOM,EAAsBxE,EAAeD,EAAUgD,EAActL,GAAK+L,EAAeU,EAAO,CAAC,EAElG,IAAI/D,GAAQ+D,GAAQd,EAAW3L,GAAKuI,EAAeD,EAAUgD,EAAe,IAAMtL,GAAK4H,CAAoB,EAC3G,GAAIc,GACF,OAAOA,EAEV,CACD,OAAO,IACR,CACD,OAAOoC,EAA2BC,CAAQ,CAC3C,CAED,SAASL,EAA6BsC,EAAY,CAChD,SAASjC,EAASK,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CACxE,IAAIK,EAAYP,EAAMC,CAAQ,EAC1BO,EAAWC,EAAYF,CAAS,EACpC,GAAIC,IAAa,SACf,OAAO,IAAIhB,EAAc,WAAatC,EAAW,KAAOgD,EAAe,cAAgBM,EAAW,MAAQ,gBAAkBrD,EAAgB,wBAAwB,EAGtK,IAAI0E,GAAUjE,EAAO,CAAE,EAAEoC,EAAMC,CAAQ,EAAG2B,CAAU,EACpD,QAAShN,MAAOiN,GAAS,CACvB,IAAIR,GAAUO,EAAWhN,EAAG,EAC5B,GAAI8H,EAAIkF,EAAYhN,EAAG,GAAK,OAAOyM,IAAY,WAC7C,OAAOM,EAAsBxE,EAAeD,EAAUgD,EAActL,GAAK+L,EAAeU,EAAO,CAAC,EAElG,GAAI,CAACA,GACH,OAAO,IAAI7B,EACT,WAAatC,EAAW,KAAOgD,EAAe,UAAYtL,GAAM,kBAAoBuI,EAAgB,mBACjF,KAAK,UAAU6C,EAAMC,CAAQ,EAAG,KAAM,IAAI,EAC7D;AAAA,cAAmB,KAAK,UAAU,OAAO,KAAK2B,CAAU,EAAG,KAAM,IAAI,CACjF,EAEQ,IAAItE,EAAQ+D,GAAQd,EAAW3L,GAAKuI,EAAeD,EAAUgD,EAAe,IAAMtL,GAAK4H,CAAoB,EAC3G,GAAIc,EACF,OAAOA,CAEV,CACD,OAAO,IACR,CAED,OAAOoC,EAA2BC,CAAQ,CAC3C,CAED,SAAS+B,EAAOnB,EAAW,CACzB,OAAQ,OAAOA,EAAS,CACtB,IAAK,SACL,IAAK,SACL,IAAK,YACH,MAAO,GACT,IAAK,UACH,MAAO,CAACA,EACV,IAAK,SACH,GAAI,MAAM,QAAQA,CAAS,EACzB,OAAOA,EAAU,MAAMmB,CAAM,EAE/B,GAAInB,IAAc,MAAQrC,EAAeqC,CAAS,EAChD,MAAO,GAGT,IAAI/B,EAAaF,EAAciC,CAAS,EACxC,GAAI/B,EAAY,CACd,IAAIsD,EAAWtD,EAAW,KAAK+B,CAAS,EACpCwB,EACJ,GAAIvD,IAAe+B,EAAU,SAC3B,KAAO,EAAEwB,EAAOD,EAAS,KAAI,GAAI,MAC/B,GAAI,CAACJ,EAAOK,EAAK,KAAK,EACpB,MAAO,OAKX,MAAO,EAAEA,EAAOD,EAAS,KAAI,GAAI,MAAM,CACrC,IAAIE,EAAQD,EAAK,MACjB,GAAIC,GACE,CAACN,EAAOM,EAAM,CAAC,CAAC,EAClB,MAAO,EAGZ,CAEb,KACU,OAAO,GAGT,MAAO,GACT,QACE,MAAO,EACV,CACF,CAED,SAASC,EAASzB,EAAUD,EAAW,CAErC,OAAIC,IAAa,SACR,GAIJD,EAKDA,EAAU,eAAe,IAAM,UAK/B,OAAO,QAAW,YAAcA,aAAqB,OAThD,EAcV,CAGD,SAASE,EAAYF,EAAW,CAC9B,IAAIC,EAAW,OAAOD,EACtB,OAAI,MAAM,QAAQA,CAAS,EAClB,QAELA,aAAqB,OAIhB,SAEL0B,EAASzB,EAAUD,CAAS,EACvB,SAEFC,CACR,CAID,SAASG,EAAeJ,EAAW,CACjC,GAAI,OAAOA,EAAc,KAAeA,IAAc,KACpD,MAAO,GAAKA,EAEd,IAAIC,EAAWC,EAAYF,CAAS,EACpC,GAAIC,IAAa,SAAU,CACzB,GAAID,aAAqB,KACvB,MAAO,OACF,GAAIA,aAAqB,OAC9B,MAAO,QAEV,CACD,OAAOC,CACR,CAID,SAASc,EAAyBH,EAAO,CACvC,IAAI9H,EAAOsH,EAAeQ,CAAK,EAC/B,OAAQ9H,EAAI,CACV,IAAK,QACL,IAAK,SACH,MAAO,MAAQA,EACjB,IAAK,UACL,IAAK,OACL,IAAK,SACH,MAAO,KAAOA,EAChB,QACE,OAAOA,CACV,CACF,CAGD,SAAS2H,GAAaT,EAAW,CAC/B,MAAI,CAACA,EAAU,aAAe,CAACA,EAAU,YAAY,KAC5C9B,EAEF8B,EAAU,YAAY,IAC9B,CAED,OAAA7B,EAAe,eAAiB3B,EAChC2B,EAAe,kBAAoB3B,EAAe,kBAClD2B,EAAe,UAAYA,EAEpBA,mDCvlBT,IAAIlC,EAAuBlB,KAE3B,SAAS4G,GAAgB,CAAE,CAC3B,SAASC,GAAyB,CAAE,CACpC,OAAAA,EAAuB,kBAAoBD,EAE3CE,GAAiB,UAAW,CAC1B,SAASC,EAAKrC,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAcC,EAAQ,CAC5E,GAAIA,IAAW3D,EAIf,KAAIe,EAAM,IAAI,MACZ,iLAGN,EACI,MAAAA,EAAI,KAAO,sBACLA,EACV,CACE8E,EAAK,WAAaA,EAClB,SAASC,GAAU,CACjB,OAAOD,CAEX,CAEE,IAAI3D,EAAiB,CACnB,MAAO2D,EACP,OAAQA,EACR,KAAMA,EACN,KAAMA,EACN,OAAQA,EACR,OAAQA,EACR,OAAQA,EACR,OAAQA,EAER,IAAKA,EACL,QAASC,EACT,QAASD,EACT,YAAaA,EACb,WAAYC,EACZ,KAAMD,EACN,SAAUC,EACV,MAAOA,EACP,UAAWA,EACX,MAAOA,EACP,MAAOA,EAEP,eAAgBH,EAChB,kBAAmBD,CACvB,EAEE,OAAAxD,EAAe,UAAYA,EAEpBA,MCxDT,GAAI,QAAQ,IAAI,WAAa,aAAc,CACzC,IAAIf,GAAUrC,KAIV6C,GAAsB,GAC1BoE,GAAA,QAAiBhH,GAAA,EAAqCoC,GAAQ,UAAWQ,EAAmB,CAC9F,MAGEoE,GAAc,QAAG1E,GAAqC,qCCfxD,SAAS2E,GAAiBxN,EAAa,CAErC,KAAM,CACJ,UAAAyN,EAAY,CAAE,CACf,EAAGzN,EACJ,MAAO,EAAQyN,EAAU,gBAC3B,CACA,SAASC,GAAa1C,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CAC5E,MAAMpL,EAAUkL,EAAMC,CAAQ,EACxB0C,EAAezC,GAAgBD,EACrC,GAAInL,GAAW,MAKf,OAAO,OAAW,IAChB,OAAO,KAET,IAAI8N,EACJ,MAAM5N,EAAcF,EAAQ,KAa5B,OAHI,OAAOE,GAAgB,YAAc,CAACwN,GAAiBxN,CAAW,IACpE4N,EAAc,+EAEZA,IAAgB,OACX,IAAI,MAAM,WAAW1F,CAAQ,MAAMyF,CAAY,oBAAoBxF,CAAa,gDAAqDyF,CAAW,oEAAyE,EAE3N,IACT,CACA,MAAMC,GAAsBxM,GAAeyM,EAAU,QAASJ,EAAY,EAC1EG,GAAoB,WAAaxM,GAAeyM,EAAU,QAAQ,WAAYJ,EAAY,EAC1F,MAAAK,GAAeF,GCrCTG,GAAkB,gBACT,SAASC,GAAUC,EAAW,CAC3C,OAAI,QAAQ,IAAI,WAAa,aACpBA,EAEF1O,EAAS,CAAE,EAAE0O,EAAW,CAC7B,CAACF,EAAe,EAAGhD,GAAS,CAC1B,MAAMmD,EAAmB,OAAO,KAAKnD,CAAK,EAAE,OAAOlK,GAAQ,CAACoN,EAAU,eAAepN,CAAI,CAAC,EAC1F,OAAIqN,EAAiB,OAAS,EACrB,IAAI,MAAM,0CAA0CA,EAAiB,IAAIrN,GAAQ,KAAKA,CAAI,IAAI,EAAE,KAAK,IAAI,CAAC,uBAAuB,EAEnI,IACR,CACL,CAAG,CACH,CCbe,SAASsN,GAAsBC,EAAM,CAKlD,IAAIC,EAAM,0CAA4CD,EACtD,QAAS3O,EAAI,EAAGA,EAAI,UAAU,OAAQA,GAAK,EAGzC4O,GAAO,WAAa,mBAAmB,UAAU5O,CAAC,CAAC,EAErD,MAAO,uBAAyB2O,EAAO,WAAaC,EAAM,wBAE5D,CClBe,SAASC,GAAgBvD,EAAOC,EAAU9C,EAAeD,EAAUgD,EAAc,CAC9F,GAAI,QAAQ,IAAI,WAAa,aAC3B,OAAO,KAET,MAAMK,EAAYP,EAAMC,CAAQ,EAC1B0C,EAAezC,GAAgBD,EACrC,OAAIM,GAAa,KACR,KAELA,GAAaA,EAAU,WAAa,EAC/B,IAAI,MAAM,WAAWrD,CAAQ,MAAMyF,CAAY,oBAAoBxF,CAAa,8BAAmC,EAErH,IACT,CCPe,SAASqG,MAAyBC,EAAO,CACtD,OAAOA,EAAM,OAAO,CAACC,EAAKC,IACpBA,GAAQ,KACHD,EAEF,YAA4BlN,EAAM,CACvCkN,EAAI,MAAM,KAAMlN,CAAI,EACpBmN,EAAK,MAAM,KAAMnN,CAAI,CAC3B,EACK,IAAM,CAAE,CAAA,CACb,CCde,SAASoN,GAASD,EAAME,EAAO,IAAK,CACjD,IAAIC,EACJ,SAASC,KAAavN,EAAM,CAC1B,MAAMwN,EAAQ,IAAM,CAElBL,EAAK,MAAM,KAAMnN,CAAI,CAC3B,EACI,aAAasN,CAAO,EACpBA,EAAU,WAAWE,EAAOH,CAAI,CACjC,CACD,OAAAE,EAAU,MAAQ,IAAM,CACtB,aAAaD,CAAO,CACxB,EACSC,CACT,CChBe,SAASE,GAAcC,EAAM,CAC1C,OAAOA,GAAQA,EAAK,eAAiB,QACvC,CCDe,SAASC,GAAYD,EAAM,CAExC,OADYD,GAAcC,CAAI,EACnB,aAAe,MAC5B,CCSe,SAASE,GAAOC,EAAKlD,EAAO,CACrC,OAAOkD,GAAQ,WACjBA,EAAIlD,CAAK,EACAkD,IACTA,EAAI,QAAUlD,EAElB,CCPA,MAAAmD,GAD0B,OAAO,OAAW,IAAcjP,EAAM,gBAAkBA,EAAM,UCDxF,SAASkP,GAAiBC,EAAI,CAC5B,MAAMH,EAAMhP,EAAM,OAAOmP,CAAE,EAC3BC,OAAAA,GAAkB,IAAM,CACtBJ,EAAI,QAAUG,CAClB,CAAG,EACMnP,EAAM,OAAO,IAAImB,OAGpB6N,EAAI,SAAS,GAAG7N,CAAI,CAAC,EAAE,OAC7B,CCfe,SAASkO,MAAcC,EAAM,CAM1C,OAAOtP,EAAM,QAAQ,IACfsP,EAAK,MAAMN,GAAOA,GAAO,IAAI,EACxB,KAEFO,GAAY,CACjBD,EAAK,QAAQN,GAAO,CAClBD,GAAOC,EAAKO,CAAQ,CAC5B,CAAO,CACP,EAEKD,CAAI,CACT,CCjBA,IAAIE,GAAmB,GACnBC,GAA0B,GAC1BC,GACJ,MAAMC,GAAsB,CAC1B,KAAM,GACN,OAAQ,GACR,IAAK,GACL,IAAK,GACL,MAAO,GACP,SAAU,GACV,OAAQ,GACR,KAAM,GACN,MAAO,GACP,KAAM,GACN,KAAM,GACN,SAAU,GACV,iBAAkB,EACpB,EASA,SAASC,GAA8Bf,EAAM,CAC3C,KAAM,CACJ,KAAA7K,EACA,QAAA6L,CACD,EAAGhB,EAOJ,MANI,GAAAgB,IAAY,SAAWF,GAAoB3L,CAAI,GAAK,CAAC6K,EAAK,UAG1DgB,IAAY,YAAc,CAAChB,EAAK,UAGhCA,EAAK,kBAIX,CASA,SAASiB,GAAcC,EAAO,CACxBA,EAAM,SAAWA,EAAM,QAAUA,EAAM,UAG3CP,GAAmB,GACrB,CASA,SAASQ,IAAoB,CAC3BR,GAAmB,EACrB,CACA,SAASS,IAAyB,CAC5B,KAAK,kBAAoB,UAKvBR,KACFD,GAAmB,GAGzB,CACA,SAASU,GAAQC,EAAK,CACpBA,EAAI,iBAAiB,UAAWL,GAAe,EAAI,EACnDK,EAAI,iBAAiB,YAAaH,GAAmB,EAAI,EACzDG,EAAI,iBAAiB,cAAeH,GAAmB,EAAI,EAC3DG,EAAI,iBAAiB,aAAcH,GAAmB,EAAI,EAC1DG,EAAI,iBAAiB,mBAAoBF,GAAwB,EAAI,CACvE,CAQA,SAASG,GAAeL,EAAO,CAC7B,KAAM,CACJ,OAAA3Q,CACD,EAAG2Q,EACJ,GAAI,CACF,OAAO3Q,EAAO,QAAQ,gBAAgB,CACvC,MAAe,CAKf,CAID,OAAOoQ,IAAoBI,GAA8BxQ,CAAM,CACjE,CACe,SAASiR,IAAoB,CAC1C,MAAMrB,EAAMhP,EAAM,YAAY6O,GAAQ,CAChCA,GAAQ,MACVqB,GAAQrB,EAAK,aAAa,CAE7B,EAAE,CAAE,CAAA,EACCyB,EAAoBtQ,EAAM,OAAO,EAAK,EAK5C,SAASuQ,GAAoB,CAM3B,OAAID,EAAkB,SAKpBb,GAA0B,GAC1B,OAAO,aAAaC,EAA8B,EAClDA,GAAiC,OAAO,WAAW,IAAM,CACvDD,GAA0B,EAC3B,EAAE,GAAG,EACNa,EAAkB,QAAU,GACrB,IAEF,EACR,CAKD,SAASE,EAAmBT,EAAO,CACjC,OAAIK,GAAeL,CAAK,GACtBO,EAAkB,QAAU,GACrB,IAEF,EACR,CACD,MAAO,CACL,kBAAAA,EACA,QAASE,EACT,OAAQD,EACR,IAAAvB,CACJ,CACA,CChKe,SAASyB,GAAiBN,EAAK,CAE5C,MAAMO,EAAgBP,EAAI,gBAAgB,YAC1C,OAAO,KAAK,IAAI,OAAO,WAAaO,CAAa,CACnD,CCNe,SAASC,GAAeC,EAAOC,EAAiBC,EAAU,OAAW,CAClF,MAAMC,EAAS,CAAA,EACf,cAAO,KAAKH,CAAK,EAAE,QAGnBxQ,GAAQ,CACN2Q,EAAO3Q,CAAI,EAAIwQ,EAAMxQ,CAAI,EAAE,OAAO,CAACiO,EAAK9O,IAAQ,CAC9C,GAAIA,EAAK,CACP,MAAMyR,EAAeH,EAAgBtR,CAAG,EACpCyR,IAAiB,IACnB3C,EAAI,KAAK2C,CAAY,EAEnBF,GAAWA,EAAQvR,CAAG,GACxB8O,EAAI,KAAKyC,EAAQvR,CAAG,CAAC,CAExB,CACD,OAAO8O,CACR,EAAE,EAAE,EAAE,KAAK,GAAG,CACnB,CAAG,EACM0C,CACT,CCpBA,MAAME,GAAmBnJ,GAAiBA,EAgB1CoJ,IAfiC,IAAM,CACrC,IAAIC,EAAWF,GACf,MAAO,CACL,UAAUG,EAAW,CACnBD,EAAWC,CACZ,EACD,SAAStJ,EAAe,CACtB,OAAOqJ,EAASrJ,CAAa,CAC9B,EACD,OAAQ,CACNqJ,EAAWF,EACZ,CACL,CACA,GACmD,ECX7CI,GAA4B,CAChC,OAAQ,SACR,QAAS,UACT,UAAW,YACX,SAAU,WACV,MAAO,QACP,SAAU,WACV,QAAS,UACT,aAAc,eACd,KAAM,OACN,SAAU,WACV,SAAU,WACV,SAAU,UACZ,EACe,SAASnR,GAAqB4H,EAAe1H,EAAMkR,EAAoB,MAAO,CAC3F,MAAMC,EAAmBF,GAA0BjR,CAAI,EACvD,OAAOmR,EAAmB,GAAGD,CAAiB,IAAIC,CAAgB,GAAK,GAAGC,GAAmB,SAAS1J,CAAa,CAAC,IAAI1H,CAAI,EAC9H,CCpBe,SAASqR,GAAuB3J,EAAe8I,EAAOU,EAAoB,MAAO,CAC9F,MAAM9Q,EAAS,CAAA,EACf,OAAAoQ,EAAM,QAAQxQ,GAAQ,CACpBI,EAAOJ,CAAI,EAAIF,GAAqB4H,EAAe1H,EAAMkR,CAAiB,CAC9E,CAAG,EACM9Q,CACT,CCPA,SAASyB,GAAE,EAAE,CAAC,IAAI,EAAET,EAAE,EAAE,GAAG,GAAa,OAAO,GAAjB,UAA8B,OAAO,GAAjB,SAAmB,GAAG,UAAoB,OAAO,GAAjB,SAAmB,GAAG,MAAM,QAAQ,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,OAAO,IAAI,EAAE,CAAC,IAAIA,EAAES,GAAE,EAAE,CAAC,CAAC,KAAK,IAAI,GAAG,KAAK,GAAGT,OAAQ,KAAI,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,GAAG,KAAK,GAAG,GAAG,OAAO,CAAC,CAAQ,SAASkQ,IAAM,CAAC,QAAQ,EAAE,EAAElQ,EAAE,EAAE,EAAE,GAAGA,EAAE,UAAU,SAAS,EAAE,UAAUA,GAAG,KAAK,EAAES,GAAE,CAAC,KAAK,IAAI,GAAG,KAAK,GAAG,GAAG,OAAO,CAAC,CCO1V,SAAS0P,GAAkBrR,EAAQ,CACxC,GAAIA,IAAW,OACb,MAAO,GAET,MAAME,EAAS,CAAA,EACf,cAAO,KAAKF,CAAM,EAAE,OAAOG,GAAQ,EAAEA,EAAK,MAAM,UAAU,GAAK,OAAOH,EAAOG,CAAI,GAAM,WAAW,EAAE,QAAQA,GAAQ,CAClHD,EAAOC,CAAI,EAAIH,EAAOG,CAAI,CAC9B,CAAG,EACMD,CACT,CCCO,SAASoR,GAAeC,EAAY,CACzC,KAAM,CACJ,aAAAC,EACA,gBAAAC,EACA,kBAAAC,EACA,uBAAAC,EACA,UAAAC,CACD,EAAGL,EACJ,GAAI,CAACC,EAAc,CAGjB,MAAMK,EAAgBT,GAAKK,GAAmB,KAAO,OAASA,EAAgB,UAAWG,EAAWD,GAA0B,KAAO,OAASA,EAAuB,UAAWD,GAAqB,KAAO,OAASA,EAAkB,SAAS,EAC1OI,EAAcjT,EAAS,CAAA,EAAI4S,GAAmB,KAAO,OAASA,EAAgB,MAAOE,GAA0B,KAAO,OAASA,EAAuB,MAAOD,GAAqB,KAAO,OAASA,EAAkB,KAAK,EACzNrH,EAAQxL,EAAS,CAAA,EAAI4S,EAAiBE,EAAwBD,CAAiB,EACrF,OAAIG,EAAc,OAAS,IACzBxH,EAAM,UAAYwH,GAEhB,OAAO,KAAKC,CAAW,EAAE,OAAS,IACpCzH,EAAM,MAAQyH,GAET,CACL,MAAAzH,EACA,YAAa,MACnB,CACG,CAKD,MAAM0H,EAAgBhS,GAAqBlB,EAAS,CAAE,EAAE8S,EAAwBD,CAAiB,CAAC,EAC5FM,EAAsCX,GAAkBK,CAAiB,EACzEO,EAAiCZ,GAAkBM,CAAsB,EACzEO,EAAoBV,EAAaO,CAAa,EAM9CF,EAAgBT,GAAKc,GAAqB,KAAO,OAASA,EAAkB,UAAWT,GAAmB,KAAO,OAASA,EAAgB,UAAWG,EAAWD,GAA0B,KAAO,OAASA,EAAuB,UAAWD,GAAqB,KAAO,OAASA,EAAkB,SAAS,EAC5SI,EAAcjT,EAAS,CAAE,EAAEqT,GAAqB,KAAO,OAASA,EAAkB,MAAOT,GAAmB,KAAO,OAASA,EAAgB,MAAOE,GAA0B,KAAO,OAASA,EAAuB,MAAOD,GAAqB,KAAO,OAASA,EAAkB,KAAK,EACvRrH,EAAQxL,EAAS,CAAE,EAAEqT,EAAmBT,EAAiBQ,EAAgCD,CAAmC,EAClI,OAAIH,EAAc,OAAS,IACzBxH,EAAM,UAAYwH,GAEhB,OAAO,KAAKC,CAAW,EAAE,OAAS,IACpCzH,EAAM,MAAQyH,GAET,CACL,MAAAzH,EACA,YAAa6H,EAAkB,GACnC,CACA,CChEA,MAAMC,GAAY,CAAC,cAAe,oBAAqB,aAAc,wBAAwB,EAatF,SAASC,GAAab,EAAY,CACvC,IAAIc,EACJ,KAAM,CACF,YAAAhT,EACA,kBAAAqS,EACA,WAAAnS,EACA,uBAAA+S,EAAyB,EAC/B,EAAQf,EACJgB,EAAOhS,GAA8BgR,EAAYY,EAAS,EACtDK,EAA0BF,EAAyB,CAAA,EAAKlS,GAAsBsR,EAAmBnS,CAAU,EAC3G,CACJ,MAAOkT,EACP,YAAAC,CACD,EAAGpB,GAAezS,EAAS,CAAE,EAAE0T,EAAM,CACpC,kBAAmBC,CACpB,CAAA,CAAC,EACI9D,EAAMK,GAAW2D,EAAaF,GAA2B,KAAO,OAASA,EAAwB,KAAMH,EAAwBd,EAAW,kBAAoB,KAAO,OAASc,EAAsB,GAAG,EAI7M,OAHcjT,GAAiBC,EAAaR,EAAS,CAAA,EAAI4T,EAAa,CACpE,IAAA/D,CACJ,CAAG,EAAGnP,CAAU,CAEhB,CCpCA,MAAM4S,GAAY,CAAC,YAAY,EAExB,SAASQ,GAAeC,EAAW,CACxC,OAAoBlT,EAAM,WAAW,SAAc2K,EAAOqE,EAAK,CAC7D,MAAMmE,EAAQtS,GAA8B8J,EAAO8H,EAAS,EAC5D,OAAoBzS,EAAM,cAAckT,EAAW/T,EAAS,CAAA,EAAIgU,EAAO,CACrE,IAAAnE,CACD,CAAA,CAAC,CACN,CAAG,CACH,CCKO,SAASoE,GAAUvB,EAAa,GAAI,CACzC,KAAM,CACJ,SAAAwB,EAAW,GACX,sBAAAC,EACA,KAAAC,EACA,QAASC,EACT,SAAAC,EACA,GAAAzM,EACA,KAAAhD,CACD,EAAG6N,EACE6B,EAAY1T,EAAM,SAClB,CAAC2T,EAAQC,CAAS,EAAI5T,EAAM,SAAS,EAAK,EAC1C,CACJ,kBAAAsQ,EACA,QAASE,EACT,OAAQD,EACR,IAAKsD,CACN,EAAGxD,GAAiB,EACf,CAACyD,EAAcC,CAAe,EAAI/T,EAAM,SAAS,EAAK,EACxDqT,GAAY,CAACC,GAAyBQ,GACxCC,EAAgB,EAAK,EAEvB/T,EAAM,UAAU,IAAM,CACpBsQ,EAAkB,QAAUwD,CAChC,EAAK,CAACA,EAAcxD,CAAiB,CAAC,EACpC,KAAM,CAAC0D,EAAiBC,CAAkB,EAAIjU,EAAM,SAAS,EAAE,EACzDkU,EAAyBC,GAAiBpE,GAAS,CACvD,IAAIqE,EACAN,GACF/D,EAAM,eAAc,GAErBqE,EAAwBD,EAAc,eAAiB,MAAQC,EAAsB,KAAKD,EAAepE,CAAK,CACnH,EACQsE,EAAmBF,GAAiBpE,GAAS,CACjD,IAAIuE,EACJ/D,EAAkBR,CAAK,EACnBO,EAAkB,UAAY,IAChCyD,EAAgB,EAAK,GAEtBO,EAAwBH,EAAc,SAAW,MAAQG,EAAsB,KAAKH,EAAepE,CAAK,CAC7G,EACQwE,EAAoBJ,GAAiBpE,GAAS,CAClD,IAAIyE,EAMJ,GAJKd,EAAU,UACbA,EAAU,QAAU3D,EAAM,eAE5BS,EAAmBT,CAAK,EACpBO,EAAkB,UAAY,GAAM,CACtC,IAAImE,EACJV,EAAgB,EAAI,GACnBU,EAAwBN,EAAc,iBAAmB,MAAQM,EAAsB,KAAKN,EAAepE,CAAK,CAClH,EACAyE,EAAyBL,EAAc,UAAY,MAAQK,EAAuB,KAAKL,EAAepE,CAAK,CAChH,EACQ2E,EAAiB,IAAM,CAC3B,MAAMC,EAASjB,EAAU,QACzB,OAAOM,IAAoB,UAAYA,IAAoB,SAAW,CAAC,SAAU,SAAU,OAAO,EAAE,SAASW,GAAU,KAAO,OAASA,EAAO,IAAI,GAAKX,IAAoB,MAAQW,GAAU,KAAO,OAASA,EAAO,KACxN,EACQC,EAAoBT,GAAiBpE,GAAS,CAClD,GAAI,CAACsD,EAAU,CACb,IAAIwB,GACHA,EAAwBV,EAAc,UAAY,MAAQU,EAAsB,KAAKV,EAAepE,CAAK,CAC3G,CACL,EACQ+E,EAAwBX,GAAiBpE,GAAS,CACtD,IAAIgF,EACC1B,IACHO,EAAU,EAAI,EACd,SAAS,iBAAiB,UAAW,IAAM,CACzCA,EAAU,EAAK,CACvB,EAAS,CACD,KAAM,EACd,CAAO,IAEFmB,EAAyBZ,EAAc,cAAgB,MAAQY,EAAuB,KAAKZ,EAAepE,CAAK,CACpH,EACQiF,EAAsBb,GAAiBpE,GAAS,CACpD,IAAIkF,EAEJ,IADCA,EAAwBd,EAAc,YAAc,MAAQc,EAAsB,KAAKd,EAAepE,CAAK,EACxG,CAAAA,EAAM,sBAGNA,EAAM,SAAWA,EAAM,eAAiB,CAAC2E,KAAoB3E,EAAM,MAAQ,KAC7EA,EAAM,eAAc,EAElBA,EAAM,SAAWA,EAAM,eAAiBA,EAAM,MAAQ,KAAO,CAACsD,GAChEO,EAAU,EAAI,EAIZ7D,EAAM,SAAWA,EAAM,eAAiB,CAAC2E,EAAgB,GAAI3E,EAAM,MAAQ,SAAW,CAACsD,GAAU,CACnG,IAAI6B,GACHA,EAAyBf,EAAc,UAAY,MAAQe,EAAuB,KAAKf,EAAepE,CAAK,EAC5GA,EAAM,eAAc,CACrB,CACL,EACQoF,EAAoBhB,GAAiBpE,GAAS,CAClD,IAAIqF,EAUJ,GANIrF,EAAM,SAAWA,EAAM,eACzB6D,EAAU,EAAK,GAEhBwB,EAAwBjB,EAAc,UAAY,MAAQiB,EAAsB,KAAKjB,EAAepE,CAAK,EAGtGA,EAAM,SAAWA,EAAM,eAAiB,CAAC2E,EAAgB,GAAI,CAACrB,GAAYtD,EAAM,MAAQ,KAAO,CAACA,EAAM,oBAAqB,CAC7H,IAAIsF,GACHA,EAAyBlB,EAAc,UAAY,MAAQkB,EAAuB,KAAKlB,EAAepE,CAAK,CAC7G,CACL,EACQuF,EAAwBtV,EAAM,YAAYuP,GAAY,CAC1D,IAAIgG,EACJtB,GAAoBsB,EAAoBhG,GAAY,KAAO,OAASA,EAAS,UAAY,KAAOgG,EAAoB,EAAE,CACvH,EAAE,CAAE,CAAA,EACCC,EAAYnG,GAAWiG,EAAuB9B,EAAaK,EAAiBH,CAAS,EACrF+B,EAAc,CAAA,EACpB,OAAIhC,IAAa,SACfgC,EAAY,SAAWhC,GAErBO,IAAoB,UACtByB,EAAY,KAAOzR,GAAsB,SACrCsP,EACFmC,EAAY,eAAe,EAAIpC,EAE/BoC,EAAY,SAAWpC,GAEhBW,IAAoB,KACzB,CAACT,GAAQ,CAACvM,IACZyO,EAAY,KAAO,SACnBA,EAAY,SAAWhC,GAA8B,GAEnDJ,IACFoC,EAAY,eAAe,EAAIpC,EAC/BoC,EAAY,SAAWnC,EAAwBG,GAA8B,EAAI,KAwB9E,CACL,aAtBmB,CAACiC,EAAgB,KAAO,CAC3C,MAAMC,EAAwBxW,EAAS,GAAIkB,GAAqBwR,CAAU,EAAGxR,GAAqBqV,CAAa,CAAC,EAC1G/K,EAAQxL,EAAS,CACrB,KAAA6E,CACN,EAAO2R,EAAuBF,EAAaC,EAAe,CACpD,OAAQrB,EAAiBsB,CAAqB,EAC9C,QAASf,EAAkBe,CAAqB,EAChD,QAASpB,EAAkBoB,CAAqB,EAChD,UAAWX,EAAoBW,CAAqB,EACpD,QAASR,EAAkBQ,CAAqB,EAChD,YAAab,EAAsBa,CAAqB,EACxD,aAAczB,EAAuByB,CAAqB,EAC1D,IAAKH,CACX,CAAK,EAKD,cAAO7K,EAAM,eACNA,CACX,EAGI,aAAAmJ,EACA,gBAAAC,EACA,OAAAJ,EACA,QAAS6B,CACb,CACA,CC9KA,MAAMI,GAAqB,CAAC,QAAS,SAAU,WAAY,UAAW,SAAU,aAAc,kBAAmB,kBAAmB,kDAAkD,EAAE,KAAK,GAAG,EAChM,SAASC,GAAYhH,EAAM,CACzB,MAAMiH,EAAe,SAASjH,EAAK,aAAa,UAAU,GAAK,GAAI,EAAE,EACrE,OAAK,OAAO,MAAMiH,CAAY,EAY1BjH,EAAK,kBAAoB,SAAWA,EAAK,WAAa,SAAWA,EAAK,WAAa,SAAWA,EAAK,WAAa,YAAcA,EAAK,aAAa,UAAU,IAAM,KAC3J,EAEFA,EAAK,SAdHiH,CAeX,CACA,SAASC,GAAmBlH,EAAM,CAIhC,GAHIA,EAAK,UAAY,SAAWA,EAAK,OAAS,SAG1C,CAACA,EAAK,KACR,MAAO,GAET,MAAMmH,EAAWC,GAAYpH,EAAK,cAAc,cAAc,sBAAsBoH,CAAQ,EAAE,EAC9F,IAAIC,EAASF,EAAS,UAAUnH,EAAK,IAAI,YAAY,EACrD,OAAKqH,IACHA,EAASF,EAAS,UAAUnH,EAAK,IAAI,IAAI,GAEpCqH,IAAWrH,CACpB,CACA,SAASsH,GAAgCtH,EAAM,CAC7C,MAAI,EAAAA,EAAK,UAAYA,EAAK,UAAY,SAAWA,EAAK,OAAS,UAAYkH,GAAmBlH,CAAI,EAIpG,CACA,SAASuH,GAAmBC,EAAM,CAChC,MAAMC,EAAkB,CAAA,EAClBC,EAAkB,CAAA,EACxB,aAAM,KAAKF,EAAK,iBAAiBT,EAAkB,CAAC,EAAE,QAAQ,CAAC/G,EAAMxP,IAAM,CACzE,MAAMmX,EAAeX,GAAYhH,CAAI,EACjC2H,IAAiB,IAAM,CAACL,GAAgCtH,CAAI,IAG5D2H,IAAiB,EACnBF,EAAgB,KAAKzH,CAAI,EAEzB0H,EAAgB,KAAK,CACnB,cAAelX,EACf,SAAUmX,EACV,KAAM3H,CACd,CAAO,EAEP,CAAG,EACM0H,EAAgB,KAAK,CAAC/T,EAAGpB,IAAMoB,EAAE,WAAapB,EAAE,SAAWoB,EAAE,cAAgBpB,EAAE,cAAgBoB,EAAE,SAAWpB,EAAE,QAAQ,EAAE,IAAIoB,GAAKA,EAAE,IAAI,EAAE,OAAO8T,CAAe,CACxK,CACA,SAASG,IAAmB,CAC1B,MAAO,EACT,CAaA,SAASC,GAAU/L,EAAO,CACxB,KAAM,CACJ,SAAAgM,EACA,iBAAAC,EAAmB,GACnB,oBAAAC,EAAsB,GACtB,oBAAAC,EAAsB,GACtB,YAAAC,EAAcX,GACd,UAAAY,EAAYP,GACZ,KAAAQ,CACD,EAAGtM,EACEuM,EAAyBlX,EAAM,OAAO,EAAK,EAC3CmX,EAAgBnX,EAAM,OAAO,IAAI,EACjCoX,EAAcpX,EAAM,OAAO,IAAI,EAC/BqX,EAAgBrX,EAAM,OAAO,IAAI,EACjCsX,EAAwBtX,EAAM,OAAO,IAAI,EAGzCuX,EAAYvX,EAAM,OAAO,EAAK,EAC9BwX,EAAUxX,EAAM,OAAO,IAAI,EAE3BwV,EAAYnG,GAAWsH,EAAS,IAAKa,CAAO,EAC5CC,EAAczX,EAAM,OAAO,IAAI,EACrCA,EAAM,UAAU,IAAM,CAEhB,CAACiX,GAAQ,CAACO,EAAQ,UAGtBD,EAAU,QAAU,CAACX,EACzB,EAAK,CAACA,EAAkBK,CAAI,CAAC,EAC3BjX,EAAM,UAAU,IAAM,CAEpB,GAAI,CAACiX,GAAQ,CAACO,EAAQ,QACpB,OAEF,MAAMrH,EAAMvB,GAAc4I,EAAQ,OAAO,EACzC,OAAKA,EAAQ,QAAQ,SAASrH,EAAI,aAAa,IACxCqH,EAAQ,QAAQ,aAAa,UAAU,IACtC,QAAQ,IAAI,WAAa,cAC3B,QAAQ,MAAM,CAAC,qDAAsD,2FAAgG,EAAE,KAAK;AAAA,CAAI,CAAC,EAEnLA,EAAQ,QAAQ,aAAa,WAAY,IAAI,GAE3CD,EAAU,SACZC,EAAQ,QAAQ,SAGb,IAAM,CAENV,IAKCO,EAAc,SAAWA,EAAc,QAAQ,QACjDH,EAAuB,QAAU,GACjCG,EAAc,QAAQ,SAExBA,EAAc,QAAU,KAEhC,CAIA,EAAK,CAACJ,CAAI,CAAC,EACTjX,EAAM,UAAU,IAAM,CAEpB,GAAI,CAACiX,GAAQ,CAACO,EAAQ,QACpB,OAEF,MAAMrH,EAAMvB,GAAc4I,EAAQ,OAAO,EACnCE,EAAYC,GAAe,CAC/BF,EAAY,QAAUE,EAClB,EAAAd,GAAuB,CAACG,EAAS,GAAMW,EAAY,MAAQ,QAM3DxH,EAAI,gBAAkBqH,EAAQ,SAAWG,EAAY,WAGvDT,EAAuB,QAAU,GAC7BE,EAAY,SACdA,EAAY,QAAQ,QAG9B,EACUQ,EAAU,IAAM,CACpB,MAAMC,EAAcL,EAAQ,QAI5B,GAAIK,IAAgB,KAClB,OAEF,GAAI,CAAC1H,EAAI,SAAU,GAAI,CAAC6G,EAAW,GAAIE,EAAuB,QAAS,CACrEA,EAAuB,QAAU,GACjC,MACD,CAQD,GALIW,EAAY,SAAS1H,EAAI,aAAa,GAKtC0G,GAAuB1G,EAAI,gBAAkBgH,EAAc,SAAWhH,EAAI,gBAAkBiH,EAAY,QAC1G,OAIF,GAAIjH,EAAI,gBAAkBmH,EAAsB,QAC9CA,EAAsB,QAAU,aACvBA,EAAsB,UAAY,KAC3C,OAEF,GAAI,CAACC,EAAU,QACb,OAEF,IAAIO,EAAW,CAAA,EAOf,IANI3H,EAAI,gBAAkBgH,EAAc,SAAWhH,EAAI,gBAAkBiH,EAAY,WACnFU,EAAWf,EAAYS,EAAQ,OAAO,GAKpCM,EAAS,OAAS,EAAG,CACvB,IAAIC,EAAsBC,EAC1B,MAAMC,EAAa,IAAUF,EAAuBN,EAAY,UAAY,MAAgBM,EAAqB,YAAeC,EAAwBP,EAAY,UAAY,KAAO,OAASO,EAAsB,OAAS,OACzNE,EAAYJ,EAAS,CAAC,EACtBK,EAAgBL,EAASA,EAAS,OAAS,CAAC,EAC9C,OAAOI,GAAc,UAAY,OAAOC,GAAkB,WACxDF,EACFE,EAAc,MAAK,EAEnBD,EAAU,MAAK,EAI3B,MACQL,EAAY,MAAK,CAEzB,EACI1H,EAAI,iBAAiB,UAAWyH,CAAO,EACvCzH,EAAI,iBAAiB,UAAWuH,EAAW,EAAI,EAQ/C,MAAMU,EAAW,YAAY,IAAM,CAC7BjI,EAAI,eAAiBA,EAAI,cAAc,UAAY,QACrDyH,GAEH,EAAE,EAAE,EACL,MAAO,IAAM,CACX,cAAcQ,CAAQ,EACtBjI,EAAI,oBAAoB,UAAWyH,CAAO,EAC1CzH,EAAI,oBAAoB,UAAWuH,EAAW,EAAI,CACxD,CACA,EAAK,CAACd,EAAkBC,EAAqBC,EAAqBE,EAAWC,EAAMF,CAAW,CAAC,EAC7F,MAAMsB,EAAUtI,GAAS,CACnBsH,EAAc,UAAY,OAC5BA,EAAc,QAAUtH,EAAM,eAEhCwH,EAAU,QAAU,GACpBD,EAAsB,QAAUvH,EAAM,OACtC,MAAMuI,EAAuB3B,EAAS,MAAM,QACxC2B,GACFA,EAAqBvI,CAAK,CAEhC,EACQwI,EAAsBxI,GAAS,CAC/BsH,EAAc,UAAY,OAC5BA,EAAc,QAAUtH,EAAM,eAEhCwH,EAAU,QAAU,EACxB,EACE,OAAoBiB,EAAK,KAACxY,EAAM,SAAU,CACxC,SAAU,CAAcyY,EAAI,IAAC,MAAO,CAClC,SAAUxB,EAAO,EAAI,GACrB,QAASsB,EACT,IAAKpB,EACL,cAAe,eACrB,CAAK,EAAgBnX,EAAM,aAAa2W,EAAU,CAC5C,IAAKnB,EACL,QAAA6C,CACN,CAAK,EAAgBI,EAAI,IAAC,MAAO,CAC3B,SAAUxB,EAAO,EAAI,GACrB,QAASsB,EACT,IAAKnB,EACL,cAAe,aACrB,CAAK,CAAC,CACN,CAAG,CACH,CACA,QAAQ,IAAI,WAAa,eAAeV,GAAU,UAAmC,CAQnF,SAAUlJ,GAUV,iBAAkBC,EAAU,KAQ5B,oBAAqBA,EAAU,KAM/B,oBAAqBA,EAAU,KAM/B,YAAaA,EAAU,KAUvB,UAAWA,EAAU,KAIrB,KAAMA,EAAU,KAAK,UACvB,GACI,QAAQ,IAAI,WAAa,eAE3BiJ,GAAU,WAAgB,EAAI9I,GAAU8I,GAAU,SAAS,GC7U7D,MAAMgC,GAAkC1Y,EAAM,cAAc,MAAS,EACjE,QAAQ,IAAI,WAAa,eAC3B0Y,GAAmB,YAAc,sBCQ5B,SAASC,IAAwB,CACtC,OAAO3Y,EAAM,WAAW0Y,EAAkB,CAC5C,CCEO,SAASE,GAAS/G,EAAa,GAAI,CACxC,KAAM,CACJ,aAAcgH,EACd,SAAUC,EAAe,GACzB,MAAOC,EAAY,GACnB,OAAAC,EACA,SAAAC,EACA,QAAAZ,EACA,SAAUa,EAAe,GACzB,MAAOC,EACP,SAAUC,CACX,EAAGvH,EACEwH,EAAqBV,KAC3B,IAAIW,EACAjG,EACApL,EACAsR,EACAzN,EACJ,GAAIuN,EAAoB,CACtB,IAAIG,EAAuBC,EAAuBC,EAMlD,GALAJ,EAAe,OACfjG,GAAYmG,EAAwBH,EAAmB,WAAa,KAAOG,EAAwB,GACnGvR,GAASwR,EAAwBJ,EAAmB,QAAU,KAAOI,EAAwB,GAC7FF,GAAYG,EAAwBL,EAAmB,WAAa,KAAOK,EAAwB,GACnG5N,EAAQuN,EAAmB,MACvB,QAAQ,IAAI,WAAa,aAAc,CACzC,MAAMM,EAAoB,CAAC,eAAgB,WAAY,QAAS,WAAY,OAAO,EAAE,OAAOlZ,GAAQoR,EAAWpR,CAAI,IAAM,MAAS,EAC9HkZ,EAAkB,OAAS,GAC7B,QAAQ,KAAK,CAAC,oEAAqE,4EAA6E,kBAAkBA,EAAkB,KAAK,IAAI,CAAC,EAAE,EAAE,KAAK;AAAA,CAAI,CAAC,CAE/N,CACL,MACIL,EAAeT,EACfxF,EAAWyF,EACX7Q,EAAQ8Q,EACRQ,EAAWL,EACXpN,EAAQqN,EAEV,KAAM,CACJ,QAASS,CACV,EAAG5Z,EAAM,OAAO8L,GAAS,IAAI,EACxB+N,EAAwB7Z,EAAM,YAAYuP,GAAY,CACtD,QAAQ,IAAI,WAAa,cACvBA,GAAYA,EAAS,WAAa,SAAW,CAACA,EAAS,OACzD,QAAQ,MAAM,CAAC,gEAAiE,iDAAkD,6DAA6D,EAAE,KAAK;AAAA,CAAI,CAAC,CAGhN,EAAE,CAAE,CAAA,EACCuK,EAAW9Z,EAAM,OAAO,IAAI,EAC5B+Z,EAAiB1K,GAAWyK,EAAUV,EAAcS,CAAqB,EACzE,CAACG,EAASC,CAAU,EAAIja,EAAM,SAAS,EAAK,EAIlDA,EAAM,UAAU,IAAM,CAChB,CAACqZ,GAAsBhG,GAAY2G,IACrCC,EAAW,EAAK,EAGhBjB,GAAU,MAAQA,IAErB,EAAE,CAACK,EAAoBhG,EAAU2G,EAAShB,CAAM,CAAC,EAClD,MAAMkB,EAAc/F,GAAiBpE,GAAS,CAC5C,IAAI0E,EAGJ,GAAI4E,GAAsB,MAAQA,EAAmB,SAAU,CAC7DtJ,EAAM,gBAAe,EACrB,MACD,CAED,IADC0E,EAAwBN,EAAc,UAAY,MAAQM,EAAsB,KAAKN,EAAepE,CAAK,EACtGsJ,GAAsBA,EAAmB,QAAS,CACpD,IAAIc,EACJd,GAAsB,OAASc,EAAwBd,EAAmB,UAAY,MAAQc,EAAsB,KAAKd,CAAkB,CACjJ,MACMY,EAAW,EAAI,CAErB,EACQG,EAAajG,GAAiBpE,GAAS,CAC3C,IAAIuE,GACHA,EAAwBH,EAAc,SAAW,MAAQG,EAAsB,KAAKH,EAAepE,CAAK,EACrGsJ,GAAsBA,EAAmB,OAC3CA,EAAmB,OAAM,EAEzBY,EAAW,EAAK,CAEtB,EACQI,EAAelG,GAAiB,CAACpE,KAAU5O,IAAS,CACxD,IAAImZ,EAAwBC,GAC5B,GAAI,CAACX,IACa7J,EAAM,QAAU+J,EAAS,UAC1B,KACb,MAAM,IAAI,MAAM,QAAQ,IAAI,WAAa,aAAe,sKAA0KU,GAAuB,EAAE,CAAC,EAGhQnB,GAAsB,OAASiB,EAAyBjB,EAAmB,WAAa,MAAQiB,EAAuB,KAAKjB,EAAoBtJ,CAAK,GAGpJwK,GAAwBpG,EAAc,WAAa,MAAQoG,GAAsB,KAAKpG,EAAepE,EAAO,GAAG5O,CAAI,CACxH,EACQsZ,EAActG,GAAiBpE,GAAS,CAC5C,IAAI8E,EACAiF,EAAS,SAAW/J,EAAM,gBAAkBA,EAAM,QACpD+J,EAAS,QAAQ,SAElBjF,EAAwBV,EAAc,UAAY,MAAQU,EAAsB,KAAKV,EAAepE,CAAK,CAC9G,EA+BE,MAAO,CACL,SAAAsD,EACA,MAAApL,EACA,QAAA+R,EACA,mBAAAX,EACA,cA3BoB,CAAC3D,EAAgB,KAAO,CAM5C,MAAMC,EAAwBxW,EAAS,CAAE,EALd,CACzB,OAAA6Z,EACA,SAAAC,EACA,QAAAZ,CACN,EACmEhY,GAAqBqV,CAAa,CAAC,EAC5FgF,EAAsBvb,EAAS,CAAE,EAAEwW,EAAuB,CAC9D,OAAQyE,EAAWzE,CAAqB,EACxC,SAAU0E,EAAa1E,CAAqB,EAC5C,QAASuE,EAAYvE,CAAqB,CAChD,CAAK,EACD,OAAOxW,EAAS,CAAE,EAAEub,EAAqB,CACvC,eAAgBzS,GAAS,OACzB,aAAcqR,EACd,MAAOxN,EACP,SAAAyN,EACA,SAAAlG,CACD,EAAEqC,EAAe,CAChB,IAAKqE,CACN,EAAEW,CAAmB,CAC1B,EAOI,aApCmB,CAAChF,EAAgB,KAAO,CAE3C,MAAMiF,EAAqBta,GAAqBwR,EAAY,CAAC,SAAU,WAAY,SAAS,CAAC,EACvF8D,EAAwBxW,EAAS,CAAE,EAAEwb,EAAoBta,GAAqBqV,CAAa,CAAC,EAClG,OAAOvW,EAAS,CAAA,EAAIuW,EAAeC,EAAuB,CACxD,QAAS8E,EAAY9E,CAAqB,CAChD,CAAK,CACL,EA8BI,SAAUoE,EACV,SAAAR,EACA,MAAAzN,CACJ,CACA,CC/JA,SAAS8O,GAAaC,EAAW,CAC/B,OAAO,OAAOA,GAAc,WAAaA,EAAS,EAAKA,CACzD,CAcA,MAAMhW,GAAsB7E,EAAM,WAAW,SAAgB2K,EAAOmQ,EAAc,CAChF,KAAM,CACJ,SAAAnE,EACA,UAAAkE,EACA,cAAAE,EAAgB,EACjB,EAAGpQ,EACE,CAACqQ,EAAWC,CAAY,EAAIjb,EAAM,SAAS,IAAI,EAE/CwV,EAAYnG,GAAyBrP,EAAM,eAAe2W,CAAQ,EAAIA,EAAS,IAAM,KAAMmE,CAAY,EAe7G,GAdA1L,GAAkB,IAAM,CACjB2L,GACHE,EAAaL,GAAaC,CAAS,GAAK,SAAS,IAAI,CAE3D,EAAK,CAACA,EAAWE,CAAa,CAAC,EAC7B3L,GAAkB,IAAM,CACtB,GAAI4L,GAAa,CAACD,EAChBhM,OAAAA,GAAO+L,EAAcE,CAAS,EACvB,IAAM,CACXjM,GAAO+L,EAAc,IAAI,CACjC,CAGG,EAAE,CAACA,EAAcE,EAAWD,CAAa,CAAC,EACvCA,EAAe,CACjB,GAAkB/a,EAAM,eAAe2W,CAAQ,EAAG,CAChD,MAAMuE,EAAW,CACf,IAAK1F,CACb,EACM,OAAoBxV,EAAM,aAAa2W,EAAUuE,CAAQ,CAC1D,CACD,OAAoBzC,EAAI,IAACzY,EAAM,SAAU,CACvC,SAAU2W,CAChB,CAAK,CACF,CACD,OAAoB8B,EAAI,IAACzY,EAAM,SAAU,CACvC,SAAUgb,GAAyBG,GAAS,aAAaxE,EAAUqE,CAAS,CAChF,CAAG,CACH,CAAC,EACD,QAAQ,IAAI,WAAa,eAAenW,GAAO,UAAmC,CAQhF,SAAU4I,EAAU,KAQpB,UAAWA,EAAgD,UAAU,CAACS,GAAiBT,EAAU,IAAI,CAAC,EAKtG,cAAeA,EAAU,IAC3B,GACI,QAAQ,IAAI,WAAa,eAE3B5I,GAAO,WAAgB,EAAI+I,GAAU/I,GAAO,SAAS,GCpFvD,SAASuW,GAAcP,EAAW,CAChC,MAAM1K,EAAMvB,GAAciM,CAAS,EACnC,OAAI1K,EAAI,OAAS0K,EACR/L,GAAY+L,CAAS,EAAE,WAAa1K,EAAI,gBAAgB,YAE1D0K,EAAU,aAAeA,EAAU,YAC5C,CACO,SAASQ,GAAW5b,EAAS6b,EAAM,CACpCA,EACF7b,EAAQ,aAAa,cAAe,MAAM,EAE1CA,EAAQ,gBAAgB,aAAa,CAEzC,CACA,SAAS8b,GAAgB9b,EAAS,CAChC,OAAO,SAASqP,GAAYrP,CAAO,EAAE,iBAAiBA,CAAO,EAAE,aAAc,EAAE,GAAK,CACtF,CACA,SAAS+b,GAA+B/b,EAAS,CAK/C,MAAMgc,EADoB,CAAC,WAAY,SAAU,QAAS,OAAQ,MAAO,OAAQ,WAAY,UAAW,MAAO,WAAY,QAAS,OAAQ,SAAU,OAAO,EAChH,QAAQhc,EAAQ,OAAO,IAAM,GACpEic,EAAgBjc,EAAQ,UAAY,SAAWA,EAAQ,aAAa,MAAM,IAAM,SACtF,OAAOgc,GAAsBC,CAC/B,CACA,SAASC,GAAmBd,EAAWe,EAAcC,EAAgBC,EAAmBR,EAAM,CAC5F,MAAMS,EAAY,CAACH,EAAcC,EAAgB,GAAGC,CAAiB,EACrE,CAAA,EAAG,QAAQ,KAAKjB,EAAU,SAAUpb,GAAW,CAC7C,MAAMuc,EAAuBD,EAAU,QAAQtc,CAAO,IAAM,GACtDwc,EAAwB,CAACT,GAA+B/b,CAAO,EACjEuc,GAAwBC,GAC1BZ,GAAW5b,EAAS6b,CAAI,CAE9B,CAAG,CACH,CACA,SAASY,GAAYC,EAAOC,EAAU,CACpC,IAAIC,EAAM,GACV,OAAAF,EAAM,KAAK,CAACG,EAAMC,IACZH,EAASE,CAAI,GACfD,EAAME,EACC,IAEF,EACR,EACMF,CACT,CACA,SAASG,GAAgBC,EAAe9R,EAAO,CAC7C,MAAM+R,EAAe,CAAA,EACf7B,EAAY4B,EAAc,UAChC,GAAI,CAAC9R,EAAM,kBAAmB,CAC5B,GAAIyQ,GAAcP,CAAS,EAAG,CAE5B,MAAM8B,EAAgBlM,GAAiB7B,GAAciM,CAAS,CAAC,EAC/D6B,EAAa,KAAK,CAChB,MAAO7B,EAAU,MAAM,aACvB,SAAU,gBACV,GAAIA,CACZ,CAAO,EAEDA,EAAU,MAAM,aAAe,GAAGU,GAAgBV,CAAS,EAAI8B,CAAa,KAG5E,MAAMC,EAAgBhO,GAAciM,CAAS,EAAE,iBAAiB,YAAY,EAC5E,CAAA,EAAG,QAAQ,KAAK+B,EAAend,GAAW,CACxCid,EAAa,KAAK,CAChB,MAAOjd,EAAQ,MAAM,aACrB,SAAU,gBACV,GAAIA,CACd,CAAS,EACDA,EAAQ,MAAM,aAAe,GAAG8b,GAAgB9b,CAAO,EAAIkd,CAAa,IAChF,CAAO,CACF,CACD,IAAIE,EACJ,GAAIhC,EAAU,sBAAsB,iBAClCgC,EAAkBjO,GAAciM,CAAS,EAAE,SACtC,CAGL,MAAMiC,EAASjC,EAAU,cACnBkC,EAAkBjO,GAAY+L,CAAS,EAC7CgC,GAAmBC,GAAU,KAAO,OAASA,EAAO,YAAc,QAAUC,EAAgB,iBAAiBD,CAAM,EAAE,YAAc,SAAWA,EAASjC,CACxJ,CAID6B,EAAa,KAAK,CAChB,MAAOG,EAAgB,MAAM,SAC7B,SAAU,WACV,GAAIA,CACV,EAAO,CACD,MAAOA,EAAgB,MAAM,UAC7B,SAAU,aACV,GAAIA,CACV,EAAO,CACD,MAAOA,EAAgB,MAAM,UAC7B,SAAU,aACV,GAAIA,CACV,CAAK,EACDA,EAAgB,MAAM,SAAW,QAClC,CAcD,MAbgB,IAAM,CACpBH,EAAa,QAAQ,CAAC,CACpB,MAAA5Q,EACA,GAAAkR,EACA,SAAAC,CACN,IAAU,CACAnR,EACFkR,EAAG,MAAM,YAAYC,EAAUnR,CAAK,EAEpCkR,EAAG,MAAM,eAAeC,CAAQ,CAExC,CAAK,CACL,CAEA,CACA,SAASC,GAAkBrC,EAAW,CACpC,MAAMsC,EAAiB,CAAA,EACvB,OAAA,EAAG,QAAQ,KAAKtC,EAAU,SAAUpb,GAAW,CACzCA,EAAQ,aAAa,aAAa,IAAM,QAC1C0d,EAAe,KAAK1d,CAAO,CAEjC,CAAG,EACM0d,CACT,CAQO,MAAMC,EAAa,CACxB,aAAc,CACZ,KAAK,WAAa,OAClB,KAAK,OAAS,OACd,KAAK,OAAS,GACd,KAAK,WAAa,EACnB,CACD,IAAIC,EAAOxC,EAAW,CACpB,IAAIyC,EAAa,KAAK,OAAO,QAAQD,CAAK,EAC1C,GAAIC,IAAe,GACjB,OAAOA,EAETA,EAAa,KAAK,OAAO,OACzB,KAAK,OAAO,KAAKD,CAAK,EAGlBA,EAAM,UACRhC,GAAWgC,EAAM,SAAU,EAAK,EAElC,MAAMF,EAAiBD,GAAkBrC,CAAS,EAClDc,GAAmBd,EAAWwC,EAAM,MAAOA,EAAM,SAAUF,EAAgB,EAAI,EAC/E,MAAMI,EAAiBrB,GAAY,KAAK,WAAYI,GAAQA,EAAK,YAAczB,CAAS,EACxF,OAAI0C,IAAmB,IACrB,KAAK,WAAWA,CAAc,EAAE,OAAO,KAAKF,CAAK,EAC1CC,IAET,KAAK,WAAW,KAAK,CACnB,OAAQ,CAACD,CAAK,EACd,UAAAxC,EACA,QAAS,KACT,eAAAsC,CACN,CAAK,EACMG,EACR,CACD,MAAMD,EAAO1S,EAAO,CAClB,MAAM4S,EAAiBrB,GAAY,KAAK,WAAYI,GAAQA,EAAK,OAAO,QAAQe,CAAK,IAAM,EAAE,EACvFZ,EAAgB,KAAK,WAAWc,CAAc,EAC/Cd,EAAc,UACjBA,EAAc,QAAUD,GAAgBC,EAAe9R,CAAK,EAE/D,CACD,OAAO0S,EAAOG,EAAkB,GAAM,CACpC,MAAMF,EAAa,KAAK,OAAO,QAAQD,CAAK,EAC5C,GAAIC,IAAe,GACjB,OAAOA,EAET,MAAMC,EAAiBrB,GAAY,KAAK,WAAYI,GAAQA,EAAK,OAAO,QAAQe,CAAK,IAAM,EAAE,EACvFZ,EAAgB,KAAK,WAAWc,CAAc,EAKpD,GAJAd,EAAc,OAAO,OAAOA,EAAc,OAAO,QAAQY,CAAK,EAAG,CAAC,EAClE,KAAK,OAAO,OAAOC,EAAY,CAAC,EAG5Bb,EAAc,OAAO,SAAW,EAE9BA,EAAc,SAChBA,EAAc,QAAO,EAEnBY,EAAM,UAERhC,GAAWgC,EAAM,SAAUG,CAAe,EAE5C7B,GAAmBc,EAAc,UAAWY,EAAM,MAAOA,EAAM,SAAUZ,EAAc,eAAgB,EAAK,EAC5G,KAAK,WAAW,OAAOc,EAAgB,CAAC,MACnC,CAEL,MAAME,EAAUhB,EAAc,OAAOA,EAAc,OAAO,OAAS,CAAC,EAIhEgB,EAAQ,UACVpC,GAAWoC,EAAQ,SAAU,EAAK,CAErC,CACD,OAAOH,CACR,CACD,WAAWD,EAAO,CAChB,OAAO,KAAK,OAAO,OAAS,GAAK,KAAK,OAAO,KAAK,OAAO,OAAS,CAAC,IAAMA,CAC1E,CACH,CC7MA,SAASzC,GAAaC,EAAW,CAC/B,OAAO,OAAOA,GAAc,WAAaA,EAAS,EAAKA,CACzD,CACA,SAAS6C,GAAiB/G,EAAU,CAClC,OAAOA,EAAWA,EAAS,MAAM,eAAe,IAAI,EAAI,EAC1D,CAIA,MAAMgH,GAAiB,IAAIP,GAWpB,SAASQ,GAAS/L,EAAY,CACnC,KAAM,CACJ,UAAAgJ,EACA,qBAAAgD,EAAuB,GACvB,kBAAAC,EAAoB,GAEpB,QAAAC,EAAUJ,GACV,qBAAAK,EAAuB,GACvB,kBAAAC,EACA,mBAAAC,EACA,SAAAvH,EACA,QAAAwH,EACA,KAAAlH,EACA,QAAAO,CACD,EAAG3F,EAGEwL,EAAQrd,EAAM,OAAO,CAAE,CAAA,EACvBoe,EAAepe,EAAM,OAAO,IAAI,EAChCqe,EAAWre,EAAM,OAAO,IAAI,EAC5BwV,EAAYnG,GAAWgP,EAAU7G,CAAO,EACxC,CAAC8G,EAAQC,CAAS,EAAIve,EAAM,SAAS,CAACiX,CAAI,EAC1CuH,EAAgBd,GAAiB/G,CAAQ,EAC/C,IAAI8H,EAAiB,IACjB5M,EAAW,aAAa,IAAM,SAAWA,EAAW,aAAa,IAAM,MACzE4M,EAAiB,IAEnB,MAAMC,EAAS,IAAM9P,GAAcwP,EAAa,OAAO,EACjDO,EAAW,KACftB,EAAM,QAAQ,SAAWgB,EAAS,QAClChB,EAAM,QAAQ,MAAQe,EAAa,QAC5Bf,EAAM,SAETuB,EAAgB,IAAM,CAC1Bb,EAAQ,MAAMY,IAAY,CACxB,kBAAAb,CACN,CAAK,EAGGO,EAAS,UACXA,EAAS,QAAQ,UAAY,EAEnC,EACQQ,EAAa3P,GAAiB,IAAM,CACxC,MAAM4P,EAAoBlE,GAAaC,CAAS,GAAK6D,EAAM,EAAG,KAC9DX,EAAQ,IAAIY,EAAU,EAAEG,CAAiB,EAGrCT,EAAS,SACXO,GAEN,CAAG,EACKG,EAAa/e,EAAM,YAAY,IAAM+d,EAAQ,WAAWY,GAAU,EAAG,CAACZ,CAAO,CAAC,EAC9EiB,EAAkB9P,GAAiBL,GAAQ,CAC/CuP,EAAa,QAAUvP,EAClBA,IAGDoI,GAAQ8H,IACVH,IACSP,EAAS,SAClBhD,GAAWgD,EAAS,QAASI,CAAc,EAEjD,CAAG,EACKQ,EAAcjf,EAAM,YAAY,IAAM,CAC1C+d,EAAQ,OAAOY,EAAU,EAAEF,CAAc,CAC7C,EAAK,CAACA,EAAgBV,CAAO,CAAC,EAC5B/d,EAAM,UAAU,IACP,IAAM,CACXif,GACN,EACK,CAACA,CAAW,CAAC,EAChBjf,EAAM,UAAU,IAAM,CAChBiX,EACF4H,KACS,CAACL,GAAiB,CAACR,IAC5BiB,GAEN,EAAK,CAAChI,EAAMgI,EAAaT,EAAeR,EAAsBa,CAAU,CAAC,EACvE,MAAM7J,EAAsBb,GAAiBpE,GAAS,CACpD,IAAIkF,GACHA,EAAwBd,EAAc,YAAc,MAAQc,EAAsB,KAAKd,EAAepE,CAAK,EAQxG,EAAAA,EAAM,MAAQ,UAAYA,EAAM,QAAU,KAE9C,CAACgP,EAAU,KAGNlB,IAEH9N,EAAM,gBAAe,EACjBoO,GACFA,EAAQpO,EAAO,eAAe,GAGtC,EACQmP,EAA4B/K,GAAiBpE,GAAS,CAC1D,IAAI8E,GACHA,EAAwBV,EAAc,UAAY,MAAQU,EAAsB,KAAKV,EAAepE,CAAK,EACtGA,EAAM,SAAWA,EAAM,eAGvBoO,GACFA,EAAQpO,EAAO,eAAe,CAEpC,EA6CE,MAAO,CACL,aA7CmB,CAACoE,EAAgB,KAAO,CAC3C,MAAMwG,EAAqBta,GAAqBwR,CAAU,EAG1D,OAAO8I,EAAmB,kBAC1B,OAAOA,EAAmB,mBAC1B,MAAMhF,EAAwBxW,EAAS,CAAE,EAAEwb,EAAoBxG,CAAa,EAC5E,OAAOhV,EAAS,CACd,KAAM,cACP,EAAEwW,EAAuB,CACxB,UAAWX,EAAoBW,CAAqB,EACpD,IAAKH,CACX,CAAK,CACL,EAiCI,iBAhCuB,CAACrB,EAAgB,KAAO,CAC/C,MAAMwB,EAAwBxB,EAC9B,OAAOhV,EAAS,CACd,cAAe,EAChB,EAAEwW,EAAuB,CACxB,QAASuJ,EAA0BvJ,CAAqB,EACxD,KAAAsB,CACN,CAAK,CACL,EAyBI,mBAxByB,IAAM,CAC/B,MAAMkI,EAAc,IAAM,CACxBZ,EAAU,EAAK,EACXN,GACFA,GAER,EACUmB,EAAe,IAAM,CACzBb,EAAU,EAAI,EACVL,GACFA,IAEEF,GACFiB,GAER,EACI,MAAO,CACL,QAAS9Q,GAAsBgR,EAAaxI,GAAY,KAAO,OAASA,EAAS,MAAM,OAAO,EAC9F,SAAUxI,GAAsBiR,EAAczI,GAAY,KAAO,OAASA,EAAS,MAAM,QAAQ,CACvG,CACA,EAKI,QAASnB,EACT,UAAWwJ,EACX,WAAAD,EACA,OAAAT,EACA,cAAAE,CACJ,CACA,CC/LO,SAASa,GAAqBjf,EAAM,CACzC,OAAOF,GAAqB,WAAYE,CAAI,CAC9C,CAC4BqR,GAAuB,WAAY,CAAC,OAAQ,SAAU,UAAU,CAAC,ECD7F,MAAMgB,GAAY,CAAC,WAAY,uBAAwB,YAAa,mBAAoB,sBAAuB,uBAAwB,gBAAiB,sBAAuB,oBAAqB,eAAgB,cAAe,kBAAmB,UAAW,YAAa,OAAQ,oBAAqB,qBAAsB,YAAa,OAAO,EAa/U6M,GAAoBzf,GAAc,CACtC,KAAM,CACJ,KAAAoX,EACA,OAAAqH,CACD,EAAGze,EAKJ,OAAO8Q,GAJO,CACZ,KAAM,CAAC,OAAQ,CAACsG,GAAQqH,GAAU,QAAQ,EAC1C,SAAU,CAAC,UAAU,CACzB,EAC+Bre,GAAsBof,EAAoB,CAAC,CAC1E,EAuBME,GAAqBvf,EAAM,WAAW,SAAe2K,EAAOmQ,EAAc,CAC9E,IAAI0E,EACJ,KAAM,CACF,SAAA7I,EACA,qBAAAqH,EAAuB,GACvB,UAAAnD,EACA,iBAAAjE,EAAmB,GACnB,oBAAAC,EAAsB,GACtB,qBAAAgH,EAAuB,GACvB,cAAA9C,EAAgB,GAChB,oBAAAjE,EAAsB,GACtB,kBAAAgH,EAAoB,GACpB,aAAA2B,EAAe,GACf,YAAAC,EAAc,GACd,gBAAAC,EACA,KAAA1I,EACA,UAAA2I,EAAY,CAAE,EACd,MAAAhP,EAAQ,CAAE,CAChB,EAAQjG,EACJwI,EAAQtS,GAA8B8J,EAAO8H,EAAS,EAClDoN,EAAoB1gB,EAAS,CAAE,EAAEwL,EAAO,CAC5C,qBAAAqT,EACA,iBAAApH,EACA,oBAAAC,EACA,qBAAAgH,EACA,cAAA9C,EACA,oBAAAjE,EACA,kBAAAgH,EACA,aAAA2B,EACA,YAAAC,CACJ,CAAG,EACK,CACJ,aAAAI,EACA,iBAAAC,EACA,mBAAAC,EACA,UAAAC,EACA,WAAAlB,EACA,OAAAT,EACA,cAAAE,CACD,EAAGZ,GAASze,EAAS,CAAE,EAAE0gB,EAAmB,CAC3C,QAAS/E,CACV,CAAA,CAAC,EACIjb,EAAaV,EAAS,CAAE,EAAE0gB,EAAmB,CACjD,OAAAvB,EACA,cAAAE,CACJ,CAAG,EACK1N,EAAUwO,GAAkBzf,CAAU,EACtCqgB,EAAa,CAAA,EAMnB,GALIvJ,EAAS,MAAM,WAAa,SAC9BuJ,EAAW,SAAW,MAIpB1B,EAAe,CACjB,KAAM,CACJ,QAAA2B,GACA,SAAAC,CACD,EAAGJ,EAAkB,EACtBE,EAAW,QAAUC,GACrBD,EAAW,SAAWE,CACvB,CACD,MAAMC,GAAQb,EAAc5O,EAAM,OAAS,KAAO4O,EAAc,MAC1Dc,EAAY5N,GAAa,CAC7B,YAAa2N,EACb,kBAAmBT,EAAU,KAC7B,uBAAwBzM,EACxB,aAAc2M,EACd,UAAWhP,EAAQ,KACnB,WAAAjR,CACJ,CAAG,EACK0gB,EAAoB3P,EAAM,SAC1B4P,EAAgB9N,GAAa,CACjC,YAAa6N,EACb,kBAAmBX,EAAU,SAC7B,aAAczL,IACL4L,EAAiB5gB,EAAS,CAAE,EAAEgV,GAAe,CAClD,QAAS5S,GAAK,CACRoe,GACFA,EAAgBpe,CAAC,EAEf4S,IAAiB,MAAQA,GAAc,SACzCA,GAAc,QAAQ5S,CAAC,CAE1B,CACF,CAAA,CAAC,EAEJ,UAAWuP,EAAQ,SACnB,WAAAjR,CACJ,CAAG,EACD,MAAI,CAAC6f,GAAe,CAACzI,IAAS,CAACuH,GAAiBF,GACvC,KAEW7F,EAAAA,IAAK5T,GAAQ,CAC/B,IAAKob,EACL,UAAWpF,EACX,cAAeE,EACf,SAAuBvC,EAAAA,KAAM6H,EAAMlhB,EAAS,CAAA,EAAImhB,EAAW,CACzD,SAAU,CAAC,CAACb,GAAgBc,EAAiC9H,EAAI,IAAC8H,EAAmBphB,EAAS,CAAA,EAAIqhB,CAAa,CAAC,EAAI,KAAmB/H,EAAAA,IAAK/B,GAAW,CACrJ,oBAAqBG,EACrB,iBAAkBD,EAClB,oBAAqBE,EACrB,UAAWiI,EACX,KAAM9H,EACN,SAAuBjX,EAAM,aAAa2W,EAAUuJ,CAAU,CACtE,CAAO,CAAC,CACR,CAAK,CAAC,CACN,CAAG,CACH,CAAC,EACD,QAAQ,IAAI,WAAa,eAAeX,GAAM,UAAmC,CAQ/E,SAAU/R,GAAoB,WAK9B,qBAAsBC,EAAU,KAQhC,UAAWA,EAAgD,UAAU,CAACS,GAAiBT,EAAU,IAAI,CAAC,EAUtG,iBAAkBA,EAAU,KAQ5B,oBAAqBA,EAAU,KAK/B,qBAAsBA,EAAU,KAKhC,cAAeA,EAAU,KAMzB,oBAAqBA,EAAU,KAK/B,kBAAmBA,EAAU,KAK7B,aAAcA,EAAU,KAOxB,YAAaA,EAAU,KAKvB,gBAAiBA,EAAU,KAQ3B,QAASA,EAAU,KAInB,kBAAmBA,EAAU,KAI7B,mBAAoBA,EAAU,KAI9B,KAAMA,EAAU,KAAK,WAKrB,UAAWA,EAAU,MAAM,CACzB,SAAUA,EAAU,UAAU,CAACA,EAAU,KAAMA,EAAU,MAAM,CAAC,EAChE,KAAMA,EAAU,UAAU,CAACA,EAAU,KAAMA,EAAU,MAAM,CAAC,CAChE,CAAG,EAMD,MAAOA,EAAU,MAAM,CACrB,SAAUA,EAAU,YACpB,KAAMA,EAAU,WACpB,CAAG,CACH,GC9QA,MAAMgT,GAAM,KAAK,IACXC,GAAM,KAAK,IACXC,GAAQ,KAAK,MACbC,GAAQ,KAAK,MACbC,GAAe1e,IAAM,CACzB,EAAGA,EACH,EAAGA,CACL,GACM2e,GAAkB,CACtB,KAAM,QACN,MAAO,OACP,OAAQ,MACR,IAAK,QACP,EACMC,GAAuB,CAC3B,MAAO,MACP,IAAK,OACP,EACA,SAASC,GAAMC,EAAOnV,EAAOoV,EAAK,CAChC,OAAOR,GAAIO,EAAOR,GAAI3U,EAAOoV,CAAG,CAAC,CACnC,CACA,SAASC,GAASrV,EAAOsV,EAAO,CAC9B,OAAO,OAAOtV,GAAU,WAAaA,EAAMsV,CAAK,EAAItV,CACtD,CACA,SAASuV,GAAQC,EAAW,CAC1B,OAAOA,EAAU,MAAM,GAAG,EAAE,CAAC,CAC/B,CACA,SAASC,GAAaD,EAAW,CAC/B,OAAOA,EAAU,MAAM,GAAG,EAAE,CAAC,CAC/B,CACA,SAASE,GAAgBC,EAAM,CAC7B,OAAOA,IAAS,IAAM,IAAM,GAC9B,CACA,SAASC,GAAcD,EAAM,CAC3B,OAAOA,IAAS,IAAM,SAAW,OACnC,CACA,SAASE,GAAYL,EAAW,CAC9B,MAAO,CAAC,MAAO,QAAQ,EAAE,SAASD,GAAQC,CAAS,CAAC,EAAI,IAAM,GAChE,CACA,SAASM,GAAiBN,EAAW,CACnC,OAAOE,GAAgBG,GAAYL,CAAS,CAAC,CAC/C,CACA,SAASO,GAAkBP,EAAWQ,EAAOC,EAAK,CAC5CA,IAAQ,SACVA,EAAM,IAER,MAAMC,EAAYT,GAAaD,CAAS,EAClCW,EAAgBL,GAAiBN,CAAS,EAC1CY,EAASR,GAAcO,CAAa,EAC1C,IAAIE,EAAoBF,IAAkB,IAAMD,KAAeD,EAAM,MAAQ,SAAW,QAAU,OAASC,IAAc,QAAU,SAAW,MAC9I,OAAIF,EAAM,UAAUI,CAAM,EAAIJ,EAAM,SAASI,CAAM,IACjDC,EAAoBC,GAAqBD,CAAiB,GAErD,CAACA,EAAmBC,GAAqBD,CAAiB,CAAC,CACpE,CACA,SAASE,GAAsBf,EAAW,CACxC,MAAMgB,EAAoBF,GAAqBd,CAAS,EACxD,MAAO,CAACiB,GAA8BjB,CAAS,EAAGgB,EAAmBC,GAA8BD,CAAiB,CAAC,CACvH,CACA,SAASC,GAA8BjB,EAAW,CAChD,OAAOA,EAAU,QAAQ,aAAcU,GAAajB,GAAqBiB,CAAS,CAAC,CACrF,CACA,SAASQ,GAAYC,EAAMC,EAASX,EAAK,CACvC,MAAMY,EAAK,CAAC,OAAQ,OAAO,EACrBC,EAAK,CAAC,QAAS,MAAM,EACrBC,EAAK,CAAC,MAAO,QAAQ,EACrBC,EAAK,CAAC,SAAU,KAAK,EAC3B,OAAQL,EAAI,CACV,IAAK,MACL,IAAK,SACH,OAAIV,EAAYW,EAAUE,EAAKD,EACxBD,EAAUC,EAAKC,EACxB,IAAK,OACL,IAAK,QACH,OAAOF,EAAUG,EAAKC,EACxB,QACE,MAAO,EACV,CACH,CACA,SAASC,GAA0BzB,EAAW0B,EAAeC,EAAWlB,EAAK,CAC3E,MAAMC,EAAYT,GAAaD,CAAS,EACxC,IAAI4B,EAAOV,GAAYnB,GAAQC,CAAS,EAAG2B,IAAc,QAASlB,CAAG,EACrE,OAAIC,IACFkB,EAAOA,EAAK,IAAIT,GAAQA,EAAO,IAAMT,CAAS,EAC1CgB,IACFE,EAAOA,EAAK,OAAOA,EAAK,IAAIX,EAA6B,CAAC,IAGvDW,CACT,CACA,SAASd,GAAqBd,EAAW,CACvC,OAAOA,EAAU,QAAQ,yBAA0BmB,GAAQ3B,GAAgB2B,CAAI,CAAC,CAClF,CACA,SAASU,GAAoBC,EAAS,CACpC,MAAO,CACL,IAAK,EACL,MAAO,EACP,OAAQ,EACR,KAAM,EACN,GAAGA,CACP,CACA,CACA,SAASC,GAAiBD,EAAS,CACjC,OAAO,OAAOA,GAAY,SAAWD,GAAoBC,CAAO,EAAI,CAClE,IAAKA,EACL,MAAOA,EACP,OAAQA,EACR,KAAMA,CACV,CACA,CACA,SAASE,GAAiBC,EAAM,CAC9B,MAAO,CACL,GAAGA,EACH,IAAKA,EAAK,EACV,KAAMA,EAAK,EACX,MAAOA,EAAK,EAAIA,EAAK,MACrB,OAAQA,EAAK,EAAIA,EAAK,MAC1B,CACA,CCtHA,SAASC,GAA2BC,EAAMnC,EAAWS,EAAK,CACxD,GAAI,CACF,UAAA2B,EACA,SAAAC,CACD,EAAGF,EACJ,MAAMG,EAAWjC,GAAYL,CAAS,EAChCW,EAAgBL,GAAiBN,CAAS,EAC1CuC,EAAcnC,GAAcO,CAAa,EACzCQ,EAAOpB,GAAQC,CAAS,EACxBwC,EAAaF,IAAa,IAC1BG,EAAUL,EAAU,EAAIA,EAAU,MAAQ,EAAIC,EAAS,MAAQ,EAC/DK,EAAUN,EAAU,EAAIA,EAAU,OAAS,EAAIC,EAAS,OAAS,EACjEM,EAAcP,EAAUG,CAAW,EAAI,EAAIF,EAASE,CAAW,EAAI,EACzE,IAAIK,EACJ,OAAQzB,EAAI,CACV,IAAK,MACHyB,EAAS,CACP,EAAGH,EACH,EAAGL,EAAU,EAAIC,EAAS,MAClC,EACM,MACF,IAAK,SACHO,EAAS,CACP,EAAGH,EACH,EAAGL,EAAU,EAAIA,EAAU,MACnC,EACM,MACF,IAAK,QACHQ,EAAS,CACP,EAAGR,EAAU,EAAIA,EAAU,MAC3B,EAAGM,CACX,EACM,MACF,IAAK,OACHE,EAAS,CACP,EAAGR,EAAU,EAAIC,EAAS,MAC1B,EAAGK,CACX,EACM,MACF,QACEE,EAAS,CACP,EAAGR,EAAU,EACb,EAAGA,EAAU,CACrB,CACG,CACD,OAAQnC,GAAaD,CAAS,EAAC,CAC7B,IAAK,QACH4C,EAAOjC,CAAa,GAAKgC,GAAelC,GAAO+B,EAAa,GAAK,GACjE,MACF,IAAK,MACHI,EAAOjC,CAAa,GAAKgC,GAAelC,GAAO+B,EAAa,GAAK,GACjE,KACH,CACD,OAAOI,CACT,CASA,MAAMC,GAAkB,MAAOT,EAAWC,EAAUS,IAAW,CAC7D,KAAM,CACJ,UAAA9C,EAAY,SACZ,SAAA+C,EAAW,WACX,WAAAC,EAAa,CAAE,EACf,SAAAC,CACD,EAAGH,EACEI,EAAkBF,EAAW,OAAO,OAAO,EAC3CvC,EAAM,MAAOwC,EAAS,OAAS,KAAO,OAASA,EAAS,MAAMZ,CAAQ,GAC5E,IAAI7B,EAAQ,MAAMyC,EAAS,gBAAgB,CACzC,UAAAb,EACA,SAAAC,EACA,SAAAU,CACJ,CAAG,EACG,CACF,EAAAhiB,EACA,EAAAC,CACD,EAAGkhB,GAA2B1B,EAAOR,EAAWS,CAAG,EAChD0C,EAAoBnD,EACpBoD,EAAiB,CAAA,EACjBC,EAAa,EACjB,QAAStlB,EAAI,EAAGA,EAAImlB,EAAgB,OAAQnlB,IAAK,CAC/C,KAAM,CACJ,KAAAulB,EACA,GAAAzV,CACN,EAAQqV,EAAgBnlB,CAAC,EACf,CACJ,EAAGwlB,EACH,EAAGC,EACH,KAAA1a,EACA,MAAA2a,CACD,EAAG,MAAM5V,EAAG,CACX,EAAA9M,EACA,EAAAC,EACA,iBAAkBgf,EAClB,UAAWmD,EACX,SAAAJ,EACA,eAAAK,EACA,MAAA5C,EACA,SAAAyC,EACA,SAAU,CACR,UAAAb,EACA,SAAAC,CACD,CACP,CAAK,EAUD,GATAthB,EAAIwiB,GAAwBxiB,EAC5BC,EAAIwiB,GAAwBxiB,EAC5BoiB,EAAiB,CACf,GAAGA,EACH,CAACE,CAAI,EAAG,CACN,GAAGF,EAAeE,CAAI,EACtB,GAAGxa,CACJ,CACP,EACQ2a,GAASJ,GAAc,GAAI,CAC7BA,IACI,OAAOI,GAAU,WACfA,EAAM,YACRN,EAAoBM,EAAM,WAExBA,EAAM,QACRjD,EAAQiD,EAAM,QAAU,GAAO,MAAMR,EAAS,gBAAgB,CAC5D,UAAAb,EACA,SAAAC,EACA,SAAAU,CACZ,CAAW,EAAIU,EAAM,OAEZ,CACC,EAAA1iB,EACA,EAAAC,CACD,EAAGkhB,GAA2B1B,EAAO2C,EAAmB1C,CAAG,GAE9D1iB,EAAI,GACJ,QACD,CACF,CACD,MAAO,CACL,EAAAgD,EACA,EAAAC,EACA,UAAWmiB,EACX,SAAAJ,EACA,eAAAK,CACJ,CACA,EAUA,eAAeM,GAAeC,EAAOC,EAAS,CAC5C,IAAIC,EACAD,IAAY,SACdA,EAAU,CAAA,GAEZ,KAAM,CACJ,EAAA7iB,EACA,EAAAC,EACA,SAAAiiB,EACA,MAAAzC,EACA,SAAAsD,EACA,SAAAf,CACD,EAAGY,EACE,CACJ,SAAAI,EAAW,oBACX,aAAAC,EAAe,WACf,eAAAC,EAAiB,WACjB,YAAAC,EAAc,GACd,QAAApC,EAAU,CACd,EAAMjC,GAAS+D,EAASD,CAAK,EACrBQ,EAAgBpC,GAAiBD,CAAO,EAExC3jB,EAAU2lB,EAASI,EADND,IAAmB,WAAa,YAAc,WACbA,CAAc,EAC5DG,EAAqBpC,GAAiB,MAAMiB,EAAS,gBAAgB,CACzE,SAAWY,EAAwB,MAAOZ,EAAS,WAAa,KAAO,OAASA,EAAS,UAAU9kB,CAAO,KAAO,MAAO0lB,EAAgC1lB,EAAUA,EAAQ,gBAAmB,MAAO8kB,EAAS,oBAAsB,KAAO,OAASA,EAAS,mBAAmBa,EAAS,QAAQ,GAChS,SAAAC,EACA,aAAAC,EACA,SAAAjB,CACD,CAAA,CAAC,EACId,EAAOgC,IAAmB,WAAa,CAC3C,GAAGzD,EAAM,SACT,EAAAzf,EACA,EAAAC,CACJ,EAAMwf,EAAM,UACJ6D,EAAe,MAAOpB,EAAS,iBAAmB,KAAO,OAASA,EAAS,gBAAgBa,EAAS,QAAQ,GAC5GQ,EAAe,MAAOrB,EAAS,WAAa,KAAO,OAASA,EAAS,UAAUoB,CAAY,GAAO,MAAOpB,EAAS,UAAY,KAAO,OAASA,EAAS,SAASoB,CAAY,IAAO,CACvL,EAAG,EACH,EAAG,CACP,EAAM,CACF,EAAG,EACH,EAAG,CACP,EACQE,EAAoBvC,GAAiBiB,EAAS,sDAAwD,MAAMA,EAAS,sDAAsD,CAC/K,KAAAhB,EACA,aAAAoC,EACA,SAAAtB,CACJ,CAAG,EAAId,CAAI,EACT,MAAO,CACL,KAAMmC,EAAmB,IAAMG,EAAkB,IAAMJ,EAAc,KAAOG,EAAY,EACxF,QAASC,EAAkB,OAASH,EAAmB,OAASD,EAAc,QAAUG,EAAY,EACpG,MAAOF,EAAmB,KAAOG,EAAkB,KAAOJ,EAAc,MAAQG,EAAY,EAC5F,OAAQC,EAAkB,MAAQH,EAAmB,MAAQD,EAAc,OAASG,EAAY,CACpG,CACA,CAOA,MAAME,GAAQZ,IAAY,CACxB,KAAM,QACN,QAAAA,EACA,MAAM,GAAGD,EAAO,CACd,KAAM,CACJ,EAAA5iB,EACA,EAAAC,EACA,UAAAgf,EACA,MAAAQ,EACA,SAAAyC,EACA,SAAAa,EACA,eAAAV,CACD,EAAGO,EAEE,CACJ,QAAAxlB,EACA,QAAA2jB,EAAU,CACX,EAAGjC,GAAS+D,EAASD,CAAK,GAAK,CAAA,EAChC,GAAIxlB,GAAW,KACb,MAAO,GAET,MAAMgmB,EAAgBpC,GAAiBD,CAAO,EACxCc,EAAS,CACb,EAAA7hB,EACA,EAAAC,CACN,EACUmf,EAAOG,GAAiBN,CAAS,EACjCY,EAASR,GAAcD,CAAI,EAC3BsE,EAAkB,MAAMxB,EAAS,cAAc9kB,CAAO,EACtDumB,EAAUvE,IAAS,IACnBwE,EAAUD,EAAU,MAAQ,OAC5BE,EAAUF,EAAU,SAAW,QAC/BG,EAAaH,EAAU,eAAiB,cACxCI,EAAUtE,EAAM,UAAUI,CAAM,EAAIJ,EAAM,UAAUL,CAAI,EAAIyC,EAAOzC,CAAI,EAAIK,EAAM,SAASI,CAAM,EAChGmE,EAAYnC,EAAOzC,CAAI,EAAIK,EAAM,UAAUL,CAAI,EAC/C6E,EAAoB,MAAO/B,EAAS,iBAAmB,KAAO,OAASA,EAAS,gBAAgB9kB,CAAO,GAC7G,IAAI8mB,EAAaD,EAAoBA,EAAkBH,CAAU,EAAI,GAGjE,CAACI,GAAc,CAAE,MAAOhC,EAAS,WAAa,KAAO,OAASA,EAAS,UAAU+B,CAAiB,MACpGC,EAAanB,EAAS,SAASe,CAAU,GAAKrE,EAAM,SAASI,CAAM,GAErE,MAAMsE,EAAoBJ,EAAU,EAAIC,EAAY,EAI9CI,EAAyBF,EAAa,EAAIR,EAAgB7D,CAAM,EAAI,EAAI,EACxEwE,EAAajG,GAAIgF,EAAcQ,CAAO,EAAGQ,CAAsB,EAC/DE,EAAalG,GAAIgF,EAAcS,CAAO,EAAGO,CAAsB,EAI/DG,EAAQF,EACRhG,EAAM6F,EAAaR,EAAgB7D,CAAM,EAAIyE,EAC7CE,EAASN,EAAa,EAAIR,EAAgB7D,CAAM,EAAI,EAAIsE,EACxDM,EAAS9F,GAAM4F,EAAOC,EAAQnG,CAAG,EAMjCqG,EAAkB,CAACrC,EAAe,OAASnD,GAAaD,CAAS,GAAK,MAAQuF,GAAUC,GAAUhF,EAAM,UAAUI,CAAM,EAAI,GAAK2E,EAASD,EAAQF,EAAaC,GAAcZ,EAAgB7D,CAAM,EAAI,EAAI,EAC3M8E,EAAkBD,EAAkBF,EAASD,EAAQC,EAASD,EAAQC,EAASnG,EAAM,EAC3F,MAAO,CACL,CAACe,CAAI,EAAGyC,EAAOzC,CAAI,EAAIuF,EACvB,KAAM,CACJ,CAACvF,CAAI,EAAGqF,EACR,aAAcD,EAASC,EAASE,EAChC,GAAID,GAAmB,CACrB,gBAAAC,CACV,CACO,EACD,MAAOD,CACb,CACG,CACH,GA+GME,GAAO,SAAU/B,EAAS,CAC9B,OAAIA,IAAY,SACdA,EAAU,CAAA,GAEL,CACL,KAAM,OACN,QAAAA,EACA,MAAM,GAAGD,EAAO,CACd,IAAIiC,EAAuBC,EAC3B,KAAM,CACJ,UAAA7F,EACA,eAAAoD,EACA,MAAA5C,EACA,iBAAAsF,EACA,SAAA7C,EACA,SAAAa,CACD,EAAGH,EACE,CACJ,SAAUoC,EAAgB,GAC1B,UAAWC,EAAiB,GAC5B,mBAAoBC,EACpB,iBAAAC,EAAmB,UACnB,0BAAAC,EAA4B,OAC5B,cAAAzE,EAAgB,GAChB,GAAG0E,CACX,EAAUvG,GAAS+D,EAASD,CAAK,EAM3B,IAAKiC,EAAwBxC,EAAe,QAAU,MAAQwC,EAAsB,gBAClF,MAAO,GAET,MAAMzE,EAAOpB,GAAQC,CAAS,EACxBqG,EAAkBtG,GAAQ+F,CAAgB,IAAMA,EAChDrF,EAAM,MAAOwC,EAAS,OAAS,KAAO,OAASA,EAAS,MAAMa,EAAS,QAAQ,GAC/EwC,EAAqBL,IAAgCI,GAAmB,CAAC3E,EAAgB,CAACZ,GAAqBgF,CAAgB,CAAC,EAAI/E,GAAsB+E,CAAgB,GAC5K,CAACG,GAA+BE,IAA8B,QAChEG,EAAmB,KAAK,GAAG7E,GAA0BqE,EAAkBpE,EAAeyE,EAA2B1F,CAAG,CAAC,EAEvH,MAAM8F,EAAa,CAACT,EAAkB,GAAGQ,CAAkB,EACrDE,EAAW,MAAM9C,GAAeC,EAAOyC,CAAqB,EAC5DK,EAAY,CAAA,EAClB,IAAIC,IAAkBb,EAAuBzC,EAAe,OAAS,KAAO,OAASyC,EAAqB,YAAc,CAAA,EAIxH,GAHIE,GACFU,EAAU,KAAKD,EAASrF,CAAI,CAAC,EAE3B6E,EAAgB,CAClB,MAAMW,EAAQpG,GAAkBP,EAAWQ,EAAOC,CAAG,EACrDgG,EAAU,KAAKD,EAASG,EAAM,CAAC,CAAC,EAAGH,EAASG,EAAM,CAAC,CAAC,CAAC,CACtD,CAOD,GANAD,EAAgB,CAAC,GAAGA,EAAe,CACjC,UAAA1G,EACA,UAAAyG,CACR,CAAO,EAGG,CAACA,EAAU,MAAMtF,GAAQA,GAAQ,CAAC,EAAG,CACvC,IAAIyF,EAAuBC,EAC3B,MAAMC,KAAeF,EAAwBxD,EAAe,OAAS,KAAO,OAASwD,EAAsB,QAAU,GAAK,EACpHG,EAAgBR,EAAWO,CAAS,EAC1C,GAAIC,EAEF,MAAO,CACL,KAAM,CACJ,MAAOD,EACP,UAAWJ,CACZ,EACD,MAAO,CACL,UAAWK,CACZ,CACb,EAKQ,IAAIC,GAAkBH,EAAwBH,EAAc,OAAO1mB,GAAKA,EAAE,UAAU,CAAC,GAAK,CAAC,EAAE,KAAK,CAACkB,EAAGpB,IAAMoB,EAAE,UAAU,CAAC,EAAIpB,EAAE,UAAU,CAAC,CAAC,EAAE,CAAC,IAAM,KAAO,OAAS+mB,EAAsB,UAG1L,GAAI,CAACG,EACH,OAAQd,EAAgB,CACtB,IAAK,UACH,CACE,IAAIe,EACJ,MAAMjH,GAAaiH,EAAwBP,EAAc,IAAI1mB,GAAK,CAACA,EAAE,UAAWA,EAAE,UAAU,OAAOwmB,GAAYA,EAAW,CAAC,EAAE,OAAO,CAACzZ,EAAKyZ,IAAazZ,EAAMyZ,EAAU,CAAC,CAAC,CAAC,EAAE,KAAK,CAACtlB,EAAGpB,IAAMoB,EAAE,CAAC,EAAIpB,EAAE,CAAC,CAAC,EAAE,CAAC,IAAM,KAAO,OAASmnB,EAAsB,CAAC,EAClPjH,IACFgH,EAAiBhH,GAEnB,KACD,CACH,IAAK,mBACHgH,EAAiBlB,EACjB,KACH,CAEH,GAAI9F,IAAcgH,EAChB,MAAO,CACL,MAAO,CACL,UAAWA,CACZ,CACb,CAEO,CACD,MAAO,EACR,CACL,CACA,EA4MA,eAAeE,GAAqBvD,EAAOC,EAAS,CAClD,KAAM,CACJ,UAAA5D,EACA,SAAAiD,EACA,SAAAa,CACD,EAAGH,EACElD,EAAM,MAAOwC,EAAS,OAAS,KAAO,OAASA,EAAS,MAAMa,EAAS,QAAQ,GAC/E3C,EAAOpB,GAAQC,CAAS,EACxBU,EAAYT,GAAaD,CAAS,EAClCwC,EAAanC,GAAYL,CAAS,IAAM,IACxCmH,EAAgB,CAAC,OAAQ,KAAK,EAAE,SAAShG,CAAI,EAAI,GAAK,EACtDiG,EAAiB3G,GAAO+B,EAAa,GAAK,EAC1C6E,EAAWxH,GAAS+D,EAASD,CAAK,EAGxC,GAAI,CACF,SAAA2D,EACA,UAAAC,EACA,cAAA5G,CACJ,EAAM,OAAO0G,GAAa,SAAW,CACjC,SAAUA,EACV,UAAW,EACX,cAAe,IACnB,EAAM,CACF,SAAU,EACV,UAAW,EACX,cAAe,KACf,GAAGA,CACP,EACE,OAAI3G,GAAa,OAAOC,GAAkB,WACxC4G,EAAY7G,IAAc,MAAQC,EAAgB,GAAKA,GAElD6B,EAAa,CAClB,EAAG+E,EAAYH,EACf,EAAGE,EAAWH,CAClB,EAAM,CACF,EAAGG,EAAWH,EACd,EAAGI,EAAYH,CACnB,CACA,CASA,MAAM5B,GAAS,SAAU5B,EAAS,CAChC,OAAIA,IAAY,SACdA,EAAU,GAEL,CACL,KAAM,SACN,QAAAA,EACA,MAAM,GAAGD,EAAO,CACd,KAAM,CACJ,EAAA5iB,EACA,EAAAC,CACD,EAAG2iB,EACE6D,EAAa,MAAMN,GAAqBvD,EAAOC,CAAO,EAC5D,MAAO,CACL,EAAG7iB,EAAIymB,EAAW,EAClB,EAAGxmB,EAAIwmB,EAAW,EAClB,KAAMA,CACd,CACK,CACL,CACA,EAOMC,GAAQ,SAAU7D,EAAS,CAC/B,OAAIA,IAAY,SACdA,EAAU,CAAA,GAEL,CACL,KAAM,QACN,QAAAA,EACA,MAAM,GAAGD,EAAO,CACd,KAAM,CACJ,EAAA5iB,EACA,EAAAC,EACA,UAAAgf,CACD,EAAG2D,EACE,CACJ,SAAUoC,EAAgB,GAC1B,UAAWC,EAAiB,GAC5B,QAAA0B,EAAU,CACR,GAAIvF,GAAQ,CACV,GAAI,CACF,EAAAphB,EACA,EAAAC,CACD,EAAGmhB,EACJ,MAAO,CACL,EAAAphB,EACA,EAAAC,CACd,CACW,CACF,EACD,GAAGolB,CACX,EAAUvG,GAAS+D,EAASD,CAAK,EACrBf,EAAS,CACb,EAAA7hB,EACA,EAAAC,CACR,EACYwlB,EAAW,MAAM9C,GAAeC,EAAOyC,CAAqB,EAC5DmB,EAAYlH,GAAYN,GAAQC,CAAS,CAAC,EAC1CsH,EAAWpH,GAAgBqH,CAAS,EAC1C,IAAII,EAAgB/E,EAAO0E,CAAQ,EAC/BM,EAAiBhF,EAAO2E,CAAS,EACrC,GAAIxB,EAAe,CACjB,MAAM8B,EAAUP,IAAa,IAAM,MAAQ,OACrCQ,EAAUR,IAAa,IAAM,SAAW,QACxCnI,EAAMwI,EAAgBnB,EAASqB,CAAO,EACtCzI,EAAMuI,EAAgBnB,EAASsB,CAAO,EAC5CH,EAAgBjI,GAAMP,EAAKwI,EAAevI,CAAG,CAC9C,CACD,GAAI4G,EAAgB,CAClB,MAAM6B,EAAUN,IAAc,IAAM,MAAQ,OACtCO,EAAUP,IAAc,IAAM,SAAW,QACzCpI,EAAMyI,EAAiBpB,EAASqB,CAAO,EACvCzI,EAAMwI,EAAiBpB,EAASsB,CAAO,EAC7CF,EAAiBlI,GAAMP,EAAKyI,EAAgBxI,CAAG,CAChD,CACD,MAAM2I,EAAgBL,EAAQ,GAAG,CAC/B,GAAG/D,EACH,CAAC2D,CAAQ,EAAGK,EACZ,CAACJ,CAAS,EAAGK,CACrB,CAAO,EACD,MAAO,CACL,GAAGG,EACH,KAAM,CACJ,EAAGA,EAAc,EAAIhnB,EACrB,EAAGgnB,EAAc,EAAI/mB,CACtB,CACT,CACK,CACL,CACA,EC11BA,SAASgnB,GAAYza,EAAM,CACzB,OAAIxC,GAAOwC,CAAI,GACLA,EAAK,UAAY,IAAI,YAAW,EAKnC,WACT,CACA,SAAS0a,GAAU1a,EAAM,CACvB,IAAI2a,EACJ,OAAQ3a,GAAQ,OAAiB2a,EAAsB3a,EAAK,gBAAkB,KAAvD,OAAuE2a,EAAoB,cAAgB,MACpI,CACA,SAASC,GAAmB5a,EAAM,CAChC,IAAI4U,EACJ,OAAQA,GAAQpX,GAAOwC,CAAI,EAAIA,EAAK,cAAgBA,EAAK,WAAa,OAAO,WAAa,KAAO,OAAS4U,EAAK,eACjH,CACA,SAASpX,GAAOP,EAAO,CACrB,OAAOA,aAAiB,MAAQA,aAAiByd,GAAUzd,CAAK,EAAE,IACpE,CACA,SAASxG,GAAUwG,EAAO,CACxB,OAAOA,aAAiB,SAAWA,aAAiByd,GAAUzd,CAAK,EAAE,OACvE,CACA,SAAS4d,GAAc5d,EAAO,CAC5B,OAAOA,aAAiB,aAAeA,aAAiByd,GAAUzd,CAAK,EAAE,WAC3E,CACA,SAAS6d,GAAa7d,EAAO,CAE3B,OAAI,OAAO,WAAe,IACjB,GAEFA,aAAiB,YAAcA,aAAiByd,GAAUzd,CAAK,EAAE,UAC1E,CACA,SAAS8d,GAAkBnqB,EAAS,CAClC,KAAM,CACJ,SAAAqoB,EACA,UAAA+B,EACA,UAAAC,EACA,QAAAC,CACJ,EAAMC,GAAiBvqB,CAAO,EAC5B,MAAO,kCAAkC,KAAKqoB,EAAWgC,EAAYD,CAAS,GAAK,CAAC,CAAC,SAAU,UAAU,EAAE,SAASE,CAAO,CAC7H,CACA,SAASE,GAAexqB,EAAS,CAC/B,MAAO,CAAC,QAAS,KAAM,IAAI,EAAE,SAAS6pB,GAAY7pB,CAAO,CAAC,CAC5D,CACA,SAASyqB,GAAkBzqB,EAAS,CAClC,MAAM0qB,EAASC,KACTC,EAAML,GAAiBvqB,CAAO,EAGpC,OAAO4qB,EAAI,YAAc,QAAUA,EAAI,cAAgB,SAAWA,EAAI,cAAgBA,EAAI,gBAAkB,SAAW,KAAU,CAACF,IAAWE,EAAI,eAAiBA,EAAI,iBAAmB,OAAS,KAAU,CAACF,IAAWE,EAAI,OAASA,EAAI,SAAW,OAAS,KAAU,CAAC,YAAa,cAAe,QAAQ,EAAE,KAAKve,IAAUue,EAAI,YAAc,IAAI,SAASve,CAAK,CAAC,GAAK,CAAC,QAAS,SAAU,SAAU,SAAS,EAAE,KAAKA,IAAUue,EAAI,SAAW,IAAI,SAASve,CAAK,CAAC,CACnc,CACA,SAASwe,GAAmB7qB,EAAS,CACnC,IAAI8qB,EAAcC,GAAc/qB,CAAO,EACvC,KAAOiqB,GAAca,CAAW,GAAK,CAACE,GAAsBF,CAAW,GAAG,CACxE,GAAIL,GAAkBK,CAAW,EAC/B,OAAOA,EAEPA,EAAcC,GAAcD,CAAW,CAE1C,CACD,OAAO,IACT,CACA,SAASH,IAAW,CAClB,OAAI,OAAO,IAAQ,KAAe,CAAC,IAAI,SAAiB,GACjD,IAAI,SAAS,0BAA2B,MAAM,CACvD,CACA,SAASK,GAAsB5b,EAAM,CACnC,MAAO,CAAC,OAAQ,OAAQ,WAAW,EAAE,SAASya,GAAYza,CAAI,CAAC,CACjE,CACA,SAASmb,GAAiBvqB,EAAS,CACjC,OAAO8pB,GAAU9pB,CAAO,EAAE,iBAAiBA,CAAO,CACpD,CACA,SAASirB,GAAcjrB,EAAS,CAC9B,OAAI6F,GAAU7F,CAAO,EACZ,CACL,WAAYA,EAAQ,WACpB,UAAWA,EAAQ,SACzB,EAES,CACL,WAAYA,EAAQ,YACpB,UAAWA,EAAQ,WACvB,CACA,CACA,SAAS+qB,GAAc3b,EAAM,CAC3B,GAAIya,GAAYza,CAAI,IAAM,OACxB,OAAOA,EAET,MAAMrO,EAENqO,EAAK,cAELA,EAAK,YAEL8a,GAAa9a,CAAI,GAAKA,EAAK,MAE3B4a,GAAmB5a,CAAI,EACvB,OAAO8a,GAAanpB,CAAM,EAAIA,EAAO,KAAOA,CAC9C,CACA,SAASmqB,GAA2B9b,EAAM,CACxC,MAAM+b,EAAaJ,GAAc3b,CAAI,EACrC,OAAI4b,GAAsBG,CAAU,EAC3B/b,EAAK,cAAgBA,EAAK,cAAc,KAAOA,EAAK,KAEzD6a,GAAckB,CAAU,GAAKhB,GAAkBgB,CAAU,EACpDA,EAEFD,GAA2BC,CAAU,CAC9C,CACA,SAASC,GAAqBhc,EAAMqU,EAAM4H,EAAiB,CACzD,IAAIC,EACA7H,IAAS,SACXA,EAAO,CAAA,GAEL4H,IAAoB,SACtBA,EAAkB,IAEpB,MAAME,EAAqBL,GAA2B9b,CAAI,EACpDoc,EAASD,MAAyBD,EAAuBlc,EAAK,gBAAkB,KAAO,OAASkc,EAAqB,MACrHG,EAAM3B,GAAUyB,CAAkB,EACxC,OAAIC,EACK/H,EAAK,OAAOgI,EAAKA,EAAI,gBAAkB,CAAE,EAAEtB,GAAkBoB,CAAkB,EAAIA,EAAqB,GAAIE,EAAI,cAAgBJ,EAAkBD,GAAqBK,EAAI,YAAY,EAAI,CAAA,CAAE,EAE/LhI,EAAK,OAAO8H,EAAoBH,GAAqBG,EAAoB,CAAE,EAAEF,CAAe,CAAC,CACtG,CCvHA,SAASK,GAAiB1rB,EAAS,CACjC,MAAM4qB,EAAML,GAAiBvqB,CAAO,EAGpC,IAAI2rB,EAAQ,WAAWf,EAAI,KAAK,GAAK,EACjCgB,EAAS,WAAWhB,EAAI,MAAM,GAAK,EACvC,MAAMiB,EAAY5B,GAAcjqB,CAAO,EACjC8rB,EAAcD,EAAY7rB,EAAQ,YAAc2rB,EAChDI,EAAeF,EAAY7rB,EAAQ,aAAe4rB,EAClDI,EAAiB9K,GAAMyK,CAAK,IAAMG,GAAe5K,GAAM0K,CAAM,IAAMG,EACzE,OAAIC,IACFL,EAAQG,EACRF,EAASG,GAEJ,CACL,MAAAJ,EACA,OAAAC,EACA,EAAGI,CACP,CACA,CAEA,SAASC,GAAcjsB,EAAS,CAC9B,OAAQ6F,GAAU7F,CAAO,EAA6BA,EAAzBA,EAAQ,cACvC,CAEA,SAASksB,GAASlsB,EAAS,CACzB,MAAMmsB,EAAaF,GAAcjsB,CAAO,EACxC,GAAI,CAACiqB,GAAckC,CAAU,EAC3B,OAAO/K,GAAa,CAAC,EAEvB,MAAM0C,EAAOqI,EAAW,wBAClB,CACJ,MAAAR,EACA,OAAAC,EACA,EAAAQ,CACJ,EAAMV,GAAiBS,CAAU,EAC/B,IAAIvpB,GAAKwpB,EAAIlL,GAAM4C,EAAK,KAAK,EAAIA,EAAK,OAAS6H,EAC3C9oB,GAAKupB,EAAIlL,GAAM4C,EAAK,MAAM,EAAIA,EAAK,QAAU8H,EAIjD,OAAI,CAAChpB,GAAK,CAAC,OAAO,SAASA,CAAC,KAC1BA,EAAI,IAEF,CAACC,GAAK,CAAC,OAAO,SAASA,CAAC,KAC1BA,EAAI,GAEC,CACL,EAAAD,EACA,EAAAC,CACJ,CACA,CAEA,MAAMwpB,GAAyBjL,GAAa,CAAC,EAC7C,SAASkL,GAAiBtsB,EAAS,CACjC,MAAMyrB,EAAM3B,GAAU9pB,CAAO,EAC7B,MAAI,CAAC2qB,GAAQ,GAAM,CAACc,EAAI,eACfY,GAEF,CACL,EAAGZ,EAAI,eAAe,WACtB,EAAGA,EAAI,eAAe,SAC1B,CACA,CACA,SAASc,GAAuBvsB,EAASwsB,EAASC,EAAsB,CAItE,OAHID,IAAY,SACdA,EAAU,IAER,CAACC,GAAwBD,GAAWC,IAAyB3C,GAAU9pB,CAAO,EACzE,GAEFwsB,CACT,CAEA,SAASE,GAAsB1sB,EAAS2sB,EAAcC,EAAiB1G,EAAc,CAC/EyG,IAAiB,SACnBA,EAAe,IAEbC,IAAoB,SACtBA,EAAkB,IAEpB,MAAMC,EAAa7sB,EAAQ,wBACrBmsB,EAAaF,GAAcjsB,CAAO,EACxC,IAAI8sB,EAAQ1L,GAAa,CAAC,EACtBuL,IACEzG,EACErgB,GAAUqgB,CAAY,IACxB4G,EAAQZ,GAAShG,CAAY,GAG/B4G,EAAQZ,GAASlsB,CAAO,GAG5B,MAAM+sB,EAAgBR,GAAuBJ,EAAYS,EAAiB1G,CAAY,EAAIoG,GAAiBH,CAAU,EAAI/K,GAAa,CAAC,EACvI,IAAIxe,GAAKiqB,EAAW,KAAOE,EAAc,GAAKD,EAAM,EAChDjqB,GAAKgqB,EAAW,IAAME,EAAc,GAAKD,EAAM,EAC/CnB,EAAQkB,EAAW,MAAQC,EAAM,EACjClB,EAASiB,EAAW,OAASC,EAAM,EACvC,GAAIX,EAAY,CACd,MAAMV,EAAM3B,GAAUqC,CAAU,EAC1Ba,EAAY9G,GAAgBrgB,GAAUqgB,CAAY,EAAI4D,GAAU5D,CAAY,EAAIA,EACtF,IAAI+G,EAAgBxB,EAAI,aACxB,KAAOwB,GAAiB/G,GAAgB8G,IAAcvB,GAAK,CACzD,MAAMyB,EAAchB,GAASe,CAAa,EACpCE,EAAaF,EAAc,wBAC3BrC,EAAML,GAAiB0C,CAAa,EACpCG,EAAOD,EAAW,MAAQF,EAAc,WAAa,WAAWrC,EAAI,WAAW,GAAKsC,EAAY,EAChGG,EAAMF,EAAW,KAAOF,EAAc,UAAY,WAAWrC,EAAI,UAAU,GAAKsC,EAAY,EAClGtqB,GAAKsqB,EAAY,EACjBrqB,GAAKqqB,EAAY,EACjBvB,GAASuB,EAAY,EACrBtB,GAAUsB,EAAY,EACtBtqB,GAAKwqB,EACLvqB,GAAKwqB,EACLJ,EAAgBnD,GAAUmD,CAAa,EAAE,YAC1C,CACF,CACD,OAAOpJ,GAAiB,CACtB,MAAA8H,EACA,OAAAC,EACA,EAAAhpB,EACA,EAAAC,CACJ,CAAG,CACH,CAEA,SAASyqB,GAAsDtJ,EAAM,CACnE,GAAI,CACF,KAAAF,EACA,aAAAoC,EACA,SAAAtB,CACD,EAAGZ,EACJ,MAAMuJ,EAA0BtD,GAAc/D,CAAY,EACpDsH,EAAkBxD,GAAmB9D,CAAY,EACvD,GAAIA,IAAiBsH,EACnB,OAAO1J,EAET,IAAI2J,EAAS,CACX,WAAY,EACZ,UAAW,CACf,EACMX,EAAQ1L,GAAa,CAAC,EAC1B,MAAMsM,EAAUtM,GAAa,CAAC,EAC9B,IAAImM,GAA2B,CAACA,GAA2B3I,IAAa,YAClEiF,GAAY3D,CAAY,IAAM,QAAUiE,GAAkBqD,CAAe,KAC3EC,EAASxC,GAAc/E,CAAY,GAEjC+D,GAAc/D,CAAY,GAAG,CAC/B,MAAMyH,EAAajB,GAAsBxG,CAAY,EACrD4G,EAAQZ,GAAShG,CAAY,EAC7BwH,EAAQ,EAAIC,EAAW,EAAIzH,EAAa,WACxCwH,EAAQ,EAAIC,EAAW,EAAIzH,EAAa,SACzC,CAEH,MAAO,CACL,MAAOpC,EAAK,MAAQgJ,EAAM,EAC1B,OAAQhJ,EAAK,OAASgJ,EAAM,EAC5B,EAAGhJ,EAAK,EAAIgJ,EAAM,EAAIW,EAAO,WAAaX,EAAM,EAAIY,EAAQ,EAC5D,EAAG5J,EAAK,EAAIgJ,EAAM,EAAIW,EAAO,UAAYX,EAAM,EAAIY,EAAQ,CAC/D,CACA,CAEA,SAASE,GAAe5tB,EAAS,CAC/B,OAAO,MAAM,KAAKA,EAAQ,eAAgB,CAAA,CAC5C,CAEA,SAAS6tB,GAAoB7tB,EAAS,CAGpC,OAAO0sB,GAAsB1C,GAAmBhqB,CAAO,CAAC,EAAE,KAAOirB,GAAcjrB,CAAO,EAAE,UAC1F,CAIA,SAAS8tB,GAAgB9tB,EAAS,CAChC,MAAM+tB,EAAO/D,GAAmBhqB,CAAO,EACjCytB,EAASxC,GAAcjrB,CAAO,EAC9BguB,EAAOhuB,EAAQ,cAAc,KAC7B2rB,EAAQ1K,GAAI8M,EAAK,YAAaA,EAAK,YAAaC,EAAK,YAAaA,EAAK,WAAW,EAClFpC,EAAS3K,GAAI8M,EAAK,aAAcA,EAAK,aAAcC,EAAK,aAAcA,EAAK,YAAY,EAC7F,IAAIprB,EAAI,CAAC6qB,EAAO,WAAaI,GAAoB7tB,CAAO,EACxD,MAAM6C,EAAI,CAAC4qB,EAAO,UAClB,OAAIlD,GAAiByD,CAAI,EAAE,YAAc,QACvCprB,GAAKqe,GAAI8M,EAAK,YAAaC,EAAK,WAAW,EAAIrC,GAE1C,CACL,MAAAA,EACA,OAAAC,EACA,EAAAhpB,EACA,EAAAC,CACJ,CACA,CAEA,SAASorB,GAAgBjuB,EAAS4kB,EAAU,CAC1C,MAAM6G,EAAM3B,GAAU9pB,CAAO,EACvB+tB,EAAO/D,GAAmBhqB,CAAO,EACjCkuB,EAAiBzC,EAAI,eAC3B,IAAIE,EAAQoC,EAAK,YACbnC,EAASmC,EAAK,aACdnrB,EAAI,EACJC,EAAI,EACR,GAAIqrB,EAAgB,CAClBvC,EAAQuC,EAAe,MACvBtC,EAASsC,EAAe,OACxB,MAAMC,EAAsBxD,MACxB,CAACwD,GAAuBA,GAAuBvJ,IAAa,WAC9DhiB,EAAIsrB,EAAe,WACnBrrB,EAAIqrB,EAAe,UAEtB,CACD,MAAO,CACL,MAAAvC,EACA,OAAAC,EACA,EAAAhpB,EACA,EAAAC,CACJ,CACA,CAGA,SAASurB,GAA2BpuB,EAAS4kB,EAAU,CACrD,MAAMiI,EAAaH,GAAsB1sB,EAAS,GAAM4kB,IAAa,OAAO,EACtEyI,EAAMR,EAAW,IAAM7sB,EAAQ,UAC/BotB,EAAOP,EAAW,KAAO7sB,EAAQ,WACjC8sB,EAAQ7C,GAAcjqB,CAAO,EAAIksB,GAASlsB,CAAO,EAAIohB,GAAa,CAAC,EACnEuK,EAAQ3rB,EAAQ,YAAc8sB,EAAM,EACpClB,EAAS5rB,EAAQ,aAAe8sB,EAAM,EACtClqB,EAAIwqB,EAAON,EAAM,EACjBjqB,EAAIwqB,EAAMP,EAAM,EACtB,MAAO,CACL,MAAAnB,EACA,OAAAC,EACA,EAAAhpB,EACA,EAAAC,CACJ,CACA,CACA,SAASwrB,GAAkCruB,EAASsuB,EAAkB1J,EAAU,CAC9E,IAAId,EACJ,GAAIwK,IAAqB,WACvBxK,EAAOmK,GAAgBjuB,EAAS4kB,CAAQ,UAC/B0J,IAAqB,WAC9BxK,EAAOgK,GAAgB9D,GAAmBhqB,CAAO,CAAC,UACzC6F,GAAUyoB,CAAgB,EACnCxK,EAAOsK,GAA2BE,EAAkB1J,CAAQ,MACvD,CACL,MAAMmI,EAAgBT,GAAiBtsB,CAAO,EAC9C8jB,EAAO,CACL,GAAGwK,EACH,EAAGA,EAAiB,EAAIvB,EAAc,EACtC,EAAGuB,EAAiB,EAAIvB,EAAc,CAC5C,CACG,CACD,OAAOlJ,GAAiBC,CAAI,CAC9B,CACA,SAASyK,GAAyBvuB,EAASwuB,EAAU,CACnD,MAAMrD,EAAaJ,GAAc/qB,CAAO,EACxC,OAAImrB,IAAeqD,GAAY,CAAC3oB,GAAUslB,CAAU,GAAKH,GAAsBG,CAAU,EAChF,GAEFZ,GAAiBY,CAAU,EAAE,WAAa,SAAWoD,GAAyBpD,EAAYqD,CAAQ,CAC3G,CAKA,SAASC,GAA4BzuB,EAAS0uB,EAAO,CACnD,MAAMC,EAAeD,EAAM,IAAI1uB,CAAO,EACtC,GAAI2uB,EACF,OAAOA,EAET,IAAI5tB,EAASqqB,GAAqBprB,EAAS,CAAA,EAAI,EAAK,EAAE,OAAOud,GAAM1X,GAAU0X,CAAE,GAAKsM,GAAYtM,CAAE,IAAM,MAAM,EAC1GqR,EAAsC,KAC1C,MAAMC,EAAiBtE,GAAiBvqB,CAAO,EAAE,WAAa,QAC9D,IAAI8qB,EAAc+D,EAAiB9D,GAAc/qB,CAAO,EAAIA,EAG5D,KAAO6F,GAAUilB,CAAW,GAAK,CAACE,GAAsBF,CAAW,GAAG,CACpE,MAAMgE,EAAgBvE,GAAiBO,CAAW,EAC5CiE,EAA0BtE,GAAkBK,CAAW,EACzD,CAACiE,GAA2BD,EAAc,WAAa,UACzDF,EAAsC,OAEVC,EAAiB,CAACE,GAA2B,CAACH,EAAsC,CAACG,GAA2BD,EAAc,WAAa,UAAY,CAAC,CAACF,GAAuC,CAAC,WAAY,OAAO,EAAE,SAASA,EAAoC,QAAQ,GAAKzE,GAAkBW,CAAW,GAAK,CAACiE,GAA2BR,GAAyBvuB,EAAS8qB,CAAW,GAGvZ/pB,EAASA,EAAO,OAAOiuB,GAAYA,IAAalE,CAAW,EAG3D8D,EAAsCE,EAExChE,EAAcC,GAAcD,CAAW,CACxC,CACD,OAAA4D,EAAM,IAAI1uB,EAASe,CAAM,EAClBA,CACT,CAIA,SAASkuB,GAAgBjL,EAAM,CAC7B,GAAI,CACF,QAAAhkB,EACA,SAAA4lB,EACA,aAAAC,EACA,SAAAjB,CACD,EAAGZ,EAEJ,MAAMkL,EAAoB,CAAC,GADMtJ,IAAa,oBAAsB6I,GAA4BzuB,EAAS,KAAK,EAAE,EAAI,CAAA,EAAG,OAAO4lB,CAAQ,EAC9EC,CAAY,EAC9DsJ,EAAwBD,EAAkB,CAAC,EAC3CE,EAAeF,EAAkB,OAAO,CAACG,EAASf,IAAqB,CAC3E,MAAMxK,EAAOuK,GAAkCruB,EAASsuB,EAAkB1J,CAAQ,EAClF,OAAAyK,EAAQ,IAAMpO,GAAI6C,EAAK,IAAKuL,EAAQ,GAAG,EACvCA,EAAQ,MAAQrO,GAAI8C,EAAK,MAAOuL,EAAQ,KAAK,EAC7CA,EAAQ,OAASrO,GAAI8C,EAAK,OAAQuL,EAAQ,MAAM,EAChDA,EAAQ,KAAOpO,GAAI6C,EAAK,KAAMuL,EAAQ,IAAI,EACnCA,CACR,EAAEhB,GAAkCruB,EAASmvB,EAAuBvK,CAAQ,CAAC,EAC9E,MAAO,CACL,MAAOwK,EAAa,MAAQA,EAAa,KACzC,OAAQA,EAAa,OAASA,EAAa,IAC3C,EAAGA,EAAa,KAChB,EAAGA,EAAa,GACpB,CACA,CAEA,SAASE,GAActvB,EAAS,CAC9B,OAAO0rB,GAAiB1rB,CAAO,CACjC,CAEA,SAASuvB,GAA8BvvB,EAASkmB,EAActB,EAAU,CACtE,MAAM2I,EAA0BtD,GAAc/D,CAAY,EACpDsH,EAAkBxD,GAAmB9D,CAAY,EACjDsG,EAAU5H,IAAa,QACvBd,EAAO4I,GAAsB1sB,EAAS,GAAMwsB,EAAStG,CAAY,EACvE,IAAIuH,EAAS,CACX,WAAY,EACZ,UAAW,CACf,EACE,MAAMC,EAAUtM,GAAa,CAAC,EAC9B,GAAImM,GAA2B,CAACA,GAA2B,CAACf,EAI1D,IAHI3C,GAAY3D,CAAY,IAAM,QAAUiE,GAAkBqD,CAAe,KAC3EC,EAASxC,GAAc/E,CAAY,GAEjCqH,EAAyB,CAC3B,MAAMI,EAAajB,GAAsBxG,EAAc,GAAMsG,EAAStG,CAAY,EAClFwH,EAAQ,EAAIC,EAAW,EAAIzH,EAAa,WACxCwH,EAAQ,EAAIC,EAAW,EAAIzH,EAAa,SACzC,MAAUsH,IACTE,EAAQ,EAAIG,GAAoBL,CAAe,GAGnD,MAAO,CACL,EAAG1J,EAAK,KAAO2J,EAAO,WAAaC,EAAQ,EAC3C,EAAG5J,EAAK,IAAM2J,EAAO,UAAYC,EAAQ,EACzC,MAAO5J,EAAK,MACZ,OAAQA,EAAK,MACjB,CACA,CAEA,SAAS0L,GAAoBxvB,EAASyvB,EAAU,CAC9C,MAAI,CAACxF,GAAcjqB,CAAO,GAAKuqB,GAAiBvqB,CAAO,EAAE,WAAa,QAC7D,KAELyvB,EACKA,EAASzvB,CAAO,EAElBA,EAAQ,YACjB,CAIA,SAAS0vB,GAAgB1vB,EAASyvB,EAAU,CAC1C,MAAME,EAAS7F,GAAU9pB,CAAO,EAChC,GAAI,CAACiqB,GAAcjqB,CAAO,EACxB,OAAO2vB,EAET,IAAIzJ,EAAesJ,GAAoBxvB,EAASyvB,CAAQ,EACxD,KAAOvJ,GAAgBsE,GAAetE,CAAY,GAAKqE,GAAiBrE,CAAY,EAAE,WAAa,UACjGA,EAAesJ,GAAoBtJ,EAAcuJ,CAAQ,EAE3D,OAAIvJ,IAAiB2D,GAAY3D,CAAY,IAAM,QAAU2D,GAAY3D,CAAY,IAAM,QAAUqE,GAAiBrE,CAAY,EAAE,WAAa,UAAY,CAACuE,GAAkBvE,CAAY,GACnLyJ,EAEFzJ,GAAgB2E,GAAmB7qB,CAAO,GAAK2vB,CACxD,CAEA,MAAMC,GAAkB,eAAgB5L,EAAM,CAC5C,GAAI,CACF,UAAAC,EACA,SAAAC,EACA,SAAAU,CACD,EAAGZ,EACJ,MAAM6L,EAAoB,KAAK,iBAAmBH,GAC5CI,EAAkB,KAAK,cAC7B,MAAO,CACL,UAAWP,GAA8BtL,EAAW,MAAM4L,EAAkB3L,CAAQ,EAAGU,CAAQ,EAC/F,SAAU,CACR,EAAG,EACH,EAAG,EACH,GAAI,MAAMkL,EAAgB5L,CAAQ,CACnC,CACL,CACA,EAEA,SAAS6L,GAAM/vB,EAAS,CACtB,OAAOuqB,GAAiBvqB,CAAO,EAAE,YAAc,KACjD,CAEA,MAAM8kB,GAAW,CACf,sDAAAwI,GACA,mBAAAtD,GACA,gBAAAiF,GACA,gBAAAS,GACA,gBAAAE,GACA,eAAAhC,GACA,cAAA0B,GACA,SAAApD,GACA,UAAArmB,GACA,MAAAkqB,EACF,EAGA,SAASC,GAAYhwB,EAASiwB,EAAQ,CACpC,IAAIC,EAAK,KACLC,EACJ,MAAMvZ,EAAOoT,GAAmBhqB,CAAO,EACvC,SAASowB,GAAU,CACjB,aAAaD,CAAS,EACtBD,GAAMA,EAAG,aACTA,EAAK,IACN,CACD,SAASG,EAAQC,EAAMC,EAAW,CAC5BD,IAAS,SACXA,EAAO,IAELC,IAAc,SAChBA,EAAY,GAEdH,IACA,KAAM,CACJ,KAAAhD,EACA,IAAAC,EACA,MAAA1B,EACA,OAAAC,CACN,EAAQ5rB,EAAQ,wBAIZ,GAHKswB,GACHL,IAEE,CAACtE,GAAS,CAACC,EACb,OAEF,MAAM4E,EAAWrP,GAAMkM,CAAG,EACpBoD,EAAatP,GAAMvK,EAAK,aAAewW,EAAOzB,EAAM,EACpD+E,EAAcvP,GAAMvK,EAAK,cAAgByW,EAAMzB,EAAO,EACtD+E,EAAYxP,GAAMiM,CAAI,EAEtB3H,EAAU,CACd,WAFiB,CAAC+K,EAAW,MAAQ,CAACC,EAAa,MAAQ,CAACC,EAAc,MAAQ,CAACC,EAAY,KAG/F,UAAW1P,GAAI,EAAGD,GAAI,EAAGuP,CAAS,CAAC,GAAK,CAC9C,EACI,IAAIK,EAAgB,GACpB,SAASC,EAAcC,EAAS,CAC9B,MAAMC,EAAQD,EAAQ,CAAC,EAAE,kBACzB,GAAIC,IAAUR,EAAW,CACvB,GAAI,CAACK,EACH,OAAOP,EAAO,EAEXU,EAKHV,EAAQ,GAAOU,CAAK,EAJpBZ,EAAY,WAAW,IAAM,CAC3BE,EAAQ,GAAO,IAAI,CACpB,EAAE,GAAG,CAIT,CACDO,EAAgB,EACjB,CAID,GAAI,CACFV,EAAK,IAAI,qBAAqBW,EAAe,CAC3C,GAAGpL,EAEH,KAAM7O,EAAK,aACnB,CAAO,CACF,MAAW,CACVsZ,EAAK,IAAI,qBAAqBW,EAAepL,CAAO,CACrD,CACDyK,EAAG,QAAQlwB,CAAO,CACnB,CACD,OAAAqwB,EAAQ,EAAI,EACLD,CACT,CAUA,SAASY,GAAW/M,EAAWC,EAAU+M,EAAQxL,EAAS,CACpDA,IAAY,SACdA,EAAU,CAAA,GAEZ,KAAM,CACJ,eAAAyL,EAAiB,GACjB,eAAAC,EAAiB,GACjB,cAAAC,EAAgB,OAAO,gBAAmB,WAC1C,YAAAC,EAAc,OAAO,sBAAyB,WAC9C,eAAAC,EAAiB,EAClB,EAAG7L,EACE8L,EAActF,GAAchI,CAAS,EACrCuN,EAAYN,GAAkBC,EAAiB,CAAC,GAAII,EAAcnG,GAAqBmG,CAAW,EAAI,CAAA,EAAK,GAAGnG,GAAqBlH,CAAQ,CAAC,EAAI,CAAA,EACtJsN,EAAU,QAAQxC,GAAY,CAC5BkC,GAAkBlC,EAAS,iBAAiB,SAAUiC,EAAQ,CAC5D,QAAS,EACf,CAAK,EACDE,GAAkBnC,EAAS,iBAAiB,SAAUiC,CAAM,CAChE,CAAG,EACD,MAAMQ,EAAYF,GAAeF,EAAcrB,GAAYuB,EAAaN,CAAM,EAAI,KAClF,IAAIS,EAAiB,GACjBC,EAAiB,KACjBP,IACFO,EAAiB,IAAI,eAAe3N,GAAQ,CAC1C,GAAI,CAAC4N,CAAU,EAAI5N,EACf4N,GAAcA,EAAW,SAAWL,GAAeI,IAGrDA,EAAe,UAAUzN,CAAQ,EACjC,qBAAqBwN,CAAc,EACnCA,EAAiB,sBAAsB,IAAM,CAC3CC,GAAkBA,EAAe,QAAQzN,CAAQ,CAC3D,CAAS,GAEH+M,GACN,CAAK,EACGM,GAAe,CAACD,GAClBK,EAAe,QAAQJ,CAAW,EAEpCI,EAAe,QAAQzN,CAAQ,GAEjC,IAAI2N,EACAC,EAAcR,EAAiB5E,GAAsBzI,CAAS,EAAI,KAClEqN,GACFS,IAEF,SAASA,GAAY,CACnB,MAAMC,EAActF,GAAsBzI,CAAS,EAC/C6N,IAAgBE,EAAY,IAAMF,EAAY,GAAKE,EAAY,IAAMF,EAAY,GAAKE,EAAY,QAAUF,EAAY,OAASE,EAAY,SAAWF,EAAY,SACtKb,IAEFa,EAAcE,EACdH,EAAU,sBAAsBE,CAAS,CAC1C,CACD,OAAAd,IACO,IAAM,CACXO,EAAU,QAAQxC,GAAY,CAC5BkC,GAAkBlC,EAAS,oBAAoB,SAAUiC,CAAM,EAC/DE,GAAkBnC,EAAS,oBAAoB,SAAUiC,CAAM,CACrE,CAAK,EACDQ,GAAaA,EAAS,EACtBE,GAAkBA,EAAe,aACjCA,EAAiB,KACbL,GACF,qBAAqBO,CAAO,CAElC,CACA,CAOA,MAAMnN,GAAkB,CAACT,EAAWC,EAAUuB,IAAY,CAIxD,MAAMiJ,EAAQ,IAAI,IACZuD,EAAgB,CACpB,SAAAnN,GACA,GAAGW,CACP,EACQyM,EAAoB,CACxB,GAAGD,EAAc,SACjB,GAAIvD,CACR,EACE,OAAOyD,GAAkBlO,EAAWC,EAAU,CAC5C,GAAG+N,EACH,SAAUC,CACd,CAAG,CACH,ECzkBM7L,GAAQZ,GAAW,CACvB,SAAS2M,EAAM/lB,EAAO,CACpB,MAAO,CAAE,EAAC,eAAe,KAAKA,EAAO,SAAS,CAC/C,CACD,MAAO,CACL,KAAM,QACN,QAAAoZ,EACA,GAAGD,EAAO,CACR,KAAM,CACJ,QAAAxlB,EACA,QAAA2jB,CACR,EAAU,OAAO8B,GAAY,WAAaA,EAAQD,CAAK,EAAIC,EACrD,OAAIzlB,GAAWoyB,EAAMpyB,CAAO,EACtBA,EAAQ,SAAW,KACdqyB,GAAQ,CACb,QAASryB,EAAQ,QACjB,QAAA2jB,CACZ,CAAW,EAAE,GAAG6B,CAAK,EAEN,GACExlB,EACFqyB,GAAQ,CACb,QAAAryB,EACA,QAAA2jB,CACV,CAAS,EAAE,GAAG6B,CAAK,EAEN,EACR,CACL,CACA,EAEA,IAAI1I,GAAQ,OAAO,SAAa,IAAcwV,EAAAA,gBAAkBC,EAAAA,UAIhE,SAASC,GAAUzvB,EAAGpB,EAAG,CACvB,GAAIoB,IAAMpB,EACR,MAAO,GAET,GAAI,OAAOoB,GAAM,OAAOpB,EACtB,MAAO,GAET,GAAI,OAAOoB,GAAM,YAAcA,EAAE,aAAepB,EAAE,WAChD,MAAO,GAET,IAAI8gB,EAAQ7iB,EAAG6yB,EACf,GAAI1vB,GAAKpB,GAAK,OAAOoB,GAAK,SAAU,CAClC,GAAI,MAAM,QAAQA,CAAC,EAAG,CAEpB,GADA0f,EAAS1f,EAAE,OACP0f,GAAU9gB,EAAE,OAAQ,MAAO,GAC/B,IAAK/B,EAAI6iB,EAAQ7iB,MAAQ,GACvB,GAAI,CAAC4yB,GAAUzvB,EAAEnD,CAAC,EAAG+B,EAAE/B,CAAC,CAAC,EACvB,MAAO,GAGX,MAAO,EACR,CAGD,GAFA6yB,EAAO,OAAO,KAAK1vB,CAAC,EACpB0f,EAASgQ,EAAK,OACVhQ,IAAW,OAAO,KAAK9gB,CAAC,EAAE,OAC5B,MAAO,GAET,IAAK/B,EAAI6iB,EAAQ7iB,MAAQ,GACvB,GAAI,CAAC,CAAE,EAAC,eAAe,KAAK+B,EAAG8wB,EAAK7yB,CAAC,CAAC,EACpC,MAAO,GAGX,IAAKA,EAAI6iB,EAAQ7iB,MAAQ,GAAI,CAC3B,MAAME,EAAM2yB,EAAK7yB,CAAC,EAClB,GAAI,EAAAE,IAAQ,UAAYiD,EAAE,WAGtB,CAACyvB,GAAUzvB,EAAEjD,CAAG,EAAG6B,EAAE7B,CAAG,CAAC,EAC3B,MAAO,EAEV,CACD,MAAO,EACR,CACD,OAAOiD,IAAMA,GAAKpB,IAAMA,CAC1B,CAEA,SAAS+wB,GAAO1yB,EAAS,CACvB,OAAI,OAAO,OAAW,IACb,GAEGA,EAAQ,cAAc,aAAe,QACtC,kBAAoB,CACjC,CAEA,SAAS2yB,GAAW3yB,EAASqM,EAAO,CAClC,MAAMumB,EAAMF,GAAO1yB,CAAO,EAC1B,OAAO,KAAK,MAAMqM,EAAQumB,CAAG,EAAIA,CACnC,CAEA,SAASC,GAAaxmB,EAAO,CAC3B,MAAMkD,EAAMhP,EAAM,OAAO8L,CAAK,EAC9ByQ,OAAAA,GAAM,IAAM,CACVvN,EAAI,QAAUlD,CAClB,CAAG,EACMkD,CACT,CAMA,SAASujB,GAAYrN,EAAS,CACxBA,IAAY,SACdA,EAAU,CAAA,GAEZ,KAAM,CACJ,UAAA5D,EAAY,SACZ,SAAA+C,EAAW,WACX,WAAAC,EAAa,CAAE,EACf,SAAAC,EACA,SAAU,CACR,UAAWiO,EACX,SAAUC,CAChB,EAAQ,CAAE,EACN,UAAAC,EAAY,GACZ,qBAAAC,EACA,KAAA1b,CACD,EAAGiO,EACE,CAAC9a,EAAMwoB,CAAO,EAAI5yB,EAAM,SAAS,CACrC,EAAG,EACH,EAAG,EACH,SAAAqkB,EACA,UAAA/C,EACA,eAAgB,CAAE,EAClB,aAAc,EAClB,CAAG,EACK,CAACuR,EAAkBC,CAAmB,EAAI9yB,EAAM,SAASskB,CAAU,EACpE2N,GAAUY,EAAkBvO,CAAU,GACzCwO,EAAoBxO,CAAU,EAEhC,KAAM,CAACyO,EAAYC,CAAa,EAAIhzB,EAAM,SAAS,IAAI,EACjD,CAACizB,EAAWC,CAAY,EAAIlzB,EAAM,SAAS,IAAI,EAC/CmzB,EAAenzB,EAAM,YAAY6O,GAAQ,CACzCA,GAAQukB,EAAa,UACvBA,EAAa,QAAUvkB,EACvBmkB,EAAcnkB,CAAI,EAExB,EAAK,CAACmkB,CAAa,CAAC,EACZK,EAAcrzB,EAAM,YAAY6O,GAAQ,CACxCA,IAASykB,EAAY,UACvBA,EAAY,QAAUzkB,EACtBqkB,EAAarkB,CAAI,EAEvB,EAAK,CAACqkB,CAAY,CAAC,EACXlC,EAAcwB,GAAqBO,EACnCQ,EAAad,GAAoBQ,EACjCG,EAAepzB,EAAM,OAAO,IAAI,EAChCszB,EAActzB,EAAM,OAAO,IAAI,EAC/BwzB,EAAUxzB,EAAM,OAAOoK,CAAI,EAC3BqpB,EAA0BnB,GAAaK,CAAoB,EAC3De,EAAcpB,GAAa/N,CAAQ,EACnCmM,EAAS1wB,EAAM,YAAY,IAAM,CACrC,GAAI,CAACozB,EAAa,SAAW,CAACE,EAAY,QACxC,OAEF,MAAMlP,EAAS,CACb,UAAA9C,EACA,SAAA+C,EACA,WAAYwO,CAClB,EACQa,EAAY,UACdtP,EAAO,SAAWsP,EAAY,SAEhCvP,GAAgBiP,EAAa,QAASE,EAAY,QAASlP,CAAM,EAAE,KAAKha,GAAQ,CAC9E,MAAMupB,EAAW,CACf,GAAGvpB,EACH,aAAc,EACtB,EACUwpB,EAAa,SAAW,CAAC3B,GAAUuB,EAAQ,QAASG,CAAQ,IAC9DH,EAAQ,QAAUG,EAClBxY,GAAS,UAAU,IAAM,CACvByX,EAAQe,CAAQ,CAC1B,CAAS,EAET,CAAK,CACF,EAAE,CAACd,EAAkBvR,EAAW+C,EAAUqP,CAAW,CAAC,EACvDnX,GAAM,IAAM,CACNtF,IAAS,IAASuc,EAAQ,QAAQ,eACpCA,EAAQ,QAAQ,aAAe,GAC/BZ,EAAQxoB,IAAS,CACf,GAAGA,EACH,aAAc,EACf,EAAC,EAER,EAAK,CAAC6M,CAAI,CAAC,EACT,MAAM2c,EAAe5zB,EAAM,OAAO,EAAK,EACvCuc,GAAM,KACJqX,EAAa,QAAU,GAChB,IAAM,CACXA,EAAa,QAAU,EAC7B,GACK,CAAE,CAAA,EACLrX,GAAM,IAAM,CAGV,GAFIyU,IAAaoC,EAAa,QAAUpC,GACpCuC,IAAYD,EAAY,QAAUC,GAClCvC,GAAeuC,EAAY,CAC7B,GAAIE,EAAwB,QAC1B,OAAOA,EAAwB,QAAQzC,EAAauC,EAAY7C,CAAM,EAEtEA,GAEH,CACF,EAAE,CAACM,EAAauC,EAAY7C,EAAQ+C,CAAuB,CAAC,EAC7D,MAAMnkB,EAAOtP,EAAM,QAAQ,KAAO,CAChC,UAAWozB,EACX,SAAUE,EACV,aAAAH,EACA,YAAAE,CACD,GAAG,CAACF,EAAcE,CAAW,CAAC,EACzBjO,EAAWplB,EAAM,QAAQ,KAAO,CACpC,UAAWgxB,EACX,SAAUuC,CACX,GAAG,CAACvC,EAAauC,CAAU,CAAC,EACvBM,EAAiB7zB,EAAM,QAAQ,IAAM,CACzC,MAAM8zB,EAAgB,CACpB,SAAUzP,EACV,KAAM,EACN,IAAK,CACX,EACI,GAAI,CAACe,EAAS,SACZ,OAAO0O,EAET,MAAMzxB,EAAI+vB,GAAWhN,EAAS,SAAUhb,EAAK,CAAC,EACxC9H,EAAI8vB,GAAWhN,EAAS,SAAUhb,EAAK,CAAC,EAC9C,OAAIsoB,EACK,CACL,GAAGoB,EACH,UAAW,aAAezxB,EAAI,OAASC,EAAI,MAC3C,GAAI6vB,GAAO/M,EAAS,QAAQ,GAAK,KAAO,CACtC,WAAY,WACtB,CACA,EAEW,CACL,SAAUf,EACV,KAAMhiB,EACN,IAAKC,CACX,CACA,EAAK,CAAC+hB,EAAUqO,EAAWtN,EAAS,SAAUhb,EAAK,EAAGA,EAAK,CAAC,CAAC,EAC3D,OAAOpK,EAAM,QAAQ,KAAO,CAC1B,GAAGoK,EACH,OAAAsmB,EACA,KAAAphB,EACA,SAAA8V,EACA,eAAAyO,CACJ,GAAM,CAACzpB,EAAMsmB,EAAQphB,EAAM8V,EAAUyO,CAAc,CAAC,CACpD,CCnQA,MAAMphB,GAAY,CAAC,WAAY,UAAW,UAAW,QAAS,OAAO,EAOrE,SAASshB,GAAcjoB,EAAO,CAC5B,OAAO,SAASA,EAAO,EAAE,GAAK,CAChC,CACA,MAAMkoB,GAAS,CACb,OAAQ,CAEN,WAAY,SAEZ,SAAU,WAEV,SAAU,SACV,OAAQ,EACR,IAAK,EACL,KAAM,EAEN,UAAW,eACZ,CACH,EACA,SAASC,GAAQC,EAAK,CACpB,OAA4BA,GAAQ,MAAQ,OAAO,KAAKA,CAAG,EAAE,SAAW,GAAKA,EAAI,mBAAqB,GAAK,CAACA,EAAI,QAClH,CAaA,MAAMC,GAAgCn0B,EAAM,WAAW,SAA0B2K,EAAOmQ,EAAc,CACpG,KAAM,CACF,SAAA7B,EACA,QAAAmb,EACA,QAAAC,EAAU,EACV,MAAAC,EACA,MAAAxoB,CACN,EAAQnB,EACJwI,EAAQtS,GAA8B8J,EAAO8H,EAAS,EAClD,CACJ,QAASmH,CACV,EAAG5Z,EAAM,OAAO8L,GAAS,IAAI,EACxBgO,EAAW9Z,EAAM,OAAO,IAAI,EAC5BwV,EAAYnG,GAAWyL,EAAchB,CAAQ,EAC7Cya,EAAYv0B,EAAM,OAAO,IAAI,EAC7Bw0B,EAAUx0B,EAAM,OAAO,CAAC,EACxB,CAACilB,EAAOwP,CAAQ,EAAIz0B,EAAM,SAAS,CACvC,iBAAkB,CACtB,CAAG,EACK00B,EAAkB10B,EAAM,YAAY,IAAM,CAC9C,MAAM20B,EAAQ7a,EAAS,QAEjByU,EADkBzf,GAAY6lB,CAAK,EACH,iBAAiBA,CAAK,EAG5D,GAAIpG,EAAc,QAAU,MAC1B,MAAO,CACL,iBAAkB,CAC1B,EAEI,MAAMqG,EAAeL,EAAU,QAC/BK,EAAa,MAAM,MAAQrG,EAAc,MACzCqG,EAAa,MAAQD,EAAM,OAAShqB,EAAM,aAAe,IACrDiqB,EAAa,MAAM,MAAM,EAAE,IAAM;AAAA,IAInCA,EAAa,OAAS,KAExB,MAAMC,EAAYtG,EAAc,UAC1BnL,EAAU2Q,GAAcxF,EAAc,aAAa,EAAIwF,GAAcxF,EAAc,UAAU,EAC7FuG,EAASf,GAAcxF,EAAc,iBAAiB,EAAIwF,GAAcxF,EAAc,cAAc,EAGpGwG,EAAcH,EAAa,aAGjCA,EAAa,MAAQ,IACrB,MAAMI,EAAkBJ,EAAa,aAGrC,IAAIK,EAAcF,EACdV,IACFY,EAAc,KAAK,IAAI,OAAOZ,CAAO,EAAIW,EAAiBC,CAAW,GAEnEb,IACFa,EAAc,KAAK,IAAI,OAAOb,CAAO,EAAIY,EAAiBC,CAAW,GAEvEA,EAAc,KAAK,IAAIA,EAAaD,CAAe,EAGnD,MAAME,EAAmBD,GAAeJ,IAAc,aAAezR,EAAU0R,EAAS,GAClFhN,EAAW,KAAK,IAAImN,EAAcF,CAAW,GAAK,EACxD,MAAO,CACL,iBAAAG,EACA,SAAApN,CACN,CACG,EAAE,CAACsM,EAASC,EAAS1pB,EAAM,WAAW,CAAC,EAClCwqB,EAAc,CAACC,EAAWC,IAAa,CAC3C,KAAM,CACJ,iBAAAH,EACA,SAAApN,CACD,EAAGuN,EAGJ,OAAIb,EAAQ,QAAU,KAAOU,EAAmB,GAAK,KAAK,KAAKE,EAAU,kBAAoB,GAAKF,CAAgB,EAAI,GAAKE,EAAU,WAAatN,IAChJ0M,EAAQ,SAAW,EACZ,CACL,SAAA1M,EACA,iBAAAoN,CACR,IAEQ,QAAQ,IAAI,WAAa,cACvBV,EAAQ,UAAY,IACtB,QAAQ,MAAM,CAAC,oDAAqD,4EAA4E,EAAE,KAAK;AAAA,CAAI,CAAC,EAGzJY,EACX,EACQE,EAAat1B,EAAM,YAAY,IAAM,CACzC,MAAMq1B,EAAWX,IACbT,GAAQoB,CAAQ,GAGpBZ,EAASW,GAAaD,EAAYC,EAAWC,CAAQ,CAAC,CAC1D,EAAK,CAACX,CAAe,CAAC,EACpBtlB,GAAkB,IAAM,CACtB,MAAMmmB,EAA0B,IAAM,CACpC,MAAMF,EAAWX,IACbT,GAAQoB,CAAQ,GASpBla,GAAS,UAAU,IAAM,CACvBsZ,EAASW,GAAaD,EAAYC,EAAWC,CAAQ,CAAC,CAC9D,CAAO,CACP,EACUG,EAAe,IAAM,CACzBhB,EAAQ,QAAU,EAClBe,GACN,EAKI,IAAIE,EACJ,MAAMC,EAAkB,IAAM,CAC5B,qBAAqBD,CAAG,EACxBA,EAAM,sBAAsB,IAAM,CAChCD,GACR,CAAO,CACP,EACUG,EAAuBpnB,GAASinB,CAAY,EAC5Cb,EAAQ7a,EAAS,QACjBiD,EAAkBjO,GAAY6lB,CAAK,EACzC5X,EAAgB,iBAAiB,SAAU4Y,CAAoB,EAC/D,IAAIvE,EACJ,OAAI,OAAO,eAAmB,MAC5BA,EAAiB,IAAI,eAAe,QAAQ,IAAI,WAAa,OAASsE,EAAkBF,CAAY,EACpGpE,EAAe,QAAQuD,CAAK,GAEvB,IAAM,CACXgB,EAAqB,MAAK,EAC1B,qBAAqBF,CAAG,EACxB1Y,EAAgB,oBAAoB,SAAU4Y,CAAoB,EAC9DvE,GACFA,EAAe,WAAU,CAEjC,CACA,EAAK,CAACsD,CAAe,CAAC,EACpBtlB,GAAkB,IAAM,CACtBkmB,GACJ,CAAG,EACDt1B,EAAM,UAAU,IAAM,CACpBw0B,EAAQ,QAAU,CACtB,EAAK,CAAC1oB,CAAK,CAAC,EACV,MAAMuO,EAAetK,GAAS,CAC5BykB,EAAQ,QAAU,EACb5a,GACH0b,IAEErc,GACFA,EAASlJ,CAAK,CAEpB,EACE,OAAoByI,EAAK,KAACxY,EAAM,SAAU,CACxC,SAAU,CAAcyY,EAAAA,IAAK,WAAYtZ,EAAS,CAChD,MAAO2M,EACP,SAAUuO,EACV,IAAK7E,EAGL,KAAM6e,EACN,MAAOl1B,EAAS,CACd,OAAQ8lB,EAAM,iBAGd,SAAUA,EAAM,SAAW,SAAW,MACvC,EAAEqP,CAAK,CACT,EAAEnhB,CAAK,CAAC,EAAgBsF,EAAI,IAAC,WAAY,CACxC,cAAe,GACf,UAAW9N,EAAM,UACjB,SAAU,GACV,IAAK4pB,EACL,SAAU,GACV,MAAOp1B,EAAS,CAAA,EAAI60B,GAAO,OAAQM,EAAO,CACxC,WAAY,EACZ,cAAe,CACvB,CAAO,CACP,CAAK,CAAC,CACN,CAAG,CACH,CAAC,EACD,QAAQ,IAAI,WAAa,eAAeH,GAAiB,UAAmC,CAQ1F,UAAW1mB,EAAU,OAIrB,QAASA,EAAU,UAAU,CAACA,EAAU,OAAQA,EAAU,MAAM,CAAC,EAKjE,QAASA,EAAU,UAAU,CAACA,EAAU,OAAQA,EAAU,MAAM,CAAC,EAIjE,SAAUA,EAAU,KAIpB,YAAaA,EAAU,OAIvB,MAAOA,EAAU,OAIjB,MAAOA,EAAU,UAAU,CAACA,EAAU,QAAQA,EAAU,MAAM,EAAGA,EAAU,OAAQA,EAAU,MAAM,CAAC,CACtG;;;;gBClQC,UAAY,CAGZ,IAAImoB,EAAS,CAAE,EAAC,eAGhB,SAASC,GAAa,CAGrB,QAFI/kB,EAAU,CAAA,EAELzR,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CAC1C,IAAIy2B,EAAM,UAAUz2B,CAAC,EACrB,GAAKy2B,EAEL,KAAIC,EAAU,OAAOD,EAErB,GAAIC,IAAY,UAAYA,IAAY,SACvCjlB,EAAQ,KAAKglB,CAAG,UACN,MAAM,QAAQA,CAAG,GAC3B,GAAIA,EAAI,OAAQ,CACf,IAAIE,EAAQH,EAAW,MAAM,KAAMC,CAAG,EAClCE,GACHllB,EAAQ,KAAKklB,CAAK,CAEnB,UACSD,IAAY,SAAU,CAChC,GAAID,EAAI,WAAa,OAAO,UAAU,UAAY,CAACA,EAAI,SAAS,SAAQ,EAAG,SAAS,eAAe,EAAG,CACrGhlB,EAAQ,KAAKglB,EAAI,SAAU,CAAA,EAC3B,QACA,CAED,QAASv2B,KAAOu2B,EACXF,EAAO,KAAKE,EAAKv2B,CAAG,GAAKu2B,EAAIv2B,CAAG,GACnCuR,EAAQ,KAAKvR,CAAG,CAGlB,EACD,CAED,OAAOuR,EAAQ,KAAK,GAAG,CACvB,CAEoCmlB,EAAO,SAC3CJ,EAAW,QAAUA,EACrBI,EAAA,QAAiBJ,GAOjB,OAAO,WAAaA,CAEtB,6CCzDMK,GAAY,CAACvrB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ogBAAogB,CAAE,CAAC,EAC1vByE,GAAa0xB,EAAU,WAACD,EAAS,ECwCjCE,EAASD,EAAA,WAAW,CAACxrB,EAAoBqE,IAA4B,CACzE,KAAM,CAAE,SAAA2H,EAAU,KAAA0f,EAAM,MAAAC,EAAO,GAAGzjB,CAAS,EAAAlI,EAErC4rB,EAAW,CACf,GAAIF,EAAO,CAAE,MAAOA,EAAM,OAAQA,CAAA,EAAS,CAAC,EAC5C,GAAIC,EAAQ,CAAE,KAAMA,GAAU,CAAC,EAC/B,IAAAtnB,EACA,GAAG6D,CAAA,EAGD,OAAAhK,EAAAA,eAAe8N,CAAQ,EAClB6f,EAAA,aAAa7f,EAAqD4f,CAAQ,EAG5E,IACT,CAAC,EAEDH,EAAO,YAAc,SCvDf,MAAAK,GAAaN,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACC,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDF,GAAW,YAAc,aCdzB,MAAMG,GAAe,CAACjsB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kLAAkL,CAAE,CAAC,EAC3ayE,GAAa0xB,EAAU,WAACS,EAAY,ECEpCC,GAAgBV,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACI,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAe,CAACpsB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2VAA2V,CAAE,CAAC,EACplByE,GAAa0xB,EAAU,WAACY,EAAY,ECEpCC,GAAgBb,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACO,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAa,CAACvsB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2gEAA2gE,CAAE,CAAC,EAClwEyE,GAAa0xB,EAAU,WAACe,EAAU,ECElCC,GAAchB,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACU,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAe,CAAC1sB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,guBAAguB,CAAE,CAAC,EACz9ByE,GAAa0xB,EAAU,WAACkB,EAAY,ECEpCC,GAAgBnB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACa,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAW,CAAC7sB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qjDAAqjD,CAAE,CAAC,EAC1yDyE,GAAa0xB,EAAU,WAACqB,EAAQ,ECEhCC,GAAYtB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAgB,CAAChtB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ohBAAohB,CAAE,CAAC,EAC9wByE,GAAa0xB,EAAU,WAACwB,EAAa,ECErCC,GAAiBzB,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmB,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAa,CAACntB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mZAAqZ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2IAA6I,CAAA,CAAC,EAC30ByE,GAAa0xB,EAAU,WAAC2B,EAAU,ECElCC,GAAc5B,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsB,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAmB,CAACttB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+MAA+M,CAAE,CAAC,EAC5cyE,GAAa0xB,EAAU,WAAC8B,EAAgB,ECExCC,GAAoB/B,EAAA,WAAW,CACnCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyB,IAAqB,CAAA,CACxB,CAAA,CAEH,EAEDD,GAAkB,YAAc,oBCdhC,MAAME,GAAe,CAACztB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mLAAmL,CAAE,CAAC,EAC5ayE,GAAa0xB,EAAU,WAACiC,EAAY,ECEpCC,GAAgBlC,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4B,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAiB,CAAC5tB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iNAAiN,CAAE,CAAC,EAC5cyE,GAAa0xB,EAAU,WAACoC,EAAc,ECEtCC,GAAkBrC,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+B,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAuB,CAAC/tB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+NAA+N,CAAE,CAAC,EACheyE,GAAa0xB,EAAU,WAACuC,EAAoB,ECE5CC,GAAwBxC,EAAA,WAAW,CACvCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkC,IAAyB,CAAA,CAC5B,CAAA,CAEH,EAEDD,GAAsB,YAAc,wBCdpC,MAAME,GAA2B,CAACluB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+PAA+P,CAAE,CAAC,EACpgByE,GAAa0xB,EAAU,WAAC0C,EAAwB,ECEhDC,GAA4B3C,EAAA,WAAW,CAC3CxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqC,IAA6B,CAAA,CAChC,CAAA,CAEH,EAEDD,GAA0B,YAAc,4BCdxC,MAAME,GAAqB,CAACruB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2PAA2P,CAAE,CAAC,EAC1fyE,GAAa0xB,EAAU,WAAC6C,EAAkB,ECE1CC,GAAsB9C,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwC,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAe,CAACxuB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qLAAqL,CAAE,CAAC,EAC9ayE,GAAa0xB,EAAU,WAACgD,EAAY,ECEpCC,GAAgBjD,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2C,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAgB,CAAC3uB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kLAAkL,CAAE,CAAC,EAC5ayE,GAAa0xB,EAAU,WAACmD,EAAa,ECErCC,GAAiBpD,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8C,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAa,CAAC9uB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8KAA8K,CAAE,CAAC,EACrayE,GAAa0xB,EAAU,WAACsD,EAAU,ECElCC,GAAcvD,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiD,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAU,CAACjvB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wXAAwX,CAAE,CAAC,EAC5mByE,GAAa0xB,EAAU,WAACyD,EAAO,ECE/BC,GAAW1D,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoD,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAc,CAACpvB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oZAAoZ,CAAE,CAAC,EAC5oByE,GAAa0xB,EAAU,WAAC4D,EAAW,ECEnCC,GAAe7D,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuD,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAc,CAACvvB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0TAA0T,CAAE,CAAC,EACljByE,GAAa0xB,EAAU,WAAC+D,EAAW,ECEnCC,GAAehE,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0D,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAa,CAAC1vB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,soFAAsoF,CAAE,CAAC,EAC73FyE,GAAa0xB,EAAU,WAACkE,EAAU,ECElCC,GAAcnE,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6D,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAoB,CAAC7vB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+VAAiW,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,sMAAwM,CAAA,CAAC,EACz1ByE,GAAa0xB,EAAU,WAACqE,EAAiB,ECEzCC,GAAqBtE,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgE,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAc,CAAChwB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8VAA8V,CAAE,CAAC,EACtlByE,GAAa0xB,EAAU,WAACwE,EAAW,ECEnCC,GAAezE,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmE,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAa,CAACnwB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+QAA+Q,CAAE,CAAC,EACtgByE,GAAa0xB,EAAU,WAAC2E,EAAU,ECElCC,GAAc5E,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsE,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAiB,CAACtwB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wRAA0R,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,yUAA2U,CAAA,CAAC,EACl5ByE,GAAa0xB,EAAU,WAAC8E,EAAc,ECEtCC,GAAkB/E,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyE,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAiB,CAACzwB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gOAAkO,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4ZAA8Z,CAAA,CAAC,EAC76ByE,GAAa0xB,EAAU,WAACiF,EAAc,ECEtCC,GAAkBlF,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4E,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAc,CAAC5wB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kaAAka,CAAE,CAAC,EAC1pByE,GAAa0xB,EAAU,WAACoF,EAAW,ECEnCC,GAAerF,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+E,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAa,CAAC/wB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,saAAwa,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,8OAAgP,CAAA,CAAC,EACj8ByE,GAAa0xB,EAAU,WAACuF,EAAU,ECElCC,GAAcxF,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkF,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAa,CAAClxB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mJAAqJ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iWAAmW,CAAA,CAAC,EACjyByE,GAAa0xB,EAAU,WAAC0F,EAAU,ECElCC,GAAc3F,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqF,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAU,CAACrxB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kIAAoI,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,yWAA2W,CAAA,CAAC,EACrxByE,GAAa0xB,EAAU,WAAC6F,EAAO,ECE/BC,GAAW9F,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwF,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAW,CAACxxB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kRAAoR,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kbAAob,CAAA,CAAC,EAC/+ByE,GAAa0xB,EAAU,WAACgG,EAAQ,ECEhCC,GAAYjG,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2F,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAiB,CAAC3xB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4GAA8G,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4NAA8N,CAAA,CAAC,EACznByE,GAAa0xB,EAAU,WAACmG,EAAc,ECEtCC,GAAkBpG,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8F,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAiB,CAAC9xB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oMAAoM,CAAE,CAAC,EAC/byE,GAAa0xB,EAAU,WAACsG,EAAc,ECEtCC,GAAkBvG,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiG,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAW,CAACjyB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0UAA0U,CAAE,CAAC,EAC/jByE,GAAa0xB,EAAU,WAACyG,EAAQ,ECEhCC,GAAY1G,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoG,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAgB,CAACpyB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4NAA4N,CAAE,CAAC,EACtdyE,GAAa0xB,EAAU,WAAC4G,EAAa,ECErCC,GAAiB7G,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuG,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAqB,CAACvyB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uHAAuH,CAAE,CAAC,EACtXyE,GAAa0xB,EAAU,WAAC+G,EAAkB,ECE1CC,GAAsBhH,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0G,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAiB,CAAC1yB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2HAA2H,CAAE,CAAC,EACtXyE,GAAa0xB,EAAU,WAACkH,EAAc,ECEtCC,GAAkBnH,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6G,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAqB,CAAC7yB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qHAAqH,CAAE,CAAC,EACpXyE,GAAa0xB,EAAU,WAACqH,EAAkB,ECE1CC,GAAsBtH,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgH,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAiB,CAAChzB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4HAA4H,CAAE,CAAC,EACvXyE,GAAa0xB,EAAU,WAACwH,EAAc,ECEtCC,GAAkBzH,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmH,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAsB,CAACnzB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0HAA0H,CAAE,CAAC,EAC1XyE,GAAa0xB,EAAU,WAAC2H,EAAmB,ECE3CC,GAAuB5H,EAAA,WAAW,CACtCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsH,IAAwB,CAAA,CAC3B,CAAA,CAEH,EAEDD,GAAqB,YAAc,uBCdnC,MAAME,GAAkB,CAACtzB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4HAA4H,CAAE,CAAC,EACxXyE,GAAa0xB,EAAU,WAAC8H,EAAe,ECEvCC,GAAmB/H,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyH,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAmB,CAACzzB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uHAAuH,CAAE,CAAC,EACpXyE,GAAa0xB,EAAU,WAACiI,EAAgB,ECExCC,GAAoBlI,EAAA,WAAW,CACnCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4H,IAAqB,CAAA,CACxB,CAAA,CAEH,EAEDD,GAAkB,YAAc,oBCdhC,MAAME,GAAe,CAAC5zB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yGAAyG,CAAE,CAAC,EAClWyE,GAAa0xB,EAAU,WAACoI,EAAY,ECEpCC,GAAgBrI,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+H,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAe,CAAC/zB,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uXAAuX,CAAE,CAAC,EAChnByE,GAAa0xB,EAAU,WAACuI,EAAY,ECEpCC,GAAgBxI,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkI,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAW,CAACl0B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oMAAsM,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4GAA8G,CAAA,CAAC,EAC3lByE,GAAa0xB,EAAU,WAAC0I,EAAQ,ECEhCC,GAAY3I,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqI,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAkB,CAACr0B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,m7CAAm7C,CAAE,CAAC,EAC/qDyE,GAAa0xB,EAAU,WAAC6I,EAAe,ECEvCC,GAAmB9I,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwI,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAiB,CAACx0B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+HAAiI,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4GAA8G,CAAA,CAAC,EAC5hByE,GAAa0xB,EAAU,WAACgJ,EAAc,ECEtCC,GAAkBjJ,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2I,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAW,CAAC30B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wuCAAwuC,CAAE,CAAC,EAC79CyE,GAAa0xB,EAAU,WAACmJ,EAAQ,ECEhCC,GAAYpJ,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8I,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAW,CAAC90B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qLAAqL,CAAE,CAAC,EAC1ayE,GAAa0xB,EAAU,WAACsJ,EAAQ,ECEhCC,GAAYvJ,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiJ,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAgB,CAACj1B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gOAAgO,CAAE,CAAC,EAC1dyE,GAAa0xB,EAAU,WAACyJ,EAAa,ECErCC,GAAiB1J,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoJ,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAgB,CAACp1B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2WAA6W,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kHAAoH,CAAA,CAAC,EAC7wByE,GAAa0xB,EAAU,WAAC4J,EAAa,ECErCC,GAAiB7J,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuJ,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAmB,CAACv1B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wUAA0U,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uKAAyK,CAAA,CAAC,EAClyByE,GAAa0xB,EAAU,WAAC+J,EAAgB,ECExCC,GAAoBhK,EAAA,WAAW,CACnCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0J,IAAqB,CAAA,CACxB,CAAA,CAEH,EAEDD,GAAkB,YAAc,oBCdhC,MAAME,GAAU,CAAC11B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iTAAiT,CAAE,CAAC,EACriByE,GAAa0xB,EAAU,WAACkK,EAAO,ECE/BC,GAAWnK,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6J,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAoB,CAAC71B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sFAAwF,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,inBAAmnB,CAAA,CAAC,EAC3/ByE,GAAa0xB,EAAU,WAACqK,EAAiB,ECEzCC,GAAqBtK,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgK,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAiB,CAACh2B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+oBAA+oB,CAAE,CAAC,EAC14ByE,GAAa0xB,EAAU,WAACwK,EAAc,ECEtCC,GAAkBzK,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmK,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAa,CAACn2B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,krBAAkrB,CAAE,CAAC,EACz6ByE,GAAa0xB,EAAU,WAAC2K,EAAU,ECElCC,GAAc5K,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsK,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAkB,CAACt2B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oQAAoQ,CAAE,CAAC,EAChgByE,GAAa0xB,EAAU,WAAC8K,EAAe,ECEvCC,GAAmB/K,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyK,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAe,CAACz2B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+eAA+e,CAAE,CAAC,EACxuByE,GAAa0xB,EAAU,WAACiL,EAAY,ECEpCC,GAAgBlL,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4K,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAa,CAAC52B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sLAAwL,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,wOAA0O,CAAA,CAAC,EAC3sByE,GAAa0xB,EAAU,WAACoL,EAAU,ECElCC,GAAcrL,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+K,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAiB,CAAC/2B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0NAA0N,CAAE,CAAC,EACrdyE,GAAa0xB,EAAU,WAACuL,EAAc,ECEtCC,GAAkBxL,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkL,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAc,CAACl3B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qoBAAqoB,CAAE,CAAC,EAC73ByE,GAAa0xB,EAAU,WAAC0L,EAAW,ECEnCC,GAAe3L,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqL,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAA+B,CAACr3B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+6BAAi7B,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kSAAoS,CAAA,CAAC,EAChhDyE,GAAa0xB,EAAU,WAAC6L,EAA4B,ECEpDC,GAAgC9L,EAAA,WAAW,CAC/CxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwL,IAAiC,CAAA,CACpC,CAAA,CAEH,EAEDD,GAA8B,YAAc,gCCd5C,MAAME,GAAU,CAACx3B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gOAAkO,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2OAA6O,CAAA,CAAC,EACrvByE,GAAa0xB,EAAU,WAACgM,EAAO,ECE/BC,GAAWjM,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2L,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAqB,CAAC33B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qMAAqM,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4OAA8O,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,+iBAAijB,CAAA,CAAC,EAC30CyE,GAAa0xB,EAAU,WAACmM,EAAkB,ECE1CC,GAAsBpM,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8L,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAS,CAAC93B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mmBAAqmB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,8OAAgP,CAAA,CAAC,EAC1nCyE,GAAa0xB,EAAU,WAACsM,EAAM,ECE9BC,GAAUvM,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiM,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAe,CAACj4B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8WAA8W,CAAE,CAAC,EACvmByE,GAAa0xB,EAAU,WAACyM,EAAY,ECEpCC,GAAgB1M,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoM,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAc,CAACp4B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mPAAqP,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uHAAyH,CAAA,CAAC,EACxpByE,GAAa0xB,EAAU,WAAC4M,EAAW,ECEnCC,GAAe7M,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuM,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAqB,CAACv4B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mUAAqU,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kmBAAomB,CAAA,CAAC,EAC1tCyE,GAAa0xB,EAAU,WAAC+M,EAAkB,ECE1CC,GAAsBhN,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0M,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAA2B,CAAC14B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ycAA2c,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,ymBAA2mB,CAAA,CAAC,EAC72CyE,GAAa0xB,EAAU,WAACkN,EAAwB,ECEhDC,GAA4BnN,EAAA,WAAW,CAC3CxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6M,IAA6B,CAAA,CAChC,CAAA,CAEH,EAEDD,GAA0B,YAAc,4BCdxC,MAAME,GAAc,CAAC74B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ieAAie,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,mFAAqF,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,mIAAqI,CAAA,CAAC,EAC3hCyE,GAAa0xB,EAAU,WAACqN,EAAW,ECEnCC,GAAetN,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgN,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAiB,CAACh5B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wIAA0I,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,ycAA2c,CAAA,CAAC,EACl4ByE,GAAa0xB,EAAU,WAACwN,EAAc,ECEtCC,GAAkBzN,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmN,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAa,CAACn5B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sXAAsX,CAAE,CAAC,EAC7mByE,GAAa0xB,EAAU,WAAC2N,EAAU,ECElCC,GAAc5N,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsN,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAc,CAACt5B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+OAA+O,CAAE,CAAC,EACveyE,GAAa0xB,EAAU,WAAC8N,EAAW,ECEnCC,GAAe/N,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyN,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAY,CAACz5B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2LAA2L,CAAE,CAAC,EACjbyE,GAAa0xB,EAAU,WAACiO,EAAS,ECEjCC,GAAalO,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4N,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAmB,CAAC55B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qKAAqK,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,oNAAsN,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,6EAA+E,CAAA,CAAC,EAC/yByE,GAAa0xB,EAAU,WAACoO,EAAgB,ECExCC,GAAoBrO,EAAA,WAAW,CACnCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+N,IAAqB,CAAA,CACxB,CAAA,CAEH,EAEDD,GAAkB,YAAc,oBCdhC,MAAME,GAAc,CAAC/5B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iLAAmL,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4KAA8K,CAAA,CAAC,EAC3oByE,GAAa0xB,EAAU,WAACuO,EAAW,ECEnCC,GAAexO,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkO,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAoB,CAACl6B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,skCAAskC,CAAE,CAAC,EACp0CyE,GAAa0xB,EAAU,WAAC0O,EAAiB,ECEzCC,GAAqB3O,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqO,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAiB,CAACr6B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uQAAuQ,CAAE,CAAC,EAClgByE,GAAa0xB,EAAU,WAAC6O,EAAc,ECEtCC,GAAkB9O,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwO,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAU,CAACx6B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uVAAuV,CAAE,CAAC,EAC3kByE,GAAa0xB,EAAU,WAACgP,EAAO,ECE/BC,GAAWjP,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2O,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAkB,CAAC36B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yrBAAyrB,CAAE,CAAC,EACr7ByE,GAAa0xB,EAAU,WAACmP,EAAe,ECEvCC,GAAmBpP,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8O,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAsB,CAAC96B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wPAAwP,CAAE,CAAC,EACxfyE,GAAa0xB,EAAU,WAACsP,EAAmB,ECE3CC,GAAuBvP,EAAA,WAAW,CACtCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiP,IAAwB,CAAA,CAC3B,CAAA,CAEH,EAEDD,GAAqB,YAAc,uBCdnC,MAAME,GAAyB,CAACj7B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wNAAwN,CAAE,CAAC,EAC3dyE,GAAa0xB,EAAU,WAACyP,EAAsB,ECE9CC,GAA0B1P,EAAA,WAAW,CACzCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoP,IAA2B,CAAA,CAC9B,CAAA,CAEH,EAEDD,GAAwB,YAAc,0BCdtC,MAAME,GAAW,CAACp7B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yVAAyV,CAAE,CAAC,EAC9kByE,GAAa0xB,EAAU,WAAC4P,EAAQ,ECEhCC,GAAY7P,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuP,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAiB,CAACv7B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mNAAqN,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,+cAAid,CAAA,CAAC,EACn9ByE,GAAa0xB,EAAU,WAAC+P,EAAc,ECEtCC,GAAkBhQ,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0P,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAe,CAAC17B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2VAA2V,CAAE,CAAC,EACplByE,GAAa0xB,EAAU,WAACkQ,EAAY,ECEpCC,GAAgBnQ,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6P,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAW,CAAC77B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2oBAA2oB,CAAE,CAAC,EACh4ByE,GAAa0xB,EAAU,WAACqQ,EAAQ,ECEhCC,GAAYtQ,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgQ,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAwB,CAACh8B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4hDAA4hD,CAAE,CAAC,EAC9xDyE,GAAa0xB,EAAU,WAACwQ,EAAqB,ECE7CC,GAAyBzQ,EAAA,WAAW,CACxCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmQ,IAA0B,CAAA,CAC7B,CAAA,CAEH,EAEDD,GAAuB,YAAc,yBCdrC,MAAME,GAAgB,CAACn8B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0cAA0c,CAAE,CAAC,EACpsByE,GAAa0xB,EAAU,WAAC2Q,EAAa,ECErCC,GAAiB5Q,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsQ,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAY,CAACt8B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0OAA4O,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iUAAmU,CAAA,CAAC,EACv1ByE,GAAa0xB,EAAU,WAAC8Q,EAAS,ECEjCC,GAAa/Q,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyQ,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAgB,CAACz8B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0aAA0a,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2CAA6C,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,sUAAwU,CAAA,CAAC,EACjoCyE,GAAa0xB,EAAU,WAACiR,EAAa,ECErCC,GAAiBlR,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4Q,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAkB,CAAC58B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4XAA8X,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,8jBAAgkB,CAAA,CAAC,EAC5uCyE,GAAa0xB,EAAU,WAACoR,EAAe,ECEvCC,GAAmBrR,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+Q,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAgB,CAAC/8B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8GAA8G,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,0sBAA4sB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,saAAwa,CAAA,CAAC,EACpkDyE,GAAa0xB,EAAU,WAACuR,EAAa,ECErCC,GAAiBxR,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkR,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAS,CAACl9B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8HAAgI,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,krBAAorB,CAAA,CAAC,EACzlCyE,GAAa0xB,EAAU,WAAC0R,EAAM,ECE9BC,GAAU3R,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqR,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAiB,CAACr9B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2VAA2V,CAAE,CAAC,EACtlByE,GAAa0xB,EAAU,WAAC6R,EAAc,ECEtCC,GAAkB9R,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwR,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAU,CAACx9B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,00BAA00B,CAAE,CAAC,EAC9jCyE,GAAa0xB,EAAU,WAACgS,EAAO,ECE/BC,GAAWjS,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2R,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAY,CAAC39B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qaAAqa,CAAE,CAAC,EAC3pByE,GAAa0xB,EAAU,WAACmS,EAAS,ECEjCC,GAAapS,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8R,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAU,CAAC99B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,moBAAmoB,CAAE,CAAC,EACv3ByE,GAAa0xB,EAAU,WAACsS,EAAO,ECE/BC,GAAWvS,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiS,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAiB,CAACj+B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+UAA+U,CAAE,CAAC,EAC1kByE,GAAa0xB,EAAU,WAACyS,EAAc,ECEtCC,GAAkB1S,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoS,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAgB,CAACp+B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yTAAyT,CAAE,CAAC,EACnjByE,GAAa0xB,EAAU,WAAC4S,EAAa,ECErCC,GAAiB7S,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuS,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAuB,CAACv+B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6fAA+f,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uWAAyW,CAAA,CAAC,EAC3pCyE,GAAa0xB,EAAU,WAAC+S,EAAoB,ECE5CC,GAAwBhT,EAAA,WAAW,CACvCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0S,IAAyB,CAAA,CAC5B,CAAA,CAEH,EAEDD,GAAsB,YAAc,wBCdpC,MAAME,GAAa,CAAC1+B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ygBAAygB,CAAE,CAAC,EAChwByE,GAAa0xB,EAAU,WAACkT,EAAU,ECElCC,GAAcnT,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6S,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAkB,CAAC7+B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wRAAwR,CAAE,CAAC,EACphByE,GAAa0xB,EAAU,WAACqT,EAAe,ECEvCC,GAAmBtT,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgT,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAgB,CAACh/B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uNAAuN,CAAE,CAAC,EACjdyE,GAAa0xB,EAAU,WAACwT,EAAa,ECErCC,GAAiBzT,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmT,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAU,CAACn/B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,g5BAAg5B,CAAE,CAAC,EACpoCyE,GAAa0xB,EAAU,WAAC2T,EAAO,ECE/BC,GAAW5T,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsT,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAU,CAACt/B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yIAA2I,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,sKAAwK,CAAA,CAAC,EACzlByE,GAAa0xB,EAAU,WAAC8T,EAAO,ECE/BC,GAAW/T,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyT,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAgB,CAACz/B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uUAAuU,CAAE,CAAC,EACjkByE,GAAa0xB,EAAU,WAACiU,EAAa,ECErCC,GAAiBlU,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4T,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAa,CAAC5/B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,w4BAAw4B,CAAE,CAAC,EAC/nCyE,GAAa0xB,EAAU,WAACoU,EAAU,ECElCC,GAAcrU,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+T,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAU,CAAC//B,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0+DAA0+D,CAAE,CAAC,EAC9tEyE,GAAa0xB,EAAU,WAACuU,EAAO,ECE/BC,GAAWxU,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkU,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAU,CAAClgC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6jBAA+jB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iHAAmH,CAAA,CAAC,EACx9ByE,GAAa0xB,EAAU,WAAC0U,EAAO,ECE/BC,GAAW3U,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqU,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAa,CAACrgC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8NAAgO,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4FAA8F,CAAA,CAAC,EACvmByE,GAAa0xB,EAAU,WAAC6U,EAAU,ECElCC,GAAc9U,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwU,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAU,CAACxgC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,khCAAkhC,CAAE,CAAC,EACtwCyE,GAAa0xB,EAAU,WAACgV,EAAO,ECE/BC,GAAWjV,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2U,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAU,CAAC3gC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+LAAiM,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,gRAAkR,CAAA,CAAC,EACzvByE,GAAa0xB,EAAU,WAACmV,EAAO,ECE/BC,GAAWpV,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8U,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAY,CAAC9gC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kVAAoV,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,yTAA2T,CAAA,CAAC,EACv7ByE,GAAa0xB,EAAU,WAACsV,EAAS,ECEjCC,GAAavV,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiV,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAgB,CAACjhC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mLAAmL,CAAE,CAAC,EAC7ayE,GAAa0xB,EAAU,WAACyV,EAAa,ECErCC,GAAiB1V,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoV,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAU,CAACphC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gJAAkJ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4GAA8G,CAAA,CAAC,EACtiByE,GAAa0xB,EAAU,WAAC4V,EAAO,ECE/BC,GAAW7V,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuV,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAe,CAACvhC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0NAA0N,CAAE,CAAC,EACndyE,GAAa0xB,EAAU,WAAC+V,EAAY,ECEpCC,GAAgBhW,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0V,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAc,CAAC1hC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,okCAAokC,CAAE,CAAC,EAC5zCyE,GAAa0xB,EAAU,WAACkW,EAAW,ECEnCC,GAAenW,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6V,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAS,CAAC7hC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8CAAgD,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,yhBAA2hB,CAAA,CAAC,EACh3ByE,GAAa0xB,EAAU,WAACqW,EAAM,ECE9BC,GAAUtW,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgW,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAY,CAAChiC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wQAAwQ,CAAE,CAAC,EAC9fyE,GAAa0xB,EAAU,WAACwW,EAAS,ECEjCC,GAAazW,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmW,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAU,CAACniC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8pBAA8pB,CAAE,CAAC,EACl5ByE,GAAa0xB,EAAU,WAAC2W,EAAO,ECE/BC,GAAW5W,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsW,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAe,CAACtiC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qSAAqS,CAAE,CAAC,EAC9hByE,GAAa0xB,EAAU,WAAC8W,EAAY,ECEpCC,GAAgB/W,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyW,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAU,CAACziC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mcAAqc,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,wDAA0D,CAAA,CAAC,EACryByE,GAAa0xB,EAAU,WAACiX,EAAO,ECE/BC,GAAWlX,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4W,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAU,CAAC5iC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oUAAoU,CAAE,CAAC,EACxjByE,GAAa0xB,EAAU,WAACoX,EAAO,ECE/BC,GAAWrX,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+W,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAY,CAAC/iC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mMAAmM,CAAE,CAAC,EACzbyE,GAAa0xB,EAAU,WAACuX,EAAS,ECEjCC,GAAaxX,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkX,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAU,CAACljC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uDAAyD,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,+UAAiV,CAAA,CAAC,EAChrByE,GAAa0xB,EAAU,WAAC0X,EAAO,ECE/BC,GAAW3X,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqX,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAS,CAACrjC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0nCAA0nC,CAAE,CAAC,EAC72CyE,GAAa0xB,EAAU,WAAC6X,EAAM,ECE9BC,GAAU9X,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwX,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAe,CAACxjC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yMAAyM,CAAE,CAAC,EAClcyE,GAAa0xB,EAAU,WAACgY,EAAY,ECEpCC,GAAgBjY,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2X,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAW,CAAC3jC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6EAA6E,CAAE,CAAC,EAClUyE,GAAa0xB,EAAU,WAACmY,EAAQ,ECEhCC,GAAYpY,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8X,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAoB,CAAC9jC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kWAAoW,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uPAAyP,CAAA,CAAC,EAC74ByE,GAAa0xB,EAAU,WAACsY,EAAiB,ECEzCC,GAAqBvY,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiY,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAwB,CAACjkC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sHAAsH,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2YAA6Y,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4PAA8P,CAAA,CAAC,EAC3mCyE,GAAa0xB,EAAU,WAACyY,EAAqB,ECE7CC,GAAyB1Y,EAAA,WAAW,CACxCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoY,IAA0B,CAAA,CAC7B,CAAA,CAEH,EAEDD,GAAuB,YAAc,yBCdrC,MAAME,GAA0B,CAACpkC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wRAAwR,CAAE,CAAC,EAC5hByE,GAAa0xB,EAAU,WAAC4Y,EAAuB,ECE/CC,GAA2B7Y,EAAA,WAAW,CAC1CxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuY,IAA4B,CAAA,CAC/B,CAAA,CAEH,EAEDD,GAAyB,YAAc,2BCdvC,MAAME,GAAyB,CAACvkC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qRAAqR,CAAE,CAAC,EACxhByE,GAAa0xB,EAAU,WAAC+Y,EAAsB,ECE9CC,GAA0BhZ,EAAA,WAAW,CACzCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0Y,IAA2B,CAAA,CAC9B,CAAA,CAEH,EAEDD,GAAwB,YAAc,0BCdtC,MAAME,GAAgB,CAAC1kC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,orDAAorD,CAAE,CAAC,EAC96DyE,GAAa0xB,EAAU,WAACkZ,EAAa,ECErCC,GAAiBnZ,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6Y,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAe,CAAC7kC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6KAA6K,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,0YAA4Y,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kRAAoR,CAAA,CAAC,EAC9qCyE,GAAa0xB,EAAU,WAACqZ,EAAY,ECEpCC,GAAgBtZ,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgZ,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAuB,CAAChlC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+MAA+M,CAAE,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,gPAAkP,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,0PAA4P,CAAA,CAAC,EACtiCyE,GAAa0xB,EAAU,WAACwZ,EAAoB,ECE5CC,GAAwBzZ,EAAA,WAAW,CACvCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmZ,IAAyB,CAAA,CAC5B,CAAA,CAEH,EAEDD,GAAsB,YAAc,wBCdpC,MAAME,GAAU,CAACnlC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2cAA2c,CAAE,CAAC,EAC/rByE,GAAa0xB,EAAU,WAAC2Z,EAAO,ECE/BC,GAAW5Z,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsZ,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAc,CAACtlC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,g6BAAg6B,CAAE,CAAC,EACxpCyE,GAAa0xB,EAAU,WAAC8Z,EAAW,ECEnCC,GAAe/Z,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyZ,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAkB,CAACzlC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wkBAAwkB,CAAE,CAAC,EACp0ByE,GAAa0xB,EAAU,WAACia,EAAe,ECEvCC,GAAmBla,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4Z,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAY,CAAC5lC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iaAAia,CAAE,CAAC,EACvpByE,GAAa0xB,EAAU,WAACoa,EAAS,ECEjCC,GAAara,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+Z,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAiB,CAAC/lC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+HAA+H,CAAE,CAAC,EAC1XyE,GAAa0xB,EAAU,WAACua,EAAc,ECEtCC,GAAkBxa,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACka,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAa,CAAClmC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yDAA2D,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iHAAmH,CAAA,CAAC,EACvdyE,GAAa0xB,EAAU,WAAC0a,EAAU,ECElCC,GAAc3a,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqa,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAW,CAACrmC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+qBAA+qB,CAAE,CAAC,EACp6ByE,GAAa0xB,EAAU,WAAC6a,EAAQ,ECEhCC,GAAY9a,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwa,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAA0B,CAACxmC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oVAAoV,CAAE,CAAC,EACxlByE,GAAa0xB,EAAU,WAACgb,EAAuB,ECE/CC,GAA2Bjb,EAAA,WAAW,CAC1CxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2a,IAA4B,CAAA,CAC/B,CAAA,CAEH,EAEDD,GAAyB,YAAc,2BCdvC,MAAME,GAAwB,CAAC3mC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gVAAgV,CAAE,CAAC,EACllByE,GAAa0xB,EAAU,WAACmb,EAAqB,ECE7CC,GAAyBpb,EAAA,WAAW,CACxCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8a,IAA0B,CAAA,CAC7B,CAAA,CAEH,EAEDD,GAAuB,YAAc,yBCdrC,MAAME,GAAyB,CAAC9mC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wVAAwV,CAAE,CAAC,EAC3lByE,GAAa0xB,EAAU,WAACsb,EAAsB,ECE9CC,GAA0Bvb,EAAA,WAAW,CACzCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACib,IAA2B,CAAA,CAC9B,CAAA,CAEH,EAEDD,GAAwB,YAAc,0BCdtC,MAAME,GAAgB,CAACjnC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sTAAsT,CAAE,CAAC,EAChjByE,GAAa0xB,EAAU,WAACyb,EAAa,ECErCC,GAAiB1b,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACob,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAc,CAACpnC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,inCAAmnC,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iTAAmT,CAAA,CAAC,EAChtDyE,GAAa0xB,EAAU,WAAC4b,EAAW,ECEnCC,GAAe7b,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACub,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAc,CAACvnC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,knCAAonC,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,scAAwc,CAAA,CAAC,EACt2DyE,GAAa0xB,EAAU,WAAC+b,EAAW,ECEnCC,GAAehc,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0b,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAc,CAAC1nC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4/CAA8/C,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,qGAAuG,CAAA,CAAC,EAC/4DyE,GAAa0xB,EAAU,WAACkc,EAAW,ECEnCC,GAAenc,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6b,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAc,CAAC7nC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,siDAAsiD,CAAE,CAAC,EAC9xDyE,GAAa0xB,EAAU,WAACqc,EAAW,ECEnCC,GAAetc,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgc,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAgB,CAAChoC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8QAAgR,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,6OAA+O,CAAA,CAAC,EAC3yByE,GAAa0xB,EAAU,WAACwc,EAAa,ECErCC,GAAiBzc,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmc,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAa,CAACnoC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sWAAwW,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2OAA6O,CAAA,CAAC,EAC93ByE,GAAa0xB,EAAU,WAAC2c,EAAU,ECElCC,GAAc5c,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsc,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAS,CAACtoC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0mCAA0mC,CAAE,CAAC,EAC71CyE,GAAa0xB,EAAU,WAAC8c,EAAM,ECE9BC,GAAU/c,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyc,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAc,CAACzoC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qyBAAuyB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,6YAA+Y,CAAA,CAAC,EACh+CyE,GAAa0xB,EAAU,WAACid,EAAW,ECEnCC,GAAeld,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4c,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAoB,CAAC5oC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8SAA8S,CAAE,CAAC,EAC5iByE,GAAa0xB,EAAU,WAACod,EAAiB,ECEzCC,GAAqBrd,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+c,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAgB,CAAC/oC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6JAA+J,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,qHAAuH,CAAA,CAAC,EAClkByE,GAAa0xB,EAAU,WAACud,EAAa,ECErCC,GAAiBxd,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkd,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAU,CAAClpC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uIAAuI,CAAE,CAAC,EAC3XyE,GAAa0xB,EAAU,WAAC0d,EAAO,ECE/BC,GAAW3d,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqd,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAiB,CAACrpC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uDAAyD,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uGAAyG,CAAA,CAAC,EAC/cyE,GAAa0xB,EAAU,WAAC6d,EAAc,ECEtCC,GAAkB9d,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwd,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAa,CAACxpC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2aAA2a,CAAE,CAAC,EAClqByE,GAAa0xB,EAAU,WAACge,EAAU,ECElCC,GAAcje,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2d,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAkB,CAAC3pC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,idAAmd,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,wnBAA0nB,CAAA,CAAC,EAC33CyE,GAAa0xB,EAAU,WAACme,EAAe,ECEvCC,GAAmBpe,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8d,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAe,CAAC9pC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0iBAA0iB,CAAE,CAAC,EACnyByE,GAAa0xB,EAAU,WAACse,EAAY,ECEpCC,GAAgBve,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACie,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAY,CAACjqC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gaAAga,CAAE,CAAC,EACtpByE,GAAa0xB,EAAU,WAACye,EAAS,ECEjCC,GAAa1e,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACoe,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAa,CAACpqC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uVAAuV,CAAE,CAAC,EAC9kByE,GAAa0xB,EAAU,WAAC4e,EAAU,ECElCC,GAAc7e,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACue,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAY,CAACvqC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,s2DAAs2D,CAAE,CAAC,EAC5lEyE,GAAa0xB,EAAU,WAAC+e,EAAS,ECEjCC,GAAahf,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0e,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAe,CAAC1qC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,m0CAAm0C,CAAE,CAAC,EAC5jDyE,GAAa0xB,EAAU,WAACkf,EAAY,ECEpCC,GAAgBnf,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6e,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAgB,CAAC7qC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6LAA6L,CAAE,CAAC,EACvbyE,GAAa0xB,EAAU,WAACqf,EAAa,ECErCC,GAAiBtf,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgf,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAiB,CAAChrC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,yLAAyL,CAAE,CAAC,EACpbyE,GAAa0xB,EAAU,WAACwf,EAAc,ECEtCC,GAAkBzf,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmf,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAY,CAACnrC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sSAAsS,CAAE,CAAC,EAC5hByE,GAAa0xB,EAAU,WAAC2f,EAAS,ECEjCC,GAAa5f,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsf,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAa,CAACtrC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qfAAqf,CAAE,CAAC,EAC5uByE,GAAa0xB,EAAU,WAAC8f,EAAU,ECElCC,GAAc/f,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyf,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAW,CAACzrC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wjBAAwjB,CAAE,CAAC,EAC7yByE,GAAa0xB,EAAU,WAACigB,EAAQ,ECEhCC,GAAYlgB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4f,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAsB,CAAC5rC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sKAAwK,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kYAAoY,CAAA,CAAC,EAC91ByE,GAAa0xB,EAAU,WAACogB,EAAmB,ECE3CC,GAAuBrgB,EAAA,WAAW,CACtCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+f,IAAwB,CAAA,CAC3B,CAAA,CAEH,EAEDD,GAAqB,YAAc,uBCdnC,MAAME,GAAU,CAAC/rC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wsCAAwsC,CAAE,CAAC,EAC57CyE,GAAa0xB,EAAU,WAACugB,EAAO,ECE/BC,GAAWxgB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkgB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAc,CAAClsC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qcAAqc,CAAE,CAAC,EAC7rByE,GAAa0xB,EAAU,WAAC0gB,EAAW,ECEnCC,GAAe3gB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqgB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAY,CAACrsC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2LAA2L,CAAE,CAAC,EACjbyE,GAAa0xB,EAAU,WAAC6gB,EAAS,ECEjCC,GAAa9gB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwgB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAoB,CAACxsC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,glBAAglB,CAAE,CAAC,EAC90ByE,GAAa0xB,EAAU,WAACghB,EAAiB,ECEzCC,GAAqBjhB,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2gB,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAU,CAAC3sC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gpBAAgpB,CAAE,CAAC,EACp4ByE,GAAa0xB,EAAU,WAACmhB,EAAO,ECE/BC,GAAWphB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8gB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAiB,CAAC9sC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,uTAAyT,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2OAA6O,CAAA,CAAC,EACn1ByE,GAAa0xB,EAAU,WAACshB,EAAc,ECEtCC,GAAkBvhB,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACihB,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAc,CAACjtC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4yGAA4yG,CAAE,CAAC,EACpiHyE,GAAa0xB,EAAU,WAACyhB,EAAW,ECEnCC,GAAe1hB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACohB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAW,CAACptC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8JAAgK,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kNAAoN,CAAA,CAAC,EAC3pByE,GAAa0xB,EAAU,WAAC4hB,EAAQ,ECEhCC,GAAY7hB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACuhB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAU,CAACvtC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ukCAAukC,CAAE,CAAC,EAC3zCyE,GAAa0xB,EAAU,WAAC+hB,EAAO,ECE/BC,GAAWhiB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0hB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAY,CAAC1tC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0WAA0W,CAAE,CAAC,EAChmByE,GAAa0xB,EAAU,WAACkiB,EAAS,ECEjCC,GAAaniB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6hB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAU,CAAC7tC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wnDAAwnD,CAAE,CAAC,EAC52DyE,GAAa0xB,EAAU,WAACqiB,EAAO,ECE/BC,GAAWtiB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgiB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAe,CAAChuC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0nBAA0nB,CAAE,CAAC,EACn3ByE,GAAa0xB,EAAU,WAACwiB,EAAY,ECEpCC,GAAgBziB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmiB,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAS,CAACnuC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,6mBAA+mB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,6OAA+O,CAAA,CAAC,EACnoCyE,GAAa0xB,EAAU,WAAC2iB,EAAM,ECE9BC,GAAU5iB,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsiB,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAc,CAACtuC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4XAA4X,CAAE,CAAC,EACpnByE,GAAa0xB,EAAU,WAAC8iB,EAAW,ECEnCC,GAAe/iB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyiB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAU,CAACzuC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,+nBAA+nB,CAAE,CAAC,EACn3ByE,GAAa0xB,EAAU,WAACijB,EAAO,ECE/BC,GAAWljB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4iB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAe,CAAC5uC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wKAAwK,CAAE,CAAC,EACjayE,GAAa0xB,EAAU,WAACojB,EAAY,ECEpCC,GAAgBrjB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+iB,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAW,CAAC/uC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,wPAA0P,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4GAA8G,CAAA,CAAC,EAC/oByE,GAAa0xB,EAAU,WAACujB,EAAQ,ECEhCC,GAAYxjB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkjB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAe,CAAClvC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8CAA8C,CAAE,CAAC,EACvSyE,GAAa0xB,EAAU,WAAC0jB,EAAY,ECEpCC,GAAgB3jB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqjB,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAU,CAACrvC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,mJAAqJ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,iHAAmH,CAAA,CAAC,EAC9iByE,GAAa0xB,EAAU,WAAC6jB,EAAO,ECE/BC,GAAW9jB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwjB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAe,CAACxvC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qFAAuF,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,wQAA0Q,CAAA,CAAC,EAC5oByE,GAAa0xB,EAAU,WAACgkB,EAAY,ECEpCC,GAAgBjkB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2jB,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAqB,CAAC3vC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iRAAmR,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,+QAAiR,CAAA,CAAC,EACr1ByE,GAAa0xB,EAAU,WAACmkB,EAAkB,ECE1CC,GAAsBpkB,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8jB,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAY,CAAC9vC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0wBAA0wB,CAAE,CAAC,EAChgCyE,GAAa0xB,EAAU,WAACskB,EAAS,ECEjCC,GAAavkB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACikB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAgB,CAACjwC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qXAAqX,CAAE,CAAC,EAC/mByE,GAAa0xB,EAAU,WAACykB,EAAa,ECErCC,GAAiB1kB,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACokB,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAY,CAACpwC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,y9CAAy9C,CAAE,CAAC,EAC/sDyE,GAAa0xB,EAAU,WAAC4kB,EAAS,ECEjCC,GAAa7kB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACukB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAU,CAACvwC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ggCAAggC,CAAE,CAAC,EACpvCyE,GAAa0xB,EAAU,WAAC+kB,EAAO,ECE/BC,GAAWhlB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0kB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAqB,CAAC1wC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8SAA8S,CAAE,CAAC,EAC7iByE,GAAa0xB,EAAU,WAACklB,EAAkB,ECE1CC,GAAsBnlB,EAAA,WAAW,CACrCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6kB,IAAuB,CAAA,CAC1B,CAAA,CAEH,EAEDD,GAAoB,YAAc,sBCdlC,MAAME,GAAoB,CAAC7wC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gTAAgT,CAAE,CAAC,EAC9iByE,GAAa0xB,EAAU,WAACqlB,EAAiB,ECEzCC,GAAqBtlB,EAAA,WAAW,CACpCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACglB,IAAsB,CAAA,CACzB,CAAA,CAEH,EAEDD,GAAmB,YAAc,qBCdjC,MAAME,GAAY,CAAChxC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kdAAkd,CAAE,CAAC,EACxsByE,GAAa0xB,EAAU,WAACwlB,EAAS,ECEjCC,GAAazlB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmlB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAS,CAACnxC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8cAA8c,CAAE,CAAC,EACjsByE,GAAa0xB,EAAU,WAAC2lB,EAAM,ECE9BC,GAAU5lB,EAAA,WAAW,CACzBxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACslB,IAAW,CAAA,CACd,CAAA,CAEH,EAEDD,GAAQ,YAAc,UCdtB,MAAME,GAAc,CAACtxC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kLAAoL,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,2UAA6U,CAAA,CAAC,EAC3yByE,GAAa0xB,EAAU,WAAC8lB,EAAW,ECEnCC,GAAe/lB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACylB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAc,CAACzxC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4QAA4Q,CAAE,CAAC,EACpgByE,GAAa0xB,EAAU,WAACimB,EAAW,ECEnCC,GAAelmB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4lB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAgB,CAAC5xC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,0JAA0J,CAAE,CAAC,EACpZyE,GAAa0xB,EAAU,WAAComB,EAAa,ECErCC,GAAiBrmB,EAAA,WAAW,CAChCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+lB,IAAkB,CAAA,CACrB,CAAA,CAEH,EAEDD,GAAe,YAAc,iBCd7B,MAAME,GAAe,CAAC/xC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4OAA4O,CAAE,CAAC,EACreyE,GAAa0xB,EAAU,WAACumB,EAAY,ECEpCC,GAAgBxmB,EAAA,WAAW,CAC/BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkmB,IAAiB,CAAA,CACpB,CAAA,CAEH,EAEDD,GAAc,YAAc,gBCd5B,MAAME,GAAY,CAAClyC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oEAAsE,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,ihBAAmhB,CAAA,CAAC,EACj4ByE,GAAa0xB,EAAU,WAAC0mB,EAAS,ECEjCC,GAAa3mB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqmB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAc,CAACryC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,gUAAgU,CAAE,CAAC,EACxjByE,GAAa0xB,EAAU,WAAC6mB,EAAW,ECEnCC,GAAe9mB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwmB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAW,CAACxyC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ikDAAikD,CAAE,CAAC,EACtzDyE,GAAa0xB,EAAU,WAACgnB,EAAQ,ECEhCC,GAAYjnB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2mB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAW,CAAC3yC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iTAAiT,CAAE,CAAC,EACtiByE,GAAa0xB,EAAU,WAACmnB,EAAQ,ECEhCC,GAAYpnB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8mB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAc,CAAC9yC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,sQAAwQ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,kNAAoN,CAAA,CAAC,EACtwByE,GAAa0xB,EAAU,WAACsnB,EAAW,ECEnCC,GAAevnB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACinB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAkB,CAACjzC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,ojBAAojB,CAAE,CAAC,EAChzByE,GAAa0xB,EAAU,WAACynB,EAAe,ECEvCC,GAAmB1nB,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAConB,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAU,CAACpzC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kcAAkc,CAAE,CAAC,EACtrByE,GAAa0xB,EAAU,WAAC4nB,EAAO,ECE/BC,GAAW7nB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACunB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAY,CAACvzC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,w0BAAw0B,CAAE,CAAC,EAC9jCyE,GAAa0xB,EAAU,WAAC+nB,EAAS,ECEjCC,GAAahoB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC0nB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAY,CAAC1zC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2DAA6D,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,uVAAyV,CAAA,CAAC,EAC9rByE,GAAa0xB,EAAU,WAACkoB,EAAS,ECEjCC,GAAanoB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC6nB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAiB,CAAC7zC,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,oRAAoR,CAAE,CAAC,EAC/gByE,GAAa0xB,EAAU,WAACqoB,EAAc,ECEtCC,GAAkBtoB,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACgoB,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAY,CAACh0C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iJAAmJ,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,8KAAgL,CAAA,CAAC,EAC3mByE,GAAa0xB,EAAU,WAACwoB,EAAS,ECEjCC,GAAazoB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACmoB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAY,CAACn0C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8xBAA8xB,CAAE,CAAC,EACphCyE,GAAa0xB,EAAU,WAAC2oB,EAAS,ECEjCC,GAAa5oB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACsoB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAW,CAACt0C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,scAAsc,CAAE,CAAC,EAC3rByE,GAAa0xB,EAAU,WAAC8oB,EAAQ,ECEhCC,GAAY/oB,EAAA,WAAW,CAC3BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACyoB,IAAa,CAAA,CAChB,CAAA,CAEH,EAEDD,GAAU,YAAc,YCdxB,MAAME,GAAY,CAACz0C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,4hBAA8hB,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,s1BAAw1B,CAAA,CAAC,EAC9pDyE,GAAa0xB,EAAU,WAACipB,EAAS,ECEjCC,GAAalpB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC4oB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,MAAME,GAAa,CAAC50C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,2QAA6Q,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,4cAA8c,CAAA,CAAC,EACpgCyE,GAAa0xB,EAAU,WAACopB,EAAU,ECElCC,GAAcrpB,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC+oB,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAU,CAAC/0C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAK,EAAoB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,qIAAuI,CAAA,EAAmBA,EAAM,cAAc,OAAQ,CAAE,EAAG,qHAAuH,CAAA,CAAC,EACpiByE,GAAa0xB,EAAU,WAACupB,EAAO,ECE/BC,GAAWxpB,EAAA,WAAW,CAC1BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACkpB,IAAY,CAAA,CACf,CAAA,CAEH,EAEDD,GAAS,YAAc,WCdvB,MAAME,GAAkB,CAACl1C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,kdAAkd,CAAE,CAAC,EAC9sByE,GAAa0xB,EAAU,WAAC0pB,EAAe,ECEvCC,GAAmB3pB,EAAA,WAAW,CAClCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACqpB,IAAoB,CAAA,CACvB,CAAA,CAEH,EAEDD,GAAiB,YAAc,mBCd/B,MAAME,GAAiB,CAACr1C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,iUAAiU,CAAE,CAAC,EAC5jByE,GAAa0xB,EAAU,WAAC6pB,EAAc,ECEtCC,GAAkB9pB,EAAA,WAAW,CACjCxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACwpB,IAAmB,CAAA,CACtB,CAAA,CAEH,EAEDD,GAAgB,YAAc,kBCd9B,MAAME,GAAa,CAACx1C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8YAA8Y,CAAE,CAAC,EACroByE,GAAa0xB,EAAU,WAACgqB,EAAU,ECElCC,GAAcjqB,EAAA,WAAW,CAC7BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC2pB,IAAe,CAAA,CAClB,CAAA,CAEH,EAEDD,GAAY,YAAc,cCd1B,MAAME,GAAc,CAAC31C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,unCAAunC,CAAE,CAAC,EAC/2CyE,GAAa0xB,EAAU,WAACmqB,EAAW,ECEnCC,GAAepqB,EAAA,WAAW,CAC9BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAAC8pB,IAAgB,CAAA,CACnB,CAAA,CAEH,EAEDD,GAAa,YAAc,eCd3B,MAAME,GAAY,CAAC91C,EAAOqE,IAAwBhP,EAAM,cAAc,MAAO,CAAE,MAAO,6BAA8B,MAAO,GAAI,OAAQ,GAAI,KAAM,eAAgB,QAAS,YAAa,IAAAgP,EAAK,GAAGrE,CAAO,EAAkB3K,EAAM,cAAc,OAAQ,CAAE,EAAG,8jBAA8jB,CAAE,CAAC,EACpzByE,GAAa0xB,EAAU,WAACsqB,EAAS,ECEjCC,GAAavqB,EAAA,WAAW,CAC5BxrB,EACAmQ,IAGE4b,MAACN,GAAQ,GAAGzrB,EAAO,IAAKmQ,EACtB,SAAA4b,EAAAA,IAACiqB,IAAc,CAAA,CACjB,CAAA,CAEH,EAEDD,GAAW,YAAc,aCdzB,SAASE,GAAczwC,EAAK,CAC1B,IAAIywC,EAAgBzwC,EAAI,cACxB,OAAS0wC,EAAiBD,IAAkB,OAASC,EAAiBA,EAAe,aAAe,KAAO,OAASA,EAAe,gBAAkB,MAAM,CACzJ,IAAIA,EACJD,EAAgBA,EAAc,WAAW,aAC1C,CACD,OAAOA,CACT,CACA,SAASE,GAAShkC,EAAQikC,EAAO,CAC/B,GAAI,CAACjkC,GAAU,CAACikC,EACd,MAAO,GAET,MAAMC,EAAWD,EAAM,aAAeA,EAAM,YAAW,EAGvD,GAAIjkC,EAAO,SAASikC,CAAK,EACvB,MAAO,GAIT,GAAIC,GAAYr3B,GAAaq3B,CAAQ,EAAG,CACtC,IAAIC,EAAOF,EACX,KAAOE,GAAM,CACX,GAAInkC,IAAWmkC,EACb,MAAO,GAGTA,EAAOA,EAAK,YAAcA,EAAK,IAChC,CACF,CAGD,MAAO,EACT,CAEA,SAASC,IAAc,CACrB,MAAMC,EAAS,UAAU,cACzB,OAAIA,GAAU,MAAQA,EAAO,SACpBA,EAAO,SAET,UAAU,QACnB,CACA,SAASC,IAAe,CACtB,MAAMD,EAAS,UAAU,cACzB,OAAIA,GAAU,MAAM,QAAQA,EAAO,MAAM,EAChCA,EAAO,OAAO,IAAI19B,GAAQ,CAC/B,GAAI,CACF,MAAA49B,EACA,QAAAC,CACD,EAAG79B,EACJ,OAAO49B,EAAQ,IAAMC,CAC3B,CAAK,EAAE,KAAK,GAAG,EAEN,UAAU,SACnB,CAcA,SAASC,GAAsBxxC,EAAO,CACpC,MAAO,CAACyxC,GAAS,GAAMzxC,EAAM,QAAU,GAAKA,EAAM,SAAW,GAAKA,EAAM,QAAU,GAAKA,EAAM,SAAW,GAAKA,EAAM,WAAa,GAAKA,EAAM,SAAW,GAAKA,EAAM,cAAgB,SAEjLA,EAAM,MAAQ,GAAKA,EAAM,OAAS,GAAKA,EAAM,WAAa,GAAKA,EAAM,SAAW,CAClF,CACA,SAAS0xC,IAAW,CAElB,MAAO,SAAS,KAAK,UAAU,MAAM,CACvC,CACA,SAASD,IAAY,CACnB,MAAME,EAAK,WACX,OAAOA,EAAG,KAAKR,GAAa,CAAA,GAAKQ,EAAG,KAAKN,GAAY,CAAE,CACzD,CACA,SAASO,IAAQ,CACf,OAAOT,GAAW,EAAG,cAAc,WAAW,KAAK,GAAK,CAAC,UAAU,cACrE,CACA,SAASU,GAAuBC,EAAaC,EAAQ,CAGnD,MAAMl6C,EAAS,CAAC,QAAS,KAAK,EAC9B,OAAKk6C,GACHl6C,EAAO,KAAK,GAAI,MAAS,EAEpBA,EAAO,SAASi6C,CAAW,CACpC,CAOA,SAASE,GAAYlzC,EAAM,CACzB,OAAQA,GAAQ,KAAO,OAASA,EAAK,gBAAkB,QACzD,CAaA,SAASmzC,GAAUjyC,EAAO,CACxB,MAAI,iBAAkBA,EACbA,EAAM,eAAe,CAAC,EAKxBA,EAAM,MACf,CACA,MAAMkyC,GAAoB,uHAC1B,SAASC,GAAkBziD,EAAS,CAClC,OAAOiqB,GAAcjqB,CAAO,GAAKA,EAAQ,QAAQwiD,EAAiB,CACpE,CChIA;AAAA;AAAA;AAAA,EASA,IAAIE,GAAqB,CAAC,qBAAsB,sBAAuB,wBAAyB,uBAAwB,sBAAuB,oCAAqC,+BAAgC,+BAAgC,gEAAiE,6CAA8C,sBAAsB,EACrXC,GAAmCD,GAAmB,KAAK,GAAG,EAC9DE,GAAY,OAAO,QAAY,IAC/BC,GAAUD,GAAY,UAAY,GAAK,QAAQ,UAAU,SAAW,QAAQ,UAAU,mBAAqB,QAAQ,UAAU,sBAC7HE,GAAc,CAACF,IAAa,QAAQ,UAAU,YAAc,SAAU5iD,EAAS,CACjF,IAAI+iD,EACJ,OAAO/iD,GAAY,OAAuC+iD,EAAuB/iD,EAAQ,eAAiB,MAAQ+iD,IAAyB,OAA3F,OAA6GA,EAAqB,KAAK/iD,CAAO,CAChM,EAAI,SAAUA,EAAS,CACrB,OAAOA,GAAY,KAA6B,OAASA,EAAQ,aACnE,EAUIgjD,GAAU,SAASA,EAAQ5zC,EAAM6zC,EAAQ,CAC3C,IAAIC,EACAD,IAAW,SACbA,EAAS,IAKX,IAAIE,EAAW/zC,GAAS,OAAoC8zC,EAAqB9zC,EAAK,gBAAkB,MAAQ8zC,IAAuB,OAArF,OAAuGA,EAAmB,KAAK9zC,EAAM,OAAO,EAC1Lg0C,EAAQD,IAAa,IAAMA,IAAa,OAOxCpiD,EAASqiD,GAASH,GAAU7zC,GAAQ4zC,EAAQ5zC,EAAK,UAAU,EAE/D,OAAOrO,CACT,EAOIsiD,GAAoB,SAA2Bj0C,EAAM,CACvD,IAAIk0C,EAIAC,EAAWn0C,GAAS,OAAoCk0C,EAAsBl0C,EAAK,gBAAkB,MAAQk0C,IAAwB,OAAvF,OAAyGA,EAAoB,KAAKl0C,EAAM,iBAAiB,EAC3M,OAAOm0C,IAAa,IAAMA,IAAa,MACzC,EAQIC,GAAgB,SAAuBjmC,EAAIkmC,EAAkBC,EAAQ,CAGvE,GAAIV,GAAQzlC,CAAE,EACZ,MAAO,GAET,IAAIomC,EAAa,MAAM,UAAU,MAAM,MAAMpmC,EAAG,iBAAiBolC,EAAiB,CAAC,EACnF,OAAIc,GAAoBZ,GAAQ,KAAKtlC,EAAIolC,EAAiB,GACxDgB,EAAW,QAAQpmC,CAAE,EAEvBomC,EAAaA,EAAW,OAAOD,CAAM,EAC9BC,CACT,EAoCIC,GAA2B,SAASA,EAAyBj+B,EAAU89B,EAAkBh+B,EAAS,CAGpG,QAFIk+B,EAAa,CAAA,EACbE,EAAkB,MAAM,KAAKl+B,CAAQ,EAClCk+B,EAAgB,QAAQ,CAC7B,IAAI7jD,EAAU6jD,EAAgB,QAC9B,GAAI,CAAAb,GAAQhjD,EAAS,EAAK,EAK1B,GAAIA,EAAQ,UAAY,OAAQ,CAE9B,IAAI8jD,EAAW9jD,EAAQ,mBACnB+jD,EAAUD,EAAS,OAASA,EAAW9jD,EAAQ,SAC/CgkD,EAAmBJ,EAAyBG,EAAS,GAAMt+B,CAAO,EAClEA,EAAQ,QACVk+B,EAAW,KAAK,MAAMA,EAAYK,CAAgB,EAElDL,EAAW,KAAK,CACd,YAAa3jD,EACb,WAAYgkD,CACtB,CAAS,CAET,KAAW,CAEL,IAAIC,EAAiBpB,GAAQ,KAAK7iD,EAAS2iD,EAAiB,EACxDsB,GAAkBx+B,EAAQ,OAAOzlB,CAAO,IAAMyjD,GAAoB,CAAC99B,EAAS,SAAS3lB,CAAO,IAC9F2jD,EAAW,KAAK3jD,CAAO,EAIzB,IAAIkkD,EAAalkD,EAAQ,YAEzB,OAAOylB,EAAQ,eAAkB,YAAcA,EAAQ,cAAczlB,CAAO,EAKxEmkD,EAAkB,CAACnB,GAAQkB,EAAY,EAAK,IAAM,CAACz+B,EAAQ,kBAAoBA,EAAQ,iBAAiBzlB,CAAO,GACnH,GAAIkkD,GAAcC,EAAiB,CAOjC,IAAIC,EAAoBR,EAAyBM,IAAe,GAAOlkD,EAAQ,SAAWkkD,EAAW,SAAU,GAAMz+B,CAAO,EACxHA,EAAQ,QACVk+B,EAAW,KAAK,MAAMA,EAAYS,CAAiB,EAEnDT,EAAW,KAAK,CACd,YAAa3jD,EACb,WAAYokD,CACxB,CAAW,CAEX,MAGQP,EAAgB,QAAQ,MAAMA,EAAiB7jD,EAAQ,QAAQ,CAElE,CACF,CACD,OAAO2jD,CACT,EAQIU,GAAc,SAAqBj1C,EAAM,CAC3C,MAAO,CAAC,MAAM,SAASA,EAAK,aAAa,UAAU,EAAG,EAAE,CAAC,CAC3D,EAQIgH,GAAc,SAAqBhH,EAAM,CAC3C,GAAI,CAACA,EACH,MAAM,IAAI,MAAM,kBAAkB,EAEpC,OAAIA,EAAK,SAAW,IAQb,0BAA0B,KAAKA,EAAK,OAAO,GAAKi0C,GAAkBj0C,CAAI,IAAM,CAACi1C,GAAYj1C,CAAI,EACzF,EAGJA,EAAK,QACd,EAUIk1C,GAAuB,SAA8Bl1C,EAAMm1C,EAAS,CACtE,IAAIvwC,EAAWoC,GAAYhH,CAAI,EAC/B,OAAI4E,EAAW,GAAKuwC,GAAW,CAACF,GAAYj1C,CAAI,EACvC,EAEF4E,CACT,EACIwwC,GAAuB,SAA8BzhD,EAAGpB,EAAG,CAC7D,OAAOoB,EAAE,WAAapB,EAAE,SAAWoB,EAAE,cAAgBpB,EAAE,cAAgBoB,EAAE,SAAWpB,EAAE,QACxF,EACI8iD,GAAU,SAAiBr1C,EAAM,CACnC,OAAOA,EAAK,UAAY,OAC1B,EACIs1C,GAAgB,SAAuBt1C,EAAM,CAC/C,OAAOq1C,GAAQr1C,CAAI,GAAKA,EAAK,OAAS,QACxC,EACIu1C,GAAuB,SAA8Bv1C,EAAM,CAC7D,IAAI,EAAIA,EAAK,UAAY,WAAa,MAAM,UAAU,MAAM,MAAMA,EAAK,QAAQ,EAAE,KAAK,SAAUkyC,EAAO,CACrG,OAAOA,EAAM,UAAY,SAC7B,CAAG,EACD,OAAO,CACT,EACIsD,GAAkB,SAAyBC,EAAOC,EAAM,CAC1D,QAASllD,EAAI,EAAGA,EAAIilD,EAAM,OAAQjlD,IAChC,GAAIilD,EAAMjlD,CAAC,EAAE,SAAWilD,EAAMjlD,CAAC,EAAE,OAASklD,EACxC,OAAOD,EAAMjlD,CAAC,CAGpB,EACImlD,GAAkB,SAAyB31C,EAAM,CACnD,GAAI,CAACA,EAAK,KACR,MAAO,GAET,IAAI41C,EAAa51C,EAAK,MAAQ0zC,GAAY1zC,CAAI,EAC1C61C,EAAc,SAAqB9/B,EAAM,CAC3C,OAAO6/B,EAAW,iBAAiB,6BAA+B7/B,EAAO,IAAI,CACjF,EACM+/B,EACJ,GAAI,OAAO,OAAW,KAAe,OAAO,OAAO,IAAQ,KAAe,OAAO,OAAO,IAAI,QAAW,WACrGA,EAAWD,EAAY,OAAO,IAAI,OAAO71C,EAAK,IAAI,CAAC,MAEnD,IAAI,CACF81C,EAAWD,EAAY71C,EAAK,IAAI,CACjC,OAAQ3G,EAAK,CAEZ,eAAQ,MAAM,2IAA4IA,EAAI,OAAO,EAC9J,EACR,CAEH,IAAI08C,EAAUP,GAAgBM,EAAU91C,EAAK,IAAI,EACjD,MAAO,CAAC+1C,GAAWA,IAAY/1C,CACjC,EACIg2C,GAAU,SAAiBh2C,EAAM,CACnC,OAAOq1C,GAAQr1C,CAAI,GAAKA,EAAK,OAAS,OACxC,EACIkH,GAAqB,SAA4BlH,EAAM,CACzD,OAAOg2C,GAAQh2C,CAAI,GAAK,CAAC21C,GAAgB31C,CAAI,CAC/C,EAGIi2C,GAAiB,SAAwBj2C,EAAM,CACjD,IAAIk2C,EAwBAC,EAAWn2C,GAAQ0zC,GAAY1zC,CAAI,EACnCo2C,GAAgBF,EAAYC,KAAc,MAAQD,IAAc,OAAS,OAASA,EAAU,KAI5FG,EAAW,GACf,GAAIF,GAAYA,IAAan2C,EAAM,CACjC,IAAIs2C,EAAeC,EAAuB57B,EAE1C,IADA07B,EAAW,CAAC,GAAGC,EAAgBF,KAAkB,MAAQE,IAAkB,SAAWC,EAAwBD,EAAc,iBAAmB,MAAQC,IAA0B,QAAUA,EAAsB,SAASH,CAAY,GAAKp2C,GAAS,OAA4B2a,EAAsB3a,EAAK,iBAAmB,MAAQ2a,IAAwB,QAAUA,EAAoB,SAAS3a,CAAI,GAClY,CAACq2C,GAAYD,GAAc,CAChC,IAAII,EAAYC,EAAgBC,EAIhCP,EAAWzC,GAAY0C,CAAY,EACnCA,GAAgBI,EAAaL,KAAc,MAAQK,IAAe,OAAS,OAASA,EAAW,KAC/FH,EAAW,CAAC,GAAGI,EAAiBL,KAAkB,MAAQK,IAAmB,SAAWC,EAAwBD,EAAe,iBAAmB,MAAQC,IAA0B,QAAUA,EAAsB,SAASN,CAAY,EAC1O,CACF,CACD,OAAOC,CACT,EACIM,GAAa,SAAoB32C,EAAM,CACzC,IAAI42C,EAAwB52C,EAAK,sBAAuB,EACtDuc,EAAQq6B,EAAsB,MAC9Bp6B,EAASo6B,EAAsB,OACjC,OAAOr6B,IAAU,GAAKC,IAAW,CACnC,EACIq6B,GAAW,SAAkB72C,EAAM4U,EAAM,CAC3C,IAAIkiC,EAAeliC,EAAK,aACtBmiC,EAAgBniC,EAAK,cAMvB,GAAI,iBAAiB5U,CAAI,EAAE,aAAe,SACxC,MAAO,GAET,IAAIg3C,EAAkBvD,GAAQ,KAAKzzC,EAAM,+BAA+B,EACpEi3C,EAAmBD,EAAkBh3C,EAAK,cAAgBA,EAC9D,GAAIyzC,GAAQ,KAAKwD,EAAkB,uBAAuB,EACxD,MAAO,GAET,GAAI,CAACH,GAAgBA,IAAiB,QAAUA,IAAiB,cAAe,CAC9E,GAAI,OAAOC,GAAkB,WAAY,CAIvC,QADIG,EAAel3C,EACZA,GAAM,CACX,IAAIm3C,EAAgBn3C,EAAK,cACrBmyC,EAAWuB,GAAY1zC,CAAI,EAC/B,GAAIm3C,GAAiB,CAACA,EAAc,YAAcJ,EAAcI,CAAa,IAAM,GAIjF,OAAOR,GAAW32C,CAAI,EACbA,EAAK,aAEdA,EAAOA,EAAK,aACH,CAACm3C,GAAiBhF,IAAanyC,EAAK,cAE7CA,EAAOmyC,EAAS,KAGhBnyC,EAAOm3C,CAEV,CACDn3C,EAAOk3C,CACR,CAWD,GAAIjB,GAAej2C,CAAI,EAKrB,MAAO,CAACA,EAAK,eAAgB,EAAC,OAmBhC,GAAI82C,IAAiB,cACnB,MAAO,EAGb,SAAaA,IAAiB,gBAM1B,OAAOH,GAAW32C,CAAI,EAKxB,MAAO,EACT,EAKIo3C,GAAyB,SAAgCp3C,EAAM,CACjE,GAAI,mCAAmC,KAAKA,EAAK,OAAO,EAGtD,QAFI+b,EAAa/b,EAAK,cAEf+b,GAAY,CACjB,GAAIA,EAAW,UAAY,YAAcA,EAAW,SAAU,CAE5D,QAASvrB,EAAI,EAAGA,EAAIurB,EAAW,SAAS,OAAQvrB,IAAK,CACnD,IAAI0hD,EAAQn2B,EAAW,SAAS,KAAKvrB,CAAC,EAEtC,GAAI0hD,EAAM,UAAY,SAGpB,OAAOuB,GAAQ,KAAK13B,EAAY,sBAAsB,EAAI,GAAO,CAACm2B,EAAM,SAASlyC,CAAI,CAExF,CAED,MAAO,EACR,CACD+b,EAAaA,EAAW,aACzB,CAKH,MAAO,EACT,EACIzU,GAAkC,SAAyC+O,EAASrW,EAAM,CAC5F,MAAI,EAAAA,EAAK,UAIT4zC,GAAQ5zC,CAAI,GAAKs1C,GAAct1C,CAAI,GAAK62C,GAAS72C,EAAMqW,CAAO,GAE9Dk/B,GAAqBv1C,CAAI,GAAKo3C,GAAuBp3C,CAAI,EAI3D,EACIq3C,GAAiC,SAAwChhC,EAASrW,EAAM,CAC1F,MAAI,EAAAkH,GAAmBlH,CAAI,GAAKgH,GAAYhH,CAAI,EAAI,GAAK,CAACsH,GAAgC+O,EAASrW,CAAI,EAIzG,EACIs3C,GAA4B,SAAmCC,EAAgB,CACjF,IAAI3yC,EAAW,SAAS2yC,EAAe,aAAa,UAAU,EAAG,EAAE,EACnE,MAAI,SAAM3yC,CAAQ,GAAKA,GAAY,EAMrC,EAMI4yC,GAAc,SAASA,EAAYjD,EAAY,CACjD,IAAIkD,EAAmB,CAAA,EACnBC,EAAmB,CAAA,EACvB,OAAAnD,EAAW,QAAQ,SAAU9mC,EAAM,EAAG,CACpC,IAAI0nC,EAAU,CAAC,CAAC1nC,EAAK,YACjB7c,EAAUukD,EAAU1nC,EAAK,YAAcA,EACvCkqC,EAAoBzC,GAAqBtkD,EAASukD,CAAO,EACzD5+B,EAAW4+B,EAAUqC,EAAY/pC,EAAK,UAAU,EAAI7c,EACpD+mD,IAAsB,EACxBxC,EAAUsC,EAAiB,KAAK,MAAMA,EAAkBlhC,CAAQ,EAAIkhC,EAAiB,KAAK7mD,CAAO,EAEjG8mD,EAAiB,KAAK,CACpB,cAAe,EACf,SAAUC,EACV,KAAMlqC,EACN,QAAS0nC,EACT,QAAS5+B,CACjB,CAAO,CAEP,CAAG,EACMmhC,EAAiB,KAAKtC,EAAoB,EAAE,OAAO,SAAU51C,EAAKo4C,EAAU,CACjF,OAAAA,EAAS,QAAUp4C,EAAI,KAAK,MAAMA,EAAKo4C,EAAS,OAAO,EAAIp4C,EAAI,KAAKo4C,EAAS,OAAO,EAC7Ep4C,CACR,EAAE,EAAE,EAAE,OAAOi4C,CAAgB,CAChC,EACIxuC,GAAW,SAAkB+C,EAAWqK,EAAS,CACnDA,EAAUA,GAAW,GACrB,IAAIk+B,EACJ,OAAIl+B,EAAQ,cACVk+B,EAAaC,GAAyB,CAACxoC,CAAS,EAAGqK,EAAQ,iBAAkB,CAC3E,OAAQghC,GAA+B,KAAK,KAAMhhC,CAAO,EACzD,QAAS,GACT,cAAeA,EAAQ,cACvB,iBAAkBihC,EACxB,CAAK,EAED/C,EAAaH,GAAcpoC,EAAWqK,EAAQ,iBAAkBghC,GAA+B,KAAK,KAAMhhC,CAAO,CAAC,EAE7GmhC,GAAYjD,CAAU,CAC/B,EClfA,MAAMsD,GADqB1mD,EAAmB,qBAAqB,SAAU,CAAA,IACvBmP,GAAMA,EAAI,GAChE,SAASw3C,GAAevqC,EAAU,CAChC,MAAMpN,EAAMhP,EAAM,OAAO,IAAM,CAC7B,GAAI,QAAQ,IAAI,WAAa,aAC3B,MAAM,IAAI,MAAM,+CAA+C,CAErE,CAAG,EACD,OAAA0mD,GAAuB,IAAM,CAC3B13C,EAAI,QAAUoN,CAClB,CAAG,EACMpc,EAAM,YAAY,UAAY,CACnC,QAAS4mD,EAAO,UAAU,OAAQzlD,EAAO,IAAI,MAAMylD,CAAI,EAAGC,EAAO,EAAGA,EAAOD,EAAMC,IAC/E1lD,EAAK0lD,CAAI,EAAI,UAAUA,CAAI,EAE7B,OAAO73C,EAAI,SAAW,KAAO,OAASA,EAAI,QAAQ,GAAG7N,CAAI,CAC1D,EAAE,CAAE,CAAA,CACP,CAgMA,IAAIob,GAAQ,OAAO,SAAa,IAAcwV,EAAAA,gBAAkBC,EAAAA,UAoQhE,SAAS7yB,IAAW,CAClB,OAAAA,GAAW,OAAO,OAAS,OAAO,OAAO,KAAI,EAAK,SAAUC,EAAQ,CAClE,QAASC,EAAI,EAAGA,EAAI,UAAU,OAAQA,IAAK,CACzC,IAAIC,EAAS,UAAUD,CAAC,EACxB,QAASE,KAAOD,EACV,OAAO,UAAU,eAAe,KAAKA,EAAQC,CAAG,IAClDH,EAAOG,CAAG,EAAID,EAAOC,CAAG,EAG7B,CACD,OAAOH,CACX,EACSD,GAAS,MAAM,KAAM,SAAS,CACvC,CAEA,IAAI2nD,GAAwB,GACxBC,GAAQ,EACZ,MAAMC,GAAQ,IAAM,eAAiBD,KACrC,SAASE,IAAgB,CACvB,KAAM,CAACC,EAAIC,CAAK,EAAInnD,EAAM,SAAS,IAAM8mD,GAAwBE,KAAU,MAAS,EACpF,OAAAzqC,GAAM,IAAM,CACN2qC,GAAM,MACRC,EAAMH,GAAK,CAAE,CAGhB,EAAE,CAAE,CAAA,EACLhnD,EAAM,UAAU,IAAM,CACf8mD,KACHA,GAAwB,GAE3B,EAAE,CAAE,CAAA,EACEI,CACT,CAWA,MAAME,GARapnD,EAAmB,QAAQ,SAAU,CAAA,GAQ5BinD,GAMtBI,GAA6BrnD,EAAM,WAAW,SAAuByjB,EAAMzU,EAAK,CACpF,GAAI,CACF,QAAS,CACP,UAAAsS,EACA,SAAU,CACR,SAAAqC,CACD,EACD,eAAgB,CACd,MAAAmC,CACD,CACF,EACD,MAAAsF,EAAQ,GACR,OAAAC,EAAS,EACT,UAAAi8B,EAAY,EACZ,YAAAC,EAAc,EACd,aAAAC,EACA,OAAAC,EACA,EAAAnmD,EACA,MAAO,CACL,UAAAoxB,EACA,GAAGg1B,CACT,EAAQ,CAAE,EACN,GAAG70C,CACJ,EAAG4Q,EACA,QAAQ,IAAI,WAAa,eACtBzU,GACH,QAAQ,KAAK,kEAAmE,YAAY,GAGhG,MAAM24C,EAAaP,KACnB,GAAI,CAACzjC,EACH,OAAO,KAKT4jC,GAAe,EACf,MAAMK,EAAkBL,EAAc,EAChCM,EAAOz8B,EAAQ,GAAKk8B,EAAY,GAAK,GACrCQ,EAAOz8B,EAAS,EAAIi8B,EAAY,EAChC,CAAC7kC,EAAMT,CAAS,EAAIV,EAAU,MAAM,GAAG,EACvCkO,EAAQjL,GAAS,MAAMZ,CAAQ,EAC/BokC,EAAgB,CAAC,CAACzmD,EAClB0mD,EAAiBvlC,IAAS,OAASA,IAAS,SAC5CwlC,EAAcT,GAAgBxlC,IAAc,MAAQ,SAAW,MACrE,IAAIkmC,EAAcV,GAAgBxlC,IAAc,MAAQ,QAAU,OAC9DwlC,GAAgBh4B,IAClB04B,EAAclmC,IAAc,MAAQ,OAAS,SAE/C,MAAMmmC,GAAUriC,GAAS,KAAO,OAASA,EAAM,IAAM,KAAO0hC,GAAgB1hC,EAAM,EAAI,GAChFsiC,GAAUtiC,GAAS,KAAO,OAASA,EAAM,IAAM,KAAO0hC,GAAgB1hC,EAAM,EAAI,GAChFuiC,EAAS/mD,GAAK,QAAU,KAAO8pB,IAAU,MAAQA,EAAQy8B,GAAQ,KAAOx8B,EAASy8B,KAAU,KAAO18B,EAAQ,EAAI,IAAMC,EAAS,IAAMw8B,EAAO,KAAOx8B,EAASy8B,IAAS,KACnKQ,EAAW,CACf,IAAKP,EAAgB,iBAAmB,GACxC,KAAMA,EAAgB,gBAAkB,iBACxC,OAAQA,EAAgB,GAAK,iBAC7B,MAAOA,EAAgB,iBAAmB,eAC3C,EAACtlC,CAAI,EACN,OAAoBziB,EAAM,cAAc,MAAOb,GAAS,CAAA,EAAI0T,EAAM,CAChE,cAAe,GACf,IAAK7D,EACL,MAAO+4C,EAAgB38B,EAAQA,EAAQm8B,EACvC,OAAQn8B,EACR,QAAS,OAASA,EAAQ,KAAOC,EAASD,EAAQC,EAASD,GAC3D,MAAO,CACL,SAAU,WACV,cAAe,OACf,CAAC88B,CAAW,EAAGC,EACf,CAACF,CAAW,EAAGG,EACf,CAAC3lC,CAAI,EAAGulC,GAAkBD,EAAgB,OAAS,eAAiBR,EAAc,EAAI,MACtF,UAAW,GAAKe,GAAY51B,GAAgC,IAC5D,GAAGg1B,CACJ,CACF,CAAA,EAAGH,EAAc,GAAkBvnD,EAAM,cAAc,OAAQ,CAC9D,SAAU,QAAU2nD,EAAa,IACjC,KAAM,OACN,OAAQF,EAGR,YAAaF,GAAejmD,EAAI,EAAI,GACpC,EAAG+mD,CACP,CAAG,EAAgBroD,EAAM,cAAc,OAAQ,CAC3C,OAAQunD,GAAe,CAACjmD,EAAIuR,EAAK,KAAO,OACxC,EAAGw1C,CACP,CAAG,EAAgBroD,EAAM,cAAc,WAAY,CAC/C,GAAI2nD,CACR,EAAkB3nD,EAAM,cAAc,OAAQ,CAC1C,EAAG,CAAC4nD,EACJ,EAAGA,GAAmBG,EAAgB,GAAK,GAC3C,MAAO38B,EAAQm8B,EACf,OAAQn8B,CACT,CAAA,CAAC,CAAC,CACL,CAAC,EAED,SAASm9B,IAAe,CACtB,MAAMC,EAAM,IAAI,IAChB,MAAO,CACL,KAAKz4C,EAAO3F,EAAM,CAChB,IAAIq+C,GACHA,EAAWD,EAAI,IAAIz4C,CAAK,IAAM,MAAQ04C,EAAS,QAAQC,GAAWA,EAAQt+C,CAAI,CAAC,CACjF,EACD,GAAG2F,EAAO44C,EAAU,CAClBH,EAAI,IAAIz4C,EAAO,CAAC,GAAIy4C,EAAI,IAAIz4C,CAAK,GAAK,CAAA,EAAK44C,CAAQ,CAAC,CACrD,EACD,IAAI54C,EAAO44C,EAAU,CACnB,IAAIC,EACJJ,EAAI,IAAIz4C,IAAS64C,EAAYJ,EAAI,IAAIz4C,CAAK,IAAM,KAAO,OAAS64C,EAAU,OAAOhnD,GAAKA,IAAM+mD,CAAQ,IAAM,CAAA,CAAE,CAC7G,CACL,CACA,CAEA,MAAME,GAAmC7oD,EAAM,cAAc,IAAI,EAC3D8oD,GAAmC9oD,EAAM,cAAc,IAAI,EAC3D+oD,GAA0B,IAAM,CACpC,IAAIC,EACJ,QAASA,EAAoBhpD,EAAM,WAAW6oD,EAAmB,IAAM,KAAO,OAASG,EAAkB,KAAO,IAClH,EACMC,GAAkB,IAAMjpD,EAAM,WAAW8oD,EAAmB,EAqElE,SAASI,GAAgBtkC,EAAM,CAC7B,MAAO,oBAAsBA,CAC/B,CAEA,SAAS0N,GAAaxmB,EAAO,CAC3B,MAAMkD,EAAMm6C,SAAOr9C,CAAK,EACxB,OAAAyQ,GAAM,IAAM,CACVvN,EAAI,QAAUlD,CAClB,CAAG,EACMkD,CACT,CAEA,MAAMo6C,GAAqCF,GAAgB,cAAc,EACzE,SAASG,GAASv9C,EAAOrL,EAAMohD,EAAa,CAC1C,OAAIA,GAAe,CAACD,GAAuBC,CAAW,EAC7C,EAEL,OAAO/1C,GAAU,SACZA,EAEFA,GAAS,KAAO,OAASA,EAAMrL,CAAI,CAC5C,CAMA,SAAS6oD,GAASC,EAAS5+C,EAAO,CAC5BA,IAAU,SACZA,EAAQ,CAAA,GAEV,KAAM,CACJ,KAAAsM,EACA,aAAAuyC,EACA,QAAAh2B,EACA,OAAAi2B,EACA,SAAU,CACR,aAAAC,EACA,SAAA/lC,CACD,EACD,KAAArU,CACD,EAAGi6C,EACE,CACJ,QAAAI,EAAU,GACV,MAAAC,EAAQ,EACR,YAAA3qC,EAAc,KACd,UAAA4qC,EAAY,GACZ,OAAAC,EAAS,EACT,KAAAC,EAAO,EACR,EAAGp/C,EACEq/C,EAAOf,KACPgB,EAAWlB,KACXmB,EAAiB53B,GAAarT,CAAW,EACzCkrC,EAAW73B,GAAas3B,CAAK,EAC7BQ,EAAiBpqD,EAAM,SACvBqqD,EAAarqD,EAAM,SACnBsqD,EAAatqD,EAAM,SACnBuqD,EAAiBvqD,EAAM,SACvBwqD,EAAoBxqD,EAAM,OAAO,EAAI,EACrCyqD,EAAoCzqD,EAAM,OAAO,EAAK,EACtD0qD,EAAqB1qD,EAAM,OAAO,IAAM,CAAE,CAAA,EAC1C2qD,EAAc3qD,EAAM,YAAY,IAAM,CAC1C,IAAI4qD,EACJ,MAAM5mD,GAAQ4mD,EAAwBp3B,EAAQ,QAAQ,YAAc,KAAO,OAASo3B,EAAsB,KAC1G,OAAQ5mD,GAAQ,KAAO,OAASA,EAAK,SAAS,OAAO,IAAMA,IAAS,WACxE,EAAK,CAACwvB,CAAO,CAAC,EAIZxzB,EAAM,UAAU,IAAM,CACpB,GAAI,CAAC2pD,EACH,OAEF,SAASH,EAAa/lC,EAAM,CAC1B,GAAI,CACF,KAAAxM,CACD,EAAGwM,EACCxM,IACH,aAAaozC,EAAW,OAAO,EAC/B,aAAaE,EAAe,OAAO,EACnCC,EAAkB,QAAU,GAE/B,CACD,OAAAf,EAAO,GAAG,aAAcD,CAAY,EAC7B,IAAM,CACXC,EAAO,IAAI,aAAcD,CAAY,CAC3C,CACA,EAAK,CAACG,EAASF,CAAM,CAAC,EACpBzpD,EAAM,UAAU,IAAM,CACpB,GAAI,CAAC2pD,GAAW,CAACO,EAAe,SAAW,CAACjzC,EAC1C,OAEF,SAAS4zC,EAAQ96C,EAAO,CAClB46C,EAAW,GACbnB,EAAa,GAAOz5C,EAAO,OAAO,CAErC,CACD,MAAMyd,EAAOu0B,GAAYp+B,CAAQ,EAAE,gBACnC,OAAA6J,EAAK,iBAAiB,aAAcq9B,CAAO,EACpC,IAAM,CACXr9B,EAAK,oBAAoB,aAAcq9B,CAAO,CACpD,CACA,EAAK,CAAClnC,EAAU1M,EAAMuyC,EAAcG,EAASO,EAAgB12B,EAASm3B,CAAW,CAAC,EAChF,MAAMG,EAAiB9qD,EAAM,YAAY,SAAU+P,EAAOg7C,EAAeC,EAAQ,CAC3ED,IAAkB,SACpBA,EAAgB,IAEdC,IAAW,SACbA,EAAS,SAEX,MAAMC,EAAa5B,GAASc,EAAS,QAAS,QAASC,EAAe,OAAO,EACzEa,GAAc,CAACX,EAAW,SAC5B,aAAaD,EAAW,OAAO,EAC/BA,EAAW,QAAU,WAAW,IAAMb,EAAa,GAAOz5C,EAAOi7C,CAAM,EAAGC,CAAU,GAC3EF,IACT,aAAaV,EAAW,OAAO,EAC/Bb,EAAa,GAAOz5C,EAAOi7C,CAAM,EAEvC,EAAK,CAACb,EAAUX,CAAY,CAAC,EACrB0B,EAA0BlrD,EAAM,YAAY,IAAM,CACtD0qD,EAAmB,QAAO,EAC1BJ,EAAW,QAAU,MACtB,EAAE,CAAE,CAAA,EACCa,EAAqBnrD,EAAM,YAAY,IAAM,CACjD,GAAIyqD,EAAkC,QAAS,CAC7C,MAAMh9B,EAAOs0B,GAAYzyC,EAAK,SAAS,OAAO,EAAE,KAChDme,EAAK,MAAM,cAAgB,GAC3BA,EAAK,gBAAgB27B,EAAqB,EAC1CqB,EAAkC,QAAU,EAC7C,CACL,EAAK,CAACn7C,CAAI,CAAC,EAKTtP,OAAAA,EAAM,UAAU,IAAM,CACpB,GAAI,CAAC2pD,EACH,OAEF,SAASyB,GAAuB,CAC9B,OAAO53B,EAAQ,QAAQ,UAAY,CAAC,QAAS,WAAW,EAAE,SAASA,EAAQ,QAAQ,UAAU,IAAI,EAAI,EACtG,CACD,SAAS63B,EAAat7C,EAAO,CAG3B,GAFA,aAAas6C,EAAW,OAAO,EAC/BG,EAAkB,QAAU,GACxBX,GAAa,CAACjI,GAAuBwI,EAAe,OAAO,GAAKN,EAAS,GAAKT,GAASc,EAAS,QAAS,MAAM,IAAM,EACvH,OAEF,MAAMmB,GAAYjC,GAASc,EAAS,QAAS,OAAQC,EAAe,OAAO,EACvEkB,GACFjB,EAAW,QAAU,WAAW,IAAM,CACpCb,EAAa,GAAMz5C,EAAO,OAAO,CAClC,EAAEu7C,EAAS,EAEZ9B,EAAa,GAAMz5C,EAAO,OAAO,CAEpC,CACD,SAASw7C,EAAax7C,EAAO,CAC3B,GAAIq7C,EAAoB,EACtB,OAEFV,EAAmB,QAAO,EAC1B,MAAMv6C,GAAM4xC,GAAYp+B,CAAQ,EAEhC,GADA,aAAa4mC,EAAe,OAAO,EAC/BL,EAAe,QAAS,CAErBjzC,GACH,aAAaozC,EAAW,OAAO,EAEjCC,EAAW,QAAUJ,EAAe,QAAQ,CAC1C,GAAGX,EACH,KAAAS,EACA,EAAGj6C,EAAM,QACT,EAAGA,EAAM,QACT,SAAU,CACRo7C,IACAD,IACAJ,EAAe/6C,EAAO,GAAM,cAAc,CAC3C,CACX,CAAS,EACD,MAAM24C,EAAU4B,EAAW,QAC3Bn6C,GAAI,iBAAiB,YAAau4C,CAAO,EACzCgC,EAAmB,QAAU,IAAM,CACjCv6C,GAAI,oBAAoB,YAAau4C,CAAO,CACtD,EACQ,MACD,EAKmB0B,EAAe,UAAY,QAAU,CAACtJ,GAASn9B,EAAU5T,EAAM,aAAa,EAAI,KAElG+6C,EAAe/6C,CAAK,CAEvB,CAKD,SAASy7C,EAAmBz7C,EAAO,CAC7Bq7C,EAAoB,GAGxBlB,EAAe,SAAW,MAAQA,EAAe,QAAQ,CACvD,GAAGX,EACH,KAAAS,EACA,EAAGj6C,EAAM,QACT,EAAGA,EAAM,QACT,SAAU,CACRo7C,IACAD,IACAJ,EAAe/6C,CAAK,CACrB,CACT,CAAO,EAAEA,CAAK,CACT,CACD,GAAIzK,GAAUokD,CAAY,EAAG,CAC3B,MAAM16C,EAAM06C,EACZ,OAAAzyC,GAAQjI,EAAI,iBAAiB,aAAcw8C,CAAkB,EAC7D7nC,GAAY,MAAQA,EAAS,iBAAiB,aAAc6nC,CAAkB,EAC9EzB,GAAQ/6C,EAAI,iBAAiB,YAAaq8C,EAAc,CACtD,KAAM,EACd,CAAO,EACDr8C,EAAI,iBAAiB,aAAcq8C,CAAY,EAC/Cr8C,EAAI,iBAAiB,aAAcu8C,CAAY,EACxC,IAAM,CACXt0C,GAAQjI,EAAI,oBAAoB,aAAcw8C,CAAkB,EAChE7nC,GAAY,MAAQA,EAAS,oBAAoB,aAAc6nC,CAAkB,EACjFzB,GAAQ/6C,EAAI,oBAAoB,YAAaq8C,CAAY,EACzDr8C,EAAI,oBAAoB,aAAcq8C,CAAY,EAClDr8C,EAAI,oBAAoB,aAAcu8C,CAAY,CAC1D,CACK,CACL,EAAK,CAAC7B,EAAc/lC,EAAUgmC,EAASJ,EAASM,EAAWC,EAAQC,EAAMe,EAAgBI,EAAyBC,EAAoB3B,EAAcvyC,EAAM+yC,EAAMG,EAAUD,EAAgB12B,CAAO,CAAC,EAMhMjX,GAAM,IAAM,CACV,IAAIkvC,EACJ,GAAK9B,GAGD1yC,IAASw0C,EAAwBvB,EAAe,UAAY,MAAQuB,EAAsB,UAAU,oBAAsBd,IAAe,CAC3I,MAAMl9B,EAAOs0B,GAAYp+B,CAAQ,EAAE,KAInC,GAHA8J,EAAK,aAAa27B,GAAuB,EAAE,EAC3C37B,EAAK,MAAM,cAAgB,OAC3Bg9B,EAAkC,QAAU,GACxCnlD,GAAUokD,CAAY,GAAK/lC,EAAU,CACvC,IAAI+nC,EACJ,MAAM18C,EAAM06C,EACNiC,EAAiB3B,GAAQ,OAAS0B,EAAwB1B,EAAK,SAAS,QAAQ,KAAKn7C,IAAQA,GAAK,KAAOo7C,CAAQ,IAAM,OAASyB,EAAwBA,EAAsB,UAAY,KAAO,OAASA,EAAsB,SAAS,SAC/O,OAAIC,IACFA,EAAe,MAAM,cAAgB,IAEvC38C,EAAI,MAAM,cAAgB,OAC1B2U,EAAS,MAAM,cAAgB,OACxB,IAAM,CACX3U,EAAI,MAAM,cAAgB,GAC1B2U,EAAS,MAAM,cAAgB,EACzC,CACO,CACF,CACF,EAAE,CAACgmC,EAAS1yC,EAAMgzC,EAAUtmC,EAAU+lC,EAAcM,EAAME,EAAgB12B,EAASm3B,CAAW,CAAC,EAChGpuC,GAAM,IAAM,CACLtF,IACHmzC,EAAe,QAAU,OACzBc,IACAC,IAEH,EAAE,CAACl0C,EAAMi0C,EAAyBC,CAAkB,CAAC,EACtDnrD,EAAM,UAAU,IACP,IAAM,CACXkrD,IACA,aAAab,EAAW,OAAO,EAC/B,aAAaE,EAAe,OAAO,EACnCY,GACN,EACK,CAACxB,EAASD,EAAcwB,EAAyBC,CAAkB,CAAC,EAChEnrD,EAAM,QAAQ,IAAM,CACzB,GAAI,CAAC2pD,EACH,MAAO,GAET,SAASiC,EAAc77C,EAAO,CAC5Bq6C,EAAe,QAAUr6C,EAAM,WAChC,CACD,MAAO,CACL,UAAW,CACT,cAAe67C,EACf,eAAgBA,EAChB,YAAY77C,EAAO,CACbkH,GAAQ6yC,IAAW,IAGvB,aAAaS,EAAe,OAAO,EACnCA,EAAe,QAAU,WAAW,IAAM,CACnCC,EAAkB,SACrBhB,EAAa,GAAMz5C,EAAM,YAAa,OAAO,CAEhD,EAAE+5C,CAAM,EACV,CACF,EACD,SAAU,CACR,cAAe,CACb,aAAaO,EAAW,OAAO,CAChC,EACD,aAAat6C,EAAO,CAClB+6C,EAAe/6C,EAAM,YAAa,EAAK,CACxC,CACF,CACP,CACA,EAAK,CAAC45C,EAASG,EAAQ7yC,EAAMuyC,EAAcsB,CAAc,CAAC,CAC1D,CA6QA,MAAMe,GAAqB,KAAO,CAChC,cAAe,GACf,aAIA,OAAO,gBAAmB,YAAc,eAAe,SAAU,EAAC,SAAS,eAAe,EAAI,OAAS,MACzG,GACA,SAASC,GAAcjxC,EAAWoI,EAAW,CAC3C,MAAM8oC,EAAcj0C,GAAS+C,EAAWgxC,GAAoB,CAAA,EACxD5oC,IAAc,QAChB8oC,EAAY,QAAO,EAErB,MAAMC,EAAcD,EAAY,QAAQnL,GAAcmB,GAAYlnC,CAAS,CAAC,CAAC,EAE7E,OAD6BkxC,EAAY,MAAMC,EAAc,CAAC,EAClC,CAAC,CAC/B,CACA,SAASC,IAAkB,CACzB,OAAOH,GAAc,SAAS,KAAM,MAAM,CAC5C,CACA,SAASI,IAAsB,CAC7B,OAAOJ,GAAc,SAAS,KAAM,MAAM,CAC5C,CACA,SAASK,GAAep8C,EAAO8K,EAAW,CACxC,MAAMuxC,EAAmBvxC,GAAa9K,EAAM,cACtCs8C,EAAgBt8C,EAAM,cAC5B,MAAO,CAACs8C,GAAiB,CAACvL,GAASsL,EAAkBC,CAAa,CACpE,CACA,SAASC,GAAmBzxC,EAAW,CACZ/C,GAAS+C,EAAWgxC,GAAoB,CAAA,EAChD,QAAQpsD,GAAW,CAClCA,EAAQ,QAAQ,SAAWA,EAAQ,aAAa,UAAU,GAAK,GAC/DA,EAAQ,aAAa,WAAY,IAAI,CACzC,CAAG,CACH,CACA,SAAS8sD,GAAkB1xC,EAAW,CACnBA,EAAU,iBAAiB,iBAAiB,EACpD,QAAQpb,GAAW,CAC1B,MAAM+sD,EAAW/sD,EAAQ,QAAQ,SACjC,OAAOA,EAAQ,QAAQ,SACnB+sD,EACF/sD,EAAQ,aAAa,WAAY+sD,CAAQ,EAEzC/sD,EAAQ,gBAAgB,UAAU,CAExC,CAAG,CACH,CAKA,MAAMgtD,GAAgB,CACpB,OAAQ,EACR,KAAM,gBACN,OAAQ,MACR,OAAQ,OACR,SAAU,SACV,QAAS,EACT,SAAU,QACV,WAAY,SACZ,MAAO,MACP,IAAK,EACL,KAAM,CACR,EACA,IAAI78B,GACJ,SAAS88B,GAAsB38C,EAAO,CAChCA,EAAM,MAAQ,QAChBA,EAAM,OACN,aAAa6f,EAAS,EAE1B,CACA,MAAM+8B,GAA0B3sD,EAAM,WAAW,SAAoB2K,EAAOqE,EAAK,CAC/E,KAAM,CAAC49C,EAAMC,CAAO,EAAI7sD,EAAM,SAAQ,EACtCuc,GAAM,KACAklC,GAAQ,GAMVoL,EAAQ,QAAQ,EAElB,SAAS,iBAAiB,UAAWH,EAAqB,EACnD,IAAM,CACX,SAAS,oBAAoB,UAAWA,EAAqB,CACnE,GACK,CAAE,CAAA,EACL,MAAMI,EAAY,CAChB,IAAA99C,EACA,SAAU,EAEV,KAAA49C,EACA,cAAeA,EAAO,OAAY,GAClC,CAAC1D,GAAgB,aAAa,CAAC,EAAG,GAClC,MAAOuD,EACX,EACE,OAAoBzsD,EAAM,cAAc,OAAQb,GAAS,CAAA,EAAIwL,EAAOmiD,CAAS,CAAC,CAChF,CAAC,EAEKC,GAA6B/sD,EAAM,cAAc,IAAI,EAC3D,SAASgtD,GAAsBC,EAAO,CACpC,GAAI,CACF,GAAA/F,EACA,KAAA7wC,CACD,EAAG42C,IAAU,OAAS,CAAA,EAAKA,EAC5B,KAAM,CAACC,EAAYC,CAAa,EAAIntD,EAAM,SAAS,IAAI,EACjDotD,EAAWhG,KACXiG,EAAgBC,KAChBljD,EAAOpK,EAAM,QAAQ,KAAO,CAChC,GAAAknD,EACA,KAAA7wC,EACA,cAAAg3C,EACA,SAAAD,CACJ,GAAM,CAAClG,EAAI7wC,EAAMg3C,EAAeD,CAAQ,CAAC,EACjC55B,EAAUxzB,EAAM,SACtB,OAAAuc,GAAM,IACG,IAAM,CACX2wC,GAAc,MAAQA,EAAW,QACvC,EACK,CAACA,EAAY9iD,CAAI,CAAC,EACrBmS,GAAM,IAAM,CACV,GAAIiX,EAAQ,UAAYppB,EAAM,OAC9BopB,EAAQ,QAAUppB,EAClB,KAAM,CACJ,GAAA88C,EACA,KAAA7wC,EACA,cAAAg3C,EACA,SAAAD,CACD,EAAGhjD,EACEmjD,EAAiBrG,EAAK,SAAS,eAAeA,CAAE,EAAI,KACpDsG,EAAOtE,GAAgB,QAAQ,EACrC,GAAIqE,EAAgB,CAClB,MAAME,EAAU,SAAS,cAAc,KAAK,EAC5CA,EAAQ,GAAKL,EACbK,EAAQ,aAAaD,EAAM,EAAE,EAC7BD,EAAe,YAAYE,CAAO,EAClCN,EAAcM,CAAO,CAC3B,KAAW,CACL,IAAI5yC,EAAYxE,IAASg3C,GAAiB,KAAO,OAASA,EAAc,YACpExyC,GAAa,CAACvV,GAAUuV,CAAS,IAAGA,EAAYA,EAAU,SAC9DA,EAAYA,GAAa,SAAS,KAClC,IAAI6yC,EAAY,KACZxG,IACFwG,EAAY,SAAS,cAAc,KAAK,EACxCA,EAAU,GAAKxG,EACfrsC,EAAU,YAAY6yC,CAAS,GAEjC,MAAMD,EAAU,SAAS,cAAc,KAAK,EAC5CA,EAAQ,GAAKL,EACbK,EAAQ,aAAaD,EAAM,EAAE,EAC7B3yC,EAAY6yC,GAAa7yC,EACzBA,EAAU,YAAY4yC,CAAO,EAC7BN,EAAcM,CAAO,CACtB,CACL,EAAK,CAACrjD,CAAI,CAAC,EACF8iD,CACT,CAMA,SAASS,GAAelqC,EAAM,CAC5B,GAAI,CACF,SAAA9M,EACA,GAAAuwC,EACA,KAAA7wC,EAAO,KACP,iBAAAu3C,EAAmB,EACpB,EAAGnqC,EACJ,MAAMypC,EAAaF,GAAsB,CACvC,GAAA9F,EACA,KAAA7wC,CACJ,CAAG,EACK,CAACw3C,EAAmBC,CAAoB,EAAI9tD,EAAM,SAAS,IAAI,EAC/D+tD,EAAmB/tD,EAAM,OAAO,IAAI,EACpCguD,EAAkBhuD,EAAM,OAAO,IAAI,EACnCiuD,EAAkBjuD,EAAM,OAAO,IAAI,EACnCkuD,EAAiBluD,EAAM,OAAO,IAAI,EAClCmuD,EAGN,CAAC,CAACN,GAEF,CAACA,EAAkB,OAEnBA,EAAkB,MAAQD,GAAoB,CAAC,EAAEv3C,GAAQ62C,GAGzDltD,OAAAA,EAAM,UAAU,IAAM,CACpB,GAAI,CAACktD,GAAc,CAACU,GAAoBC,GAAqB,MAAQA,EAAkB,MACrF,OAMF,SAASx1C,EAAQtI,EAAO,CAClBm9C,GAAcf,GAAep8C,CAAK,IACnBA,EAAM,OAAS,UACDw8C,GAAoBD,IACvCY,CAAU,CAEzB,CAGD,OAAAA,EAAW,iBAAiB,UAAW70C,EAAS,EAAI,EACpD60C,EAAW,iBAAiB,WAAY70C,EAAS,EAAI,EAC9C,IAAM,CACX60C,EAAW,oBAAoB,UAAW70C,EAAS,EAAI,EACvD60C,EAAW,oBAAoB,WAAY70C,EAAS,EAAI,CAC9D,CACA,EAAK,CAAC60C,EAAYU,EAAkBC,GAAqB,KAAO,OAASA,EAAkB,KAAK,CAAC,EAC3E7tD,EAAM,cAAc+sD,GAAc,SAAU,CAC9D,MAAO/sD,EAAM,QAAQ,KAAO,CAC1B,iBAAA4tD,EACA,iBAAAG,EACA,gBAAAC,EACA,gBAAAC,EACA,eAAAC,EACA,WAAAhB,EACA,qBAAAY,CACN,GAAQ,CAACF,EAAkBV,CAAU,CAAC,CACnC,EAAEiB,GAAsBjB,GAA2BltD,EAAM,cAAc2sD,GAAY,CAClF,YAAa,UACb,IAAKoB,EACL,QAASh+C,GAAS,CAChB,GAAIo8C,GAAep8C,EAAOm9C,CAAU,EAAG,CACrC,IAAIkB,GACHA,EAAwBH,EAAgB,UAAY,MAAQG,EAAsB,OAC3F,KAAa,CACL,MAAMC,EAAenC,OAA0B2B,GAAqB,KAAO,OAASA,EAAkB,KAAK,aAAa,SACxHQ,GAAgB,MAAQA,EAAa,OACtC,CACF,CACF,CAAA,EAAGF,GAAsBjB,GAA2BltD,EAAM,cAAc,OAAQ,CAC/E,YAAaktD,EAAW,GACxB,MAAOT,EACR,CAAA,EAAGS,GAA2BoB,gBAAa33C,EAAUu2C,CAAU,EAAGiB,GAAsBjB,GAA2BltD,EAAM,cAAc2sD,GAAY,CAClJ,YAAa,UACb,IAAKqB,EACL,QAASj+C,GAAS,CAChB,GAAIo8C,GAAep8C,EAAOm9C,CAAU,EAAG,CACrC,IAAIqB,GACHA,EAAwBL,EAAe,UAAY,MAAQK,EAAsB,OAC1F,KAAa,CACL,MAAMC,EAAevC,OAAsB4B,GAAqB,KAAO,OAASA,EAAkB,KAAK,aAAa,SACpHW,GAAgB,MAAQA,EAAa,QACpCX,GAAqB,MAAgBA,EAAkB,kBAAqBA,GAAqB,MAAgBA,EAAkB,aAAa,GAAO99C,EAAM,WAAW,EAC1K,CACF,CACF,CAAA,CAAC,CACJ,CACA,MAAMu9C,GAAmB,IAAMttD,EAAM,WAAW+sD,EAAa,EAo9B7D,IAAI0B,GACA,QAAQ,IAAI,WAAa,eAC3BA,GAA6B,IAAI,KAOnC,SAASl8B,GAAYrN,EAAS,CAC5B,IAAIwpC,EACAxpC,IAAY,SACdA,EAAU,CAAA,GAEZ,KAAM,CACJ,KAAAjO,EAAO,GACP,aAAc03C,EACd,OAAAC,CACD,EAAG1pC,EACJ,GAAI,QAAQ,IAAI,WAAa,aAAc,CACzC,IAAI2pC,EACJ,MAAM3mD,EAAM,4JACZ,IAAK2mD,EAAoB3pC,EAAQ,WAAa,MAAQ2pC,EAAkB,WAAa,CAACvpD,GAAU4f,EAAQ,SAAS,SAAS,EAAG,CAC3H,IAAI4pC,EACJ,GAAI,GAAGA,EAAiBL,KAAkB,MAAQK,EAAe,IAAI5mD,CAAG,GAAI,CAC1E,IAAI6mD,GACHA,EAAkBN,KAAkB,MAAQM,EAAgB,IAAI7mD,CAAG,EACpE,QAAQ,MAAMA,CAAG,CAClB,CACF,CACF,CACD,KAAM,CAAC8mD,EAAeC,CAAe,EAAIjvD,EAAM,SAAS,IAAI,EACtD0pD,IAAiBgF,EAAqBxpC,EAAQ,WAAa,KAAO,OAASwpC,EAAmB,YAAcM,EAC5GE,EAAWC,GAAcjqC,CAAO,EAChC8kC,EAAOf,KACPmG,EAASrG,GAAyB,GAAI,KACtCS,EAAe7C,GAAe,CAAC1vC,EAAMlH,EAAOi7C,IAAW,CACvD/zC,IACFuc,EAAQ,QAAQ,UAAYzjB,GAE9B05C,EAAO,KAAK,aAAc,CACxB,KAAAxyC,EACA,MAAAlH,EACA,OAAAi7C,EACA,OAAAoE,CACN,CAAK,EACDT,GAAyB,MAAQA,EAAsB13C,EAAMlH,EAAOi7C,CAAM,CAC9E,CAAG,EACKqE,EAAkBrvD,EAAM,OAAO,IAAI,EACnCwzB,EAAUxzB,EAAM,OAAO,CAAE,CAAA,EACzBypD,EAASzpD,EAAM,SAAS,IAAMuoD,GAAc,CAAA,EAAE,CAAC,EAC/C+G,EAAalI,KACbmI,EAAuBvvD,EAAM,YAAY6O,GAAQ,CACrD,MAAM2gD,EAAoBlqD,GAAUuJ,CAAI,EAAI,CAC1C,sBAAuB,IAAMA,EAAK,sBAAuB,EACzD,eAAgBA,CACjB,EAAGA,EACJqgD,EAAS,KAAK,aAAaM,CAAiB,CAChD,EAAK,CAACN,EAAS,IAAI,CAAC,EACZ/7B,EAAenzB,EAAM,YAAY6O,GAAQ,EACzCvJ,GAAUuJ,CAAI,GAAKA,IAAS,QAC9BwgD,EAAgB,QAAUxgD,EAC1BogD,EAAgBpgD,CAAI,IAKlBvJ,GAAU4pD,EAAS,KAAK,UAAU,OAAO,GAAKA,EAAS,KAAK,UAAU,UAAY,MAItFrgD,IAAS,MAAQ,CAACvJ,GAAUuJ,CAAI,IAC9BqgD,EAAS,KAAK,aAAargD,CAAI,CAErC,EAAK,CAACqgD,EAAS,IAAI,CAAC,EACZ5/C,EAAOtP,EAAM,QAAQ,KAAO,CAChC,GAAGkvD,EAAS,KACZ,aAAA/7B,EACA,qBAAAo8B,EACA,aAAcF,CAClB,GAAM,CAACH,EAAS,KAAM/7B,EAAco8B,CAAoB,CAAC,EACjDnqC,EAAWplB,EAAM,QAAQ,KAAO,CACpC,GAAGkvD,EAAS,SACZ,aAAcxF,CACf,GAAG,CAACwF,EAAS,SAAUxF,CAAY,CAAC,EAC/BH,EAAUvpD,EAAM,QAAQ,KAAO,CACnC,GAAGkvD,EACH,KAAA5/C,EACA,SAAA8V,EACA,QAAAoO,EACA,OAAAo7B,EACA,WAAAU,EACA,OAAA7F,EACA,KAAAxyC,EACA,aAAAuyC,CACD,GAAG,CAAC0F,EAAUN,EAAQU,EAAY7F,EAAQxyC,EAAMuyC,EAAcl6C,EAAM8V,CAAQ,CAAC,EAC9E,OAAA7I,GAAM,IAAM,CACV,MAAM1N,EAAOm7C,GAAQ,KAAO,OAASA,EAAK,SAAS,QAAQ,KAAKn7C,GAAQA,EAAK,KAAO+/C,CAAM,EACtF//C,IACFA,EAAK,QAAU06C,EAErB,CAAG,EACMvpD,EAAM,QAAQ,KAAO,CAC1B,GAAGkvD,EACH,QAAA3F,EACA,KAAAj6C,EACA,SAAA8V,CACJ,GAAM,CAAC8pC,EAAU5/C,EAAM8V,EAAUmkC,CAAO,CAAC,CACzC,CAOA,SAASkG,GAASlG,EAAS5+C,EAAO,CAC5BA,IAAU,SACZA,EAAQ,CAAA,GAEV,KAAM,CACJ,KAAAsM,EACA,aAAAuyC,EACA,OAAAC,EACA,KAAAn6C,EACA,SAAU,CACR,SAAAqU,EACA,aAAA+lC,CACD,CACF,EAAGH,EACE,CACJ,QAAAI,EAAU,GACV,YAAA+F,EAAc,EACf,EAAG/kD,EACEglD,EAAgB3vD,EAAM,OAAO,EAAK,EAClCqqD,EAAarqD,EAAM,SACnB4vD,EAAsB5vD,EAAM,OAAO,EAAI,EAC7CA,OAAAA,EAAM,UAAU,IAAM,CACpB,GAAI,CAAC2pD,EACH,OAEF,MAAMz+B,EAAM3B,GAAUmgC,CAAY,EAKlC,SAAS1wC,GAAS,CACZ,CAAC/B,GAAQyS,GAAcggC,CAAY,GAAKA,IAAiB9I,GAAcmB,GAAY2H,CAAY,CAAC,IAClGiG,EAAc,QAAU,GAE3B,CACD,SAASE,GAAY,CACnBD,EAAoB,QAAU,EAC/B,CACD,OAAA1kC,EAAI,iBAAiB,OAAQlS,CAAM,EACnCkS,EAAI,iBAAiB,UAAW2kC,EAAW,EAAI,EACxC,IAAM,CACX3kC,EAAI,oBAAoB,OAAQlS,CAAM,EACtCkS,EAAI,oBAAoB,UAAW2kC,EAAW,EAAI,CACxD,CACG,EAAE,CAAClsC,EAAU+lC,EAAczyC,EAAM0yC,CAAO,CAAC,EAC1C3pD,EAAM,UAAU,IAAM,CACpB,GAAI,CAAC2pD,EACH,OAEF,SAASH,EAAa/lC,EAAM,CAC1B,GAAI,CACF,OAAAunC,CACD,EAAGvnC,GACAunC,IAAW,mBAAqBA,IAAW,gBAC7C2E,EAAc,QAAU,GAE3B,CACD,OAAAlG,EAAO,GAAG,aAAcD,CAAY,EAC7B,IAAM,CACXC,EAAO,IAAI,aAAcD,CAAY,CAC3C,CACA,EAAK,CAACC,EAAQE,CAAO,CAAC,EACpB3pD,EAAM,UAAU,IACP,IAAM,CACX,aAAaqqD,EAAW,OAAO,CACrC,EACK,CAAE,CAAA,EACErqD,EAAM,QAAQ,IACd2pD,EAGE,CACL,UAAW,CACT,cAAc55C,EAAO,CACfwxC,GAAsBxxC,EAAM,WAAW,IAC3C6/C,EAAoB,QAAU,GAC/B,EACD,cAAe,CACbD,EAAc,QAAU,EACzB,EACD,QAAQ5/C,EAAO,CACb,GAAI4/C,EAAc,QAAS,OAC3B,MAAMvwD,EAAS4iD,GAAUjyC,EAAM,WAAW,EAC1C,GAAI2/C,GAAepqD,GAAUlG,CAAM,EACjC,GAAI,CAIF,GAAIqiD,GAAQ,GAAME,KAAS,MAAM,MAAK,EACtC,GAAI,CAACviD,EAAO,QAAQ,gBAAgB,EAAG,MACxC,MAAW,CAEV,GAAI,CAACwwD,EAAoB,SAAW,CAAC1N,GAAkB9iD,CAAM,EAC3D,MAEH,CAEHoqD,EAAa,GAAMz5C,EAAM,YAAa,OAAO,CAC9C,EACD,OAAOA,EAAO,CACZ4/C,EAAc,QAAU,GACxB,MAAMtD,EAAgBt8C,EAAM,cAItB+/C,EAAoBxqD,GAAU+mD,CAAa,GAAKA,EAAc,aAAanD,GAAgB,aAAa,CAAC,GAAKmD,EAAc,aAAa,WAAW,IAAM,UAGhKhC,EAAW,QAAU,OAAO,WAAW,IAAM,CAC3C,MAAM0F,EAAWnP,GAAc8I,EAAeA,EAAa,cAAgB,QAAQ,EAG/E,CAAC2C,GAAiB0D,IAAarG,GAK/B5I,GAASxxC,EAAK,SAAS,QAAS+8C,CAAa,GAAKvL,GAAS4I,EAAc2C,CAAa,GAAKyD,GAG/FtG,EAAa,GAAOz5C,EAAM,YAAa,OAAO,CAC1D,CAAW,CACF,CACF,CACP,EAvDa,GAwDR,CAAC45C,EAAS+F,EAAahG,EAAcp6C,EAAMk6C,CAAY,CAAC,CAC7D,CAEA,MAAMwG,GAAa,SACbC,GAAe,WACrB,SAASC,GAAWC,EAAWC,EAAWC,EAAY,CACpD,MAAM7H,EAAM,IAAI,IACV8H,EAASD,IAAe,OAC9B,IAAIE,EAAeJ,EACnB,GAAIG,GAAUH,EAAW,CAEvB,KAAM,CACJ,CAACH,EAAU,EAAGQ,EACd,CAACP,EAAY,EAAGQ,EAChB,GAAGC,CACJ,EAAGP,EACJI,EAAeG,CAChB,CACD,MAAO,CACL,GAAIL,IAAe,YAAc,CAC/B,SAAU,EAChB,EACI,GAAGE,EACH,GAAGH,EAAU,IAAItkD,GAAS,CACxB,MAAM6kD,EAAkB7kD,EAAQA,EAAMukD,CAAU,EAAI,KACpD,OAAI,OAAOM,GAAoB,WACtBR,EAAYQ,EAAgBR,CAAS,EAAI,KAE3CQ,CACb,CAAK,EAAE,OAAOR,CAAS,EAAE,OAAO,CAAC9hD,EAAK1D,KAC3BA,GAGL,OAAO,QAAQA,CAAK,EAAE,QAAQ8Y,GAAQ,CACpC,GAAI,CAAClkB,EAAKuM,CAAK,EAAI2X,EACnB,GAAI,EAAA6sC,GAAU,CAACN,GAAYC,EAAY,EAAE,SAAS1wD,CAAG,GAGrD,GAAIA,EAAI,QAAQ,IAAI,IAAM,GAIxB,GAHKipD,EAAI,IAAIjpD,CAAG,GACdipD,EAAI,IAAIjpD,EAAK,CAAA,CAAE,EAEb,OAAOuM,GAAU,WAAY,CAC/B,IAAI28C,GACHA,EAAWD,EAAI,IAAIjpD,CAAG,IAAM,MAAQkpD,EAAS,KAAK38C,CAAK,EACxDuC,EAAI9O,CAAG,EAAI,UAAY,CAErB,QADIqpD,EACKhC,EAAO,UAAU,OAAQzlD,EAAO,IAAI,MAAMylD,CAAI,EAAGC,EAAO,EAAGA,EAAOD,EAAMC,IAC/E1lD,EAAK0lD,CAAI,EAAI,UAAUA,CAAI,EAE7B,OAAQ+B,EAAYJ,EAAI,IAAIjpD,CAAG,IAAM,KAAO,OAASqpD,EAAU,IAAIz5C,GAAMA,EAAG,GAAGhO,CAAI,CAAC,EAAE,KAAKoF,GAAOA,IAAQ,MAAS,CACjI,CACW,OAED8H,EAAI9O,CAAG,EAAIuM,CAErB,CAAO,EACMuC,GACN,EAAE,CACT,CACA,CAQA,SAASuiD,GAAgBR,EAAW,CAC9BA,IAAc,SAChBA,EAAY,CAAA,GAId,MAAMS,EAAOT,EACPU,EAAoB9wD,EAAM,YAAYmwD,GAAaD,GAAWC,EAAWC,EAAW,WAAW,EAErGS,CAAI,EACEE,EAAmB/wD,EAAM,YAAYmwD,GAAaD,GAAWC,EAAWC,EAAW,UAAU,EAEnGS,CAAI,EACEG,EAAehxD,EAAM,YAAYmwD,GAAaD,GAAWC,EAAWC,EAAW,MAAM,EAM3FA,EAAU,IAAI7wD,GAAOA,GAAO,KAAO,OAASA,EAAI,IAAI,CAAC,EACrD,OAAOS,EAAM,QAAQ,KAAO,CAC1B,kBAAA8wD,EACA,iBAAAC,EACA,aAAAC,CACD,GAAG,CAACF,EAAmBC,EAAkBC,CAAY,CAAC,CACzD,CAqgBA,MAAMC,GAA0C,IAAI,IAAI,CAAC,CAAC,SAAU,SAAS,EAAG,CAAC,WAAY,SAAS,EAAG,CAAC,QAAS,EAAK,CAAC,CAAC,EAO1H,SAASC,GAAQ3H,EAAS5+C,EAAO,CAC/B,IAAIwmD,EACAxmD,IAAU,SACZA,EAAQ,CAAA,GAEV,KAAM,CACJ,KAAAsM,EACA,WAAAq4C,CACD,EAAG/F,EACE,CACJ,QAAAI,EAAU,GACV,KAAAiD,EAAO,QACR,EAAGjiD,EACEymD,GAAYD,EAAwBF,GAA2B,IAAIrE,CAAI,IAAM,KAAOuE,EAAwBvE,EAC5GyE,EAAcjK,KAEdkK,EADWvI,MACY,KAC7B,OAAO/oD,EAAM,QAAQ,IAAM,CACzB,GAAI,CAAC2pD,EAAS,MAAO,GACrB,MAAM4H,EAAgB,CACpB,GAAIjC,EACJ,GAAI8B,GAAY,CACd,KAAMA,CACd,CACA,EACI,OAAIA,IAAa,WAAaxE,IAAS,QAC9B,CACL,UAAW,CACT,CAAC,SAAWA,IAAS,QAAU,aAAe,cAAc,EAAG31C,EAAOq4C,EAAa,MACpF,EACD,SAAUiC,CAClB,EAEW,CACL,UAAW,CACT,gBAAiBt6C,EAAO,OAAS,QACjC,gBAAiBm6C,IAAa,cAAgB,SAAWA,EACzD,gBAAiBn6C,EAAOq4C,EAAa,OACrC,GAAI8B,IAAa,WAAa,CAC5B,KAAM,UAChB,EACQ,GAAIA,IAAa,QAAU,CACzB,GAAIC,CACd,EACQ,GAAID,IAAa,QAAUE,GAAY,CACrC,KAAM,UAChB,EACQ,GAAI1E,IAAS,UAAY,CACvB,oBAAqB,MAC/B,EACQ,GAAIA,IAAS,YAAc,CACzB,oBAAqB,MAC/B,CACO,EACD,SAAU,CACR,GAAG2E,EACH,GAAIH,IAAa,QAAU,CACzB,kBAAmBC,CAC7B,CACO,EACD,KAAK5tC,EAAM,CACT,GAAI,CACF,OAAA9P,EACA,SAAA69C,CACD,EAAG/tC,EACJ,MAAMguC,EAAc,CAClB,KAAM,SACN,GAAI99C,GAAU,CACZ,GAAI27C,EAAa,SAC7B,CACA,EAKQ,OAAQ1C,EAAI,CACV,IAAK,SACH,MAAO,CACL,GAAG6E,EACH,gBAAiB99C,GAAU69C,CACzC,EACU,IAAK,WAED,MAAO,CACL,GAAGC,EACH,GAAI99C,GAAU,CACZ,gBAAiB,EACnC,CACA,CAES,CACD,MAAO,EACR,CACP,CACA,EAAK,CAACg2C,EAASiD,EAAMwE,EAAUn6C,EAAMq4C,EAAY+B,EAAaC,CAAQ,CAAC,CACvE,CAQA,SAASI,GAAgBz6C,EAAM06C,EAAY,CACzC,KAAM,CAACC,EAAWC,CAAY,EAAI7xD,EAAM,SAASiX,CAAI,EACrD,OAAIA,GAAQ,CAAC26C,GACXC,EAAa,EAAI,EAEnB7xD,EAAM,UAAU,IAAM,CACpB,GAAI,CAACiX,EAAM,CACT,MAAMxI,EAAU,WAAW,IAAMojD,EAAa,EAAK,EAAGF,CAAU,EAChE,MAAO,IAAM,aAAaljD,CAAO,CAClC,CACL,EAAK,CAACwI,EAAM06C,CAAU,CAAC,EACdC,CACT,CAMA,SAASE,GAAoBvI,EAAS5+C,EAAO,CACvCA,IAAU,SACZA,EAAQ,CAAA,GAEV,KAAM,CACJ,KAAAsM,EACA,SAAU,CACR,SAAA0M,CACD,CACF,EAAG4lC,EACE,CACJ,SAAAwI,EAAW,GACZ,EAAGpnD,EAEEqnD,GADmB,OAAOD,GAAa,SACHA,EAAWA,EAAS,QAAU,EAClE,CAACE,EAAWC,CAAY,EAAIlyD,EAAM,SAAS,EAAK,EAChD,CAACmyD,EAAQC,CAAS,EAAIpyD,EAAM,SAAS,WAAW,EAChD4xD,EAAYF,GAAgBz6C,EAAM+6C,CAAa,EAMrD,OAAAz1C,GAAM,IAAM,CACN01C,GAAa,CAACL,GAChBQ,EAAU,WAAW,CAE3B,EAAK,CAACH,EAAWL,CAAS,CAAC,EACzBr1C,GAAM,IAAM,CACV,GAAKoH,EACL,GAAI1M,EAAM,CACRm7C,EAAU,SAAS,EACnB,MAAMC,EAAQ,sBAAsB,IAAM,CACxCD,EAAU,MAAM,CACxB,CAAO,EACD,MAAO,IAAM,CACX,qBAAqBC,CAAK,CAClC,CACA,MACMH,EAAa,EAAI,EACjBE,EAAU,OAAO,CAEvB,EAAK,CAACn7C,EAAM0M,CAAQ,CAAC,EACZ,CACL,UAAAiuC,EACA,OAAAO,CACJ,CACA,CCx/GA,SAASG,GAAE9wD,EAAE,CAAC,OAAOS,GAAG,CAACT,EAAE,QAAQM,GAAG,CAAC,OAAOA,GAAG,WAAWA,EAAEG,CAAC,EAAEH,GAAG,OAAOA,EAAE,QAAQG,EAAE,CAAC,CAAC,CAAC,CCAnF,MAAMswD,GAAqB,GAErBC,GAAsB,UC6E7BC,GAAYt8B,EAAA,WAAW,CAC3BxrB,EACAmQ,IACc,CACR,KAAA,CAAE,SAAAnE,EAAU,UAAAzE,EAAW,MAAAwgD,EAAO,UAAApxC,EAAY,MAAO,cAAAvG,EAAgB,GAAO,WAAA43C,EAAY,GAAG9/C,CAAA,EAASlI,EAEhGioD,EAAWzJ,SAAO,IAAI,EACtB,CAAC0J,EAASC,CAAU,EAAIC,WAAS,EAAK,EACtC,CAAE,KAAAzjD,EAAM,eAAAukB,EAAgB,QAAA01B,CAAA,EAAYh3B,GAAY,CACpD,qBAAsB9B,GACtB,UAAAnP,EACA,KAAMuxC,EACN,aAAcC,EACd,WAAY,CACVhsC,GAAO,EAAE,EACTG,GAAK,EACL8B,GAAM,EACNjD,GAAM,CAAE,QAAS8sC,EAAU,CAC7B,CAAA,CACD,EAEKI,EAAQ1J,GAASC,EAAS,CAAE,MAAO,CAAE,KAAMgJ,GAAoB,MAAOC,EAAoB,CAAG,CAAA,EAC7FS,EAAQxD,GAASlG,CAAO,EACxBqD,EAAOsE,GAAQ3H,EAAS,CAAE,KAAM,UAAW,EAC3C,CAAE,UAAAqI,EAAW,OAAAO,CAAO,EAAIL,GAAoBvI,CAAO,EAEnD,CAAE,kBAAAuH,EAAmB,iBAAAC,CAAiB,EAAIH,GAAgB,CAC9DhE,EACAoG,EACAC,CAAA,CACD,EAEKjkD,EAAMkkD,EAAAA,QAAQ,IAAMC,GAAU,CAAC7jD,EAAK,aAAcqH,EAAS,MAAM,GAAG,CAAC,EAAG,CAC5ErH,EAAK,aACLqH,CAAA,CACD,EAEKy8C,EAAeF,UAAQ,IAAMC,GAAU,CAAC7jD,EAAK,YAAawL,CAAY,CAAC,EAAG,CAC9ExL,EAAK,YACLwL,CAAA,CACD,EAED,GAAI,CAAC43C,EACI,OAAA/7C,EAGH,MAAA08C,EAAiBrzD,EAAM,aAAa2W,EAAUm6C,EAAkB,CAAE,IAAA9hD,EAAK,GAAG2H,EAAS,KAAM,CAAC,CAAC,EAE3F28C,EACJ58B,EAAA,IAAC,MAAA,CACE,GAAG7jB,EACH,GAAGk+C,EAAiB,EACrB,IAAKqC,EACL,MAAO,CAAE,GAAGv/B,CAAe,EAC3B,UAAW0/B,GAAG,aAAcrhD,CAAS,EAEpC,SAAA0/C,UACE,MAAI,CAAA,UAAW2B,GAAG,oBAAqB,sBAAsBpB,CAAM,EAAE,EACnE,SAAA,CAAAO,QACArL,GAAc,CAAA,IAAKuL,EAAU,QAAArJ,EAAkB,UAAU,oBAAoB,CAAA,EAChF,CAAA,CAAA,EAKAiK,EAAW,OAAOb,GAAe,SAAWA,EAAa,OACzD1yC,EAAY,OAAO0yC,GAAe,SAAWA,EAAa,OAEhE,OAEKc,EAAA,KAAA/uD,WAAA,CAAA,SAAA,CAAA2uD,EACAR,IAAY93C,EACTu4C,EAEA58B,EAAA,IAACi3B,IAAe,GAAI6F,EAAU,KAAMvzC,EACjC,SACHqzC,CAAA,CAAA,EAEN,CAAA,CAAA,CAEJ,CAAC,EAEDb,GAAU,YAAc,wBC/FlBiB,GAAsB,CAAC,CAAE,KAAA1vD,EAAM,MAAAsyB,EAAO,OAAA3iB,EAAQ,SAAAN,EAAU,QAAAsgD,EAAS,SAAAC,KAQjE5vD,IAAS,YAAcsyB,IAAU,WAAaA,IAAU,eACnD,CACL,oBACA,GAAI3iB,EAAS,CAAC,2BAA2B,EAAI,CAAC,EAC9C,GAAIN,EAAW,CAAC,6BAA6B,EAAI,CAAC,EAClD,GAAIsgD,EAAU,CAAC,4BAA4B,EAAI,CAAC,CAAA,EAIhD3vD,IAAS,WAAasyB,IAAU,SAC3B,CACL,2BACA,GAAI3iB,EAAS,CAAC,kCAAkC,EAAI,CAAC,EACrD,GAAIN,EAAW,CAAC,oCAAoC,EAAI,CAAC,EACzD,GAAIsgD,EAAU,CAAC,mCAAmC,EAAI,CAAC,CAAA,EAIvD3vD,IAAS,cAAgBsyB,IAAU,WAAaA,IAAU,eACrD,CACL,sBACA,GAAI3iB,EAAS,CAAC,6BAA6B,EAAI,CAAC,EAChD,GAAIN,EAAW,CAAC,+BAA+B,EAAI,CAAC,EACpD,GAAIsgD,EAAU,CAAC,8BAA8B,EAAI,CAAC,CAAA,EAIlD3vD,IAAS,aAAesyB,IAAU,SAC7B,CACL,6BACA,GAAI3iB,EAAS,CAAC,oCAAoC,EAAI,CAAC,EACvD,GAAIN,EAAW,CAAC,sCAAsC,EAAI,CAAC,EAC3D,GAAIsgD,EAAU,CAAC,qCAAqC,EAAI,CAAC,CAAA,EAIzD3vD,IAAS,YAAcsyB,IAAU,UAC5B,CACL,qBACA,GAAI3iB,EAAS,CAAC,4BAA4B,EAAI,CAAC,EAC/C,GAAIN,EAAW,CAAC,8BAA8B,EAAI,CAAC,EACnD,GAAIsgD,EAAU,CAAC,6BAA6B,EAAI,CAAC,EACjD,GAAIC,EAAW,CAAC,+BAA+B,EAAI,CAAC,CAAA,EAIpD5vD,IAAS,YAAcsyB,IAAU,SAC5B,CACL,4BACA,GAAI3iB,EAAS,CAAC,mCAAmC,EAAI,CAAC,EACtD,GAAIN,EAAW,CAAC,qCAAqC,EAAI,CAAC,EAC1D,GAAIsgD,EAAU,CAAC,oCAAoC,EAAI,CAAC,EACxD,GAAIC,EAAW,CAAC,sCAAsC,EAAI,CAAC,CAAA,EAI3D5vD,IAAS,YAAcsyB,IAAU,cAC5B,CACL,iCACA,GAAI3iB,EAAS,CAAC,wCAAwC,EAAI,CAAC,EAC3D,GAAIN,EAAW,CAAC,0CAA0C,EAAI,CAAC,EAC/D,GAAIsgD,EAAU,CAAC,yCAAyC,EAAI,CAAC,EAC7D,GAAIC,EAAW,CAAC,2CAA2C,EAAI,CAAC,CAAA,EAI7D,GAeHC,GAAW19B,EAAA,WAAW,CAACxrB,EAAsBmQ,IAAkD,CAC7F,KAAA,CACJ,SAAAnE,EACA,UAAAzE,EACA,MAAAokB,EAAQ,UACR,SAAAjjB,EAAW,GACX,QAAAygD,EACA,SAAAC,EAAW,SACX,QAAAJ,EAAU,GACV,YAAAK,EACA,QAAAC,EACA,UAAAC,EACA,QAAAC,EACA,KAAAnwD,EAAO,YACP,GAAG+gB,CACD,EAAApa,EAEE,CAAE,aAAAmV,EAAc,OAAAnM,EAAQ,aAAAG,CAAA,EAAiBV,GAAU,CACvD,GAAGzI,EACH,KAAMopD,EACN,QAASj5C,CAAA,CACV,EAED,SAASs5C,EAAcrkD,EAAgD,CACjE4jD,GAAWtgD,GAIf4gD,GAAA,MAAAA,EAAUlkD,EACZ,CAEA,MAAMuQ,EAAYR,EAAa,CAC7B,QAASs0C,EACT,GAAGrvC,CAAA,CACJ,EAEK6uC,EAAW,CAAC,CAACM,GAAa,CAAC,CAACJ,EAC5BO,EAAW,CAAC19C,IAAcu9C,GAAa,CAACJ,GAAaA,GAAW,CAACI,GAEjEpjD,EAAUyiD,GAAG,YAAarhD,EAAW,CACzC,2BAA4B4B,EAC5B,sBAAuBT,EACvB,uBAAwBghD,GAAY,EAAEV,GAAWK,GACjD,qBAAsBL,CAAA,EACrBD,GAAoB,CAAE,KAAA1vD,EAAM,MAAAsyB,EAAO,OAAA3iB,EAAQ,SAAAN,EAAU,QAAAsgD,EAAS,SAAAC,CAAU,CAAA,CAAC,EAEtEU,EAAgBf,GAAG,oBAAqB,CAC5C,2BAA4BS,GAAeK,CAAA,CAC5C,EAGC,OAAA39B,EAAA,IAAC+7B,IAAU,MAAO0B,EAEhB,gBAAC,SAAQ,CAAA,GAAG7zC,EAAW,UAAWxP,EAE9B,SAAA,CAAaojD,GAAA,CAACP,GACXj9B,EAAA,IAAA,OAAA,CAAK,KAAK,MAAM,UAAU,wBACxB,SACHw9B,CAAA,CAAA,EAIFP,GACGj9B,EAAA,IAAA,OAAA,CAAK,KAAK,cAAc,UAAW49B,EAClC,SAAC59B,EAAAA,IAAAiX,GAAA,CAAW,UAAU,oBAAA,CAAqB,CAC7C,CAAA,EAGHgmB,GAAWK,EACX,CAACL,GAAWh9C,EAEXm9C,GAAW,CAACH,GACVj9B,EAAA,IAAC,QAAK,KAAK,MAAM,UAAU,sBACxB,SACHo9B,CAAA,CAAA,CAAA,CAGN,CAAA,CACF,CAAA,CAEJ,CAAC,EAEDD,GAAS,YAAc,uBCnNjBU,GAAmBvwD,GACnBA,IAAS,UACJ,2BAGLA,IAAS,WACJ,4BAGF,6BAGHwwD,GAA8B,CAACC,EAAgBC,IAC/CD,GAASC,EACJ,GAGLD,EACK,iCAGLC,EACK,gCAGF,kCAoBHC,GAAgBx+B,EAAA,WAAW,CAC/BxrB,EACAmQ,IACgB,OACV,KAAA,CAAE,SAAAnE,EAAU,UAAAzE,EAAW,SAAAmB,EAAU,KAAArP,EAAO,YAAa,GAAG6O,CAAS,EAAAlI,EAEjEmG,EAAUyiD,GAAGrhD,EAAW,kBAAmBqiD,GAAgBvwD,CAAI,EAAG,CAAE,4BAA6BqP,CAAA,CAAU,EAC3GuhD,EAAgBC,EAAAA,SAAS,MAAMl+C,CAAQ,EAE7C,aACG,MAAI,CAAA,KAAK,QAAQ,UAAW7F,EAAS,gBAAeuC,EAAU,IAAKyH,EAAe,GAAGjI,EAElF,UAAAgiD,EAAAA,EAAAA,SAAS,IAAIl+C,EAAU,CAAChC,EAAQ4H,IAAU,CACpC,GAAA,CAAC1T,EAAAA,eAAe8L,CAAM,EACjB,OAGT,MAAM8/C,EAAQl4C,IAAU,EAClBm4C,EAAOn4C,IAAUq4C,EAAgB,EACjCE,EAAiBngD,EAAO,MAAM,UAAYtB,EAC1C0hD,EAAgBxB,GACpB,0BACA,CAAE,oCAAqCuB,CAAe,EACtDN,GAA4BC,EAAOC,CAAI,EACvC//C,EAAO,MAAM,SAAA,EAGf,OAAO6hB,EAAAA,aAAa7hB,EAA8B,CAChD,IAAKA,EAAO,KAAO4H,EACnB,KAAM5H,EAAO,MAAM,MAAQ3Q,EAC3B,SAAU8wD,EACV,UAAWC,CAAA,CACZ,CACF,CAAA,IArBDF,YAAAA,EAqBI,OAAO,QAEf,CAAA,CAEJ,CAAC,EAEDF,GAAc,YAAc,4BCtE5B,SAASK,GACPrqD,EACAmQ,EACc,CACR,KAAA,CACJ,SAAAnE,EACA,UAAAzE,EACA,MAAAokB,EAAQ,UACR,SAAAjjB,EACA,QAAA4gD,EACA,SAAAzC,EACA,KAAAxtD,EAAO,YACP,MAAA8H,EACA,GAAGghD,CACD,EAAAniD,EAEEmG,EAAUyiD,GAAG,mBAAoB,CACrC,6BAA8BlgD,EAC9B,6BAA8Bm+C,GAC7Bt/C,CAAS,EAGV,OAAAwkB,EAAA,IAACm9B,GAAA,CACE,GAAG/G,EACJ,UAAWh8C,EACX,KAAA9M,EACA,MAAAsyB,EACA,SAAAjjB,EACA,eAAcm+C,EACd,QAAUzhD,GAAUkkD,GAAA,YAAAA,EAAUlkD,EAAOjE,GACrC,IAAKgP,EAEJ,SAAAnE,CAAA,CAAA,CAGP,CAEM,MAAAs+C,GAAiB9+B,aAAW6+B,EAAmB,EAErDC,GAAe,YAAc,iBCpC7B,SAASC,GAAmBppD,EAAsBqpD,EAAyC,CACrF,OAAAA,IAAc,QAAarpD,IAAU,OAChC,GAGL,MAAM,QAAQqpD,CAAS,EAClBA,EAAU,QAAQrpD,CAAK,GAAK,EAG9BA,IAAUqpD,CACnB,CAeA,SAASC,GACPzqD,EACAmQ,EACc,CACR,KAAA,CAAE,SAAAnE,EAAU,UAAAzE,EAAW,SAAAmB,EAAU,SAAA4F,EAAU,MAAAnN,EAAO,SAAAupD,EAAW,EAAU,EAAA1qD,EAEvE0P,EAAe,CAACtK,EAA0CulD,IAAyB,CACnFJ,GAAgBI,EAAaxpD,CAAK,GAIrCmN,GAAA,MAAAA,EAA6DlJ,EAAOulD,EAAW,EAG5EC,EAAuB,CAACxlD,EAA0CulD,IAAyB,CAC/F,IAAIE,EAAgB,CAAA,EAEhB,MAAM,QAAQ1pD,CAAK,IACV0pD,EAAA,CAAC,GAAG1pD,CAAK,GAGhB,MAAAyQ,EAAQi5C,EAAS,QAAQF,CAAW,EAEtC/4C,GAAS,EACFi5C,EAAA,OAAOj5C,EAAO,CAAC,EAExBi5C,EAAS,KAAKF,CAAW,EAG1Br8C,GAAA,MAAAA,EAA+DlJ,EAAOylD,EAAQ,EAG3E1kD,EAAUyiD,GAAGrhD,EAAW,wBAAwB,EAEhDujD,EAAoBZ,EAAA,SAAS,IAAIl+C,EAAWoqC,GAC5Cl4C,EAAAA,eAAek4C,CAAK,EACfvqB,EAAAA,aAAauqB,EAA+C,CACjE,SAAU1tC,GAAY0tC,EAAM,MAAM,SAClC,SAAUmU,GAAmBnU,EAAM,MAAM,MAAOj1C,CAAK,EACrD,QAASupD,EAAWE,EAAuBl7C,CAAA,CAC5C,EAGI0mC,CACR,EAGC,OAAArqB,MAACi+B,IAAc,UAAW7jD,EAAS,IAAKgK,EAAe,GAAGnQ,EACvD,SACH8qD,CAAA,CAAA,CAEJ,CAEM,MAAAC,GAAsBv/B,aAAWi/B,EAAwB,EAE/DM,GAAoB,YAAc,kCCvE5BC,GAIF,CACF,MAAQhrD,GAAW+rB,EAAAA,IAAAk/B,GAAA,CAAW,GAAGjrD,EAAO,EACxC,KAAOA,GAAW+rB,EAAAA,IAAAsV,GAAA,CAAU,GAAGrhC,EAAO,EACtC,QAAUA,GAAW+rB,EAAAA,IAAAm/B,GAAA,CAAa,GAAGlrD,EAAO,EAC5C,QAAUA,GAAW+rB,EAAAA,IAAAo/B,GAAA,CAAa,GAAGnrD,EAAO,CAC9C,EAEA,SAASorD,GAAQprD,EAAkC,CAC3C,KAAA,CACJ,QAAAqrD,EACA,SAAAr/C,EACA,UAAAzE,EACA,KAAA+jD,EACA,QAAA93C,EACA,KAAAyuC,EAAO,QACP,KAAA5oD,EAAO,MACL,EAAA2G,EAGF,OAAA8oD,OAAC,OAAI,UAAWyC,GAAW,sBAAsBlyD,CAAI,GAAIkO,CAAS,EAAG,KAAA06C,EAClE,SAAA,CAAAqJ,IAAS,GACRv/B,EAAA,IAAC,MAAI,CAAA,UAAW,kCAAkC1yB,CAAI,GACnD,SAAAiyD,GAAQN,GAAmB3xD,CAAI,EAAE,CACpC,CAAA,EACE,KACJyvD,EAAAA,KAAC,MAAI,CAAA,UAAU,oBACZ,SAAA,CAAA98C,EACAq/C,EAEIt/B,EAAAA,IAAA,MAAA,CAAI,UAAU,oBACZ,UACH,CAAA,EACE,IAAA,EACR,EACCvY,EAGGuY,EAAA,IAACm9B,GAAA,CACC,KAAK,WACL,aAAW,QACX,UAAU,kBACV,gBAAYn0B,GAAU,EAAA,EACtB,QAAS,IAAMvhB,EAAQ,CAAA,CACzB,EACE,IACR,CAAA,CAAA,CAEJ,aCvFA,SAASg4C,GAAexrD,EAAoC,CACpD,KAAA,CAAE,SAAAgM,EAAU,UAAAzE,CAAc,EAAAvH,EAEhC,aACG,MAAI,CAAA,UAAWurD,GAAW,iBAAkBhkD,CAAS,EACnD,SAAAyE,CACH,CAAA,CAEJ,CCrBA,MAAMy/C,GAAeC,EAAAA,cAAmC,IAAI,EAErD,SAASC,IAAuC,CACrD,OAAOC,EAAAA,WAAWH,EAAY,CAChC,aCEMI,GAAWrgC,EAAA,WAGf,CAACxrB,EAAOqE,IAAQ,CAChB,KAAM,CAAE,KAAAiI,EAAM,UAAA/E,EAAW,GAAGW,GAASlI,EAEnC,OAAA+rB,EAAA,IAAC,MAAA,CACC,UAAW68B,GAAG,CAAE,qBAAsBt8C,CAAA,EAAQ/E,CAAS,EACvD,IAAAlD,EACC,GAAG6D,CAAA,CAAA,CAGV,CAAC,EAmCK4jD,GAAUtgC,EAAA,WAAW,CACzBxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,KAAA7D,EACA,SAAAN,EACA,MAAAyU,EAAQ,KACR,KAAAwhC,EAAO,SACP,UAAA16C,EACA,QAAAiM,EACA,GAAGtL,CACD,EAAAlI,EAEE+rD,EAAgB,IAAY,CACtBv4C,GAAA,MAAAA,GAAA,EAGZ,OACGuY,EAAAA,IAAA0/B,GAAa,SAAb,CAAsB,MAAOzrD,EAC5B,SAAA+rB,EAAA,IAACnX,GAAA,CACC,IAAKzE,EACL,KAAA8xC,EACA,aAAW,OACX,UAAW2G,GAAG,WAAYrhD,CAAS,EACnC,KAAA+E,EACA,QAASy/C,EACT,MAAO,CAAE,SAAUzjD,GAAeujD,EAAQ,CAAE,EAC3C,GAAG3jD,EAEJ,SAAA6jB,EAAA,IAAC,OAAI,UAAW68B,GAAG,oBAAqB,sBAAsBnoC,CAAK,EAAE,EAClE,SAAAzU,CACH,CAAA,CAAA,CAEJ,CAAA,CAAA,CAEJ,CAAC,EAED8/C,GAAQ,YAAc,UCnFtB,SAASE,GAAmBhsD,EAAoC,CACxD,KAAA,CACJ,UAAAuH,EACA,SAAAyE,EACA,GAAG9D,CACD,EAAAlI,EAEEisD,EAAWN,KAEjB,GAAIM,IAAa,KACT,MAAA,IAAI,MAAM,gEAAgE,EAG5E,KAAA,CAAE,QAAAz4C,CAAY,EAAAy4C,EAEdF,EAAgB,IAAY,CACtBv4C,GAAA,MAAAA,GAAA,EAIV,OAAAuY,MAACm9B,IAAU,GAAGhhD,EAAM,KAAK,WAAW,QAAS6jD,EAAe,UAAAxkD,EACzD,SAAAyE,CACH,CAAA,CAEJ,CAEAggD,GAAmB,YAAc,qBCzB3B,MAAAE,GAAgB1gC,EAAA,WAAW,CAC/BxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,SAAAnE,EACA,UAAAzE,EACA,GAAGW,CACD,EAAAlI,EAEEisD,EAAWN,KAEjB,GAAIM,IAAa,KACT,MAAA,IAAI,MAAM,2DAA2D,EAGvE,KAAA,CAAE,QAAAz4C,CAAY,EAAAy4C,EAGlB,OAAAnD,OAAC,MAAK,CAAA,GAAG5gD,EAAM,IAAKiI,EAAc,UAAWy4C,GAAG,mBAAoBrhD,CAAS,EAC3E,SAAA,CAACwkB,EAAAA,IAAA,MAAA,CAAI,UAAU,2BACZ,SAAA/f,CACH,CAAA,EACCwH,SACEw4C,GAAmB,CAAA,UAAU,yBAAyB,UAAWjgC,MAACgJ,IAAU,CAAA,EAAI,CAErF,CAAA,CAAA,CAEJ,CAAC,EAEDm3B,GAAc,YAAc,gBCnCtB,MAAAC,GAAqB3gC,EAAA,WAAW,CACpCxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,UAAA5I,EACA,SAAAyE,EACA,GAAG9D,CACD,EAAAlI,EAGF,OAAA+rB,EAAA,IAAC,MAAK,CAAA,GAAG7jB,EAAM,IAAKiI,EAAc,UAAWy4C,GAAG,yBAA0BrhD,CAAS,EAChF,SAAAyE,CACH,CAAA,CAEJ,CAAC,EAEDmgD,GAAmB,YAAc,qBCb3B,MAAAC,GAAc5gC,EAAA,WAAW,CAC7BxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,SAAAnE,EACA,QAAAyM,EAAU,SACV,UAAAlR,EACA,GAAGW,CACD,EAAAlI,EAEJ,OACG+rB,EAAAA,IAAA,MAAA,CAAK,GAAG7jB,EAAM,IAAKiI,EAAc,UAAWy4C,GAAG,iBAAkB,mBAAmBnwC,CAAO,GAAIlR,CAAS,EACtG,SAAAyE,CACH,CAAA,CAEJ,CAAC,EAEDogD,GAAY,YAAc,cCnBpB,MAAAC,GAAgB7gC,EAAA,WAAW,CAC/BxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,SAAAnE,EACA,UAAAzE,EACA,GAAGW,CACD,EAAAlI,EAGF,OAAA+rB,EAAA,IAAC,MAAK,CAAA,GAAG7jB,EAAM,IAAKiI,EAAc,UAAWy4C,GAAG,mBAAoBrhD,CAAS,EAC1E,SAAAyE,CACH,CAAA,CAEJ,CAAC,EAEDqgD,GAAc,YAAc,gBCnBtB,MAAAC,GAAuB9gC,EAAA,WAAW,CACtCxrB,EACAmQ,IACiB,CACX,KAAA,CACJ,UAAA5I,EACA,SAAAyE,EACA,GAAG9D,CACD,EAAAlI,EAGF,OAAA+rB,EAAA,IAAC,MAAK,CAAA,GAAG7jB,EAAM,IAAKiI,EAAc,UAAWy4C,GAAG,4BAA6BrhD,CAAS,EACnF,SAAAyE,CACH,CAAA,CAEJ,CAAC,EAEDsgD,GAAqB,YAAc,mCCsB7BC,GAAe,IAAoBxgC,EAAAA,IAAA,OAAA,CAAK,SAAM,GAAA,CAAA,EAS9CygC,GAAchhC,EAAA,WAAW,CAACxrB,EAAyBqE,IAAsC,CAC7F,KAAM,CAAE,UAAAkD,EAAW,QAAAklD,EAAS,UAAAC,EAAW,MAAApvD,EAAO,UAAAqvD,EAAW,WAAAC,EAAY,MAAAC,EAAO,SAAAC,EAAU,QAAAtD,EAAS,GAAGthD,CAAA,EAASlI,EAGzG,OAAA8oD,EAAA,KAAC,MAAA,CACE,GAAG5gD,EACJ,UAAW0gD,GAAG,gBAAiBrhD,EAAW,CACxC,uBAAwBjK,EACxB,4BAA6BqvD,CAAA,CAC9B,EACD,IAAAtoD,EAEE,SAAA,EAAAwoD,GAASC,IACThE,EAAA,KAAC,MAAI,CAAA,UAAU,2BACZ,SAAA,CAAA+D,GACE/D,EAAAA,KAAA,QAAA,CAAM,UAAU,uBAAuB,QAAS4D,EAC9C,SAAA,CAAUG,IAAA,IAAMN,KAAiBM,EACjCrD,SACE1B,GAAU,CAAA,MAAO0B,EAChB,SAACz9B,EAAA,IAAAsV,GAAA,CAAS,UAAU,qBAAA,CAAsB,CAC5C,CAAA,CAAA,EAEJ,EAEDyrB,GACC/gC,EAAA,IAAC,OAAK,CAAA,UAAU,0BACb,SACH+gC,EAAA,CAAA,EAEJ,EAEDL,EACAG,SACE,OAAK,CAAA,UAAU,wBACb,SAAeA,IAAA,IAAML,GAAa,EAAIK,CACzC,CAAA,CAAA,CAAA,CAAA,CAIR,CAAC,EC7FD,SAAwBjO,GAAS,CAC/B,QAAAnpC,EACA,QAAA0qC,CACF,EAGgB,GAA4F,CAC1G,KAAM,CAAC6M,EAASC,CAAU,EAAI5E,WAAS,EAAK,EAEtC6E,EAAmBC,EAAAA,YAAY,IAAM,CACzCF,EAAW,EAAI,EACLx3C,GAAA,MAAAA,GAAA,EACT,CAACA,CAAO,CAAC,EAEN23C,EAAmBD,EAAAA,YAAY,IAAM,CACzCF,EAAW,EAAK,EACN9M,GAAA,MAAAA,GAAA,EACT,CAACA,CAAO,CAAC,EAEL,MAAA,CACL,QAAA6M,EACA,SAAU,CACR,aAAcE,EACd,aAAcE,CAChB,CAAA,CAEJ,aC0FA,SAAS/oD,GACPC,EACAlD,EACM,CACF,OAAOkD,GAAQ,WACjBA,EAAIlD,CAAK,EACAkD,IACTA,EAAI,QAAUlD,EAElB,CAEA,SAASisD,MACJzoD,EACiC,CAM7B,OAAAtP,EAAM,QAAQ,IACfsP,EAAK,MAAON,GAAQA,GAAO,IAAI,EAC1B,KAGDO,GAAa,CACdD,EAAA,QAASN,GAAQ,CACpBD,GAAOC,EAAKO,CAAQ,CAAA,CACrB,CAAA,EAGFD,CAAI,CACT,CAOA,MAAM0oD,GAAc7hC,EAAA,WAAW,CAC7BxrB,EACAmQ,IACG,CACG,KAAA,CACJ,SAAAm9C,EACA,UAAA/lD,EACA,UAAAgmD,EACA,aAAA5+C,EACA,SAAAjG,EACA,MAAApL,EACA,WAAYkwD,EAAe,CAAC,EAC5B,YAAAC,EACA,QAAAhkC,EACA,QAAAC,EACA,UAAAgkC,EACA,OAAAr/C,EACA,SAAAC,EACA,cAAAq/C,EACA,QAAAjgD,EACA,SAAAkgD,EACA,SAAAh/C,EACA,aAAAi/C,EACA,MAAA1sD,EACA,GAAG+G,CACD,EAAAlI,EACE8tD,EAAsC3sD,GAAU,KAEhDgO,EAAWqvC,SAA+C,IAAI,EAC9DuP,EAAUX,GAAYj+C,EAAUgB,CAAY,EAE5C,CAAC69C,EAAeC,CAAgB,EAAI7F,EAAS,SAAA0F,EAAen/C,EAAe,EAAE,EAC7Eu/C,EAAaJ,EAAeE,EAAgB7sD,EAElDkmB,EAAAA,UAAU,IAAM,CACEsmC,GAAA,MAAAA,GAAAO,GAAA,YAAAA,EAAY,SAAU,EAAC,EACtC,CAACA,EAAYP,CAAa,CAAC,EAExB,MAAAQ,EAAkBv3D,GAAuE,CAC5Eq3D,EAAAr3D,EAAE,OAAO,KAAK,EAE/B0X,GAAA,MAAAA,EAAW1X,EAAC,EAGR,CAAE,QAAAm2D,EAAS,SAAUqB,GAAkBzP,GAAS,EAEhD,CAAE,cAAA0P,EAAe,aAAAl5C,EAAc,QAAA9F,CAAA,EAAYpB,GAAS,CACxD,aAAAU,EACA,SAAAjG,EACA,MAAApL,EACA,SAAUywD,EACV,OAAA1/C,EACA,SAAU8/C,EACV,QAAAzgD,EACA,SAAAkB,EACA,MAAOk/C,EAAe,OAAYI,CAAA,CACnC,EAEKI,EAAe13D,GAAqD,CACpE,GAAA,CAACuY,EAAS,QACZ,OAGFA,EAAS,QAAQ,MAAQ,GACzB8+C,EAAiB,EAAE,EAEb,MAAA7oD,EAAQ,OAAO,OAAOxO,EAAG,CAC7B,OAAQ,CAAE,MAAOuY,EAAS,OAAQ,EAClC,cAAe,CAAE,MAAOA,EAAS,OAAQ,CAAA,CAC1C,EAEDb,GAAA,MAAAA,EAAWlJ,EAAK,EAGZmpD,GAAiB,IAA2B,CAC1C,MAAAC,EAAY9lD,GAAYklD,GAAY,CAACM,EAGzC,OAAAniC,EAAA,IAACm9B,GAAA,CACC,aAAW,QACX,KAAK,WACL,UAAWN,GAAG,8BAA+B,CAC3C,sCAAuC4F,CAAA,CACxC,EAED,YAAc53D,GAAMA,EAAE,eAAe,EACrC,gBAAYm+B,GAAU,EAAA,EACtB,QAASu5B,CAAA,CAAA,CACX,EAIEG,EAAwB7F,GAAG,gBAAiBrhD,EAAW,CAC3D,0BAA2BmB,EAC3B,uBAAwBpL,EACxB,yBAA0B+R,EAC1B,yBAA0B09C,EAC1B,0BAA2Ba,EAC3B,0BAA2Bh/C,CAAA,CAC5B,EAEK8/C,EAAaL,EAAc,CAC/B,GAAGb,EACH,UAAW5E,GAAG,uBAAwB4E,EAAa,UAAW,CAC5D,kCAAmCE,EACnC,kCAAmCH,GAAaM,EAChD,iCAAkCJ,CAAA,CACnC,EACD,GAAGvlD,EACH,SAAA0lD,CAAA,CACD,EAGC,OAAA9E,EAAA,KAAC,OAAI,UAAW2F,EAAwB,GAAGt5C,EAAa,EAAI,GAAGi5C,EAC5D,SAAA,CAAAX,GACE1hC,EAAA,IAAA,OAAA,CAAK,UAAU,yBAA0B,SAAY0hC,EAAA,EAEvDC,IACCJ,EACKvhC,EAAA,IAAAvC,GAAA,CAAkB,GAAGklC,EAAY,QAAAhlC,EAAkB,QAAAD,CAAkB,CAAA,EACrEsC,EAAAA,IAAA,WAAA,CAAU,GAAG2iC,EAAY,KAAMhlC,CAAS,CAAA,GAE9C,CAACgkC,GAAc3hC,EAAA,IAAA,QAAA,CAAO,GAAG2iC,CAAY,CAAA,GACpCb,GAAgBN,IACfzE,EAAA,KAAA,OAAA,CAAK,UAAU,yBACb,SAAA,CAAAyE,GAAagB,GAAe,EAC5BV,CAAA,EACH,CAEJ,CAAA,CAAA,CAEJ,CAAC,EAEDR,GAAY,YAAc,cC9Rb,MAAAsB,GAAmBC,GACvB,GAAGA,CAAS,IAAI,KAAK,MAAM,KAAK,OAAW,EAAA,GAAI,CAAC,GCuHnDC,GAAerjC,EAAA,WAAW,CAACxrB,EAA0BqE,IAA8C,CACjG,KAAA,CACJ,UAAAkD,EACA,UAAAgmD,EACA,aAAA5+C,EACA,SAAAjG,EACA,MAAApL,EACA,WAAAsvD,EACA,WAAA8B,EACA,MAAA7B,EACA,YAAAY,EACA,KAAAxzC,EACA,OAAA5L,EACA,SAAAC,EACA,QAAAZ,EACA,YAAAohD,EACA,SAAAlB,EACA,SAAAh/C,EACA,aAAAi/C,EACA,QAAArE,EACA,MAAAroD,EACA,GAAAo7C,EACA,GAAGr0C,CACD,EAAAlI,EAEE0sD,EAAYnQ,IAAMmS,GAAA,YAAAA,EAAY,KAAMC,GAAgB,mBAAmB,EAEvEI,EAAmC,CACvC,UAAAxB,EACA,aAAA5+C,EACA,SAAAjG,EACA,MAAApL,EACA,GAAIovD,EACJ,WAAAgC,EACA,YAAAjB,EACA,KAAAxzC,EACA,OAAA5L,EACA,SAAAC,EACA,QAAAZ,EACA,YAAAohD,EACA,SAAAlB,EACA,SAAAh/C,EACA,aAAAi/C,EACA,MAAA1sD,CAAA,EAIA,OAAA4qB,EAAA,IAACygC,GAAA,CACE,GAAGtkD,EACJ,UAAW0gD,GAAG,iBAAkBrhD,CAAS,EACzC,QACEwkB,EAAA,IAACshC,GAAA,CACE,GAAG0B,EACJ,IAAA1qD,CAAA,CACF,EAEF,UAAAqoD,EACA,MAAApvD,EACA,WAAAsvD,EACA,MAAAC,EACA,QAAArD,CAAA,CAAA,CAGN,CAAC,EAEDqF,GAAa,YAAc,2BCpCrBG,GAAcxjC,EAAA,WAAW,CAACxrB,EAAyBqE,IAA2C,CAC5F,KAAA,CACJ,SAAAipD,EACA,UAAA/lD,EACA,QAAA0nD,EACA,aAAAtgD,EACA,SAAAjG,EACA,MAAApL,EACA,WAAAsvD,EACA,GAAArQ,EACA,MAAAsQ,EACA,SAAAqC,EACA,QAAAzlC,EACA,QAAAC,EAAU,EACV,KAAAzP,EACA,OAAA5L,EACA,SAAAC,EACA,QAAAZ,EACA,YAAAohD,EACA,SAAAlB,EACA,SAAAh/C,EACA,UAAAugD,EACA,cAAAC,EACA,QAAA5F,EACA,MAAAroD,EACA,GAAG+G,CACD,EAAAlI,EAEE0sD,EAAYnQ,IAAM6S,GAAA,YAAAA,EAAe,KAAMT,GAAgB,kBAAkB,EAEzEI,EAAmC,CACvC,SAAAzB,EACA,aAAA3+C,EACA,SAAAjG,EACA,MAAApL,EACA,GAAIovD,EACJ,WAAY,CACV,GAAG0C,EACH,UAAWxG,GAAG,0BAA2BwG,GAAA,YAAAA,EAAe,UAAW,CACjE,qCAAsCD,CAAA,CACvC,CACH,EACA,QAAA1lC,EACA,QAAAC,EACA,KAAAzP,EACA,OAAA5L,EACA,SAAAC,EACA,QAAAZ,EACA,YAAAohD,EACA,SAAAlB,EACA,SAAAh/C,EACA,MAAAzN,CAAA,EAGI,CAACi7C,EAAOiT,CAAQ,EAAIjH,WAAS,CAAC,EAGlC,OAAAr8B,EAAA,IAACygC,GAAA,CACE,GAAGtkD,EACJ,UAAW0gD,GAAG,gBAAiBrhD,CAAS,EACxC,QACEwkB,EAAA,IAACshC,GAAA,CACE,GAAG0B,EACJ,UAAS,GACT,cAAeM,EACf,IAAAhrD,CAAA,CACF,EAEF,UAAAqoD,EACA,MAAApvD,EACA,WAAAsvD,EACA,MAAAC,EACA,SAAUoC,GACPljC,MAAA,OAAA,CAAK,UAAU,yBACb,SAAA,GAAGqwB,CAAK,GAAG8S,EAAW,IAAIA,CAAQ,GAAK,EAAE,GAC5C,EAEF,QAAA1F,CAAA,CAAA,CAGN,CAAC,EAEDwF,GAAY,YAAc,cCvO1B,MAAMM,GAAoB5D,EAAAA,cAAwC,IAAI,EAE/D,SAAS6D,IAAiD,CAC/D,OAAO3D,EAAAA,WAAW0D,EAAiB,CACrC,CCLO,MAAME,GAA0D,CAAC,GAAI,GAAI,EAAE,EAErEC,GAAyB,EAEzBC,GAA0B,ECH1BC,GAAO,IAAY,CAEhC,ECLO,SAAS9rD,GAAKtM,EAA0B,CACtC,OAAA,IAAI,QAASD,GAAM,CAAE,WAAWA,EAAGC,CAAC,CAAA,CAAI,CACjD,CCAA,IAAIL,GAAIoE,GACJ,QAAQ,IAAI,WAAa,cACNpE,GAAE,WACDA,GAAE,aAEhBA,GAAE,mDCFL,SAASq0D,MAAcqE,EAA4C,CACxE,OAAOA,EAAI,OAAO,OAAO,EAAE,KAAK,GAAG,EAAE,MACvC,CCoBgB,SAAAC,GACdC,EACAr3C,EACe,CACf,GAAI,CAACq3C,EACI,MAAA,CACL,EAAG,EACH,EAAG,EACH,KAAM,EACN,MAAO,EACP,IAAK,EACL,OAAQ,EACR,MAAO,EACP,OAAQ,CAAA,EAIZ,GAAI,CAAE,IAAA3tC,EAAK,MAAA4tC,EAAO,OAAAC,EAAQ,KAAA9tC,EAAM,MAAAzB,EAAO,OAAAC,CAAW,EAAAovC,EAElD,OAAIr3C,IACEA,EAAQ,OACVyJ,GAAQzJ,EAAQ,KAChBgI,GAAShI,EAAQ,MAGfA,EAAQ,QACVs3C,GAASt3C,EAAQ,MACjBgI,GAAShI,EAAQ,OAGfA,EAAQ,MACV0J,GAAO1J,EAAQ,IACfiI,GAAUjI,EAAQ,KAGhBA,EAAQ,SACVu3C,GAAUv3C,EAAQ,OAClBiI,GAAUjI,EAAQ,SAIf,CAAE,EAAGyJ,EAAM,EAAGC,EAAK,IAAAA,EAAK,MAAA4tC,EAAO,OAAAC,EAAQ,KAAA9tC,EAAM,MAAAzB,EAAO,OAAAC,CAAO,CACpE,CCpEA,MAAMuvC,GAAc,iBAKb,SAASC,GAAgBC,EAAmC,CACjE,IAAIC,EAAmC,KACvC,MAAM1kD,EAAO,SAAS,eAAeykD,GAAYF,EAAW,EAE5D,GAAIvkD,aAAgB,eACN0kD,EAAA1kD,MACP,CAEL,MAAMoX,EAAO,SAAS,qBAAqB,MAAM,EAAE,CAAC,EACxCstC,EAAA,SAAS,cAAc,KAAK,EAEpCttC,GAAQstC,GACVttC,EAAK,YAAYstC,CAAS,CAE9B,CAEA,OAAIA,IACQA,EAAA,aACR,QACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAAA,EAWE,SAAS,KAAK,YAAcA,GACrB,SAAA,KAAK,YAAYA,CAAS,EAGrCA,EAAU,GAAKD,GAAYF,IAGtBG,CACT,CC+BO,SAASC,GAASz0D,EAAyB,CACzC,OAAAA,GAAOA,EAAI,aAAe,MACnC,CAKO,SAAS00D,GAAS10D,EAAyB,CACzC,OAAAA,IAAQ,QAAUA,EAAI,aAC/B,CChFgB,SAAA20D,GAAkBz7D,EAAsByS,EAAuC,CAE7F,IAAI+uC,EAA2BxhD,EAE/B,KAAOwhD,GAAQ,CAACA,EAAK,UAAU,SAAS/uC,CAAS,GAC/C+uC,EAAOA,EAAK,cAGP,OAAAA,CACT,CCVgB,SAAAka,GACdr+C,EACAikC,EACS,CACL,GAAA,CAACjkC,GAAU,CAACikC,EAAgB,MAAA,GAChC,IAAIE,EAAYF,EAEhB,KAAOE,GAAM,CACX,GAAIA,IAASnkC,EAAiB,MAAA,GAC9BmkC,EAAOA,EAAK,UACd,CAEO,MAAA,EACT,CCkBA,IAAIma,GAAY,CAAC,EACf,OAAO,OAAW,KAClB,OAAO,UACP,OAAO,SAAS,eASdC,GAA4B,CAC9B,UAAAD,GAEA,cAAe,OAAO,OAAW,IAEjC,qBACEA,IAAa,CAAC,EAAE,OAAO,kBAAqB,OAAe,aAE7D,eAAgBA,IAAa,CAAC,CAAC,OAAO,OAEtC,WAAY,CAACA,EACf,ECrBIE,GACAD,GAAqB,YAErBC,GAAA,SAAS,gBACT,SAAS,eAAe,YAGxB,SAAS,eAAe,WAAW,GAAI,EAAE,IAAM,IAGnD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,GAcA,SAASC,GAAiBC,EAAsBC,EAAe,CAC7D,GACE,CAACJ,GAAqB,WACrBI,GAAW,EAAE,qBAAsB,UAE7B,MAAA,GAGT,IAAIC,EAAY,KAAOF,EACnBG,EAAcD,KAAa,SAE/B,GAAI,CAACC,EAAa,CACZ,IAAAl8D,EAAe,SAAS,cAAc,KAAK,EACvCA,EAAA,aAAai8D,EAAW,SAAS,EAC3BC,EAAA,OAAOl8D,EAAQi8D,CAAS,GAAM,UAC9C,CAEA,MAAI,CAACC,GAAeL,IAAiBE,IAAoB,UAEvDG,EAAc,SAAS,eAAe,WAAW,eAAgB,KAAK,GAGjEA,CACT,CCXA,IAAIC,GAAa,GAGbC,GAAUC,GAAeC,GAAaC,GAAcC,GAGpDC,GAGAC,GAAWC,GAAeC,GAAaC,GAGvCC,GAGAC,GAAcC,GAAYC,GAE1BC,GAEJ,SAASC,IAAiB,CACxB,GAAI,CAAAhB,GAIS,CAAAA,GAAA,GAOb,IAAIiB,EAAM,UAAU,UAChBC,EACF,iLAAiL,KAC/KD,CAAA,EAEAE,EAAK,+BAA+B,KAAKF,CAAG,EAehD,GAbUL,GAAA,qBAAqB,KAAKK,CAAG,EAC/BJ,GAAA,cAAc,KAAKI,CAAG,EACnBP,GAAA,WAAW,KAAKO,CAAG,EACpBH,GAAA,cAAc,KAAKG,CAAG,EACtBF,GAAA,UAAU,KAAKE,CAAG,EAO5BN,GAAS,CAAC,CAAC,QAAQ,KAAKM,CAAG,EAEvBC,EAAO,CACTjB,GAAMiB,EAAM,CAAC,EACT,WAAWA,EAAM,CAAC,CAAC,EACnBA,EAAM,CAAC,EACP,WAAWA,EAAM,CAAC,CAAC,EACnB,IAEAjB,IAAO,UAAa,SAAiB,eACvCA,GAAO,SAAiB,cAGtB,IAAAmB,EAAU,yBAAyB,KAAKH,CAAG,EAC/CX,GAAmBc,EAAU,WAAWA,EAAQ,CAAC,CAAC,EAAI,EAAInB,GAE1DC,GAAWgB,EAAM,CAAC,EAAI,WAAWA,EAAM,CAAC,CAAC,EAAI,IAC7Cf,GAASe,EAAM,CAAC,EAAI,WAAWA,EAAM,CAAC,CAAC,EAAI,IAC3Cd,GAAUc,EAAM,CAAC,EAAI,WAAWA,EAAM,CAAC,CAAC,EAAI,IACxCd,IAIMc,EAAA,yBAAyB,KAAKD,CAAG,EAC/BZ,GAAAa,GAASA,EAAM,CAAC,EAAI,WAAWA,EAAM,CAAC,CAAC,EAAI,KAE3Cb,GAAA,GACZ,MAEMJ,GAAAC,GAAWC,GAASE,GAAUD,GAAU,IAGhD,GAAIe,EAAI,CACF,GAAAA,EAAG,CAAC,EAAG,CAML,IAAAE,EAAM,iCAAiC,KAAKJ,CAAG,EAE5CV,GAAAc,EAAM,WAAWA,EAAI,CAAC,EAAE,QAAQ,IAAK,GAAG,CAAC,EAAI,EAAA,MAE7Cd,GAAA,GAEEC,GAAA,CAAC,CAACW,EAAG,CAAC,EACRV,GAAA,CAAC,CAACU,EAAG,CAAC,CAAA,MAEfZ,GAAOC,GAAWC,GAAS,GAE/B,CAEA,IAAIa,GAAuB,CAOzB,GAAI,UAAY,CACd,OAAON,GAAe,GAAAf,EACxB,EAQA,oBAAqB,UAAY,CACxB,OAAAe,GAAA,GAAeV,GAAmBL,EAC3C,EAOA,KAAM,UAAY,CACT,OAAAqB,GAAqB,GAAQ,GAAAX,EACtC,EAQA,QAAS,UAAY,CACnB,OAAOK,GAAe,GAAAd,EACxB,EAQA,MAAO,UAAY,CACjB,OAAOc,GAAe,GAAAb,EACxB,EAQA,OAAQ,UAAY,CAClB,OAAOa,GAAe,GAAAZ,EACxB,EAMA,OAAQ,UAAY,CAClB,OAAOkB,GAAqB,QAC9B,EAQA,OAAQ,UAAY,CAClB,OAAON,GAAe,GAAAX,EACxB,EAOA,QAAS,UAAY,CACnB,OAAOW,GAAe,GAAAR,EACxB,EAQA,IAAK,UAAY,CACf,OAAOQ,GAAe,GAAAT,EACxB,EAOA,MAAO,UAAY,CACjB,OAAOS,GAAe,GAAAP,EACxB,EAQA,OAAQ,UAAY,CAClB,OAAOO,GAAe,GAAAJ,EACxB,EAEA,OAAQ,UAAY,CAClB,OAAOI,GAAU,GAAKJ,IAAWC,IAASH,IAAYK,EACxD,EAEA,UAAW,UAAY,CAErB,OAAOC,GAAe,GAAAF,EACxB,EAEA,QAAS,UAAY,CACnB,OAAOE,GAAe,GAAAN,EACxB,EAEA,KAAM,UAAY,CAChB,OAAOM,GAAe,GAAAH,EACxB,CACF,EC7QA,MAAMU,GAAa,GACbC,GAAc,GACdC,GAAc,IAsGb,SAASC,GAA2BvtD,EAKzC,CACA,IAAIwtD,EAAK,EACLC,EAAK,EACLC,EAAK,EACLC,EAAK,EAGT,MAAI,WAAY3tD,IACdytD,EAAKztD,EAAM,QAET,eAAgBA,IACbytD,EAAA,CAACztD,EAAM,WAAa,KAEvB,gBAAiBA,IACdytD,EAAA,CAACztD,EAAM,YAAc,KAExB,gBAAiBA,IACdwtD,EAAA,CAACxtD,EAAM,YAAc,KAIxB,SAAUA,GAASA,EAAM,OAASA,EAAM,kBACrCwtD,EAAAC,EACAA,EAAA,GAGPC,EAAKF,EAAKJ,GACVO,EAAKF,EAAKL,GAEN,WAAYptD,IACd2tD,EAAK3tD,EAAM,QAET,WAAYA,IACd0tD,EAAK1tD,EAAM,SAGR0tD,GAAMC,IAAO3tD,EAAM,YAClBA,EAAM,YAAc,GAEhB0tD,GAAAL,GACAM,GAAAN,KAGAK,GAAAJ,GACAK,GAAAL,KAKNI,GAAM,CAACF,IACJA,EAAAE,EAAK,EAAI,GAAK,GAEjBC,GAAM,CAACF,IACJA,EAAAE,EAAK,EAAI,GAAK,GAGd,CACL,MAAOH,EACP,MAAO,CAACC,EACR,OAAQC,EACR,OAAQ,CAACC,CAAA,CAEb,CAQAJ,GAAe,aAAe,UAAuD,CAEnF,OAAOJ,GAAqB,QAAQ,EAChC,iBACA3B,GAAiB,OAAO,EACtB,QACA,YACR,EC/MgB,SAAAoC,GACdC,EAGAC,EACAC,EAIA,CACO,MAAA,CACL,YAAcv8D,GAAwB,CACpCq8D,EAAU,SAAS,CAAE,QAAS,EAAM,CAAA,EACpCC,GAAA,MAAAA,EAAOt8D,EACT,EACA,aAAeA,GAAwB,CAKrC,GAAIq8D,EAAU,WAAaA,EAAU,UAAU,SAE3C,CAACzC,GAASyC,EAAU,UAAU,QAASr8D,EAAE,YAAY,MAAa,EAClE,CACAu8D,GAAA,MAAAA,EAAMv8D,GACN,MACF,CAGFq8D,EAAU,SAAS,CAAE,QAAS,EAAO,CAAA,EACrCE,GAAA,MAAAA,EAAMv8D,EACR,CAAA,CAEJ,CA+BO,SAASw8D,GACdH,EAIA,CACO,MAAA,CACL,QAAS,IAAMA,EAAU,SAAS,CAAE,QAAS,GAAM,EACnD,OAAQ,IAAMA,EAAU,SAAS,CAAE,QAAS,GAAO,CAAA,CAEvD,CCnFO,SAASI,GACd,EAKS,qBACL,GAAA,CACF,MAAMC,EAAW,EACjB,OAAAC,EAAAD,EAAS,kBAAT,MAAAC,EAAA,KAAAD,IACAE,EAAAF,EAAS,iBAAT,MAAAE,EAAA,KAAAF,GAEIA,EAAS,eACXG,GAAAC,EAAAJ,EAAS,aAAY,2BAArB,MAAAG,EAAA,KAAAC,IACAC,GAAAC,EAAAN,EAAS,aAAY,kBAArB,MAAAK,EAAA,KAAAC,IACAC,GAAAC,EAAAR,EAAS,aAAY,iBAArB,MAAAO,EAAA,KAAAC,IAEK,QACK,CAEL,MAAA,EACT,CACF,CC3BA,SAASC,GAAWn4D,EAA2B,CAC7C,OAAO,OAAOA,GAAQ,UACxB,CAyBgB,SAAAo4D,EACdC,EACA9yD,EACA+yD,EACmB,CACnB,GAAID,EACE,OAAAF,GAAW5yD,CAAK,EACXA,EAAM8yD,CAAS,EAEjB9yD,EACP,GAAI+yD,EACA,OAAAH,GAAWG,CAAS,EACfA,EAAU,EAEZA,CAIX,CCpCO,MAAMC,GAAiB,cAMjBC,GAAkB,qBCgG/B,IAAIhE,GAAmC,KAMvC,MAAMiE,GAAkD,CAAA,EAa3C,MAAAC,WAAiBj/D,EAAM,SAAqB,CAA5C,kCACXk/D,EAAA,iBAAYl/D,EAAM,aAClBk/D,EAAA,aAAgB,CAAA,GA8EhBA,EAAA,kBAAa,IAAY,OAEnB,KAAK,WAGL,KAAK,eACPhB,EAAA,KAAK,gBAAL,MAAAA,EAAqB,GAAG,IAAI,MAEPc,GAAA,KAAK,CAAC,KAAK,QAAS,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAC3D,GAGFE,EAAA,qBAAgB,IAAY,CACpB,MAAAC,MAAe,IAEAH,GAAA,QAAQ,CAAC1iD,EAAMjd,IAAM,CACnCid,EAAA,CAAC,EAAE,OAAO,IAAI,EAEfA,EAAK,CAAC,EAAE,OAAS,GACnB6iD,EAAS,IAAI9/D,CAAC,CAChB,CACD,EAED,MAAM,KAAK8/D,EAAS,OAAA,CAAQ,EACzB,OACA,QAAA,EACA,QAAS5iD,GAAUyiD,GAAqB,OAAOziD,EAAO,CAAC,CAAC,CAAA,GAGrD2iD,EAAA,0BAAsB39D,GAAwB,WAChD,GAAC,KAAK,MAAM,QAEZ,KAAK,YAAa,CACd,KAAA,CAAE,kBAAA69D,CAAkB,EAAI,KAAK,MACnC,GAAI,CAAE,gBAAAC,EAAkBtE,IAAc,KAAK,MAOvC,GANAqE,IACgBC,EAAA,SAAS,eAAeD,CAAiB,GAKzD,KAAK,MAAM,wBAEX,GAAAjE,GAAS,KAAK,UAAU,QAAS55D,EAAE,MAAa,GAC7CA,EAAE,SAAW,KAAK,UAAU,QAE/B,eAGF45D,GAASkE,EAAiB99D,EAAE,MAAa,GACpCA,EAAE,SAAW,KAAK,UAAU,QAEjC,UAGG28D,EAAA,KAAK,gBAAL,YAAAA,EAAqB,GAAG,OAAQ,IAAM,GAAKF,GAAgBz8D,CAAC,GAC5D88D,GAAAF,EAAA,KAAA,OAAM,UAAN,MAAAE,EAAA,KAAAF,EAAgB58D,GAErB,KAAK,cAAc,CACrB,CAAA,GAvIF,mBAA0B,CAClB,KAAA,CAAE,gBAAA89D,CAAgB,EAAI,KAAK,MACxB,SAAA,iBAAiB,YAAa,KAAK,kBAAkB,EAGzDA,IACStE,GAAAF,GAAgB,KAAK,OAAO,GAG1CA,GAAgBiE,EAAc,EAE1B,CAAC/D,IAAa,CAACsE,GAET,QAAA,KACN,iFAAA,EAIA,KAAK,QAAU,KAAK,WAAW,EACnC,KAAK,mBAAmB,CAC1B,CAEA,oBAA2B,CACrB,GAAA,CAAC,KAAK,UAAU,QAAW,OAEzB,KAAA,CAAE,cAAAC,CAAc,EAAI,KAAK,MAK/B,GAFI,KAAK,QAAU,KAAK,WAAW,EAE/BA,IAAkB,OAAQ,CAC5B,MAAM7E,EAAM,KAAK,UAAU,QAAQ,sBAAsB,EAEzD,KAAK,SAAS,CACZ,cAAeA,EAAI,MACnB,eAAgBA,EAAI,MAAA,CACrB,CACH,CACF,CAEA,sBAA6B,CAE3B,KAAK,cAAc,EACV,SAAA,oBAAoB,YAAa,KAAK,kBAAkB,CACnE,CAEA,IAAI,QAAkB,CACd,KAAA,CAAE,OAAA8E,CAAO,EAAI,KAAK,MAExB,MAAO,EAAQA,CACjB,CAEA,IAAY,SAAmC,CACvC,KAAA,CAAE,kBAAAH,CAAkB,EAAI,KAAK,MAEnC,OAAOA,GAAqBL,EAC9B,CAGA,IAAY,eAAgD,CACnD,OAAAC,GAAqBA,GAAqB,OAAS,CAAC,CAC7D,CAEA,IAAY,eAAyB,OACnC,QAAOd,EAAA,KAAK,gBAAL,YAAAA,EAAqB,MAAO,KAAK,OAC1C,CAEA,IAAY,aAAuB,CACjC,MAAMsB,EAAU,KAAK,cACd,OAAAA,GAAA,YAAAA,EAAU,MAAO,KAAK,UAAWA,GAAA,YAAAA,EAAU,GAAG,IAAI,MAC3D,CAEA,IAAY,UAAoB,CACvB,MAAA,EAAQR,GAAqB,KAAM1iD,GAASA,EAAK,CAAC,EAAE,IAAI,IAAI,CAAC,CACtE,CAgEA,cAAcgY,EAA0C,CACtD,KAAM,CAAE,UAAApiB,EAAW,eAAAutD,EAAiB,CAAA,EAAI,SAAA9oD,GAAa,KAAK,MAGxD,OAAA+f,EAAA,IAAC,MAAA,CACC,UAAWw/B,GAAW,WAAYhkD,CAAS,EAC3C,MAAAoiB,EACA,IAAK,KAAK,UACT,GAAGmrC,EAEH,SAAA9oD,CAAA,CAAA,CAGP,CAEA,QAA6B,CAC3B,KAAM,CAAE,cAAA2oD,EAAe,eAAgBI,CAAA,EAAmB,KAAK,MACzD,CACJ,OAAAH,EACA,gBAAAF,EAAkBtE,GAClB,YAAA4E,EACA,MAAOC,EAAc,EACrB,SAAAC,EACA,OAAAx0C,EACA,OAAAy0C,EACA,SAAAC,EACA,UAAAC,EACA,WAAAC,EACA,iBAAAC,EACA,cAAAC,EACA,OAAAC,CAAA,EACE,KAAK,MAET,GAAIb,EAAQ,CACV,GAAI,CAACF,EACH,kBAAW,IAAM,KAAK,YAAY,EAAG,GAAG,EACjC,KAGT,IAAIj0C,EAAQ,KAAK,IAAIw0C,GAAe,EAAG,CAAC,GAAKN,GAAiB,EAK1De,EAAch1C,GAAUq0C,GAAkB,OAAO,IAErD,MAAMY,EAAahB,GAAiB,EAChC,IAAAiB,EAAYC,EAAUC,EACxBC,EAEEN,EACEN,EACKU,EAAA,GACET,EACAW,EAAA,GACAV,EACCS,EAAA,GAEDF,EAAA,GAEFT,GAGLO,EAAc,IAChBA,EAAcd,EAAO,IAAM,GAGzBK,EAAc,IAChBx0C,EAAQm0C,EAAO,OAGjBiB,EAAOjB,EAAO,KAAOI,EAAcJ,EAAO,OAAS,GAAKc,EAC/CE,EAAA,CAACC,GACL,OAAO,YACNjB,EAAO,QACNI,EAAcJ,EAAO,OAAS,GAC/Bc,EACNI,EAAU,CAACF,GAAU,CAACC,GAAQF,EAAa,OAAO,WAAaf,EAAO,MACtEmB,EAAS,CAACH,GAAU,CAACC,GAAQ,CAACC,GAAWH,EAAaf,EAAO,MACpDQ,GAGLM,EAAc,IAChBA,EAAc,OAAO,YAAc,GAGjCT,EAAc,IAChBx0C,EAAQm0C,EAAO,KAAO,GAGxBmB,EAAS,CAACH,GAAU,CAACC,GAAQ,CAACC,GAAWH,EAAaf,EAAO,KAC7DiB,EAAO,CAACE,GACHnB,EAAO,KAAOI,EAAcJ,EAAO,OAAS,GAAKc,EAC7CE,EAAA,CAACG,GACL,CAACF,GACD,OAAO,YACNjB,EAAO,QACNI,EAAcJ,EAAO,OAAS,GAC/Bc,EACII,EAAA,CAACC,GACN,CAACH,GACD,CAACC,GACDF,EAAa,OAAO,WAAaf,EAAO,OACpCS,GAGLK,EAAc,IAChBA,EAAc,OAAO,YAAc,GAGjCT,EAAc,IACRx0C,EAAA,OAAO,WAAam0C,EAAO,MAAQ,GAGnCkB,EAAA,CAACF,GACN,CAACC,GACD,CAACE,GACDJ,EAAa,OAAO,WAAaf,EAAO,MAC7CmB,EAAS,CAACH,GAAU,CAACC,GAAQ,CAACC,GAAWH,EAAaf,EAAO,KAC7DgB,EAAS,CAACG,GACL,CAACD,GACD,CAACD,GACD,OAAO,YACNjB,EAAO,QACNI,EAAcJ,EAAO,OAAS,GAC/Bc,EACCG,EAAA,CAACE,GACH,CAACD,GACD,CAACF,GACDhB,EAAO,KAAOI,EAAcJ,EAAO,OAAS,GAAKc,IAIlDA,EAAc,IACFA,EAAA,OAAO,YAAcd,EAAO,OAAS,GAGjDK,EAAc,IAChBx0C,EAAQm0C,EAAO,OAGjBgB,EAAS,OAAO,YACVhB,EAAO,QACNI,EAAcJ,EAAO,OAAS,GACjCc,EACJG,EAAO,CAACD,GACHhB,EAAO,KAAOI,EAAcJ,EAAO,OAAS,GAAKc,EACtDI,EAAU,CAACF,GAAU,CAACC,GAAQF,EAAa,OAAO,WAAaf,EAAO,MACtEmB,EAAS,CAACH,GAAU,CAACC,GAAQ,CAACC,GAAWH,EAAaf,EAAO,MAG/D,IAAIoB,GAAaJ,GAAUC,IAASjB,EAAO,KAAO,OAAO,WAAa,EAElEY,IACUQ,EAAA,IAGVv1C,IACFA,EAAQ,KAAK,IAAIA,GAAS,EAAG,OAAO,UAAU,GAG5Cu0C,GAAe,CAACC,IAClBx0C,EAAQ,KAAK,IAAS,EAAG,OAAO,UAAU,GAGxCy0C,IACMz0C,EAAA,KAAK,IAAIA,EAAOy0C,CAAQ,GAGlC,MAAMe,EAAiB,KAAK,IAAIP,EAAa,OAAO,WAAW,EAAI,GAAK,EAGlEQ,EAAWN,EAEX,KAAK,IADPZ,EACWJ,EAAO,IACPA,EAAO,OADK,CAAC,EAGxBiB,EACE,KAAK,IACLjB,EAAO,IAAMqB,GAAkBjB,EAAcJ,EAAO,OAAS,GAC7D,OAAO,YAAcqB,CAErB,EAAAb,GAAYC,EACVT,EAAO,IACP,EAEFuB,EAAY,KAAK,IAErBH,EACIpB,EAAO,MAAQe,EAEfG,EACElB,EAAO,OAASI,EAAcJ,EAAO,MAAQ,GAC7CmB,EACEnB,EAAO,KAAOe,GAAcX,EAAcJ,EAAO,MAAQ,GACzDA,EAAO,KACf,CACF,GAAKY,EAAgB/0C,EAAQ,EAAI,GAE3B21C,EAAS,CACb,IAAK,KAAK,IAAIF,EAAUT,EAASS,EAAW,CAAC,EAC7C,KAAMZ,EACFV,EAAO,MAAQA,EAAO,MAAQe,GAAc,EAC5CQ,EACJ,MAAO11C,GAAS,OAGhB,OAAQw1C,GAAkB,MAAA,EASxB,GANCtB,IACIyB,EAAA,MAAQlB,IAAaI,EAAa,EAAI,IAK3C70C,IAAU,QAAU,CAACg1C,EAAQ,CAE/B,GAAIW,EAAO,KAAO31C,EAAQ,OAAO,WAAY,CAC3C,MAAM41C,EAAS,OAAO,YAAcD,EAAO,KAAO31C,GAClD21C,EAAO,MAAQC,CACjB,CAGID,EAAO,KAAO,IACTA,EAAA,KAAOd,EAAa,EAAI,GAI7Bc,EAAO,KAAO31C,GAAS,OAAO,aAC5B60C,EACKc,EAAA,KAAO,OAAO,YAAc31C,EAAQ,GAClC21C,EAAO,KAAO31C,EAAQ,OAAO,aACtC21C,EAAO,KAAO,EACdA,EAAO,MAAQ,OAAO,YAG5B,CAII,GAAAH,IAAmB,QAAU,CAACR,EAAQ,CAExC,GAAIW,EAAO,IAAMH,EAAiB,OAAO,YAAa,CACpD,MAAMI,EAAS,OAAO,aAAeD,EAAO,IAAMH,GAClDG,EAAO,KAAOC,CAChB,CAGID,EAAO,IAAM,IACfA,EAAO,IAAM,GAIXA,EAAO,IAAMH,EAAiB,OAAO,cACvCG,EAAO,IAAM,EACbA,EAAO,OAAS,OAAO,YAE3B,CAEA,OAAIX,EACK,KAAK,cAAcW,CAAM,EAG3B5lD,GAAS,aAAa,KAAK,cAAc4lD,CAAM,EAAG1B,CAAe,CAC1E,CAEA,OAAIa,EACK,KAAK,gBAEP,IACT,CACF,aCrhBM,KAAEz/C,GAAK,IAAAC,EAAQ,EAAA,KAErB,SAASM,GAAM3e,EAAW4+D,EAAgBC,EAAwB,CAChE,OAAOzgD,GAAIC,GAAIre,EAAG4+D,CAAM,EAAGC,CAAM,CACnC,CAEA,SAASC,GAAelgD,EAAeC,EAAahf,EAAmB,CACjEA,EAAA8e,GAAM9e,EAAG,EAAG,CAAC,EACjB,MAAMk/D,EAAOl/D,EAAI,GAAM,EAAIA,EAAIA,EAAIA,GAAKA,EAAI,IAAM,EAAIA,EAAI,IAAM,EAAIA,EAAI,GAAK,EACrE,OAAAgf,EAAMD,GAASmgD,EAAOngD,CAChC,CAEO,MAAMogD,GAAmB,CAC9B,MAAO,sBACP,KAAM,oBACR,EAmFa,MAAAC,WAAqBthE,EAAM,SAAiC,CAA5D,kCACXk/D,EAAA,aAAgB,CACd,OAAQ,GACR,WAAY,GACZ,IAAK,CAAC,EAAG,CAAC,CAAA,GAGZA,EAAA,iBAAYl/D,EAAM,aACVk/D,EAAA,eAAUl/D,EAAM,aAChBk/D,EAAA,eAAUl/D,EAAM,aAChBk/D,EAAA,uBACAA,EAAA,4BACAA,EAAA,mBAAc,IACdA,EAAA,uBAAkB,IAClBA,EAAA,0BAAqB,IACrBA,EAAA,uBAAkB,IAClBA,EAAA,aAAQ,CACd,GAAI,EACJ,SAAU,CAAC,EAAG,CAAC,EACf,QAAS,CAAC,EAAG,CAAC,EACd,UAAW,EAAA,GAebA,EAAA,YAAO,IAAY,CACjB,KAAM,CAAE,OAAAK,EAAQ,cAAAgC,GAAkB,KAAK,MAKrC,GAAA,IAAChC,GAAA,MAAAA,EAAQ,QACN,EAACgC,GAAA,MAAAA,EAAe,QAChBhC,EAAO,OAASgC,EAAc,QAMjC,IAAChC,GAAA,MAAAA,EAAQ,SACN,EAACgC,GAAA,MAAAA,EAAe,SAChBhC,EAAO,QAAUgC,EAAc,SAKhC,CAAC,KAAK,aAAehC,GAAUgC,GAAiB,KAAK,QAAQ,UAC/D,KAAK,YAAc,GAEf,KAAK,MAAM,UAAU,CACjB,MAAAC,EAAU,KAAK,mBACrB,KAAK,MAAM,SACT,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChEA,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,CACF,GAsMMrC,EAAA,yBAAoB,SAA2B,CAC/C,MAAAuC,EAAU,KAAK,QAAQ,QAC7B,GAAI,CAACA,EAAW,OAChB,MAAMjzD,GAAK,CAAC,EACZ,MAAMmI,EAAW,MAAM,KAAK8qD,EAAQ,QAAQ,EAC5C,IAAI5B,EAAW,GAENlpD,EAAA,QAASoqC,GAAU,CAC1B,KAAM,CAAE,MAAA31B,CAAA,EAAU21B,EAAM,sBAAsB,EAC1C31B,EAAQy0C,IAAuBA,EAAAz0C,EAAO,CAC3C,EAEG,KAAK,MAAM,cAAgBy0C,GAC7B,KAAK,SAAS,CAAE,YAAaA,CAAU,CAAA,CACzC,GAGMX,EAAA,yBAAoB,CAC1BwC,EACAC,IACwB,CACxB,IAAI1gD,EAAQ,EACN,MAAA8wC,EAAW,KAAK,MAAM,oBAAsB,IAE5C6P,EAAa1/D,GAAoB,OAGjC,GAFA,CAAC,KAAK,UAAU,SAChB,CAAC,KAAK,QAAQ,SACd,CAAC,KAAK,QAAQ,QAAW,OAE7B,MAAMq9D,EAAS,KAAK,UAAU,QAAQ,sBAAsB,EACtDgC,GAAgBrD,EAAA,KAAK,QAAQ,UAAb,YAAAA,EAAsB,wBACtCsD,EAAU,KAAK,iBAAiBjC,EAAQgC,CAAa,EAEvD,GAAA,CAAC,KAAK,UAAU,QAAW,OAC1BtgD,IAAiBA,EAAA/e,GAChB,MAAAk/D,GAAQl/D,EAAI+e,GAAS8wC,EACrB7kC,EAAS,CACbi0C,GAAeO,EAAW,CAAC,EAAGC,EAAS,CAAC,EAAGP,CAAI,EAC/CD,GAAeO,EAAW,CAAC,EAAGC,EAAS,CAAC,EAAGP,CAAI,CAAA,EAG5C,KAAA,QAAQ,QAAQ,WAAa,KAAK,IACrC,KAAK,IAAIl0C,EAAO,CAAC,GAAK,EAAGs0C,EAAQ,YAAY,CAAC,CAAC,EAC/C,CAAA,EAGG,KAAA,QAAQ,QAAQ,UAAY,KAAK,IACpC,KAAK,IAAIt0C,EAAO,CAAC,GAAK,EAAGs0C,EAAQ,YAAY,CAAC,CAAC,EAC/C,CAAA,EAGF,KAAK,SAAS,CACZ,IAAK,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EACrE,OAAAjC,EACA,cAAAgC,CAAA,CACD,EAGC,KAAK,MAAM,UACRhC,GACAgC,GACA,KAAK,UAAU,SAElB,KAAK,MAAM,SACT,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChEC,EAAQ,YACRjC,EACAgC,EACA,EAAA,EAIA,KAAK,MAAM,WAAaH,EAAO,IAC5B,KAAA,gBAAkB,sBAAsBQ,CAAS,EACxD,EAGK,OAAAA,CAAA,GAuDT1C,EAAA,oBAAe,IAAY,CACzB,KAAK,SAAS,CACZ,OAAQ,OACR,cAAe,MAAA,CAChB,EAED,KAAK,kBAAkB,CAAA,GAGzBA,EAAA,wBAAoB39D,GAAwB,CAC1C,IAAIsgE,EAAsB,KAEjB,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,QAAQ,OAAQlC,EAAIyiE,IACnCD,EAAAtgE,EAAE,QAAQ,KAAKlC,CAAC,EACpB,CAAAwiE,GAF6C,EAAExiE,EAEnD,CAKEwiE,IACF,KAAK,MAAM,SAAW,CAACA,EAAM,MAAOA,EAAM,KAAK,EAC1C,KAAA,MAAM,GAAKA,EAAM,YAGnB,KAAA,SAAUzsC,IAAe,CAAE,IAAKA,EAAU,IAAK,OAAQ,GAAM,UAAW,EAAA,EAAQ,EAChE,qBAAA,KAAK,MAAM,SAAS,EACzC,KAAK,MAAM,UAAY,EAAA,GAGzB8pC,EAAA,sBAAkB39D,GAAwB,CACxC,IAAIsgE,EAAsB,KACjB,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,QAAQ,OAAQlC,EAAIyiE,EAAM,EAAEziE,EAEnD,GADQwiE,EAAAtgE,EAAE,QAAQ,KAAKlC,CAAC,EACpBwiE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,CAGF,GAAI,CAACA,GACM,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,cAAc,OAAQlC,EAAIyiE,EAAM,EAAEziE,EAEzD,GADQwiE,EAAAtgE,EAAE,cAAc,KAAKlC,CAAC,EAC1BwiE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,EAIJ,GAAI,CAACA,GACM,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,eAAe,OAAQlC,EAAIyiE,EAAM,EAAEziE,EAE1D,GADQwiE,EAAAtgE,EAAE,eAAe,KAAKlC,CAAC,EAC3BwiE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,EAIJ,GAAKA,IACA,KAAA,SAAUzsC,IAAe,CAAE,IAAKA,EAAU,IAAK,OAAQ,EAAQ,EAAA,GAGjE,KAAK,IAAI,KAAK,MAAM,QAAQ,CAAC,CAAC,EAAI,GAC9B,KAAK,IAAI,KAAK,MAAM,QAAQ,CAAC,CAAC,EAAI,IACpC,KAAK,QAAQ,SAChB,CACA,KAAM,CAAE,OAAAmqC,EAAQ,cAAAgC,GAAkB,KAAK,MACjC,CAAE,QAAAQ,CAAQ,EAAI,KAAK,QACJ,qBAAA,KAAK,MAAM,SAAS,EAEzC,MAAMC,EAAiB,IAAY,CACjCD,EAAQ,YAAc,KAAK,MAAM,QAAQ,CAAC,EAC1CA,EAAQ,WAAa,KAAK,MAAM,QAAQ,CAAC,EACnC,MAAAP,EAAU,KAAK,mBACrBO,EAAQ,WAAa,KAAK,IACxBA,EAAQ,WACRP,EAAQ,YAAY,CAAC,CAAA,EAEfO,EAAA,UAAY,KAAK,IAAIA,EAAQ,UAAWP,EAAQ,YAAY,CAAC,CAAC,EAEtE,KAAK,SAAS,CACZ,IAAK,CAACO,EAAQ,WAAYA,EAAQ,SAAS,CAAA,CAC5C,EAEG,KAAK,MAAM,UAAYxC,GAAUgC,GACnC,KAAK,MAAM,SACT,CAACQ,EAAQ,WAAYA,EAAQ,SAAS,EACtCP,EAAQ,YACRjC,EACAgC,CAAA,EAIC,KAAA,MAAM,QAAQ,CAAC,GAAK,IACpB,KAAA,MAAM,QAAQ,CAAC,GAAK,IAEvB,KAAK,IAAI,KAAK,MAAM,QAAQ,CAAC,CAAC,EAAI,MAC/B,KAAK,IAAI,KAAK,MAAM,QAAQ,CAAC,CAAC,EAAI,KAErC,sBAAsBS,CAAc,EAC7B,KAAK,MAAM,UAAY,EAAI,EAGjC,KAAA,MAAM,UAAY,sBAAsBA,CAAc,CAC7D,CAAA,GAGF9C,EAAA,uBAAmB39D,GAAwB,CAErC,GADA,EAAEA,EAAE,yBAAyB,iBAC7B,CAAC,KAAK,QAAQ,QAAW,OAC7B,KAAM,CAAE,OAAAg+D,EAAQ,cAAAgC,EAAe,OAAAU,CAAA,EAAW,KAAK,MAE/C,IAAIJ,EAAsB,KACjB,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,QAAQ,OAAQlC,EAAIyiE,IACnCD,EAAAtgE,EAAE,QAAQ,KAAKlC,CAAC,EACpB,EAAAwiE,GACEA,EAAM,aAAe,KAAK,MAAM,KAHW,EAAExiE,EAEnD,CAKF,GAAI,CAACwiE,EAAS,OAET,KAAA,QAAQ,QAAQ,YAAc,KAAK,MAAM,SAAS,CAAC,EAAIA,EAAM,MAC7D,KAAA,QAAQ,QAAQ,WAAa,KAAK,MAAM,SAAS,CAAC,EAAIA,EAAM,MAC5D,KAAA,MAAM,QAAQ,CAAC,EAAI,KAAK,MAAM,SAAS,CAAC,EAAIA,EAAM,MAClD,KAAA,MAAM,QAAQ,CAAC,EAAI,KAAK,MAAM,SAAS,CAAC,EAAIA,EAAM,MAElD,KAAK,MAAM,oBACd,KAAK,MAAM,QAAU,CAAC,EAAG,CAAC,GAG5B,KAAK,MAAM,SAAW,CAACA,EAAM,MAAOA,EAAM,KAAK,EACzC,MAAAL,EAAU,KAAK,mBAEhB,KAAA,QAAQ,QAAQ,WAAa,KAAK,IACrC,KAAK,QAAQ,QAAQ,WACrBA,EAAQ,YAAY,CAAC,CAAA,EAGlB,KAAA,QAAQ,QAAQ,UAAY,KAAK,IACpC,KAAK,QAAQ,QAAQ,UACrBA,EAAQ,YAAY,CAAC,CAAA,EAGvB,KAAK,SAAS,CACZ,IAAK,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EACrE,UAAW,EAAA,CACZ,EAEG,KAAK,MAAM,UAAYjC,GAAUgC,GACnC,KAAK,MAAM,SACT,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChEC,EAAQ,YACRjC,EACAgC,CAAA,EAKFU,GACG1C,IACCiC,EAAQ,SAAS,CAAC,EAAI,GAAKA,EAAQ,SAAS,CAAC,EAAI,IAErDxD,GAAgBz8D,CAAC,EAGE,qBAAA,KAAK,MAAM,SAAS,CAAA,GAG3C29D,EAAA,mBAAe39D,GAA2B,CAGpC,GAFA,EAAEA,EAAE,yBAAyB,iBAC7B,KAAK,MAAM,cACX,CAAC,KAAK,QAAQ,QAAkB,MAAA,GAEpC,KAAM,CAAE,OAAAg+D,EAAQ,cAAAgC,EAAe,OAAAU,CAAA,EAAW,KAAK,MACzCC,EAAQ5E,GAAe/7D,CAAC,EAExB4gE,EAAU,KAAK,QAAQ,QAAQ,WAAaD,EAAM,OAClDE,EAAS,KAAK,QAAQ,QAAQ,UAAYF,EAAM,OAEhDV,EAAU,KAAK,mBAEfa,EAAc,KAAK,IAAIF,EAASX,EAAQ,YAAY,CAAC,CAAC,EAEtDc,EAAa,KAAK,IAAIF,EAAQZ,EAAQ,YAAY,CAAC,CAAC,EAoBxD,GAlBG,KAAA,QAAQ,QAAQ,WAAaa,EAC7B,KAAA,QAAQ,QAAQ,UAAYC,EAEjC,KAAK,SAAS,CACZ,IAAK,CAACD,EAAaC,CAAU,EAC7B,UAAW,EAAA,CACZ,EAEG,KAAK,MAAM,UAAY/C,GAAUgC,GACnC,KAAK,MAAM,SACT,CAACc,EAAaC,CAAU,EACxBd,EAAQ,YACRjC,EACAgC,CAAA,EAKFU,GACG1C,IACCiC,EAAQ,SAAS,CAAC,EAAI,GAAKA,EAAQ,SAAS,CAAC,EAAI,GAEjD,GAAA,KAAK,MAAM,wBACb,GACG,KAAK,MAAMa,CAAW,EAAI,KAAK,MAAMb,EAAQ,YAAY,CAAC,CAAC,GACvD,KAAK,MAAMa,CAAW,EAAI,GAC3B,KAAK,MAAMC,CAAU,EAAI,KAAK,MAAMd,EAAQ,YAAY,CAAC,CAAC,GACzD,KAAK,MAAMc,CAAU,EAAI,EAE9B,OAAA/gE,EAAE,eAAe,EACjBy8D,GAAgBz8D,CAAC,EACV,OAGT,QAAAA,EAAE,eAAe,EACjBy8D,GAAgBz8D,CAAC,EACV,GAIX,OAAAA,EAAE,eAAe,EACV,EAAA,GAGT29D,EAAA,+BAA2B39D,GAAgD,CACzE,KAAM,CAAE,OAAAg+D,EAAQ,cAAAgC,GAAkB,KAAK,MAGjCC,EAAU,KAAK,mBAGfe,EAAc,CAClBf,EAAQ,YAAY,CAAC,EAAIA,EAAQ,SAAS,CAAC,EAC3CA,EAAQ,YAAY,CAAC,EAAIA,EAAQ,SAAS,CAAC,CAAA,EAE7C,IAAIgB,EAAW,CAACjhE,EAAE,YAAY,QAASA,EAAE,YAAY,OAAO,EAE5D,KAAK,SAAS,CACZ,WAAY,GACZ,UAAW,EAAA,CACZ,EAED,KAAM,CAAE,UAAAkhE,EAAW,cAAerjE,CAAA,EAAWmC,EAE7CnC,EAAO,kBAAkBqjE,CAAS,EAE5B,MAAAC,EAAaC,GAAgC,CAGjD,GAAI,UAAWA,GACT,GAAA,CAAEA,EAAU,MAAgB,CAEtBC,IACR,MACF,UACS,CAAGD,EAAkB,QAAkB,CAExCC,IACR,MACF,CAEA,MAAMC,EAAS,CAACF,EAAU,QAASA,EAAU,OAAO,EAC9CG,EAAW,CAACD,EAAO,CAAC,EAAIL,EAAS,CAAC,EAAGK,EAAO,CAAC,EAAIL,EAAS,CAAC,CAAC,EAG9D,GAFOA,EAAAK,EAEP,KAAK,QAAQ,QAAS,CAClB,MAAAV,EAAU,KAAK,QAAQ,QAAQ,WAAaW,EAAS,CAAC,EAAIP,EAAY,CAAC,EAExE,KAAA,QAAQ,QAAQ,WAAa,KAAK,IACrCJ,EACAX,EAAQ,YAAY,CAAC,CAAA,EAGvB,KAAK,SAAS,CACZ,IAAK,CACH,KAAK,QAAQ,QAAQ,WACrB,KAAK,QAAQ,QAAQ,SACvB,CAAA,CACD,CACH,CAGImB,EAAU,iBAAmBA,EAAU,gBAAgB,EACvDA,EAAU,gBAAkBA,EAAU,eAAe,EACzDA,EAAU,aAAe,GACzBA,EAAU,YAAc,GAItB,KAAK,MAAM,UACRpD,GACAgC,GACA,KAAK,QAAQ,SAEhB,KAAK,MAAM,SACT,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChEC,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,EAGIqB,EAAU,IAAY,CACjB,SAAA,oBAAoB,YAAaF,CAAS,EAC1C,SAAA,oBAAoB,UAAWE,CAAO,EACxCxjE,EAAA,oBAAoB,UAAWwjE,CAAO,EAC7CxjE,EAAO,sBAAsBqjE,CAAS,EAEtC,KAAK,SAAS,CACZ,WAAY,EAAA,CACb,CAAA,EAGM,SAAA,iBAAiB,YAAaC,CAAS,EACvC,SAAA,iBAAiB,UAAWE,CAAO,EACrCxjE,EAAA,iBAAiB,UAAWwjE,CAAO,CAAA,GAG5C1D,EAAA,6BAAyB39D,GAAgD,CACvE,KAAM,CAAE,OAAAg+D,EAAQ,cAAAgC,GAAkB,KAAK,MAGjCC,EAAU,KAAK,mBAGfe,EAAc,CAClBf,EAAQ,YAAY,CAAC,EAAIA,EAAQ,SAAS,CAAC,EAC3CA,EAAQ,YAAY,CAAC,EAAIA,EAAQ,SAAS,CAAC,CAAA,EAE7C,IAAIgB,EAAW,CAACjhE,EAAE,YAAY,QAASA,EAAE,YAAY,OAAO,EAE5D,KAAK,SAAS,CACZ,WAAY,GACZ,UAAW,EAAA,CACZ,EAED,KAAM,CAAE,UAAAkhE,EAAW,cAAerjE,CAAA,EAAWmC,EAC7CnC,EAAO,kBAAkBqjE,CAAS,EAE5B,MAAAC,EAAaC,GAAgC,CAGjD,GAAI,UAAWA,GACT,GAAA,CAAEA,EAAU,MAAgB,CAEtBC,IACR,MACF,UACS,CAAGD,EAAkB,QAAkB,CAExCC,IACR,MACF,CAEA,MAAMC,EAAS,CAACF,EAAU,QAASA,EAAU,OAAO,EAC9CG,EAAW,CAACD,EAAO,CAAC,EAAIL,EAAS,CAAC,EAAGK,EAAO,CAAC,EAAIL,EAAS,CAAC,CAAC,EAG9D,GAFOA,EAAAK,EAEP,KAAK,QAAQ,QAAS,CAClB,MAAAT,EAAS,KAAK,QAAQ,QAAQ,UAAYU,EAAS,CAAC,EAAIP,EAAY,CAAC,EAEtE,KAAA,QAAQ,QAAQ,UAAY,KAAK,IACpCH,EACAZ,EAAQ,YAAY,CAAC,CAAA,EAGvB,KAAK,SAAS,CACZ,IAAK,CACH,KAAK,QAAQ,QAAQ,WACrB,KAAK,QAAQ,QAAQ,SACvB,CAAA,CACD,CACH,CAGImB,EAAU,iBAAmBA,EAAU,gBAAgB,EACvDA,EAAU,gBAAkBA,EAAU,eAAe,EACzDA,EAAU,aAAe,GACzBA,EAAU,YAAc,GAItB,KAAK,MAAM,UACRpD,GACAgC,GACA,KAAK,QAAQ,SAEhB,KAAK,MAAM,SACT,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChEC,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,EAGIqB,EAAU,IAAY,CACjB,SAAA,oBAAoB,YAAaF,CAAS,EAC1C,SAAA,oBAAoB,UAAWE,CAAO,EACxCxjE,EAAA,oBAAoB,UAAWwjE,CAAO,EAC7CxjE,EAAO,sBAAsBqjE,CAAS,EAEtC,KAAK,SAAS,CACZ,WAAY,EAAA,CACb,CAAA,EAGM,SAAA,iBAAiB,YAAaC,CAAS,EACvC,SAAA,iBAAiB,UAAWE,CAAO,EACrCxjE,EAAA,iBAAiB,UAAWwjE,CAAO,CAAA,GAxxB5C,wBAAwBG,EAA0C,CAC1D,KAAA,CAAE,SAAApsD,CAAS,EAAI,KAAK,MAEtB,OAAC,KAAK,qBACH,KAAA,gBAAkBosD,EAAU,WAAapsD,GAGhD,KAAK,mBAAqB,GACnB,IACT,CAuCA,mBAA0B,CACxB,KAAK,mBAAmB,EACjB,OAAA,iBAAiB,SAAU,KAAK,YAAY,EAGnD,WAAW,IAAM,KAAK,mBAAmB,EAAG,EAAE,EAI1C,KAAK,UAAU,UACjB,KAAK,UAAU,QAAQ,iBAAiB,QAAS,KAAK,YAAa,CACjE,QAAS,EAAA,CACV,EAED,KAAK,UAAU,QAAQ,iBACrB,YACA,KAAK,gBACL,CACE,QAAS,EACX,CAAA,EAGF,KAAK,UAAU,QAAQ,iBACrB,aACA,KAAK,gBAAA,EAGP,KAAK,UAAU,QAAQ,iBAAiB,WAAY,KAAK,cAAc,GAGzE,KAAK,kBAAkB,CACzB,CAEA,oBAA2B,OACzB,KAAM,CAAE,OAAA4oD,EAAQ,cAAAgC,GAAkB,KAAK,MACjC,CAAE,SAAAyB,EAAU,mBAAAC,EAAoB,aAAAC,CAAA,EAAiB,KAAK,MAE5D,IACG,CAAC3D,GAAU,KAAK,kBACd,KAAK,QAAQ,SACb,KAAK,QAAQ,SACb,KAAK,UAAU,QAClB,CACA,KAAK,gBAAkB,GACvB,KAAK,mBAAqB,GAC1B,MAAM4D,EAAY,KAAK,UAAU,QAAQ,sBAAsB,EACzDC,EAAmB,KAAK,QAAQ,QAAQ,sBAAsB,EAEpE,GAAIJ,EAAU,CACN,MAAAxB,EAAU,KAAK,mBAErBwB,EACE,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChExB,EAAQ,YACR2B,EACAC,CAAA,CAEJ,CAEA,KAAK,SAAS,CACZ,OAAQD,EACR,cAAeC,CAAA,CAChB,CACH,CAGA,GACE7D,GACGgC,GACA,KAAK,QAAQ,SACb,KAAK,UAAU,QAClB,CACA,MAAM8B,EAAiB,KAAK,UAAU,QAAQ,sBAAsB,EAC9DC,EAAe,KAAK,QAAQ,QAAQ,sBAAsB,GAG9DD,EAAe,QAAU9D,EAAO,OAC7B8D,EAAe,SAAW9D,EAAO,QACjC+D,EAAa,QAAU/B,EAAc,OACrC+B,EAAa,SAAW/B,EAAc,SAEzC,KAAK,SAAS,CACZ,OAAQ8B,EACR,cAAeC,CAAA,CAChB,CAEL,CAGM,KAAA,CAAE,aAAAC,CAAa,EAAI,KAAK,MAY5B,GATAA,IAAiB,QACd,OAAO,MAAMA,EAAa,CAAC,CAAC,GAC5B,OAAO,MAAMA,EAAa,CAAC,CAAC,IAE/BA,EAAa,CAAC,EAAI,EAClBA,EAAa,CAAC,EAAI,GAIlBhE,GACGgC,GACA,KAAK,QAAQ,SACb,KAAK,UAAU,SACf,KAAK,iBAAmBgC,EAC3B,CACA,MAAMJ,EAAY,KAAK,UAAU,QAAQ,sBAAsB,EACzDC,GAAmBlF,EAAA,KAAK,QAAQ,UAAb,YAAAA,EAAsB,wBAE/C,KAAK,eAAiBqF,GAAgB,CAAC,EAAG,CAAC,EAC3C,MAAM5B,EAAW,KAAK,eACtB,IAAID,EAA+B,CACjC,KAAK,QAAQ,QAAQ,WACrB,KAAK,QAAQ,QAAQ,SAAA,EA2BvB,GAvBIuB,IAAuB,IACzBvB,EAAa,KAAK,eAElB,KAAK,QAAQ,QAAQ,WAAaA,EAAW,CAAC,EAC9C,KAAK,QAAQ,QAAQ,UAAYA,EAAW,CAAC,GAG/C,KAAK,SAAS,CACZ,IAAKA,EACL,OAAQyB,EACR,cAAeC,EACf,UAAW,EAAA,CACZ,EAEM,OAAA,qBAAqB,KAAK,eAAe,EAE5CH,IAAuB,IACzB,KAAK,gBAAkB,sBACrB,KAAK,kBAAkBvB,EAAYC,CAAQ,CAAA,GAM7CqB,GACGG,GACAC,GACA,KAAK,UAAU,QAClB,CACA,MAAM5B,EAAU,KAAK,iBAAiB2B,EAAWC,CAAgB,EACjEJ,EACE,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChExB,EAAQ,YACR2B,EACAC,CAAA,CAEJ,CAAA,SAEA7D,GACGgC,GACA,KAAK,QAAQ,SACb,KAAK,sBAAwB2B,GAC7BF,EACH,CACA,KAAK,oBAAsBE,EACrB,MAAA1B,EAAU,KAAK,mBACrBwB,EACE,CAAC,KAAK,QAAQ,QAAQ,WAAY,KAAK,QAAQ,QAAQ,SAAS,EAChExB,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,CAEA,KAAK,kBAAkB,CACzB,CAEA,sBAA6B,CACpB,OAAA,oBAAoB,SAAU,KAAK,YAAY,EAElD,KAAK,UAAU,UACjB,KAAK,UAAU,QAAQ,oBAAoB,QAAS,KAAK,WAAW,EACpE,KAAK,UAAU,QAAQ,oBACrB,YACA,KAAK,eAAA,EAEP,KAAK,UAAU,QAAQ,oBACrB,aACA,KAAK,gBAAA,EAEP,KAAK,UAAU,QAAQ,oBACrB,WACA,KAAK,cAAA,EAGX,CAkFQ,iBACNiC,EACAC,EAMA,CACA,GAAI,CAAE,OAAAlE,EAAQ,cAAAgC,GAAkB,KAAK,MACrChC,EAASiE,GAAejE,EACxBgC,EAAgBkC,GAAsBlC,EAEhC,MAAAmC,EAA6B,CAAC,EAAG,CAAC,EAClCC,EAA6B,CAAC,EAAG,CAAC,EAClCC,EAA6B,CAAC,EAAG,CAAC,EAClCC,EAAgC,CAAC,EAAG,CAAC,EAE3C,OAAItE,GAAUgC,IACZoC,EAAS,CAAC,EAAIpE,EAAO,MAAQgC,EAAc,MAC3CmC,EAAS,CAAC,EAAIC,EAAS,CAAC,EAAIpE,EAAO,MACnCmE,EAAS,CAAC,EAAI,KAAK,IAAIA,EAAS,CAAC,EAAG,EAAE,EAC7BA,EAAA,CAAC,EAAI,KAAK,IAAIA,EAAS,CAAC,EAAGnE,EAAO,KAAK,GAG9CoE,EAAS,CAAC,EAAI,GAAKpE,GAAUgC,IAC/BqC,EAAS,CAAC,EAAIrE,EAAO,MAAQmE,EAAS,CAAC,EACvCG,EAAY,CAAC,EAAItC,EAAc,MAAQhC,EAAO,OAG5CA,GAAUgC,IACZoC,EAAS,CAAC,EAAIpE,EAAO,OAASgC,EAAc,OAC5CmC,EAAS,CAAC,EAAIC,EAAS,CAAC,EAAIpE,EAAO,OACnCmE,EAAS,CAAC,EAAI,KAAK,IAAIA,EAAS,CAAC,EAAG,EAAE,EAC7BA,EAAA,CAAC,EAAI,KAAK,IAAIA,EAAS,CAAC,EAAGnE,EAAO,MAAM,GAG/CoE,EAAS,CAAC,EAAI,GAAKpE,GAAUgC,IAC/BqC,EAAS,CAAC,EAAIrE,EAAO,OAASmE,EAAS,CAAC,EACxCG,EAAY,CAAC,EAAItC,EAAc,OAAShC,EAAO,QAGrC,CACV,SAAAmE,EACA,SAAAC,EACA,SAAAC,EACA,YAAAC,CAAA,CAIJ,CAsaA,QAAsB,eACpB,KAAM,CAAE,OAAA5B,EAAQ,WAAA6B,EAAY,OAAAvE,EAAQ,IAAAzyC,EAAK,YAAAi3C,GAAgB,KAAK,MAExD,CACJ,UAAA7xD,EACA,iBAAA8xD,EACA,eAAAvE,EACA,aAAAwE,EACA,SAAAttD,EACA,aAAAusD,EACA,iBAAAgB,EACA,KAAAC,EAAO9C,GAAiB,IAAA,EACtB,KAAK,MAEH+C,EAAS,GACbjG,GAAAD,EAAA,KAAK,UAAL,YAAAA,EAAc,UAAd,YAAAC,EAAuB,aAAc,IACrCC,GAAAC,EAAA,KAAK,UAAL,YAAAA,EAAc,UAAd,YAAAD,EAAuB,YAAa,CAAA,EAEhCoD,EAAU,KAAK,mBACd4C,EAAA,CAAC,EAAKt3C,EAAI,CAAC,EAAI00C,EAAQ,YAAY,CAAC,EAAKA,EAAQ,SAAS,CAAC,EAC3D4C,EAAA,CAAC,EAAKt3C,EAAI,CAAC,EAAI00C,EAAQ,YAAY,CAAC,EAAKA,EAAQ,SAAS,CAAC,EAE9D,OAAO,MAAM4C,EAAO,CAAC,CAAC,IAAKA,EAAO,CAAC,EAAI,GACvC,OAAO,MAAMA,EAAO,CAAC,CAAC,IAAKA,EAAO,CAAC,EAAI,GAE3C,MAAMC,EAAW,CACf,CACE,KAAMD,EAAO,CAAC,EACd,MAAOzF,GACHsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAS,CAAC,EAAI,GACrBsC,GAActC,EAAQ,SAAS,CAAC,EAAI,EAC1CA,EAAQ,SAAS,CAAC,EAClB,CACF,EACA,QAAS7C,GACLsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAS,CAAC,EAAI,GACrBsC,GAActC,EAAQ,SAAS,CAAC,EAAI,EAC1C,EACA,CACF,EACA,OAAQ,KACV,EAEA,CACE,IAAK4C,EAAO,CAAC,EACb,OAAQzF,GACJsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAS,CAAC,EAAI,GACrBsC,GAActC,EAAQ,SAAS,CAAC,EAAI,EAC1CA,EAAQ,SAAS,CAAC,EAClB,CACF,EACA,QAAS7C,GACLsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAS,CAAC,EAAI,GACrBsC,GAActC,EAAQ,SAAS,CAAC,EAAI,EAC1C,EACA,CACF,EACA,MAAO,KACT,CAAA,EAGF,OAEE/N,EAAA,KAAC,MAAA,CACC,UAAWyC,GAAW,eAAgBiO,EAAMjyD,CAAS,EACpD,GAAGutD,EACJ,IAAK,KAAK,UACV,MAAOA,GAAA,YAAAA,EAAgB,MACvB,YAAa,IAAM,CACjB,KAAK,SAAS,CAAE,IAAA3yC,EAAK,OAAQ,EAAM,CAAA,EACnC,KAAK,YAAY,CACnB,EACA,aAAevrB,GAAM,CACnB,MAAMwO,EAAQxO,EAAE,YACZ,IAAAsN,EAAwBkB,EAAc,WAAaA,EAAM,cAE7D,KAAOlB,GAAM,CAET,GAAAA,EAAK,aAAe,KAAK,UAAU,SAChCA,IAAS,KAAK,UAAU,QAE3B,OAGFA,EAAOA,EAAK,aACd,CAEA,KAAK,SAAS,CAAE,IAAAie,EAAK,OAAQ,EAAO,CAAA,CACtC,EAEA,SAAA,CAAA4J,EAAA,IAAC,MAAA,CACC,IAAK,KAAK,QACV,UAAWw/B,GAAW,wBAAyB8N,CAAgB,EAC/D,MAAO,CAAC,EACP,GAAGC,EAEJ,SAAAvtC,EAAA,IAAC,MAAA,CACC,IAAK,KAAK,QACV,UAAU,wBACV,MAAO,CACL,SAAU,KAAK,IACbqtC,GAAe,IACfxF,EAAA,KAAK,QAAQ,UAAb,YAAAA,EAAsB,wBAAwB,QAAS,CACzD,EACA,OAAQ2E,EACR,KAAM,OAAOA,CAAY,KACzB,UAAWA,CACb,EAEC,SAAAvsD,CAAA,CACH,CAAA,CACF,EACA+f,EAAA,IAAC,MAAA,CACC,UAAWw/B,GACT,oBACA,0BACF,EACA,MAAOmO,EAAS,CAAC,EACjB,cAAe,KAAK,uBAAA,CACtB,EACA3tC,EAAA,IAAC,MAAA,CACC,UAAWw/B,GAAW,mBAAmB,EACzC,MAAOmO,EAAS,CAAC,EACjB,cAAe,KAAK,qBAAA,CACtB,CAAA,CAAA,CACF,CAEJ,CACF,aCniCM,CAAE,IAAA5jD,GAAK,IAAAC,EAAQ,EAAA,KAErB,SAASM,GAAM3e,EAAW4+D,EAAgBC,EAAwB,CAChE,OAAOzgD,GAAIC,GAAIre,EAAG4+D,CAAM,EAAGC,CAAM,CACnC,CAEA,SAASC,GAAelgD,EAAeC,EAAahf,EAAmB,CACjEA,EAAA8e,GAAM9e,EAAG,EAAG,CAAC,EACjB,MAAMk/D,EAAOl/D,EAAI,GAAM,EAAIA,EAAIA,EAAIA,GAAKA,EAAI,IAAM,EAAIA,EAAI,IAAM,EAAIA,EAAI,GAAK,EACrE,OAAAgf,EAAMD,GAASmgD,EAAOngD,CAChC,CAOO,MAAMqjD,GAAiB,CAC5B,MAAO,oBACP,KAAM,kBACR,EAyFa,MAAAC,WAAmBvkE,EAAM,SAA+B,CAAxD,kCACXk/D,EAAA,aAAgB,CACd,OAAQ,GACR,WAAY,GACZ,IAAK,CAAA,GAGPA,EAAA,iBAAYl/D,EAAM,aAClBk/D,EAAA,oBAAel/D,EAAM,aACbk/D,EAAA,eAAUl/D,EAAM,aAChBk/D,EAAA,uBACAA,EAAA,4BACAA,EAAA,mBAAc,IACdA,EAAA,uBAAkB,IAClBA,EAAA,0BAAqB,IACrBA,EAAA,uBAAkB,IAClBA,EAAA,aAAQ,CACd,GAAI,EACJ,EAAG,EACH,QAAS,EACT,UAAW,EAAA,GAebA,EAAA,YAAO,IAAY,CACX,KAAA,CAAE,WAAAsF,CAAW,EAAI,KAAK,MACtB,CAAE,OAAAjF,EAAQ,cAAAgC,GAAkB,KAAK,MAIvC,GAAIiD,GAEA,GAAA,EAACjF,GAAA,MAAAA,EAAQ,QACN,EAACgC,GAAA,MAAAA,EAAe,QAChBhC,EAAO,OAASgC,EAAc,MAEjC,eAGF,EAAChC,GAAA,MAAAA,EAAQ,SACJ,EAACgC,GAAA,MAAAA,EAAe,SAChBhC,EAAO,QAAUgC,EAAc,OAEpC,OAGF,GACE,CAAC,KAAK,aACHhC,GACAgC,GACA,KAAK,UAAU,UAElB,KAAK,YAAc,GAEf,KAAK,MAAM,UAAU,CACjB,MAAAC,EAAU,KAAK,mBACrB,KAAK,MAAM,SACTgD,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,CACF,GAkMMrC,EAAA,yBAAoB,CAACwC,EAAoBC,IAA0C,CACzF,IAAI1gD,EAAQ,EACN,MAAA8wC,EAAW,KAAK,MAAM,oBAAsB,IAE5C6P,EAAa1/D,GAAoB,OAEjC,GADA,CAAC,KAAK,UAAU,SAChB,CAAC,KAAK,QAAQ,QAAW,OACvB,KAAA,CAAE,WAAAsiE,CAAW,EAAI,KAAK,MAEtBjF,EAAS,KAAK,UAAU,QAAQ,sBAAsB,EACtDgC,GAAgBrD,EAAA,KAAK,QAAQ,UAAb,YAAAA,EAAsB,wBACtCsD,EAAU,KAAK,iBAAiBjC,EAAQgC,CAAa,EAEvD,GAAA,CAAC,KAAK,UAAU,QAAW,OAC1BtgD,IAAiBA,EAAA/e,GAChB,MAAAk/D,GAAQl/D,EAAI+e,GAAS8wC,EACrB7kC,EAASi0C,GAAeO,EAAYC,EAAUP,CAAI,EAEpDoD,EACG,KAAA,UAAU,QAAQ,WAAa,KAAK,IACvC,KAAK,IAAIt3C,GAAU,EAAGs0C,EAAQ,WAAW,EACzC,CAAA,EAGG,KAAA,UAAU,QAAQ,UAAY,KAAK,IACtC,KAAK,IAAIt0C,GAAU,EAAGs0C,EAAQ,WAAW,EACzC,CAAA,EAIC,KAAA,kBACHgD,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,SAAA,EAG7B,KAAK,SAAS,CACZ,IAAKA,EACD,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3B,OAAAjF,EACA,cAAAgC,CAAA,CACD,EAGC,KAAK,MAAM,UACRhC,GACAgC,GACA,KAAK,UAAU,SAElB,KAAK,MAAM,SACTiD,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACRjC,EACAgC,EACA,EAAA,EAIA,KAAK,MAAM,WAAaH,EAAO,IAC5B,KAAA,gBAAkB,sBAAsBQ,CAAS,EACxD,EAGK,OAAAA,CAAA,GA6FT1C,EAAA,oBAAe,IAAY,CACzB,KAAK,SAAS,CACZ,OAAQ,OACR,cAAe,MAAA,CAChB,CAAA,GAGHA,EAAA,wBAAoB39D,GAAwB,CAC1C,IAAIsgE,EAAsB,KAEjB,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,QAAQ,OAAQlC,EAAIyiE,IACnCD,EAAAtgE,EAAE,QAAQ,KAAKlC,CAAC,EACpB,CAAAwiE,GAF6C,EAAExiE,EAEnD,CAKEwiE,IACG,KAAA,MAAM,EAAIA,EAAM,MAChB,KAAA,MAAM,GAAKA,EAAM,YAGnB,KAAA,SAAUzsC,IAAe,CAAE,IAAKA,EAAU,IAAK,OAAQ,GAAM,UAAW,EAAA,EAAQ,EAChE,qBAAA,KAAK,MAAM,SAAS,EACzC,KAAK,MAAM,UAAY,EAAA,GAGzB8pC,EAAA,sBAAkB39D,GAAwB,CAClC,KAAA,CAAE,WAAAijE,CAAW,EAAI,KAAK,MAE5B,IAAI3C,EAAsB,KACjB,QAAA,EAAI,EAAGC,EAAOvgE,EAAE,QAAQ,OAAQ,EAAIugE,EAAM,EAAE,EAEnD,GADQD,EAAAtgE,EAAE,QAAQ,KAAK,CAAC,EACpBsgE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,CAGF,GAAI,CAACA,GACM,QAAA,EAAI,EAAGC,EAAOvgE,EAAE,cAAc,OAAQ,EAAIugE,EAAM,EAAE,EAEzD,GADQD,EAAAtgE,EAAE,cAAc,KAAK,CAAC,EAC1BsgE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,EAIJ,GAAI,CAACA,GACM,QAAA,EAAI,EAAGC,EAAOvgE,EAAE,eAAe,OAAQ,EAAIugE,EAAM,EAAE,EAE1D,GADQD,EAAAtgE,EAAE,eAAe,KAAK,CAAC,EAC3BsgE,EAAO,CACT,GAAIA,EAAM,aAAe,KAAK,MAAM,GAAM,MAClCA,EAAA,IACV,EAIJ,GAAKA,IACA,KAAA,SAAUzsC,IAAe,CAAE,IAAKA,EAAU,IAAK,OAAQ,EAAQ,EAAA,EAEhE,KAAK,IAAI,KAAK,MAAM,OAAO,EAAI,GAAK,KAAK,UAAU,SAAS,CAC9D,KAAM,CAAE,OAAAmqC,EAAQ,cAAAgC,GAAkB,KAAK,MACjC,CAAE,QAAAQ,CAAQ,EAAI,KAAK,UACJ,qBAAA,KAAK,MAAM,SAAS,EAEzC,MAAMC,EAAiB,IAAY,CAC7BwC,EAAsBzC,EAAA,YAAc,KAAK,MAAM,QAA0BA,EAAA,WAAa,KAAK,MAAM,QAC/F,MAAAP,EAAU,KAAK,mBACjBgD,EACFzC,EAAQ,WAAa,KAAK,IACxBA,EAAQ,WACRP,EAAQ,WAAA,EAGVO,EAAQ,UAAY,KAAK,IAAIA,EAAQ,UAAWP,EAAQ,WAAW,EAGhE,KAAA,kBACHgD,EAAazC,EAAQ,WAAaA,EAAQ,SAAA,EAG5C,KAAK,SAAS,CACZ,IAAKyC,EAAazC,EAAQ,WAAaA,EAAQ,SAAA,CAChD,EAEG,KAAK,MAAM,UAAYxC,GAAUgC,GACnC,KAAK,MAAM,SACTiD,EAAazC,EAAQ,WAAaA,EAAQ,UAC1CP,EAAQ,YACRjC,EACAgC,CAAA,EAIJ,KAAK,MAAM,SAAW,IAClB,KAAK,IAAI,KAAK,MAAM,OAAO,EAAI,KACjC,sBAAsBS,CAAc,EAC7B,KAAK,MAAM,UAAY,EAAI,EAGjC,KAAA,MAAM,UAAY,sBAAsBA,CAAc,CAC7D,CAAA,GAGF9C,EAAA,uBAAmB39D,GAAwB,CACrC,GAAA,EAAEA,EAAE,yBAAyB,gBAAmB,OAE9C,KAAA,CAAE,WAAAijE,CAAW,EAAI,KAAK,MACtB,CAAE,OAAAjF,EAAQ,cAAAgC,EAAe,OAAAU,CAAA,EAAW,KAAK,MAE/C,IAAIJ,EAAsB,KACjB,QAAAxiE,EAAI,EAAGyiE,EAAOvgE,EAAE,QAAQ,OAAQlC,EAAIyiE,IACnCD,EAAAtgE,EAAE,QAAQ,KAAKlC,CAAC,EACpB,EAAAwiE,GACEA,EAAM,aAAe,KAAK,MAAM,KAHW,EAAExiE,EAEnD,CAKF,GAAI,CAACwiE,EAAS,OAEV2C,EACFjjE,EAAE,cAAc,YAAc,KAAK,MAAM,EAAIsgE,EAAM,MAEnDtgE,EAAE,cAAc,WAAa,KAAK,MAAM,EAAIsgE,EAAM,MAGpD,KAAK,MAAM,QAAU,KAAK,MAAM,EAAIA,EAAM,MACrC,KAAK,MAAM,oBAAqB,KAAK,MAAM,QAAU,GAC1D,KAAK,MAAM,EAAI2C,EAAa3C,EAAM,MAAQA,EAAM,MAC1C,MAAAL,EAAU,KAAK,mBAEjBgD,EACAjjE,EAAA,cAAc,WAAa,KAAK,IAChCA,EAAE,cAAc,WAChBigE,EAAQ,WAAA,EAGRjgE,EAAA,cAAc,UAAY,KAAK,IAC/BA,EAAE,cAAc,UAChBigE,EAAQ,WAAA,EAIP,KAAA,kBACHgD,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,SAAA,EAG5D,KAAK,SAAS,CACZ,IAAKijE,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,UAC/D,UAAW,EAAA,CACZ,EAEG,KAAK,MAAM,UAAYg+D,GAAUgC,GACnC,KAAK,MAAM,SACTiD,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,UAC1DigE,EAAQ,YACRjC,EACAgC,CAAA,EAIAU,GAAU1C,GAAUiC,EAAQ,SAAW,GACzCxD,GAAgBz8D,CAAC,EAGE,qBAAA,KAAK,MAAM,SAAS,CAAA,GAG3C29D,EAAA,mBAAe39D,GAAwB,CAEjC,GADA,EAAEA,EAAE,yBAAyB,iBAC7B,KAAK,MAAM,aAAgB,OAEzB,KAAA,CAAE,WAAAijE,CAAW,EAAI,KAAK,MACtB,CAAE,OAAAjF,EAAQ,cAAAgC,EAAe,OAAAU,CAAA,EAAW,KAAK,MACzCC,EAAQ5E,GAAe/7D,CAAC,EAE9B,GAAIijE,EAAY,CAGV,GAAA,KAAK,MAAM,qBACT,KAAK,IAAItC,EAAM,MAAM,EAAI,KAAK,IAAIA,EAAM,MAAM,EAAK,OAGvD3gE,EAAA,cAAc,YAAc2gE,EAAM,OAClC3gE,EAAA,cAAc,YAAc2gE,EAAM,MAAA,MAC3B3gE,EAAA,cAAc,WAAa2gE,EAAM,OAEtC,MAAAV,EAAU,KAAK,mBAEjBgD,EACAjjE,EAAA,cAAc,WAAa,KAAK,IAChCA,EAAE,cAAc,WAChBigE,EAAQ,WAAA,EAGRjgE,EAAA,cAAc,UAAY,KAAK,IAC/BA,EAAE,cAAc,UAChBigE,EAAQ,WAAA,EAIP,KAAA,kBACHgD,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,SAAA,EAG5D,KAAK,SAAS,CACZ,IAAKijE,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,UAC/D,UAAW,EAAA,CACZ,EAEG,KAAK,MAAM,UAAYg+D,GAAUgC,GACnC,KAAK,MAAM,SACTiD,EAAajjE,EAAE,cAAc,WAAaA,EAAE,cAAc,UAC1DigE,EAAQ,YACRjC,EACAgC,CAAA,EAIAU,GAAU1C,GAAUiC,EAAQ,SAAW,IACrC,KAAK,MAAM,uBAEX,KAAK,MAAMjgE,EAAE,cAAc,SAAS,EAChC,KAAK,MAAMigE,EAAQ,WAAW,GAC/B,KAAK,MAAMjgE,EAAE,cAAc,SAAS,EAAI,GAE3Cy8D,GAAgBz8D,CAAC,EAGnBy8D,GAAgBz8D,CAAC,EAErB,GAGF29D,EAAA,qBAAiB39D,GAAgD,CACzD,KAAA,CAAE,WAAAijE,CAAW,EAAI,KAAK,MACtB,CAAE,OAAAjF,EAAQ,cAAAgC,GAAkB,KAAK,MAGjCC,EAAU,KAAK,mBAGfe,EAAcf,EAAQ,YAAcA,EAAQ,SAClD,IAAIiD,EAASD,EAAajjE,EAAE,YAAY,QAAUA,EAAE,YAAY,QAEhE,KAAK,SAAS,CACZ,WAAY,GACZ,UAAW,EAAA,CACZ,EAED,KAAM,CAAE,UAAAkhE,EAAW,cAAerjE,CAAA,EAAWmC,EAC7CnC,EAAO,kBAAkBqjE,CAAS,EAE5B,MAAAC,EAAaC,GAAgC,CAGjD,GAAI,UAAWA,GACT,GAAA,CAAEA,EAAU,MAAgB,CAEtBC,IACR,MACF,UACS,EAAGD,GAAA,MAAAA,EAAmB,SAAkB,CAEzCC,IACR,MACF,CAEA,MAAM8B,EAAOF,EAAa7B,EAAU,QAAUA,EAAU,QAClDgC,EAASD,EAAOD,EACbA,EAAAC,EAEL,KAAK,UAAU,UACbF,EACG,KAAA,UAAU,QAAQ,YAAcG,EAASpC,EAClC,KAAA,UAAU,QAAQ,WAAaoC,EAASpC,EAElDiC,EACG,KAAA,UAAU,QAAQ,WAAa,KAAK,IACvC,KAAK,UAAU,QAAQ,WACvBhD,EAAQ,WAAA,EAGL,KAAA,UAAU,QAAQ,UAAY,KAAK,IACtC,KAAK,UAAU,QAAQ,UACvBA,EAAQ,WAAA,EAIP,KAAA,kBACHgD,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,SAAA,EAG7B,KAAK,SAAS,CACZ,IAAKA,EACD,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,SAAA,CAC5B,GAIC7B,EAAU,iBAAmBA,EAAU,gBAAgB,EACvDA,EAAU,gBAAkBA,EAAU,eAAe,EACzDA,EAAU,aAAe,GACzBA,EAAU,YAAc,GAItB,KAAK,MAAM,UACRpD,GACAgC,GACA,KAAK,UAAU,SAElB,KAAK,MAAM,SACTiD,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,EAGIqB,EAAU,IAAY,CACjB,SAAA,oBAAoB,YAAaF,CAAS,EAC1C,SAAA,oBAAoB,UAAWE,CAAO,EACxCxjE,EAAA,oBAAoB,UAAWwjE,CAAO,EAC7CxjE,EAAO,sBAAsBqjE,CAAS,EAEtC,KAAK,SAAS,CACZ,WAAY,EAAA,CACb,CAAA,EAGM,SAAA,iBAAiB,YAAaC,CAAS,EACvC,SAAA,iBAAiB,UAAWE,CAAO,EACrCxjE,EAAA,iBAAiB,UAAWwjE,CAAO,CAAA,GA3uB5C,wBAAwBG,EAAwC,CACxD,KAAA,CAAE,SAAApsD,CAAS,EAAI,KAAK,MAEtB,OAAC,KAAK,qBACH,KAAA,gBAAkBosD,EAAU,WAAapsD,GAGhD,KAAK,mBAAqB,GACnB,IACT,CA+CA,mBAA0B,CACxB,KAAK,mBAAmB,EACjB,OAAA,iBAAiB,SAAU,KAAK,YAAY,EAGnD,WAAW,IAAM,KAAK,mBAAmB,EAAG,EAAE,EAI1C,KAAK,UAAU,UACjB,KAAK,UAAU,QAAQ,iBAAiB,QAAS,KAAK,YAAa,CACjE,QAAS,EAAA,CACV,EAED,KAAK,UAAU,QAAQ,iBACrB,YACA,KAAK,gBACL,CACE,QAAS,EACX,CAAA,EAGF,KAAK,UAAU,QAAQ,iBACrB,aACA,KAAK,gBAAA,EAGP,KAAK,UAAU,QAAQ,iBAAiB,WAAY,KAAK,cAAc,EAE3E,CAEA,oBAA2B,OACzB,KAAM,CAAE,WAAA6tD,EAAY,SAAAxB,EAAU,mBAAAC,EAAoB,aAAAC,GAAiB,KAAK,MAClE,CAAE,OAAA3D,EAAQ,cAAAgC,GAAkB,KAAK,MAGpC,IAAA,CAAChC,GAAU,KAAK,kBACd,KAAK,QAAQ,SACb,KAAK,UAAU,QAClB,CACA,KAAK,gBAAkB,GACvB,KAAK,mBAAqB,GAC1B,MAAM4D,EAAY,KAAK,UAAU,QAAQ,sBAAsB,EACzDC,EAAmB,KAAK,QAAQ,QAAQ,sBAAsB,EAEpE,GAAIJ,EAAU,CACN,MAAAxB,EAAU,KAAK,mBAErBwB,EACEwB,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACR2B,EACAC,CAAA,CAEJ,CAEA,KAAK,SAAS,CACZ,OAAQD,EACR,cAAeC,CAAA,CAChB,CACH,CAGA,GACE7D,GACGgC,GACA,KAAK,QAAQ,SACb,KAAK,UAAU,QAClB,CACA,MAAM8B,EAAiB,KAAK,UAAU,QAAQ,sBAAsB,EAC9DC,EAAe,KAAK,QAAQ,QAAQ,sBAAsB,GAG9DD,EAAe,QAAU9D,EAAO,OAC7B8D,EAAe,SAAW9D,EAAO,QACjC+D,EAAa,QAAU/B,EAAc,OACrC+B,EAAa,SAAW/B,EAAc,SAEzC,KAAK,SAAS,CACZ,OAAQ8B,EACR,cAAeC,CAAA,CAChB,CAEL,CAGI,GAAA,CAAE,cAAAsB,CAAc,EAAI,KAAK,MAG7B,GAFIA,IAAkB,QAAU,OAAO,MAAMA,CAAa,IAAqBA,EAAA,GAG7ErF,GACGgC,GACA,KAAK,UAAU,SACf,KAAK,iBAAmBqD,EAC3B,CACA,MAAMzB,EAAY,KAAK,UAAU,QAAQ,sBAAsB,EACzDC,GAAmBlF,EAAA,KAAK,QAAQ,UAAb,YAAAA,EAAsB,wBAE/C,KAAK,eAAiB0G,GAAiB,EACvC,MAAMjD,EAAW,KAAK,eAClB,IAAAD,EAAa8C,EACb,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UA+B3B,GA5BIvB,IAAuB,IACzBvB,EAAa,KAAK,eAEd8C,EACG,KAAA,UAAU,QAAQ,WAAa9C,EAE/B,KAAA,UAAU,QAAQ,UAAYA,GAIvC,KAAK,kBAAkBA,CAAU,EAEjC,KAAK,SAAS,CACZ,IAAKA,EACL,OAAQyB,EACR,cAAeC,EACf,UAAW,EAAA,CACZ,EAEM,OAAA,qBAAqB,KAAK,eAAe,EAE5CH,IAAuB,IACzB,KAAK,gBAAkB,sBACrB,KAAK,kBAAkBvB,EAAYC,CAAQ,CAAA,GAM7CqB,GACGG,GACAC,GACA,KAAK,UAAU,QAClB,CACA,MAAM5B,EAAU,KAAK,iBAAiB2B,EAAWC,CAAgB,EACjEJ,EACEwB,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACR2B,EACAC,CAAA,CAEJ,CAAA,SAEA7D,GACGgC,GACA,KAAK,UAAU,SACf,KAAK,sBAAwB2B,GAC7BF,EACH,CACA,KAAK,oBAAsBE,EACrB,MAAA1B,EAAU,KAAK,mBACrBwB,EACEwB,EACI,KAAK,UAAU,QAAQ,WACvB,KAAK,UAAU,QAAQ,UAC3BhD,EAAQ,YACRjC,EACAgC,CAAA,CAEJ,CACF,CAEA,sBAA6B,CACpB,OAAA,oBAAoB,SAAU,KAAK,YAAY,EAElD,KAAK,UAAU,UACjB,KAAK,UAAU,QAAQ,oBAAoB,QAAS,KAAK,WAAW,EACpE,KAAK,UAAU,QAAQ,oBACrB,YACA,KAAK,eAAA,EAEP,KAAK,UAAU,QAAQ,oBACrB,aACA,KAAK,gBAAA,EAEP,KAAK,UAAU,QAAQ,oBACrB,WACA,KAAK,cAAA,EAGX,CAuEQ,iBACNiC,EACAC,EAMA,CACM,KAAA,CAAE,WAAAe,CAAW,EAAI,KAAK,MAC5B,GAAI,CAAE,OAAAjF,EAAQ,cAAAgC,GAAkB,KAAK,MACrChC,EAASiE,GAAejE,EACxBgC,EAAgBkC,GAAsBlC,EAEtC,IAAIsD,EAAY,EACZlB,EAAW,EACXC,EAAW,EACXC,EAAc,EAElB,OAAIW,GACEjF,GAAUgC,IACDoC,EAAApE,EAAO,MAAQgC,EAAc,MACxCsD,EAAYlB,EAAWpE,EAAO,MAClBsF,EAAA,KAAK,IAAIA,EAAW,EAAE,EAClCA,EAAY,KAAK,IAAIA,EAAWtF,EAAO,KAAK,GAG1CoE,EAAW,GAAKpE,GAAUgC,IAC5BqC,EAAWrE,EAAO,MAAQsF,EACZhB,EAAAtC,EAAc,MAAQhC,EAAO,SAGzCA,GAAUgC,IACDoC,EAAApE,EAAO,OAASgC,EAAc,OACzCsD,EAAYlB,EAAWpE,EAAO,OAClBsF,EAAA,KAAK,IAAIA,EAAW,EAAE,EAClCA,EAAY,KAAK,IAAIA,EAAWtF,EAAO,MAAM,GAG3CoE,EAAW,GAAKpE,GAAUgC,IAC5BqC,EAAWrE,EAAO,OAASsF,EACbhB,EAAAtC,EAAc,OAAShC,EAAO,SAIzC,CACL,UAAAsF,EACA,SAAAlB,EACA,SAAAC,EACA,YAAAC,CAAA,CAEJ,CAEA,kBAAkB/2C,EAAmB,CAC7B,MAAAg4C,EAAY,KAAK,aAAa,QACpC,GAAI,CAACA,EAAa,OAElB,KAAM,CAAE,KAAAriD,EAAO,EAAqB,WAAA+hD,CAAA,EAAe,KAAK,MAExD,IAAIJ,EAASt3C,EACP,MAAA00C,EAAU,KAAK,mBACV4C,GAAAt3C,EAAM00C,EAAQ,YAAeA,EAAQ,SAE5CgD,GACQM,EAAA,MAAM,KAAO,GAAGV,CAAM,KAChCU,EAAU,MAAM,IAAMnG,EACpBl8C,IAAS,EACT,MACAqiD,EAAU,MAAM,GAAA,EAElBA,EAAU,MAAM,OAASnG,EACvBl8C,IAAS,EACT,MACAqiD,EAAU,MAAM,MAAA,IAGRA,EAAA,MAAM,IAAM,GAAGV,CAAM,KAC/BU,EAAU,MAAM,KAAOnG,EACrBl8C,IAAS,EACT,MACAqiD,EAAU,MAAM,IAAA,EAElBA,EAAU,MAAM,MAAQnG,EACtBl8C,IAAS,EACT,MACAqiD,EAAU,MAAM,KAAA,EAGtB,CA0VA,QAAsB,CACpB,KAAM,CAAE,OAAA7C,EAAQ,WAAA6B,EAAY,OAAAvE,EAAQ,IAAAzyC,GAAQ,KAAK,MAE3C,CACJ,UAAA5a,EACA,iBAAA8xD,EACA,eAAAvE,EACA,aAAAwE,EACA,SAAAttD,EACA,aAAAusD,EACA,KAAAzgD,EAAO,EACP,WAAA+hD,EACA,iBAAAN,EACA,KAAAC,EAAOG,GAAe,IAAA,EACpB,KAAK,MAET,IAAIF,EAASt3C,EACP,MAAA00C,EAAU,KAAK,mBACV4C,GAAAt3C,EAAM00C,EAAQ,YAAeA,EAAQ,SAE5C,OAAO,MAAM4C,CAAM,IACZA,EAAA,GAGX,MAAMC,EAAW,IACXG,EACK,CACL,KAAMJ,EACN,MAAOzF,GACHsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAW,GACnBsC,EACLtC,EAAQ,UACR,CACF,EACA,QAAS7C,GACLsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACnD3E,GACAiC,EAAQ,SAAW,GACnBsC,EACL,EACA,CACF,EACA,IAAKnF,EAAKl8C,IAAS,EAAoB,KAAK,EAC5C,OAAQk8C,EAAKl8C,IAAS,EAAqB,KAAK,CAAA,EAG7C,CACL,IAAK2hD,EACL,OAAQzF,GACJsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACjD3E,GACAiC,EAAQ,SAAW,GACnBsC,EACPtC,EAAQ,UACR,CACF,EACA,QAAS7C,GACLsD,GAAUiC,GAAoB,KAAK,MAAM,WAAa,IACjD3E,GACAiC,EAAQ,SAAW,GACnBsC,EACP,EACA,CACF,EACA,KAAMnF,EAAKl8C,IAAS,EAAoB,KAAK,EAC7C,MAAOk8C,EAAKl8C,IAAS,EAAqB,KAAK,CAAA,EAInD,OAEEgxC,EAAA,KAAC,MAAA,CACC,UAAWyC,GAAW,aAAciO,EAAMjyD,CAAS,EAClD,GAAGutD,EACJ,IAAK,KAAK,UACV,MAAO,CACL,GAAGA,GAAA,YAAAA,EAAgB,MACnB,cAAe+E,EAAa,MAAQ,MACtC,EACA,YAAa,IAAM,CACjB,KAAK,SAAS,CAAE,IAAA13C,EAAK,OAAQ,EAAM,CAAA,EACnC,KAAK,YAAY,CACnB,EACA,aAAevrB,GAAM,CACnB,MAAMwO,EAAQxO,EAAE,YACZ,IAAAsN,EAAwBkB,EAAc,WAAaA,EAAM,cAE7D,KAAOlB,GAAM,CAET,GAAAA,EAAK,aAAe,KAAK,UAAU,SAChCA,IAAS,KAAK,UAAU,QAE3B,OAGFA,EAAOA,EAAK,aACd,CAEA,KAAK,SAAS,CAAE,IAAAie,EAAK,OAAQ,EAAO,CAAA,CACtC,EAEA,SAAA,CAAA4J,EAAA,IAAC,MAAA,CACC,IAAK,KAAK,QACV,UAAWw/B,GACT,sBACAyI,EAAK6F,EAAY,gCAAgC,EACjDR,CACF,EACA,MAAO,CACL,OAAQd,EACR,KAAM,OAAOA,CAAY,KACzB,UAAWA,CACb,EACC,GAAGe,EAEH,SAAAttD,CAAA,CACH,EACA+f,EAAA,IAAC,MAAA,CACC,IAAK,KAAK,aACV,UAAWw/B,GACT,kBACAsO,EAAa,yBAA2B,MAC1C,EACA,MAAOH,EAAS,EAChB,cAAe,KAAK,aAAA,CACtB,CAAA,CAAA,CACF,CAEJ,CACF,aCj6Ba,MAAAU,WAAiB/kE,EAAM,SAAqB,CA6CvD,YAAY2K,EAAkB,CAC5B,MAAMA,CAAK,EA7Cbu0D,EAAA,aAAQ,CACN,WAAY,EACZ,SAAU,CAAA,GAOZA,EAAA,iBAAYl/D,EAAM,aAMlBk/D,EAAA,cAAmB,CAAA,GAKnBA,EAAA,qBAAgB,GAEhBA,EAAA,kBAAa,IAMbA,EAAA,yBAEAA,EAAA,eAAU,IAEVA,EAAA,uBAAkB,KAElBA,EAAA,qBAAgB,KAMhBA,EAAA,yBAAoB,IAEpBA,EAAA,iBA4IAA,EAAA,oBAAe,IAAY,CACnB,KAAA,CAAE,MAAA8F,CAAM,EAAI,KAAK,MAEvB,GAAI,KAAK,kBAAmB,CAC1B,QAAS3lE,EAAI,EAAGA,EAAI2lE,EAAO,EAAE3lE,EAAU,KAAA,YAAY,IAAIA,CAAC,EACxD,KAAK,YAAY,CACnB,CAAA,GAGF6/D,EAAA,0BAAqB,CACnB+F,EACAC,EACAC,EACA5D,IACS,CACJ,KAAA,aAAa0D,EAAU,CAAC,EAAGC,EAAU,CAAC,EAAGC,EAAY5D,CAAa,CAAA,GAGzErC,EAAA,oBAAe,CACb+F,EACAC,EACAC,EACA5D,IACS,CACT,KAAM,CAAE,QAAA6D,EAAS,MAAAJ,EAAO,SAAAhC,EAAU,QAAAqC,GAAY,KAAK,MAEnD,IAAIC,EAAa,GACbC,EAAW,GAEX,GAAAtK,GAASmK,CAAO,EAGlBE,EAAa,KAAK,MAAML,EAAYG,CAAO,EAAI,EAC/CG,EAAW,KAAK,OAAON,EAAYE,EAAW,QAAUC,CAAO,EAAI,MAC9D,CACQE,EAAA,EACFC,EAAA,EACX,IAAIC,EAAQ,EACRC,EAAa,GACX,MAAA9K,EAASsK,EAAYE,EAAW,OAEtC,KAAOK,EAAQP,GAAa,EAAEQ,EAAa,KAAK,OAAO,QAC7CD,EAAA,KAAK,OAAOC,CAAU,EAKhC,IAFAH,EAAaG,EAAa,EAEnBD,EAAQ7K,GAAU,EAAE8K,EAAa,KAAK,OAAO,QAC1CD,EAAA,KAAK,OAAOC,CAAU,EAGhCF,EAAWE,EAAa,CAC1B,CAGaH,EAAA,KAAK,IAAI,KAAK,IAAIA,EAAY,CAAC,EAAGN,EAAQ,CAAC,EAC7CO,EAAA,KAAK,IAAI,KAAK,IAAIA,EAAU,CAAC,EAAGP,EAAQ,CAAC,EAEpD,KAAM,CAAE,WAAYU,EAAiB,SAAUC,GAAkB,KAAK,OAElEL,IAAeI,GAAmBH,IAAaI,KACjDN,GAAA,MAAAA,EAAUC,EAAYC,EAAUP,EAAOO,IAAaP,EAAQ,GAC5D,KAAK,SAAS,CACZ,WAAAM,EACA,SAAAC,CAAA,CACD,GAGCvC,GACOA,EAAAiC,EAAWC,EAAWC,EAAY5D,CAAa,CAC1D,GA9MK,KAAA,sBAAsB,KAAK,KAAK,CACvC,CAEA,mBAA0B,CACxB,KAAK,QAAU,GACf,KAAK,YAAY,EACV,OAAA,iBAAiB,SAAU,KAAK,YAAY,CACrD,CAOA,sBAAsBqE,EAA+B,CAC7C,KAAA,CAAE,MAAAZ,CAAM,EAAI,KAAK,MAInB,OAAA/J,GAAS2K,EAAU,OAAO,GAC5B,KAAK,OAAS,GACd,KAAK,WAAaA,EAAU,QACrB,MAKPA,EAAU,YAAc,KAAK,kBAC1BA,EAAU,QAAUZ,GACpB,CAAC,KAAK,WAET,KAAK,eAAeY,CAAS,EAE7B,WAAW,IAAM,CACf,KAAK,eAAeA,CAAS,EAC7B,KAAK,YAAY,GAChB,GAAG,GAGD,GACT,CAEA,oBAA2B,CACnB,KAAA,CAAE,OAAAC,CAAO,EAAI,KAAK,MAEpB,GAAA,KAAK,UAAU,KAAO,EAAG,CAC3B,MAAMC,EAAO,MAAM,KAAK,KAAK,UAAU,MAAM,EACvCC,EAAMF,GAAU,EACtBC,EAAK,KAAK,EAEV,IAAIE,EAAW,EAKN,QAAA3mE,EAAI,EAAGyiE,EAAOgE,EAAK,OAAQzmE,EAAIyiE,EAAM,EAAEziE,EAAG,CAC3C,MAAA4mE,EAAWH,EAAKzmE,CAAC,EACjB6mE,EAAeJ,EAAKzmE,EAAI,CAAC,GAAK,KAAK,OAAO,OAAS,EAIzD,GAAI4mE,IAAa,KAAK,OAAO,OAAS,EAAG,CACvC,MAAME,EAAS,KAAK,UAAU,IAAIF,CAAQ,EAC1C,GAAI,CAACE,GAAU,CAACA,EAAO,QAAW,SAC5BC,MAAAA,EAASD,EAAO,QAAQ,sBAAsB,EAC/C,KAAA,cAAgBC,EAAO,OAASL,EAChC,KAAA,YAAY,OAAOE,CAAQ,EAChC,QACF,CAEM,MAAAI,EAAS,KAAK,OAAOJ,CAAQ,EAC7BK,EAAa,KAAK,OAAOL,EAAW,CAAC,EAErCE,EAAS,KAAK,UAAU,IAAIF,CAAQ,EAE1C,GAAI,CAACE,GAAU,CAACA,EAAO,QAAW,SAC5B,MAAAC,EAASD,EAAO,QAAQ,sBAAsB,EAIpDH,EAHmBK,EAASD,EAAO,OAASL,EAGpBO,EAEnB,KAAA,YAAY,OAAOL,CAAQ,EAIhC,QAAStkE,EAAIskE,EAAW,EAAGtkE,GAAKukE,EAAc,EAAEvkE,EACzC,KAAA,OAAOA,CAAC,GAAKqkE,CAEtB,CAEA,KAAK,UAAU,QAKf,KAAK,YAAY,CACnB,CACF,CAEA,sBAA6B,CACvB,KAAK,UAAY,KAAK,SAAS,aAC5B,OAAA,oBAAoB,SAAU,KAAK,YAAY,CACxD,CAKA,IAAI,cAAuB,CACzB,KAAM,CAAE,QAAAZ,EAAS,MAAAJ,GAAU,KAAK,MAC5B,OAAA/J,GAASmK,CAAO,EAAYJ,EAAQI,GAIhC,KAAK,OAAOJ,EAAQ,CAAC,GAAK,GAAK,KAAK,IAAI,KAAK,aAAa,CACpE,CAMA,IAAI,aAAmC,CACrC,KAAM,CAAE,eAAAvF,EAAiB,GAAI,gBAAA8G,EAAkB,GAAM,KAAK,MACpD,CAAE,MAAAjyC,CAAU,EAAAmrC,EACZ+G,EAA6B,CAAA,EAEnC,OAAID,EAAkB,IACdC,EAAA,UAAYD,EAAkB,KAAK,YAGpC,CACL,GAAGC,EACH,GAAGlyC,CAAA,CAEP,CA+EA,eAAe3pB,EAAwB,CACjC,GAAAswD,GAAStwD,EAAM,OAAO,EAAK,OAC/B,KAAK,iBAAmBA,EAAM,UAC9B,IAAImiB,EAAM,EACV,KAAK,YAAY,QACjB,KAAK,OAAS,GAGd,QAASztB,EAAI,EAAGA,EAAIsL,EAAM,MAAO,EAAEtL,EAAG,CAEpC,IAAIonE,EAAW97D,EAAM,QAAQtL,EAAGA,IAAMsL,EAAM,MAAQ,CAAC,EAIjD87D,EAAW,GACDA,GAAA,GACP,KAAA,YAAY,IAAIpnE,CAAC,EACtB,KAAK,kBAAoB,GAMpB,KAAK,OAAOA,CAAC,IACX,KAAA,OAAOA,CAAC,EAAIytB,IAGd,KAAA,OAAOztB,CAAC,EAAIytB,EAGfztB,IAAMsL,EAAM,MAAQ,IACtB,KAAK,cAAgB87D,GAGvB,KAAK,WAAa,KAAK,IAAI,KAAK,WAAYA,CAAQ,EAC7C35C,GAAA25C,CACT,CACF,CAEQ,gBAAgBC,EAAgF,CACtG,KAAM,CAAE,WAAApB,EAAY,SAAAC,GAAa,KAAK,MAChC,CAAE,QAAAH,EAAS,MAAAJ,GAAU,KAAK,MAChC,GAAI,CAAC0B,EAAuB,OAAA,KAC5B,MAAMZ,EAAuC,CAAA,EAGzC,IAAAa,EAEA1L,GAASmK,CAAO,EACTuB,EAACtnE,GAAcA,EAAI+lE,EAE5BuB,EAAUtnE,GAAc,KAAK,OAAOA,CAAC,EAGvC,QAASA,EAAIimE,EAAYjmE,GAAKkmE,GAAYlmE,EAAI2lE,EAAO,EAAE3lE,EAAG,CAClD,MAAAytB,EAAM65C,EAAOtnE,CAAC,EACpB,IAAI2P,EAEA,KAAK,YAAY,IAAI3P,CAAC,GAAK,CAAC,KAAK,UAAU,IAAIA,CAAC,IAClD2P,EAAMhP,EAAM,YACP,KAAA,UAAU,IAAIX,EAAG2P,CAAG,GAG3B,MAAMslB,EAA6B,CACjC,SAAU,WACV,MAAO,OACP,KAAM,EACN,IAAAxH,CAAA,EAMI85C,EAAMF,EAAa,CACvB,MAAOrnE,EACP,MAAO,CAAC,EACR,MAAOA,IAAMkmE,GAAYlmE,IAAM2lE,EAAQ,EACvC,SAAU1wC,CAAA,CACX,EAED,GAAI,CAACsyC,GAAO,CAAC5mE,EAAM,eAAe4mE,CAAG,EAAY,OAAA,KAO5Cd,EAAA,WACF,MAAY,CAAA,UAAU,gBAAgB,IAAA92D,EAAU,MAAAslB,EAC9C,YADOj1B,CAEV,CAAA,CAEJ,CAEO,OAAAymE,CACT,CAEA,QAAsB,CACd,KAAA,CACJ,kBAAAe,EACA,SAAAlwD,EACA,UAAAzE,EACA,eAAAutD,EACA,MAAAuF,EACA,aAAAzB,EACA,mBAAAN,EACA,gBAAA6D,EACA,WAAAC,CAAA,EACE,KAAK,MAIT,OAFgB/B,GAAS,EAIpBtuC,EAAAA,IAAA,MAAA,CAAI,UAAWw/B,GAAW,WAAY,kBAAmBhkD,CAAS,EACjE,SAACwkB,MAAA,MAAA,CAAI,UAAU,kBAAmB,WAAW,CAC/C,CAAA,EAIAowC,EAEApwC,EAAA,IAAC4qC,GAAA,CACC,IAAK,KAAK,UACV,kBAAAuF,EACA,UAAW3Q,GAAW,WAAYhkD,CAAS,EAC3C,aAAc,KAAK,aACnB,eAAgB,CACd,GAAGutD,EACH,MAAO,KAAK,WACd,EACA,mBAAAwD,EACA,SAAU,KAAK,mBAEd,SAAA,KAAK,gBAAgBtsD,CAAQ,CAAA,CAAA,EAMlC+f,EAAA,IAAC6tC,GAAA,CACC,IAAK,KAAK,UACV,kBAAAsC,EACA,UAAW3Q,GAAW,WAAYhkD,CAAS,EAC3C,aAAc,KAAK,aACnB,eAAgB,CACd,GAAGutD,EACH,MAAO,KAAK,WACd,EACA,cAAe8D,EACf,mBAAAN,EACA,SAAU,KAAK,aAEd,SAAA,KAAK,gBAAgBtsD,CAAQ,CAAA,CAAA,CAGpC,CACF,aCtfaqwD,GAAa,CACxB,OAAQ,iBACR,MAAO,gBACP,KAAM,cACR,EAqBO,SAASC,GAAOt8D,EAAoC,CACnD,KAAA,CACJ,UAAAuH,EACA,eAAAutD,EACA,KAAAppC,EAAO2wC,GAAW,MAChB,EAAAr8D,EAGF,OAAA+rB,EAAA,IAAC,MAAA,CACC,UAAWw/B,GAAW,SAAU7/B,EAAMnkB,CAAS,EAC9C,GAAGutD,CAAA,CAAA,CAGV,aCLayH,GAAgB,CAK3B,aAAc,0BAId,oBAAqB,iCAKrB,cAAe,2BAIf,MAAO,kBAKP,SAAU,qBACZ,EA2Ka,MAAAC,WAAkBnnE,EAAM,SAA8B,CAAtD,kCACXk/D,EAAA,aAAgB,CACd,eAAgB,KAChB,QAAS,GACT,QAAS,GACT,cAAe,MAAA,GAGjBA,EAAA,iBAAYl/D,EAAM,aACVk/D,EAAA,iBAAYl/D,EAAM,aAClBk/D,EAAA,iBAAYl/D,EAAM,aAClBk/D,EAAA,iBAAYl/D,EAAM,aAClBk/D,EAAA,gBAAW,IACXA,EAAA,sBAAiB,IACjBA,EAAA,oBAAe,IACfA,EAAA,qBAAgB,IA6ExBA,EAAA,wBAAmB,IAAY,CAC7B,KAAK,cAAgB,EAAA,GAGvBA,EAAA,mBAAe39D,GAAkC,SACzC,KAAA,CAAE,SAAA8R,CAAS,EAAI,KAAK,MACpB,CAAE,eAAA+zD,CAAe,EAAI,KAAK,MAEhC,KAAK,cAAgB,GACjB,EAAA/zD,GAMA,CAJY6nD,GACd35D,EAAE,OACF,oBAAA,KAIE,SAAS,gBAAkB,KAAK,UAAU,SAC5C,KAAK,SAAW,GAChB,WAAW,IAAM,CACf,KAAK,SAAW,IACf,EAAE,GACA28D,EAAA,KAAA,UAAU,UAAV,MAAAA,EAAmB,SACfkJ,GACJjJ,EAAA,KAAA,UAAU,UAAV,MAAAA,EAAmB,OAExB,KAAK,WAAW,EAClB,GAGFe,EAAA,kBAAa,IAAY,CACvB,KAAM,CAAE,SAAA7rD,EAAU,gBAAAg0D,EAAiB,OAAAC,CAAA,EAAW,KAAK,MAEnD,GAAI,CAAC,KAAK,UAAU,SAAWj0D,EAAY,OAE3C,MAAMonD,EAAMD,GACV,KAAK,UAAU,QAAQ,sBAAsB,EAC7C,CACE,OAAQ,EACR,GAAG6M,CACL,CAAA,EAGF5M,EAAI,KAAO,EACXA,EAAI,QAAU,EACdA,EAAI,QAAU,EAEd,KAAK,SAAS,CACZ,eAAgBA,CAAA,CACjB,EAEQ6M,GAAA,MAAAA,GAAA,GAGXpI,EAAA,mBAAc,IAAY,CAClB,KAAA,CAAE,QAAA/gD,CAAQ,EAAI,KAAK,OAErBA,GAAA,YAAAA,OAAgB,IAEpB,KAAK,SAAS,CACZ,eAAgB,KAChB,YAAa,EAAA,CACd,CAAA,GAGH+gD,EAAA,mBAAe39D,GAAwB,CAC/B,KAAA,CAAE,SAAA8R,CAAS,EAAI,KAAK,MAI1B,GAAI,KAAK,cAAe,CACtB,KAAK,cAAgB,GACrB,MACF,CAEIA,GACA9R,EAAE,SAAW,KAAK,UAAU,SAC9B,KAAK,WAAW,CAClB,GAGF29D,EAAA,kBAAc39D,GAAwB,OAC9B,KAAA,CAAE,SAAA8R,CAAS,EAAI,KAAK,MAE1B,GAAI,CAAAA,GACA9R,EAAE,SAAW,KAAK,UAAU,QAAS,CACvC,GAAI,KAAK,SAAU,CACjB,KAAK,SAAW,GACX,KAAK,iBACH28D,EAAA,KAAA,UAAU,UAAV,MAAAA,EAAmB,QAE1B,MACF,CAEA,KAAK,YAAY,CACnB,CAAA,GAGFgB,EAAA,oBAAgBqI,GAAqC,IAAM,CACzD,KAAM,CAAE,SAAAl0D,EAAU,SAAA4F,GAAa,KAAK,MAEhC5F,IACJ4F,GAAA,MAAAA,EAAWsuD,EAAO,OAClB,KAAK,SAAS,CACZ,eAAgB,KAChB,cAAeA,EAAO,KAAA,CACvB,EAAA,GAMHrI,EAAA,oBAAgB39D,GAA+B,SAC7C,KAAM,CAAE,SAAA8R,EAAU,SAAAm0D,GAAa,KAAK,MAEpC,GAAIn0D,EAAY,OAEhB,MAAMo0D,GAActJ,GAAAD,EAAA38D,EAAE,SAAF,YAAA28D,EAAkB,QAAlB,YAAAC,EAAyB,oBAC7C,KAAK,SAAS,CACZ,YAAasJ,CAAA,CACd,EACDD,GAAA,MAAAA,EAAWC,EAAU,GAGvBvI,EAAA,mBAAc,IAAY,CACxB,KAAK,SAAW,EAAA,GAGlBA,EAAA,mBAAc,MACZwI,EACAC,EACAC,EACAC,IACkB,CAClB,KAAM,CAAE,QAAAC,EAAS,WAAAC,EAAY,QAAA7iD,CAAA,EAAY,KAAK,MAE1C2iD,GAAS,CAAC,KAAK,cAAgBC,IACjC,KAAK,aAAe,GACpB,MAAMC,GAAA,YAAAA,EAAa7iD,IACnB,KAAK,aAAe,GACtB,GAGFg6C,EAAA,uBAAmB39D,GAA8B,CAC/C,KAAM,CAAE,eAAgBymE,GAAwB,KAAK,MAC/C,CAAE,eAAAZ,CAAe,EAAI,KAAK,OAM5BY,GAAuBZ,IACzBpJ,GAAgBz8D,CAAC,CACnB,GApOF,mBAA0B,CACf,SAAA,iBAAiB,UAAW,KAAK,WAAW,EAC5C,SAAA,iBAAiB,WAAY,KAAK,UAAU,EAC9C,OAAA,iBAAiB,OAAQ,KAAK,gBAAgB,CACvD,CAEA,mBAAmB0mE,EAA2B7yC,EAAyB,OAC/D,KAAA,CAAE,eAAAgyC,CAAe,EAAI,KAAK,MAC1B,CAAE,UAAAc,CAAU,EAAI,KAAK,MAGvB9yC,EAAU,iBAAmBgyC,GAAkBA,GAC7Cc,IACF,KAAK,SAAW,GAChB,KAAK,eAAiB,IACjBhK,EAAA,KAAA,UAAU,UAAV,MAAAA,EAAmB,QAG9B,CAEA,sBAA6B,CAClB,SAAA,oBAAoB,UAAW,KAAK,WAAW,EAC/C,SAAA,oBAAoB,WAAY,KAAK,UAAU,EACjD,OAAA,oBAAoB,OAAQ,KAAK,gBAAgB,CAC1D,CAEA,IAAI,YAAuC,OACnC,KAAA,CACJ,QAAAh5C,EACA,aAAA5L,EACA,MAAO6uD,EACP,aAAAC,CAAA,EACE,KAAK,MAGL,GAA2BA,GAAiB,KAAe,OAAAA,EAEzD,KAAA,CAAE,cAAAzP,CAAc,EAAI,KAAK,MACzB7sD,EAAQq8D,GAAmBxP,GAAiBr/C,EAE3C,QAAA4kD,EAAAh5C,EAAQ,KAAMqiD,GAAWA,EAAO,QAAUz7D,CAAK,IAA/C,YAAAoyD,EAAkD,QAAS,EACpE,CAEA,IAAI,YAAqB,CACvB,KAAM,CAAE,QAAAh5C,EAAS,aAAA5L,EAAc,MAAO6uD,GAAoB,KAAK,MACzD,CAAE,cAAAxP,CAAc,EAAI,KAAK,MACzB7sD,EAAQq8D,GAAmBxP,GAAiBr/C,EAElD,OAAO4L,EAAQ,UAAWqiD,GAAWA,EAAO,QAAUz7D,CAAK,GAAK,CAClE,CAMA,IAAI,SAAiC,CAC7B,KAAA,CAAE,YAAAu8D,CAAY,EAAI,KAAK,MACvB,CAAE,QAAAnjD,CAAQ,EAAI,KAAK,MAEnBuiD,EAAaY,GAAA,YAAAA,EAAa,oBAEhC,OAAIZ,EACKviD,EAAQ,OAAQotC,GACjBA,EAAE,OACGA,EAAE,OAAO,kBAAA,EAAoB,QAAQmV,CAAU,EAAI,GACtDzM,GAAS1I,EAAE,KAAK,EACbA,EAAE,MAAM,kBAAA,EAAoB,QAAQmV,CAAU,EAAI,GAEpD,EACR,EAGIviD,CACT,CA8JA,cAA4B,CACpB,KAAA,CACJ,MAAAojD,EACA,QAAAC,EACA,SAAAl1D,EACA,MAAApL,EACA,MAAAuvD,EACA,KAAA2M,EAAO+C,GAAc,aACrB,YAAAzN,EACA,aAAA+O,EACA,WAAYC,CAAA,EACV,KAAK,MACH,CAAE,QAAA/Q,EAAS,QAAA19C,EAAS,eAAAotD,CAAA,EAAmB,KAAK,MAC5C,CAAE,WAAAsB,CAAe,EAAA,KAEvB,OAIIhyC,MAAAhyB,EAAAA,SAAA,CAAA,SAAA+uD,EAAA,KAAC,MAAA,CACC,UAAWyC,GACT,qBACAyI,EAAK3kD,GAAWotD,EAAgB,kBAAkB,EAClDzI,EAAKjH,EAAS,oBAAoB,EAClCiH,EACE+J,GAAc,CAAChR,EACf,oBACA,kBACF,EACAiH,EAAK12D,EAAO,kBAAkB,EAC9B02D,EAAKnH,EAAO,sBAAsB,EAClC,wBACA2M,EACAxF,EAAKtrD,EAAU6zD,GAAc,QAAQ,CACvC,EACA,IAAK,KAAK,UACT,GAAGvJ,GAAa,IAAI,EACpB,GAAGI,GAAa,IAAI,EACrB,YAAa,KAAK,gBAClB,QAAS,KAAK,YAEb,SAAA,CAAAY,EAAK2J,EAAQ5xC,EAAA,IAAA,MAAA,CAAI,UAAU,mBAAoB,WAAM,CAAM,EAC3DioC,EAAKnH,EAAO9gC,EAAA,IAAC,OAAI,UAAU,mBAAoB,WAAM,CAAM,EAC5DA,EAAAA,IAAC,MAAI,CAAA,UAAU,kBACb,SAAA+8B,EAAA,KAAC,MAAA,CACC,UAAWyC,GACT,mBACAyI,EAAK+J,EAAY,GAAI,wBAAwB,CAC/C,EAEC,SAAA,CAAA/J,EAAK8J,EAAkBE,GACrBjyC,EAAAA,IAAA,IAAA,CAAG,WAAI,CACT,EACAgyC,GAAcjP,CAAA,CAAA,CAAA,EAEnB,EAEA/iC,EAAA,IAAC,MAAA,CACC,UAAWw/B,GACT,wBACAyI,EAAK4J,EAAS,eAAe,CAC/B,EACA,QAASC,EACT,KAAK,SACL,SAAU,EAEV,eAAClrC,GAAgB,EAAA,CAAA,CACnB,CAAA,CAAA,CAEJ,CAAA,CAAA,CAEJ,CAEA,gBAAiD,CACzC,KAAA,CACJ,eAAAsrC,EACA,aAAAtvD,EACA,eAAA8tD,EACA,QAAAU,EACA,UAAAI,EACA,UAAAW,EACA,KAAA1E,EAAO+C,GAAc,aACrB,gBAAAX,EAAkB,EAClB,MAAO4B,CAAA,EACL,KAAK,MACH,CAAE,cAAAxP,CAAc,EAAI,KAAK,MACzB7sD,EAAQq8D,GAAmBxP,GAAiBr/C,EAC5CwvD,EAAa,KAAK,QAClB,CAAE,eAAgBd,GAAwB,KAAK,MAErD,OAAOrJ,EAAKqJ,GAAuBZ,EAAiB7H,GAAWZ,EAC7DiK,EACA,IACM5oE,EAAM,eAAe4oE,CAAc,EAGjCA,EAAe,OAAS3J,GACnBj/D,EAAM,aAAa4oE,EAAgB,CACxC,GAAGA,EAAe,MAEhB,OAAArJ,EACA,MAAO,KAAK,IAAI,IAAKA,EAAO,KAAK,EACjC,QAAS,KAAK,YACd,eAAgB,CAAE,YAAa,KAAK,WAAY,CAClD,CACD,EAMIv/D,EAAM,aAAa4oE,EAAgB,CACxC,GAAGA,EAAe,MAClB,eAAgB,CACd,OAAArJ,EACA,MAAO,KAAK,IAAI,IAAKA,EAAO,KAAK,EACjC,QAAS,KAAK,YACd,eAAgB,CAAE,YAAa,KAAK,WAAY,CAClD,CAAA,CACD,GAIH,QAAQ,KAAK,iCAAiC,EACvC,MAGT7oC,EAAA,IAACuoC,GAAA,CACC,OAAAM,EACA,MAAO,KAAK,IAAI,IAAKA,EAAO,KAAK,EACjC,QAAS,KAAK,YACd,eAAgB,CAAE,YAAa,KAAK,WAAY,EAChD,UAAW4E,EAEX,SAAA1Q,EAAA,KAAC,MAAA,CACC,UAAWyC,GACT,mBACAyI,EAAKkK,EAAW,mBAAmB,CACrC,EAEC,SAAA,CAAAlK,EAAKuJ,EAAW,IAAM,KAAK,aAAA,CAAc,EACzCvJ,EACCkK,EACAnyC,EAAAA,IAAC,OAAI,UAAU,6BACb,eAACuwC,GAAO,CAAA,KAAMD,GAAW,KAAA,CAAO,CAClC,CAAA,EAEAtwC,EAAA,IAACquC,GAAA,CACC,UAAU,kBACV,MAAO+D,EAAW,QAAUhB,EAAU,EAAI,GAC1C,QAAS,GACT,gBAAAvB,EACA,aAAc,KAAK,IAAI,KAAK,WAAa,EAAG,CAAC,EAAI,GACjD,QAASuB,EAAU,KAAK,YAAc,OAErC,SAAC,CAAA,CAAE,MAAAvrD,EAAO,MAAA+X,EAAO,MAAAuzC,KAAY,CACtB,MAAAN,EAASuB,EAAWvsD,CAAK,EAE/B,OAAIsrD,GAASC,EAETpxC,EAAA,IAAC,MAAA,CAEC,UAAWw/B,GAAW,mBAAmB,EACzC,MAAA5hC,EAEA,SAACoC,EAAA,IAAAuwC,GAAA,CAAO,KAAMD,GAAW,KAAM,CAAA,EAJ1BzqD,CAAA,EAWTk3C,EAAA,KAAC,MAAA,CAEC,UAAWyC,GACT,oBACAyI,EAAK4I,EAAO,QAAUz7D,EAAO,qBAAqB,EAClD6yD,EAAK4I,EAAO,QAAS,oBAAoB,CAC3C,EACA,MAAAjzC,EACA,QAAS,KAAK,aAAaizC,CAAM,EACjC,KAAK,SACL,gBAAeA,EAAO,QAAUz7D,EAChC,SAAU,EAEV,SAAA,CAAC4qB,EAAAA,IAAA,OAAA,CAAM,WAAO,KAAM,CAAA,EACpBA,EAAAA,IAACmG,GAAU,CAAA,UAAU,uBAAwB,CAAA,CAAA,CAAA,EAbxCtgB,CAcP,CAEJ,CAAA,CACF,CACF,CAAA,CAAA,CACF,CAAA,CACF,CAAA,CACD,CACH,CAEA,cAA4B,CACpB,KAAA,CAAE,YAAA8rD,CAAY,EAAI,KAAK,MAG3B,OAAA5U,EAAA,KAAC,MAAI,CAAA,UAAU,oBACb,SAAA,CAAC/8B,EAAAA,IAAAugB,GAAA,CAAW,UAAU,uBAAwB,CAAA,EAC9CvgB,EAAA,IAAC,QAAA,CACC,MAAO2xC,EACP,WAAW,QACX,YAAY,QACZ,IAAK,KAAK,UACV,KAAK,OACL,YAAY,eACZ,YAAa,IAAM,OACjB,KAAK,SAAW,GAChB,KAAK,eAAiB,IACjBnK,EAAA,KAAA,UAAU,UAAV,MAAAA,EAAmB,OAC1B,EACA,SAAU,KAAK,YAAA,CACjB,CACF,CAAA,CAAA,CAEJ,CAEA,QAAsB,CACd,KAAA,CACJ,UAAAhsD,EACA,eAAAutD,EACA,aAAAnmD,EACA,MAAO6uD,EACP,QAAAjjD,EACA,KAAAi/C,EAAO+C,GAAc,aACrB,KAAA7wC,EACA,SAAA1f,EACA,SAAAtD,EACA,YAAA01D,CAAA,EACE,KAAK,MACH,CAAE,cAAApQ,CAAc,EAAI,KAAK,MACzB7sD,EAAQq8D,GAAmBxP,GAAiBr/C,EAGhD,OAAAm6C,EAAA,KAAC,MAAA,CACC,IAAK,KAAK,UACV,UAAWyC,GACT,YACAiO,EACA9tC,EACAsoC,EAAKtrD,EAAU6zD,GAAc,QAAQ,EACrCh1D,CACF,EACC,GAAGutD,EAEJ,SAAA,CAAA/oC,EAAA,IAAC,SAAA,CACC,IAAK,KAAK,UACV,MAAA5qB,EACA,SAAUwuD,GACV,SAAAjnD,EACC,GAAG01D,EAEH,SAAQ7jD,EAAA,IAAK8jD,SACX,SAAuB,CAAA,MAAOA,EAAI,MAAO,aAAYA,EAAI,KAA7C,EAAAA,EAAI,KAAgD,CAClE,CAAA,CACH,EACCrK,EAAKhoD,IAAa,OAAQ,KAAK,cAAc,EAC7C,KAAK,eAAe,CAAA,CAAA,CAAA,CAG3B,CACF,CCpuBO,SAASsyD,IAAuD,CACrE,MAAMC,EAAgBhP,KAEtB,GAAI,CAACgP,EACG,MAAA,IAAI,MAAM,mFAAmF,EAGrG,KAAM,CAAE,aAAAC,EAAc,oBAAAC,EAAqB,qBAAAC,CAAA,EAAyBH,EAE9DhkD,GAAWkkD,GAAuBjP,IAAgC,IAAK79C,GACvE,OAAOA,GAAS,SACX,CACL,MAAOA,EAAK,SAAS,EACrB,MAAOA,CAAA,EAIJA,CACR,EAEG,OAAA4I,EAAQ,OAAS,EACZ,KAIPwR,EAAA,IAACywC,GAAA,CACC,MAAOgC,EACP,QAAAjkD,EACA,SAAUmkD,EACV,aAAW,yBAAA,CAAA,CAGjB,CClCO,MAAMC,GAAY,MAET,SAAAC,GAAMxiE,EAAcggD,EAA8B,CACzD,OAAA,MAAMA,CAAK,EAAE,KAAK,CAAC,EAAE,IAAI,CAACyJ,EAAGj0C,IAAUA,EAAQxV,CAAI,CAC5D,CASgB,SAAAyiE,GAAYC,EAA0BC,EAAiD,CACrG,MAAMC,EAAwC,CAAA,EACxCC,EAAgBF,EAAa,EAEnC,OAAIA,GAActP,GAEVmP,GAAA,EAAGG,CAAU,EAAE,IAAK3nE,GAAM4nE,EAAS,KAAK5nE,CAAC,CAAC,GAGhD4nE,EAAS,KAAK,CAAC,EAMXF,GAAoBrP,GAA0BC,GAA0B,EAC1EkP,GACE,EACAnP,GAAyBC,GAA0B,CAAA,EACnD,IAAKt4D,GAAM4nE,EAAS,KAAK5nE,CAAC,CAAC,EAE7B4nE,EAAS,KAAKL,EAAS,EAKrBG,EAAmBrP,GAA0BC,GAA0B,GACtEoP,EAAmBG,EAAiBvP,GAA2B,GAClEkP,GACEE,EAAmBpP,GACnBD,GAA0BC,GAA0B,CAAA,EACpD,IAAKt4D,GAAM4nE,EAAS,KAAK5nE,CAAC,CAAC,EAI3B0nE,GAAoBG,EAAiBvP,GAA2B,EAClEkP,GACEG,GAActP,GAAyBC,IACvCD,GAAyBC,GAA0B,CAAA,EACnD,IAAKt4D,GAAM4nE,EAAS,KAAK5nE,CAAC,CAAC,EAE7B4nE,EAAS,KAAKL,EAAS,EAIzBK,EAAS,KAAKC,CAAa,GAGtBD,CACT,CCvDgB,SAAAE,GAA2B,CAAE,MAAA/9D,GAAuD,CAClG,MAAMo9D,EAAgBhP,KAEtB,GAAI,CAACgP,EACG,MAAA,IAAI,MAAM,6EAA6E,EAGzF,KAAA,CAAE,KAAAY,EAAM,aAAAC,CAAiB,EAAAb,EACzBc,EAAS,OAAOl+D,GAAU,SAC1B0rD,EAAQwS,GAAUl+D,EAAQ,GAAG,eAAmB,EAAAA,EAChDuH,EAAWvH,IAAUw9D,IAAaQ,IAASh+D,EAC3C0lD,EAAWsY,IAASh+D,EAEpBm+D,EAAe,IAA0B,CAC7C,GAAKD,EAIL,OAAIxY,EACK,sBAAsBgG,CAAK,GAG7B,cAAcA,CAAK,EAAA,EAGtBpD,EAAgB,IAAY,CAC5B,OAAOtoD,GAAU,WACnBi+D,GAAA,MAAAA,EAAej+D,GACjB,EAIA,OAAA4qB,EAAA,IAACm9B,GAAA,CACC,KAAK,WACL,eAAcrC,EAAW,GAAO,OAChC,aAAYyY,EAAa,EACzB,UAAW1W,GAAG,iCAAkC,CAAE,2CAA4C/B,EAAU,EACxG,SAAAn+C,EACA,QAAS+gD,EAER,SAAAoD,CAAA,CAAA,CAGP,CC/CO,SAAS0S,IAA6C,CAC3D,MAAMhB,EAAgBhP,KAEtB,GAAI,CAACgP,EACG,MAAA,IAAI,MAAM,yEAAyE,EAG3F,KAAM,CAAE,MAAAniB,EAAO,KAAA+iB,EAAM,aAAAX,EAAc,aAAAY,GAAiBb,EAEpD,GAAIniB,GAASoiB,EACJ,OAAA,KAGT,MAAMgB,EAAS,IAAY,CACzBJ,GAAA,MAAAA,EAAeD,EAAO,EAAC,EAGnBM,EAAS,IAAY,CACzBL,GAAA,MAAAA,EAAeD,EAAO,EAAC,EAGnBH,EAAWH,GAAYM,EAAM,KAAK,KAAK/iB,EAAQoiB,CAAY,CAAC,EAIhE,OAAAzyC,EAAA,IAAC,OAAI,KAAK,aAAa,aAAW,wBAAwB,UAAU,4BAClE,SAAA+8B,EAAA,KAAC,KACC,CAAA,SAAA,CAAA/8B,MAAC,KACC,CAAA,SAAAA,EAAA,IAACm9B,GAAA,CACC,QAASuW,EACT,KAAK,WACL,aAAW,sBACX,SAAUN,IAAS,EAEnB,eAAClsC,GAAgB,EAAA,CAAA,CAAA,EAErB,EACC+rC,EAAS,IAAI,CAACrtD,EAAMC,UAClB,KAA0C,CAAA,SAAAma,MAACmzC,GAA2B,CAAA,MAAOvtD,EAAM,CAA3E,EAAA,iBAAiBA,CAAI,IAAIC,CAAK,EAA+C,CACvF,QACA,KACC,CAAA,SAAAma,EAAA,IAACm9B,GAAA,CACC,QAASsW,EACT,KAAK,WACL,aAAW,kBACX,SAAUL,GAAQ,KAAK,KAAK/iB,EAAQoiB,CAAY,EAAI,EAEpD,eAACjrC,GAAiB,EAAA,CAAA,CAAA,EAEtB,CAAA,CACF,CAAA,CACF,CAAA,CAEJ,CCzDO,SAASmsC,IAAmC,CACjD,MAAMnB,EAAgBhP,KAEtB,GAAI,CAACgP,EACG,MAAA,IAAI,MAAM,sEAAsE,EAGxF,KAAM,CAAE,MAAAniB,EAAO,KAAA+iB,EAAM,aAAAX,CAAA,EAAiBD,EAChCjoD,EAAS6oD,EAAOX,EAAgB,EAChCjoD,EAAM,KAAK,KAAK4oD,EAAO,GAAKX,EAAcpiB,CAAK,EAEnD,OAAA0M,EAAA,KAAC,MAAI,CAAA,UAAU,yBAAyB,SAAA,CAAA,UAErC,IACAxyC,EAAM,eAAe,EACrB,IACAA,IAAUC,EACPuyC,EAAAA,KAAA/uD,EAAA,SAAA,CAAA,SAAA,CAAA,KAEC,IACAwc,EAAI,eAAe,EACnB,GAAA,CAAA,CACH,EACE,KAAK,KAER,IACA6lC,EAAM,eAAe,CACxB,CAAA,CAAA,CAEJ,aCLMujB,GAAen0C,EAAA,WAAW,CAC9BxrB,EACAmQ,IACuB,CACjB,KAAA,CACJ,MAAAisC,EACA,UAAA70C,EACA,KAAA43D,EACA,aAAAX,EACA,oBAAAC,EACA,aAAAW,EACA,qBAAAV,EACA,GAAGx2D,CACD,EAAAlI,EAEJ,OAAIo8C,EAAQ,EACH,WAINkT,GAAkB,SAAlB,CAA2B,MAAOtvD,EACjC,SAAC8oD,EAAAA,KAAA,MAAA,CAAK,GAAG5gD,EAAM,UAAW0gD,GAAG,gBAAiBrhD,CAAS,EAAG,IAAK4I,EAC7D,SAAA,CAAC24C,EAAAA,KAAA,MAAA,CAAI,UAAU,sBACb,SAAA,CAAA/8B,EAAA,IAACuyC,GAAiC,EAAA,QACjCoB,GAAoB,EAAA,CAAA,EACvB,QACCH,GAAuB,EAAA,CAAA,CAC1B,CAAA,CACF,CAAA,CAEJ,CAAC,EAEDI,GAAa,YAAc","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,61,63,65,67,69,71,73,75,77,79,81,83,85,87,89,91,93,95,97,99,101,103,105,107,109,111,113,115,117,119,121,123,125,127,129,131,133,135,137,139,141,143,145,147,149,151,153,155,157,159,161,163,165,167,169,171,173,175,177,179,181,183,185,187,189,191,193,195,197,199,201,203,205,207,209,211,213,215,217,219,221,223,225,227,229,231,233,235,237,239,241,243,245,247,249,251,253,255,257,259,261,263,265,267,269,271,273,275,277,279,281,283,285,287,289,291,293,295,297,299,301,303,305,307,309,311,313,315,317,319,321,323,325,327,329,331,333,335,337,339,341,343,345,347,349,351,353,355,357,359,361,363,365,367,369,371,373,375,377,379,381,383,385,387,389,391,393,395,397,399,401,403,405,407,409,411,413,415,417,419,421,423,425,427,429,431,433,435,437,439,441,443,445,447,449,451,453,455,457,459,461,463,465,467,469,471,473,475,477,479,481,483,485,487,489,491,493,495,497,499,501,503,505,507,509,510,511,512,539]}