@economic/taco 1.17.3 → 1.18.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Icon/components/index.d.ts +1 -1
- package/dist/components/Input/Input.d.ts +1 -1
- package/dist/components/Menu/components/Item.d.ts +1 -1
- package/dist/components/Menu/components/Link.d.ts +1 -1
- package/dist/components/Progress/Progress.stories.d.ts +1 -0
- package/dist/components/Select2/Select2.stories.d.ts +1 -0
- package/dist/components/Select2/components/Edit.d.ts +2 -2
- package/dist/components/Select2/components/Option.d.ts +1 -1
- package/dist/components/Select2/components/Search.d.ts +1 -1
- package/dist/components/Tag/Tag.d.ts +14 -3
- package/dist/esm/index.css +3 -3
- package/dist/esm/packages/taco/src/components/Button/util.js +3 -3
- package/dist/esm/packages/taco/src/components/Button/util.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js +1 -1
- package/dist/esm/packages/taco/src/components/Datepicker/Datepicker.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Icon/components/index.js +0 -2
- package/dist/esm/packages/taco/src/components/Icon/components/index.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Input/util.js +1 -1
- package/dist/esm/packages/taco/src/components/Input/util.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Menu/components/Item.js +1 -1
- package/dist/esm/packages/taco/src/components/Menu/components/Item.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Select2/Select2.js +19 -0
- package/dist/esm/packages/taco/src/components/Select2/Select2.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Select2/components/Edit.js +3 -3
- package/dist/esm/packages/taco/src/components/Select2/components/Edit.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js +7 -7
- package/dist/esm/packages/taco/src/components/Select2/components/Trigger.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Select2/utilities.js +1 -1
- package/dist/esm/packages/taco/src/components/Select2/utilities.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Tag/Tag.js +13 -3
- package/dist/esm/packages/taco/src/components/Tag/Tag.js.map +1 -1
- package/dist/esm/packages/taco/src/index.js +1 -1
- package/dist/index.css +3 -3
- package/dist/taco.cjs.development.js +51 -49
- package/dist/taco.cjs.development.js.map +1 -1
- package/dist/taco.cjs.production.min.js +1 -1
- package/dist/taco.cjs.production.min.js.map +1 -1
- package/package.json +2 -2
- package/types.json +16 -5
- package/dist/components/Icon/components/Spinner.d.ts +0 -3
- package/dist/esm/packages/taco/src/components/Icon/components/Spinner.js +0 -20
- package/dist/esm/packages/taco/src/components/Icon/components/Spinner.js.map +0 -1
- package/dist/esm/packages/taco/src/utils/colors.js +0 -14
- package/dist/esm/packages/taco/src/utils/colors.js.map +0 -1
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"taco.cjs.production.min.js","sources":["../src/components/AlertDialog/Context.tsx","../src/utils/mergeRefs.ts","../src/components/AlertDialog/components/Trigger.tsx","../src/components/AlertDialog/components/Footer.tsx","../src/components/Backdrop/Backdrop.tsx","../src/components/Dialog/util.ts","../src/components/AlertDialog/components/Content.tsx","../src/components/AlertDialog/AlertDialog.tsx","../src/components/Icon/components/AccountPreview.tsx","../src/components/Icon/components/AccountingYearCancel.tsx","../src/components/Icon/components/AccountingYear.tsx","../src/components/Icon/components/Accounting.tsx","../src/components/Icon/components/ArrowBottom.tsx","../src/components/Icon/components/ArrowDown.tsx","../src/components/Icon/components/ArrowEnd.tsx","../src/components/Icon/components/ArrowLeft.tsx","../src/components/Icon/components/ArrowRight.tsx","../src/components/Icon/components/ArrowStart.tsx","../src/components/Icon/components/ArrowTop.tsx","../src/components/Icon/components/ArrowUp.tsx","../src/components/Icon/components/AttachAuto.tsx","../src/components/Icon/components/AttachCancel.tsx","../src/components/Icon/components/Attach.tsx","../src/components/Icon/components/AutotextInsert.tsx","../src/components/Icon/components/Autotext.tsx","../src/components/Icon/components/BasicTabs.tsx","../src/components/Icon/components/Basic.tsx","../src/components/Icon/components/BellSolid.tsx","../src/components/Icon/components/Book.tsx","../src/components/Icon/components/Booking.tsx","../src/components/Icon/components/Budget.tsx","../src/components/Icon/components/Calendar.tsx","../src/components/Icon/components/CashAccount.tsx","../src/components/Icon/components/CashReports.tsx","../src/components/Icon/components/ChatSolid.tsx","../src/components/Icon/components/Chat.tsx","../src/components/Icon/components/ChevronDownDouble.tsx","../src/components/Icon/components/ChevronDownSolid.tsx","../src/components/Icon/components/ChevronDown.tsx","../src/components/Icon/components/ChevronLeftDouble.tsx","../src/components/Icon/components/ChevronLeftSolid.tsx","../src/components/Icon/components/ChevronLeft.tsx","../src/components/Icon/components/ChevronRightDouble.tsx","../src/components/Icon/components/ChevronRightSolid.tsx","../src/components/Icon/components/ChevronRight.tsx","../src/components/Icon/components/ChevronUpDouble.tsx","../src/components/Icon/components/ChevronUpSolid.tsx","../src/components/Icon/components/ChevronUp.tsx","../src/components/Icon/components/CircleClose.tsx","../src/components/Icon/components/CircleMinus.tsx","../src/components/Icon/components/CirclePlus.tsx","../src/components/Icon/components/CircleTick.tsx","../src/components/Icon/components/ClampOpen.tsx","../src/components/Icon/components/Clamp.tsx","../src/components/Icon/components/Close.tsx","../src/components/Icon/components/ConnectionEnable.tsx","../src/components/Icon/components/ConnectionRevoke.tsx","../src/components/Icon/components/Contacts.tsx","../src/components/Icon/components/Copy.tsx","../src/components/Icon/components/Courses.tsx","../src/components/Icon/components/Credit.tsx","../src/components/Icon/components/DeletePermanently.tsx","../src/components/Icon/components/Delete.tsx","../src/components/Icon/components/Depecriate.tsx","../src/components/Icon/components/Developer.tsx","../src/components/Icon/components/DistributionTemplate.tsx","../src/components/Icon/components/DocumentApprove.tsx","../src/components/Icon/components/DocumentCreateEntry.tsx","../src/components/Icon/components/DocumentCut.tsx","../src/components/Icon/components/DocumentError.tsx","../src/components/Icon/components/DocumentIsolatePage.tsx","../src/components/Icon/components/DocumentMerge.tsx","../src/components/Icon/components/DocumentMove.tsx","../src/components/Icon/components/DocumentPreview.tsx","../src/components/Icon/components/DocumentReceived.tsx","../src/components/Icon/components/DocumentRejectedRequest.tsx","../src/components/Icon/components/DocumentSplit.tsx","../src/components/Icon/components/DocumentTime.tsx","../src/components/Icon/components/Document.tsx","../src/components/Icon/components/Download.tsx","../src/components/Icon/components/Drag.tsx","../src/components/Icon/components/ECopedia.tsx","../src/components/Icon/components/ESignature.tsx","../src/components/Icon/components/Edit.tsx","../src/components/Icon/components/EllipsisHorizontal.tsx","../src/components/Icon/components/EllipsisVertical.tsx","../src/components/Icon/components/EntriesOnAccount.tsx","../src/components/Icon/components/EntriesOpen.tsx","../src/components/Icon/components/EntriesWarning.tsx","../src/components/Icon/components/EntryTypeCustomerInvoice.tsx","../src/components/Icon/components/EntryTypeCustomerPayment.tsx","../src/components/Icon/components/EntryTypeJournalEntry.tsx","../src/components/Icon/components/EntryTypeManualCustomerInvoice.tsx","../src/components/Icon/components/EntryTypeSupplierInvoice.tsx","../src/components/Icon/components/EntryTypeSupplierPayment.tsx","../src/components/Icon/components/EnvelopeApproved.tsx","../src/components/Icon/components/Envelope.tsx","../src/components/Icon/components/ExpandView.tsx","../src/components/Icon/components/Expenses.tsx","../src/components/Icon/components/ExportToExcel.tsx","../src/components/Icon/components/ExportToPdf.tsx","../src/components/Icon/components/Export.tsx","../src/components/Icon/components/FilterSolid.tsx","../src/components/Icon/components/Filter.tsx","../src/components/Icon/components/GraphSolid.tsx","../src/components/Icon/components/Hash.tsx","../src/components/Icon/components/Home.tsx","../src/components/Icon/components/Images.tsx","../src/components/Icon/components/Import.tsx","../src/components/Icon/components/InboxEinvoicing.tsx","../src/components/Icon/components/InboxScanning.tsx","../src/components/Icon/components/InboxSmart.tsx","../src/components/Icon/components/Inbox.tsx","../src/components/Icon/components/Info.tsx","../src/components/Icon/components/InventoryMatrix.tsx","../src/components/Icon/components/Inventory.tsx","../src/components/Icon/components/JournalPro.tsx","../src/components/Icon/components/LayoutBoth.tsx","../src/components/Icon/components/LayoutFirst.tsx","../src/components/Icon/components/LayoutLast.tsx","../src/components/Icon/components/LayoutNone.tsx","../src/components/Icon/components/Layout.tsx","../src/components/Icon/components/LedgerCardCustomerReminder.tsx","../src/components/Icon/components/LedgerCardManualCustomerInvoice.tsx","../src/components/Icon/components/LedgerCardObsoleteStock.tsx","../src/components/Icon/components/LedgerCardOpeningEntry.tsx","../src/components/Icon/components/LedgerCardReservedEntry.tsx","../src/components/Icon/components/LedgerCardShrinkagePilferage.tsx","../src/components/Icon/components/LedgerCardStockAdjustment.tsx","../src/components/Icon/components/LedgerCardTransferredOpeningEntry.tsx","../src/components/Icon/components/LedgerCard.tsx","../src/components/Icon/components/Lightbulb.tsx","../src/components/Icon/components/Line.tsx","../src/components/Icon/components/ListBulleted.tsx","../src/components/Icon/components/ListSearch.tsx","../src/components/Icon/components/List.tsx","../src/components/Icon/components/LockOpen.tsx","../src/components/Icon/components/LogOut.tsx","../src/components/Icon/components/Log.tsx","../src/components/Icon/components/Market.tsx","../src/components/Icon/components/MatchAmount.tsx","../src/components/Icon/components/MatchEntries.tsx","../src/components/Icon/components/Menu.tsx","../src/components/Icon/components/Mileage.tsx","../src/components/Icon/components/ModalResize.tsx","../src/components/Icon/components/ModalShrink.tsx","../src/components/Icon/components/MoreSolid.tsx","../src/components/Icon/components/More.tsx","../src/components/Icon/components/Move.tsx","../src/components/Icon/components/NavigationList.tsx","../src/components/Icon/components/NoteFollowUp.tsx","../src/components/Icon/components/NoteRead.tsx","../src/components/Icon/components/Note.tsx","../src/components/Icon/components/Numbers.tsx","../src/components/Icon/components/PartnerApi.tsx","../src/components/Icon/components/Period.tsx","../src/components/Icon/components/PersonChange.tsx","../src/components/Icon/components/PersonMinus.tsx","../src/components/Icon/components/PersonPlus.tsx","../src/components/Icon/components/PersonTick.tsx","../src/components/Icon/components/Play.tsx","../src/components/Icon/components/PlusMinus.tsx","../src/components/Icon/components/Print.tsx","../src/components/Icon/components/ProcessPayment.tsx","../src/components/Icon/components/ProductLedgerCard.tsx","../src/components/Icon/components/Profile.tsx","../src/components/Icon/components/ProjectCards.tsx","../src/components/Icon/components/Projects.tsx","../src/components/Icon/components/Quicklinks.tsx","../src/components/Icon/components/RatingBankruptcy.tsx","../src/components/Icon/components/RatingPaymentProblems.tsx","../src/components/Icon/components/Reconciled.tsx","../src/components/Icon/components/Refresh.tsx","../src/components/Icon/components/ReportSolid.tsx","../src/components/Icon/components/Report.tsx","../src/components/Icon/components/Restore.tsx","../src/components/Icon/components/RotateLeft.tsx","../src/components/Icon/components/RotateRight.tsx","../src/components/Icon/components/Sales.tsx","../src/components/Icon/components/SearchBold.tsx","../src/components/Icon/components/Search.tsx","../src/components/Icon/components/SecureTick.tsx","../src/components/Icon/components/Secure.tsx","../src/components/Icon/components/SettingsSolid.tsx","../src/components/Icon/components/Settings.tsx","../src/components/Icon/components/Shortcuts.tsx","../src/components/Icon/components/ShowAll.tsx","../src/components/Icon/components/ShowLess.tsx","../src/components/Icon/components/ShowMore.tsx","../src/components/Icon/components/ShowTemplate.tsx","../src/components/Icon/components/Sliders.tsx","../src/components/Icon/components/Smartpay.tsx","../src/components/Icon/components/SortBy.tsx","../src/components/Icon/components/Spinner.tsx","../src/components/Icon/components/StarSolid.tsx","../src/components/Icon/components/Star.tsx","../src/components/Icon/components/Subscriptions.tsx","../src/components/Icon/components/SystemEntries.tsx","../src/components/Icon/components/Tag.tsx","../src/components/Icon/components/TemplateOverride.tsx","../src/components/Icon/components/Templates.tsx","../src/components/Icon/components/ThumbBoth.tsx","../src/components/Icon/components/ThumbDownSolid.tsx","../src/components/Icon/components/ThumbDown.tsx","../src/components/Icon/components/ThumbUpSolid.tsx","../src/components/Icon/components/ThumbUp.tsx","../src/components/Icon/components/Tick.tsx","../src/components/Icon/components/Time.tsx","../src/components/Icon/components/TransferCancel.tsx","../src/components/Icon/components/TransferLocked.tsx","../src/components/Icon/components/Transfer.tsx","../src/components/Icon/components/Undo.tsx","../src/components/Icon/components/Undock.tsx","../src/components/Icon/components/Unreconciled.tsx","../src/components/Icon/components/Warning.tsx","../src/components/Icon/components/Webshop.tsx","../src/components/Icon/components/Website.tsx","../src/components/Icon/components/Workflow.tsx","../src/components/Icon/components/Zoom.tsx","../src/components/Icon/components/index.tsx","../src/components/Icon/Icon.tsx","../src/components/Accordion/Accordion.tsx","../src/components/VisuallyHidden/VisuallyHidden.tsx","../src/utils/taillwind.ts","../src/components/Badge/Badge.tsx","../src/primitives/Button.tsx","../src/components/Tooltip/Tooltip.tsx","../src/components/Button/util.tsx","../src/components/IconButton/IconButton.tsx","../src/components/Provider/Localization.tsx","../src/components/Banner/Banner.tsx","../src/components/Banner/util.tsx","../src/components/Button/Button.tsx","../src/components/Calendar/Calendar.tsx","../src/components/Card/Card.tsx","../src/hooks/useId.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/Input/util.ts","../src/utils/debounce.ts","../src/hooks/useBoundingClientRectListener.ts","../src/hooks/useMergedRef.ts","../src/components/Input/Input.tsx","../src/utils/hooks/useListKeyboardNavigation.ts","../src/utils/hooks/useListScrollTo.ts","../src/components/Spinner/Spinner.tsx","../src/components/Listbox/ScrollableList.tsx","../src/utils/input.ts","../src/components/Listbox/util.ts","../src/components/Combobox/useCombobox.tsx","../src/components/Combobox/Combobox.tsx","../src/utils/date.ts","../src/components/Popover/Primitives.tsx","../src/components/Popover/Popover.tsx","../src/components/Popover/util.ts","../src/components/Datepicker/Datepicker.tsx","../src/components/Datepicker/useDatepicker.tsx","../src/components/Dialog/Context.tsx","../src/components/Dialog/components/Trigger.tsx","../src/components/Dialog/components/Content.tsx","../src/utils/hooks/useDraggable.tsx","../src/components/Dialog/components/Drawer.tsx","../src/components/Dialog/components/Extra.tsx","../src/components/Dialog/Dialog.tsx","../src/components/Field/Field.tsx","../src/components/Form/Form.tsx","../src/components/Group/Group.tsx","../src/components/Hanger/Hanger.tsx","../src/components/HoverCard/Primitives.tsx","../src/components/HoverCard/HoverCard.tsx","../src/components/SearchInput/SearchInput.tsx","../src/utils/hooks/useTimer.ts","../src/components/Listbox/useTypeahead.tsx","../src/components/Listbox/Listbox.tsx","../src/components/Listbox/useListbox.tsx","../src/components/Listbox/useMultiListbox.tsx","../src/components/Menu/Context.tsx","../src/components/Menu/components/Content.tsx","../src/components/Menu/components/Item.tsx","../src/components/Menu/components/Link.tsx","../src/components/Menu/components/Trigger.tsx","../src/components/Menu/components/Checkbox.tsx","../src/components/RadioGroup/RadioGroup.tsx","../src/components/Menu/components/RadioGroup.tsx","../src/components/Menu/components/Header.tsx","../src/components/Menu/Menu.tsx","../src/components/Menu/components/Separator.tsx","../src/components/Treeview/Treeview.tsx","../src/utils/hooks/useDropTarget.ts","../src/components/Navigation/Navigation.tsx","../src/components/Pagination/PageNumbers.tsx","../src/components/Select/Select.tsx","../src/components/Select/useSelect.tsx","../src/components/Pagination/Pagination.tsx","../src/components/Pagination/usePaginationShortcuts.tsx","../src/components/Toast/Toast.tsx","../src/components/Toast/util.tsx","../src/components/Toast/Toaster.tsx","../src/utils/aria.ts","../src/primitives/Collection/components/Root.tsx","../src/primitives/Listbox2/components/Context.tsx","../src/primitives/Listbox2/components/Root.tsx","../src/primitives/Listbox2/components/Option.tsx","../src/primitives/Listbox2/components/Group.tsx","../src/primitives/Listbox2/components/Title.tsx","../src/utils/colors.ts","../src/components/Tag/Tag.tsx","../src/components/Select2/components/Context.tsx","../../../node_modules/babel-plugin-transform-async-to-promises/helpers.mjs","../src/components/Select2/components/Edit.tsx","../src/utils/device.ts","../src/components/Select2/components/Option.tsx","../src/components/Select2/utilities.ts","../src/components/Select2/components/Group.tsx","../src/components/Select2/components/Title.tsx","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select2/components/Trigger.tsx","../src/utils/dom.ts","../src/primitives/BubbleSelect.tsx","../src/hooks/usePrevious.ts","../src/components/Select2/components/Search.tsx","../src/components/Select2/components/Create.tsx","../src/components/Select2/components/Collection.tsx","../src/components/Select2/Select2.tsx","../src/components/Select2/hooks/useChildren.tsx","../src/hooks/useIsFormControl.ts","../src/components/Table/util.ts","../src/components/Table/util/sortTypes.ts","../src/components/Table/hooks/plugins/useRowEditing.tsx","../src/components/Table/hooks/plugins/useRowActions.tsx","../src/components/Table/hooks/plugins/useRowDraggable.tsx","../src/components/Table/hooks/useTable.tsx","../src/components/Table/hooks/plugins/useRowSelect.tsx","../src/components/Table/hooks/useTableKeyboardNavigation.ts","../src/components/Table/util/renderRow.tsx","../src/components/Table/util/renderColumn.tsx","../src/components/Table/components/BaseTable.tsx","../src/components/Table/components/Table.tsx","../src/components/Table/components/PaginatedTable.tsx","../src/components/Table/components/WindowedTable.tsx","../src/components/Table/util/rowIndexPath.ts","../src/components/Table/hooks/useRowCreation.tsx","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/Textarea.tsx","../src/components/Switch/Switch.tsx","../src/components/Tour/Tour.tsx","../src/components/Progress/Progress.tsx","../src/components/Provider/Provider.tsx","../src/utils/hooks/useOnClickOutside.ts","../src/components/Pagination/usePagination.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-empty-function */\nimport React from 'react';\n\nexport type AlertDialogContext = {\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n};\n\nexport const AlertDialogContext = React.createContext<AlertDialogContext>({\n props: {},\n ref: null,\n});\n\nexport const useCurrentAlertDialog = () => {\n return React.useContext(AlertDialogContext);\n};\n","import React from 'react';\n\nexport function mergeRefs<T = any>(refs: Array<React.MutableRefObject<T> | React.LegacyRef<T>>): React.RefCallback<T> {\n return value => {\n refs.forEach(ref => {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref != null) {\n (ref as React.MutableRefObject<T | null>).current = value;\n }\n });\n };\n}\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport { useCurrentAlertDialog } from '../Context';\nimport { mergeRefs } from '../../../utils/mergeRefs';\n\nexport type AlertDialogTriggerProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Trigger = React.forwardRef(function AlertDialogTrigger(\n props: AlertDialogTriggerProps,\n externalRef: React.Ref<HTMLButtonElement>\n) {\n const { ref: parentRef, props: parentProps } = useCurrentAlertDialog();\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n return <AlertDialogPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild />;\n});\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\n\nexport type AlertDialogFooterProps = React.HTMLAttributes<HTMLDivElement>;\nexport const Footer = React.forwardRef(function AlertDialogFooter(props: AlertDialogFooterProps, ref: React.Ref<HTMLDivElement>) {\n const className = 'flex justify-end gap-2';\n\n return (\n <div {...props} className={className} ref={ref}>\n {props.children}\n </div>\n );\n});\n\nexport type AlertDialogCancelProps = React.HTMLAttributes<HTMLButtonElement>;\nexport const Cancel = React.forwardRef(function AlertDialogCancel(\n props: AlertDialogCancelProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n return <AlertDialogPrimitive.Cancel {...props} ref={ref} asChild />;\n});\n\nexport type AlertDialogActionProps = React.HTMLAttributes<HTMLButtonElement>;\nexport const Action = React.forwardRef(function AlertDialogAction(\n props: AlertDialogActionProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n return <AlertDialogPrimitive.Action {...props} className={props.className} ref={ref} asChild />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\n\nexport type BackdropProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Backdrop = React.forwardRef<HTMLDivElement, BackdropProps>(function Backdrop(props, ref) {\n const className = cn('fixed inset-0 cursor-default overflow-y-auto bg-blue-900/[0.3] aria-hidden:invisible', props.className);\n\n return <div {...props} className={className} data-taco=\"backdrop\" ref={ref} />;\n});\n","import { DialogSize } from './types';\n\nexport const getDialogSizeClassnames = (size: DialogSize) => {\n switch (size) {\n case 'dialog':\n return 'w-128';\n case 'xs':\n return 'w-xs';\n case 'sm':\n return 'w-sm';\n case 'md':\n return 'w-md';\n case 'lg':\n return 'w-lg';\n }\n};\n\nexport const getDialogPositionClassnames = () => 'mt-16 mx-auto';\n\nexport const getDialogStylingClassnames = () =>\n 'bg-white rounded animate-[fade-in_150ms] shadow-[0_6px_9px_0_rgba(89,85,98,0.3),0_0_1px_0_rgba(89,85,98,0.2)]';\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport cn from 'classnames';\nimport { Backdrop } from '../../Backdrop/Backdrop';\nimport { getDialogPositionClassnames, getDialogSizeClassnames, getDialogStylingClassnames } from '../../Dialog/util';\n\nexport type AlertDialogTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function AlertDialogTitle(\n props: AlertDialogTitleProps,\n ref: React.Ref<HTMLHeadingElement>\n) {\n const className = cn('text-center', props.className);\n return <AlertDialogPrimitive.Title {...props} className={className} ref={ref} />;\n});\n\nexport type AlertDialogContentProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & {\n /** An accessible label to be announced when the dialog is opened */\n 'aria-label': string;\n children: React.ReactNode;\n};\nexport const Content = React.forwardRef(function AlertDialogContent(\n props: AlertDialogContentProps,\n ref: React.Ref<HTMLDivElement>\n) {\n const className = cn('p-6', getDialogPositionClassnames(), getDialogStylingClassnames(), getDialogSizeClassnames('dialog'));\n\n return (\n <AlertDialogPrimitive.Portal>\n <AlertDialogPrimitive.Overlay asChild>\n <Backdrop>\n <AlertDialogPrimitive.Content\n {...props}\n ref={ref}\n className={className}\n onEscapeKeyDown={event => event.preventDefault()}>\n {props.children}\n </AlertDialogPrimitive.Content>\n </Backdrop>\n </AlertDialogPrimitive.Overlay>\n </AlertDialogPrimitive.Portal>\n );\n});\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport { AlertDialogContext } from './Context';\nimport { Trigger, AlertDialogTriggerProps } from './components/Trigger';\nimport {\n Cancel,\n Action,\n Footer,\n AlertDialogCancelProps,\n AlertDialogActionProps,\n AlertDialogFooterProps,\n} from './components/Footer';\nimport { Title, Content, AlertDialogContentProps, AlertDialogTitleProps } from './components/Content';\n\nexport type AlertDialogProps = {\n children: React.ReactNode | React.ReactNode[];\n /** Set whether the alert dialog is open by default or not, use when not providing a trigger */\n defaultOpen?: boolean;\n /** Called when the alert dialog opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the dialog from outside the component */\n open?: boolean;\n /** A trigger to be used for the alert dialog, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\n\nexport type ForwardedAlertDialogWithStatics = React.ForwardRefExoticComponent<\n AlertDialogProps & React.RefAttributes<HTMLElement>\n> & {\n Trigger: React.ForwardRefExoticComponent<AlertDialogTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n Content: React.ForwardRefExoticComponent<AlertDialogContentProps & React.RefAttributes<HTMLDivElement>>;\n Title: React.ForwardRefExoticComponent<AlertDialogTitleProps & React.RefAttributes<HTMLHeadingElement>>;\n Footer: React.ForwardRefExoticComponent<AlertDialogFooterProps & React.RefAttributes<HTMLDivElement>>;\n Action: React.ForwardRefExoticComponent<AlertDialogActionProps & React.RefAttributes<HTMLButtonElement>>;\n Cancel: React.ForwardRefExoticComponent<AlertDialogCancelProps & React.RefAttributes<HTMLButtonElement>>;\n};\n\nexport const AlertDialog = React.forwardRef(function AlertDialog(props: AlertDialogProps, ref: React.Ref<HTMLElement>) {\n const { children: initialChildren, defaultOpen, onChange, open, trigger, ...otherProps } = props;\n\n const context = React.useMemo(\n () => ({\n props: otherProps,\n ref,\n }),\n [open, otherProps]\n );\n\n return (\n <AlertDialogContext.Provider value={context}>\n <AlertDialogPrimitive.Root {...props} defaultOpen={defaultOpen} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {props.children}\n </AlertDialogPrimitive.Root>\n </AlertDialogContext.Provider>\n );\n}) as ForwardedAlertDialogWithStatics;\n\nAlertDialog.Trigger = Trigger;\nAlertDialog.Content = Content;\nAlertDialog.Title = Title;\nAlertDialog.Cancel = Cancel;\nAlertDialog.Action = Action;\nAlertDialog.Footer = Footer;\n","import * as React from 'react';\nfunction IconAccountPreview(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v14.5a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-4.5 7.25a4.5 4.5 0 013.632 7.158l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.5 4.5 0 11-2.495-8.245zm0 1.5a3 3 0 100 6 3 3 0 000-6zm-7 3.25a.75.75 0 110 1.5h-.5a.75.75 0 110-1.5h.5zm0-4a.75.75 0 110 1.5h-.5a.75.75 0 110-1.5h.5zm9-4a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5zm-9 0a.75.75 0 010 1.5h-.5a.75.75 0 010-1.5h.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountPreview);\n","import * as React from 'react';\nfunction IconAccountingYearCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M4.5 16.25v3a.25.25 0 00.193.243l.057.007H13V21H4.75A1.75 1.75 0 013 19.25v-3h1.5zm4.946-6.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.718-1.72H3.75a.75.75 0 01-.102-1.493L3.75 13h6.44l-1.72-1.72a.75.75 0 01-.073-.976l.073-.084a.75.75 0 01.976-.073zM16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75V13h-1.5V8h-15v3.25H3v-6.5C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5zm12.804 10.147a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountingYearCancel);\n","import * as React from 'react';\nfunction IconAccountingYear(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25v-3h1.5v3a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V8h-15v3.25H3v-6.5C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zm-6.804 8.147l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H3.75a.75.75 0 01-.102-1.493L3.75 13h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountingYear);\n","import * as React from 'react';\nfunction IconAccounting(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h12.5zM13 17.5H6.5a.5.5 0 00-.492.41L6 18v1.5a.5.5 0 00.41.492L6.5 20H13a.5.5 0 00.492-.41l.008-.09V18a.5.5 0 00-.41-.492L13 17.5zm4.5 0h-2a.5.5 0 00-.492.41L15 18v1.5a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 19.5V18a.5.5 0 00-.41-.492l-.09-.008zm-9-3.5h-2a.5.5 0 00-.492.41L6 14.5V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L9 16v-1.5a.5.5 0 00-.41-.492L8.5 14zm9 0h-2a.5.5 0 00-.492.41L15 14.5V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 16v-1.5a.5.5 0 00-.41-.492L17.5 14zM13 14h-2a.5.5 0 00-.492.41l-.008.09V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L13.5 16v-1.5a.5.5 0 00-.41-.492L13 14zm-4.5-3.5h-2a.5.5 0 00-.492.41L6 11v1.5a.5.5 0 00.41.492L6.5 13h2a.5.5 0 00.492-.41L9 12.5V11a.5.5 0 00-.41-.492L8.5 10.5zm9 0h-2a.5.5 0 00-.492.41L15 11v1.5a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 12.5V11a.5.5 0 00-.41-.492l-.09-.008zm-4.5 0h-2a.5.5 0 00-.492.41L10.5 11v1.5a.5.5 0 00.41.492L11 13h2a.5.5 0 00.492-.41l.008-.09V11a.5.5 0 00-.41-.492L13 10.5zM17.5 4h-11a.5.5 0 00-.492.41L6 4.5V8a.5.5 0 00.41.492l.09.008h11a.5.5 0 00.492-.41L18 8V4.5a.5.5 0 00-.41-.492L17.5 4zm-1 1a.5.5 0 01.5.5V7a.5.5 0 01-.5.5h-1A.5.5 0 0115 7V5.5a.5.5 0 01.5-.5h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccounting);\n","import * as React from 'react';\nfunction IconArrowBottom(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.25 18h7.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5zM12 4.5a.75.75 0 01.743.648l.007.102v8.189l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012L12 16l-.029-.002h-.023l-.021-.003-.054-.006-.07-.015-.072-.024-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.22 2.219V5.25A.75.75 0 0112 4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowBottom);\n","import * as React from 'react';\nfunction IconArrowDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 6.25a.75.75 0 01.743.648L12.75 7l-.001 8.189 2.22-2.22a.75.75 0 011.134.977l-.073.084-3.5 3.5-.038.036-.046.037h-.002l-.008.007-.081.051-.134.056-.085.02-.084.011h-.103l-.12-.018-.12-.039-.078-.038-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.219 2.218L11.25 7a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowDown);\n","import * as React from 'react';\nfunction IconArrowEnd(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.75 7.5a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm-6.554.397l.084.073 3.5 3.5c.025.024.048.05.069.078l-.069-.078.04.042.04.052.068.114.038.098.02.084.012.088v.104l-.018.119-.03.098-.047.1-.032.051-.027.038-.064.072-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.219-2.22H5.25a.75.75 0 01-.102-1.493l.102-.007h8.189l-2.22-2.22a.75.75 0 01.977-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowEnd);\n","import * as React from 'react';\nfunction IconArrowLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.03 7.97a.75.75 0 01.073.976l-.073.084-2.219 2.219L17 11.25a.75.75 0 01.102 1.493L17 12.75l-8.19-.001 2.22 2.22a.75.75 0 01-.976 1.134l-.084-.073-3.5-3.5-.08-.094-.051-.081-.05-.116-.027-.103-.01-.089v-.094l.018-.124.03-.099.047-.099.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowLeft);\n","import * as React from 'react';\nfunction IconArrowRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.946 7.897l.084.073 3.5 3.5.036.038.044.056.051.081.05.116.027.103.01.084v.103l-.018.12-.039.12-.038.078-.06.09-.063.071-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.218-2.22H7a.75.75 0 01-.102-1.493L7 11.25h8.189l-2.22-2.22a.75.75 0 01.977-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowRight);\n","import * as React from 'react';\nfunction IconArrowStart(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.25 7.5a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm7.53.47a.75.75 0 01.073.976l-.073.084-2.219 2.22h8.189a.75.75 0 01.102 1.493l-.102.007h-8.189l2.22 2.22a.75.75 0 01-.977 1.133l-.084-.073-3.5-3.5-.055-.06-.046-.065-.049-.088-.044-.12-.018-.089L8 11.965l.019-.136.03-.098.047-.1.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowStart);\n","import * as React from 'react';\nfunction IconArrowTop(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.86 8.013l.067-.01.125-.001.119.018.098.03.1.047.051.032.038.027.072.064 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219v8.189a.75.75 0 01-1.493.102l-.007-.102v-8.189l-2.22 2.22a.75.75 0 01-1.133-.977l.073-.084 3.5-3.5.042-.04.052-.04.114-.068.098-.038.084-.02zM15.75 4.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowTop);\n","import * as React from 'react';\nfunction IconArrowUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.864 6.262l.089-.01h.095l.123.018.12.039.078.038.09.06.071.063 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219V17a.75.75 0 01-1.493.102L11.25 17V8.81l-2.22 2.22a.75.75 0 01-1.133-.976l.073-.084 3.5-3.5.094-.08.081-.051.134-.056.085-.02z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowUp);\n","import * as React from 'react';\nfunction IconAttachAuto(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.916 10.159l1.06 1.06-2.663 2.665a3.75 3.75 0 005.159 5.44l.144-.137 6.657-6.657a.75.75 0 011.128.984l-.067.077-6.657 6.657a5.25 5.25 0 01-7.575-7.269l.15-.156 2.664-2.664zm11.771-6.468a3.75 3.75 0 01.137 5.16l-.137.144-9.132 9.132a2.25 2.25 0 01-3.287-3.07l.105-.112 6.657-6.657a.75.75 0 011.128.984l-.067.076-6.657 6.657a.75.75 0 00.984 1.128l.077-.067 9.132-9.132a2.25 2.25 0 00-3.07-3.287l-.112.105-2.933 2.932-1.061-1.061 2.933-2.932a3.75 3.75 0 015.303 0zM4 9a2 2 0 002 2 2 2 0 00-1.995 1.85L4 13l-.004-.132A2 2 0 002 11a2 2 0 002-2zm6-2.5a2 2 0 002 2 2 2 0 00-1.995 1.85L10 10.5l-.004-.132A2 2 0 008 8.5a2 2 0 002-2zM6.5 2c0 2.21 2.015 4 4.5 4-2.412 0-4.381 1.687-4.495 3.806L6.5 10l-.01-.263C6.338 7.65 4.386 6 2 6c2.485 0 4.5-1.79 4.5-4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttachAuto);\n","import * as React from 'react';\nfunction IconAttachCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.026 18.467a.75.75 0 01-.977 1.133l-.084-.073-2.288-2.288-3.005 3.006a5.25 5.25 0 01-7.574-7.269l.15-.156 3.005-3.005-2.288-2.288a.75.75 0 01.977-1.133l.084.073 12 12zm-9.713-7.592l-3.005 3.006a3.75 3.75 0 005.16 5.44l.144-.137 3.005-3.005-1.061-1.061-3.005 3.005a2.25 2.25 0 01-3.287-3.069l.105-.113 3.005-3.005-1.061-1.061zm2.122 2.122L8.43 16.002a.75.75 0 00.984 1.128l.076-.067 3.005-3.006-1.06-1.06zm7.894-.47a.75.75 0 01.067.984l-.067.077-1.53 1.53-1.061-1.061 1.53-1.53a.75.75 0 011.061 0zm.354-8.839a3.75 3.75 0 01.137 5.16l-.137.144-4.006 4.004-1.06-1.06 4.005-4.005a2.25 2.25 0 00-3.07-3.287l-.112.105-4.005 4.005-1.061-1.061 4.005-4.005a3.75 3.75 0 015.304 0zm-4.596 4.597a.75.75 0 01.067.983l-.067.077-1.531 1.53-1.061-1.061 1.53-1.53a.75.75 0 011.062 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttachCancel);\n","import * as React from 'react';\nfunction IconAttach(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.38 3.688a3.75 3.75 0 015.44 5.16l-.137.144-9.132 9.131a2.25 2.25 0 01-3.287-3.069l.105-.113 6.657-6.656a.75.75 0 011.128.983l-.067.077-6.657 6.657a.75.75 0 00.984 1.128l.076-.067 9.132-9.132a2.25 2.25 0 00-3.07-3.287l-.112.105-9.132 9.132a3.75 3.75 0 005.16 5.44l.144-.137 6.657-6.657a.75.75 0 011.127.984l-.067.077-6.657 6.657a5.25 5.25 0 01-7.574-7.269l.15-.156 9.131-9.132z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttach);\n","import * as React from 'react';\nfunction IconAutotextInsert(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.75 5.75a.25.25 0 00-.193-.243L14.5 5.5H14a.75.75 0 01-.102-1.493L14 4h.5c.372 0 .718.116 1.001.315.242-.17.53-.28.841-.308L16.5 4h.5l.102.007a.75.75 0 010 1.486L17 5.5h-.5l-.057.007a.25.25 0 00-.184.175l-.009.068V8h4c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 0120.25 16h-4v2.25l.007.057a.25.25 0 00.175.184l.068.009h.5l.102.007a.75.75 0 010 1.486L17 20h-.5l-.144-.006a1.74 1.74 0 01-.856-.308 1.734 1.734 0 01-.856.308L14.5 20H14a.75.75 0 01-.102-1.493L14 18.5h.5a.25.25 0 00.243-.193l.007-.057V5.75zm5.5 3.75h-4v5h4a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L20.25 9.5zM6 11a1 1 0 110 2 1 1 0 010-2zm3.5 0a1 1 0 110 2 1 1 0 010-2zm3.5 0c.087 0 .17.011.25.032v1.936A1.002 1.002 0 0112 12a1 1 0 011-1zm-9.25 5A1.75 1.75 0 012 14.25v-4.5C2 8.784 2.784 8 3.75 8h9.5v1.5h-9.5a.25.25 0 00-.243.193L3.5 9.75v4.5a.25.25 0 00.193.243l.057.007h9.5V16h-9.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAutotextInsert);\n","import * as React from 'react';\nfunction IconAutotext(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 8c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 0120.25 16H3.75A1.75 1.75 0 012 14.25v-4.5C2 8.784 2.784 8 3.75 8h16.5zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 9.75v4.5a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L20.25 9.5zM6 11a1 1 0 110 2 1 1 0 010-2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAutotext);\n","import * as React from 'react';\nfunction IconBasicTabs(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.5 12.25l1.5 1.5V21a1 1 0 01-1 1H5a1 1 0 01-1-1v-7.25l1.5-1.5v8.25h13v-8.25zm-6.875.582l.375.375.375-.375a1.591 1.591 0 112.25 2.25L12 17.707l-2.625-2.625a1.591 1.591 0 012.25-2.25zm.821-10.685l.084.073L17 6.689V5.5a.5.5 0 01.5-.5h.5a.5.5 0 01.5.5v2.689l3.03 3.03a.75.75 0 01-.976 1.134l-.084-.073L12 3.811l-8.47 8.47a.75.75 0 01-.976.072l-.084-.073a.75.75 0 01-.073-.976l.073-.084 9-9a.75.75 0 01.976-.073z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBasicTabs);\n","import * as React from 'react';\nfunction IconBasic(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M15.25 18.999V21h-2.5v-2.001h2.5zM21 16.75v2.5A1.75 1.75 0 0119.25 21h-2.5v-2.001H19V16.75h2zm-11.5-4c.966 0 1.75.784 1.75 1.75v4.75A1.75 1.75 0 019.5 21H4.75A1.75 1.75 0 013 19.25V14.5c0-.966.784-1.75 1.75-1.75H9.5zm11.5 0v2.5h-2v-2.5h2zm0-4v2.5h-2v-2.5h2zm-16 0v2.5H3v-2.5h2zM19.25 3c.966 0 1.75.784 1.75 1.75v2.5h-2V4.999h-2.25V3h2.5zm-12 0v1.999H5V7.25H3v-2.5C3 3.784 3.784 3 4.75 3h2.5zm4 0v1.999h-2.5V3h2.5zm4 0v1.999h-2.5V3h2.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBasic);\n","import * as React from 'react';\nfunction IconBellSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 19.5a2.5 2.5 0 01-4.995.164L9.5 19.5h5zM12 2c.915 0 1.686.767 1.924 1.815A6.002 6.002 0 0118 9.5V15l1.6 1.2A1 1 0 0119 18H5a1 1 0 01-.6-1.8L6 15V9.5a6.003 6.003 0 014.077-5.685C10.314 2.767 11.085 2 12 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBellSolid);\n","import * as React from 'react';\nfunction IconBook(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 4.5c1.583 0 3.165.45 4.748 1.352a.5.5 0 01.252.435V19.15a.5.5 0 01-.728.445C19.848 18.865 18.424 18.5 17 18.5c-1.667 0-3.333.5-5 1.5-1.667-1-3.333-1.5-5-1.5-1.424 0-2.848.365-4.272 1.095A.5.5 0 012 19.15V6.287a.5.5 0 01.252-.435C3.835 4.951 5.417 4.5 7 4.5c1.667 0 3.333.5 5 1.5 1.667-1 3.333-1.5 5-1.5zM17 6c-1.284 0-2.586.363-3.92 1.108l-.308.178L12 7.75l-.772-.463C9.786 6.421 8.383 6 7 6c-1.11 0-2.232.271-3.378.825l-.122.062v10.739l.056-.02a10.363 10.363 0 013.059-.598L7 17c1.585 0 3.156.382 4.704 1.134l.296.149.296-.149c1.429-.694 2.878-1.073 4.339-1.127L17 17c1.027 0 2.05.16 3.065.48l.435.147V6.887l-.122-.062c-1.041-.504-2.064-.773-3.075-.818L17 6zm0 7.75c.836 0 1.669.115 2.5.344v1.567a7.98 7.98 0 00-2.5-.411c-1.16 0-2.325.266-3.501.804v-1.627A9.628 9.628 0 0117 13.75zm0-3c.836 0 1.669.115 2.5.344v1.567a7.98 7.98 0 00-2.5-.411c-1.16 0-2.325.266-3.501.804v-1.627A9.628 9.628 0 0117 10.75zm0-3c.836 0 1.669.115 2.5.344v1.567A7.98 7.98 0 0017 9.25c-1.16 0-2.325.266-3.501.804V8.427A9.628 9.628 0 0117 7.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBook);\n","import * as React from 'react';\nfunction IconBooking(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 2a.75.75 0 01.743.648L20 2.75v18.5a.75.75 0 01-.648.743L19.25 22H6.75a2.75 2.75 0 01-2.739-3H4V5l.043.001A.749.749 0 014 4.75a2.75 2.75 0 012.582-2.745L6.75 2h12.5zm-.75 16H6.75a1.25 1.25 0 00-.128 2.494l.128.006H18.5v-.75H6.75a.5.5 0 110-1H18.5V18zM5.506 4.622L5.5 4.75a.749.749 0 01-.043.251L5.5 5v11.8a2.732 2.732 0 011-.289V3.525a1.25 1.25 0 00-.994 1.097zM18.5 3.5h-11v13h11v-13zM14.25 9a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm2-3a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBooking);\n","import * as React from 'react';\nfunction IconBudget(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.75 11c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0110.75 22h-6A1.75 1.75 0 013 20.25v-7.5c0-.966.784-1.75 1.75-1.75h6zm.25 8.5H9.5v1H11v-1zm-2.5 0h-4v1h4v-1zM14.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v9.836A1.75 1.75 0 0119.25 20H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L14 7.25V3.499L8.25 3.5a.25.25 0 00-.243.193L8 3.75V10H6.5V3.75C6.5 2.784 7.284 2 8.25 2h6.336zM11 17.5H9.5v1H11v-1zm-2.5 0H7v1h1.5v-1zm-2.5 0H4.5v1H6v-1zm10.016-6.984c.152 0 .333.058.371.263l.008.084v.242c.554.063 1.043.247 1.34.536.21.203.32.418.32.644 0 .29-.239.492-.516.492-.242 0-.437-.074-.648-.234-.328-.25-.586-.348-.93-.348-.379 0-.61.23-.61.48 0 .226.168.369.56.457l.14.028.687.121c1 .176 1.508.68 1.508 1.508 0 .908-.638 1.554-1.67 1.741l-.185.029v.175c0 .27-.207.352-.375.352-.157 0-.34-.065-.38-.269l-.007-.083v-.164c-.649-.047-1.211-.242-1.543-.558-.2-.196-.316-.41-.316-.645 0-.347.265-.543.59-.543.159 0 .308.044.495.162l.118.08c.343.254.726.395 1.043.395.48 0 .722-.203.722-.5 0-.217-.177-.353-.617-.458l-.14-.03-.672-.133c-.996-.192-1.489-.703-1.489-1.54 0-.885.638-1.523 1.633-1.683l.18-.023v-.23c0-.274.21-.348.383-.348zM11 15.5H9.5v1H11v-1zm-2.5 0H7v1h1.5v-1zm-2.5 0H4.5v1H6v-1zm5-3H4.5v2H11v-2zm4.5-7.881V7.25a.25.25 0 00.193.243l.057.007h2.631L15.5 4.619z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBudget);\n","import * as React from 'react';\nfunction IconCalendar(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2c.414 0 .75.294.75.656V3h2.25c.966 0 1.75.83 1.75 1.853v14.294C21 20.17 20.216 21 19.25 21H4.75C3.784 21 3 20.17 3 19.147V4.853C3 3.83 3.784 3 4.75 3H7v-.344C7 2.294 7.336 2 7.75 2s.75.294.75.656V3h7v-.344c0-.362.336-.656.75-.656zm3.25 6h-15v11.147c0 .125.082.23.193.258l.057.007h14.5a.254.254 0 00.243-.204l.007-.06V8zm-11 7a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm-9-4.5a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2A.5.5 0 016 12v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zM7 4.588H4.75a.254.254 0 00-.243.204l-.007.06V6.5h15V4.853a.262.262 0 00-.193-.258l-.057-.007H17v.256c0 .362-.336.656-.75.656s-.75-.294-.75-.656v-.256h-7v.256c0 .362-.336.656-.75.656S7 5.206 7 4.844v-.256z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCalendar);\n","import * as React from 'react';\nfunction IconCashAccount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 8a2 2 0 012 2v9a2 2 0 01-2 2H8a2 2 0 01-2-2v-9a2 2 0 012-2h12zm.5 5h-13v6a.5.5 0 00.41.492L8 19.5h12a.5.5 0 00.492-.41L20.5 19v-6zM12 15a.5.5 0 01.5.5V17a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1.5a.5.5 0 01.5-.5h2zm4.607-10.568L17.294 7h-1.553l-.583-2.18a.5.5 0 00-.524-.369l-.089.016L3.92 7.314a.5.5 0 00-.369.523l.016.089L5 13.276v3.905a1.992 1.992 0 01-.812-1.14l-2.07-7.727a2 2 0 011.414-2.45l10.625-2.846a2 2 0 012.45 1.414zM20 9.5H8a.5.5 0 00-.492.41L7.5 10v1.5h13V10a.5.5 0 00-.41-.492L20 9.5z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCashAccount);\n","import * as React from 'react';\nfunction IconCashReports(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm-1.143 6.234c.215 0 .434.097.48.36l.009.107v.387c.714.091 1.353.338 1.75.725.301.285.463.602.463.902 0 .355-.28.602-.618.602-.29 0-.51-.102-.779-.333-.456-.435-.843-.607-1.38-.607-.634 0-1.037.36-1.037.811 0 .372.266.62.843.762l.15.033 1.016.21c1.353.263 2.02.934 2.02 2.035 0 1.218-.86 2.076-2.251 2.304l-.193.027v.338c0 .344-.247.468-.49.468-.214 0-.437-.098-.484-.361l-.01-.107v-.327c-.816-.07-1.535-.322-1.981-.736-.301-.274-.473-.585-.473-.908 0-.419.306-.655.688-.655.236 0 .43.075.735.333.478.435 1.005.66 1.547.66.758 0 1.166-.338 1.166-.853 0-.374-.264-.605-.921-.77l-.159-.036-1.01-.22c-1.3-.269-1.955-.967-1.955-2.063 0-1.187.855-2.034 2.199-2.223l.186-.022v-.376c0-.349.247-.467.489-.467zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCashReports);\n","import * as React from 'react';\nfunction IconChatSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.557 13.056c1.474.7 2.443 1.881 2.443 3.222 0 1.294-.903 2.44-2.292 3.147l.89 1.582a.556.556 0 01-.748.761l-.084-.055-2.059-1.647a7.87 7.87 0 01-1.263.1c-2.853 0-5.205-1.506-5.52-3.444 2.666-.007 5.071-.766 6.817-1.966a7.924 7.924 0 001.802-1.682l.014-.018zM10.889 3.5c4.91 0 8.889 2.736 8.889 6.111 0 3.309-3.825 6.004-8.601 6.108l-.426.003-5.406 4.324a.556.556 0 01-.832-.706l2.398-4.262C3.999 14.074 2 12.003 2 9.61 2 6.236 5.98 3.5 10.889 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChatSolid);\n","import * as React from 'react';\nfunction IconChat(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.313 12.156c.59.664.937 1.466.937 2.344 0 1.01-.467 1.944-1.272 2.68l-.21.179.885 1.77c.174.348.174.753.01 1.096l-.068.125-.084.118c-.352.44-.948.585-1.501.347l-.127-.062-.129-.09-2.446-1.955-.233.021-.19.012-.385.009c-2.065 0-3.908-.798-4.923-2.035a13.97 13.97 0 002.216-.108c.728.397 1.667.643 2.707.643.209 0 .415-.01.619-.03l.303-.037.323-.047 2.059 1.649-.969-1.94.582-.36c.86-.533 1.333-1.252 1.333-1.985 0-.371-.122-.733-.343-1.065.3-.336.562-.69.781-1.06l.125-.219zM11 3.25c4.786 0 8.75 2.725 8.75 6.25 0 3.455-3.81 6.143-8.47 6.247l-.139.001-4.662 3.73a1.25 1.25 0 01-1.567-.004l-.1-.09-.09-.102a1.25 1.25 0 01-.174-1.27l.06-.124 1.737-3.087-.23-.106c-2.193-1.046-3.646-2.768-3.842-4.737l-.017-.228-.006-.23c0-3.525 3.964-6.25 8.75-6.25zm0 1.5c-4.05 0-7.25 2.2-7.25 4.75 0 1.679 1.397 3.263 3.66 4.119l.255.092.85.293-1.969 3.498 4.072-3.255.267.002.384-.002c3.922-.095 6.981-2.253 6.981-4.747 0-2.55-3.2-4.75-7.25-4.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChat);\n","import * as React from 'react';\nfunction IconChevronDownDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 6.47a.75.75 0 01.976-.073l.084.073L12 10.939l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 010-1.06zm0 5a.75.75 0 01.976-.073l.084.073L12 15.939l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 010-1.06z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDownDouble);\n","import * as React from 'react';\nfunction IconChevronDownSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.854 9.354l5.792 5.792a.5.5 0 00.708 0l5.792-5.792a.5.5 0 00-.353-.854H6.207a.5.5 0 00-.353.854z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDownSolid);\n","import * as React from 'react';\nfunction IconChevronDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 10.03a.75.75 0 01.976-1.133l.084.073L12 13.439l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDown);\n","import * as React from 'react';\nfunction IconChevronLeftDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.53 6.47a.75.75 0 01.073.976l-.073.084L13.061 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 011.06 0zm-5 0a.75.75 0 01.073.976l-.073.084L8.061 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeftDouble);\n","import * as React from 'react';\nfunction IconChevronLeftSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M15.5 6.207a.5.5 0 00-.854-.353l-5.792 5.792a.5.5 0 000 .708l5.792 5.792a.5.5 0 00.854-.353V6.207z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeftSolid);\n","import * as React from 'react';\nfunction IconChevronLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.97 6.47a.75.75 0 011.133.976l-.073.084L10.561 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeft);\n","import * as React from 'react';\nfunction IconChevronRightDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.47 6.47a.75.75 0 01.976-.073l.084.073 5 5 .073.084a.75.75 0 01.007.882l-.08.094-5 5-.084.073a.75.75 0 01-.882.007l-.094-.08-.073-.084a.75.75 0 01-.007-.882l.08-.094L15.939 12l-4.47-4.47-.072-.084a.75.75 0 01.073-.976zm-5 0a.75.75 0 01.976-.073l.084.073 5 5 .073.084a.75.75 0 01.007.882l-.08.094-5 5-.084.073a.75.75 0 01-.882.007l-.094-.08-.073-.084a.75.75 0 01-.007-.882l.08-.094L10.939 12l-4.47-4.47-.072-.084a.75.75 0 01.073-.976z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRightDouble);\n","import * as React from 'react';\nfunction IconChevronRightSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M8.5 17.793a.5.5 0 00.854.353l5.792-5.792a.5.5 0 000-.708L9.354 5.854a.5.5 0 00-.854.353v11.586z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRightSolid);\n","import * as React from 'react';\nfunction IconChevronRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.03 6.47a.75.75 0 00-1.133.976l.073.084L13.439 12l-4.47 4.47a.75.75 0 00-.072.976l.073.084a.75.75 0 00.976.073l.084-.073 5-5a.75.75 0 00.073-.976l-.073-.084-5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRight);\n","import * as React from 'react';\nfunction IconChevronUpDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 12.53a.75.75 0 01-.073-.976l.073-.084 5-5 .084-.073a.75.75 0 01.882-.007l.094.08 5 5 .073.084a.75.75 0 01.007.882l-.08.094-.084.073a.75.75 0 01-.882.007l-.094-.08L12 8.061l-4.47 4.47-.084.072a.75.75 0 01-.976-.073zm0 5a.75.75 0 01-.073-.976l.073-.084 5-5 .084-.073a.75.75 0 01.882-.007l.094.08 5 5 .073.084a.75.75 0 01.007.882l-.08.094-.084.073a.75.75 0 01-.882.007l-.094-.08L12 13.061l-4.47 4.47-.084.072a.75.75 0 01-.976-.073z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUpDouble);\n","import * as React from 'react';\nfunction IconChevronUpSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.854 14.646l5.792-5.792a.5.5 0 01.708 0l5.792 5.792a.5.5 0 01-.353.854H6.207a.5.5 0 01-.353-.854z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUpSolid);\n","import * as React from 'react';\nfunction IconChevronUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.53 13.97a.75.75 0 01-.976 1.133l-.084-.073L12 10.561l-4.47 4.47a.75.75 0 01-.976.072l-.084-.073a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 01.976-.073l.084.073 5 5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUp);\n","import * as React from 'react';\nfunction IconCircleClose(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zM8.641 8.641a.75.75 0 01.984-.067l.077.067L12 10.94l2.298-2.298a.75.75 0 011.128.984l-.067.077L13.06 12l2.298 2.298a.75.75 0 01-.984 1.128l-.077-.067L12 13.06l-2.298 2.298a.75.75 0 01-1.128-.984l.067-.077L10.94 12 8.641 9.702a.75.75 0 010-1.06z\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleClose);\n","import * as React from 'react';\nfunction IconCircleMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm4 7.75c.934 0 1.027 1.366.102 1.493-8 0 0 0-8.102.007-.934 0-1.027-1.366-.102-1.493z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleMinus);\n","import * as React from 'react';\nfunction IconCirclePlus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm0 3.75a.75.75 0 01.743.648L12.75 8v3.25H16a.75.75 0 01.102 1.493L16 12.75h-3.25V16a.75.75 0 01-1.493.102L11.25 16v-3.25H8a.75.75 0 01-.102-1.493L8 11.25h3.25V8a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCirclePlus);\n","import * as React from 'react';\nfunction IconCircleTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm4.403 3.867a.75.75 0 01.282.938l-.052.098-5.091 8a.75.75 0 01-1.145.145l-.074-.08-2.909-3.636a.75.75 0 011.096-1.018l.076.081 2.253 2.817 4.528-7.115a.75.75 0 011.036-.23z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleTick);\n","import * as React from 'react';\nfunction IconClampOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.03 12.97a.75.75 0 01.073.976l-.073.084-5.72 5.72H8.5a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007-5.051-.002-.12-.018-.068-.019-.06-.023-.07-.035-.082-.054-.08-.07a.749.749 0 01-.096-.118l-.05-.09-.04-.103a.737.737 0 01-.026-.116L2.75 20.5v-5a.75.75 0 011.493-.102l.007.102-.001 3.189 5.72-5.72a.75.75 0 011.061 0zm4.368-10.213l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L19.75 8.5V5.31l-5.72 5.72a.75.75 0 01-1.133-.976l.073-.084 5.718-5.72H15.5a.75.75 0 01-.743-.648L14.75 3.5a.75.75 0 01.648-.743z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClampOpen);\n","import * as React from 'react';\nfunction IconClamp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.398 12.757l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9.75 18.5v-3.19l-5.72 5.72a.75.75 0 01-1.133-.976l.073-.084 5.718-5.72H5.5a.75.75 0 01-.743-.648L4.75 13.5a.75.75 0 01.648-.743zM21.03 2.97a.75.75 0 01.073.976l-.073.084-5.72 5.72h3.19a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007-5.051-.002-.12-.018-.068-.019-.06-.023-.07-.035-.082-.054-.08-.07a.749.749 0 01-.096-.118l-.05-.09-.04-.103a.737.737 0 01-.026-.116l-.007-.102v-5a.75.75 0 011.493-.102l.007.102v3.188l5.72-5.718a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClamp);\n","import * as React from 'react';\nfunction IconClose(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.554 6.397a.75.75 0 011.049 1.05l-.073.083L13.061 12l4.47 4.47a.75.75 0 01-.977 1.133l-.084-.073L12 13.061l-4.47 4.47-.084.072a.75.75 0 01-1.049-1.05l.073-.083L10.939 12l-4.47-4.47a.75.75 0 01.977-1.133l.084.073L12 10.939l4.47-4.47.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClose);\n","import * as React from 'react';\nfunction IconConnectionEnable(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19 9a3 3 0 11-2.877 3.854H7.877A3.001 3.001 0 012 12a3 3 0 015.93-.647h8.14A3.001 3.001 0 0119 9zM5 10.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm14 0a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconConnectionEnable);\n","import * as React from 'react';\nfunction IconConnectionRevoke(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.66 4.174a.75.75 0 01.32.933l-.045.091-8.298 14.373a.75.75 0 01-1.344-.659l.045-.091 8.298-14.373a.75.75 0 011.025-.274zM5 9a3.001 3.001 0 012.935 2.374.685.685 0 01.169-.02h1.814l-.866 1.5h-.948a.75.75 0 01-.22-.033A2.998 2.998 0 012 12a3 3 0 013-3zm14 0a3 3 0 11-2.877 3.854h-1.875l.866-1.5.956-.001A3.001 3.001 0 0119 9zM5 10.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm14 0a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconConnectionRevoke);\n","import * as React from 'react';\nfunction IconContacts(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V18h-.5a.75.75 0 110-1.5H4v-3.75h-.5a.75.75 0 110-1.5H4V8h-.5a.75.75 0 010-1.5H4V3.75C4 2.784 4.784 2 5.75 2h12.5zm0 1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6.5H6A.75.75 0 016 8h-.5v3.25H6a.75.75 0 110 1.5h-.5v3.75H6A.75.75 0 116 18h-.5v2.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5zM11.866 12c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0114.482 18H9.25a1.75 1.75 0 01-1.724-2.05c.46-2.634 1.906-3.95 4.34-3.95zm0-5.5c1.104 0 2 1.12 2 2.5s-.896 2.5-2 2.5c-1.105 0-2-1.12-2-2.5s.895-2.5 2-2.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconContacts);\n","import * as React from 'react';\nfunction IconCopy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6 5v1.5h-.25a.25.25 0 00-.243.193L5.5 6.75v13.5a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V20H17v.25A1.75 1.75 0 0115.25 22h-9.5A1.75 1.75 0 014 20.25V6.75C4 5.784 4.784 5 5.75 5H6zm7.586-3a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0118.25 19h-9.5A1.75 1.75 0 017 17.25V3.75C7 2.784 7.784 2 8.75 2h4.836zM13 3.5H8.75a.25.25 0 00-.243.193L8.5 3.75v13.5a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm1.5 1.121V7.25a.25.25 0 00.193.243l.057.007h2.629L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCopy);\n","import * as React from 'react';\nfunction IconCourses(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.441 3.441a1.25 1.25 0 01.983-.058l.135.058 9.598 4.799a.85.85 0 01.464.859l-.001 6.151a.75.75 0 11-1.5 0v-4.971L19 11.339V17.5c0 1.657-3.134 3-7 3-3.772 0-6.847-1.278-6.994-2.88L5 17.5v-6.162L1.842 9.76a.85.85 0 01-.421-1.042l.041-.098a.85.85 0 01.286-.325l.094-.055 9.598-4.799zm-4.942 8.647v5.395c.009.095.385.448 1.217.791C8.82 18.73 10.351 19 12 19c1.689 0 3.253-.284 4.359-.757.472-.203.822-.425 1.023-.629l.11-.117c.003-.003.005-.004.006-.003l.002.006v-5.411l-4.941 2.47a1.25 1.25 0 01-.983.058l-.135-.058-4.942-2.471zM12 4.838L3.677 8.999l8.322 4.162 8.323-4.162L12 4.838z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCourses);\n","import * as React from 'react';\nfunction IconCredit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.499 15l.001 5.25a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V20H18v.25A1.75 1.75 0 0116.25 22h-9.5A1.75 1.75 0 015 20.25L4.999 15h1.5zm8.087-13a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0119.25 19h-9.5A1.75 1.75 0 018 17.25L7.999 15h1.5l.001 2.25a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057L19.499 9H15.75a1.75 1.75 0 01-1.744-1.606L14 7.25l-.001-3.75H9.75a.25.25 0 00-.243.193L9.5 3.75 9.499 5h-1.5L8 3.75C8 2.784 8.784 2 9.75 2h4.836zM4.392 8.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082L4.341 9.03l.051-.074zM8.25 6a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528A2.5 2.5 0 006.711 8.03a.75.75 0 11-.925-1.181A3.985 3.985 0 018.25 6zm7.249-1.38l.001 2.63a.25.25 0 00.193.243l.057.007h2.629l-2.88-2.88z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCredit);\n","import * as React from 'react';\nfunction IconDeletePermanently(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2a4.5 4.5 0 014.472 4h-1.514a3 3 0 00-5.917 0H20.25a.75.75 0 110 1.5h-.75V18a4 4 0 01-4 4h-7a4 4 0 01-4-4V7.5h-.75a.75.75 0 010-1.5h3.777A4.5 4.5 0 0112 2zm6 5.5H6V18a2.5 2.5 0 002.336 2.495l.164.005h7a2.5 2.5 0 002.495-2.336L18 18V7.5zm-3.946 3.397a.75.75 0 011.049 1.05l-.073.083L13.061 14l1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073L12 15.061l-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083L10.939 14l-1.97-1.97a.75.75 0 01.977-1.133l.084.073L12 12.939l1.97-1.97.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDeletePermanently);\n","import * as React from 'react';\nfunction IconDelete(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2a4.5 4.5 0 014.472 4h3.778a.75.75 0 110 1.5h-.75V18a4 4 0 01-4 4h-7a4 4 0 01-4-4V7.5h-.75a.75.75 0 010-1.5h3.777A4.5 4.5 0 0112 2zm6 5.5H6V18a2.5 2.5 0 002.336 2.495l.164.005h7a2.5 2.5 0 002.495-2.336L18 18V7.5zm-8.25 2a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm4.5 0a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zM12 3.5A3 3 0 009.041 6h5.917A3 3 0 0012 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDelete);\n","import * as React from 'react';\nfunction IconDepecriate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H17v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V8h-15v11.25a.25.25 0 00.193.243l.057.007H7V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM12 11.25a.75.75 0 01.743.648l.007.102v6.439l1.72-1.72a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 1.72 1.719V12a.75.75 0 01.75-.75zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDepecriate);\n","import * as React from 'react';\nfunction IconDeveloper(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.303 2.787a1.25 1.25 0 01.934 1.39l-.024.126-4 16a1.25 1.25 0 01-2.45-.48l.024-.126 4-16a1.25 1.25 0 011.516-.91zM7.05 5.04a1.25 1.25 0 01.242 1.65l-.082.11L2.877 12l4.333 5.2a1.25 1.25 0 01-.06 1.667l-.1.093a1.25 1.25 0 01-1.667-.06l-.093-.1-5-6a1.25 1.25 0 01-.083-1.49l.083-.11 5-6a1.25 1.25 0 011.76-.16zm9.9 0a1.25 1.25 0 011.667.06l.093.1 5 6 .083.11a1.25 1.25 0 010 1.38l-.083.11-5 6-.093.1a1.25 1.25 0 01-1.558.142l-.11-.082-.1-.093a1.25 1.25 0 01-.14-1.558l.08-.11L21.124 12 16.79 6.8l-.082-.11a1.25 1.25 0 01.242-1.65z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDeveloper);\n","import * as React from 'react';\nfunction IconDistributionTemplate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.5 17a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-1 1.5h-2v2h2v-2zm-5-14.75a.75.75 0 01.102 1.493l-.102.007H13a.25.25 0 00-.243.193l-.007.057v5.75h1.75a.75.75 0 01.102 1.493l-.102.007h-1.75v5.75a.25.25 0 00.193.243l.057.007h1.5a.75.75 0 01.102 1.493l-.102.007H13a1.75 1.75 0 01-1.744-1.606l-.006-.144v-5.75H9.5a.75.75 0 01-.102-1.493l.102-.007h1.75V5.5a1.75 1.75 0 011.606-1.744L13 3.75h1.5zm6 5.75a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-13 0a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4A.5.5 0 013 14v-4a.5.5 0 01.5-.5h4zm12 1.5h-2v2h2v-2zm-13 0h-2v2h2v-2zm14-9a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-1 1.5h-2v2h2v-2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDistributionTemplate);\n","import * as React from 'react';\nfunction IconDocumentApprove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm6.194 13.72a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 2.47 2.469 4.47-4.47a.75.75 0 011.06 0zm-2.4-8.22L14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentApprove);\n","import * as React from 'react';\nfunction IconDocumentCreateEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V13h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm2.164 11.5a.75.75 0 01.743.648l.007.102V17h2.75a.75.75 0 01.102 1.493l-.102.007H16.5v2.75a.75.75 0 01-1.493.102L15 21.25V18.5h-2.75a.75.75 0 01-.102-1.493L12.25 17H15v-2.75a.75.75 0 01.75-.75zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentCreateEntry);\n","import * as React from 'react';\nfunction IconDocumentCut(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.95 11.146l2.219 3.843.868.234a2.5 2.5 0 111.826 2.042l-1.633-.438.845 1.464a2.5 2.5 0 11-2.444-1.235l-.45-.778-4.287-1.148a.75.75 0 11.388-1.45l2.839.761-1.47-2.545a.75.75 0 011.3-.75zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V11h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.176 16.675a1 1 0 101 1.732 1 1 0 00-1-1.732zm3.134-4.084a1 1 0 101.932.518 1 1 0 00-1.932-.518zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentCut);\n","import * as React from 'react';\nfunction IconDocumentError(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm-1 12.91c.516 0 .935.333.935.849 0 .515-.42.848-.935.848-.516 0-.94-.333-.94-.848 0-.516.424-.849.94-.849zm0-5.978c.509 0 .883.352.917.807l.001.106-.15 3.62a.754.754 0 01-.768.736.757.757 0 01-.768-.632l-.01-.104-.135-3.62c-.022-.505.37-.913.913-.913zm2.5-5.811V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentError);\n","import * as React from 'react';\nfunction IconDocumentIsolatePage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v4.336h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h5V22h-5A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm5.664 12.25a.75.75 0 01.743.648L20 15v4.5a.75.75 0 01-1.493.102L18.5 19.5v-2.69l-4.97 4.97a.75.75 0 01-1.133-.976l.073-.084 4.968-4.97H14.75a.75.75 0 01-.743-.648L14 15a.75.75 0 01.648-.743l.102-.007h4.5zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentIsolatePage);\n","import * as React from 'react';\nfunction IconDocumentMerge(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.586 2a1 1 0 01.707.293l3.414 3.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0119.25 17H15v3.25A1.75 1.75 0 0113.25 22h-8.5A1.75 1.75 0 013 20.25V8.75C3 7.784 3.784 7 4.75 7H9V3.75C9 2.784 9.784 2 10.75 2h5.836zM15.5 3.499l-4.75.001a.25.25 0 00-.243.193l-.007.057V7h1v1.5h-1V10H9V8.5H4.75a.25.25 0 00-.243.193L4.5 8.75v11.5a.25.25 0 00.193.243l.057.007h8.5a.25.25 0 00.243-.193l.007-.057V17h-1v-1.5h1V14H15v1.5h4.25a.25.25 0 00.243-.193l.007-.057V7.5h-2.25a1.75 1.75 0 01-1.744-1.606L15.5 5.75V3.499zM10.5 14v1.25a.25.25 0 00.193.243l.057.007h.75V17h-.75A1.75 1.75 0 019 15.25V14h1.5zm4.5-3v2h-1.5v-2H15zm-4.5 0v2H9v-2h1.5zm2-4h.75c.966 0 1.75.784 1.75 1.75V10h-1.5V8.75a.25.25 0 00-.193-.243L13.25 8.5h-.75V7zM17 4.12v1.63a.25.25 0 00.193.243L17.25 6h1.631L17 4.12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentMerge);\n","import * as React from 'react';\nfunction IconDocumentMove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V12h1.5v8.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5h-2V2h2.586zM4.433 7.25a.5.5 0 01-.717.661l-.07-.057-1-1-.057-.07a.5.5 0 010-.568l.057-.07 1-1 .07-.057a.5.5 0 01.568 0l.07.057.057.07a.5.5 0 01.022.535L6.25 5.75V3.933a.5.5 0 01-.534-.022l-.07-.057a.5.5 0 01-.057-.638l.057-.07 1-1 .07-.057a.5.5 0 01.568 0l.07.057 1 1 .057.07a.5.5 0 010 .568l-.057.07-.07.057a.5.5 0 01-.534.022V5.75h1.817a.5.5 0 01.022-.534l.057-.07a.5.5 0 01.638-.057l.07.057 1 1a.5.5 0 01.057.638l-.057.07-1 1a.5.5 0 01-.787-.604H7.75v1.817a.5.5 0 01.534.022l.07.057a.5.5 0 01.057.638l-.057.07-1 1a.5.5 0 01-.638.057l-.07-.057-1-1a.5.5 0 01.605-.787L6.25 7.25H4.433zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentMove);\n","import * as React from 'react';\nfunction IconDocumentPreview(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm.164 10.75a3 3 0 100 6 3 3 0 000-6zm.75-8.129V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621zm-.75 15.629a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentPreview);\n","import * as React from 'react';\nfunction IconDocumentReceived(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V17H20v3.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.032 9.147a.75.75 0 01.882-.007l.094.08.073.084a.75.75 0 01.007.882l-.08.094L12.811 14h6.439l.102.007a.75.75 0 010 1.486l-.102.007h-6.439l1.72 1.72.072.084a.75.75 0 01-1.05 1.049l-.083-.073-3-3-.073-.084a.75.75 0 01-.007-.882l.08-.094 3-3 .084-.073zm.946-6.526V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentReceived);\n","import * as React from 'react';\nfunction IconDocumentRejectedRequest(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm5.218 13.647a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentRejectedRequest);\n","import * as React from 'react';\nfunction IconDocumentSplit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 14v6.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V14h4v1.5H5.5v4.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V15.5H16V14h4zm-6 0v1.5h-4V14h4zm0-3v1.5h-4V11h4zm.5-6.379V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621zM4 3.75C4 2.784 4.784 2 5.75 2h7.836a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12.5h-4V11h2.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V11H8v1.5H4V3.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentSplit);\n","import * as React from 'react';\nfunction IconDocumentTime(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V10H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM10 10a6 6 0 110 12 6 6 0 010-12zm0 1.5a4.5 4.5 0 100 9 4.5 4.5 0 000-9zm0 .75a.75.75 0 01.743.648l.007.102v3a.75.75 0 01-.648.743L10 16.75H8a.75.75 0 01-.102-1.493L8 15.25l1.25-.001V13a.75.75 0 01.648-.743L10 12.25zm4.5-7.629V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentTime);\n","import * as React from 'react';\nfunction IconDocument(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm2.5 12.25a.75.75 0 01.102 1.493l-.102.007h-7a.75.75 0 01-.102-1.493l.102-.007h7zm0-4a.75.75 0 01.102 1.493l-.102.007h-7a.75.75 0 01-.102-1.493l.102-.007h7zm-1-7.129V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocument);\n","import * as React from 'react';\nfunction IconDownload(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 16.25a.75.75 0 01.743.648L21 17v1.25a3.75 3.75 0 01-3.55 3.745l-.2.005H6.75a3.75 3.75 0 01-3.745-3.55L3 18.25V17a.75.75 0 011.493-.102L4.5 17v1.25a2.25 2.25 0 002.096 2.245l.154.005h10.5a2.25 2.25 0 002.245-2.096l.005-.154V17a.75.75 0 01.75-.75zm-3.5.75a.75.75 0 110 1.5h-9.5a.75.75 0 110-1.5h9.5zM12 2a.75.75 0 01.743.648l.007.102v9.189l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012L12 14.5l-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.22 2.219V2.75A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDownload);\n","import * as React from 'react';\nfunction IconDrag(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.5 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDrag);\n","import * as React from 'react';\nfunction IconECopedia(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 4c1.583 0 3.165.45 4.748 1.352a.5.5 0 01.252.435V18.65a.5.5 0 01-.728.445C19.848 18.365 18.424 18 17 18c-1.667 0-3.333.5-5 1.5-1.667-1-3.333-1.5-5-1.5-1.424 0-2.848.365-4.272 1.095A.5.5 0 012 18.65V5.787a.5.5 0 01.252-.435C3.835 4.451 5.417 4 7 4c1.667 0 3.333.5 5 1.5 1.667-1 3.333-1.5 5-1.5zM7 13.5c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 13.677 8.226 13.5 7 13.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928c-.897-.359-1.96-.536-3.186-.536zm-10-3c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 10.677 8.226 10.5 7 10.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928c-.897-.359-1.96-.536-3.186-.536zm-10-3c-1.227 0-2.289.177-3.186.536a.5.5 0 00.372.928C4.956 8.656 5.893 8.5 7 8.5s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 7.677 8.226 7.5 7 7.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 00.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C19.289 7.677 18.226 7.5 17 7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconECopedia);\n","import * as React from 'react';\nfunction IconESignature(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13 2v5.25l.006.144a1.75 1.75 0 001.593 1.6L14.75 9H20v11.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2H13zm-3 7.75c-1.572 0-2.858 1.745-3.337 3.877l-.048.23-.039.217c-.138.832-.124 1.608.046 2.26l.07.238.055.148-.191.101c-.33.166-.672.305-1.025.413a.75.75 0 00.339 1.457l.1-.023.281-.092c.35-.122.691-.268 1.02-.435l.325-.174.098-.059.02.014c.302.18.66.293 1.074.32L9 18.25l.255-.004c1.076-.038 1.983-.315 2.706-.82l.193-.145.124-.104.014.052c.044.14.098.262.164.369l.069.102.086.107c.579.665 1.275.432 2.018-.32l.117-.122.102-.115.021.104c.043.2.09.356.163.512.209.456.598.755 1.132.708.582-.052 1.196-.55 2.042-1.612l.162-.206.32-.425.17-.23a.75.75 0 00-1.144-.965l-.071.085-.293.396-.28.362-.251.308-.22.256-.187.205-.11.112-.082-.493-.042-.199-.024-.09c-.083-.294-.201-.52-.436-.692-.598-.437-1.122-.163-1.695.514l-.258.312-.107.118-.007-.214a12.73 12.73 0 01.094-1.533c.1-.89-1.135-1.152-1.438-.372l-.033.103-.057.203c-.397 1.321-1.216 2.03-2.562 2.195l-.217.022-.176.009.199-.19a8.876 8.876 0 001.813-2.556c1.013-2.18.695-4.247-1.274-4.247zm0 1.5c.406 0 .531.695-.005 1.934l-.081.181-.116.237a7.434 7.434 0 01-1.401 1.893l-.25.236-.105.089-.032-.177c-.06-.406-.037-.911.077-1.5C8.402 12.53 9.306 11.25 10 11.25zm4.5-4V2L20 7.5h-5.25l-.057-.007a.25.25 0 01-.184-.175L14.5 7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconESignature);\n","import * as React from 'react';\nfunction IconEdit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 20.5a.75.75 0 110 1.5H3.75a.75.75 0 110-1.5h16.5zM16.013 2.927a1.75 1.75 0 012.35-.114l.124.114 1.586 1.586a1.75 1.75 0 01.114 2.35l-.114.124L8.061 19H4v-4.06L16.013 2.926zM14.499 6.56l-8.999 9v1.94h1.938l9-9-1.939-1.94zm2.928-2.573a.25.25 0 00-.3-.04l-.054.04L15.56 5.5l1.939 1.94 1.514-1.512a.25.25 0 00.065-.24l-.025-.06-.04-.054-1.586-1.586z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEdit);\n","import * as React from 'react';\nfunction IconEllipsisHorizontal(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 10.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm10 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEllipsisHorizontal);\n","import * as React from 'react';\nfunction IconEllipsisVertical(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEllipsisVertical);\n","import * as React from 'react';\nfunction IconEntriesOnAccount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-2.25 9.5a.75.75 0 110 1.5H6.75a.75.75 0 110-1.5h10.5zm0-3.5a.75.75 0 110 1.5H6.75a.75.75 0 110-1.5h10.5zm0-3.5a.75.75 0 110 1.5H6.75a.75.75 0 010-1.5h10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesOnAccount);\n","import * as React from 'react';\nfunction IconEntriesOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-7.25 2a.5.5 0 01.5.5v9a.5.5 0 01-.5.5h-.5a.5.5 0 01-.5-.5v-9a.5.5 0 01.5-.5h.5zm-3.5 7.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 010 1.5h-2a.75.75 0 010-1.5h2zm8.5 0a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesOpen);\n","import * as React from 'react';\nfunction IconEntriesWarning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.75 12.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm.5-9.5c.966 0 1.75.784 1.75 1.75l.001 6.687a5.96 5.96 0 00-1.5-.39L19.5 6h-15v13.25a.25.25 0 00.193.243l.057.007h8.544a5.99 5.99 0 00.985 1.5H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-.5 16a.75.75 0 100 1.5.75.75 0 000-1.5zm0-5.5a.75.75 0 00-.743.648L18 14.25v3.5a.75.75 0 001.493.102l.007-.102v-3.5a.75.75 0 00-.75-.75zM12.25 8a.5.5 0 01.5.5v9a.5.5 0 01-.5.5h-.5a.5.5 0 01-.5-.5v-9a.5.5 0 01.5-.5h.5zm-3.5 7.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 010 1.5h-2a.75.75 0 010-1.5h2zm8.5 0a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesWarning);\n","import * as React from 'react';\nfunction IconEntryTypeCustomerInvoice(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm.25-12.5a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h7.525c.464 0 .91.184 1.238.513l3.974 3.974c.329.329.513.774.513 1.238V18.25A1.75 1.75 0 0119.25 20h-6.038l-.01-.063a11.184 11.184 0 00-.369-1.437h6.417a.25.25 0 00.243-.193l.007-.057v-10h-3a1.75 1.75 0 01-1.744-1.606L14.75 6.5v-3h-7zm-.25 7c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm9.75 3a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zm0-3a.75.75 0 110 1.5h-6a.75.75 0 110-1.5h6zm1.378-3.75L16.25 4.371V6.5a.25.25 0 00.193.243l.057.007h2.128z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeCustomerInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeCustomerPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm14.263-3.75c.155.24.237.491.237.75 0 1.272-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-1.25 0-2.43-.122-3.466-.339a4.583 4.583 0 00-1.063-.672c.175-.294.313-.626.404-.984.945.25 2.042.417 3.225.474l.612.019.288.002.453-.006c3.293-.078 6.014-1.006 6.81-2.243zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm14.263-1.75c.155.24.237.491.237.75 0 1.272-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-1.524 0-2.941-.182-4.125-.494a3.637 3.637 0 00-.68-1.398 3.187 3.187 0 00-.47-.478c1.163.463 2.705.773 4.423.85l.564.018.288.002.453-.006c3.293-.078 6.014-1.006 6.81-2.243zM14.5 3c.77 0 1.514.046 2.214.133l.516.072C20.022 3.642 22 4.728 22 6s-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-.77 0-1.514-.046-2.214-.133l-.516-.072C8.978 8.358 7 7.272 7 6s1.978-2.358 4.77-2.795l.516-.072A18.02 18.02 0 0114.5 3zm0 1.5c-1.835 0-3.538.288-4.746.771-.456.183-.81.381-1.042.57L8.538 6l.082.078c.225.212.613.442 1.134.65 1.208.484 2.91.772 4.746.772 1.835 0 3.538-.288 4.746-.771.456-.183.81-.381 1.042-.57L20.461 6l-.081-.078c-.225-.212-.613-.442-1.134-.65-1.208-.484-2.91-.772-4.746-.772z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeCustomerPayment);\n","import * as React from 'react';\nfunction IconEntryTypeJournalEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.275 17.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM14.25 3c.966 0 1.75.784 1.75 1.75V9c-.516 0-1.018.026-1.5.074V5.5h-11v10.75a.25.25 0 00.193.243l.057.007H9V18H3.75A1.75 1.75 0 012 16.25V4.75C2 3.784 2.784 3 3.75 3h10.5zm-3.975 11.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM16 10c3.314 0 6 1.12 6 2.5S19.314 15 16 15s-6-1.12-6-2.5 2.686-2.5 6-2.5zm-8.25 3a.75.75 0 110 1.5h-1.5a.75.75 0 110-1.5h1.5zM16 11.5c-1.425 0-2.742.232-3.666.617a3.354 3.354 0 00-.65.347l-.048.036.048.036c.126.091.292.186.493.278l.157.07c.924.384 2.24.616 3.666.616 1.425 0 2.742-.232 3.666-.617.273-.114.492-.233.65-.347l.047-.037-.047-.035a3.044 3.044 0 00-.493-.278l-.157-.07c-.924-.384-2.24-.616-3.666-.616zM8.25 10a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm3.5-3a.75.75 0 110 1.5h-5.5a.75.75 0 010-1.5h5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeJournalEntry);\n","import * as React from 'react';\nfunction IconEntryTypeManualCustomerInvoice(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.371 18.835l1.564 1.565a.998.998 0 010 1.414l-.392.393a.996.996 0 01-1.414 0l-1.565-1.565 1.807-1.807zM7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm7.5 2.5l1.498 1.5h-3.286l-.01-.063a11.184 11.184 0 00-.369-1.437H15zm.453-4.586l4.212 4.213-1.808 1.808-4.21-4.213-.005-1.762 1.811-.046zM15.275 2c.464 0 .91.184 1.238.513l3.974 3.974c.329.329.513.774.513 1.238v10.334l-1.5-1.501V8.25h-3a1.75 1.75 0 01-1.744-1.606L14.75 6.5v-3h-7a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h7.525zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm7.25 1a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm1.5-7.129V6.5a.25.25 0 00.193.243l.057.007h2.128L16.25 4.371z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeManualCustomerInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeSupplierInvoice(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.5 8l3 3v8.25A1.75 1.75 0 0120.75 21h-7.5a1.75 1.75 0 01-1.75-1.75v-9.5c0-.966.784-1.75 1.75-1.75h6.25zm-1 1.5h-5.25a.25.25 0 00-.243.193L13 9.75v9.5a.25.25 0 00.193.243l.057.007h7.5a.25.25 0 00.243-.193L21 19.25V12h-2.5V9.5zm.25 7a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM6.25 14a1.5 1.5 0 110 3 1.5 1.5 0 010-3zM18 3a1.75 1.75 0 011.744 1.606l.006.144V7h-6.27a3.11 3.11 0 00-1.955.675l-.152.13a2.654 2.654 0 00-.866 1.757l-.007.188v5.5H8.738a2.5 2.5 0 00-2.324-2.245L6.25 13a2.5 2.5 0 00-2.488 2.25H2.25l-.102-.007a.75.75 0 01-.641-.641L1.5 14.5V9.929l.008-.108a.75.75 0 01.112-.3l.066-.086 3-3.429.076-.075a.75.75 0 01.381-.173l.107-.008h2.5v-1a1.75 1.75 0 011.606-1.744L9.5 3H18zm.75 10.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM7 7.25H5.59L4 9.068V10h3V7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeSupplierInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeSupplierPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.775 17.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zm0-3c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM6.25 14a1.5 1.5 0 110 3 1.5 1.5 0 010-3zM18 3a1.75 1.75 0 011.744 1.606l.006.144.001 4.617A13.959 13.959 0 0016.5 9c-1.809 0-3.443.316-4.627.81-.695.289-1.247.646-1.628 1.029-.458.46-.695.97-.738 1.488L9.5 12.5v2.75h-.762a2.5 2.5 0 00-2.324-2.245L6.25 13a2.5 2.5 0 00-2.488 2.25H2.25l-.102-.007a.75.75 0 01-.641-.641L1.5 14.5V9.929l.008-.108a.75.75 0 01.112-.3l.066-.086 3-3.429.076-.075a.75.75 0 01.381-.173l.107-.008h2.5v-1a1.75 1.75 0 011.606-1.744L9.5 3H18zm-1.5 7c3.314 0 6 1.12 6 2.5s-2.686 2.5-6 2.5-6-1.12-6-2.5 2.686-2.5 6-2.5zm0 1.5c-1.425 0-2.742.232-3.666.617a3.354 3.354 0 00-.65.347l-.048.036.048.036c.126.091.292.186.493.278l.157.07c.924.384 2.24.616 3.666.616 1.425 0 2.742-.232 3.666-.617.273-.114.492-.233.65-.347l.047-.037-.047-.035a3.044 3.044 0 00-.493-.278l-.157-.07c-.924-.384-2.24-.616-3.666-.616zM7 7.25H5.59L4 9.068V10h3V7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeSupplierPayment);\n","import * as React from 'react';\nfunction IconEnvelopeApproved(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v6.14l-1.5-.001v-5.55l-8.04 6.253a.75.75 0 01-.826.062l-.094-.062L3.5 6.339V18.25a.25.25 0 00.193.243l.057.007H12V20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm1.53 9.72a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 2.47 2.469 4.47-4.47a.75.75 0 011.06 0zM19.134 5.5H4.865L12 11.049 19.134 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEnvelopeApproved);\n","import * as React from 'react';\nfunction IconEnvelope(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm.25 2.339l-8.04 6.253a.75.75 0 01-.826.062l-.094-.062L3.5 6.339V18.25a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V6.339zM19.134 5.5H4.865L12 11.049 19.134 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEnvelope);\n","import * as React from 'react';\nfunction IconExpandView(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v5.75H3V4.75C3 3.784 3.784 3 4.75 3h14.5zm-9 9c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0110.25 21h-5.5A1.75 1.75 0 013 19.25v-5.5c0-.966.784-1.75 1.75-1.75h5.5zm0 1.5h-5.5a.25.25 0 00-.243.193l-.007.057v5.5a.25.25 0 00.193.243l.057.007h5.5a.25.25 0 00.243-.193l.007-.057v-5.5a.25.25 0 00-.193-.243l-.057-.007zm7.25-7.75a.75.75 0 01.743.648l.007.102V10a.75.75 0 01-1.493.102L16.75 10V8.31l-3.22 3.22a.75.75 0 01-1.133-.976l.073-.084 3.218-3.22H14a.75.75 0 01-.743-.648L13.25 6.5a.75.75 0 01.648-.743L14 5.75h3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExpandView);\n","import * as React from 'react';\nfunction IconExpenses(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2a1.75 1.75 0 011.744 1.606L20 3.75v16a.75.75 0 01-.177.484l-.074.076-1.813 1.613a.75.75 0 01-.908.068l-.089-.068-1.314-1.17-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068L12 20.753l-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068-1.314-1.17-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068-1.813-1.613a.75.75 0 01-.243-.454L4 19.75v-16a1.75 1.75 0 011.606-1.744L5.75 2h12.5zm0 1.5H5.75a.25.25 0 00-.243.193L5.5 3.75v15.662l1.063.946 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.062-.945V3.75a.25.25 0 00-.13-.22l-.063-.023-.057-.007zm-2.5 9.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5h7.5zm-3-3.5a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm3-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExpenses);\n","import * as React from 'react';\nfunction IconExportToExcel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H12.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v8.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.648 14.507l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9 20.25v-3.19l-4.72 4.72a.75.75 0 01-1.133-.976l.073-.084L7.938 16H4.75a.75.75 0 01-.743-.648L4 15.25a.75.75 0 01.648-.743zM16.5 16.5v2h-4v-2h4zm0-3v2h-4v-2h4zm-5-3v2h-4v-2h4zm5 0v2h-4v-2h4zm-2-5.879V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExportToExcel);\n","import * as React from 'react';\nfunction IconExportToPdf(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H12.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v8.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.648 14.507l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9 20.25v-3.19l-4.72 4.72a.75.75 0 01-1.133-.976l.073-.084L7.938 16H4.75a.75.75 0 01-.743-.648L4 15.25a.75.75 0 01.648-.743zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExportToPdf);\n","import * as React from 'react';\nfunction IconExport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.5 7.999V9.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5H15.5V7.999L18.25 8c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8l2.75-.001zM11.992 2l.1.006.076.013.08.023.107.047.091.058.084.073 3 3a.75.75 0 01-.976 1.133l-.084-.073-1.72-1.719V15.25a.75.75 0 01-1.493.102l-.007-.102V4.561l-1.72 1.72a.75.75 0 01-1.133-.977l.073-.084 3-3a.753.753 0 01.125-.101l.088-.049.119-.043.106-.021A.754.754 0 0111.992 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExport);\n","import * as React from 'react';\nfunction IconFilterSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 2a.75.75 0 01.75.75v2a.75.75 0 01-.15.45l-5.7 7.6a.75.75 0 00-.15.45v6.725a.75.75 0 01-.494.705l-4 1.454A.75.75 0 019.5 21.43v-8.163a.75.75 0 00-.168-.473L3.168 5.207A.75.75 0 013 4.734V2.75A.75.75 0 013.75 2h16.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconFilterSolid);\n","import * as React from 'react';\nfunction IconFilter(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 2a.75.75 0 01.75.75v2a.75.75 0 01-.15.45l-5.7 7.6a.75.75 0 00-.15.45v6.725a.75.75 0 01-.494.705l-4 1.454A.75.75 0 019.5 21.43v-8.163a.75.75 0 00-.168-.473L3.168 5.207A.75.75 0 013 4.734V2.75A.75.75 0 013.75 2h16.5zm-.75 1.5h-15v.967l5.996 7.38c.285.351.457.779.496 1.226l.008.193v7.092l2.5-.91V13.25c0-.426.12-.842.347-1.2l.103-.15 5.55-7.401V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconFilter);\n","import * as React from 'react';\nfunction IconGraphSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-.925 3.324a.75.75 0 00-.95.263l-.051.088-4.124 8.591-2.924-6.09-.057-.1a.751.751 0 00-1.238 0l-.057.1-1.724 3.59-.524-1.09-.05-.09a.75.75 0 00-1.34.644l.038.095 1.2 2.5.057.1a.751.751 0 001.238 0l.057-.1L9.6 11.233l2.924 6.092.057.1a.751.751 0 001.238 0l.057-.1 4.8-10 .038-.095a.75.75 0 00-.39-.906z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconGraphSolid);\n","import * as React from 'react';\nfunction IconHash(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.158 2.017a.75.75 0 01.59.79l-.015.102-1.047 4.841H20a.75.75 0 01.102 1.493L20 9.25h-2.638l-1.189 5.5H18.5a.75.75 0 01.102 1.493l-.102.007h-2.652l-1.115 5.159a.75.75 0 01-1.48-.216l.014-.101 1.046-4.842H7.848l-1.115 5.159a.75.75 0 01-1.48-.216l.014-.101 1.046-4.842H4a.75.75 0 01-.102-1.493L4 14.75h2.637l1.189-5.5H5.5a.75.75 0 01-.102-1.493L5.5 7.75h2.651l1.116-5.158a.75.75 0 011.48.216l-.014.1L9.686 7.75h6.465l1.116-5.158a.75.75 0 01.891-.575zM14.637 14.75l1.189-5.5H9.362l-1.189 5.5h6.464z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconHash);\n","import * as React from 'react';\nfunction IconHome(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 6l8 8v7a1 1 0 01-1 1h-5v-5a1 1 0 00-.883-.993L13 16h-2a1 1 0 00-.993.883L10 17v5H5a1 1 0 01-1-1v-7l8-8zm.613-3.79l.094.083L17 6.585V4.75a.5.5 0 01.5-.5h1a.5.5 0 01.5.5v3.835l2.707 2.708a1 1 0 01-1.32 1.497l-.094-.083L12 4.415l-8.293 8.292a1 1 0 01-1.32.083l-.094-.083a1 1 0 01-.083-1.32l.083-.094 9-9a1 1 0 011.32-.083z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconHome);\n","import * as React from 'react';\nfunction IconImages(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 6c.966 0 1.75.784 1.75 1.75v11.5A1.75 1.75 0 0116.25 21H4.75A1.75 1.75 0 013 19.25V7.75C3 6.784 3.784 6 4.75 6h11.5zm0 1.5H4.75a.25.25 0 00-.243.193L4.5 7.75v11.5a.25.25 0 00.193.243l.057.007h11.5a.25.25 0 00.243-.193l.007-.057V7.75a.25.25 0 00-.193-.243L16.25 7.5zm-4.264 6.889l3.164 3.961h-9.5l2.375-3.164 1.605 2.148 2.356-2.945zM19.25 3a1.75 1.75 0 011.744 1.606L21 4.75v12.5a.75.75 0 01-1.493.102l-.007-.102V4.75a.25.25 0 00-.193-.243L19.25 4.5H6.75a.75.75 0 01-.102-1.493L6.75 3h12.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconImages);\n","import * as React from 'react';\nfunction IconImport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.5 8v1.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5H15.5V8h2.75c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8H8.5zM12 2a.75.75 0 01.743.648l.007.102v10.689l1.72-1.72a.75.75 0 011.133.977l-.073.084-3 3a.753.753 0 01-.125.101l-.088.049-.119.043-.106.021-.041.004-.07.002-.073-.006-.076-.013-.08-.023-.1-.043a.75.75 0 01-.182-.135l-3-3a.75.75 0 01.976-1.133l.084.073 1.72 1.719V2.75A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconImport);\n","import * as React from 'react';\nfunction IconInboxEinvoicing(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 3.997v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.221a1 1 0 00.916.598h3.694a1 1 0 00.915-.598l.976-2.22a1 1 0 01.915-.599h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.578v3.952a1.75 1.75 0 01-1.607 1.744l-.143.006H3.75A1.75 1.75 0 012 18.247v-3.952c0-.197.033-.393.098-.578L5.09 5.169a1.75 1.75 0 011.652-1.172H12zM17.966 1c2.373 0 4.052 1.688 4.052 3.99 0 .988-.267 1.349-1.03 1.386l-.14.003h-4.72v.404c.01 1.301.836 2.136 2.216 2.136.64 0 1.114-.139 1.502-.41l.403-.307c.267-.196.425-.276.705-.276.483 0 .817.334.817.844 0 .367-.2.72-.554 1.016l-.278.216c-.63.455-1.627.727-2.745.727-2.653 0-4.32-1.515-4.416-4.023l-.005-.23V5.27c0-2.547 1.688-4.27 4.193-4.27zM18 2.763c-1.09 0-1.805.769-1.868 1.932l-.004.186h3.674v-.017c0-1.275-.703-2.101-1.802-2.101z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxEinvoicing);\n","import * as React from 'react';\nfunction IconInboxScanning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.5 4v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.577v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4H13.5zM20 1l3 3v6c0 .51-.388.935-.884.993L22 11h-6.005a.998.998 0 01-.988-.884L15 10l.005-8a1 1 0 01.879-.993L16 1h4zm-1 1v3h3l-3-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxScanning);\n","import * as React from 'react';\nfunction IconInboxSmart(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 4v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.577v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4H12zm6.167-2.76a.35.35 0 01.631-.074l.036.074 1.145 3.115 3.183.179c.283.016.421.342.286.57l-.043.058-.037.036-2.476 2.104.823 3.226c.073.288-.182.527-.43.46l-.068-.025-.042-.024L18.5 9.121l-2.674 1.816c-.24.163-.535-.018-.552-.286l.003-.075.01-.049.821-3.226-2.475-2.104a.384.384 0 01.088-.637l.068-.02.05-.007 3.183-.179 1.145-3.115z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxSmart);\n","import * as React from 'react';\nfunction IconInbox(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M17.258 4c.744 0 1.407.47 1.652 1.172l2.992 8.547c.065.186.098.382.098.578v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4h10.516zm-.177 2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-2.8-8z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInbox);\n","import * as React from 'react';\nfunction IconInfo(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.917 9.355c.406-.018.793.073 1.133.31.962.674.524 2.404-.048 3.869l-.158.391-.237.55-.455 1.002-.078.188c-.01.027-.02.051-.027.073-.561 1.637.086 2.057 1.037 1.797l.103-.03-.069.77c-1.848 1.337-4.443.961-3.364-2.283.052-.156.122-.33.204-.52l.176-.393.398-.867.2-.457c.385-.92.675-1.867.453-2.548-.164-.5-.684-.534-1.214-.352l-.114.042.068-.711c.543-.42 1.177-.732 1.79-.813l.202-.018zM13.148 5c.747 0 1.352.609 1.352 1.362 0 .75-.605 1.36-1.352 1.36a1.357 1.357 0 01-1.354-1.36c0-.753.605-1.362 1.354-1.362z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInfo);\n","import * as React from 'react';\nfunction IconInventoryMatrix(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-8 12.25H4.5v4a.25.25 0 00.193.243l.057.007h6.5v-4.25zm8.25-5h-6.75v9.25h6.5a.25.25 0 00.243-.193l.007-.057v-9zm-2.996 2.383c.419 0 .71.26.755.67l.007.115v3.945c0 .442-.23.688-.637.688-.373 0-.597-.207-.635-.573l-.006-.115v-3.511h-.015l-.41.277c-.204.129-.313.168-.442.168a.431.431 0 01-.445-.445c0-.165.086-.314.256-.445l.091-.063.637-.426c.305-.195.582-.285.844-.285zM11.25 4.5h-6.5a.25.25 0 00-.243.193L4.5 4.75v9h6.75V4.5zM7.883 6.57c1.074 0 1.86.657 1.86 1.551 0 .505-.224.954-.764 1.519l-1.268 1.282v.055h1.625c.363 0 .59.195.59.515 0 .285-.18.468-.484.502L9.336 12H6.664c-.379 0-.629-.215-.629-.543 0-.208.102-.392.399-.699l.12-.121 1.352-1.39c.418-.427.594-.708.594-1.005 0-.383-.277-.64-.688-.64-.332 0-.574.168-.746.515-.171.266-.32.367-.546.367-.31 0-.524-.21-.524-.507 0-.727.82-1.407 1.887-1.407zM19.25 4.5h-6.5v4.25h6.75v-4a.25.25 0 00-.193-.243L19.25 4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInventoryMatrix);\n","import * as React from 'react';\nfunction IconInventory(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 15a3.5 3.5 0 110 7 3.5 3.5 0 010-7zm0 2.25a1.25 1.25 0 100 2.5 1.25 1.25 0 000-2.5zm11.518-1.94l.04.121a1.25 1.25 0 01-.762 1.492l-.122.04-6.175 1.654.001-.117a4.48 4.48 0 00-.633-2.302l6.16-1.65a1.25 1.25 0 011.491.762zm-3.375-9.442l1.812 6.762a1 1 0 01-.707 1.224l-5.943 1.592a4.496 4.496 0 00-2.268-1.326L9.45 8.197a1 1 0 01.707-1.224l6.761-1.812a1 1 0 011.225.707zM3.657 1.536l.128.049 2.69 1.184c.304.133.54.381.66.686l.044.134L9.97 14l-.18.005a4.475 4.475 0 00-2.218.706L4.919 4.815l-2.141-.942a1.25 1.25 0 01-.69-1.52l.05-.128c.259-.59.918-.879 1.519-.689zM15.44 7.37a.75.75 0 00-.819-.55l-.1.02-1.449.388a.75.75 0 00.288 1.469l.1-.02 1.45-.388a.75.75 0 00.53-.919z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInventory);\n","import * as React from 'react';\nfunction IconJournalPro(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.737 3.668c-.055 1.093.226 2.033.894 2.7.668.669 1.608.95 2.7.897a18.08 18.08 0 01-3.09 4.184 27.666 27.666 0 01-3.127 2.706v3.318a.553.553 0 01-.162.39l-3.975 3.975a.553.553 0 01-.943-.39V18.32a.55.55 0 01.162-.39l1.24-1.24a.553.553 0 00.161-.39v-.133c-1.238.463-2.218.487-2.735-.03-.517-.517-.493-1.497-.03-2.735H7.7a.553.553 0 00-.325.105l-.066.057-1.24 1.24a.553.553 0 01-.303.154l-.087.007H2.553a.553.553 0 01-.455-.867l.064-.076 3.975-3.975a.553.553 0 01.304-.155l.086-.007h3.318a27.666 27.666 0 012.706-3.126 18.078 18.078 0 014.186-3.092zM21.93 2.07c.104.105.095.547-.048 1.212l-.083.35-.107.386-.061.204-.142.43c-.154.444-.345.928-.575 1.436-1.073.193-1.96.04-2.501-.5-.523-.523-.684-1.37-.52-2.395l.019-.107a16.762 16.762 0 011.654-.649l.416-.13.197-.055.368-.095c.76-.18 1.27-.2 1.383-.087z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconJournalPro);\n","import * as React from 'react';\nfunction IconLayoutBoth(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 3a1 1 0 011 1v16a1 1 0 01-1 1H4a1 1 0 01-1-1V4a1 1 0 011-1h6zm10 0a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutBoth);\n","import * as React from 'react';\nfunction IconLayoutFirst(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 3a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6zM10 3a1 1 0 011 1v16a1 1 0 01-1 1H4a1 1 0 01-1-1V4a1 1 0 011-1h6zm9.5 1.5h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutFirst);\n","import * as React from 'react';\nfunction IconLayoutLast(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 3a1 1 0 01.993.883L11 4v16a1 1 0 01-.883.993L10 21H4a1 1 0 01-.993-.883L3 20V4a1 1 0 01.883-.993L4 3h6zm10 0a1 1 0 01.993.883L21 4v16a1 1 0 01-.883.993L20 21h-6a1 1 0 01-.993-.883L13 20V4a1 1 0 01.883-.993L14 3h6zM9.5 4.5h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutLast);\n","import * as React from 'react';\nfunction IconLayoutNone(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 3a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6zM10 3a1 1 0 01.993.883L11 4v16a1 1 0 01-.883.993L10 21H4a1 1 0 01-.993-.883L3 20V4a1 1 0 01.883-.993L4 3h6zm9.5 1.5h-5v15h5v-15zm-10 0h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutNone);\n","import * as React from 'react';\nfunction IconLayout(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM16.326 2.676a1.752 1.752 0 012.349-.113l.125.113.594.593c.59.589.676 1.502.21 2.216l-.094.131-.115.128-7.504 7.5-3 .008-.078-3.067 7.513-7.509zm-.796 2.916l-5.202 5.199.025.957.914-.002 5.209-5.207-.946-.947zM20 9v2.25h-1.5V9H20zM5.5 7.5v3.75H4V7.5h1.5zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm9.687 1.697a.252.252 0 00-.248 0l-.053.04-.796.795.946.947.82-.82a.248.248 0 00.043-.216l-.021-.053-.044-.06-.594-.593-.053-.04zM13 2v1.499L9.5 3.5V2H13z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayout);\n","import * as React from 'react';\nfunction IconLedgerCardCustomerReminder(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.69 0 3.093.4 4.212 1.198a4.49 4.49 0 00-.83 1.255C12.996 13.307 11.875 13 10.5 13c-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007h6.506L12.5 22H5.993a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm8.725 9.474A1.259 1.259 0 0118 22c-.605 0-1.11-.44-1.225-1.026h2.45zM18 12c.456 0 .841.392.961.927A3 3 0 0121 15.769v2.898l.835.642a.5.5 0 01-.213.888l-.092.008h-7.06a.5.5 0 01-.305-.896l.835-.642v-2.898c0-1.32.854-2.442 2.04-2.843.119-.534.504-.926.96-.926zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardCustomerReminder);\n","import * as React from 'react';\nfunction IconLedgerCardManualCustomerInvoice(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-8.75 9.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardManualCustomerInvoice);\n","import * as React from 'react';\nfunction IconLedgerCardObsoleteStock(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.25 16.5V18h-2.5a.75.75 0 110-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5v-1.5h2.5zm-7.75 0V18H8.25v-1.5h3.25zm4.25 0V18H12.5v-1.5h3.25zm-8.5-3.501v1.5l-2.5.001a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zM7.25 9.5V11h-2.5a.75.75 0 110-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5V9.5h2.5zm-7.75 0V11H8.25V9.5h3.25zm4.25 0V11H12.5V9.5h3.25zM7.25 6v1.5h-2.5a.75.75 0 010-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5V6h2.5zM11.5 6v1.5H8.25V6h3.25zm4.25 0v1.5H12.5V6h3.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardObsoleteStock);\n","import * as React from 'react';\nfunction IconLedgerCardOpeningEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.567 12.105a.4.4 0 01.1.309l-.29 2.798 2.434 1.41a.4.4 0 01-.116.737l-2.752.587-.587 2.752a.4.4 0 01-.738.116L15.21 18.38l-2.798.292a.4.4 0 01-.339-.666l1.88-2.092-1.141-2.571a.4.4 0 01.528-.528l2.57 1.141 2.093-1.88a.4.4 0 01.565.03zM19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V6h-15v13.25a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-8.5 12.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm0-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm0-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardOpeningEntry);\n","import * as React from 'react';\nfunction IconLedgerCardReservedEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75a1.75 1.75 0 01-1.732-1.499L19.25 19.5a.25.25 0 00.243-.193l.007-.057L19.499 6h-15v3.5h-1.5L3 4.75C3 3.784 3.784 3 4.75 3h14.5zM6.28 10.97a.75.75 0 01.073.976l-.073.084-1.719 1.719 5.689.001a.75.75 0 110 1.5l-5.69-.001 1.72 1.72a.75.75 0 01-.976 1.134l-.084-.073-3-3-.08-.094-.051-.081-.05-.116-.027-.103-.01-.089v-.094l.018-.124.03-.099.047-.099.054-.082.069-.08 3-3a.75.75 0 011.06 0zm10.97 4.53a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-8.5a.75.75 0 010-1.5h8.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardReservedEntry);\n","import * as React from 'react';\nfunction IconLedgerCardShrinkagePilferage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.25a.75.75 0 01.743.648l.007.102v3.439l1.22-1.22a.75.75 0 011.133.977l-.073.084-2.5 2.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.116.026-.056.006h-.104l-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-2.5-2.5a.75.75 0 01.977-1.133l.084.073 1.22 1.219V16a.75.75 0 01.75-.75zm-4.75-2.751v1.5L4.75 14a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zm-8.5-3.5v1.5l-2.5.001a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zm3.5-3.499a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardShrinkagePilferage);\n","import * as React from 'react';\nfunction IconLedgerCardStockAdjustment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 20.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm-2.5-8a.75.75 0 01.743.648l.007.102v3.439l1.22-1.22a.75.75 0 011.133.977l-.073.084-2.5 2.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012-.052.002-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-2.5-2.5a.75.75 0 01.977-1.133l.084.073L16 6.189V2.75a.75.75 0 01.75-.75zm-9.576.004l.128-.002.119.018.098.03.1.047.051.032.038.027.072.064 2.5 2.5a.75.75 0 01-.976 1.133L9.22 5.78 7.999 4.56 8 8a.75.75 0 01-1.493.102L6.5 8l-.001-3.438L5.28 5.78a.75.75 0 01-1.133-.976l.073-.084 2.5-2.5.042-.04.052-.04.114-.068.098-.038.084-.02a.75.75 0 01.064-.01z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardStockAdjustment);\n","import * as React from 'react';\nfunction IconLedgerCardTransferredOpeningEntry(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.567 12.105a.4.4 0 01.1.309l-.29 2.798 2.434 1.41a.4.4 0 01-.116.737l-2.752.587-.587 2.752a.4.4 0 01-.738.116L15.21 18.38l-2.798.292a.4.4 0 01-.339-.666l1.88-2.092-1.141-2.571a.4.4 0 01.528-.528l2.57 1.141 2.093-1.88a.4.4 0 01.565.03zM4.5 15v4.25a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V15h1.5zm6.28-1.72l-3 3-.084.073a.75.75 0 01-1.049-1.05l.073-.083 1.718-1.72H2.75a.75.75 0 110-1.5h5.689l-1.72-1.72a.75.75 0 01.977-1.133l.084.073 3 3a.754.754 0 01.092.11l.054.095.035.086.027.103.01.084-.001.121-.017.102-.019.068-.023.06-.035.07-.06.09-.063.071zM19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V6h-15v4.5H3V4.75C3 3.784 3.784 3 4.75 3h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardTransferredOpeningEntry);\n","import * as React from 'react';\nfunction IconLedgerCard(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zM19.25 2c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 20h-6.038l-.01-.063a11.184 11.184 0 00-.369-1.437h6.417a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L19.25 3.5H7.75a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h11.5zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm9.75 3.5a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-4a.75.75 0 110 1.5h-6a.75.75 0 110-1.5h6zm0-4a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCard);\n","import * as React from 'react';\nfunction IconLightbulb(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.598 20.501a2.999 2.999 0 01-5.196 0h5.196zm.152-2.251a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zM12 4.5c3.314 0 6 2.716 6 6.067 0 1.502-.517 2.528-1.087 3.398l-.265.392-.39.561c-.418.614-.761 1.208-.82 1.929l-.01.22c0 .256-.112.4-.338.428L15 17.5H9c-.254 0-.395-.114-.423-.342l-.006-.091c0-.774-.328-1.414-.75-2.064l-.262-.392-.273-.402-.24-.364C6.492 12.978 6 11.973 6 10.567 6 7.217 8.686 4.5 12 4.5zM12 6c-2.482 0-4.5 2.04-4.5 4.567 0 .931.245 1.599.876 2.573l.647.96.152.234c.322.512.56.988.709 1.474l.052.192h4.128l.054-.192c.126-.402.314-.796.561-1.208l.156-.25.235-.352.408-.587c.736-1.07 1.022-1.78 1.022-2.844C16.5 8.04 14.482 6 12 6zm-5.846 7.875a.75.75 0 01-.19.968l-.084.057-.866.5a.75.75 0 01-.835-1.243l.085-.057.866-.5a.75.75 0 011.024.275zm12.625-.32l.091.045.866.5a.75.75 0 01-.658 1.344l-.092-.044-.866-.5a.75.75 0 01.659-1.344zm2.33-4.661a.75.75 0 01-.509.844l-.099.025-.985.173a.75.75 0 01-.36-1.453l.1-.024.985-.174a.75.75 0 01.868.609zm-17.451-.62l.101.011.985.174a.75.75 0 01-.159 1.488l-.101-.01-.985-.174a.75.75 0 01.159-1.489zm14.288-4.86a.75.75 0 01.152.974l-.06.083-.643.766a.75.75 0 01-1.209-.882l.06-.082.643-.766a.75.75 0 011.057-.093zM7.04 3.433l.07.074.644.766A.75.75 0 016.675 5.31l-.07-.073-.643-.766A.75.75 0 017.04 3.433zM12 1.25a.75.75 0 01.743.648L12.75 2v1a.75.75 0 01-1.493.102L11.25 3V2a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLightbulb);\n","import * as React from 'react';\nfunction IconLine(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 11.25a.75.75 0 01.102 1.493L18 12.75H6a.75.75 0 01-.102-1.493L6 11.25h12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLine);\n","import * as React from 'react';\nfunction IconListBulleted(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.25 16a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5a.75.75 0 01-.75-.75v-2.5a.75.75 0 01.75-.75h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 17.25h10.25zM6.25 10a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5a.75.75 0 01-.75-.75v-2.5a.75.75 0 01.75-.75h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 11.25h10.25zM6.25 4a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5A.75.75 0 013 7.25v-2.5A.75.75 0 013.75 4h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 5.25h10.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconListBulleted);\n","import * as React from 'react';\nfunction IconListSearch(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.5 11a4.5 4.5 0 013.632 7.158l.036-.05 1.862 1.862a.75.75 0 01-.976 1.133l-.084-.073-1.863-1.862-.112.077A4.5 4.5 0 1117.5 11zm-6.25 7.5a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm6.25-6a3 3 0 100 6 3 3 0 000-6zm-7.25 1.167a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5zm3-4.834a.75.75 0 110 1.5H2.75a.75.75 0 110-1.5h10.5zm8-4.833a.75.75 0 110 1.5H2.75a.75.75 0 010-1.5h18.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconListSearch);\n","import * as React from 'react';\nfunction IconList(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 18a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconList);\n","import * as React from 'react';\nfunction IconLockOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 1a5.001 5.001 0 014.87 3.863.75.75 0 01-1.461.34 3.502 3.502 0 00-6.904.605L8.5 6v2h9.75c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8H7V6a5 5 0 015-5zm6.25 8.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5zM12 13a1.5 1.5 0 01.751 2.799l-.001.951a.75.75 0 11-1.5 0v-.95A1.5 1.5 0 0112 13z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLockOpen);\n","import * as React from 'react';\nfunction IconLogOut(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.25 4.5H6.5v15h6.75a1.25 1.25 0 110 2.5h-7A2.25 2.25 0 014 19.75V4.25A2.25 2.25 0 016.25 2h7a1.25 1.25 0 110 2.5zm6.384 2.616l-.102-.091a1.25 1.25 0 00-1.666 1.859l1.867 1.866H11.75l-.128.007a1.25 1.25 0 00.128 2.493h7.982l-1.866 1.866-.091.102a1.25 1.25 0 001.859 1.666l4-4 .08-.089.05-.063.068-.106.058-.112.049-.127.03-.108.016-.088.012-.112L24 12l-.004-.096-.016-.13-.03-.127-.03-.087-.046-.107-.046-.086-.065-.1a1.267 1.267 0 00-.13-.15l-4-4zm4.084 4.094l-.084-.094c.03.03.058.061.084.094z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLogOut);\n","import * as React from 'react';\nfunction IconLog(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V10.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V19H20v1.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.105 10.074c1.447 0 2.3.875 2.367 2.279l.004.178v.621c0 1.5-.863 2.446-2.371 2.446-1.444 0-2.304-.872-2.371-2.268l-.004-.178v-.62c0-1.516.871-2.458 2.375-2.458zm5.362 0c1.328 0 2.058.776 2.172 1.653l.012.132h-1.25c-.074-.414-.406-.734-.945-.734-.638 0-1.007.443-1.05 1.222l-.005.16v.626c0 .805.293 1.414 1.09 1.414.598 0 .914-.34.956-.745l.005-.095v-.234h-.93v-.903h2.14v1.04c0 1.038-.667 1.988-2.199 1.988-1.57 0-2.3-.987-2.355-2.296l-.004-.165v-.64c0-1.427.84-2.423 2.363-2.423zm-10.182.094v4.262h2.141v1.07H7.376v-5.332h1.285zm4.82.95c-.597 0-1.012.415-1.062 1.23l-.005.168v.64c0 .926.43 1.399 1.067 1.399.593 0 1.008-.416 1.057-1.23l.005-.169v-.64c0-.926-.43-1.399-1.062-1.399zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLog);\n","import * as React from 'react';\nfunction IconMarket(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7 17.5a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H3.5a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5H7zm5.5 0a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H9a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5h3.5zm5.5 0a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5h-3.5a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5H18zM7 12a.5.5 0 01.5.5V16a.5.5 0 01-.5.5H3.5A.5.5 0 013 16v-3.5a.5.5 0 01.5-.5H7zm5.5 0a.5.5 0 01.5.5V16a.5.5 0 01-.5.5H9a.5.5 0 01-.5-.5v-3.5A.5.5 0 019 12h3.5zm6.97-2.523l.906 3.381a.5.5 0 01-.353.612l-3.381.906a.5.5 0 01-.612-.353l-.906-3.381a.5.5 0 01.353-.612l3.381-.906a.5.5 0 01.612.353zM7 6.5a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H3.5a.5.5 0 01-.5-.5V7a.5.5 0 01.5-.5H7zm3.642-2.376l3.38.906a.5.5 0 01.354.612l-.906 3.38a.5.5 0 01-.612.354l-3.38-.906a.5.5 0 01-.354-.612l.906-3.38a.5.5 0 01.612-.354zM20 2a.5.5 0 01.5.5V6a.5.5 0 01-.5.5h-3.5A.5.5 0 0116 6V2.5a.5.5 0 01.5-.5H20z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMarket);\n","import * as React from 'react';\nfunction IconMatchAmount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H13l-.001-1.5h5.251a.25.25 0 00.243-.193l.007-.057L18.499 9H14.75a1.75 1.75 0 01-1.744-1.606L13 7.25l-.001-3.75H5.75a.25.25 0 00-.243.193L5.5 3.75 5.499 13H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.142 16.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074zM8 14a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 018 14zm6.499-9.38l.001 2.63a.25.25 0 00.193.243l.057.007h2.629l-2.88-2.88z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMatchAmount);\n","import * as React from 'react';\nfunction IconMatchEntries(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3a1.75 1.75 0 011.744 1.606L21 4.75v14.5a1.75 1.75 0 01-1.606 1.744L19.25 21H12v-1.5h7.25a.25.25 0 00.243-.193l.007-.057V5.996L19.406 6H4.5l.001 6H3V4.75a1.75 1.75 0 011.606-1.744L4.75 3h14.5zM3.696 15.809l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074a.5.5 0 01.55-.147zM7.002 13a4.001 4.001 0 013.92 3.197l.357-.62a.5.5 0 01.602-.221l.081.038a.5.5 0 01.221.601l-.038.082-1.237 2.143a.5.5 0 01-.601.221l-.082-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.034-1.798.75.75 0 11-.924-1.181A3.985 3.985 0 017.002 13zm10.248 2a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm-.125-3.5c.483 0 .875.336.875.75s-.392.75-.875.75h-5.25c-.483 0-.875-.336-.875-.75s.392-.75.875-.75h5.25zM17.25 8a.75.75 0 110 1.5H6.75a.75.75 0 010-1.5h10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMatchEntries);\n","import * as React from 'react';\nfunction IconMenu(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M4 19h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1s.45 1 1 1zm0-6h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1s.45 1 1 1zM3 6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMenu);\n","import * as React from 'react';\nfunction IconMileage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10 0 1.806-.479 3.5-1.316 4.962L20.66 17a.75.75 0 01-.933.32l-.091-.045-1.516-.875a.75.75 0 01.659-1.344l.091.044.84.485c.406-.874.67-1.83.757-2.834l-.967-.001a.75.75 0 01-.102-1.493l.102-.007h.967a8.447 8.447 0 00-.757-2.834l-.84.484a.75.75 0 01-.835-1.243l.085-.057.838-.483a8.548 8.548 0 00-2.075-2.075l-.483.838a.75.75 0 01-1.344-.659l.044-.091.484-.84a8.447 8.447 0 00-2.833-.757l-.001.967a.75.75 0 01-1.493.102L11.25 4.5v-.967a8.447 8.447 0 00-2.834.757l.484.84a.75.75 0 01-1.243.835L7.6 5.88l-.483-.838a8.548 8.548 0 00-2.075 2.075l.838.483a.75.75 0 01-.659 1.344L5.13 8.9l-.84-.484a8.447 8.447 0 00-.757 2.834H4.5a.75.75 0 01.102 1.493l-.102.007h-.967a8.427 8.427 0 00.758 2.835l.839-.485a.75.75 0 01.835 1.243l-.085.057-1.516.875A.75.75 0 013.34 17l-.02-.04-.003.003A9.954 9.954 0 012 12C2 6.477 6.477 2 12 2zm4.03 5.97a.75.75 0 01.073.976l-.073.084-2.792 2.794a1.25 1.25 0 11-1.061-1.061L14.97 7.97a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMileage);\n","import * as React from 'react';\nfunction IconModalResize(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-10 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconModalResize);\n","import * as React from 'react';\nfunction IconModalShrink(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v5.75H3V4.75C3 3.784 3.784 3 4.75 3h14.5zm-9 9c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0110.25 21h-5.5A1.75 1.75 0 013 19.25v-5.5c0-.966.784-1.75 1.75-1.75h5.5zm0 1.5h-5.5a.25.25 0 00-.243.193l-.007.057v5.5a.25.25 0 00.193.243l.057.007h5.5a.25.25 0 00.243-.193l.007-.057v-5.5a.25.25 0 00-.193-.243l-.057-.007zm7.78-7.53a.75.75 0 01.073.976l-.073.084-3.22 3.22h1.69a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007H13a.75.75 0 01-.743-.648L12.25 11V7.5a.75.75 0 011.493-.102l.007.102v1.688l3.22-3.218a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconModalShrink);\n","import * as React from 'react';\nfunction IconMoreSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 8.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm0 5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm0-10a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMoreSolid);\n","import * as React from 'react';\nfunction IconMore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 10a2 2 0 110 4 2 2 0 010-4zm0 6.5a2 2 0 110 4 2 2 0 010-4zm0-13a2 2 0 110 4 2 2 0 010-4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMore);\n","import * as React from 'react';\nfunction IconMove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.924 6.254l.128-.002.119.018.098.03.1.047.051.032.038.027.072.064 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219V17a.75.75 0 01-1.493.102L6.25 17V8.811l-2.22 2.22a.75.75 0 01-1.133-.977l.073-.084 3.5-3.5.042-.04.052-.04.114-.068.098-.038.084-.02a.75.75 0 01.064-.01zM17 6.25a.75.75 0 01.743.648L17.75 7l-.001 8.19 2.22-2.22a.75.75 0 011.134.976l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012-.052.002-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.219 2.218L16.25 7a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMove);\n","import * as React from 'react';\nfunction IconNavigationList(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 22v-.018A1.75 1.75 0 014 20.25V3.75c0-.882.652-1.61 1.5-1.732V2h12.75c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.5zM9 18.3H5.5v1.95a.25.25 0 00.193.243l.057.007H9v-2.2zm9.25-14.8H10.5v17h7.75a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5zM9 14.6H5.5v2.2H9v-2.2zm0-3.7H5.5v2.2H9v-2.2zm0-3.7H5.5v2.2H9V7.2zm0-3.7H5.75a.25.25 0 00-.243.193L5.5 3.75V5.7H9V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNavigationList);\n","import * as React from 'react';\nfunction IconNoteFollowUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H14v-1.5h4.25a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V11H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM9.225 20.974A1.259 1.259 0 018 22c-.605 0-1.11-.44-1.225-1.026h2.45zM8 12c.456 0 .841.392.961.927A3 3 0 0111 15.769v2.898l.835.642a.5.5 0 01-.305.896H4.47a.5.5 0 01-.305-.896L5 18.667v-2.898c0-1.32.854-2.442 2.04-2.843.119-.534.504-.926.96-.926zm7.25 2.5a.75.75 0 110 1.5h-1.5a.75.75 0 110-1.5h1.5zm0-3.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNoteFollowUp);\n","import * as React from 'react';\nfunction IconNoteRead(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2a.75.75 0 01.75.75V3h1.75a1.75 1.75 0 011.744 1.606L21 4.75v14.5a1.75 1.75 0 01-1.606 1.744L19.25 21H4.75a1.75 1.75 0 01-1.744-1.606L3 19.25V4.75a1.75 1.75 0 011.606-1.744L4.75 3H6.5v-.25a.75.75 0 011.5 0V3h3.25v-.25a.75.75 0 111.5 0V3H16v-.25a.75.75 0 01.75-.75zM6.499 4.5H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v14.5l.007.057a.25.25 0 00.175.184l.068.009h14.5l.057-.007a.25.25 0 00.184-.175l.009-.068V4.75l-.007-.057a.25.25 0 00-.175-.184L19.25 4.5H17.5v.25a.75.75 0 11-1.5 0V4.5h-3.25v.25a.75.75 0 11-1.5 0V4.5H7.999L8 4.75a.75.75 0 01-1.5 0l-.001-.25zM16.25 12a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm0-3a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNoteRead);\n","import * as React from 'react';\nfunction IconNote(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2a.75.75 0 01.75.75V3h1.75a1.75 1.75 0 011.744 1.606L21 4.75V14h-1.5V4.75l-.007-.057a.25.25 0 00-.175-.184L19.25 4.5H17.5v.25a.75.75 0 11-1.5 0V4.5h-3.25v.25a.75.75 0 11-1.5 0V4.5H7.999L8 4.75a.75.75 0 01-1.5 0l-.001-.25H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v14.5l.007.057a.25.25 0 00.175.184l.068.009H14V21H4.75a1.75 1.75 0 01-1.744-1.606L3 19.25V4.75a1.75 1.75 0 011.606-1.744L4.75 3H6.5v-.25a.75.75 0 011.5 0V3h3.25v-.25a.75.75 0 111.5 0V3H16v-.25a.75.75 0 01.75-.75zm-3.94 7.75l7.513 7.513a1.75 1.75 0 01.114 2.35l-.114.124-.586.586a1.75 1.75 0 01-2.35.114l-.124-.114-7.513-7.512V9.75h3.06zm5.697 7.818l-.938.94.754.755a.25.25 0 00.24.065l.06-.025.054-.04.586-.586a.25.25 0 00.04-.3l-.04-.054-.756-.755zm-6.318-6.318h-.939v.939l5.258 5.258.938-.94-5.257-5.257z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNote);\n","import * as React from 'react';\nfunction IconNumbers(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.203 16.625c0 .602.328.96.875.96.555 0 .875-.35.875-.96V7.898c0-.671-.437-1.132-1.078-1.132-.375 0-.742.14-1.273.515L1.125 8.344c-.367.25-.54.508-.54.789 0 .367.282.656.65.656.195 0 .382-.07.663-.266l1.258-.898h.047v8zm4.149.031c0 .516.414.844 1.046.844h5.22c.53 0 .843-.281.843-.734 0-.461-.328-.743-.844-.743H9.648v-.101l2.665-2.953c1.367-1.492 1.812-2.313 1.812-3.36 0-1.742-1.43-2.984-3.422-2.984-2.086 0-3.492 1.375-3.492 2.742 0 .485.312.813.766.813.367 0 .617-.211.804-.657.266-.906.93-1.43 1.82-1.43 1.063 0 1.774.665 1.774 1.657 0 .688-.344 1.313-1.21 2.266l-3.071 3.406c-.563.601-.742.89-.742 1.234zm8.562-1.375c0 1.242 1.555 2.446 3.617 2.446 2.274 0 3.867-1.297 3.867-3.141 0-1.352-.992-2.484-2.296-2.617v-.11c1.078-.171 1.953-1.257 1.953-2.421 0-1.649-1.461-2.813-3.524-2.813-1.984 0-3.414 1.156-3.414 2.39 0 .454.305.766.742.766.344 0 .578-.164.782-.578.367-.742 1.007-1.156 1.851-1.156 1.086 0 1.828.648 1.828 1.61 0 .952-.758 1.64-1.804 1.64h-.813c-.43 0-.726.305-.726.71 0 .423.304.735.726.735h.86c1.25 0 2.085.719 2.085 1.79 0 1.077-.82 1.765-2.093 1.765-.961 0-1.711-.422-2.14-1.188-.25-.414-.47-.57-.782-.57-.422 0-.719.313-.719.742z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNumbers);\n","import * as React from 'react';\nfunction IconPartnerApi(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.884 11.616a1.25 1.25 0 01.091 1.666l-.091.102-1.868 1.866H19a1.25 1.25 0 01.128 2.494L19 17.75H8.017l1.867 1.866a1.25 1.25 0 01-1.666 1.859l-.102-.091-4-4a1.26 1.26 0 01-.13-.152l-.068-.106-.042-.079-.046-.107-.03-.087-.03-.127-.016-.126-.004-.1.002-.08.013-.111.016-.088.03-.108.05-.127.086-.16.062-.088.064-.076 4.043-4.046a1.25 1.25 0 011.768 0zm5.898-9.091l.102.091 4 4c.03.03.058.061.084.094l-.084-.094c.048.048.09.099.13.152l.064.099.046.086.046.107.03.087.03.127.016.13.004.096-.002.08-.013.111-.016.088-.03.108-.05.127-.057.112-.069.106-.048.063-.081.089-4 4a1.25 1.25 0 01-1.859-1.666l.091-.102 1.866-1.866H5a1.25 1.25 0 01-.128-2.494L5 6.25h10.983l-1.867-1.866a1.25 1.25 0 011.666-1.859z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPartnerApi);\n","import * as React from 'react';\nfunction IconPeriod(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 6c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 22H7.75A1.75 1.75 0 016 20.25V19h1.5v1.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V7.75a.25.25 0 00-.193-.243L20.25 7.5H19V6h1.25zm-7-5a.75.75 0 01.75.75V2h2.25c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0116.25 18H3.75A1.75 1.75 0 012 16.25V3.75C2 2.784 2.784 2 3.75 2H6v-.25a.75.75 0 011.5 0V2h5v-.25a.75.75 0 01.75-.75zm3.25 6.5h-13v8.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V7.5zm-6.195 1.277c.38 0 .62.21.662.554l.006.107v4.554c0 .356-.235.59-.582.59-.313 0-.538-.19-.58-.487l-.006-.103V9.957H9.78l-.824.574a.48.48 0 01-.312.106.402.402 0 01-.415-.422c0-.15.05-.267.172-.377l.082-.065L9.602 9a1.09 1.09 0 01.703-.223zM6 3.5H3.75a.25.25 0 00-.243.193L3.5 3.75V6h13V3.75a.25.25 0 00-.193-.243L16.25 3.5H14v.25a.75.75 0 11-1.5 0V3.5h-5v.25a.75.75 0 01-1.5 0V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPeriod);\n","import * as React from 'react';\nfunction IconPersonChange(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.75 11.5c4.166 0 6.596 2.43 7.291 7.29A2.813 2.813 0 0119.257 22h-9.014a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm0 1.5c-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007h9.014a1.313 1.313 0 001.3-1.498C19.96 14.84 18.12 13 14.75 13zM6.446 6.397l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H1.75a.75.75 0 01-.102-1.493l.102-.007h5.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM14.75 2c1.933 0 3.5 1.903 3.5 4.25s-1.567 4.25-3.5 4.25-3.5-1.903-3.5-4.25S12.817 2 14.75 2zm0 1.5c-1.033 0-2 1.174-2 2.75s.967 2.75 2 2.75 2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonChange);\n","import * as React from 'react';\nfunction IconPersonMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm2.25 3.75h-4.5a.75.75 0 00-.102 1.493l.102.007h4.5a.75.75 0 00.102-1.493l-.102-.007zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonMinus);\n","import * as React from 'react';\nfunction IconPersonPlus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm0 1.5a.75.75 0 00-.743.648l-.007.102v1.5h-1.5a.75.75 0 00-.743.648l-.007.102c0 .38.282.693.648.743l.102.007h1.5v1.5c0 .38.282.693.648.743l.102.007a.75.75 0 00.743-.648l.007-.102v-1.5h1.5a.75.75 0 00.743-.648l.007-.102a.75.75 0 00-.648-.743l-.102-.007h-1.5v-1.5a.75.75 0 00-.648-.743L17.5 14.5zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonPlus);\n","import * as React from 'react';\nfunction IconPersonTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm2.403 1.867a.75.75 0 00-.97.141l-.066.09-1.983 3.114-.798-.999-.076-.081a.75.75 0 00-1.159.927l.063.091 1.455 1.819.073.079a.75.75 0 001.081-.059l.064-.086 2.546-4 .052-.098a.75.75 0 00-.282-.938zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonTick);\n","import * as React from 'react';\nfunction IconPlay(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zM9.8 8a.7.7 0 011.05-.606l.084.057 4.86 3.84a.7.7 0 01.081 1.023l-.081.075-4.86 3.84a.7.7 0 01-1.127-.449l-.007-.1V8zm1.4 1.445v4.789l3.03-2.395-3.03-2.394z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPlay);\n","import * as React from 'react';\nfunction IconPlusMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.169 17.055c.43 0 .734-.305.734-.75V13.43h2.649c.453 0 .757-.297.757-.72 0-.429-.304-.726-.757-.726H6.903V9.258c0-.445-.304-.758-.734-.758s-.727.313-.727.758v2.726H2.825c-.445 0-.758.297-.758.727 0 .422.313.719.758.719h2.617v2.875c0 .445.305.75.727.75zm5.598 2.453c.352 0 .64-.211.735-.555l3.453-12.25a1.17 1.17 0 00.047-.258c.007-.406-.336-.75-.766-.75-.36 0-.648.211-.742.547l-3.446 12.25a.749.749 0 00.719 1.016zm9.388-6.11c.578 0 .882-.32.882-.78 0-.462-.304-.766-.882-.766h-3.68c-.57 0-.883.312-.883.765 0 .461.305.781.883.781h3.68z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPlusMinus);\n","import * as React from 'react';\nfunction IconPrint(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2c.966 0 1.75.784 1.75 1.75v1.758A3.75 3.75 0 0122 9.25v7.5a1.75 1.75 0 01-1.75 1.75H18.5v1.75A1.75 1.75 0 0116.75 22h-9.5a1.75 1.75 0 01-1.75-1.75V18.5H3.75A1.75 1.75 0 012 16.75v-7.5a3.75 3.75 0 013.5-3.742V3.75C5.5 2.784 6.284 2 7.25 2h9.5zM17 14.5H7v5.75a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193L17 20.25V14.5zM18.25 7H5.75a2.25 2.25 0 00-2.245 2.096L3.5 9.25v7.5a.25.25 0 00.193.243L3.75 17H5.5v-3.25a.75.75 0 01.75-.75h11.5a.75.75 0 01.75.75V17h1.75a.25.25 0 00.243-.193l.007-.057v-7.5a2.25 2.25 0 00-2.096-2.245L18.25 7zm-.5 3a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm-1-6.5h-9.5a.25.25 0 00-.243.193L7 3.75V5.5h10V3.75a.25.25 0 00-.193-.243L16.75 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPrint);\n","import * as React from 'react';\nfunction IconProcessPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.247 2a.75.75 0 01.75.75l-.001.25h2.25c.967 0 1.75.784 1.75 1.75v14.5a1.75 1.75 0 01-1.75 1.75h-7.25v-1.5h7.25a.25.25 0 00.244-.193l.007-.057L19.496 8h-15v4h-1.5V4.75c0-.966.784-1.75 1.75-1.75h2.25v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM3.139 15.956a.5.5 0 01.631-.11l2.144 1.238.073.052a.5.5 0 01.11.631l-.052.074a.5.5 0 01-.631.11l-.878-.506a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.814-.574l1.237-2.143zM6.997 13a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.601.221l-.082-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 016.997 13zm-.001-8.5h-2.25a.25.25 0 00-.243.193l-.006.057-.001 1.75h15V4.75a.25.25 0 00-.192-.243l-.057-.007h-2.251v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProcessPayment);\n","import * as React from 'react';\nfunction IconProductLedgerCard(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.797 9c.464 0 .91.184 1.237.513l6.229 6.228a1.75 1.75 0 010 2.475l-4.047 4.047a1.75 1.75 0 01-2.475 0l-6.228-6.229A1.75 1.75 0 012 14.797V10.75C2 9.784 2.784 9 3.75 9h4.047zM18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H14.5v-1.5h3.75a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V8H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM7.797 10.5H3.75a.25.25 0 00-.243.193l-.007.057v4.047a.25.25 0 00.033.125l.04.052 6.228 6.228a.25.25 0 00.3.04l.054-.04 4.047-4.047a.25.25 0 00.04-.3l-.04-.054-6.228-6.228a.25.25 0 00-.112-.064l-.065-.009zm-2.504 1.793a1 1 0 111.414 1.414 1 1 0 01-1.414-1.414zM15.75 9.5a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProductLedgerCard);\n","import * as React from 'react';\nfunction IconProfile(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M22 12c0-5.523-4.477-10-10-10S2 6.477 2 12a9.97 9.97 0 003.047 7.187A9.967 9.967 0 0012 22a9.967 9.967 0 006.953-2.813A9.97 9.97 0 0022 12zM5.704 16.936A7.986 7.986 0 0012 20a7.986 7.986 0 006.296-3.064A7 7 0 0012 13a7 7 0 00-6.296 3.936zM12 12a3.5 3.5 0 100-7 3.5 3.5 0 000 7z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProfile);\n","import * as React from 'react';\nfunction IconProjectCards(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm0 1.5H4.75a.25.25 0 00-.243.193L4.5 4.75v14.5a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5zM8.25 15a.75.75 0 01.75.75v1a.75.75 0 01-.75.75h-1a.75.75 0 01-.75-.75v-1a.75.75 0 01.75-.75h1zm8.5 1a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-3.167a.75.75 0 010 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-3.166a.75.75 0 110 1.5h-4.5a.75.75 0 010-1.5h4.5zM8.25 6.5a.75.75 0 01.75.75v1a.75.75 0 01-.75.75h-1a.75.75 0 01-.75-.75v-1a.75.75 0 01.75-.75h1zm8.5 0a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProjectCards);\n","import * as React from 'react';\nfunction IconProjects(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 3a1 1 0 00-.993.883L11 6v6.02l.01.118.022.113.023.077.03.075.047.093.062.096.07.085.072.071.096.075.099.06.075.036 3.5 1.5.11.04a1 1 0 00.782-1.826l-.104-.052L13 11.34V6l-.007-.117A1 1 0 0012 5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProjects);\n","import * as React from 'react';\nfunction IconQuicklinks(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.102 11.125c.753 0 1.472.295 2.007.817l.142.148 4.806 5.407c.183.206.434.337.705.37l.136.008h3.416L17.22 16.78l-.073-.084a.75.75 0 011.05-1.049l.083.073 2.5 2.5a.753.753 0 01.097.118l.053.094.028.07.023.08.013.075.006.102-.002.042-.009.075-.027.111-.043.102-.038.066-.027.04-.035.043-.039.042-2.5 2.5-.084.073a.75.75 0 01-1.049-1.05l.073-.083 1.095-1.096-3.417.001a2.875 2.875 0 01-2.007-.817l-.142-.148-4.806-5.407a1.125 1.125 0 00-.705-.37l-.136-.008H3.75a.875.875 0 01-.11-1.743l.11-.007h3.352zm11.094-8.978l.084.073 2.5 2.5a.63.63 0 01.101.125l.049.088.043.119.021.106.004.042.002.069-.006.073-.013.076-.023.08-.047.107-.058.091-.073.084-2.5 2.5a.75.75 0 01-1.133-.976l.073-.084 1.095-1.096-3.426.001-.136.008c-.223.027-.433.12-.603.268l-.096.095-2.905 3.215-.085.083a.875.875 0 01-1.287-1.162l.074-.094 2.904-3.215.141-.146a2.875 2.875 0 011.79-.795l.203-.007 3.424-.001L17.22 3.28a.75.75 0 01.976-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconQuicklinks);\n","import * as React from 'react';\nfunction IconRatingBankruptcy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm.035 4.982c-.264 0-.533.13-.533.51v.41C9.92 8.05 8.9 8.998 8.9 10.352c0 1.135.646 1.88 1.926 2.202l1.309.288c.844.181 1.178.44 1.178.879 0 .562-.446.931-1.272.931-.592 0-1.166-.246-1.687-.72-.334-.282-.545-.364-.803-.364-.416 0-.75.258-.75.715 0 .352.187.692.515.99.487.452 1.272.727 2.163.803v.358c0 .375.275.51.539.51.263 0 .533-.135.533-.51v-.37c1.64-.193 2.666-1.154 2.666-2.543 0-1.143-.66-1.862-1.997-2.176l-1.314-.273c-.744-.146-1.084-.427-1.084-.867 0-.492.44-.885 1.131-.885.586 0 1.008.188 1.506.662.293.252.533.364.85.364.369 0 .673-.27.673-.657 0-.328-.175-.673-.503-.984-.434-.422-1.131-.691-1.91-.79v-.423c0-.375-.27-.51-.534-.51z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRatingBankruptcy);\n","import * as React from 'react';\nfunction IconRatingPaymentProblems(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M21.25 11.25A.75.75 0 0122 12c0 5.523-4.477 10-10 10a9.986 9.986 0 01-7.638-3.545l-.038 1.071a.75.75 0 01-1.496.05l-.003-.102.099-2.827a.75.75 0 01.775-.723l2.827.098a.75.75 0 01.05 1.496l-.102.004-.966-.034A8.5 8.5 0 0020.5 12a.75.75 0 01.75-.75zm-9.215-4.268c.237 0 .48.11.526.405l.007.105v.422c.78.1 1.477.37 1.91.791.329.31.504.656.504.984 0 .387-.304.657-.673.657-.317 0-.557-.112-.85-.364-.498-.474-.92-.662-1.506-.662-.691 0-1.13.393-1.13.885 0 .406.289.677.919.831l.164.036 1.108.229c1.476.287 2.203 1.02 2.203 2.22 0 1.331-.942 2.27-2.464 2.515l-.202.028v.37c0 .375-.27.51-.533.51-.238 0-.485-.11-.532-.405l-.007-.105v-.358c-.891-.076-1.676-.351-2.163-.803-.328-.298-.515-.638-.515-.99 0-.457.334-.715.75-.715.258 0 .469.082.803.364.521.474 1.095.72 1.687.72.826 0 1.271-.369 1.271-.931 0-.41-.29-.662-1.015-.842l-.162-.037-1.102-.24c-1.418-.293-2.133-1.055-2.133-2.25 0-1.298.937-2.223 2.407-2.427l.195-.023v-.41c0-.38.27-.51.533-.51zM12 2c3 0 5.77 1.332 7.639 3.545l.037-1.071a.75.75 0 011.496-.05l.003.102-.099 2.827a.75.75 0 01-.674.72l-.101.003-2.827-.098a.75.75 0 01-.05-1.496l.102-.004.966.034A8.5 8.5 0 003.5 12 .75.75 0 112 12C2 6.477 6.477 2 12 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRatingPaymentProblems);\n","import * as React from 'react';\nfunction IconReconciled(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 7a5 5 0 01.217 9.995L17 17h-2.5a.75.75 0 01-.102-1.493l.102-.007H17a3.5 3.5 0 00.192-6.995L17 8.5h-2.5a.75.75 0 01-.102-1.493L14.5 7H17zM9.5 7a.75.75 0 01.102 1.493L9.5 8.5H7a3.5 3.5 0 00-.192 6.995L7 15.5h2.5a.75.75 0 01.102 1.493L9.5 17H7a5 5 0 01-.217-9.995L7 7h2.5zm7.5 4.25a.75.75 0 110 1.5H7a.75.75 0 110-1.5h10z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReconciled);\n","import * as React from 'react';\nfunction IconRefresh(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.268 21.246L12 21.25l-.323-.006-.32-.016-.3-.025-.329-.04a9.166 9.166 0 01-2.067-.534l-.288-.117-.353-.16-.237-.117-.358-.193-.385-.233-.263-.173-.3-.215-.23-.177-.238-.196-.356-.319a9.308 9.308 0 01-.345-.343l-.151-.162a9.197 9.197 0 01-1.662-2.58l-.126-.311-.134-.372-.087-.268-.08-.285A9.229 9.229 0 012.75 12c0-.893.127-1.757.363-2.574l.137-.431.077-.218.169-.421a9.17 9.17 0 01.768-1.431l.171-.25c.213-.303.447-.595.701-.876l.168-.18c.174-.183.356-.36.545-.528l.197-.17.345-.278.328-.239.302-.202.117-.072a8.88 8.88 0 01.664-.375l.484-.23.37-.152.427-.153.353-.11.263-.071.145-.036A9.232 9.232 0 0112 2.75l.24.003.317.014.389.031.284.033.487.079.43.091.287.073.39.116.293.099.336.127.17.07.379.172.259.129.25.135.416.248.255.166a9.12 9.12 0 011.14.911V3.222a.75.75 0 01.638-.742l.111-.008a.75.75 0 01.742.639l.008.11v3.83a.75.75 0 01-.64.741l-.11.008h-3.828a.75.75 0 01-.111-1.492l.11-.008h2.009l-.197-.177-.22-.182-.131-.102-.2-.147-.225-.156-.235-.15-.236-.139-.149-.081-.222-.115-.268-.126-.121-.053a7.709 7.709 0 00-1.013-.352l-.263-.067-.258-.055-.262-.047-.278-.04-.349-.036-.353-.02L12 4.25l-.183.002-.376.018-.294.026-.248.032-.335.055-.344.073-.243.061-.202.058a7.72 7.72 0 00-.54.183l-.282.114-.204.09-.317.156-.24.13a7.755 7.755 0 00-.629.397l-.383.285-.21.174-.075.064a7.796 7.796 0 00-.195.178l-.18.174-.239.25-.175.198-.152.184a7.778 7.778 0 00-.59.84l-.174.305-.116.222-.112.232a7.079 7.079 0 00-.15.346l-.11.29-.122.368-.046.16c-.084.304-.15.612-.197.923l-.05.409.01-.098c-.05.453-.06.91-.03 1.364l.024.285c.031.307.081.611.15.913l.073.3.058.204c.072.245.157.486.255.724l.085.2c.05.112.102.223.156.332l.091.175.137.245.148.246.058.088a7.766 7.766 0 00.436.604l.141.173.093.107.174.191.174.18.18.175.246.22.324.264.349.255.123.083.24.151.2.118.259.14.257.128.33.146.24.095c.195.073.393.139.594.196l.359.094.136.03.124.026.297.053.329.045.246.024.097.008c.091.006.183.011.275.014l.275.005A7.75 7.75 0 0019.75 12a.75.75 0 111.5 0 9.25 9.25 0 01-8.982 9.246z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRefresh);\n","import * as React from 'react';\nfunction IconReportSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.5 12a1 1 0 011 1v6a1 1 0 01-1 1H4a1 1 0 01-1-1v-6a1 1 0 011-1h2.5zm6.75-5a1 1 0 011 1v11a1 1 0 01-1 1h-2.5a1 1 0 01-1-1V8a1 1 0 011-1h2.5zM20 4a1 1 0 011 1v14a1 1 0 01-1 1h-2.5a1 1 0 01-1-1V5a1 1 0 011-1H20z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReportSolid);\n","import * as React from 'react';\nfunction IconReport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.25 12c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 016.25 20h-1.5A1.75 1.75 0 013 18.25v-4.5c0-.966.784-1.75 1.75-1.75h1.5zm6.5-5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0112.75 20h-1.5a1.75 1.75 0 01-1.75-1.75v-9.5c0-.966.784-1.75 1.75-1.75h1.5zm6.5-3c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0119.25 20h-1.5A1.75 1.75 0 0116 18.25V5.75c0-.966.784-1.75 1.75-1.75h1.5zm-13 9.5h-1.5a.25.25 0 00-.243.193l-.007.057v4.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L6.25 13.5zm6.5-5h-1.5a.25.25 0 00-.243.193L11 8.75v9.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193L13 18.25v-9.5a.25.25 0 00-.193-.243L12.75 8.5zm6.5-3h-1.5a.25.25 0 00-.243.193l-.007.057v12.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193l.007-.057V5.75a.25.25 0 00-.193-.243L19.25 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReport);\n","import * as React from 'react';\nfunction IconRestore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 9.25a.75.75 0 01.743.648l.007.102v8.25a3.75 3.75 0 01-3.55 3.745L15 22h-5a3.75 3.75 0 01-3.745-3.55l-.005-.2V10a.75.75 0 01.648-.743L7 9.25h11zm-.75 1.5h-9.5v7.5a2.25 2.25 0 001.938 2.229l.158.016.154.005h5a2.25 2.25 0 002.245-2.096l.005-.154v-7.5zm-6.75 1.5a.75.75 0 01.743.648l.007.102v5.25a.75.75 0 01-1.493.102l-.007-.102V13a.75.75 0 01.75-.75zm4 0a.75.75 0 01.743.648l.007.102v5.25a.75.75 0 01-1.493.102l-.007-.102V13a.75.75 0 01.75-.75zm2.372-9.849a3.847 3.847 0 012.03 4.45l2.668 1.302a.75.75 0 01-.563 1.386l-.094-.038L9.086 3.732a.75.75 0 01.563-1.386l.094.038 2.373 1.157a3.847 3.847 0 014.756-1.14zM3 4.25a.75.75 0 01.743.648L3.75 5v.63c2.434-1.684 5.714-1.245 7.542 1.11a.75.75 0 11-1.185.919C8.819 6 6.547 5.647 4.777 6.749l.723.001a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743L5.5 8.25H3a.75.75 0 01-.743-.648L2.25 7.5V5A.75.75 0 013 4.25zm10.507-.031l4.005 1.953a2.347 2.347 0 00-4.005-1.953z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRestore);\n","import * as React from 'react';\nfunction IconRotateLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2.75a9.25 9.25 0 016.54 15.79.75.75 0 11-1.06-1.06 7.75 7.75 0 10-13.224-5.797l.714-.713.084-.073a.75.75 0 011.049 1.05l-.073.083-2 2-.084.073a.75.75 0 01-.882.007l-.094-.08-2-2-.073-.084a.75.75 0 01-.007-.882l.08-.094.084-.073a.75.75 0 01.882-.007l.094.08.725.724A9.25 9.25 0 0112 2.75z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRotateLeft);\n","import * as React from 'react';\nfunction IconRotateRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2.75a9.25 9.25 0 019.245 8.944l.725-.724a.75.75 0 01.976-.073l.084.073a.75.75 0 01.073.976l-.073.084-2 2a.75.75 0 01-.976.073l-.084-.073-2-2a.75.75 0 01.976-1.133l.084.073.714.712A7.75 7.75 0 106.52 17.48a.75.75 0 11-1.06 1.06A9.25 9.25 0 0112 2.75z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRotateRight);\n","import * as React from 'react';\nfunction IconSales(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.021 23.316c.594 0 1.121-.33 1.121-1.12V21.14c3.546-.382 5.761-2.465 5.761-5.498 0-2.61-1.569-4.192-4.825-4.904l-2.676-.606C9.727 9.763 8.91 8.999 8.91 7.878c0-1.344 1.16-2.32 2.98-2.32 1.476 0 2.504.5 3.651 1.78.58.606 1.029.83 1.635.83.738 0 1.305-.514 1.305-1.279 0-.738-.435-1.542-1.173-2.267-.976-.923-2.439-1.53-4.087-1.74V1.787c0-.777-.527-1.107-1.134-1.107-.593 0-1.12.316-1.12 1.107v1.055c-3.415.317-5.59 2.36-5.59 5.287 0 2.557 1.569 4.258 4.575 4.93l2.676.62c1.951.461 2.755 1.147 2.755 2.307 0 1.503-1.173 2.452-3.27 2.452-1.568 0-2.873-.593-4.06-1.872-.672-.672-1.041-.817-1.542-.817-.805 0-1.411.514-1.411 1.397 0 .778.448 1.582 1.252 2.281 1.055.962 2.703 1.556 4.536 1.727v1.042c0 .79.527 1.12 1.133 1.12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSales);\n","import * as React from 'react';\nfunction IconSearchBold(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.75 2a7.75 7.75 0 016.292 12.275l5.592 5.591a1.25 1.25 0 01-1.666 1.859l-.102-.091-5.59-5.592A7.75 7.75 0 119.75 2zm0 2.5a5.25 5.25 0 100 10.5 5.25 5.25 0 000-10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSearchBold);\n","import * as React from 'react';\nfunction IconSearch(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 2.25a7.75 7.75 0 015.985 12.674l5.545 5.546a.75.75 0 01-.976 1.133l-.084-.073-5.546-5.545A7.75 7.75 0 1110 2.25zm0 1.5a6.25 6.25 0 100 12.5 6.25 6.25 0 000-12.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSearch);\n","import * as React from 'react';\nfunction IconSecureTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.01 2.25a.75.75 0 01.665.402c.72 1.376 3.174 2.323 7.389 2.683a.75.75 0 01.686.748c0 7.747-1.54 11.378-5.945 14.213l-.502.312-.525.306a26.51 26.51 0 01-.834.452l-.29.148-.323.16a.75.75 0 01-.654.003c-6.293-3-8.427-6.542-8.427-15.594a.75.75 0 01.686-.748c4.215-.36 6.67-1.307 7.389-2.683a.75.75 0 01.56-.395l.126-.007zM12 4.245l-.064.067C10.702 5.54 8.479 6.317 5.277 6.705l-.523.058.01.54c.012.53.033 1.039.063 1.525l.052.713c.472 5.577 2.312 8.141 6.618 10.372l.272.139.228.113.262-.133c4.685-2.43 6.538-5.033 6.915-11.21l.038-.743.025-.778.007-.402.001-.136-.522-.058c-3.068-.372-5.238-1.1-6.5-2.242l-.159-.15L12 4.244zm4.903 4.104l.077.067a.75.75 0 01.067.984l-.067.077-5.52 5.52-3.382-3.38a.75.75 0 01.984-1.129l.076.067 2.32 2.322 4.461-4.46a.75.75 0 01.984-.068z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSecureTick);\n","import * as React from 'react';\nfunction IconSecure(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.01 2.25a.75.75 0 01.665.402c.72 1.376 3.174 2.323 7.389 2.683a.75.75 0 01.686.748c0 7.747-1.54 11.378-5.945 14.213l-.502.312-.525.306a26.51 26.51 0 01-.834.452l-.29.148-.323.16a.75.75 0 01-.654.003c-6.293-3-8.427-6.542-8.427-15.594a.75.75 0 01.686-.748c4.215-.36 6.67-1.307 7.389-2.683a.75.75 0 01.56-.395l.126-.007zM12 4.245l-.064.067C10.702 5.54 8.479 6.317 5.277 6.705l-.523.058.01.54c.012.53.033 1.039.063 1.525l.052.713c.472 5.577 2.312 8.141 6.618 10.372l.272.139.228.113.262-.133c4.685-2.43 6.538-5.033 6.915-11.21l.038-.743.025-.778.007-.402.001-.136-.522-.058c-3.068-.372-5.238-1.1-6.5-2.242l-.159-.15L12 4.244zM12 8l.15.005a2 2 0 01.98 3.645L14 16h-4l.87-4.35a2 2 0 01.982-3.644L11.999 8z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSecure);\n","import * as React from 'react';\nfunction IconSettingsSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13 2a1 1 0 011 1v1.77a7.44 7.44 0 011.698.703l1.252-1.251a1 1 0 011.414 0l1.414 1.414a1 1 0 010 1.414l-1.251 1.252c.3.53.538 1.099.703 1.698H21a1 1 0 011 1v2a1 1 0 01-1 1h-1.77a7.454 7.454 0 01-.703 1.698l1.251 1.252a1 1 0 010 1.414l-1.414 1.414a1 1 0 01-1.414 0l-1.252-1.251a7.47 7.47 0 01-1.697.703L14 21a1 1 0 01-1 1h-2a1 1 0 01-1-1v-1.77a7.454 7.454 0 01-1.698-.703L7.05 19.778a1 1 0 01-1.414 0l-1.414-1.414a1 1 0 010-1.414l1.251-1.252A7.454 7.454 0 014.77 14H3a1 1 0 01-1-1v-2a1 1 0 011-1h1.77a7.44 7.44 0 01.703-1.698L4.222 7.05a1 1 0 010-1.414l1.414-1.414a1 1 0 011.414 0l1.252 1.251c.53-.3 1.099-.538 1.698-.703V3a1 1 0 011-1h2zm-1 6a4 4 0 100 8 4 4 0 000-8z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSettingsSolid);\n","import * as React from 'react';\nfunction IconSettings(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.056 2c.918 0 1.67.707 1.744 1.606l.006.144v.787l.243.093.154.063.093.042.554-.553a1.75 1.75 0 012.217-.212l.133.1.125.113 1.492 1.492a1.75 1.75 0 01.114 2.35l-.113.125-.524.523.046.1.068.156.064.157.039.108h.74a1.75 1.75 0 011.725 1.459l.018.148.006.143v2.112a1.75 1.75 0 01-1.606 1.744l-.144.006h-.739l-.04.108-.063.158-.068.156-.047.098.524.524c.553.551.663 1.389.29 2.08l-.08.136-.095.131-.115.128-1.492 1.492c-.59.59-1.502.676-2.216.21l-.131-.095-.128-.115-.554-.554-.093.043-.154.064-.243.092v.789a1.752 1.752 0 01-1.459 1.725l-.148.018-.143.006h-2.111A1.75 1.75 0 019.2 20.393l-.006-.143v-.848l-.08-.03-.148-.06-.214-.097-.602.603a1.75 1.75 0 01-2.217.212l-.133-.1-.125-.113-1.492-1.492a1.75 1.75 0 01-.114-2.35l.114-.125.632-.634-.09-.204-.079-.206h-.897a1.752 1.752 0 01-1.725-1.459l-.018-.148L2 13.056v-2.112A1.75 1.75 0 013.606 9.2l.144-.006h.896l.08-.206.089-.205-.632-.633a1.75 1.75 0 01-.213-2.217l.099-.133.114-.125 1.492-1.492c.59-.59 1.502-.676 2.216-.21l.131.095.128.115.602.601.214-.095.149-.062.079-.03V3.75c0-.791.528-1.469 1.294-1.684l.146-.035.151-.023.16-.008h2.111zm-2.069 1.499l-.073.003a.25.25 0 00-.212.186l-.007.062v1.377a.75.75 0 01-.528.717c-.417.129-.818.3-1.2.51a.75.75 0 01-.809-.054l-.083-.071-.952-.954-.058-.053a.25.25 0 00-.27-.023l-.059.044-1.493 1.493a.25.25 0 00-.04.3l.04.054 1.009 1.008a.75.75 0 01.132.883c-.2.375-.361.769-.483 1.177a.75.75 0 01-.61.528l-.108.008H3.75a.25.25 0 00-.243.193l-.007.057v2.11c0 .12.083.22.193.245l.057.007h1.433a.75.75 0 01.719.537c.121.408.283.802.482 1.176a.75.75 0 01-.061.8l-.071.083-1.009 1.008a.25.25 0 00-.04.3l.04.054 1.493 1.493a.25.25 0 00.3.04l.054-.04.985-.986a.75.75 0 01.893-.126c.38.21.782.382 1.199.511a.75.75 0 01.52.609l.008.108v1.377a.25.25 0 00.192.243l.057.007h2.111a.251.251 0 00.244-.193l.007-.057v-1.331a.75.75 0 01.545-.721 6.398 6.398 0 001.247-.503.75.75 0 01.8.06l.083.072.896.898.058.053a.25.25 0 00.27.023l.059-.044 1.462-1.46.052-.057a.25.25 0 00.023-.27l-.044-.06-.907-.905a.75.75 0 01-.126-.894 6.4 6.4 0 00.533-1.269.75.75 0 01.61-.528l.108-.008h1.275a.25.25 0 00.243-.193l.007-.057v-2.111a.25.25 0 00-.193-.244l-.057-.007h-1.275a.75.75 0 01-.718-.536 6.4 6.4 0 00-.533-1.269.75.75 0 01.055-.81l.071-.083.907-.906a.25.25 0 00.04-.3l-.04-.054-1.493-1.493a.25.25 0 00-.3-.04l-.054.04-.93.93a.75.75 0 01-.882.132 6.398 6.398 0 00-1.247-.503.75.75 0 01-.536-.611l-.008-.11-.001-1.33a.251.251 0 00-.194-.244l-.056-.007-2.069-.001zM12 7.533a4.467 4.467 0 110 8.934 4.467 4.467 0 010-8.934zm0 1.5a2.967 2.967 0 100 5.934 2.967 2.967 0 000-5.934z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSettings);\n","import * as React from 'react';\nfunction IconShortcuts(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 5c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0120.25 19H3.75A1.75 1.75 0 012 17.25V6.75C2 5.784 2.784 5 3.75 5h16.5zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 6.75v10.5a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V6.75a.25.25 0 00-.193-.243L20.25 6.5zM6.5 14a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm9 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-7a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h7zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm-12-3a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm-12-3a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShortcuts);\n","import * as React from 'react';\nfunction IconShowAll(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 6a1.75 1.75 0 011.744 1.606L21 7.75V11h-1.5V7.75l-.007-.057a.25.25 0 00-.175-.184L19.25 7.5H7.75l-.057.007a.25.25 0 00-.184.175L7.5 7.75v11.5l.007.057a.25.25 0 00.175.184l.068.009H11V21H7.75a1.75 1.75 0 01-1.744-1.606L6 19.25V7.75a1.75 1.75 0 011.606-1.744L7.75 6h11.5zm-2-3l.102.007a.75.75 0 010 1.486l-.102.007H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v12.5l-.007.102a.75.75 0 01-1.486 0L3 17.25V4.75l.006-.144a1.75 1.75 0 011.593-1.6L4.75 3h12.5zm-2.5 8.75a3 3 0 100 6 3 3 0 000-6zm0 7.5a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowAll);\n","import * as React from 'react';\nfunction IconShowLess(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.75 4a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 013.75 4zm3.5 0a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 017.25 4zm7.78 3.97a.75.75 0 01.073.976l-.073.084-2.219 2.22h7.439a.75.75 0 01.102 1.493l-.102.007h-7.439l2.22 2.22a.75.75 0 01-.977 1.133l-.084-.073-3.5-3.5-.055-.06-.046-.065-.049-.088-.044-.12-.018-.089-.007-.143.019-.136.03-.098.047-.1.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowLess);\n","import * as React from 'react';\nfunction IconShowMore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.75 4a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 013.75 4zm3.5 0a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 017.25 4zm3.5 0a.75.75 0 01.75.75v6.5h6.939l-2.22-2.22a.75.75 0 01.977-1.133l.084.073 3.5 3.5c.025.024.048.05.069.078l-.069-.078.04.042.04.052.068.114.038.098.02.084.012.088v.104l-.003.02-.006.055-.015.07-.024.072-.047.1-.032.051-.027.038-.064.072-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.219-2.22h-6.94l.001 6.5a.75.75 0 11-1.5 0V4.75a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowMore);\n","import * as React from 'react';\nfunction IconShowTemplate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 18v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zm8.25-5.25a3 3 0 100 6 3 3 0 000-6zm-8.25 0v3.75H4v-3.75h1.5zM20 7.5v3.75h-1.5V7.5H20zm-14.5 0v3.75H4V7.5h1.5zM18.25 2c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5zm-.75 18.25a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowTemplate);\n","import * as React from 'react';\nfunction IconSliders(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M2.5 12.75H7a.75.75 0 110 1.5H5.5v7a.75.75 0 11-1.5 0v-7H2.5a.75.75 0 110-1.5zm9.5-2a.75.75 0 01.75.75v9.75a.75.75 0 11-1.5 0V11.5a.75.75 0 01.75-.75zm9.5 4a.75.75 0 110 1.5H20v5a.75.75 0 11-1.5 0v-5H17a.75.75 0 110-1.5h4.5zM19.25 2a.75.75 0 01.75.75v9.75a.75.75 0 11-1.5 0V2.75a.75.75 0 01.75-.75zM4.75 2a.75.75 0 01.75.75v7.75a.75.75 0 11-1.5 0V2.75A.75.75 0 014.75 2zM12 2a.75.75 0 01.75.75v5h1.5a.75.75 0 110 1.5h-4.5a.75.75 0 010-1.5h1.5v-5A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSliders);\n","import * as React from 'react';\nfunction IconSmartpay(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75V7.5h-5a5 5 0 00-4.995 4.783L11 12.5a5 5 0 004.783 4.995L16 17.5h5v1.75A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm1.5 6c.69 0 1.25.56 1.25 1.25v4.5c0 .69-.56 1.25-1.25 1.25H16a3.5 3.5 0 010-7h4.75zM16 11a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSmartpay);\n","import * as React from 'react';\nfunction IconSortBy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.25 18a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm12.5-13.5a.75.75 0 01.743.648l.007.102v11.689l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.753.753 0 01-.125.101l-.088.049-.119.043-.106.021-.041.004-.07.002-.073-.006-.076-.013-.08-.023-.1-.043a.75.75 0 01-.182-.135l-3.5-3.5a.75.75 0 01.976-1.133l.084.073L17 16.939V5.25a.75.75 0 01.75-.75zm-9.5 9a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zm3-4.5a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm3-4.5a.75.75 0 110 1.5H2.75a.75.75 0 010-1.5h11.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSortBy);\n","import * as React from 'react';\nfunction IconSpinner(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <g fill=\"currentColor\" fillRule=\"evenodd\">\n <path d=\"M12 2C6.477 2 2 6.477 2 12s4.477 10 10 10 10-4.477 10-10S17.523 2 12 2zm0 1.5a8.5 8.5 0 110 17 8.5 8.5 0 010-17z\" />\n <path d=\"M12 2a.75.75 0 110 1.5 8.5 8.5 0 108.5 8.5.75.75 0 111.5 0c0 5.523-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2z\" />\n </g>\n </svg>\n );\n}\nexport default React.forwardRef(IconSpinner);\n","import * as React from 'react';\nfunction IconStarSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.895 8.726l-6.683.358-.105.012c-.608.114-.833.91-.328 1.319l5.197 4.217-1.725 6.467-.02.098c-.085.616.605 1.08 1.152.725L12 18.28l5.617 3.64.087.05c.56.27 1.214-.242 1.045-.872l-1.726-6.467 5.198-4.217.077-.072c.425-.45.14-1.225-.51-1.26l-6.684-.357L12.7 2.481a.75.75 0 00-1.4 0L8.895 8.726z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconStarSolid);\n","import * as React from 'react';\nfunction IconStar(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.895 8.726l-6.683.358-.105.012c-.608.114-.833.91-.328 1.319l5.197 4.217-1.725 6.467-.02.098c-.085.616.605 1.08 1.152.725L12 18.28l5.617 3.64.087.05c.56.27 1.214-.242 1.045-.872l-1.726-6.467 5.198-4.217.077-.072c.425-.45.14-1.225-.51-1.26l-6.684-.357L12.7 2.481a.75.75 0 00-1.4 0L8.895 8.726zM12 4.836l1.88 4.883.046.1a.75.75 0 00.614.38l5.223.278-4.062 3.297-.08.075a.75.75 0 00-.172.7l1.349 5.055-4.39-2.845-.096-.053a.75.75 0 00-.72.053l-4.391 2.845 1.35-5.054.02-.108a.75.75 0 00-.272-.668l-4.063-3.297 5.224-.278a.75.75 0 00.66-.48L12 4.836z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconStar);\n","import * as React from 'react';\nfunction IconSubscriptions(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H13l-.001-1.5h5.251a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75 5.499 13H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM4.142 16.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074zM8 14a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 018 14zm7.75-1a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5h7.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSubscriptions);\n","import * as React from 'react';\nfunction IconSystemEntries(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-8.75 9.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSystemEntries);\n","import * as React from 'react';\nfunction IconTag(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.356 2c.464 0 .909.184 1.237.513l9.92 9.919a1.75 1.75 0 010 2.475l-6.606 6.606a1.75 1.75 0 01-2.475 0l-9.92-9.92A1.75 1.75 0 012 10.356V3.75C2 2.784 2.784 2 3.75 2h6.606zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 3.75v6.606a.25.25 0 00.033.125l.04.051 9.92 9.92a.25.25 0 00.3.04l.053-.04 6.606-6.606a.25.25 0 00.04-.3l-.04-.053-9.92-9.92a.25.25 0 00-.111-.064l-.065-.009zm1.57 5.394c.365-.007.652.086.852.287.256.255.225.645-.02.89-.215.215-.453.322-.78.366-.512.07-.826.211-1.13.515-.335.335-.335.742-.114.963.203.203.484.176.923-.106l.123-.084.715-.5c1.04-.729 1.934-.732 2.666 0 .809.809.81 1.956.044 3.041l-.12.163.155.155c.238.238.128.494-.02.642-.14.14-.364.246-.581.093l-.072-.062-.145-.145c-.615.532-1.285.857-1.858.87-.349.004-.642-.082-.85-.29-.306-.307-.244-.714.042-1 .145-.146.32-.24.605-.301l.151-.028c.529-.08.991-.293 1.271-.573.425-.425.46-.818.197-1.08-.193-.194-.473-.155-.963.148l-.139.09-.71.476c-1.05.711-1.938.694-2.677-.045-.789-.79-.783-1.929-.026-2.957l.12-.154-.204-.203c-.242-.242-.121-.494.03-.646.138-.137.353-.246.57-.09l.073.062.214.214c.546-.435 1.14-.704 1.657-.71zM6.042 6.043a1 1 0 111.414 1.414 1 1 0 01-1.414-1.414z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTag);\n","import * as React from 'react';\nfunction IconTemplateOverride(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM20 7.5v3.75h-1.5V7.5H20zM4 11.25V7.5h9.25a.75.75 0 01.75.75v2.25a.75.75 0 01-.75.75H4zM18.25 2c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTemplateOverride);\n","import * as React from 'react';\nfunction IconTemplates(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM12.25 14a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-4a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM20 7.5v3.75h-1.5V7.5H20zm-14.5 0v3.75H4V7.5h1.5zM15.25 6a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5zm3-4c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTemplates);\n","import * as React from 'react';\nfunction IconThumbBoth(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 11.25a1.75 1.75 0 011.744 1.606l.006.144v4.586c0 .406-.141.797-.396 1.109l-.117.128-3.304 3.305a1.25 1.25 0 01-2.114-1.11l.032-.133.642-2.135H12.5a1.75 1.75 0 01-1.726-1.458l-.018-.148L10.75 17c0-.173.026-.345.076-.51l.059-.163 1.666-4a1.75 1.75 0 011.465-1.07l.15-.007H18zm0 1.5h-3.833a.25.25 0 00-.202.102l-.03.052-1.666 4a.25.25 0 00.174.34l.057.006h2.866a.85.85 0 01.838.99l-.024.104-.606 2.023 2.603-2.604a.25.25 0 00.064-.112l.009-.065V13a.25.25 0 00-.193-.243L18 12.75zm4-1.5c.513 0 .94.441.994 1.003l.006.122v4.5c0 .619-.45 1.125-1 1.125-.513 0-.94-.441-.994-1.003L21 16.875v-4.5c0-.619.45-1.125 1-1.125zM2 6c.513 0 .94.441.994 1.003L3 7.125v4.5c0 .619-.45 1.125-1 1.125-.513 0-.94-.441-.994-1.003L1 11.625v-4.5C1 6.506 1.45 6 2 6zm6.067-4.128a1.25 1.25 0 012.114 1.11l-.032.133-.642 2.135H11.5c.867 0 1.587.63 1.726 1.458l.018.148.006.144c0 .173-.026.345-.076.51l-.059.163-1.666 4a1.75 1.75 0 01-1.465 1.07l-.15.007H6a1.75 1.75 0 01-1.744-1.606L4.25 11V6.414c0-.406.141-.797.396-1.109l.117-.128 3.304-3.305zm.359 1.761L5.823 6.237a.25.25 0 00-.064.112l-.009.065V11a.25.25 0 00.193.243L6 11.25h3.833a.25.25 0 00.202-.102l.03-.052 1.666-4a.25.25 0 00-.174-.34L11.5 6.75H8.634c-.123-.006-.123-.006-.244-.036a.85.85 0 01-.594-.954l.024-.104.606-2.023z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbBoth);\n","import * as React from 'react';\nfunction IconThumbDownSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.839 4c.935 0 1.709.754 1.784 1.705l.006.152v9.277c0 .438-.149.86-.414 1.19l-.105.12-4.96 5.144a1.298 1.298 0 01-1.888.01 1.427 1.427 0 01-.389-1.118l.022-.155.85-4.253H4.687c-1.868 0-3.145-1.925-2.531-3.719l.06-.163 2.919-7.066c.266-.63.84-1.06 1.495-1.117L6.782 4h8.057zm5.37 0c.936 0 1.71.754 1.785 1.705l.006.152v7.43c0 1.02-.806 1.856-1.79 1.856-.936 0-1.71-.754-1.785-1.705l-.006-.152V5.857c0-1.021.806-1.857 1.79-1.857z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbDownSolid);\n","import * as React from 'react';\nfunction IconThumbDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.839 4c.935 0 1.709.754 1.784 1.705l.006.152v9.277c0 .438-.149.86-.414 1.19l-.105.12-4.96 5.144a1.298 1.298 0 01-1.888.01 1.427 1.427 0 01-.389-1.118l.022-.155.85-4.253H4.687c-1.868 0-3.145-1.925-2.531-3.719l.06-.163 2.919-7.066c.266-.63.84-1.06 1.495-1.117L6.782 4h8.057zm0 1.5H6.782a.284.284 0 00-.223.129l-.038.067-2.916 7.062c-.34.83.192 1.728.97 1.808l.112.006h6.888l-1.114 5.57 4.569-4.74a.373.373 0 00.092-.19l.007-.078V5.857c0-.18-.112-.318-.237-.35L14.84 5.5zm5.37-1.5c.936 0 1.71.754 1.785 1.705l.006.152v7.43c0 1.02-.806 1.856-1.79 1.856-.936 0-1.71-.754-1.785-1.705l-.006-.152V5.857c0-1.021.806-1.857 1.79-1.857z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbDown);\n","import * as React from 'react';\nfunction IconThumbUpSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.85 2.412a1.298 1.298 0 011.888-.01c.287.298.425.705.389 1.118l-.022.155-.85 4.253h5.058c1.868 0 3.145 1.925 2.531 3.719l-.06.163-2.919 7.066a1.811 1.811 0 01-1.495 1.117l-.152.007H9.161c-.935 0-1.709-.754-1.784-1.705l-.006-.152V8.866c0-.438.149-.86.414-1.19l.105-.12 4.96-5.144zM3.79 8.857c.936 0 1.71.754 1.785 1.705l.006.152v7.429C5.58 19.164 4.775 20 3.79 20c-.936 0-1.71-.754-1.785-1.705L2 18.143v-7.43c0-1.02.806-1.856 1.79-1.856z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbUpSolid);\n","import * as React from 'react';\nfunction IconThumbUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.738 2.403c.287.297.425.704.389 1.117l-.022.155-.85 4.253h5.058c1.868 0 3.145 1.925 2.531 3.719l-.06.163-2.919 7.066a1.811 1.811 0 01-1.495 1.117l-.152.007H9.161c-.935 0-1.709-.754-1.784-1.705l-.006-.152V8.866c0-.438.149-.86.414-1.19l.105-.12 4.96-5.144a1.298 1.298 0 011.888-.01zM3.79 8.857c.936 0 1.71.754 1.785 1.705l.006.152v7.429C5.58 19.164 4.775 20 3.79 20c-.936 0-1.71-.754-1.785-1.705L2 18.143v-7.43c0-1.02.806-1.856 1.79-1.856zm9.749-4.999L8.97 8.598a.373.373 0 00-.092.19l-.007.078v9.277c0 .18.112.318.237.35l.053.007h8.057c.08 0 .166-.047.223-.129l.038-.067 2.916-7.062c.34-.83-.192-1.728-.97-1.808l-.112-.006h-6.888l1.114-5.57z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbUp);\n","import * as React from 'react';\nfunction IconTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.867 6.097a.75.75 0 011.318.708l-.052.098-7 11a.75.75 0 01-1.145.145l-.074-.08-4-5A.75.75 0 017.01 11.95l.076.081 3.344 4.181 6.437-10.115z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTick);\n","import * as React from 'react';\nfunction IconTime(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0119.116 22h-5.232a1.75 1.75 0 01-1.724-2.05c.46-2.634 1.906-3.95 4.34-3.95zM12 2c5.523 0 10 4.477 10 10a9.96 9.96 0 01-1.005 4.374 5.097 5.097 0 00-1.182-1.017A8.488 8.488 0 0020.5 12a8.5 8.5 0 10-9.996 8.369c.02.578.196 1.118.487 1.58C5.942 21.444 2 17.183 2 12 2 6.477 6.477 2 12 2zm4.5 8.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zM12 5.25a.75.75 0 01.743.648L12.75 6v6a.75.75 0 01-.648.743L12 12.75H7.5a.75.75 0 01-.102-1.493l.102-.007h3.75V6a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTime);\n","import * as React from 'react';\nfunction IconTransferCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M18.804 15.647a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072z\"\n fill=\"#CF3C16\"\n fillRule=\"nonzero\"\n />\n <path\n d=\"M5.5 16.5v3.75a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V16.5h1.5zm2.946-6.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm.914 2.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </g>\n </svg>\n );\n}\nexport default React.forwardRef(IconTransferCancel);\n","import * as React from 'react';\nfunction IconTransferLocked(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 16.5v3.75a.25.25 0 00.193.243l.057.007h4.75V22H5.75A1.75 1.75 0 014 20.25V16.5h1.5zM16 12a3 3 0 013 3v1a1 1 0 011 1v4a1 1 0 01-1 1h-6a1 1 0 01-1-1v-4a1 1 0 011-1v-1a3 3 0 013-3zm0 5.5a1 1 0 00-.5 1.866V20a.5.5 0 00.992.09L16.5 20l.001-.634A1 1 0 0016 17.5zm-7.554-7.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM16 13.5a1.5 1.5 0 00-1.493 1.356L14.5 15v1h3v-1a1.5 1.5 0 00-1.356-1.493L16 13.5zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V11.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm.914 2.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTransferLocked);\n","import * as React from 'react';\nfunction IconTransfer(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V16.5h1.5v3.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm-5.14 8.397l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTransfer);\n","import * as React from 'react';\nfunction IconUndo(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path d=\"M6.75 4.75l-4 4 4 4\" stroke=\"currentColor\" strokeWidth={1.5} strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n <path\n d=\"M3 8.75h13c2.9 0 5.25 2.35 5.25 5.25v0c0 2.9-2.35 5.25-5.25 5.25h-5.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUndo);\n","import * as React from 'react';\nfunction IconUndock(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 5v1.5H4.75a.25.25 0 00-.243.193L4.5 6.75v12.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V12H19v7.25A1.75 1.75 0 0117.25 21H4.75A1.75 1.75 0 013 19.25V6.75C3 5.784 3.784 5 4.75 5H12zm8.25-2a.75.75 0 01.743.648L21 3.75v4.5a.75.75 0 01-1.493.102L19.5 8.25V5.56l-4.97 4.97a.75.75 0 01-1.133-.976l.073-.084 4.968-4.97H15.75a.75.75 0 01-.743-.648L15 3.75a.75.75 0 01.648-.743L15.75 3h4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUndock);\n","import * as React from 'react';\nfunction IconUnreconciled(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.368 4.346l.092.062 18 14a.75.75 0 01-.828 1.246l-.092-.062-3.34-2.597L17 17h-2.5a.75.75 0 01-.102-1.493l.102-.007h.778l-3.536-2.75H7a.75.75 0 110-1.5h2.814l-3.46-2.69a3.501 3.501 0 00.454 6.935L7 15.5h2.5a.75.75 0 01.102 1.493L9.5 17H7a5 5 0 01-2.074-9.55L2.54 5.591a.75.75 0 01.828-1.246zM17 7a5 5 0 013.39 8.676l-1.208-.94a3.5 3.5 0 00-1.99-6.231L17 8.5h-2.5a.75.75 0 01-.102-1.493L14.5 7H17zm0 4.25a.75.75 0 110 1.5h-.372l-1.929-1.5H17z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUnreconciled);\n","import * as React from 'react';\nfunction IconWarning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.527 17.197c.157-.827.938-1.344 1.771-1.177a1.515 1.515 0 011.213 1.772c-.157.826-.939 1.343-1.771 1.177a1.515 1.515 0 01-1.213-1.772zm2.265-11.05c.164-.863.784-1.276 1.607-1.112.815.163 1.23.782 1.066 1.646l-.038.183-.025.097-1.368 6.473c-.179.793-.67 1.182-1.43 1.03-.712-.142-1.032-.634-.96-1.356l.02-.147 1.1-6.628.028-.185z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWarning);\n","import * as React from 'react';\nfunction IconWebshop(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11 15.5a2.25 2.25 0 110 4.5 2.25 2.25 0 010-4.5zm5.831 0a2.25 2.25 0 110 4.5 2.25 2.25 0 010-4.5zM11 17a.75.75 0 100 1.5.75.75 0 000-1.5zm5.831 0a.75.75 0 100 1.5.75.75 0 000-1.5zM5.287 4a1.75 1.75 0 011.56.955l.062.138 3.24 8a.25.25 0 00.173.15l.06.007h7.743a.25.25 0 00.204-.105l.028-.054 2.159-5.496a.25.25 0 00-.141-.324l-.045-.013-.047-.005-10.04-.003a.75.75 0 01-.102-1.493l.102-.007 10.04.003A1.75 1.75 0 0121.962 8l-.049.143-2.158 5.497a1.75 1.75 0 01-1.476 1.103l-.153.007h-7.743a1.75 1.75 0 01-1.56-.955l-.062-.138-3.24-8a.25.25 0 00-.173-.15l-.06-.007H2.75a.75.75 0 01-.102-1.493L2.75 4h2.537z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWebshop);\n","import * as React from 'react';\nfunction IconWebsite(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm.25 6h-17v8.25a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V10zm-.25-4.5H3.75a.25.25 0 00-.243.193L3.5 5.75V8.5h17V5.75a.25.25 0 00-.193-.243L20.25 5.5zM5.5 6.5v1h-1v-1h1zm2 0v1h-1v-1h1zm2 0v1h-1v-1h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWebsite);\n","import * as React from 'react';\nfunction IconWorkflow(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.144 16.292a2.853 2.853 0 00-2.754 2.144H7.722a2.857 2.857 0 01-2.856-2.858 2.857 2.857 0 012.856-2.859h1.53a2.842 2.842 0 005.508 0h1.529a4.286 4.286 0 004.283-4.287 4.286 4.286 0 00-4.283-4.288H7.62A2.856 2.856 0 002 4.859a2.856 2.856 0 005.62.715h8.669a2.857 2.857 0 012.855 2.858 2.857 2.857 0 01-2.855 2.858h-1.53a2.842 2.842 0 00-5.508 0h-1.53a4.286 4.286 0 00-4.283 4.288 4.286 4.286 0 004.284 4.287h8.668a2.85 2.85 0 005.6-.964 2.852 2.852 0 00-2.846-2.609zM4.866 6.288a1.429 1.429 0 11.002-2.857 1.429 1.429 0 01-.002 2.857zm7.14 4.287a1.429 1.429 0 11-.002 2.857 1.429 1.429 0 01.001-2.857zm7.138 10.005a1.429 1.429 0 11.002-2.857 1.429 1.429 0 01-.002 2.857z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWorkflow);\n","import * as React from 'react';\nfunction IconZoom(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 2.25a7.75 7.75 0 015.985 12.674l5.545 5.546a.75.75 0 01-.976 1.133l-.084-.073-5.546-5.545A7.75 7.75 0 1110 2.25zm0 1.5a6.25 6.25 0 100 12.5 6.25 6.25 0 000-12.5zm0 2.75a.75.75 0 01.75.75v2h2a.75.75 0 110 1.5h-2v2a.75.75 0 11-1.5 0v-2h-2a.75.75 0 110-1.5h2v-2A.75.75 0 0110 6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconZoom);\n","import AccountPreview from './AccountPreview';\nimport AccountingYearCancel from './AccountingYearCancel';\nimport AccountingYear from './AccountingYear';\nimport Accounting from './Accounting';\nimport ArrowBottom from './ArrowBottom';\nimport ArrowDown from './ArrowDown';\nimport ArrowEnd from './ArrowEnd';\nimport ArrowLeft from './ArrowLeft';\nimport ArrowRight from './ArrowRight';\nimport ArrowStart from './ArrowStart';\nimport ArrowTop from './ArrowTop';\nimport ArrowUp from './ArrowUp';\nimport AttachAuto from './AttachAuto';\nimport AttachCancel from './AttachCancel';\nimport Attach from './Attach';\nimport AutotextInsert from './AutotextInsert';\nimport Autotext from './Autotext';\nimport BasicTabs from './BasicTabs';\nimport Basic from './Basic';\nimport BellSolid from './BellSolid';\nimport Book from './Book';\nimport Booking from './Booking';\nimport Budget from './Budget';\nimport Calendar from './Calendar';\nimport CashAccount from './CashAccount';\nimport CashReports from './CashReports';\nimport ChatSolid from './ChatSolid';\nimport Chat from './Chat';\nimport ChevronDownDouble from './ChevronDownDouble';\nimport ChevronDownSolid from './ChevronDownSolid';\nimport ChevronDown from './ChevronDown';\nimport ChevronLeftDouble from './ChevronLeftDouble';\nimport ChevronLeftSolid from './ChevronLeftSolid';\nimport ChevronLeft from './ChevronLeft';\nimport ChevronRightDouble from './ChevronRightDouble';\nimport ChevronRightSolid from './ChevronRightSolid';\nimport ChevronRight from './ChevronRight';\nimport ChevronUpDouble from './ChevronUpDouble';\nimport ChevronUpSolid from './ChevronUpSolid';\nimport ChevronUp from './ChevronUp';\nimport CircleClose from './CircleClose';\nimport CircleMinus from './CircleMinus';\nimport CirclePlus from './CirclePlus';\nimport CircleTick from './CircleTick';\nimport ClampOpen from './ClampOpen';\nimport Clamp from './Clamp';\nimport Close from './Close';\nimport ConnectionEnable from './ConnectionEnable';\nimport ConnectionRevoke from './ConnectionRevoke';\nimport Contacts from './Contacts';\nimport Copy from './Copy';\nimport Courses from './Courses';\nimport Credit from './Credit';\nimport DeletePermanently from './DeletePermanently';\nimport Delete from './Delete';\nimport Depecriate from './Depecriate';\nimport Developer from './Developer';\nimport DistributionTemplate from './DistributionTemplate';\nimport DocumentApprove from './DocumentApprove';\nimport DocumentCreateEntry from './DocumentCreateEntry';\nimport DocumentCut from './DocumentCut';\nimport DocumentError from './DocumentError';\nimport DocumentIsolatePage from './DocumentIsolatePage';\nimport DocumentMerge from './DocumentMerge';\nimport DocumentMove from './DocumentMove';\nimport DocumentPreview from './DocumentPreview';\nimport DocumentReceived from './DocumentReceived';\nimport DocumentRejectedRequest from './DocumentRejectedRequest';\nimport DocumentSplit from './DocumentSplit';\nimport DocumentTime from './DocumentTime';\nimport Document from './Document';\nimport Download from './Download';\nimport Drag from './Drag';\nimport ECopedia from './ECopedia';\nimport ESignature from './ESignature';\nimport Edit from './Edit';\nimport EllipsisHorizontal from './EllipsisHorizontal';\nimport EllipsisVertical from './EllipsisVertical';\nimport EntriesOnAccount from './EntriesOnAccount';\nimport EntriesOpen from './EntriesOpen';\nimport EntriesWarning from './EntriesWarning';\nimport EntryTypeCustomerInvoice from './EntryTypeCustomerInvoice';\nimport EntryTypeCustomerPayment from './EntryTypeCustomerPayment';\nimport EntryTypeJournalEntry from './EntryTypeJournalEntry';\nimport EntryTypeManualCustomerInvoice from './EntryTypeManualCustomerInvoice';\nimport EntryTypeSupplierInvoice from './EntryTypeSupplierInvoice';\nimport EntryTypeSupplierPayment from './EntryTypeSupplierPayment';\nimport EnvelopeApproved from './EnvelopeApproved';\nimport Envelope from './Envelope';\nimport ExpandView from './ExpandView';\nimport Expenses from './Expenses';\nimport ExportToExcel from './ExportToExcel';\nimport ExportToPdf from './ExportToPdf';\nimport Export from './Export';\nimport FilterSolid from './FilterSolid';\nimport Filter from './Filter';\nimport GraphSolid from './GraphSolid';\nimport Hash from './Hash';\nimport Home from './Home';\nimport Images from './Images';\nimport Import from './Import';\nimport InboxEinvoicing from './InboxEinvoicing';\nimport InboxScanning from './InboxScanning';\nimport InboxSmart from './InboxSmart';\nimport Inbox from './Inbox';\nimport Info from './Info';\nimport InventoryMatrix from './InventoryMatrix';\nimport Inventory from './Inventory';\nimport JournalPro from './JournalPro';\nimport LayoutBoth from './LayoutBoth';\nimport LayoutFirst from './LayoutFirst';\nimport LayoutLast from './LayoutLast';\nimport LayoutNone from './LayoutNone';\nimport Layout from './Layout';\nimport LedgerCardCustomerReminder from './LedgerCardCustomerReminder';\nimport LedgerCardManualCustomerInvoice from './LedgerCardManualCustomerInvoice';\nimport LedgerCardObsoleteStock from './LedgerCardObsoleteStock';\nimport LedgerCardOpeningEntry from './LedgerCardOpeningEntry';\nimport LedgerCardReservedEntry from './LedgerCardReservedEntry';\nimport LedgerCardShrinkagePilferage from './LedgerCardShrinkagePilferage';\nimport LedgerCardStockAdjustment from './LedgerCardStockAdjustment';\nimport LedgerCardTransferredOpeningEntry from './LedgerCardTransferredOpeningEntry';\nimport LedgerCard from './LedgerCard';\nimport Lightbulb from './Lightbulb';\nimport Line from './Line';\nimport ListBulleted from './ListBulleted';\nimport ListSearch from './ListSearch';\nimport List from './List';\nimport LockOpen from './LockOpen';\nimport LogOut from './LogOut';\nimport Log from './Log';\nimport Market from './Market';\nimport MatchAmount from './MatchAmount';\nimport MatchEntries from './MatchEntries';\nimport Menu from './Menu';\nimport Mileage from './Mileage';\nimport ModalResize from './ModalResize';\nimport ModalShrink from './ModalShrink';\nimport MoreSolid from './MoreSolid';\nimport More from './More';\nimport Move from './Move';\nimport NavigationList from './NavigationList';\nimport NoteFollowUp from './NoteFollowUp';\nimport NoteRead from './NoteRead';\nimport Note from './Note';\nimport Numbers from './Numbers';\nimport PartnerApi from './PartnerApi';\nimport Period from './Period';\nimport PersonChange from './PersonChange';\nimport PersonMinus from './PersonMinus';\nimport PersonPlus from './PersonPlus';\nimport PersonTick from './PersonTick';\nimport Play from './Play';\nimport PlusMinus from './PlusMinus';\nimport Print from './Print';\nimport ProcessPayment from './ProcessPayment';\nimport ProductLedgerCard from './ProductLedgerCard';\nimport Profile from './Profile';\nimport ProjectCards from './ProjectCards';\nimport Projects from './Projects';\nimport Quicklinks from './Quicklinks';\nimport RatingBankruptcy from './RatingBankruptcy';\nimport RatingPaymentProblems from './RatingPaymentProblems';\nimport Reconciled from './Reconciled';\nimport Refresh from './Refresh';\nimport ReportSolid from './ReportSolid';\nimport Report from './Report';\nimport Restore from './Restore';\nimport RotateLeft from './RotateLeft';\nimport RotateRight from './RotateRight';\nimport Sales from './Sales';\nimport SearchBold from './SearchBold';\nimport Search from './Search';\nimport SecureTick from './SecureTick';\nimport Secure from './Secure';\nimport SettingsSolid from './SettingsSolid';\nimport Settings from './Settings';\nimport Shortcuts from './Shortcuts';\nimport ShowAll from './ShowAll';\nimport ShowLess from './ShowLess';\nimport ShowMore from './ShowMore';\nimport ShowTemplate from './ShowTemplate';\nimport Sliders from './Sliders';\nimport Smartpay from './Smartpay';\nimport SortBy from './SortBy';\nimport Spinner from './Spinner';\nimport StarSolid from './StarSolid';\nimport Star from './Star';\nimport Subscriptions from './Subscriptions';\nimport SystemEntries from './SystemEntries';\nimport Tag from './Tag';\nimport TemplateOverride from './TemplateOverride';\nimport Templates from './Templates';\nimport ThumbBoth from './ThumbBoth';\nimport ThumbDownSolid from './ThumbDownSolid';\nimport ThumbDown from './ThumbDown';\nimport ThumbUpSolid from './ThumbUpSolid';\nimport ThumbUp from './ThumbUp';\nimport Tick from './Tick';\nimport Time from './Time';\nimport TransferCancel from './TransferCancel';\nimport TransferLocked from './TransferLocked';\nimport Transfer from './Transfer';\nimport Undo from './Undo';\nimport Undock from './Undock';\nimport Unreconciled from './Unreconciled';\nimport Warning from './Warning';\nimport Webshop from './Webshop';\nimport Website from './Website';\nimport Workflow from './Workflow';\nimport Zoom from './Zoom';\n\nexport const icons: Record<\n IconName,\n React.ForwardRefExoticComponent<React.SVGAttributes<SVGSVGElement> & React.RefAttributes<SVGSVGElement>>\n> = {\n 'account-preview': AccountPreview,\n 'accounting-year-cancel': AccountingYearCancel,\n 'accounting-year': AccountingYear,\n accounting: Accounting,\n 'arrow-bottom': ArrowBottom,\n 'arrow-down': ArrowDown,\n 'arrow-end': ArrowEnd,\n 'arrow-left': ArrowLeft,\n 'arrow-right': ArrowRight,\n 'arrow-start': ArrowStart,\n 'arrow-top': ArrowTop,\n 'arrow-up': ArrowUp,\n 'attach-auto': AttachAuto,\n 'attach-cancel': AttachCancel,\n attach: Attach,\n 'autotext-insert': AutotextInsert,\n autotext: Autotext,\n 'basic-tabs': BasicTabs,\n basic: Basic,\n 'bell-solid': BellSolid,\n book: Book,\n booking: Booking,\n budget: Budget,\n calendar: Calendar,\n 'cash-account': CashAccount,\n 'cash-reports': CashReports,\n 'chat-solid': ChatSolid,\n chat: Chat,\n 'chevron-down-double': ChevronDownDouble,\n 'chevron-down-solid': ChevronDownSolid,\n 'chevron-down': ChevronDown,\n 'chevron-left-double': ChevronLeftDouble,\n 'chevron-left-solid': ChevronLeftSolid,\n 'chevron-left': ChevronLeft,\n 'chevron-right-double': ChevronRightDouble,\n 'chevron-right-solid': ChevronRightSolid,\n 'chevron-right': ChevronRight,\n 'chevron-up-double': ChevronUpDouble,\n 'chevron-up-solid': ChevronUpSolid,\n 'chevron-up': ChevronUp,\n 'circle-close': CircleClose,\n 'circle-minus': CircleMinus,\n 'circle-plus': CirclePlus,\n 'circle-tick': CircleTick,\n 'clamp-open': ClampOpen,\n clamp: Clamp,\n close: Close,\n 'connection-enable': ConnectionEnable,\n 'connection-revoke': ConnectionRevoke,\n contacts: Contacts,\n copy: Copy,\n courses: Courses,\n credit: Credit,\n 'delete-permanently': DeletePermanently,\n delete: Delete,\n depecriate: Depecriate,\n developer: Developer,\n 'distribution-template': DistributionTemplate,\n 'document-approve': DocumentApprove,\n 'document-create-entry': DocumentCreateEntry,\n 'document-cut': DocumentCut,\n 'document-error': DocumentError,\n 'document-isolate-page': DocumentIsolatePage,\n 'document-merge': DocumentMerge,\n 'document-move': DocumentMove,\n 'document-preview': DocumentPreview,\n 'document-received': DocumentReceived,\n 'document-rejected-request': DocumentRejectedRequest,\n 'document-split': DocumentSplit,\n 'document-time': DocumentTime,\n document: Document,\n download: Download,\n drag: Drag,\n 'e-copedia': ECopedia,\n 'e-signature': ESignature,\n edit: Edit,\n 'ellipsis-horizontal': EllipsisHorizontal,\n 'ellipsis-vertical': EllipsisVertical,\n 'entries-on-account': EntriesOnAccount,\n 'entries-open': EntriesOpen,\n 'entries-warning': EntriesWarning,\n 'entry-type-customer-invoice': EntryTypeCustomerInvoice,\n 'entry-type-customer-payment': EntryTypeCustomerPayment,\n 'entry-type-journal-entry': EntryTypeJournalEntry,\n 'entry-type-manual-customer-invoice': EntryTypeManualCustomerInvoice,\n 'entry-type-supplier-invoice': EntryTypeSupplierInvoice,\n 'entry-type-supplier-payment': EntryTypeSupplierPayment,\n 'envelope-approved': EnvelopeApproved,\n envelope: Envelope,\n 'expand-view': ExpandView,\n expenses: Expenses,\n 'export-to-excel': ExportToExcel,\n 'export-to-pdf': ExportToPdf,\n export: Export,\n 'filter-solid': FilterSolid,\n filter: Filter,\n 'graph-solid': GraphSolid,\n hash: Hash,\n home: Home,\n images: Images,\n import: Import,\n 'inbox-einvoicing': InboxEinvoicing,\n 'inbox-scanning': InboxScanning,\n 'inbox-smart': InboxSmart,\n inbox: Inbox,\n info: Info,\n 'inventory-matrix': InventoryMatrix,\n inventory: Inventory,\n 'journal-pro': JournalPro,\n 'layout-both': LayoutBoth,\n 'layout-first': LayoutFirst,\n 'layout-last': LayoutLast,\n 'layout-none': LayoutNone,\n layout: Layout,\n 'ledger-card-customer-reminder': LedgerCardCustomerReminder,\n 'ledger-card-manual-customer-invoice': LedgerCardManualCustomerInvoice,\n 'ledger-card-obsolete-stock': LedgerCardObsoleteStock,\n 'ledger-card-opening-entry': LedgerCardOpeningEntry,\n 'ledger-card-reserved-entry': LedgerCardReservedEntry,\n 'ledger-card-shrinkage-pilferage': LedgerCardShrinkagePilferage,\n 'ledger-card-stock-adjustment': LedgerCardStockAdjustment,\n 'ledger-card-transferred-opening-entry': LedgerCardTransferredOpeningEntry,\n 'ledger-card': LedgerCard,\n lightbulb: Lightbulb,\n line: Line,\n 'list-bulleted': ListBulleted,\n 'list-search': ListSearch,\n list: List,\n 'lock-open': LockOpen,\n 'log-out': LogOut,\n log: Log,\n market: Market,\n 'match-amount': MatchAmount,\n 'match-entries': MatchEntries,\n menu: Menu,\n mileage: Mileage,\n 'modal-resize': ModalResize,\n 'modal-shrink': ModalShrink,\n 'more-solid': MoreSolid,\n more: More,\n move: Move,\n 'navigation-list': NavigationList,\n 'note-follow-up': NoteFollowUp,\n 'note-read': NoteRead,\n note: Note,\n numbers: Numbers,\n 'partner-api': PartnerApi,\n period: Period,\n 'person-change': PersonChange,\n 'person-minus': PersonMinus,\n 'person-plus': PersonPlus,\n 'person-tick': PersonTick,\n play: Play,\n 'plus-minus': PlusMinus,\n print: Print,\n 'process-payment': ProcessPayment,\n 'product-ledger-card': ProductLedgerCard,\n profile: Profile,\n 'project-cards': ProjectCards,\n projects: Projects,\n quicklinks: Quicklinks,\n 'rating-bankruptcy': RatingBankruptcy,\n 'rating-payment-problems': RatingPaymentProblems,\n reconciled: Reconciled,\n refresh: Refresh,\n 'report-solid': ReportSolid,\n report: Report,\n restore: Restore,\n 'rotate-left': RotateLeft,\n 'rotate-right': RotateRight,\n sales: Sales,\n 'search-bold': SearchBold,\n search: Search,\n 'secure-tick': SecureTick,\n secure: Secure,\n 'settings-solid': SettingsSolid,\n settings: Settings,\n shortcuts: Shortcuts,\n 'show-all': ShowAll,\n 'show-less': ShowLess,\n 'show-more': ShowMore,\n 'show-template': ShowTemplate,\n sliders: Sliders,\n smartpay: Smartpay,\n 'sort-by': SortBy,\n spinner: Spinner,\n 'star-solid': StarSolid,\n star: Star,\n subscriptions: Subscriptions,\n 'system-entries': SystemEntries,\n tag: Tag,\n 'template-override': TemplateOverride,\n templates: Templates,\n 'thumb-both': ThumbBoth,\n 'thumb-down-solid': ThumbDownSolid,\n 'thumb-down': ThumbDown,\n 'thumb-up-solid': ThumbUpSolid,\n 'thumb-up': ThumbUp,\n tick: Tick,\n time: Time,\n 'transfer-cancel': TransferCancel,\n 'transfer-locked': TransferLocked,\n transfer: Transfer,\n undo: Undo,\n undock: Undock,\n unreconciled: Unreconciled,\n warning: Warning,\n webshop: Webshop,\n website: Website,\n workflow: Workflow,\n zoom: Zoom,\n};\n\n// the prop extraction tool can't handle this\n//export type IconName = keyof typeof icons;\nexport type IconName =\n | 'account-preview'\n | 'accounting-year-cancel'\n | 'accounting-year'\n | 'accounting'\n | 'arrow-bottom'\n | 'arrow-down'\n | 'arrow-end'\n | 'arrow-left'\n | 'arrow-right'\n | 'arrow-start'\n | 'arrow-top'\n | 'arrow-up'\n | 'attach-auto'\n | 'attach-cancel'\n | 'attach'\n | 'autotext-insert'\n | 'autotext'\n | 'basic-tabs'\n | 'basic'\n | 'bell-solid'\n | 'book'\n | 'booking'\n | 'budget'\n | 'calendar'\n | 'cash-account'\n | 'cash-reports'\n | 'chat-solid'\n | 'chat'\n | 'chevron-down-double'\n | 'chevron-down-solid'\n | 'chevron-down'\n | 'chevron-left-double'\n | 'chevron-left-solid'\n | 'chevron-left'\n | 'chevron-right-double'\n | 'chevron-right-solid'\n | 'chevron-right'\n | 'chevron-up-double'\n | 'chevron-up-solid'\n | 'chevron-up'\n | 'circle-close'\n | 'circle-minus'\n | 'circle-plus'\n | 'circle-tick'\n | 'clamp-open'\n | 'clamp'\n | 'close'\n | 'connection-enable'\n | 'connection-revoke'\n | 'contacts'\n | 'copy'\n | 'courses'\n | 'credit'\n | 'delete-permanently'\n | 'delete'\n | 'depecriate'\n | 'developer'\n | 'distribution-template'\n | 'document-approve'\n | 'document-create-entry'\n | 'document-cut'\n | 'document-error'\n | 'document-isolate-page'\n | 'document-merge'\n | 'document-move'\n | 'document-preview'\n | 'document-received'\n | 'document-rejected-request'\n | 'document-split'\n | 'document-time'\n | 'document'\n | 'download'\n | 'drag'\n | 'e-copedia'\n | 'e-signature'\n | 'edit'\n | 'ellipsis-horizontal'\n | 'ellipsis-vertical'\n | 'entries-on-account'\n | 'entries-open'\n | 'entries-warning'\n | 'entry-type-customer-invoice'\n | 'entry-type-customer-payment'\n | 'entry-type-journal-entry'\n | 'entry-type-manual-customer-invoice'\n | 'entry-type-supplier-invoice'\n | 'entry-type-supplier-payment'\n | 'envelope-approved'\n | 'envelope'\n | 'expand-view'\n | 'expenses'\n | 'export-to-excel'\n | 'export-to-pdf'\n | 'export'\n | 'filter-solid'\n | 'filter'\n | 'graph-solid'\n | 'hash'\n | 'home'\n | 'images'\n | 'import'\n | 'inbox-einvoicing'\n | 'inbox-scanning'\n | 'inbox-smart'\n | 'inbox'\n | 'info'\n | 'inventory-matrix'\n | 'inventory'\n | 'journal-pro'\n | 'layout-both'\n | 'layout-first'\n | 'layout-last'\n | 'layout-none'\n | 'layout'\n | 'ledger-card-customer-reminder'\n | 'ledger-card-manual-customer-invoice'\n | 'ledger-card-obsolete-stock'\n | 'ledger-card-opening-entry'\n | 'ledger-card-reserved-entry'\n | 'ledger-card-shrinkage-pilferage'\n | 'ledger-card-stock-adjustment'\n | 'ledger-card-transferred-opening-entry'\n | 'ledger-card'\n | 'lightbulb'\n | 'line'\n | 'list-bulleted'\n | 'list-search'\n | 'list'\n | 'lock-open'\n | 'log-out'\n | 'log'\n | 'market'\n | 'match-amount'\n | 'match-entries'\n | 'menu'\n | 'mileage'\n | 'modal-resize'\n | 'modal-shrink'\n | 'more-solid'\n | 'more'\n | 'move'\n | 'navigation-list'\n | 'note-follow-up'\n | 'note-read'\n | 'note'\n | 'numbers'\n | 'partner-api'\n | 'period'\n | 'person-change'\n | 'person-minus'\n | 'person-plus'\n | 'person-tick'\n | 'play'\n | 'plus-minus'\n | 'print'\n | 'process-payment'\n | 'product-ledger-card'\n | 'profile'\n | 'project-cards'\n | 'projects'\n | 'quicklinks'\n | 'rating-bankruptcy'\n | 'rating-payment-problems'\n | 'reconciled'\n | 'refresh'\n | 'report-solid'\n | 'report'\n | 'restore'\n | 'rotate-left'\n | 'rotate-right'\n | 'sales'\n | 'search-bold'\n | 'search'\n | 'secure-tick'\n | 'secure'\n | 'settings-solid'\n | 'settings'\n | 'shortcuts'\n | 'show-all'\n | 'show-less'\n | 'show-more'\n | 'show-template'\n | 'sliders'\n | 'smartpay'\n | 'sort-by'\n | 'spinner'\n | 'star-solid'\n | 'star'\n | 'subscriptions'\n | 'system-entries'\n | 'tag'\n | 'template-override'\n | 'templates'\n | 'thumb-both'\n | 'thumb-down-solid'\n | 'thumb-down'\n | 'thumb-up-solid'\n | 'thumb-up'\n | 'tick'\n | 'time'\n | 'transfer-cancel'\n | 'transfer-locked'\n | 'transfer'\n | 'undo'\n | 'undock'\n | 'unreconciled'\n | 'warning'\n | 'webshop'\n | 'website'\n | 'workflow'\n | 'zoom';\n","import React from 'react';\nimport cn from 'classnames';\nimport { IconName, icons } from './components/index';\n\nexport { icons } from './components/index';\nexport type { IconName } from './components/index';\n\nexport type IconProps = React.SVGAttributes<SVGSVGElement> & {\n /** Set what svg icon should be rendered */\n name: IconName; // this dynamic type causes the type extraction for props to fail\n};\n\nexport const Icon = React.forwardRef(function Icon(props: IconProps, ref: React.Ref<SVGSVGElement>) {\n const { name, ...otherProps } = props;\n const Component = icons[name];\n /* 24x24 _at the base body font_ - must be em so that they scale with font size - tailwind spacing uses rem */\n const className = cn('inline-flex h-[1.715em] w-[1.715em] flex-shrink-0', props.className, {\n 'p-[3px]': props.className?.includes('rounded-full'),\n });\n\n return Component ? (\n <Component {...otherProps} className={className} data-taco=\"icon\" focusable=\"false\" ref={ref} role=\"img\" />\n ) : null;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport { Icon } from '../Icon/Icon';\n\ntype AccordionContext = {\n as: 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n};\nconst AccordionContext = React.createContext<AccordionContext>({\n as: 'h2',\n});\n\nexport type AccordionTriggerProps = React.HTMLAttributes<HTMLElement>;\n\nconst StyledTrigger = React.forwardRef(function AccordionStyledTrigger(\n props: AccordionPrimitive.AccordionTriggerProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n const isExpanded = !!props['aria-expanded'];\n\n const className = cn(\n 'w-full inline-flex justify-between items-center align-middle',\n 'focus:rounded-sm focus:border-blue-500 focus:yt-focus',\n props.className\n );\n\n return (\n <button {...props} ref={ref} className={className}>\n {props.children}\n <Icon name={isExpanded ? 'chevron-up' : 'chevron-down'} />\n </button>\n );\n});\n\nconst Trigger = React.forwardRef(function AccordionTrigger(props: AccordionTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const { children } = props;\n const { as: Heading } = React.useContext(AccordionContext);\n\n return (\n <AccordionPrimitive.Header asChild>\n <Heading className=\"my-3\">\n <AccordionPrimitive.Trigger ref={ref} asChild>\n <StyledTrigger>{children}</StyledTrigger>\n </AccordionPrimitive.Trigger>\n </Heading>\n </AccordionPrimitive.Header>\n );\n});\n\nexport type AccordionContentProps = React.HTMLAttributes<HTMLElement>;\nconst Content = React.forwardRef(function AccordionContent(props: AccordionContentProps, ref: React.Ref<HTMLDivElement>) {\n return <AccordionPrimitive.Content {...props} ref={ref} />;\n});\n\nexport type AccordionItemProps = React.HTMLAttributes<HTMLDivElement> & {\n id: string;\n disabled?: boolean;\n};\nconst Item = (props: AccordionItemProps) => {\n const { id, ...otherProps } = props;\n return <AccordionPrimitive.Item {...otherProps} value={id} />;\n};\n\ntype AccordionBaseProps = {\n children: React.ReactNode[];\n\n /** Change what heading element accordion regions will render */\n as?: 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n\n /** Additional classes for Accordion root element */\n className?: string;\n};\n\nexport interface AccordionUncontrolledProps extends AccordionBaseProps {\n /** Default expanded accordion(s) */\n defaultId: string | string[];\n\n id?: never;\n onChange?: never;\n}\n\nexport interface AccordionMultipleControlledProps extends AccordionBaseProps {\n /** Expanded accordions */\n id: string[];\n\n /** onChange function to receive ids of expanded accordions */\n onChange: (id: string[]) => void;\n\n defaultId?: never;\n}\nexport interface AccordionSingleControlledProps extends AccordionBaseProps {\n /** Expanded accordion */\n id: string;\n\n /** onChange function to receive id of expanded accordion */\n onChange: (id: string) => void;\n\n defaultId?: never;\n}\n\nexport type AccordionProps = AccordionUncontrolledProps | AccordionMultipleControlledProps | AccordionSingleControlledProps;\n\nexport const Accordion = (props: AccordionProps) => {\n const { id, defaultId, onChange, as = 'h2', ...otherProps } = props;\n const context = React.useMemo(() => ({ as }), [as]);\n\n let valueProps;\n\n if (defaultId) {\n valueProps = {\n defaultValue: defaultId || undefined,\n };\n } else {\n valueProps = {\n onValueChange: onChange,\n value: id || undefined,\n };\n }\n\n const type = Array.isArray(valueProps.defaultValue) || Array.isArray(valueProps.value) ? 'multiple' : 'single';\n const className = cn('divide-y divide-grey-200', props.className);\n\n return (\n <AccordionContext.Provider value={context}>\n <AccordionPrimitive.Root {...otherProps} {...valueProps} data-taco=\"accordion\" className={className} type={type} />\n </AccordionContext.Provider>\n );\n};\n\nAccordion.Item = Item;\nAccordion.Trigger = Trigger;\nAccordion.Content = Content;\n","import * as React from 'react';\n\ntype Props = React.HTMLAttributes<HTMLSpanElement>;\n\nexport const VisuallyHidden = React.forwardRef(function VisuallyHidden(props: Props, ref: React.Ref<HTMLSpanElement>) {\n return <span {...props} className=\"sr-only\" ref={ref} />;\n});\n","import { State, Appearance } from '../types';\n\nexport const getAppearanceClasses = (value: Appearance | undefined): string => {\n switch (value) {\n case 'primary':\n return 'yt-blue-solid';\n\n case 'danger':\n return 'yt-red-solid';\n\n case 'ghost':\n return 'yt-blue-inverted';\n\n case 'discrete':\n return 'yt-transparent';\n\n default:\n return 'yt-grey-solid';\n }\n};\n\nexport const getStateClasses = (value: State | undefined): string => {\n switch (value) {\n case 'information':\n return 'yt-blue-solid';\n\n case 'warning':\n return 'yt-yellow-solid';\n\n case 'error':\n return 'yt-red-solid';\n\n case 'success':\n return 'yt-green-solid';\n\n default:\n return 'yt-grey-solid';\n }\n};\n\nexport const getOutlineClasses = (state: Appearance | State | undefined): string => {\n switch (state) {\n case 'information':\n case 'primary':\n return 'yt-blue-inverted';\n\n case 'warning':\n return 'yt-yellow-inverted';\n\n case 'error':\n case 'danger':\n return 'yt-red-inverted';\n\n case 'success':\n return 'yt-green-inverted';\n\n default:\n return 'yt-grey-inverted';\n }\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport { State } from '../../types';\nimport { getStateClasses, getOutlineClasses } from '../../utils/taillwind';\nimport './Badge.css';\n\nexport type BadgeProps = React.HTMLAttributes<HTMLSpanElement> & {\n /** Content should be a numerical value or tag/status like text **/\n children: React.ReactNode;\n /** Show compact version **/\n compact?: boolean;\n /** Show outlined version **/\n outline?: boolean;\n /** State will change the style of the badge **/\n state?: State;\n};\n\nexport const Badge = React.forwardRef(function Badge(props: BadgeProps, ref: React.Ref<HTMLSpanElement>) {\n const { children, compact = false, outline = false, state, ...otherProps } = props;\n const className = cn(\n 'rounded-full border font-bold text-xs uppercase overflow-hidden whitespace-nowrap inline-flex items-center justify-center',\n {\n [getOutlineClasses(state)]: outline,\n [`border-transparent ${getStateClasses(state)}`]: !outline,\n 'h-2 w-2 min-w-0': compact,\n 'h-5 py-0 px-1.5': !compact, // custom padding keeps single digits in a perfect circle\n },\n props.className\n );\n\n return (\n <span\n {...otherProps}\n aria-atomic=\"true\"\n aria-live=\"polite\"\n className={className}\n data-taco=\"badge\"\n ref={ref}\n role=\"status\"\n title={props['aria-label']}>\n {compact ? <VisuallyHidden>{children}</VisuallyHidden> : children}\n </span>\n );\n});\n","import * as React from 'react';\n\ntype ButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement | HTMLAnchorElement> & {\n /** Content should be a text */\n children: React.ReactNode;\n /** Provides url for buttons being used as a link */\n href?: string;\n /** Provides target for buttons being used as a link */\n target?: '_self' | '_blank' | '_parent' | '_top';\n};\n\nconst Button = React.forwardRef(function Button(props: ButtonProps, ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>) {\n const { disabled, target, type = 'button', ...otherProps } = props;\n\n const Tag = props.href ? 'a' : 'button';\n\n return (\n <Tag\n {...otherProps}\n aria-disabled={disabled ? 'true' : undefined}\n disabled={disabled}\n target={Tag === 'a' ? target : undefined}\n type={Tag !== 'a' ? type : undefined}\n ref={ref as any}>\n {React.Children.count(props.children) > 1\n ? React.Children.map(props.children, child => (typeof child === 'string' ? <span>{child}</span> : child))\n : props.children}\n </Tag>\n );\n});\n\nexport { Button };\nexport type { ButtonProps };\n","import * as React from 'react';\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip';\nimport cn from 'classnames';\n\nexport type TooltipProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> & {\n /** The element which activates the tooltip when hovered. Should be a single React/HTML element */\n children: React.ReactElement | any;\n /** Text displayed in the tooltip */\n title: string | JSX.Element;\n /**\n * Placement of the tooltip relative to the reference element. Placement will be reversed if a collision occurs\n * @defaultValue bottom\n */\n placement?: 'top' | 'right' | 'bottom' | 'left';\n};\n\nexport const Tooltip = React.forwardRef(function Tooltip(props: TooltipProps, ref: React.Ref<HTMLElement>) {\n const { title, children, placement, ...otherProps } = props;\n const className = cn(otherProps.className);\n\n return (\n <TooltipPrimitive.Root delayDuration={250}>\n <TooltipPrimitive.Trigger asChild ref={ref as any}>\n {children}\n </TooltipPrimitive.Trigger>\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content {...otherProps} asChild className={className} side={placement} sideOffset={3}>\n <div\n className=\"xs:max-w-[theme(spacing.56)] max-w-[theme(spacing.32)] animate-[fade-in_150ms] rounded-sm bg-blue-900/90 px-2 py-1 text-xs font-bold text-white opacity-90\"\n data-taco=\"tooltip\"\n style={{\n transformOrigin: 'var(--radix-tooltip-content-transform-origin)',\n }}>\n <TooltipPrimitive.Arrow className=\"-mt-px fill-blue-900/90 stroke-blue-900/90\" />\n {title}\n </div>\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n </TooltipPrimitive.Root>\n );\n});\n","import React from 'react';\nimport { Appearance } from '../../types';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { Tooltip } from '../Tooltip/Tooltip';\n\nexport const getButtonClasses = () => {\n return 'flex-shrink-0 min-h-[theme(spacing.8)] min-w-[theme(spacing.8)] gap-1 h-max leading-5 inline-flex items-center justify-center';\n};\n\nexport const getAppearanceClasses = (value: Appearance | undefined, icon = false): string => {\n switch (value) {\n case 'primary':\n return `yt-blue-solid focus:bg-blue-500 focus:text-white focus:yt-focus active:bg-blue-700 active:text-white hover:bg-blue-300 hover:text-white hover:focus:bg-blue-300 hover:focus:border-blue-300 hover:focus:text-white disabled:hover:yt-blue-solid disabled:hover:hover:border-blue-500`;\n\n case 'danger':\n return `yt-red-solid focus:bg-red-500 focus:text-white focus:yt-focus-red active:bg-red-700 active:text-white hover:bg-red-300 hover:text-white hover:focus:bg-red-300 hover:focus:text-white disabled:hover:yt-red-solid`;\n\n case 'ghost':\n return `bg-white shadow-[inset_0_0_0_1px_theme(colors.blue.500)] text-blue-500 focus:bg-transparent focus:text-blue-500 active:bg-blue-100 focus:!shadow-[inset_0_0_0_1px_theme(colors.blue.500),0_0_0_2px_rgba(0,99,255,0.25)] active:text-blue-700 hover:bg-blue-100 hover:shadow-[inset_0_0_0_1px_theme(colors.blue.300)] hover:text-blue-300 hover:focus:bg-blue-100 hover:focus:!shadow-[inset_0_0_0_1px_theme(colors.blue.300),0_0_0_2px_rgba(0,99,255,0.25)] hover:focus:text-blue-300`;\n\n case 'discrete': {\n if (icon) {\n return `bg-transparent text-black border-transparent focus:text-black focus:yt-focus active:text-black hover:text-grey-700 hover:focus:text-grey-700 disabled:hover:text-black `;\n }\n\n return `yt-transparent focus:text-blue-500 focus:yt-focus active:text-blue-700 hover:text-blue-300 hover:focus:text-blue-300 disabled:hover:yt-transparent`;\n }\n\n default:\n return `yt-grey-solid focus:bg-grey-200 focus:yt-focus active:bg-grey-300 active:text-black hover:bg-grey-100 hover:text-grey-700 hover:focus:bg-grey-100 hover:focus:text-grey-700 disabled:hover:yt-grey-solid`;\n }\n};\n\nexport const createButtonWithTooltip = (\n props: any,\n className: string,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n): JSX.Element => {\n const { tooltip, ...buttonProps } = props;\n const button = <ButtonPrimitive.Button {...buttonProps} className={className} ref={ref} />;\n\n if (tooltip) {\n return <Tooltip title={tooltip}>{button}</Tooltip>;\n }\n\n return button;\n};\n\nexport const createButtonWithOverlays = (props: any, buttonBase: JSX.Element) => {\n const { dialog, hanger, menu, popover } = props;\n let button = buttonBase;\n\n if (typeof dialog === 'function') {\n button = dialog({ trigger: button });\n } else if (typeof menu === 'function') {\n button = menu({ trigger: button });\n } else if (typeof popover === 'function') {\n button = popover({ trigger: button });\n }\n\n if (typeof hanger === 'function') {\n button = hanger({ anchor: button });\n }\n\n return button;\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { Icon, IconName } from '../Icon/Icon';\nimport { getAppearanceClasses, getButtonClasses, createButtonWithTooltip, createButtonWithOverlays } from '../Button/util';\nimport { Appearance } from '../../types';\nimport { DialogProps, HangerProps, MenuProps, PopoverProps } from '../..';\n\nexport type IconButtonProps = Omit<ButtonPrimitive.ButtonProps, 'children'> & {\n /** Appearance will change the style of the button */\n appearance?: Appearance;\n /**\n * Dialog component associated with the button, clicking the button will open the dialog.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated dialog when clicked.\n */\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n /** Hanger component associated with the button. */\n hanger?: (props: Partial<HangerProps>) => JSX.Element;\n /** Set which icon should be rendered within button */\n icon: IconName; // this dynamic type causes the type extraction for props to fail\n /** Menu component associated with the button. */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n /**\n * Popover component associated with the button, clicking the button will open the popover.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated popover when clicked.\n */\n popover?: (props: Partial<PopoverProps>) => JSX.Element;\n /**\n * Set whether the button is rounded.\n * Default value is `false`\n */\n rounded?: boolean;\n /** A tooltip to show when hovering over the button */\n tooltip?: string;\n};\n\nexport const Base = React.forwardRef(function IconButtonBase(\n props: IconButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { icon, rounded = false, ...otherProps } = props;\n\n const className = cn(\n 'w-8',\n getButtonClasses(),\n getAppearanceClasses(otherProps.appearance, true),\n {\n 'rounded-full': rounded,\n rounded: !rounded,\n 'cursor-not-allowed opacity-50': props.disabled,\n 'focus:yt-focus active:focus:yt-focus': !props.disabled,\n },\n props.className\n );\n\n if (!icon) {\n return null;\n }\n\n return createButtonWithTooltip(\n { ...otherProps, children: <Icon name={icon} className=\"m-0 p-0\" />, 'data-taco': 'icon-button' },\n className,\n ref\n );\n});\n\nexport const IconButton = React.forwardRef(function Button(\n props: IconButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { dialog, hanger, menu, popover, ...buttonProps } = props;\n const button = <Base {...buttonProps} ref={ref} />;\n\n return createButtonWithOverlays({ dialog, hanger, menu, popover }, button);\n});\n","import * as React from 'react';\nimport { Locale } from '../../types';\nimport { CalendarTexts } from '../Calendar/Calendar';\nimport { ComboboxTexts } from '../Combobox/Combobox';\nimport { DialogTexts } from '../Dialog/Dialog';\nimport { PaginationTexts } from '../Pagination/Pagination';\nimport { ListboxTexts } from '../Listbox/Listbox';\nimport { ToastsTexts } from '../Toast/Toast';\nimport { DatepickerTexts } from '../Datepicker/Datepicker';\nimport { HangerTexts } from '../Hanger/Hanger';\nimport { SelectTexts } from '../Select/Select';\nimport { TourTexts } from '../Tour/Tour';\nimport { TableTexts } from '../Table/Table';\nimport { SearchInputTexts } from '../SearchInput/SearchInput';\nimport { Select2Texts } from '../Select2/Select2';\nimport { BannerTexts } from '../Banner/Banner';\n\nexport type LocalizationTexts = {\n /** Localized texts and aria-labels for [Calendar](component:calendar) component */\n calendar: CalendarTexts;\n /** Localized texts and aria-labels for [Combobox](component:combobox) component */\n combobox: ComboboxTexts;\n /** Localized texts and aria-labels for [DatePicker](component:datepicker) component */\n datepicker: DatepickerTexts;\n /** Localized texts and aria-labels for [Hanger](component:hanger) component */\n hanger: HangerTexts;\n /** Localized texts and aria-labels for [Banner](component:banner) component */\n banner: BannerTexts;\n /** Localized texts and aria-labels for [Listbox](component:listbox) component */\n listbox: ListboxTexts;\n /** Localized texts and aria-labels for [Dialog](component:dialog) component */\n dialog: DialogTexts;\n /** Localized texts and aria-labels for [Pagination](component:pagination) component */\n pagination: PaginationTexts;\n /** Localized texts and aria-labels for [Table](component:table) component */\n table: TableTexts;\n /** Localized texts and aria-labels for [Select](component:select) component */\n select: SelectTexts;\n /** Localized texts and aria-labels for [Select2](component:select2) component */\n select2: Select2Texts;\n /** Localized texts and aria-labels for [Toast](component:toast) component */\n toasts: ToastsTexts;\n /** Localized texts and aria-labels for [Tour](component:tour) component */\n tour: TourTexts;\n /** Localized texts and aria-labels for [SearchInput](component:searchinput) component */\n searchInput: SearchInputTexts;\n};\n\nexport type Localization = {\n /**\n * Provide the language code used in application.\n * Default value is `en-GB`\n */\n locale: Locale;\n /** Provide the texts and aria-labels for components used within the provider */\n texts: LocalizationTexts;\n /** Provide the formatting */\n formatting: {\n /** Default value is `dd.mm.yy` */\n date: string;\n };\n};\n\nexport const defaultLocalisationTexts = {\n calendar: {\n months: [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December',\n ],\n weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n actions: {\n previousMonth: 'Previous month',\n nextMonth: 'Next month',\n previousYear: 'Previous year',\n nextYear: 'Next year',\n today: 'Today',\n },\n },\n combobox: {\n tooltip: 'Search in list',\n },\n datepicker: {\n calendar: 'Calendar',\n clear: 'Clear',\n expand: 'Show calendar',\n shortcuts: 'Shortcuts',\n },\n hanger: {\n close: 'Close',\n },\n banner: {\n close: 'Close',\n },\n listbox: {\n loading: 'Loading results...',\n empty: 'No results found',\n allOption: 'All',\n },\n dialog: {\n close: 'Close',\n drag: 'Drag',\n },\n pagination: {\n label: 'Pagination',\n pageSize: 'Items per page',\n showingXofYofTotal: 'Showing [X] - [Y] of [total]',\n actions: {\n firstPage: 'Goto first page',\n firstPageWithShortcut: 'Goto first page (Home)',\n previousPage: 'Goto previous page',\n previousPageWithShortcut: 'Goto previous page (Page Up)',\n nextPage: 'Goto next page',\n nextPageWithShortcut: 'Goto next page (Page Down)',\n lastPage: 'Goto last page',\n lastPageWithShortcut: 'Goto last page (End)',\n pageX: 'Goto page [X]',\n },\n },\n table: {\n actions: 'Other actions',\n edit: 'Edit (e)',\n copy: 'Copy (c)',\n del: 'Delete (del)',\n newSubRow: 'New row (shift + n)',\n loading: 'Loading...',\n },\n select: {\n allOptionsSelected: 'All',\n },\n select2: {\n allSelect: 'Select all',\n allDeselect: 'Deselect all',\n cancel: 'Cancel',\n chooseColor: 'Pick a color',\n create: 'Create',\n delete: 'Delete',\n save: 'Save',\n search: 'Search...',\n searchOrCreate: 'Search or create...',\n },\n toasts: {\n dismiss: 'Dismiss',\n },\n tour: {\n back: 'Back',\n close: 'Close',\n skip: 'Close and complete',\n last: 'Done',\n next: 'Next',\n open: 'Open',\n },\n searchInput: {\n button: 'Search',\n placeholder: 'Search...',\n clear: 'Clear',\n },\n};\n\nconst defaultLocalizationContext: Localization = {\n locale: 'en-GB',\n texts: defaultLocalisationTexts,\n formatting: {\n date: 'dd.mm.yy',\n },\n};\n\nexport const LocalizationContext = React.createContext<Localization>(defaultLocalizationContext);\nexport interface LocalizationProviderProps {\n children: React.ReactNode;\n localization?: Localization;\n}\nexport const LocalizationProvider: React.FC<LocalizationProviderProps> = ({ localization, children }) => {\n return (\n <LocalizationContext.Provider value={localization || defaultLocalizationContext}>{children}</LocalizationContext.Provider>\n );\n};\n\nexport const useLocalization = () => React.useContext(LocalizationContext);\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { State } from '../../types';\nimport { getBannerIcon } from './util';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type BannerProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Content can be any react element, for e.g. a `div` */\n children: React.ReactNode;\n /** State will change the icon displayed in banner */\n state: State;\n onClose?: () => void;\n};\n\nexport type BannerTexts = {\n /** Aria-label for the close icon button of banner */\n close: string;\n};\n\nexport const Banner = React.forwardRef(function Banner(props: BannerProps, ref: React.Ref<HTMLDivElement>) {\n const { children, state, onClose } = props;\n const { texts } = useLocalization();\n const className = cn('bg-white relative flex items-center gap-2 py-2 px-4 leading-6 shadow-md z-10', props.className);\n\n return (\n <div className={className} data-taco=\"banner\" ref={ref}>\n {getBannerIcon(state)}\n {children}\n {onClose ? (\n <IconButton\n aria-label={texts.banner.close}\n className=\"ml-auto -mr-2 self-start\"\n icon=\"close\"\n appearance=\"discrete\"\n onClick={onClose}\n />\n ) : null}\n </div>\n );\n});\n","import React from 'react';\nimport { Icon } from '../Icon/Icon';\nimport { State } from '../../types';\n\nexport const getBannerIcon = (type: State): JSX.Element | null => {\n switch (type) {\n case 'success':\n return <Icon name=\"tick\" className=\"yt-green-solid mt-1 self-start rounded-full\" />;\n\n case 'error':\n return <Icon name=\"warning\" className=\"yt-red-solid mt-1 self-start rounded-full\" />;\n\n case 'warning':\n return <Icon name=\"warning\" className=\"yt-yellow-solid mt-1 self-start rounded-full\" />;\n\n case 'information':\n return <Icon name=\"info\" className=\"yt-blue-solid mt-1 self-start rounded-full\" />;\n\n default:\n return null;\n }\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Appearance } from '../../types';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { getAppearanceClasses, getButtonClasses, createButtonWithTooltip, createButtonWithOverlays } from './util';\nimport { HangerProps } from '../Hanger/Hanger';\nimport { MenuProps } from '../Menu/Menu';\nimport { DialogProps } from '../Dialog/Dialog';\nimport { PopoverProps } from '../Popover/Popover';\nimport './Button.css';\nimport { Icon } from '../Icon/Icon';\n\nexport type ButtonProps = ButtonPrimitive.ButtonProps & {\n /** Appearance will change the style of the button */\n appearance?: Appearance;\n /**\n * Dialog component associated with the button, clicking the button will open the dialog.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated dialog when clicked.\n */\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n /** If fluid, button expands to the width of it's container */\n fluid?: boolean;\n /** Hanger component associated with the button. */\n hanger?: (props: Partial<HangerProps>) => JSX.Element;\n /** Menu component associated with the button. */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n /**\n * Popover component associated with the button, clicking the button will open the popover.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated popover when clicked.\n */\n popover?: (props: Partial<PopoverProps>) => JSX.Element;\n /** A tooltip to show when hovering over the button */\n tooltip?: string | JSX.Element;\n};\n\nconst Base = React.forwardRef(function ButtonBase(props: ButtonProps, ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>) {\n const { fluid, ...otherProps } = props;\n const className = cn(\n getButtonClasses(),\n getAppearanceClasses(otherProps.appearance),\n 'rounded px-3',\n {\n 'cursor-not-allowed opacity-50': props.disabled,\n 'focus:yt-focus active:focus:yt-focus': !props.disabled,\n 'w-full': fluid,\n },\n props.className\n );\n\n return createButtonWithTooltip({ ...otherProps, 'data-taco': 'button' }, className, ref);\n});\n\nexport const Button = React.forwardRef(function Button(\n props: ButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { dialog, hanger, menu, popover, ...buttonProps } = props;\n\n let children = buttonProps.children;\n\n // add a chevron icon to menu buttons\n if (typeof menu === 'function') {\n children = Array.isArray(children)\n ? [...children, <Icon key=\"chevron-down\" name=\"chevron-down\" />]\n : [children, <Icon key=\"chevron-down\" name=\"chevron-down\" />];\n }\n\n const button = (\n <Base {...buttonProps} ref={ref}>\n {children}\n </Base>\n );\n\n return createButtonWithOverlays({ dialog, hanger, menu, popover }, button);\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport ReactDayPicker, { NavbarElementProps, Modifier } from 'react-day-picker';\nimport { useLocalization } from '../Provider/Localization';\nimport './Calendar.css';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type CalendarTextsActions = {\n /** Aria-label for previous month action button */\n previousMonth: string;\n /** Aria-label for next month action button */\n nextMonth: string;\n /** Aria-label for previous year action button */\n previousYear: string;\n /** Aria-label for next year action button */\n nextYear: string;\n /** Text displayed within today action button */\n today: string;\n};\n\nexport type CalendarTexts = {\n /** Text and aria-label for action buttons in Calendar */\n actions: CalendarTextsActions;\n /** Text abbreviation for months in Calendar's header, starting with January */\n months: string[];\n /** Text abbreviation for days in Calendar's header, starting with Sunday */\n weekdaysShort: string[];\n};\n\n/** @internal */\ntype CustomNavbarElementProps = NavbarElementProps & {\n onMonthChange: (month: Date) => void;\n value?: Date;\n};\n\nconst thisYear = new Date().getFullYear();\nconst years: number[] = [];\n\nfor (let i = thisYear - 50; i <= thisYear + 10; i += 1) {\n years.push(i);\n}\n\nconst Navbar = React.memo(\n ({ onMonthChange, onNextClick, onPreviousClick, value = new Date() }: CustomNavbarElementProps): JSX.Element => {\n const {\n texts: {\n calendar: { actions, months },\n },\n } = useLocalization();\n\n const handleChange = function handleChange(event) {\n const { year, month } = event.target.form;\n onMonthChange(new Date(year.value, month.value));\n };\n\n return (\n <div className=\"mb-2 flex items-center justify-between\">\n <form className=\"inline-flex space-x-1\">\n <select className=\"h-8 px-2\" name=\"month\" onChange={handleChange} value={value.getMonth()}>\n {months.map((month, i) => (\n <option key={month} value={i}>\n {month}\n </option>\n ))}\n </select>\n <select className=\"h-8 px-2\" name=\"year\" onChange={handleChange} value={value.getFullYear()}>\n {years.map(year => (\n <option key={year} value={year}>\n {String(year)}\n </option>\n ))}\n </select>\n </form>\n <div>\n <IconButton\n appearance=\"discrete\"\n icon=\"chevron-left\"\n aria-label={actions.previousMonth}\n onClick={() => onPreviousClick()}\n rounded\n />\n <IconButton\n appearance=\"discrete\"\n icon=\"chevron-right\"\n aria-label={actions.nextMonth}\n onClick={() => onNextClick()}\n rounded\n />\n </div>\n </div>\n );\n }\n);\n\nexport type CalendarProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'value'> & {\n /** Handler called when a day is clicked in calendar */\n onChange: (date: Date, event?: React.MouseEvent<HTMLDivElement>) => void;\n value?: Date;\n disabledDays?: Modifier[];\n};\n\nexport const Calendar = React.forwardRef(function Calendar(props: CalendarProps, ref: React.Ref<ReactDayPicker>) {\n const { onChange: handleChange, value, disabledDays, ...otherProps } = props;\n const { locale, texts } = useLocalization();\n const [visibleMonth, setVisibleMonth] = React.useState(value ?? new Date());\n\n React.useEffect(() => {\n if (visibleMonth !== value) {\n setVisibleMonth(value ?? new Date());\n }\n }, [value]);\n\n const handleDayClick = (date, modifiers, event) => {\n if (modifiers.outside || modifiers.disabled) {\n return;\n }\n\n handleChange(date, event);\n };\n\n const handleCalendarClickToday = (): void => {\n const today = new Date();\n\n // set to midday to avoid UTC offset causing dates to be mismatched server side\n today.setHours(12);\n today.setMinutes(0);\n today.setSeconds(0);\n\n handleChange(today);\n };\n\n const className = cn('flex bg-white text-xs p-4', otherProps.className);\n\n return (\n <div data-taco=\"calendar\">\n <ReactDayPicker\n {...otherProps}\n className={className}\n month={visibleMonth}\n selectedDays={value}\n locale={locale.substring(0, 2)}\n firstDayOfWeek={1}\n months={texts.calendar.months}\n weekdaysShort={texts.calendar.weekdaysShort}\n navbarElement={navProps => <Navbar {...navProps} onMonthChange={setVisibleMonth} value={visibleMonth} />}\n onDayClick={handleDayClick}\n onMonthChange={setVisibleMonth}\n onTodayButtonClick={handleCalendarClickToday}\n captionElement={() => null}\n todayButton={texts.calendar.actions.today}\n numberOfMonths={1}\n ref={ref}\n disabledDays={disabledDays}\n />\n </div>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\n\nimport { MenuProps } from '../Menu/Menu';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type CardContentProps = React.HTMLAttributes<HTMLDivElement> & {\n noPadding?: boolean;\n};\n\nconst Content = React.forwardRef<HTMLDivElement, CardContentProps>(function CardContent(externalProps, ref) {\n const { noPadding, ...props } = externalProps;\n const className = cn(\n 'flex-grow overflow-auto',\n {\n 'mx-4 mb-4': !noPadding,\n },\n props.className\n );\n return <div {...props} className={className} ref={ref} />;\n});\n\nexport type CardProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Title of the Card */\n title: string | React.ReactElement;\n /** Menu component associated with the Card */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n};\n\nexport const Card = React.forwardRef<HTMLDivElement, CardProps>(function Card(props, ref) {\n const { title, menu, children } = props;\n const className = cn(\n 'bg-white flex flex-col rounded-xl shadow-[0px_0px_1px_rgba(0,0,0,0.1),0px_6px_18px_rgba(47,51,68,0.2)]',\n props.className\n );\n\n return (\n <div className={className} data-taco=\"card\" ref={ref}>\n <div className=\"mx-4 mt-4 mb-2 flex\">\n {title && <h4 className=\"mb-0 flex-grow text-left\">{title}</h4>}\n {menu ? <IconButton icon=\"ellipsis-horizontal\" appearance=\"discrete\" menu={menu} className=\"-mt-[4px]\" /> : null}\n </div>\n {children}\n </div>\n );\n}) as React.ForwardRefExoticComponent<CardProps> & {\n Content: React.ForwardRefExoticComponent<CardContentProps>;\n};\nCard.Content = Content;\n","import { v4 as uuid } from 'uuid';\nimport React from 'react';\n\n// React 18 has this built-in, when we upgrade this hook should be removed and the uuid dependency should be removed\n\nexport const useId = (nativeId: string | undefined) => {\n return React.useMemo(() => nativeId ?? uuid(), []);\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox';\nimport { Icon } from '../Icon/Icon';\nimport { useId } from '../../hooks/useId';\n\ntype CheckedState = boolean | 'indeterminate';\n\ntype CheckboxBaseProps = Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'children' | 'onChange'> & {\n /* Increases visual prominenance of the checkbox */\n highlighted?: boolean;\n /**\n * Indeterminate state should only be used with sub-checkboxes. The indeterminate state is shown if not all\n * sub-checkboxes are selected. This only affects the style, changing the icon in the checkbox.\n */\n indeterminate?: boolean;\n /* Whether the checkbox is in an invalid state */\n invalid?: boolean;\n /** Label for the checkbox */\n label?: React.ReactNode;\n /* Whether user input is required */\n required?: boolean;\n};\n\ninterface UncontrolledCheckboxProps extends CheckboxBaseProps {\n checked?: never;\n onChange?: never;\n /* The default checked state (uncontrolled) */\n defaultChecked?: boolean;\n}\n\ninterface ControlledCheckboxProps extends CheckboxBaseProps {\n defaultChecked?: never;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean) => void;\n}\n\nexport type CheckboxProps = UncontrolledCheckboxProps | ControlledCheckboxProps;\n\nexport const Checkbox = React.forwardRef(function Checkbox(props: CheckboxProps, ref: React.Ref<HTMLButtonElement>) {\n const { checked, highlighted, indeterminate, invalid, label, onChange, ...otherProps } = props;\n const id = useId(props.id);\n\n const className = cn(\n 'bg-white h-5 w-5 border rounded text-sm flex-shrink-0 self-start mt-[0.1rem] focus:yt-focus', //hover:shadow-[0_0_0_1px_rgba(235,235,235,1)]\n props.className,\n {\n 'border-grey-300 text-blue-500 hover:text-blue-300 focus:border-blue-500 focus:hover:border-blue-300':\n !props.disabled && !invalid,\n 'border-grey-200 text-blue-300 cursor-not-allowed': props.disabled,\n 'bg-[rgba(255,255,0,0.2)] disabled:bg-[rgba(255,255,0,0.075)]': highlighted,\n 'border-red-500 text-red-500 hover:text-red-300 hover:border-red-300 focus:border-red-500 focus:hover:border-red-300':\n invalid && !props.disabled,\n }\n );\n\n let handleChange: ((checked: CheckedState) => void) | undefined;\n\n if (onChange) {\n handleChange = (checked: CheckedState) => onChange(checked === 'indeterminate' ? false : checked);\n }\n\n let labelledByProps: Record<string, string> | null = null;\n\n if (label) {\n labelledByProps = {\n 'aria-labelledby': `${id}-label`,\n id,\n };\n }\n\n const element = (\n <CheckboxPrimitive.Root\n {...otherProps}\n {...labelledByProps}\n data-taco=\"checkbox\"\n checked={indeterminate ? 'indeterminate' : checked}\n className={className}\n onCheckedChange={handleChange}\n ref={ref}>\n <CheckboxPrimitive.Indicator className=\"flex h-full w-full\">\n <Icon name={indeterminate ? 'line' : 'tick'} className=\"!h-full !w-full\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n );\n\n if (label) {\n const labelContainerClassName = cn(\n 'flex items-center cursor-pointer gap-2',\n {\n 'cursor-not-allowed text-grey-300': props.disabled,\n },\n props.className\n );\n\n return (\n <span className={labelContainerClassName}>\n {element}\n <label htmlFor={id} id={`${id}-label`}>\n {label}\n </label>\n </span>\n );\n }\n\n return element;\n});\nCheckbox.displayName = 'Checkbox';\n","import cn from 'classnames';\n\nexport const getInputClasses = props => {\n const disabled = props.disabled || !!props['aria-disabled'];\n const readOnly = props.readOnly || !!props['aria-readonly'];\n const invalid = props.invalid || !!props['aria-invalid'];\n\n return cn(\n 'peer bg-white text-black text-sm border font-normal not-italic no-underline rounded inline-flex items-center leading-6 px-2 relative w-full text-ellipsis transition-colors transition-opacity ease-in min-h-[theme(spacing.8)]',\n {\n // default\n 'border-grey-300 focus:border-blue-300 focus:yt-focus': !invalid,\n 'hover:shadow-[0_0_0.1rem_theme(colors.grey.500)] active:border-blue-700': !invalid && !disabled,\n // disabled\n 'border-grey-200 text-opacity-25 cursor-not-allowed placeholder:text-grey-700': disabled,\n // highlighted\n 'bg-[rgba(255,255,0,0.075)]': props.highlighted && disabled,\n 'bg-[rgba(255,255,0,0.2)]': props.highlighted && !disabled,\n // invalid\n 'border-red focus:border-red-300 focus:yt-focus-red active:border-red-700': invalid,\n 'hover:shadow-[0_0_0.15rem_theme(colors.red.500)]': invalid && !disabled,\n // readOnly\n 'cursor-not-allowed text-black bg-grey-200': readOnly,\n }\n );\n};\n\nexport const getButtonStateClasses = (invalid: boolean | undefined): string => {\n if (invalid) {\n return 'border !border-red-500 group-peer-focus:!border-red-300 focus:yt-focus-red group-focus:group-active:!border-red-300 transition-colors ease-in';\n }\n\n return 'border border-grey-300 focus:!border-blue-300 group-peer-focus:!border-blue-300 group-peer-focus:group-peer-active:!border-blue-700 transition-colors transition-opacity ease-in';\n};\n","export const debounce = (fn: Function, delay: number) => {\n let timeoutId: ReturnType<typeof setTimeout>;\n\n return function (this: any, ...args: any[]) {\n clearTimeout(timeoutId);\n timeoutId = setTimeout(() => fn.apply(this, args), delay);\n };\n};\n","import * as React from 'react';\nimport { debounce } from '../utils/debounce';\n\nconst getVisibility = (element: HTMLElement | null): boolean =>\n Boolean(element && (element.offsetWidth || element.offsetHeight || element.getClientRects().length));\n\nexport const useBoundingClientRectListener = (\n ref: React.RefObject<HTMLElement>,\n dependencies?: Array<any>\n): DOMRectReadOnly | undefined => {\n const [dimensions, setDimensions] = React.useState<DOMRectReadOnly | undefined>(undefined);\n const isRefElementVisible = getVisibility(ref.current);\n const [visibility, setVisibility] = React.useState(isRefElementVisible);\n\n const resize = () => {\n if (visibility) {\n setDimensions(ref.current?.getBoundingClientRect());\n }\n };\n\n React.useEffect(() => {\n const timeout = setTimeout(resize, 0);\n const debouncedResize = debounce(resize, 250);\n\n window.addEventListener('resize', debouncedResize);\n\n return () => {\n clearTimeout(timeout);\n window.removeEventListener('resize', debouncedResize);\n };\n }, [ref.current, visibility]);\n\n React.useEffect(() => {\n const newRefElementVisibility = getVisibility(ref.current);\n\n if (visibility !== newRefElementVisibility) {\n // When visibility of an element changes, then the new visibility of the element can only be checked after the\n // component has rendered. That's why the visibility check is inside the useEffect. This useEffect will cause\n // the consumer to rerender and that will cause the above hook to recalculate the dimensions\n setVisibility(newRefElementVisibility);\n }\n });\n\n React.useEffect(() => {\n if (dependencies) {\n setDimensions(ref.current?.getBoundingClientRect());\n }\n }, dependencies);\n\n return dimensions;\n};\n","import React from 'react';\n\n// merges an external ref (optional) with an internal ref (required)\nexport const useMergedRef = <T extends HTMLElement>(ref: React.Ref<HTMLElement>): React.RefObject<T> => {\n const internalRef = React.useRef<T>(null);\n\n React.useEffect(() => {\n if (ref) {\n if (typeof ref === 'function') {\n ref(internalRef.current);\n } else {\n (ref as React.MutableRefObject<HTMLElement | null>).current = internalRef.current;\n }\n }\n }, [ref]);\n\n return internalRef;\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Icon, IconName } from '../Icon/Icon';\nimport { getButtonStateClasses, getInputClasses } from './util';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { useMergedRef } from '../../hooks/useMergedRef';\n\nexport type InputWithoutDeprecatedFeaturesProps = Omit<React.InputHTMLAttributes<HTMLInputElement>, 'prefix'> & {\n /** Draws attention to the input by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n postfix?: string | JSX.Element;\n prefix?: string | JSX.Element;\n};\n\nconst validSetSelectionRangeTypes = ['text', 'search', 'url', 'tel', 'password'];\n\nconst InputWithoutDeprecatedFeatures = React.forwardRef(function InputWithoutDeprecatedFeatures(\n props: InputWithoutDeprecatedFeaturesProps,\n ref: React.Ref<HTMLInputElement>\n) {\n const { highlighted, invalid, onKeyDown, postfix, prefix, type = 'text', ...attributes } = props;\n const internalRef = useMergedRef<HTMLInputElement>(ref);\n\n let handleKeyDown = onKeyDown;\n\n // home and end keys only navigate to the start/end of input value if the input container does not scroll\n // if it has scroll height then the browser reverts to native scrolling behaviour only\n // so we manually override it to ensure _our_ desired behaviour remains intact\n // only the 'text', 'search', 'url', 'tel', 'password' input types support setSelectionRange\n if (validSetSelectionRangeTypes.includes(type)) {\n handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (!event.shiftKey && (event.key === 'Home' || event.key === 'End')) {\n event.preventDefault();\n const position = event.key === 'End' ? event.currentTarget.value.length : 0;\n event.currentTarget.setSelectionRange(position, position);\n }\n\n if (typeof onKeyDown === 'function') {\n onKeyDown(event);\n }\n };\n }\n\n const prefixRef = React.useRef<HTMLDivElement>(null);\n const prefixRect = useBoundingClientRectListener(prefixRef);\n const postfixRef = React.useRef<HTMLDivElement>(null);\n const postfixRect = useBoundingClientRectListener(postfixRef);\n\n const className = cn(\n getInputClasses(props),\n {\n 'pl-8': !!prefix,\n 'pr-8': !!postfix,\n },\n attributes.className\n );\n\n return (\n <div className=\"relative inline-flex w-full\" data-taco=\"input-container\" style={{ opacity: 0.999 }}>\n <input\n {...attributes}\n className={className}\n data-taco=\"input\"\n onKeyDown={handleKeyDown}\n ref={internalRef}\n style={{\n paddingLeft: prefixRect ? `${prefixRect.width - 1}px` : undefined,\n paddingRight: postfixRect ? `${postfixRect.width - 1}px` : undefined,\n }}\n type={type}\n />\n {prefix ? <Affix type=\"prefix\" children={prefix} disabled={attributes.disabled} ref={prefixRef} /> : null}\n {postfix ? <Affix type=\"postfix\" children={postfix} disabled={attributes.disabled} ref={postfixRef} /> : null}\n </div>\n );\n});\n\ntype AffixProps = {\n children?: string | JSX.Element;\n disabled?: boolean;\n type: 'prefix' | 'postfix';\n};\nconst Affix = React.memo(\n React.forwardRef(function Affix(props: AffixProps, ref: React.Ref<HTMLDivElement>) {\n const { children, disabled, type } = props;\n\n if (children) {\n return (\n <div\n className={cn(\n 'group absolute top-0 flex h-full items-center justify-center px-2',\n // icon\n '[&_[data-taco=\"icon\"]]:!h-5 [&_[data-taco=\"icon\"]]:!w-5',\n {\n 'text-grey-300': disabled,\n 'text-grey-700': !disabled,\n 'left-0 [&>button]:!-ml-2': type === 'prefix',\n 'right-0 [&>button]:!-mr-2': type === 'postfix',\n }\n )}\n ref={ref}>\n {children}\n </div>\n );\n }\n\n return null;\n })\n);\n\nexport type InputProps = InputWithoutDeprecatedFeaturesProps & {\n /** Shows a button within the input field */\n button?: React.ReactElement;\n /** Shows an icon within the input field */\n icon?: IconName | JSX.Element;\n};\n\nexport const Input = React.forwardRef(function LegacyInput(props: InputProps, ref: React.Ref<HTMLInputElement>) {\n const { button, icon, ...attributes } = props;\n\n let postfix;\n\n if (button) {\n const disabled = button.props.disabled || attributes.disabled;\n const buttonClassName = cn(\n 'items-center focus:z-10 flex justify-center rounded-l-none rounded-r h-full focus:rounded focus:outline-none',\n getButtonStateClasses(attributes.invalid),\n button.props.className\n );\n postfix = React.cloneElement(button, {\n className: buttonClassName,\n disabled,\n });\n } else if (icon) {\n postfix = typeof icon === 'string' ? <Icon name={icon} /> : icon;\n }\n\n return <InputWithoutDeprecatedFeatures {...attributes} postfix={attributes.postfix ?? postfix} ref={ref} />;\n});\n","import React from 'react';\nimport { Orientation } from '../../types';\n\nexport const getNextIndexFromKey = (\n key: string,\n length: number,\n index: number | undefined,\n direction: Orientation = 'vertical'\n): number | undefined => {\n const previousKey = direction === 'horizontal' ? 'ArrowLeft' : 'ArrowUp';\n const nextKey = direction === 'horizontal' ? 'ArrowRight' : 'ArrowDown';\n\n switch (key) {\n case previousKey:\n return index !== undefined ? (index - 1 < 0 ? 0 : index - 1) : index;\n\n case nextKey:\n return index !== undefined ? (index + 1 >= length ? index : index + 1) : index;\n\n case 'Home':\n return 0;\n\n case 'End':\n return length - 1;\n\n default:\n return;\n }\n};\n\nexport type useListKeyboardNavigationOptions = {\n direction?: Orientation;\n initialIndex?: number;\n};\n\nexport const useListKeyboardNavigation = (\n length = 0,\n options: useListKeyboardNavigationOptions = {\n direction: 'vertical',\n }\n): [number | undefined, (index: number | undefined) => void, (event: React.KeyboardEvent<HTMLElement>) => number | undefined] => {\n const [index, setIndex] = React.useState<number | undefined>(options.initialIndex);\n\n const getNextIndex = (event: React.KeyboardEvent<HTMLElement>): number | undefined => {\n const nextIndex = getNextIndexFromKey(event.key, length, index, options.direction);\n\n if (nextIndex !== undefined) {\n event.preventDefault();\n }\n\n return nextIndex;\n };\n\n return [index, setIndex, getNextIndex];\n};\n","const scrollToChildElement = (parent: HTMLElement, child: HTMLElement): void => {\n const clientHeight = parent.clientHeight;\n\n if (parent.scrollHeight > clientHeight) {\n const scrollTop = parent.scrollTop;\n const scrollBottom = clientHeight + scrollTop;\n const childBottom = child.offsetTop + child.offsetHeight;\n\n if (childBottom > scrollBottom) {\n parent.scrollTop = childBottom - clientHeight;\n } else if (child.offsetTop < scrollTop) {\n parent.scrollTop = child.offsetTop;\n }\n }\n};\n\nexport const useListScrollTo = (internalRef: any, itemRefs: any[]): any => {\n const scrollTo = (index: number | undefined): void => {\n if (internalRef && internalRef.current) {\n if (index !== undefined) {\n const activeRef = itemRefs[index];\n\n if (activeRef && activeRef.current) {\n scrollToChildElement(internalRef.current, activeRef.current);\n }\n } else {\n internalRef.current.scrollTop = 0;\n }\n }\n };\n\n return { scrollTo };\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport './Spinner.css';\n\nexport type SpinnerProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * Define a delay in milliseconds after which the spinner is shown.\n * Default value is `500`ms\n */\n delay?: number;\n /** Define a text that will be displayed below spinner */\n label?: string;\n};\n\nexport const Spinner = React.forwardRef(function Spinner(props: SpinnerProps, ref: React.Ref<HTMLDivElement>) {\n const { delay = 500, label, ...otherProps } = props;\n const [visible, setVisibility] = React.useState(!delay);\n\n React.useEffect(() => {\n let timeout: number;\n\n if (delay) {\n timeout = window.setTimeout(() => setVisibility(true), delay);\n }\n\n return () => {\n if (timeout) {\n clearTimeout(timeout);\n }\n };\n }, [delay]);\n\n if (!visible) {\n return null;\n }\n\n const className = cn('inline-flex flex-col relative items-center', otherProps.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"spinner\" ref={ref}>\n <svg\n className=\"h-10 w-10 animate-[spinnerRotation_2s_linear_infinite]\"\n viewBox=\"0 0 100 100\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"50\" cy=\"50\" r=\"45\"></circle>\n </svg>\n {label && <span className=\"mt-4\">{label}</span>}\n </div>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { getNextIndexFromKey } from '../../utils/hooks/useListKeyboardNavigation';\nimport { useListScrollTo } from '../../utils/hooks/useListScrollTo';\nimport './ScrollableList.css';\nimport { Spinner } from '../Spinner/Spinner';\nimport { useLocalization } from '../Provider/Localization';\nimport { Checkbox } from '../Checkbox/Checkbox';\nimport { getInputClasses } from '../Input/util';\n\nexport type ScrollableListItemValue = string | number | boolean | null;\n\nexport type ScrollableListItem = {\n /**\n * Set whether the item is disabled.\n * This will both change the style and make the item unselectable\n */\n disabled?: boolean;\n /* Specifies whether the item has child items -- intended for internal use only */\n hasChildren?: boolean;\n /** Place an icon before the item's text */\n icon?: React.ReactElement;\n /* The index path to the item -- intended for internal use only */\n path?: string;\n /** Text describing the item */\n text: string | JSX.Element;\n /** Value of the item */\n value: ScrollableListItemValue;\n /** Child items to show hierarchical data */\n children?: ScrollableListItem[];\n};\n\n/** @internal */\nexport type ScrollableListProps = Omit<\n React.HTMLAttributes<HTMLUListElement>,\n 'defaultValue' | 'id' | 'onChange' | 'onClick' | 'onKeyDown'\n> & {\n /** Data indicating the options in scrollable list */\n data: ScrollableListItem[];\n /** Sets the list to be disabled */\n disabled?: boolean;\n /** Draws attention to the scrollable list by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Set an id for the scrollable list */\n id: string;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in `Provider` component.\n */\n loading?: boolean;\n /**\n * Handler called when current active/selected option changes in a scrollable list.\n * @param index indicates the index of the current active option\n */\n onChange: (index: number) => void;\n /** Handler called when option is clicked */\n onClick?: (event: React.MouseEvent<HTMLLIElement>, index: number) => void;\n /**\n * Set whether the selected item should be scrolled into view when listbox is focused.\n * Default value is `false`\n */\n scrollOnFocus?: boolean;\n /** Handler called when a key is pressed */\n onKeyDown?: (event: React.KeyboardEvent<HTMLUListElement>, index: number | undefined) => void;\n /* Sets the list to read only mode */\n readOnly?: boolean;\n /**\n * Value of the scrollable list representing the selected item.\n * It needs to be an existing value from the provided data.\n */\n value: number | undefined;\n /**\n * Allows to select multiple items from the list\n */\n multiselect?: boolean;\n /**\n * Contains the currently selected values when multiselect mode is ON.\n */\n selectedIndexes?: number[];\n /**\n * True when all available (not disabled) options are selected\n */\n allOptionsSelected?: boolean;\n};\n\n/** @internal */\nexport type ScrollableListPropsWithRef = ScrollableListProps & React.RefAttributes<HTMLUListElement>;\n\nexport const getId = (id: string, value: ScrollableListItemValue): string => `${id}_${value}`;\n\nconst getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n data: ScrollableListItem[],\n index: number | undefined\n): number | undefined => {\n const nextIndex = getNextIndexFromKey(event.key, data.length, index);\n\n if (nextIndex) {\n if (nextIndex === index) {\n return index;\n } else if (data[nextIndex] && data[nextIndex].disabled) {\n return getNextEnabledItem(event, data, nextIndex);\n }\n }\n\n return nextIndex;\n};\n\nexport const ScrollableList = React.forwardRef(function ScrollableList(\n props: ScrollableListProps,\n ref: React.Ref<HTMLUListElement>\n) {\n const {\n data,\n disabled,\n highlighted,\n id,\n invalid: _,\n loading,\n onChange: setCurrentIndex,\n onClick,\n onFocus,\n onKeyDown,\n readOnly,\n scrollOnFocus = false,\n value: currentIndex,\n multiselect,\n selectedIndexes = [],\n allOptionsSelected = false,\n ...otherProps\n } = props;\n const listRef = useMergedRef<HTMLUListElement>(ref);\n const itemRefs = React.useMemo(() => data.map(() => React.createRef<HTMLLIElement>()), [data]);\n const { texts } = useLocalization();\n const { scrollTo } = useListScrollTo(listRef, itemRefs);\n\n React.useEffect(() => {\n if (currentIndex && itemRefs[currentIndex]?.current) {\n itemRefs[currentIndex].current?.scrollIntoView({\n block: 'center',\n });\n }\n }, []);\n\n React.useEffect(() => {\n scrollTo(currentIndex);\n }, [currentIndex]);\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLUListElement>): void => {\n const nextIndex = getNextEnabledItem(event, data, currentIndex);\n\n if (nextIndex !== undefined && nextIndex !== currentIndex) {\n event.preventDefault();\n scrollTo(nextIndex);\n setCurrentIndex(nextIndex);\n }\n\n if (onKeyDown) {\n event.persist();\n const index = nextIndex !== undefined ? nextIndex : currentIndex;\n onKeyDown(event, index);\n }\n };\n\n const handleClick = (index: number) => (event: React.MouseEvent<HTMLLIElement>) => {\n setCurrentIndex(index);\n\n if (onClick) {\n event.persist();\n onClick(event, index);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLUListElement>): void => {\n if (scrollOnFocus) {\n scrollTo(currentIndex);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const getOptionCheckedState = (optionValue: string, index: number): boolean => {\n if (optionValue === '#ALL-OPTIONS#') {\n return allOptionsSelected;\n } else if (!optionValue || !selectedIndexes) {\n return false;\n } else {\n return selectedIndexes.findIndex(i => i === index) !== -1;\n }\n };\n\n const options = data.map((option, index) => {\n const depth = option.path ? option.path.split('.').length - 1 : 0;\n\n return {\n 'aria-selected': multiselect ? getOptionCheckedState(String(option.value), index) : currentIndex === index,\n 'data-focused': currentIndex === index,\n children: option.text,\n className: cn(\n 'flex items-center px-3 w-full cursor-pointer bg-white flex-[0_0_2rem] focus:wcag-blue-500 focus:border-blue-500',\n {\n 'sticky top-0 font-bold': depth === 0 && !!option.hasChildren,\n }\n ),\n disabled: option.disabled,\n icon: option.icon,\n id: getId(id, option.value),\n key: getId(id, option.value),\n onClick: !disabled && !readOnly ? handleClick(index) : undefined,\n ref: itemRefs[index],\n role: 'option',\n style:\n depth > 0\n ? {\n paddingLeft: `${depth + 1}rem`,\n }\n : undefined,\n };\n });\n\n const list: React.HTMLAttributes<HTMLUListElement> &\n React.RefAttributes<HTMLUListElement> & { disabled?: boolean; readOnly?: boolean } = {\n ...otherProps,\n className: cn(\n 'inline-flex flex-col list-none !p-0 m-0 overflow-y-auto h-auto',\n getInputClasses(props),\n {\n 'yt-list--multiselect': multiselect,\n 'pointer-events-none': disabled,\n 'cursor-not-allowed': disabled || readOnly,\n },\n otherProps.className\n ),\n disabled,\n id,\n onFocus: !disabled && !readOnly ? handleFocus : undefined,\n onKeyDown: !disabled && !readOnly ? handleKeyDown : undefined,\n readOnly,\n ref: listRef,\n role: options.length <= 0 || loading ? 'presentation' : 'listbox',\n tabIndex: otherProps.tabIndex || 0,\n };\n\n return (\n <ul {...list} data-taco=\"scrollable-list\">\n {loading ? (\n <li className=\"yt-list__empty\">\n <span>\n <Spinner delay={0} />\n </span>\n <span>{texts.listbox.loading}</span>\n </li>\n ) : options.length ? (\n options.map(({ children, icon, ...optionProps }) => (\n <li {...optionProps}>\n {icon}\n <span className=\"flex-grow truncate text-left\">{children}</span>\n {multiselect && (\n <Checkbox\n // In multiselect variant, this checkbox only acts as visual representation of item being selected,\n // so need to be taken out of screen reader scope.\n aria-hidden\n tabIndex={-1}\n checked={optionProps['aria-selected']}\n onChange={() => null}\n className=\"pointer-events-none ml-2 self-center p-px\"\n />\n )}\n </li>\n ))\n ) : (\n <li className=\"yt-list__empty\">\n <span>{texts.listbox.empty}</span>\n </li>\n )}\n </ul>\n );\n});\n","// returns a custom event compatible with all browsers\nexport const createCustomEvent = (eventType: string) => {\n let customEvent;\n\n if (typeof Event === 'function') {\n customEvent = new Event(eventType, { bubbles: true });\n } else {\n customEvent = document.createEvent('Event');\n customEvent.initEvent(eventType, true, true);\n }\n return customEvent;\n};\n\n// returns a custom keyboard event compatible with all browsers\nexport const createCustomKeyboardEvent = (event: React.KeyboardEvent<HTMLInputElement>) => {\n let customKeyboardEvent;\n\n if (typeof KeyboardEvent === 'function') {\n customKeyboardEvent = new KeyboardEvent(event.type, event as any);\n } else {\n customKeyboardEvent = document.createEvent('Event') as any;\n customKeyboardEvent.initEvent(event.type, true, true);\n customKeyboardEvent.key = event.key;\n customKeyboardEvent.charCode = event.charCode;\n }\n\n return customKeyboardEvent;\n};\n\nexport const setInputValueByRef = (input: HTMLInputElement | null, value: string | undefined, event = 'change'): void => {\n if (!input) {\n return;\n }\n\n const previousValue = input.value;\n input.value = value || '';\n\n const tracker = (input as any)._valueTracker;\n\n if (tracker) {\n tracker.setValue(previousValue);\n }\n\n // 'change' instead of 'input', see https://github.com/facebook/react/issues/11488#issuecomment-381590324\n input.dispatchEvent(createCustomEvent(event));\n};\n","import React from 'react';\nimport { ScrollableListItem, ScrollableListItemValue, getId } from './ScrollableList';\nimport { setInputValueByRef as setInputValueByRefBase } from '../../utils/input';\n\nconst getValue = (value: ScrollableListItemValue | undefined): string => String(value ?? '');\n\nexport const setInputValueByRef = (input: HTMLInputElement | null, value: ScrollableListItemValue, event = 'change'): void => {\n setInputValueByRefBase(input, getValue(value), event);\n};\n\nexport const getIndexFromValue = (data: ScrollableListItem[], value: ScrollableListItemValue | undefined): number | undefined => {\n const index = data.findIndex(option => getValue(option.value) === getValue(value));\n return index > -1 ? index : undefined;\n};\n\nexport const getSelectedIndexesFromValue = (data: ScrollableListItem[], value: ScrollableListItemValue | undefined): number[] => {\n if (typeof value !== 'string') return [];\n\n return value\n .split(',')\n .map(v => data.findIndex(o => String(o.value) === v))\n .filter(v => v !== -1);\n};\n\nexport const findByValue = (data: ScrollableListItem[], value: ScrollableListItemValue): ScrollableListItem | undefined => {\n return data.find(option => getValue(option.value) === getValue(value));\n};\n\nexport const searchForString = (child: JSX.Element | string, value: string, strategy = 'includes'): boolean => {\n try {\n if (typeof child !== 'string' && child.props?.children) {\n if (Array.isArray(child.props?.children)) {\n return !!child.props.children.find((subChild: JSX.Element | string) =>\n searchForString(subChild, value, strategy)\n );\n }\n\n return searchForString(child.props?.children, value, strategy);\n } else {\n return child.toString().toLowerCase()[strategy](String(value).toLowerCase());\n }\n } catch {\n return false;\n }\n};\n\nconst getIndexInRangeByValue = (\n data: ScrollableListItem[],\n query: string,\n firstIndex: number,\n lastIndex: number = data.length\n): number => {\n const index = data.slice(firstIndex, lastIndex).findIndex(option => {\n if (option.disabled) {\n return false;\n }\n\n return searchForString(option.text, query, 'startsWith');\n });\n\n return index > -1 ? index + firstIndex : -1;\n};\n\nexport const findNextIndexByValue = (data: ScrollableListItem[], query: string, activeIndex: number | undefined): number => {\n const firstIndex = activeIndex === undefined ? 0 : activeIndex + 1;\n let index = getIndexInRangeByValue(data, query, firstIndex);\n\n if (index === -1) {\n index = getIndexInRangeByValue(data, query, 0, activeIndex);\n }\n\n return index;\n};\n\nexport const getActiveDescendant = (data: ScrollableListItem[], currentIndex: number | undefined, id: string): any => {\n return currentIndex !== undefined && data[currentIndex] ? getId(id, data[currentIndex].value) : undefined;\n};\n\nexport const useFlattenedData = (data: ScrollableListItem[]): ScrollableListItem[] => {\n return React.useMemo(() => {\n const items: ScrollableListItem[] = [];\n\n const flatten = (item: ScrollableListItem, path: number, parentPath?: string, parentDisabled?: boolean) => {\n const currentPath = parentPath ? `${parentPath}.${path}` : `${path}`;\n const isItemDisabled = parentDisabled || item.disabled;\n\n items.push({\n ...item,\n disabled: isItemDisabled,\n path: currentPath,\n hasChildren: !!item.children,\n });\n\n if (item.children) {\n item.children.forEach((childItem: ScrollableListItem, childPath: number) =>\n flatten(childItem, childPath, currentPath, isItemDisabled)\n );\n }\n };\n\n data.forEach((item, index) => {\n flatten(item, index);\n });\n\n return items;\n }, [data]);\n};\n\nexport const sanitizeItem = (item: ScrollableListItem | undefined) => {\n if (item) {\n const { hasChildren: _1, path: _2, ...rest } = item;\n return rest;\n }\n\n return undefined;\n};\n\nexport const getOptionParents = (data: ScrollableListItem[], path?: string) => {\n const indexes = path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n return indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(data.find((i: ScrollableListItem) => i.path === lastPath));\n });\n }\n\n return null;\n};\n\nexport const filterData = (data: ScrollableListItem[], value: ScrollableListItemValue = ''): ScrollableListItem[] => {\n if (value === '' || value === null) {\n return data;\n }\n\n const filteredOptionValues = new Set();\n const shouldFilterOption = (option: ScrollableListItem): boolean => {\n if (option.disabled) {\n return false;\n }\n\n return searchForString(option.text, String(value));\n };\n\n data.forEach(option => {\n if (shouldFilterOption(option)) {\n const parents = getOptionParents(data, option.path);\n\n filteredOptionValues.add(option.value);\n\n if (parents !== null) {\n parents.forEach(option => filteredOptionValues.add(option?.value));\n }\n }\n });\n\n return data.filter(({ value }) => filteredOptionValues.has(value));\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport debounce from 'lodash/debounce';\nimport { ComboboxProps } from './Combobox';\nimport {\n setInputValueByRef,\n getIndexFromValue,\n findByValue,\n useFlattenedData,\n sanitizeItem,\n getOptionParents,\n filterData,\n} from '../Listbox/util';\nimport { createCustomKeyboardEvent } from '../../utils/input';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { getId, ScrollableListItemValue, ScrollableListPropsWithRef } from '../Listbox/ScrollableList';\nimport { InputProps } from '../Input/Input';\n\nconst debouncer = debounce(f => f(), 200);\n\nconst convertToInputValue = (value: ScrollableListItemValue | undefined) => String(value ?? '');\n\ntype useCombobox = React.HTMLAttributes<HTMLDivElement> & {\n combobox: React.HTMLAttributes<HTMLSpanElement>;\n input: Omit<InputProps, 'defaultValue'> & { ref: React.RefObject<HTMLInputElement> };\n list: ScrollableListPropsWithRef;\n button: { ref: any };\n popover: { open: boolean; onOpenChange: (open: boolean) => void };\n};\n\nexport const useCombobox = (\n {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data: unfilteredData = [],\n defaultValue,\n disabled,\n id: nativeId,\n inline,\n loading: __,\n onChange,\n onClick,\n onKeyDown,\n onSearch,\n readOnly,\n value,\n ...props\n }: Omit<ComboboxProps, 'dialog'>,\n ref: React.Ref<HTMLInputElement>\n): useCombobox => {\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const buttonRef = React.useRef<HTMLButtonElement>(null);\n const listRef = React.useRef<HTMLUListElement>(null);\n const [open, setOpen] = React.useState(false);\n const listId = React.useMemo(() => uuid(), []);\n const [inputValue, setInputValue] = React.useState<string>(convertToInputValue(value));\n const shouldFilterData = !onSearch && (!inline || (inline && inputValue !== convertToInputValue(value)));\n const flattenedData = useFlattenedData(unfilteredData);\n const data = React.useMemo(\n () => (shouldFilterData ? filterData(flattenedData, inputValue) : flattenedData),\n [shouldFilterData, inputValue, flattenedData]\n );\n // listbox/select change value _with_ the index, but combobox changes on select of an index (click/enter), so we need state\n const [currentIndex, setCurrentIndex] = React.useState<number | undefined>(\n inputValue !== undefined ? getIndexFromValue(data, inputValue) : undefined\n );\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n setInputValueByRef(inputRef.current, option.value, 'focusout');\n }\n }\n };\n\n const setCurrentValue = (index: number | undefined) => {\n if (index === undefined) {\n return;\n }\n\n const option = data[index];\n\n // if the selected option is not already selected, trigger blur event\n if (option.value !== value) {\n setInputValueByIndex(index);\n } else {\n // if the selected option is already selected, refill input with its value\n setInputValue(convertToInputValue(value));\n }\n };\n\n // ensure the external value is synced with the internal value when mounting, e.g. incase a default value was set\n React.useEffect(() => {\n if (defaultValue && !value) {\n setInputValueByIndex(getIndexFromValue(data, defaultValue));\n }\n }, [data]);\n\n // update input value if it changed 'externally', e.g. clicking/entering an item in the listbox, from a modal etc\n React.useEffect(() => {\n if (value !== undefined && value !== inputValue) {\n setInputValue(convertToInputValue(value));\n }\n }, [value]);\n\n React.useEffect(() => {\n if (onSearch) {\n debouncer(() => {\n onSearch(inputValue);\n });\n }\n }, [inputValue]);\n\n // show listbox based on input value\n React.useEffect(() => {\n // don't show the popover if the internal (input) value already is the current value\n // this prevents the popover showing after selecting a value or pressing escape\n const isCurrentValue = value !== undefined && value !== null && inputValue === String(value);\n\n if (inputValue && data.length && !isCurrentValue) {\n setCurrentIndex(0);\n\n if (!open) {\n setOpen(true);\n }\n } else {\n setOpen(false);\n }\n }, [inputValue, data]);\n\n React.useEffect(() => {\n if (open) {\n setCurrentIndex(getIndexFromValue(data, inputValue) || 0);\n } else {\n setCurrentIndex(undefined);\n }\n }, [open]);\n\n // event handlers\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (event.relatedTarget === listRef.current) {\n event.preventDefault();\n return;\n }\n\n if (onChange && event.target.value !== value) {\n const item = findByValue(flattenedData, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const parents = getOptionParents(flattenedData, item?.path);\n\n if (parents !== null && parents.length > 0) {\n (event as any).detail.parents = parents;\n }\n\n onChange(event);\n }\n\n if (props.onBlur) {\n props.onBlur(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n setInputValue(event.target.value);\n };\n\n const handleInputClick = (event: React.MouseEvent<HTMLInputElement>): void => {\n if (inline || (!open && inputValue && data.length)) {\n setOpen(true);\n }\n\n if (onClick) {\n event.persist();\n onClick(event);\n }\n };\n\n const handleInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\n event.persist();\n\n switch (event.key) {\n case 'Backspace': {\n return;\n }\n\n case 'Escape': {\n event.preventDefault();\n setInputValue(convertToInputValue(value));\n setOpen(false);\n return;\n }\n\n case 'Tab':\n case 'Enter': {\n if (event.key !== 'Tab') {\n event.preventDefault();\n }\n\n setCurrentValue(currentIndex);\n setOpen(false);\n return;\n }\n\n case 'ArrowDown':\n if (open) {\n event.preventDefault();\n } else {\n if (!inline && buttonRef.current) {\n buttonRef.current.click();\n }\n }\n break;\n\n case 'ArrowUp':\n case 'Home':\n case 'End': {\n if (open) {\n event.preventDefault();\n }\n break;\n }\n\n default:\n }\n\n // we aren't focused on the list, so manually forward the keydown event to it\n if (listRef.current) {\n listRef.current.dispatchEvent(createCustomKeyboardEvent(event));\n }\n\n if (inline && !open) {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {\n event.preventDefault();\n const initialIndex = event.key === 'ArrowUp' ? data.length - 1 : 0;\n setCurrentIndex(currentIndex !== undefined ? currentIndex : initialIndex);\n setOpen(true);\n }\n }\n\n if (!event.isDefaultPrevented() && onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxChange = (index: number): void => {\n setCurrentIndex(index);\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>, index: number): void => {\n event.preventDefault();\n setCurrentValue(index);\n setOpen(false);\n };\n\n const combobox = {\n 'aria-expanded': open,\n 'aria-owns': listId,\n 'aria-haspopup': 'listbox' as const,\n role: 'combobox',\n };\n\n const input = {\n ...props,\n 'aria-controls': listId,\n // Indicates that the autocomplete behavior of the text input is to suggest a list of possible values in a popup and that the suggestions\n // are related to the string that is present in the textbox\n 'aria-autocomplete': 'list' as const,\n // Enables assistive technologies to know which element the application regards as focused while DOM focus remains on the input element\n 'aria-activedescendant':\n currentIndex !== undefined && data[currentIndex] ? getId(listId, String(data[currentIndex].value)) : undefined,\n 'aria-labelledby': ariaLabelledBy,\n disabled,\n onBlur: !disabled && !readOnly ? handleInputBlur : undefined,\n onChange: !disabled && !readOnly ? handleInputChange : undefined,\n onClick: !disabled && !readOnly ? handleInputClick : undefined,\n onKeyDown: !disabled && !readOnly ? handleInputKeyDown : undefined,\n readOnly,\n ref: inputRef,\n type: 'text',\n value: inputValue ?? '',\n };\n\n const list: ScrollableListPropsWithRef = {\n 'aria-labelledby': ariaLabelledBy,\n data,\n disabled,\n id: listId,\n onChange: handleListboxChange,\n onClick: handleListboxClick,\n ref: listRef,\n scrollOnFocus: false,\n tabIndex: -1,\n value: currentIndex,\n };\n\n const button = {\n ref: buttonRef,\n };\n\n return {\n combobox,\n input,\n list,\n button,\n popover: {\n open,\n onOpenChange: setOpen,\n //visible: !data.length ? false : open,\n },\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Input, InputProps } from '../Input/Input';\nimport { useCombobox } from './useCombobox';\nimport { ScrollableList, ScrollableListItem, ScrollableListItemValue } from '../Listbox/ScrollableList';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { IconButton } from '../IconButton/IconButton';\nimport './Combobox.css';\nimport { DialogProps } from '../Dialog/Dialog';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type ComboboxTexts = {\n /* Tooltip shown for the dialog button */\n tooltip: string;\n};\n\nexport type ComboboxItem = ScrollableListItem;\nexport type ComboboxValue = ScrollableListItemValue;\n\ntype ComboboxBaseProps = Omit<InputProps, 'defaultValue' | 'button' | 'onChange' | 'value'> & {\n /** Array of options in combobox */\n data?: ComboboxItem[];\n /**\n * Initial value of the input in combobox.\n * This is used when combobox is mounted, if no value is provided.\n * *Note* that combobox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ComboboxValue;\n /** Set what value should have an empty option in combobox */\n emptyValue?: ComboboxValue;\n /** Draws attention to the combobox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Displays loading state in listbox */\n loading?: boolean;\n /**\n * Handler called when user chooses an option from the provided suggestions.\n * Suggestions will be calculated based on the input value.\n * There are two ways to choose an option: either click on it, or navigate using keyboard and press `enter`\n */\n onChange?: React.ChangeEventHandler<HTMLInputElement>;\n /** Handler called when the user enters a query **/\n onSearch?: (query: string) => void | Promise<void>;\n /** Value of the input in combobox */\n value?: ComboboxValue;\n};\n\ninterface InlineComboboxProps extends ComboboxBaseProps {\n dialog?: never;\n /**\n * Combobox will display its data when input is clicked/focused, even if the input is empty.\n * *Note* that default combobox will display matching data only when user starts typing in input.\n */\n inline: boolean; // Example 3 on https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html\n}\n\ninterface DialogComboboxProps extends ComboboxBaseProps {\n dialog: (props: Partial<DialogProps>) => JSX.Element;\n inline?: never;\n}\n\nexport type ComboboxProps = InlineComboboxProps | DialogComboboxProps;\n\nexport const Combobox = React.forwardRef(function Combobox(props: ComboboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, dialog, style, ...otherProps } = props;\n const { combobox, button, input, popover, list } = useCombobox(otherProps, ref);\n const internalRef = React.useRef<HTMLDivElement>(null);\n const { texts } = useLocalization();\n const selectDimensions = useBoundingClientRectListener(internalRef);\n const className = cn(\n 'inline-flex relative',\n {\n 'yt-combobox--inline': props.inline,\n },\n externalClassName\n );\n\n return (\n <span className={className} data-taco=\"combobox\" style={style}>\n <PopoverPrimitive.Root {...popover}>\n <PopoverPrimitive.Anchor asChild ref={internalRef}>\n <div {...combobox} className=\"inline w-full\" ref={ref}>\n <Input\n {...input}\n autoComplete=\"off\"\n button={\n props.inline ? (\n <IconButton\n // In case of inline combobox, this icon button acts only as visual chevron representation,\n // so should be taken out of screen reader scope.\n aria-hidden\n appearance=\"discrete\"\n className=\"!border-l-0 focus:!border-none focus:!shadow-none active:!border-none\"\n icon={popover.open ? 'chevron-up' : 'chevron-down'}\n onClick={() => {\n popover.onOpenChange(true);\n input.ref.current?.focus();\n }}\n tabIndex={-1}\n />\n ) : dialog ? (\n <IconButton\n aria-label={texts.combobox.tooltip}\n icon=\"list-search\"\n disabled={props.readOnly || props.disabled}\n dialog={dialog}\n onFocus={(event: React.FocusEvent<HTMLButtonElement>) => {\n // Prevents the default focus behaviour of showing the tooltip, on parent tooltip element\n event.preventDefault();\n input.ref.current?.focus();\n }}\n ref={button.ref}\n tabIndex={-1}\n tooltip={texts.combobox.tooltip}\n />\n ) : undefined\n }\n />\n </div>\n </PopoverPrimitive.Anchor>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n align=\"start\"\n onOpenAutoFocus={event => {\n event.preventDefault();\n }}\n sideOffset={4}>\n <ScrollableList\n {...list}\n className={cn('max-h-[calc(12rem+2px)] w-auto max-w-[theme(spacing.96)] !border-blue-500')}\n style={{ minWidth: selectDimensions?.width }}\n tabIndex={popover.open ? 0 : -1}\n />\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n </span>\n );\n});\n","import { isDate, toDate, isValid } from 'date-fns';\n\nexport const format = (date: Date | undefined, mask = 'dd.mm.yy'): string | undefined => {\n if (!date) {\n return undefined;\n }\n\n const value = isDate(date) ? date : toDate(date);\n\n if (!isValid(value)) {\n return undefined;\n }\n\n const pad = (v: number): string => (String(v).length === 1 ? `0${v}` : v.toString());\n\n return mask\n .replace('dd', pad(value.getDate()))\n .replace('mm', pad(value.getMonth() + 1))\n .replace('yy', String(value.getFullYear()).slice(2));\n};\n\nexport const parseFromCustomString = (date = '', mask = 'dd.mm.yy'): Date | undefined => {\n if (!date || !date.length) {\n return undefined;\n }\n\n const sanitizedMask = mask.split(/[^dmy]/);\n const dd = sanitizedMask.findIndex(x => x === 'dd');\n const mm = sanitizedMask.findIndex(x => x === 'mm');\n const yy = sanitizedMask.findIndex(x => x === 'yy' || x === 'yyyy');\n\n let day;\n let month;\n let year;\n\n const getFullYear = (y: string): string => {\n if (y && y.length === 2) {\n const z = Number.parseInt(y, 10);\n\n return z > 50 ? `19${y}` : `20${y}`;\n }\n\n return y;\n };\n\n const inputParts = date.split(/\\D/);\n\n if (inputParts.length === 1) {\n const fullDate = inputParts[0];\n const unseparatedMask = mask.replace(/[^dmy]/g, '');\n\n day = fullDate.slice(unseparatedMask.indexOf('d'), unseparatedMask.lastIndexOf('d') + 1);\n month = fullDate.slice(unseparatedMask.indexOf('m'), unseparatedMask.lastIndexOf('m') + 1);\n year = getFullYear(fullDate.slice(unseparatedMask.indexOf('y'), unseparatedMask.lastIndexOf('y') + 3)); // account for full years\n } else {\n day = inputParts[dd];\n month = inputParts[mm];\n year = getFullYear(inputParts[yy]);\n }\n\n day = Number.parseInt(day, 10);\n month = Number.parseInt(month, 10);\n year = Number.parseInt(year, 10);\n\n const currentDate = new Date();\n\n return new Date(\n /* year */ Object.is(year, NaN) ? currentDate.getFullYear() : year,\n /* month */ Object.is(month, NaN) ? currentDate.getMonth() : month - 1, // months are zero based in javascript, so subtract a day\n /* day */ Object.is(day, NaN) ? currentDate.getDate() : day,\n /* hours */ 12,\n /* minutes */ 0 // set to midday to avoid UTC offset causing dates to be mismatched server side\n );\n};\n\nexport const parseFromISOString = (date: string): Date | undefined => {\n const tempDate = new Date(date);\n return isValid(tempDate) ? parseFromCustomString(format(new Date(date))) : undefined;\n};\n","import * as React from 'react';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\n\nexport const UnstyledArrow = React.forwardRef<SVGSVGElement, React.SVGAttributes<SVGElement>>(function PopoverArrow(props, ref) {\n return (\n <PopoverPrimitive.Arrow className=\"pointer-events-none -mt-px\" asChild offset={2} width={30} height={11}>\n <svg {...props} ref={ref} viewBox=\"0 19 30 11\" style={{ transform: 'rotateZ(180deg)' }}>\n <path\n className=\"text-grey-300 fill-current group-focus:text-blue-300\"\n d=\"M23.7,27.1L17,19.9C16.5,19.3,15.8,19,15,19s-1.6,0.3-2.1,0.9l-6.6,7.2C5.3,28.1,3.4,29,2,29h26 C26.7,29,24.6,28.1,23.7,27.1z\"></path>\n <path\n className=\"fill-current\"\n d=\"M23,27.8c1.1,1.2,3.4,2.2,5,2.2h2H0h2c1.7,0,3.9-1,5-2.2l6.6-7.2c0.7-0.8,2-0.8,2.7,0L23,27.8L23,27.8z\"></path>\n </svg>\n </PopoverPrimitive.Arrow>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from './Primitives';\nimport { mergeRefs } from '../../utils/mergeRefs';\nimport { getPopoverStyleClassnames } from './util';\n\ntype PopoverContextValue = { props: any; ref: React.Ref<HTMLElement> };\n\nconst PopoverContext = React.createContext<PopoverContextValue>({\n props: {},\n ref: null,\n});\n\nexport type PopoverTriggerProps = React.HTMLAttributes<HTMLElement>;\nconst Trigger = React.forwardRef(function PopoverAnchor(props: PopoverTriggerProps, externalRef: React.Ref<HTMLElement>) {\n const { ref: parentRef, props: parentProps } = React.useContext(PopoverContext);\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n let children = props.children;\n\n if (React.isValidElement(props.children) && typeof props.children?.type === 'function') {\n console.warn(\n `Popover.Trigger requires its child to forwardRef so that it can attach to the dom element. Did you mean to wrap '${props.children.type.name}' in React.forwardRef()? Taco has wrapped '${props.children.type.name}' in a 'span' to maintain functionality, but this may cause unintended behaviour`\n );\n children = <span>{props.children}</span>;\n }\n\n return (\n <PopoverPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild>\n {children}\n </PopoverPrimitive.Trigger>\n );\n});\n\nconst RenderPropWrapper = React.forwardRef(function RenderPropWrapper({ children, onClick }: any, ref) {\n const close = () => {\n onClick(new CustomEvent('hide'));\n };\n\n return children({ close, ref });\n});\n\nexport type PopoverContentRenderProps = { close: () => void };\nexport type PopoverContentProps = Omit<PopoverPrimitive.PopoverContentProps, 'side'> & {\n children: React.ReactNode | ((props: PopoverContentRenderProps) => React.ReactNode);\n /** Set the position of the Popover relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\nconst Content = React.forwardRef(function PopoverContent(props: PopoverContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side, ...popoverContentProps } = props;\n const className = cn(getPopoverStyleClassnames(), props.className);\n\n let output;\n\n if (typeof props.children === 'function') {\n output = (\n <PopoverPrimitive.Close asChild>\n <RenderPropWrapper>{props.children}</RenderPropWrapper>\n </PopoverPrimitive.Close>\n );\n } else {\n output = props.children;\n }\n\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n {...popoverContentProps}\n className={className}\n data-taco=\"popover\"\n side={side}\n sideOffset={1}\n ref={ref}>\n {output}\n <UnstyledArrow className=\"text-white\" />\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n );\n});\n\nexport type PopoverCloseProps = React.HTMLAttributes<HTMLButtonElement>;\nconst Close = React.forwardRef(\n (props: PopoverCloseProps, ref: React.Ref<HTMLButtonElement>): JSX.Element => (\n <PopoverPrimitive.Close {...props} ref={ref} asChild />\n )\n);\n\nexport type PopoverProps = React.PropsWithChildren<{\n modal?: boolean;\n /** A trigger to be used for the popover, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n /** Set whether the popover is open by default or not, use when not providing a trigger */\n defaultOpen?: boolean;\n /** Control the open state of the popover from outside the component */\n open?: boolean;\n /** Called when the popover opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n}>;\nexport type ForwardedPopoverWithStatics = React.ForwardRefExoticComponent<PopoverProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<PopoverTriggerProps>;\n Content: React.ForwardRefExoticComponent<PopoverContentProps>;\n Close: React.ForwardRefExoticComponent<PopoverCloseProps>;\n Portal: React.FunctionComponent<PopoverPrimitive.PortalProps>;\n};\n\nexport const Popover = React.forwardRef<HTMLElement, PopoverProps>(function Popover(props, ref) {\n const { children, defaultOpen, modal = false, open, onChange, trigger, ...otherProps } = props;\n const context = React.useMemo(() => ({ props: otherProps, ref }), [otherProps]);\n\n return (\n <PopoverContext.Provider value={context}>\n <PopoverPrimitive.Root defaultOpen={defaultOpen} modal={modal} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {children}\n </PopoverPrimitive.Root>\n </PopoverContext.Provider>\n );\n}) as ForwardedPopoverWithStatics;\nPopover.Trigger = Trigger;\nPopover.Content = Content;\nPopover.Close = Close;\nPopover.Portal = PopoverPrimitive.Portal;\n","export const getPopoverStyleClassnames = () =>\n 'bg-white focus:border-blue-300 border border-transparent rounded p-3 yt-shadow focus:yt-focus outline-none group';\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { Input, InputProps } from '../Input/Input';\nimport { useLocalization } from '../Provider/Localization';\nimport { useDatepicker } from './useDatepicker';\nimport { IconButton } from '../IconButton/IconButton';\nimport { Popover } from '../Popover/Popover';\n\nexport type DatepickerTexts = {\n /** Aria-label for calendar */\n calendar: string;\n /** Clear button text */\n clear: string;\n /**\n * Aria-label for calendar icon button in the input.\n * Calendar will open when user clicks this icon button.\n */\n expand: string;\n /** Shortcut heading text */\n shortcuts: string;\n};\n\nexport type DatePickerShortcut = {\n onClick: (event: React.MouseEvent) => void;\n text: string;\n};\n\nexport type DatepickerProps = Omit<InputProps, 'value'> & {\n /** [Calendar](component:calendar) component associated with the DatePicker */\n calendar?: CalendarProps;\n /** List of shortcuts */\n shortcuts?: DatePickerShortcut[];\n /** Title for the shortcuts panel */\n shortcutsText?: string;\n /** Handler to be called when the clear button is clicked */\n onReset?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n /**\n * Date value of the calendar.\n * This will be displayed in DatePicker's input in the format given to the [Provider](component:provider) component\n */\n value?: Date;\n};\n\nexport const Datepicker = React.forwardRef(function Datepicker(props: DatepickerProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, onReset: handleReset, style, shortcuts, shortcutsText, ...otherProps } = props;\n const { calendar, input } = useDatepicker(otherProps, ref);\n const { texts } = useLocalization();\n const className = cn('inline-flex w-full text-black font-normal', externalClassName);\n\n return (\n <span className={className} data-taco=\"datepicker\" style={style}>\n <Input\n {...input}\n button={\n <IconButton\n aria-label={texts.datepicker.expand}\n disabled={input.disabled || input.readOnly}\n icon=\"calendar\"\n popover={props => (\n <Popover {...props}>\n <Popover.Content>\n {({ close }) => (\n <div className=\"-m-3 flex\">\n <Calendar\n {...calendar}\n onChange={(date: Date, event?: React.MouseEvent<HTMLDivElement>) => {\n calendar.onChange(date, event);\n close();\n }}\n tabIndex={-1}\n />\n {shortcuts && (\n <div className=\"border-grey-300 flex flex-col border-l\">\n <span className=\"m-4 mb-3 flex h-8 w-32 items-center text-xs font-semibold\">\n {shortcutsText ?? texts.datepicker.shortcuts}\n </span>\n <ul>\n {shortcuts.map(shortcut => (\n <li key={shortcut.text}>\n <button\n type=\"button\"\n className=\"hover:bg-grey-100 flex w-full items-start px-4 py-1 text-xs\"\n onClick={event => {\n event.persist();\n shortcut.onClick(event);\n close();\n }}>\n {shortcut.text}\n </button>\n </li>\n ))}\n </ul>\n {handleReset && (\n <button\n type=\"button\"\n className=\"my-4 mx-auto mt-auto inline-flex cursor-pointer border-none bg-transparent text-xs text-blue-500 hover:text-blue-300\"\n onClick={event => {\n event.persist();\n handleReset(event);\n close();\n }}>\n {texts.datepicker.clear}\n </button>\n )}\n </div>\n )}\n </div>\n )}\n </Popover.Content>\n </Popover>\n )}\n />\n }\n />\n </span>\n );\n});\nDatepicker.displayName = 'Datepicker';\n","import * as React from 'react';\nimport { parseFromCustomString, format } from '../../utils/date';\nimport { useLocalization } from '../Provider/Localization';\nimport { setInputValueByRef } from '../../utils/input';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { DatepickerProps } from './Datepicker';\nimport { CalendarProps } from '../Calendar/Calendar';\nimport { InputProps as BaseInputProps } from '../Input/Input';\n\ntype InputProps = BaseInputProps & { ref: React.RefObject<HTMLInputElement> };\ntype useDatepicker = React.HTMLAttributes<HTMLDivElement> & {\n calendar: CalendarProps;\n input: InputProps;\n};\n\nexport const useDatepicker = (\n { defaultValue: _, calendar, onBlur, onChange, value, ...props }: DatepickerProps,\n ref: React.Ref<HTMLInputElement>\n): useDatepicker => {\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const { formatting } = useLocalization();\n const [internalValue, setInternalValue] = React.useState(value ? format(value, formatting.date) : '');\n\n // update internal value if it changed 'externally'\n React.useEffect(() => {\n if (value) {\n const formattedValue = format(value, formatting.date);\n\n if (formattedValue !== internalValue) {\n setInternalValue(formattedValue);\n }\n } else {\n setInternalValue('');\n }\n }, [value]);\n\n // event handlers\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>): void => {\n event.persist();\n\n const valueAsDate = parseFromCustomString(event.target.value);\n const formattedValue = valueAsDate ? format(valueAsDate) || '' : '';\n\n event.target.value = formattedValue;\n\n if (onChange) {\n (event as any).detail = valueAsDate;\n onChange(event);\n } else {\n // update the internal value to use the formatted date\n setInternalValue(formattedValue);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n setInternalValue(event.target.value);\n };\n\n const handleChange = date => {\n setInputValueByRef(inputRef.current, format(date, formatting.date), 'focusout');\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter') {\n event.target.dispatchEvent(new Event('focusout', { bubbles: true }));\n }\n };\n\n const inputProps: InputProps = {\n ...props,\n autoComplete: 'off',\n onBlur: handleInputBlur,\n onChange: handleInputChange,\n onKeyDown: handleKeyDown,\n ref: inputRef,\n type: 'text',\n value: internalValue,\n };\n\n const calendarProps: CalendarProps = {\n ...calendar,\n onChange: handleChange,\n value,\n };\n\n return {\n input: inputProps,\n calendar: calendarProps,\n };\n};\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport * as React from 'react';\nimport { DialogSize } from './types';\n\nexport type DialogContext = {\n closeOnEscape: boolean;\n draggable: boolean;\n drawer: {\n open: boolean;\n toggle: () => void;\n };\n elements: {\n drawer?: React.ReactNode;\n extra?: React.ReactNode;\n };\n onClose?: () => void;\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n showCloseButton: boolean;\n size: DialogSize;\n};\n\nexport const DialogContext = React.createContext<DialogContext>({\n closeOnEscape: true,\n draggable: false,\n drawer: {\n open: false,\n toggle: () => {},\n },\n elements: {\n drawer: undefined,\n extra: undefined,\n },\n onClose: () => {},\n props: {},\n ref: null,\n showCloseButton: true,\n size: 'sm',\n});\n\nexport const useCurrentDialog = () => {\n return React.useContext(DialogContext);\n};\n","import * as React from 'react';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { useCurrentDialog } from '../Context';\nimport { mergeRefs } from '../../../utils/mergeRefs';\n\nexport type DialogTriggerProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Trigger = React.forwardRef(function DialogTrigger(\n props: DialogTriggerProps,\n externalRef: React.Ref<HTMLButtonElement>\n) {\n const { ref: parentRef, props: parentProps } = useCurrentDialog();\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n return <DialogPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useDraggable } from '../../../utils/hooks/useDraggable';\nimport { DialogContext, useCurrentDialog } from '../Context';\nimport { useLocalization } from '../../Provider/Localization';\nimport { IconButton } from '../../IconButton/IconButton';\nimport { Backdrop } from '../../Backdrop/Backdrop';\nimport { getDialogPositionClassnames, getDialogSizeClassnames } from '../util';\n\nexport type DialogContentDrawerRenderProps = DialogContext['drawer'];\n\nexport type DialogContentRenderProps = {\n close: () => void;\n drawer?: DialogContentDrawerRenderProps;\n};\n\nexport type DialogTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function DialogTitle(props: DialogTitleProps, ref: React.Ref<HTMLHeadingElement>) {\n const className = cn('text-center', props.className);\n return <DialogPrimitive.Title {...props} className={className} ref={ref} />;\n});\n\nexport type DialogFooterProps = React.HTMLAttributes<HTMLDivElement>;\nexport const Footer = React.forwardRef(function DialogFooter(props: DialogFooterProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn('mt-8 flex justify-end', props.className);\n return (\n <div {...props} className={className} ref={ref}>\n {props.children}\n </div>\n );\n});\n\nexport type DialogCloseProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Close = React.forwardRef(function DialogClose(props: DialogCloseProps, ref: React.Ref<HTMLButtonElement>) {\n const dialog = useCurrentDialog();\n\n return <DialogPrimitive.Close onClick={dialog.onClose} {...props} ref={ref} asChild />;\n});\n\nconst RenderPropWrapper = React.forwardRef(function RenderPropWrapper({ children, onClick, renderProps }: any, ref) {\n const close = () => {\n onClick(new CustomEvent('close'));\n };\n\n return children({ close, ref, ...renderProps });\n});\n\nexport type DialogContentProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & {\n /** An accessible label to be announced when the dialog is opened */\n 'aria-label': string;\n children: Omit<React.ReactNode, 'Function'> | ((props: DialogContentRenderProps) => JSX.Element);\n};\nexport const Content = React.forwardRef(function DialogContent(props: DialogContentProps, ref: React.Ref<HTMLDivElement>) {\n const dialog = useCurrentDialog();\n const internalRef = useMergedRef<HTMLDivElement>(ref);\n const { position, dragging, handleProps: dragHandleProps } = useDraggable(internalRef);\n const { texts } = useLocalization();\n\n const className = cn(\n 'relative bg-white animate-[fade-in_150ms]',\n getDialogPositionClassnames(),\n getDialogSizeClassnames(dialog.size)\n );\n\n const containerClassName = cn(\n 'bg-white p-6 rounded relative z-10',\n 'shadow-[0_6px_9px_0_rgba(89,85,98,0.3),0_0_1px_0_rgba(89,85,98,0.2)]',\n {\n 'rounded-b-none': !!dialog.elements.extra,\n },\n props.className\n );\n\n const handleEscapeKeyDown = (event: KeyboardEvent) => {\n if (!dialog.closeOnEscape) {\n event.preventDefault();\n } else if (dialog.onClose) {\n dialog.onClose();\n }\n };\n\n // the chosen behaviour in taco is that outside clicks do not close the dialog\n const handleInteractOutside = event => event.preventDefault();\n\n let output;\n\n if (typeof props.children === 'function') {\n output = (\n <DialogPrimitive.Close asChild>\n <RenderPropWrapper renderProps={{ drawer: dialog.drawer }}>{props.children}</RenderPropWrapper>\n </DialogPrimitive.Close>\n );\n } else {\n output = props.children;\n }\n\n return (\n <DialogPrimitive.Portal>\n <DialogPrimitive.Overlay asChild>\n <Backdrop>\n <DialogPrimitive.Content\n {...props}\n className={className}\n onEscapeKeyDown={handleEscapeKeyDown}\n onInteractOutside={handleInteractOutside}\n ref={internalRef}\n style={{\n ...props.style,\n left: dialog.draggable ? `${position.x}px` : undefined,\n top: dialog.draggable ? `${position.y}px` : undefined,\n }}>\n <div className={containerClassName} data-taco=\"dialog\">\n {output}\n {dialog.draggable && (\n <div\n {...dragHandleProps}\n role=\"button\"\n draggable\n aria-grabbed={dragging}\n aria-label={texts.dialog.drag}\n className=\"yt-dialog__drag absolute-center-x bg-grey-100 top-1.5 h-3 w-24 cursor-move rounded text-center\"\n />\n )}\n {dialog.showCloseButton ? (\n <DialogPrimitive.Close onClick={dialog.onClose} asChild>\n <IconButton\n appearance=\"discrete\"\n aria-label={texts.dialog.close}\n className=\"absolute top-0 right-0 mt-2 mr-2\"\n icon=\"close\"\n />\n </DialogPrimitive.Close>\n ) : null}\n </div>\n {dialog.elements.drawer}\n {dialog.elements.extra}\n </DialogPrimitive.Content>\n </Backdrop>\n </DialogPrimitive.Overlay>\n </DialogPrimitive.Portal>\n );\n});\n","import React from 'react';\nimport { useMove } from '@react-aria/interactions';\n\nexport const useDraggable = (ref: React.MutableRefObject<HTMLDivElement | null>): any => {\n const [position, setPosition] = React.useState({\n x: 0,\n y: 0,\n });\n\n const [dragging, setDragging] = React.useState(false);\n\n const { moveProps } = useMove({\n onMoveStart() {\n setDragging(true);\n },\n onMove(event) {\n const rect = ref.current?.getBoundingClientRect();\n\n // Prevent dragging out of bounds\n if (\n rect &&\n (rect.left + event.deltaX < 0 ||\n rect.right + event.deltaX > window.innerWidth ||\n rect.top + event.deltaY < 0 ||\n rect.bottom + event.deltaY > window.innerHeight)\n ) {\n return;\n }\n\n setPosition(({ x, y }) => {\n x += event.deltaX;\n y += event.deltaY;\n return { x, y };\n });\n },\n onMoveEnd() {\n setDragging(false);\n },\n });\n\n return {\n position,\n dragging,\n handleProps: moveProps,\n };\n};\n","import * as React from 'react';\nimport { motion } from 'framer-motion';\nimport cn from 'classnames';\nimport { DialogContext, useCurrentDialog } from '../Context';\n\nexport type DialogDrawerRenderProps = DialogContext['drawer'];\n\nexport type DialogDrawerProps = Omit<\n React.HTMLAttributes<HTMLDivElement>,\n 'onAnimationStart' | 'onDragStart' | 'onDragEnd' | 'onDrag'\n> & {\n children: Omit<React.ReactNode, 'Function'> | ((props: DialogDrawerRenderProps) => React.ReactNode);\n};\n\nconst Drawer = React.forwardRef(function DialogDrawer(props: DialogDrawerProps, ref: React.Ref<HTMLDivElement>) {\n const dialog = useCurrentDialog();\n const className = cn(\n 'absolute top-0 -ml-[4px] hidden h-full w-full overflow-y-auto rounded-r bg-white p-6 text-left',\n props.className\n );\n\n return (\n <motion.div\n {...props}\n className={className}\n data-taco=\"dialog-drawer\"\n aria-hidden={!dialog.drawer?.open}\n variants={{\n visible: {\n left: '100%',\n display: 'block',\n transition: { ease: 'easeOut', duration: 0.2 },\n },\n hidden: {\n left: '0%',\n transition: { ease: 'easeOut', duration: 0.2 },\n transitionEnd: {\n display: 'none',\n },\n },\n }}\n animate={dialog.drawer?.open ? 'visible' : 'hidden'}\n ref={ref}>\n {typeof props.children === 'function' ? props.children(dialog.drawer) : props.children}\n </motion.div>\n );\n});\nDrawer.displayName = 'DialogDrawer';\n\nexport { Drawer };\n","import * as React from 'react';\nimport cn from 'classnames';\n\nexport type DialogExtraProps = React.HTMLAttributes<HTMLDivElement>;\n\nconst Extra = React.forwardRef(function DialogExtra(props: DialogExtraProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn(\n 'bg-grey-100 yt-shadow-inset absolute top-full left-0 -mt-px w-full rounded-t-none rounded-b p-6 text-left',\n props.className\n );\n\n return <div {...props} className={className} data-taco=\"dialog-extra\" ref={ref} />;\n});\nExtra.displayName = 'DialogExtra';\n\nexport { Extra };\n","import * as React from 'react';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport './Dialog.css';\nimport { DialogTriggerProps, Trigger } from './components/Trigger';\nimport {\n Content,\n Title,\n Footer,\n Close,\n DialogContentProps,\n DialogContentRenderProps,\n DialogContentDrawerRenderProps,\n DialogTitleProps,\n DialogFooterProps,\n DialogCloseProps,\n} from './components/Content';\nimport { DialogDrawerProps, DialogDrawerRenderProps, Drawer } from './components/Drawer';\nimport { DialogExtraProps, Extra } from './components/Extra';\nimport { DialogContext } from './Context';\nimport { DialogSize } from './types';\n\nexport type {\n DialogCloseProps,\n DialogContentDrawerRenderProps,\n DialogContentProps,\n DialogContentRenderProps,\n DialogDrawerProps,\n DialogDrawerRenderProps,\n DialogFooterProps,\n DialogSize,\n DialogTitleProps,\n};\n\nexport type DialogTexts = {\n /**\n * Aria-label for close icon button in dialog.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n close: string;\n drag: string;\n};\n\nexport type DialogProps = {\n children: React.ReactNode | React.ReactNode[];\n /** When `true`, pressing escape will close the dialog */\n closeOnEscape?: boolean;\n /** Set whether the dialog is open by default or not */\n defaultOpen?: boolean;\n /** Allows dragging the dialog around the screen (window constrained) */\n draggable?: boolean;\n /** Handler called when dialog closes by user interaction */\n onClose?: () => void;\n /** Called when the dialog opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the dialog from outside the component */\n open?: boolean;\n /** Shows the close icon button of the dialog */\n showCloseButton?: boolean;\n /** Size of the dialog. This is the recommended way to set a size for dialog component. */\n size?: DialogSize;\n /** A trigger to be used for the dialog, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\n\nconst useSeparatedChildren = initialChildren => {\n return React.useMemo(() => {\n const children: any[] = [];\n let drawer;\n let extra;\n\n React.Children.toArray(initialChildren).forEach((child: any) => {\n if (child.type?.displayName === Drawer.displayName) {\n drawer = child;\n } else if (child.type?.displayName === Extra.displayName) {\n extra = child;\n } else {\n children.push(child);\n }\n });\n\n return [children, drawer, extra];\n }, [initialChildren]);\n};\n\nexport type ForwardedDialogWithStatics = React.ForwardRefExoticComponent<DialogProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<DialogTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n Content: React.ForwardRefExoticComponent<DialogContentProps & React.RefAttributes<HTMLDivElement>>;\n Title: React.ForwardRefExoticComponent<DialogTitleProps & React.RefAttributes<HTMLHeadingElement>>;\n Footer: React.ForwardRefExoticComponent<DialogFooterProps & React.RefAttributes<HTMLDivElement>>;\n Extra: React.ForwardRefExoticComponent<DialogExtraProps & React.RefAttributes<HTMLDivElement>>;\n Drawer: React.ForwardRefExoticComponent<DialogDrawerProps & React.RefAttributes<HTMLDivElement>>;\n Close: React.ForwardRefExoticComponent<DialogCloseProps & React.RefAttributes<HTMLButtonElement>>;\n};\n\nexport const Dialog = React.forwardRef(function Dialog(props: DialogProps, ref: React.Ref<HTMLElement>) {\n const {\n children: initialChildren,\n closeOnEscape = true,\n defaultOpen,\n draggable = false,\n onChange,\n onClose,\n open,\n showCloseButton = true,\n size = 'sm',\n trigger,\n ...otherProps\n } = props;\n const [children, drawer, extra] = useSeparatedChildren(initialChildren);\n const [drawerOpen, setDrawerOpen] = React.useState(false);\n\n const context = React.useMemo(\n () => ({\n closeOnEscape,\n draggable,\n drawer: {\n open: drawerOpen,\n toggle: () => setDrawerOpen(isDrawerOpen => !isDrawerOpen),\n },\n elements: {\n drawer,\n extra,\n },\n onClose,\n props: otherProps,\n showCloseButton,\n size,\n ref,\n }),\n [closeOnEscape, drawerOpen, draggable, drawer, extra, open, otherProps, showCloseButton]\n );\n\n return (\n <DialogContext.Provider value={context}>\n <DialogPrimitive.Root defaultOpen={defaultOpen} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {children}\n </DialogPrimitive.Root>\n </DialogContext.Provider>\n );\n}) as ForwardedDialogWithStatics;\n\nDialog.Trigger = Trigger;\nDialog.Content = Content;\nDialog.Title = Title;\nDialog.Footer = Footer;\nDialog.Extra = Extra;\nDialog.Drawer = Drawer;\nDialog.Close = Close;\n","import * as React from 'react';\nimport cn from 'classnames';\n\nimport './Field.css';\n\nexport type FieldProps = React.LabelHTMLAttributes<HTMLLabelElement> & {\n /** Content of the field */\n children: React.ReactNode;\n /**\tChanges the style to indicate the element is disabled */\n disabled?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Text displayed below the children of Field.\n * Should be a short text that indicates feedback for user.\n */\n message?: string;\n};\n\nexport const Field = React.forwardRef(function Field(props: FieldProps, ref: React.Ref<HTMLLabelElement>) {\n const { disabled, children, invalid = false, message, ...otherProps } = props;\n const className = cn(\n 'flex flex-col font-bold text-xs leading-loose pb-4 min-h-[theme(spacing.18)]',\n {\n 'text-grey-300': disabled,\n },\n props.className\n );\n const messageClassName = cn(\n 'h-4 text-xs text-left leading-normal font-normal truncate -mb-4',\n {\n 'text-grey-700': !invalid,\n 'text-red-500': invalid,\n 'opacity-50': disabled,\n },\n props.className\n );\n\n return (\n <label {...otherProps} className={className} data-taco=\"label\" ref={ref}>\n {children}\n {message && (\n <span className={messageClassName} role={invalid ? 'alert' : undefined}>\n {message}\n </span>\n )}\n </label>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport './Form.css';\n\nexport type FormProps = React.FormHTMLAttributes<HTMLFormElement> & {\n /** Content should be composed of other Taco form elements */\n children: React.ReactNode;\n /** Display the form fields in a horizontal layout */\n horizontal?: boolean;\n};\n\nexport const Form = React.forwardRef(function Form(props: FormProps, ref: React.Ref<HTMLFormElement>) {\n const { horizontal = false, ...otherProps } = props;\n const className = cn(\n 'yt-form',\n {\n 'yt-form--horizontal flex flex-wrap': horizontal,\n },\n props.className\n );\n\n return <form {...otherProps} className={className} data-taco=\"form\" ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Orientation } from '../../types';\n\nexport type GroupProps = React.HTMLAttributes<HTMLElement> & {\n /**\n * Change what html tag element will render.\n * Default value is `span`\n */\n as?: 'div' | 'span' | 'nav';\n /** Content should be composed of other Taco elements */\n children: React.ReactNode;\n /**\n * Define orientation of grouping.\n * @defaultValue horizontal\n */\n orientation?: Orientation;\n};\n\nexport const Group = React.forwardRef(function Group(props: GroupProps, ref: React.Ref<HTMLDivElement>) {\n const { as: Tag = 'span', orientation = 'horizontal', ...otherProps } = props;\n const className = cn('flex ', 'gap-2', { 'flex-col ': orientation === 'vertical' }, props.className);\n return <Tag {...otherProps} className={className} data-taco=\"group\" ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { IconButton } from '../IconButton/IconButton';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from '../Popover/Primitives';\nimport { useLocalization } from '../Provider/Localization';\nimport './Hanger.css';\nimport { mergeRefs } from '../../utils/mergeRefs';\n\ntype HangerContextValue = {\n /** Handler called when hanger closes by user interaction */\n onClose?: () => void;\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n};\nconst HangerContext = React.createContext<HangerContextValue>({\n onClose: undefined,\n props: {},\n ref: null,\n});\n\nexport type HangerTexts = {\n /** Aria-label for the close icon button of hanger */\n close: string;\n};\n\nexport type HangerAnchorProps = React.HTMLAttributes<HTMLDivElement>;\nconst Anchor = React.forwardRef(function HangerAnchor(props: HangerAnchorProps, externalRef: React.Ref<HTMLDivElement>) {\n const { ref: parentRef, props: parentProps } = React.useContext(HangerContext);\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n let children = props.children;\n\n if (React.isValidElement(props.children) && typeof props.children?.type === 'function') {\n console.warn(\n `Hanger.Anchor requires its child to forwardRef so that it can attach to the dom element. Did you mean to wrap '${props.children.type.name}' in React.forwardRef()? Taco has wrapped '${props.children.type.name}' in a 'span' to maintain functionality, but this may cause unintended behaviour`\n );\n children = <span>{props.children}</span>;\n }\n\n return (\n <PopoverPrimitive.Anchor {...parentProps} {...props} ref={refCallback} asChild>\n {children}\n </PopoverPrimitive.Anchor>\n );\n});\n\nexport type HangerTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function DialogTitle(props: HangerTitleProps, ref: React.Ref<HTMLHeadingElement>) {\n const className = cn('mb-1 text-base font-bold flex w-full', props.className);\n return <span {...props} className={className} ref={ref} />;\n});\n\nexport type HangerContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Set the position of the Hanger relative to its achor. Default value is `bottom` */\n placement?: Placement;\n};\n\nconst Content = React.forwardRef(function HangerContent(props: HangerContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side } = props;\n const context = React.useContext(HangerContext);\n const { texts } = useLocalization();\n const className = cn(\n 'wcag-blue-500 border border-transparent rounded p-3 pr-12 yt-shadow focus:border-transparent max-w-sm',\n props.className\n );\n const handleInteractOutside = (event: CustomEvent): void => {\n event.preventDefault();\n };\n\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n className={className}\n data-taco=\"hanger\"\n onInteractOutside={handleInteractOutside}\n side={side}\n sideOffset={1}\n ref={ref}>\n {props.children}\n <UnstyledArrow className=\"text-blue-500\" />\n <PopoverPrimitive.Close asChild>\n <IconButton\n appearance=\"primary\"\n aria-label={texts.hanger.close}\n className=\"absolute top-0 right-0 ml-2 mr-2 mt-2 text-white\"\n icon=\"close\"\n onClick={context.onClose}\n />\n </PopoverPrimitive.Close>\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n );\n});\n\nexport type HangerProps = React.PropsWithChildren<{\n /** An anchor to be used for the hanger, should not be set if `children` already contains an anchor */\n anchor?: JSX.Element;\n /**\n * Shows or hides hanger depending on the value\n * @defaultValue true\n */\n defaultOpen?: boolean;\n /** Handler called when user closes the hanger */\n onClose?: () => void;\n}>;\n\nexport type ForwardedHangerWithStatics = React.ForwardRefExoticComponent<HangerProps & React.RefAttributes<HTMLElement>> & {\n Anchor: React.ForwardRefExoticComponent<HangerAnchorProps>;\n Content: React.ForwardRefExoticComponent<HangerContentProps>;\n Title: React.ForwardRefExoticComponent<HangerTitleProps>;\n};\n\nexport const Hanger = React.forwardRef<HTMLElement, HangerProps>(function Hanger(props, ref) {\n const { anchor, children, defaultOpen = true, onClose, ...otherProps } = props;\n const context = React.useMemo(() => ({ onClose, props: otherProps, ref }), [onClose, otherProps]);\n\n // we do this to ensure hangers are mounted after their containers, e.g. if the container is another portal\n const [open, setOpen] = React.useState(false);\n React.useEffect(() => {\n if (defaultOpen) {\n setOpen(defaultOpen);\n }\n }, []);\n\n return (\n <HangerContext.Provider value={context}>\n <PopoverPrimitive.Root key={String(open)} defaultOpen={open}>\n {anchor && <Anchor>{anchor}</Anchor>}\n {children}\n </PopoverPrimitive.Root>\n </HangerContext.Provider>\n );\n}) as ForwardedHangerWithStatics;\nHanger.Anchor = Anchor;\nHanger.Content = Content;\nHanger.Title = Title;\n","import * as React from 'react';\nimport * as HoverCardPrimitive from '@radix-ui/react-hover-card';\n\nexport const UnstyledArrow = React.forwardRef(function HoverCardArrow(\n props: React.SVGAttributes<SVGElement>,\n ref: React.Ref<SVGSVGElement>\n) {\n return (\n <HoverCardPrimitive.Arrow className=\"pointer-events-none -mt-px\" asChild offset={2} width={30} height={11}>\n <svg {...props} ref={ref} viewBox=\"0 19 30 11\" style={{ transform: 'rotateZ(180deg)' }}>\n <path\n className=\"text-grey-300 fill-current group-focus:text-blue-300\"\n d=\"M23.7,27.1L17,19.9C16.5,19.3,15.8,19,15,19s-1.6,0.3-2.1,0.9l-6.6,7.2C5.3,28.1,3.4,29,2,29h26 C26.7,29,24.6,28.1,23.7,27.1z\"></path>\n <path\n className=\"fill-current\"\n d=\"M23,27.8c1.1,1.2,3.4,2.2,5,2.2h2H0h2c1.7,0,3.9-1,5-2.2l6.6-7.2c0.7-0.8,2-0.8,2.7,0L23,27.8L23,27.8z\"></path>\n </svg>\n </HoverCardPrimitive.Arrow>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as HoverCardPrimitive from '@radix-ui/react-hover-card';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from './Primitives';\nimport { getPopoverStyleClassnames } from '../Popover/util';\n\nexport type HoverCardTriggerProps = React.HTMLAttributes<HTMLAnchorElement>;\nconst Trigger = React.forwardRef(function HoverCardTrigger(props: HoverCardTriggerProps, ref: React.Ref<HTMLAnchorElement>) {\n return <HoverCardPrimitive.Trigger {...props} asChild ref={ref} />;\n});\n\nexport type HoverCardContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Set the position of the HoverCard relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\nconst Content = React.forwardRef(function HoverCardContent(props: HoverCardContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side } = props;\n const className = cn(getPopoverStyleClassnames(), 'min-w-[theme(spacing.40)] max-w-[theme(spacing.96)]', props.className);\n\n return (\n <HoverCardPrimitive.Portal>\n <HoverCardPrimitive.Content className={className} data-taco=\"hover-card\" side={side} sideOffset={1} ref={ref}>\n {props.children}\n <UnstyledArrow className=\"text-white\" />\n </HoverCardPrimitive.Content>\n </HoverCardPrimitive.Portal>\n );\n});\n\nexport type HoverCardProps = React.PropsWithChildren<{}>;\n\nexport const HoverCard = (props: HoverCardProps) => {\n return <HoverCardPrimitive.Root {...props} openDelay={300} />;\n};\nHoverCard.Trigger = Trigger;\nHoverCard.Content = Content;\n","import * as React from 'react';\nimport { Input, InputProps } from '../Input/Input';\nimport { useLocalization } from '../Provider/Localization';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef } from '../../utils/input';\n\nexport type SearchInputTexts = {\n button: string;\n clear: string;\n placeholder: string;\n};\n\nexport type SearchInputProps = Omit<InputProps, 'button' | 'icon' | 'prefix' | 'postfix'> & {\n /** Current input value will be passed to the method. In order to get the value, the component must be controlled otherwise value will always be undefined */\n onSearch?: (value: string | number | readonly string[] | undefined) => void;\n};\n\nexport const SearchInput = React.forwardRef(function SearchInput(\n { onSearch, ...props }: SearchInputProps,\n ref: React.Ref<HTMLInputElement>\n) {\n const internalRef = useMergedRef<HTMLInputElement>(ref);\n const { texts } = useLocalization();\n\n const handleClick = (): void => {\n onSearch?.(internalRef.current?.value ?? '');\n };\n\n const handleCancelClick = (): void => {\n setInputValueByRef(internalRef.current, '');\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\n if (event.key === 'Enter') {\n event.preventDefault();\n handleClick();\n return;\n }\n\n props.onKeyDown?.(event);\n };\n\n return (\n <Input\n aria-label={texts.searchInput.placeholder}\n placeholder={texts.searchInput.placeholder}\n {...props}\n onKeyDown={handleKeyDown}\n postfix={\n <>\n {props.disabled || props.readOnly || !props.value ? null : (\n <IconButton\n aria-hidden\n className=\"group-peer-focus:visible group-peer-hover:visible !text-grey-700 invisible mr-0.5 !h-5 !min-h-[theme(spacing.4)] !w-5 !min-w-[theme(spacing.4)] text-xs hover:visible group-hover:visible\"\n icon=\"close\"\n onClick={handleCancelClick}\n rounded\n tabIndex={-1}\n tooltip={texts.searchInput.clear}\n />\n )}\n <IconButton\n aria-label={texts.searchInput.button}\n icon=\"search\"\n className=\"group-peer-focus:!border-transparent group-peer-focus:group-peer-active:!border-transparent -mr-2 !border-transparent !bg-transparent focus:!border-transparent\"\n disabled={props.disabled || props.readOnly}\n onClick={handleClick}\n tooltip={texts.searchInput.button}\n />\n </>\n }\n ref={internalRef}\n type=\"search\"\n />\n );\n});\n","import * as React from 'react';\n\nexport interface Timer {\n running: boolean;\n start: () => void;\n pause: () => void;\n resume: () => void;\n}\n\ntype Tracker = {\n remaining: number;\n started: number | null;\n};\n\nexport default function useTimer(duration = 0, callback: () => void): Timer {\n const timer = React.useRef<number>();\n const [tracker, setTracker] = React.useState<Tracker>({\n remaining: duration,\n started: null,\n });\n\n React.useEffect(() => {\n if (duration) {\n if (tracker.started) {\n timer.current = window.setTimeout(callback, tracker.remaining);\n } else {\n clearTimeout(timer.current);\n }\n }\n\n return () => {\n clearTimeout(timer.current);\n };\n }, [tracker.started]);\n\n return {\n running: !!tracker.started,\n start: () => {\n setTracker({\n remaining: duration,\n started: Date.now(),\n });\n },\n pause: () => {\n if (tracker.started) {\n setTracker({\n remaining: tracker.remaining - (Date.now() - tracker.started),\n started: null,\n });\n }\n },\n resume: () => {\n if (tracker.remaining && !tracker.started) {\n setTracker({\n remaining: tracker.remaining,\n started: Date.now(),\n });\n }\n },\n };\n}\n","import * as React from 'react';\nimport useTimer from '../../utils/hooks/useTimer';\nimport { findNextIndexByValue } from './util';\nimport { ScrollableListItem } from './ScrollableList';\n\ntype useTypeahead = {\n getNextIndex: (key: string) => number;\n};\n\ntype useTypeaheadProps = {\n data: ScrollableListItem[];\n currentIndex: number | undefined;\n};\n\nexport const useTypeahead = ({ data, currentIndex }: useTypeaheadProps): useTypeahead => {\n const typeaheadQuery = React.useRef<string | undefined>();\n const typeaheadQueryTimer = useTimer(1000, () => {\n typeaheadQuery.current = undefined;\n });\n\n const getNextIndex = (charKey: string): number => {\n const query = (typeaheadQuery.current ? typeaheadQuery.current + charKey : charKey).toLowerCase();\n const nextIndex = findNextIndexByValue(data, query, currentIndex);\n\n typeaheadQueryTimer.start();\n typeaheadQuery.current = query;\n\n return nextIndex;\n };\n\n return { getNextIndex };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { useListbox } from './useListbox';\nimport { useMultiListbox } from './useMultiListbox';\nimport { ScrollableList, ScrollableListItemValue, ScrollableListItem } from './ScrollableList';\n\nexport type ListboxItem = ScrollableListItem;\nexport type ListboxValue = ScrollableListItemValue;\n\nexport type ListboxTexts = {\n /**\n * Text displayed in the listbox if no data provided.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n empty: string;\n /**\n * Text displayed in the listbox to indicate the data is loading.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading: string;\n /**\n * The first option displayed in a multiselect listbox that selects all available options.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n allOption: string;\n};\n\nexport type ListboxProps = Pick<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onFocus'> &\n Omit<React.InputHTMLAttributes<HTMLElement>, 'defaultValue' | 'onChange' | 'value'> & {\n /** Data indicating the options in listbox */\n data?: ListboxItem[];\n /**\n * Initial value of the listbox.\n * This is used when listbox is mounted, if no value is provided.\n * *Note* that listbox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ListboxValue;\n /** Set what value should have an empty option in listbox */\n emptyValue?: ListboxValue;\n /** Draws attention to the listbox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading?: boolean;\n /**\n * Value of the listbox representing the selected item.\n * It needs to be an existing value from the provided data\n */\n value?: ListboxValue;\n };\n\nexport const Listbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{ ...list.style, maxHeight: 'calc(12rem + 2px)' /* (6 * option height) + listbox border */ }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n\nexport const MultiListbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useMultiListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{\n ...list.style,\n maxHeight: 'calc(12rem + 2px + 2px)' /* (6 * option height) + listbox border + ALL_OPTIONS bottom border */,\n }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { ListboxProps } from './Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, getIndexFromValue, findByValue, getActiveDescendant, useFlattenedData, sanitizeItem } from './util';\nimport { ScrollableListProps } from './ScrollableList';\nimport { useTypeahead } from './useTypeahead';\n\ntype useListbox = {\n list: ScrollableListProps;\n input: Omit<React.HTMLAttributes<HTMLInputElement>, 'defaultValue'>;\n};\n\nexport const useListbox = (\n {\n data: externalData = [],\n defaultValue,\n disabled,\n emptyValue,\n id: nativeId,\n invalid,\n name,\n onChange,\n onFocus,\n onKeyDown,\n value = emptyValue,\n ...otherProps\n }: ListboxProps,\n ref: React.Ref<HTMLInputElement>\n): useListbox => {\n const data = useFlattenedData(emptyValue !== undefined ? [{ text: '', value: emptyValue }, ...externalData] : externalData);\n const id = React.useMemo(() => nativeId || uuid(), [nativeId]);\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const currentIndex = value !== undefined ? getIndexFromValue(data, value) : undefined;\n const { getNextIndex } = useTypeahead({ data, currentIndex });\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n setInputValueByRef(inputRef.current, option.value);\n }\n }\n };\n\n const handleListboxChange = (index: number): void => {\n setInputValueByIndex(index);\n };\n\n React.useEffect(() => {\n if (data.length && currentIndex === undefined) {\n if (defaultValue !== undefined) {\n const defaultValueIndex = getIndexFromValue(data, defaultValue);\n\n if (defaultValueIndex !== undefined) {\n setInputValueByIndex(defaultValueIndex);\n }\n } else {\n setInputValueByIndex(0);\n }\n }\n }, [data]);\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n const charKey = event.key;\n\n // event.key always returns the whole string (String.fromCharCode(event.keyCode) does not)\n // We need to filter out only alphabetical or numeric letters, that's why that condition has been changed\n if (charKey.length === 1 && /(\\w)/g.test(charKey)) {\n const nextIndex = getNextIndex(charKey);\n\n if (nextIndex > -1 && nextIndex !== currentIndex) {\n setInputValueByIndex(nextIndex);\n }\n return;\n }\n\n if (onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxFocus = (event: React.FocusEvent<HTMLElement>): void => {\n if (currentIndex === undefined && data.length) {\n setInputValueByIndex(0);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (onChange) {\n const item = findByValue(data, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const indexes = item?.path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n (event as any).detail.parents = indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(data.find(i => i.path === lastPath));\n });\n }\n\n onChange(event);\n }\n };\n\n const list: ScrollableListProps = {\n ...otherProps,\n 'aria-activedescendant': getActiveDescendant(data, currentIndex, id),\n data,\n disabled,\n id,\n invalid,\n onChange: handleListboxChange,\n onFocus: handleListboxFocus,\n onKeyDown: handleListboxKeyDown,\n scrollOnFocus: true,\n tabIndex: disabled ? -1 : otherProps.tabIndex ? otherProps.tabIndex : 0,\n value: currentIndex,\n };\n\n const input = {\n name,\n onChange: handleInputChange,\n ref: inputRef,\n tabIndex: -1,\n value: value ?? '',\n };\n\n return { list, input };\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { useLocalization } from '../Provider/Localization';\nimport { ListboxProps } from './Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, getIndexFromValue, getSelectedIndexesFromValue, findByValue, getActiveDescendant } from './util';\nimport { ScrollableListProps, ScrollableListItem, ScrollableListItemValue } from './ScrollableList';\nimport { useTypeahead } from './useTypeahead';\n\ntype useListbox = {\n list: ScrollableListProps;\n input: Omit<React.HTMLAttributes<HTMLInputElement>, 'defaultValue'>;\n};\n\nexport const useMultiListbox = (\n {\n data: externalData = [],\n defaultValue,\n disabled,\n emptyValue: _,\n id: nativeId,\n name,\n onClick,\n onChange,\n onFocus,\n onKeyDown,\n value,\n ...otherProps\n }: ListboxProps,\n ref: React.Ref<HTMLInputElement>\n): useListbox => {\n const { texts } = useLocalization();\n const id = React.useMemo(() => nativeId || uuid(), [nativeId]);\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const data = React.useMemo(() => {\n return [{ text: texts.listbox.allOption, value: '#ALL-OPTIONS#' }, ...externalData];\n }, [externalData]);\n const [currentIndex, setCurrentIndex] = React.useState(getIndexFromValue(data, value) || 0);\n const [allOptionsSelected, setAllOptionsSelected] = React.useState(false);\n const { getNextIndex } = useTypeahead({ data, currentIndex });\n const [selectedIndexes, setSelectedIndexes] = React.useState(getSelectedIndexesFromValue(data, value));\n\n React.useEffect(() => {\n if (defaultValue && !value) {\n setInputValueByRef(inputRef.current, defaultValue.toString());\n }\n }, []);\n\n React.useEffect(() => {\n const selectableItemsCount = data.filter(item => !item.disabled).length - 1;\n\n if (selectableItemsCount === selectedIndexes.length) {\n setAllOptionsSelected(true);\n } else {\n setAllOptionsSelected(false);\n }\n }, [selectedIndexes, data]);\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n let newInputValue: ScrollableListItemValue = '';\n const currentInputValue = inputRef.current?.value;\n const currentValuesArray = currentInputValue?.split(',') || [];\n const optionAlreadySelected = currentValuesArray.findIndex(val => val === String(option.value)) !== -1;\n\n // Handling the select_all option\n if (option.value === '#ALL-OPTIONS#') {\n if (!allOptionsSelected) {\n newInputValue = data\n .filter((option, index) => index !== 0 && !option.disabled)\n .map(option => option.value)\n .join(',');\n } else {\n newInputValue = '';\n }\n } else {\n // Handling rest options\n if (optionAlreadySelected) {\n newInputValue = currentValuesArray.filter(val => val !== String(option.value)).join(',');\n } else {\n newInputValue = currentInputValue ? `${currentInputValue},${option.value}` : option.value;\n }\n }\n\n setInputValueByRef(inputRef.current, newInputValue);\n }\n }\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>, index: number): void => {\n event.preventDefault();\n\n if (!data[index].disabled) {\n setCurrentIndex(index);\n setInputValueByIndex(index);\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>, index?: number): void => {\n const charKey = event.key;\n\n // event.key always returns the whole string (String.fromCharCode(event.keyCode) does not)\n // We need to filter out only alphabetical or numeric letters, that's why that condition has been changed\n if (charKey.length === 1 && /(\\w)/g.test(charKey)) {\n const nextIndex = getNextIndex(charKey);\n\n if (nextIndex > -1 && nextIndex !== currentIndex) {\n setCurrentIndex(nextIndex);\n }\n return;\n }\n\n switch (event.key) {\n case ' ': {\n event.preventDefault();\n setInputValueByIndex(index);\n break;\n }\n\n case 'Enter': {\n setInputValueByIndex(index);\n break;\n }\n\n default:\n }\n setCurrentIndex(index !== undefined ? index : 0);\n\n if (onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxFocus = (event: React.FocusEvent<HTMLElement>): void => {\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n setSelectedIndexes(getSelectedIndexesFromValue(data, event.target.value));\n\n if (onChange) {\n const detail: ScrollableListItem[] = [];\n const valuesArray = event.target.value.split(',');\n\n valuesArray.forEach(val => {\n const item = findByValue(data, val);\n if (item) {\n detail.push(item);\n }\n });\n (event as any).detail = detail;\n\n onChange(event);\n }\n };\n\n const list = {\n ...otherProps,\n 'aria-activedescendant': getActiveDescendant(data, currentIndex, id),\n 'aria-multiselectable': true,\n data,\n disabled,\n id,\n onChange: () => null,\n onClick: handleListboxClick,\n onFocus: handleListboxFocus,\n onKeyDown: handleListboxKeyDown,\n scrollOnFocus: false,\n tabIndex: disabled ? -1 : otherProps.tabIndex ? otherProps.tabIndex : 0,\n value: currentIndex,\n selectedIndexes,\n multiselect: true,\n allOptionsSelected,\n };\n\n const input = {\n name,\n onChange: handleInputChange,\n ref: inputRef,\n tabIndex: -1,\n value: value ?? '',\n };\n\n return { list, input };\n};\n","import * as React from 'react';\n\nexport const MenuContext = React.createContext<\n | {\n indented: boolean;\n registerIndentation: () => void;\n minWidth?: number;\n setMinWidth: (width: number) => void;\n close: () => void;\n }\n | undefined\n>(undefined);\n\nexport const useCurrentMenu = () => {\n return React.useContext(MenuContext);\n};\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { Align, Placement } from '../../../types';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuContentProps = Omit<DropdownMenuPrimitive.DropdownMenuContentProps, 'children' | 'side'> & {\n align?: Align;\n children: React.ReactNode;\n /** Set the position of the Menu relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\n\nexport const Content = React.forwardRef(function MenuContent(props: MenuContentProps, ref: React.Ref<HTMLDivElement>) {\n const internalRef = useMergedRef<any>(ref);\n const menu = useCurrentMenu();\n const { align = 'start', children, placement: side, ...otherProps } = props;\n const className = cn('border border-transparent rounded block outline-none p-1 yt-shadow wcag-white', props.className);\n\n return (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n {...otherProps}\n align={align}\n className={className}\n data-taco=\"menu\"\n side={side}\n sideOffset={3}\n style={{ minWidth: menu?.minWidth }}\n ref={internalRef}>\n {children}\n </DropdownMenuPrimitive.Content>\n </DropdownMenuPrimitive.Portal>\n );\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { IconName } from '../../Icon/Icon';\nimport { Icon as IconPrimitive } from '../../Icon/Icon';\nimport { useCurrentMenu } from '../Context';\nimport { DialogProps } from '../../Dialog/Dialog';\n\nexport const Icon = ({ name }) => (\n <span className=\"absolute left-0 ml-1\">\n <IconPrimitive className=\"-ml-px -mt-px !h-5 !w-5\" name={name} />\n </span>\n);\n\nexport const useItemStyling = ({ disabled, indented, className }) => {\n const menu = useCurrentMenu();\n\n React.useEffect(() => {\n if (indented && !menu?.indented) {\n menu?.registerIndentation();\n }\n }, [indented]);\n\n return cn(\n 'flex items-center justify-start h-8 pr-1.5 relative rounded w-full focus:outline-none group',\n {\n 'pl-7': menu?.indented,\n 'pl-1.5': !menu?.indented,\n 'cursor-pointer hover:bg-grey-100 text-black hover:text-black': !disabled,\n 'cursor-not-allowed hover:bg-white text-grey-300': disabled,\n },\n className\n );\n};\n\nexport const Shortcut = props => {\n return <span {...props} className=\"text-grey-700 ml-auto pl-3\" />;\n};\n\nexport type MenuItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n disabled?: boolean;\n icon?: IconName;\n onClick?: (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void;\n shortcut?: string;\n};\n\nexport const Item = React.forwardRef(function MenuItem(props: MenuItemProps, ref: React.Ref<HTMLDivElement>) {\n const { dialog, icon, onClick, shortcut, ...otherProps } = props;\n const menu = useCurrentMenu();\n const className = useItemStyling({\n disabled: props.disabled,\n indented: !!icon,\n className: props.className,\n });\n\n const disabled = props.disabled ?? props['aria-disabled'];\n\n let handleClick;\n\n // radix has a bug that does not disable clicks when disabled is set on items\n if (disabled) {\n handleClick = event => {\n event.preventDefault();\n event.stopPropagation();\n };\n }\n\n const handleSelect = event => {\n if (onClick) {\n onClick(event);\n }\n\n if (props['aria-haspopup'] || typeof dialog === 'function') {\n event.preventDefault();\n }\n };\n\n let button = (\n <DropdownMenuPrimitive.Item {...otherProps} className={className} onClick={handleClick} onSelect={handleSelect} ref={ref}>\n {icon && <Icon name={icon} />}\n {props.children}\n {shortcut && <Shortcut>{shortcut}</Shortcut>}\n </DropdownMenuPrimitive.Item>\n );\n\n if (typeof dialog === 'function') {\n button = dialog({ trigger: button, onClose: menu?.close });\n }\n\n return button;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { IconName } from '../../Icon/Icon';\nimport { Icon, useItemStyling } from './Item';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuLinkItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n disabled?: boolean;\n icon?: IconName;\n href: string;\n onClick?: (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void;\n};\n\nexport const Link = React.forwardRef(function MenuLink(props: MenuLinkItemProps, ref: React.Ref<HTMLDivElement>) {\n const { href, icon, onClick, ...otherProps } = props;\n const menu = useCurrentMenu();\n\n const className = useItemStyling({\n disabled: props.disabled,\n indented: !!icon,\n className: props.className,\n });\n\n const handleClick: React.MouseEventHandler<HTMLDivElement> = event => {\n onClick?.(event);\n menu?.close();\n };\n\n return (\n <DropdownMenuPrimitive.Item {...otherProps} asChild className={className} ref={ref} onClick={handleClick}>\n <a href={href} target=\"_blank\">\n {icon && <Icon name={icon} />}\n {props.children}\n </a>\n </DropdownMenuPrimitive.Item>\n );\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuTriggerProps = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children'> & {\n children: React.ReactElement;\n};\n\nexport const Trigger = React.forwardRef(function MenuTrigger(props: MenuTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const menu = useCurrentMenu();\n const internalRef = useMergedRef<HTMLButtonElement>(ref);\n\n React.useEffect(() => {\n if (internalRef.current) {\n menu?.setMinWidth(internalRef.current.getBoundingClientRect().width);\n }\n }, [internalRef]);\n\n return <DropdownMenuPrimitive.Trigger {...props} asChild ref={internalRef} />;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { Icon } from '../../Icon/Icon';\nimport { useItemStyling } from './Item';\n\nexport type MenuCheckboxItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n /* Whether the checkbox item is disabled */\n disabled?: boolean;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean | 'indeterminate') => void;\n};\n\nexport const Checkbox = React.forwardRef<HTMLDivElement, MenuCheckboxItemProps>(function MenuCheckboxItem(props, ref) {\n const { checked, children, onChange, ...otherProps } = props;\n const className = useItemStyling({\n disabled: props.disabled,\n indented: true,\n className: props.className,\n });\n\n return (\n <DropdownMenuPrimitive.CheckboxItem\n {...otherProps}\n checked={checked}\n className={className}\n onCheckedChange={onChange}\n ref={ref}>\n <DropdownMenuPrimitive.ItemIndicator className=\"absolute left-0 ml-1.5\">\n <Icon name=\"tick\" className=\"-ml-px !h-4 !w-4\" />\n </DropdownMenuPrimitive.ItemIndicator>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group';\nimport { Orientation } from '../../types';\n\nexport type RadioGroupItemValue = string | number | boolean | null;\n\nexport const getRadioGroupItemValueAsString = (value: RadioGroupItemValue): string => String(value ?? '');\n\nexport const findByValue = (values: RadioGroupItemValue[], valueAsString: string): RadioGroupItemValue =>\n values.find(value => getRadioGroupItemValueAsString(value) === valueAsString) as RadioGroupItemValue;\n\nconst RadioGroupContext = React.createContext({ disabled: false, invalid: false });\n\nexport type RadioGroupItemProps<T = HTMLButtonElement> = Omit<\n React.ButtonHTMLAttributes<T>,\n 'children' | 'onSelect' | 'value'\n> & {\n /** Label for the radio group item */\n children: React.ReactNode;\n /* Whether the radio group item is disabled */\n disabled?: boolean;\n /** Value of the radio button */\n value: RadioGroupItemValue;\n};\n\nconst RadioGroupItem = React.forwardRef(function RadioGroupItem(props: RadioGroupItemProps, ref: React.Ref<HTMLButtonElement>) {\n const context = React.useContext(RadioGroupContext);\n const { children, value, ...otherProps } = props;\n\n const isDisabled = context.disabled || props.disabled;\n\n const className = cn(\n 'flex flex-shrink-0 self-start items-center justify-center h-4 w-4 mt-[0.2rem] rounded-full bg-white border-2',\n {\n 'border-grey-300 hover:border-4 focus:yt-focus aria-checked:bg-blue-500 aria-checked:border-blue-500 hover:aria-checked:border-blue-300':\n !isDisabled && !context.invalid,\n 'border-grey-200 cursor-not-allowed aria-checked:bg-blue-300 aria-checked:border-blue-300 ': isDisabled,\n 'border-red-500 hover:border-4 text-red-500 focus:border-red-500 focus:yt-focus-red aria-checked:bg-red-500 aria-checked:border-red':\n context.invalid && !isDisabled,\n }\n );\n const labelClassName = cn(\n 'flex items-center gap-2',\n {\n 'cursor-pointer': !isDisabled,\n 'cursor-not-allowed text-grey-300': isDisabled,\n },\n props.className\n );\n\n return (\n <label className={labelClassName}>\n <RadioGroupPrimitive.Item\n {...otherProps}\n className={className}\n disabled={isDisabled}\n ref={ref}\n value={getRadioGroupItemValueAsString(value)}>\n <RadioGroupPrimitive.Indicator className=\"h-2 w-2 rounded-full bg-white\" />\n </RadioGroupPrimitive.Item>\n {children}\n </label>\n );\n});\n\ntype ReactGroupBaseChild = React.ReactElement<RadioGroupItemProps> | boolean | null;\n\ntype RadioGroupBaseProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n children: ReactGroupBaseChild[];\n /* Whether the radio group is disabled */\n disabled?: boolean;\n /* Whether the radio group is in an invalid state */\n invalid?: boolean;\n /** The name of the radio group, used when submitting an HTML form */\n name?: string;\n /**\n * Orientation of the radio group\n * @defaultValue vertical\n */\n orientation?: Orientation;\n /* Whether the radio group requires user input */\n required?: boolean;\n};\n\ninterface UncontrolledRadioGroupProps extends RadioGroupBaseProps {\n /* The default value (uncontrolled) */\n defaultValue?: RadioGroupItemValue;\n onChange?: never;\n value?: never;\n}\n\ninterface ControlledRadioGroupProps extends RadioGroupBaseProps {\n defaultValue?: never;\n /** Handler called when the value changes */\n onChange: (value: RadioGroupItemValue) => void;\n /** The current value (controlled) */\n value?: RadioGroupItemValue;\n}\n\nexport type RadioGroupProps = UncontrolledRadioGroupProps | ControlledRadioGroupProps;\n\nexport type ForwardedRadioGroupWithStatics = React.ForwardRefExoticComponent<\n RadioGroupProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Item component rendered in a `RadioGroup` component */\n Item: React.ForwardRefExoticComponent<RadioGroupItemProps>;\n};\n\nexport const useRadioGroup = (props: RadioGroupProps) => {\n const { children, defaultValue, disabled, invalid, onChange, orientation = 'vertical', value, ...otherProps } = props;\n\n const values = React.useMemo<RadioGroupItemValue[]>(() => {\n const radioGroupItemValues: RadioGroupItemValue[] = [];\n\n React.Children.forEach(children, child => {\n if (React.isValidElement(child)) {\n radioGroupItemValues.push(child.props.value);\n }\n });\n\n return radioGroupItemValues;\n }, [children]);\n\n const context = React.useMemo(() => ({ disabled: disabled ?? false, invalid: invalid ?? false }), [disabled, invalid]);\n\n let valueProps;\n\n if (onChange !== undefined) {\n const handleChange = (value: string): void => onChange(findByValue(values, value));\n\n valueProps = {\n onValueChange: handleChange,\n value: value !== undefined ? getRadioGroupItemValueAsString(value) : undefined,\n };\n } else {\n valueProps = {\n defaultValue: defaultValue !== undefined ? getRadioGroupItemValueAsString(defaultValue) : undefined,\n };\n }\n\n return {\n context,\n props: {\n ...otherProps,\n ...valueProps,\n children,\n disabled,\n orientation,\n },\n };\n};\n\nexport const RadioGroup = React.forwardRef(function RadioGroup(props: RadioGroupProps, ref: React.Ref<HTMLDivElement>) {\n const { context, props: otherProps } = useRadioGroup(props);\n const className = cn(\n 'flex items-start gap-y-2',\n {\n 'flex-wrap gap-x-4 ': otherProps.orientation === 'horizontal',\n 'flex-col': otherProps.orientation === 'vertical',\n },\n otherProps.className\n );\n\n return (\n <RadioGroupContext.Provider value={context}>\n <RadioGroupPrimitive.Root {...otherProps} className={className} data-taco=\"radio-group\" ref={ref} />\n </RadioGroupContext.Provider>\n );\n}) as ForwardedRadioGroupWithStatics;\nRadioGroup.Item = RadioGroupItem;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { getRadioGroupItemValueAsString, RadioGroupItemProps, RadioGroupProps, useRadioGroup } from '../../RadioGroup/RadioGroup';\nimport { useItemStyling } from './Item';\n\nexport type MenuRadioGroupItemProps = RadioGroupItemProps<HTMLDivElement>;\n\nexport const RadioItem = (props: MenuRadioGroupItemProps) => {\n const context = React.useContext(MenuRadioGroupContext);\n const { children, value, ...otherProps } = props;\n const disabled = context.disabled || props.disabled;\n const className = useItemStyling({\n disabled: disabled,\n indented: true,\n className: props.className,\n });\n\n return (\n <DropdownMenuPrimitive.RadioItem\n {...otherProps}\n className={className}\n disabled={disabled}\n value={getRadioGroupItemValueAsString(value)}>\n <DropdownMenuPrimitive.ItemIndicator className=\"absolute left-0 ml-1.5\">\n <span className=\"ml-1 flex h-1.5 w-1.5 rounded-full bg-current \" />\n </DropdownMenuPrimitive.ItemIndicator>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n );\n};\n\nconst MenuRadioGroupContext = React.createContext({ disabled: false });\n\nexport type MenuRadioGroupProps = RadioGroupProps;\n\nexport type ForwardedMenuRadioGroupWithStatics = React.ForwardRefExoticComponent<\n MenuRadioGroupProps & React.RefAttributes<HTMLElement>\n> & {\n Item: React.FunctionComponent<MenuRadioGroupItemProps>;\n};\n\nexport const RadioGroup = React.forwardRef<HTMLDivElement, MenuRadioGroupProps>(function MenuRadioItem(props, ref) {\n const { context, props: otherProps } = useRadioGroup(props);\n const className = cn('flex flex-col', props.className);\n\n return (\n <MenuRadioGroupContext.Provider value={context}>\n <DropdownMenuPrimitive.RadioGroup {...otherProps} className={className} ref={ref} />\n </MenuRadioGroupContext.Provider>\n );\n}) as ForwardedMenuRadioGroupWithStatics;\nRadioGroup.Item = RadioItem;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuHeaderProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Header = React.forwardRef<HTMLDivElement, MenuHeaderProps>(function MenuHeader(props, ref) {\n const menu = useCurrentMenu();\n const className = cn(\n 'flex items-center justify-start h-7 pr-1.5 text-xs text-grey-700',\n {\n 'pl-7': menu?.indented,\n 'pl-1.5': !menu?.indented,\n },\n props.className\n );\n\n return <DropdownMenuPrimitive.Label {...props} className={className} ref={ref} />;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport { MenuContext } from './Context';\nimport { Content, MenuContentProps } from './components/Content';\nimport { Item, MenuItemProps } from './components/Item';\nimport { Link, MenuLinkItemProps } from './components/Link';\nimport { Trigger, MenuTriggerProps } from './components/Trigger';\nimport { Checkbox, MenuCheckboxItemProps } from './components/Checkbox';\nimport { ForwardedMenuRadioGroupWithStatics, RadioGroup } from './components/RadioGroup';\nimport { Separator } from './components/Separator';\nimport { Header, MenuHeaderProps } from './components/Header';\n\nexport type MenuProps = {\n children: React.ReactNode;\n /** Set whether the menu is open by default or not */\n defaultOpen?: boolean;\n /** Called when the menu opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the menu from outside the component */\n open?: boolean;\n /** A trigger to be used for the menu, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\nexport type ForwardedMenuWithStatics = React.ForwardRefExoticComponent<MenuProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<MenuTriggerProps>;\n Content: React.ForwardRefExoticComponent<MenuContentProps>;\n Item: React.ForwardRefExoticComponent<MenuItemProps>;\n Link: React.ForwardRefExoticComponent<MenuLinkItemProps>;\n Checkbox: React.ForwardRefExoticComponent<MenuCheckboxItemProps>;\n Separator: React.FunctionComponent;\n Header: React.ForwardRefExoticComponent<MenuHeaderProps>;\n RadioGroup: ForwardedMenuRadioGroupWithStatics;\n};\n\nexport const Menu = React.forwardRef<HTMLButtonElement, MenuProps>(function Menu(externalProps, ref) {\n const { children, defaultOpen: defaultProp, onChange, open: prop, trigger, ...props } = externalProps;\n const [indented, setIndented] = React.useState(false);\n const [minWidth, setMinWidth] = React.useState<number | undefined>(undefined);\n\n const [open, setOpen] = useControllableState<boolean>({\n // uncontrolled\n defaultProp,\n // controlled\n onChange,\n prop,\n });\n\n const context = React.useMemo(\n () => ({\n indented,\n registerIndentation: () => setIndented(true),\n minWidth,\n setMinWidth: (width: number) => setMinWidth(width),\n close: () => setOpen(false),\n }),\n [indented, minWidth]\n );\n\n return (\n <MenuContext.Provider value={context}>\n <DropdownMenuPrimitive.Root {...props} modal={false} open={open} onOpenChange={setOpen}>\n {trigger && <Trigger ref={ref}>{trigger}</Trigger>}\n {children}\n </DropdownMenuPrimitive.Root>\n </MenuContext.Provider>\n );\n}) as ForwardedMenuWithStatics;\nMenu.Trigger = Trigger;\nMenu.Content = Content;\nMenu.Item = Item;\nMenu.Link = Link;\nMenu.Checkbox = Checkbox;\nMenu.Separator = Separator;\nMenu.Header = Header;\nMenu.RadioGroup = RadioGroup;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\n\nexport const Separator = () => {\n return <DropdownMenuPrimitive.Separator className=\"bg-grey-300 my-1 h-px\" />;\n};\n","import React from 'react';\nimport cn from 'classnames';\n\nexport type TreeviewItemProps = React.LinkHTMLAttributes<HTMLAnchorElement>;\n\nconst TreeviewItem = React.forwardRef(function TreeviewItem(props: TreeviewItemProps, ref: React.Ref<HTMLAnchorElement>) {\n return <a {...props} ref={ref} />;\n});\n\nexport type TreeviewGroupProps = Omit<React.LinkHTMLAttributes<HTMLDivElement>, 'className' | 'onClick' | 'title'> & {\n /** Add a classname to the treeview */\n className?: string | ((expanded: boolean) => string);\n /**\n * Set wheter the region is expanded, showing the children, or collapsed.\n * Default value is `false`\n */\n expanded?: boolean;\n /** Region is expanded at mount and can't be collapsed */\n fixed?: boolean;\n /** Handler called when user clicks the title of the group */\n onClick?: (event: React.MouseEvent<HTMLDivElement>, expanded: boolean) => void;\n /** Text displayed in the group's header */\n title: React.ReactNode | ((expanded: boolean) => React.ReactNode);\n};\n\nconst TreeviewGroup = React.forwardRef(function TreeviewGroup(props: TreeviewGroupProps, ref: React.Ref<HTMLDivElement>) {\n const {\n children,\n className: externalClassName,\n expanded: initialExpanded = false,\n title,\n fixed,\n onClick,\n ...otherProps\n } = props;\n const [expanded, setExpanded] = React.useState(fixed || initialExpanded);\n\n React.useEffect(() => {\n if (!fixed) {\n setExpanded(fixed || initialExpanded);\n }\n }, [fixed, initialExpanded]);\n\n const listClassName = cn('flex-col mb-0', {\n flex: expanded,\n hidden: !expanded,\n });\n\n const itemProps = {\n ...otherProps,\n 'aria-expanded': expanded,\n role: 'treeitem',\n tabIndex: -1,\n };\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>): void => {\n const nextState = !expanded;\n\n if (!fixed) {\n setExpanded(nextState);\n }\n\n if (onClick) {\n onClick(event, nextState);\n }\n };\n\n const className = typeof externalClassName === 'function' ? externalClassName(expanded) : externalClassName;\n\n return (\n <div {...itemProps} className={className} ref={ref}>\n <div onClick={handleClick}>{typeof title === 'function' ? title(expanded) : title}</div>\n <ul role=\"group\" className={listClassName}>\n {React.Children.toArray(children)\n .filter(item => !!item)\n .map((item, i) => (\n <li key={i} role=\"none\">\n {React.cloneElement(item as React.ReactElement<any>, { role: 'treeitem' })}\n </li>\n ))}\n </ul>\n </div>\n );\n});\n\nexport type TreeviewProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type ForwardedTreeviewWithStatics = React.ForwardRefExoticComponent<\n TreeviewProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Navigable link */\n Item: React.ForwardRefExoticComponent<TreeviewItemProps & React.RefAttributes<HTMLAnchorElement>>;\n /** Container for a set of related links, usually expandable */\n Group: React.ForwardRefExoticComponent<TreeviewGroupProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Treeview = React.forwardRef(function Treeview(props: TreeviewProps, ref: React.Ref<HTMLDivElement>) {\n return <div {...props} ref={ref} role=\"tree\" />;\n}) as ForwardedTreeviewWithStatics;\n\nTreeview.Group = TreeviewGroup;\nTreeview.Item = TreeviewItem;\n","import React from 'react';\n\nexport type useDropTarget = [\n boolean,\n (\n | undefined\n | {\n onDragEnter: React.DragEventHandler;\n onDragLeave: React.DragEventHandler;\n onDragOver: React.DragEventHandler;\n onDrop: React.DragEventHandler;\n }\n )\n];\n\nexport const useDropTarget = (onDrop: React.DragEventHandler | undefined): useDropTarget => {\n const [isDraggedOver, setDraggedOver] = React.useState(false);\n\n const handleDragEnter = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n setDraggedOver(true);\n }, []);\n\n const handleDragLeave = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n\n if (event.target === event.currentTarget) {\n setDraggedOver(false);\n }\n }, []);\n\n const handleDragOver = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n }, []);\n\n const handleDrop = React.useCallback(\n (event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n event.persist();\n\n setDraggedOver(false);\n\n if (onDrop) {\n onDrop(event);\n }\n },\n [onDrop]\n );\n\n const props = onDrop\n ? {\n onDragEnter: handleDragEnter,\n onDragLeave: handleDragLeave,\n onDragOver: handleDragOver,\n onDrop: handleDrop,\n }\n : undefined;\n\n return [isDraggedOver, props];\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { TreeviewProps, Treeview, TreeviewGroupProps, TreeviewItemProps } from '../Treeview/Treeview';\nimport { Icon } from '../Icon/Icon';\nimport { useDropTarget } from '../../utils/hooks/useDropTarget';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport './Navigation.css';\n\n// Item\nexport type NavigationItemProps = Omit<TreeviewItemProps, 'prefix'> & {\n /** Change the style to indicate the link is selected */\n active?: boolean;\n /** Handler to be used when dropping a dragged element over the navigation link */\n onDrop?: React.DragEventHandler;\n /**\n * Small amount of information placed next to the text of the link.\n * This can be any valid react element, for e.g. a `span`.\n * Should be used to indicate a relevant information of the link,\n * for e.g. the number of unread notifications\n */\n postfix?: React.ReactNode;\n /**\n * Small amount of information placed before the text of the link.\n * This can be any valid react element, for e.g. a `span`.\n * Should be used to indicate a feedback for user,\n * for e.g. display some sort of visual informational state or a relevant icon.\n */\n prefix?: React.ReactNode;\n /** Target of the link */\n target?: string;\n};\n\nconst Item = React.forwardRef(function Item(props: NavigationItemProps, ref: React.Ref<HTMLAnchorElement>) {\n const { active, children, onDrop, postfix, prefix, role, ...otherProps } = props;\n const proxyRef = useMergedRef<HTMLAnchorElement>(ref);\n const [isDraggedOver, dropTargetProps] = useDropTarget(onDrop);\n const isTreeitem = role === 'treeitem';\n const className = cn(\n 'yt-navigation__item cursor-pointer',\n {\n 'w-full mb-px py-1 px-3 flex items-center hover:bg-grey-300': isTreeitem,\n 'bg-white w-full h-10 px-3 flex-shrink-0 flex items-center justify-between cursor-pointer': !isTreeitem,\n 'yt-navigation__item--active': active && !isDraggedOver,\n 'bg-grey-300': isTreeitem && active && !isDraggedOver,\n 'yt-navigation__item--dropping bg-blue-500': isDraggedOver,\n },\n props.className\n );\n\n const handleClick = (event: React.MouseEvent<HTMLSpanElement>): void => {\n if (event.target instanceof HTMLAnchorElement || event.target instanceof HTMLButtonElement) {\n return;\n }\n\n if (proxyRef.current) {\n proxyRef.current.click();\n }\n };\n\n return (\n <span {...dropTargetProps} className={className} onClick={handleClick} role={role}>\n {prefix && <span className=\"yt-navigation__item__prefix flex items-center\">{prefix}</span>}\n <a {...otherProps} className=\"block flex-grow truncate\" ref={proxyRef}>\n {children}\n </a>\n {postfix && <span className=\"yt-navigation__item__postfix ml-1\">{postfix}</span>}\n </span>\n );\n});\n\n// Panel\nexport type NavigationPanelProps = React.HTMLAttributes<HTMLDivElement>;\n\nconst Panel = React.forwardRef(function Panel(props: NavigationPanelProps, ref: React.Ref<HTMLDivElement>) {\n return <div {...props} className={cn('w-full bg-white p-3', props.className)} ref={ref} />;\n});\n\n// Group\nexport type NavigationMenuGroupProps = TreeviewGroupProps;\n\nconst MenuGroup = React.forwardRef(function MenuGroup(props: NavigationMenuGroupProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn(\n 'flex-shrink-0 space-y-1 outline-none',\n {\n 'bg-white pb-2': props.fixed,\n },\n typeof props.className === 'function' ? props.className(false) : props.className\n );\n const title = (expanded: boolean): JSX.Element => {\n const className = cn('bg-white h-10 pl-3 pr-1 flex items-center justify-between w-full', {\n 'mb-1': expanded,\n 'cursor-pointer hover:text-blue-500': !props.fixed,\n });\n\n return (\n <span className={className}>\n {typeof props.title === 'function' ? props.title(expanded) : props.title}\n {!props.fixed && <Icon name={expanded ? 'chevron-up' : 'chevron-down'} />}\n </span>\n );\n };\n\n return <Treeview.Group {...props} className={className} title={title} ref={ref} />;\n});\n\n// Menu\nexport type NavigationMenuProps = React.PropsWithChildren<TreeviewProps>;\n\nexport type ForwardedNavigationMenuWithStatics = React.ForwardRefExoticComponent<\n NavigationMenuProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Expandable region reprezenting a group of related links */\n Group: React.ForwardRefExoticComponent<NavigationMenuGroupProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nconst Menu = React.forwardRef(function Menu(props: NavigationMenuProps, ref: React.Ref<HTMLDivElement>) {\n const scrollableAreas = React.useMemo(() => {\n const scrollableAreas: React.ReactNode[] = [];\n\n const children = React.Children.toArray(props.children).filter(\n child => !!child\n ) as React.ReactElement<NavigationMenuGroupProps>[];\n\n children.forEach(child => {\n if (child.props.fixed) {\n scrollableAreas.push(child);\n } else {\n const x = scrollableAreas[scrollableAreas.length - 1];\n if (Array.isArray(x)) {\n x.push(child);\n } else {\n scrollableAreas.push([child]);\n }\n }\n });\n\n return scrollableAreas;\n }, [props.children]);\n\n return (\n <Treeview\n {...props}\n className={cn('divide-grey-100 flex flex-grow flex-col divide-y-2 overflow-y-auto', props.className)}\n ref={ref}>\n {scrollableAreas.map((area, i) =>\n Array.isArray(area) ? (\n <div\n className=\"divide-grey-100 flex h-0 flex-auto flex-shrink-0 flex-grow flex-col divide-y-2 overflow-y-auto\"\n key={i}>\n {area}\n </div>\n ) : (\n area\n )\n )}\n </Treeview>\n );\n}) as ForwardedNavigationMenuWithStatics;\n\nMenu.Group = MenuGroup;\n\n// Navigation\nexport type NavigationProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type ForwardedNavigationWithStatics = React.ForwardRefExoticComponent<\n NavigationProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Navigation link */\n Item: React.ForwardRefExoticComponent<NavigationItemProps & React.RefAttributes<HTMLAnchorElement>>;\n /**\n * Container for the expandable groups that hold navigation links.\n * Should be used as a direct child of Navigation component, e.g. `Navigation.Menu`.\n * Should have the menu groups as a direct child, e.g. `Navigation.Menu.Group`\n */\n Menu: ForwardedNavigationMenuWithStatics;\n /**\n * Isolated container within the Navigation.\n * This can be used to create a region in the Navigation that is usually not scrollable, nor expandable,\n * containing useful information for user and quick actions\n */\n Panel: React.ForwardRefExoticComponent<NavigationPanelProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Navigation = React.forwardRef(function Navigation(props: NavigationProps, ref: React.Ref<HTMLDivElement>) {\n const { children, ...otherProps } = props;\n const className = cn('h-full flex flex-col bg-grey-100 divide-y-2 divide-grey-100', props.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"navigation\" ref={ref}>\n {children}\n </div>\n );\n}) as ForwardedNavigationWithStatics;\n\nNavigation.Menu = Menu;\nNavigation.Item = Item;\nNavigation.Panel = Panel;\n","import * as React from 'react';\nimport { Button } from '../Button/Button';\nimport { useLocalization } from '../Provider/Localization';\n\ntype PageNumberProps = {\n currentPageIndex: number;\n onClick: (pageIndex: number) => void;\n pageCount: number;\n};\n\nconst createPageRange = (pageCount: number, pageNumber: number): number[] => {\n let lowerLimit = Math.min(pageNumber, pageCount);\n let upperLimit = Math.min(pageNumber, pageCount);\n\n for (let b = 1; b < 5 && b < pageCount; ) {\n if (lowerLimit > 1) {\n lowerLimit--;\n b++;\n }\n if (b < 5 && upperLimit < pageCount) {\n upperLimit++;\n b++;\n }\n }\n\n const range: number[] = [];\n\n for (let i = lowerLimit; i <= upperLimit; i++) {\n range.push(i);\n }\n\n return range;\n};\n\nexport const PageNumbers = ({ currentPageIndex = 0, onClick: handleClick, pageCount }: PageNumberProps): JSX.Element => {\n const range = createPageRange(pageCount, currentPageIndex + 1);\n const { texts } = useLocalization();\n\n return (\n <>\n {range.map((pageNumber: number) => (\n <Button\n appearance={pageNumber === currentPageIndex + 1 ? 'primary' : 'default'}\n aria-current={pageNumber === currentPageIndex + 1 ? 'page' : undefined}\n key={pageNumber}\n onClick={() => handleClick(pageNumber - 1)}\n aria-label={texts.pagination.actions.pageX.replace('[X]', String(pageNumber))}\n tooltip={texts.pagination.actions.pageX.replace('[X]', String(pageNumber))}>\n {pageNumber}\n </Button>\n ))}\n </>\n );\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Icon } from '../Icon/Icon';\nimport { Listbox, MultiListbox, ListboxProps } from '../Listbox/Listbox';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { useSelect } from './useSelect';\nimport { Combobox, ComboboxProps } from '../Combobox/Combobox';\nimport { Badge } from '../Badge/Badge';\nimport { getInputClasses } from '../Input/util';\n\nexport type SelectTexts = {\n /**\n * The text displayed when all options are selected when multiselect mode in on.\n */\n allOptionsSelected: string;\n};\n\nexport type BaseSelectProps = Omit<ListboxProps, 'dialog'> &\n Omit<ComboboxProps, 'inline'> & {\n /**\n * Allows to select multiple values.\n * All the selected values will be combined in a comma-seperated string as the value of the input.\n */\n multiselect?: boolean;\n };\n\nexport type SelectProps = BaseSelectProps & {\n /**\n * Creates an editable select.\n * Setting this will render a inline Combobox which will display the provided data on click/focus,\n * even if there is no value in the input.\n * After user starts typing, matching data will be displayed.\n */\n editable?: boolean;\n};\n\nconst BaseSelect = React.forwardRef(function BaseSelect(props: BaseSelectProps, ref: React.Ref<HTMLInputElement>) {\n const { autoFocus, className: externalClassName, highlighted, style, ...otherProps } = props;\n const { button, listbox, popover, input, text, more = 0 } = useSelect(otherProps, ref);\n const internalRef = React.useRef<HTMLButtonElement>(null);\n const selectDimensions = useBoundingClientRectListener(internalRef);\n const className = cn('inline-flex relative w-full', { 'yt-select--readonly': props.readOnly }, externalClassName);\n const inputClassname = cn(getInputClasses(props), 'h-8 text-left !pr-0', {\n 'border-blue-500': popover.open,\n });\n\n React.useEffect(() => {\n if (autoFocus && internalRef.current) {\n internalRef.current.focus();\n }\n }, []);\n\n const renderMultiSelection = (): React.ReactNode => {\n return (\n <>\n <span className=\"flex-grow truncate text-left\">{text}</span>\n {more > 0 && <Badge className=\"ml-2\">{`+${more}`}</Badge>}\n </>\n );\n };\n\n const commonListboxProps: ListboxProps = {\n ...listbox,\n className: 'w-auto',\n invalid: undefined,\n style: { minWidth: selectDimensions?.width },\n tabIndex: popover.open ? 0 : -1,\n };\n\n return (\n <span className={className} data-taco=\"select\" style={style}>\n <PopoverPrimitive.Root {...popover}>\n <PopoverPrimitive.Trigger {...button} className={inputClassname} ref={internalRef}>\n {props.multiselect ? renderMultiSelection() : <span className=\"flex-grow truncate text-left\">{text}</span>}\n <span className=\"flex h-8 w-8 items-center justify-center\">\n <Icon className=\"pointer-events-none\" name={popover.open ? 'chevron-up' : 'chevron-down'} />\n </span>\n </PopoverPrimitive.Trigger>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content align=\"start\" sideOffset={4}>\n {props.multiselect ? <MultiListbox {...commonListboxProps} /> : <Listbox {...commonListboxProps} />}\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n <input {...input} className=\"hidden\" type=\"text\" />\n </PopoverPrimitive.Root>\n </span>\n );\n});\n\nexport const Select = React.forwardRef(function Select(props: SelectProps, ref: React.Ref<HTMLInputElement>) {\n const { editable, ...otherProps } = props;\n\n if (editable) {\n return <Combobox {...otherProps} dialog={undefined} inline ref={ref} />;\n }\n\n return <BaseSelect {...otherProps} ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { v4 as uuid } from 'uuid';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { useLocalization } from '../Provider/Localization';\nimport { SelectProps } from './Select';\nimport { ListboxProps } from '../Listbox/Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, findByValue, useFlattenedData, sanitizeItem } from '../Listbox/util';\nimport { ScrollableListItemValue } from '../Listbox/ScrollableList';\nimport { createCustomEvent } from '../../utils/input';\n\ntype InternalButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement>;\ntype InternalListboxProps = ListboxProps & { ref: React.ForwardedRef<HTMLInputElement> };\ntype InternalInputProps = React.InputHTMLAttributes<HTMLInputElement> & { ref: React.ForwardedRef<HTMLInputElement> };\n\ntype useSelect = React.HtmlHTMLAttributes<HTMLDivElement> & {\n button: InternalButtonProps;\n listbox: InternalListboxProps;\n input: InternalInputProps;\n popover: Pick<PopoverPrimitive.PopoverProps, 'onOpenChange' | 'open'>;\n text: string | JSX.Element;\n more?: number;\n};\n\nexport const useSelect = (\n {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data = [],\n defaultValue,\n disabled,\n emptyValue,\n id: nativeId,\n multiselect,\n onBlur,\n onClick,\n onChange,\n readOnly,\n value,\n ...otherProps\n }: SelectProps,\n ref: React.Ref<HTMLInputElement>\n): useSelect => {\n const { texts } = useLocalization();\n const flattenedData = useFlattenedData(data);\n const listboxInputRef = useMergedRef<HTMLInputElement>(ref);\n const [open, setOpen] = React.useState(false);\n const id = React.useMemo(() => nativeId || `select_${uuid()}`, [nativeId]);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const buttonId = `${id}-button`;\n // support 'escape' resetting to the value that was set when the listbox opened\n const [lastValue, setLastValue] = React.useState<ScrollableListItemValue | undefined>(value);\n\n React.useEffect(() => {\n setLastValue(value);\n }, [open]);\n\n React.useEffect(() => {\n if (value === undefined) {\n if (defaultValue !== undefined && findByValue(flattenedData, defaultValue)) {\n setInputValueByRef(inputRef.current, defaultValue);\n } else {\n if (emptyValue !== undefined) {\n setInputValueByRef(inputRef.current, emptyValue);\n } else if (data.length > 0) {\n setInputValueByRef(inputRef.current, data[0].value);\n }\n }\n } else {\n if (!multiselect && !findByValue(flattenedData, value)) {\n if (emptyValue !== undefined) {\n setInputValueByRef(inputRef.current, emptyValue);\n } else if (data.length > 0) {\n setInputValueByRef(inputRef.current, data[0].value);\n }\n }\n }\n }, []);\n\n // event handlers\n const handleButtonKeyDown = (event: React.KeyboardEvent<HTMLButtonElement>): void => {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {\n event.preventDefault();\n setOpen(true);\n }\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n switch (event.key) {\n case 'Escape': {\n event.preventDefault();\n if (lastValue !== undefined) {\n setInputValueByRef(listboxInputRef.current, lastValue);\n }\n\n setOpen(false);\n break;\n }\n\n case 'Tab':\n case 'Enter': {\n if (event.key !== 'Tab') {\n event.preventDefault();\n }\n setOpen(false);\n break;\n }\n\n default:\n }\n\n if (otherProps.onKeyDown) {\n otherProps.onKeyDown(event);\n }\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>): void => {\n event.preventDefault();\n if (!multiselect) {\n setOpen(false);\n if (onBlur) {\n onBlur(createCustomEvent('blur'));\n }\n }\n };\n\n let text: string | JSX.Element = '';\n let more = 0;\n\n if (value !== undefined) {\n if (multiselect) {\n const selectedValues = value?.toString().split(',') || [];\n\n if (selectedValues.length === flattenedData.filter(item => !item.disabled).length) {\n text = texts.select.allOptionsSelected;\n } else {\n text = findByValue(flattenedData, selectedValues[0])?.text ?? '';\n more = selectedValues.length > 1 ? selectedValues.length - 1 : 0;\n }\n } else {\n const item = findByValue(flattenedData, value);\n\n if (item) {\n text = item.icon ? (\n <>\n {React.cloneElement(item.icon, {\n className: cn(item.icon.props.className, 'mr-1 -mt-px'),\n })}\n {item.text}\n </>\n ) : (\n item.text\n );\n }\n }\n }\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (onChange) {\n const item = findByValue(flattenedData, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const indexes = item?.path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n (event as any).detail.parents = indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(flattenedData.find(i => i.path === lastPath));\n });\n }\n\n onChange(event);\n }\n };\n\n const button: InternalButtonProps = {\n 'aria-haspopup': 'listbox' as const,\n 'aria-label': ariaLabel ? `${ariaLabel} ${text}` : undefined,\n 'aria-labelledby': ariaLabelledBy ? `${ariaLabelledBy} ${buttonId}` : undefined,\n disabled: disabled || readOnly,\n id: buttonId,\n onKeyDown: !disabled && !readOnly ? handleButtonKeyDown : undefined,\n type: 'button',\n };\n\n const listbox: InternalListboxProps = {\n ...otherProps,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data,\n disabled,\n emptyValue,\n onBlur,\n onClick: handleListboxClick,\n onChange: event => {\n setInputValueByRef(inputRef.current, event.target.value);\n },\n onKeyDown: handleListboxKeyDown,\n ref: listboxInputRef,\n value,\n };\n\n const input: InternalInputProps = {\n onChange: handleInputChange,\n ref: inputRef,\n value: String(value ?? ''),\n };\n\n return {\n button,\n listbox,\n input,\n popover: {\n open,\n onOpenChange: open => {\n if (!open && onBlur) {\n onBlur(createCustomEvent('blur'));\n }\n setOpen(open);\n },\n },\n text,\n more,\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { PageNumbers } from './PageNumbers';\nimport { LocalizationTexts, useLocalization } from '../Provider/Localization';\nimport { Select } from '../Select/Select';\nimport { Group } from '../Group/Group';\nimport { IconButton } from '../IconButton/IconButton';\nimport { usePaginationValues } from './usePagination';\nimport { usePaginationShortcuts } from './usePaginationShortcuts';\n\nexport * from './usePagination';\n\nexport type PaginationTextsActions = {\n /**\n * Aria-label for first page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n firstPage: string;\n /**\n * Aria-label for first page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n firstPageWithShortcut: string;\n /**\n * Aria-label for next page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n nextPage: string;\n /**\n * Aria-label for next page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n nextPageWithShortcut: string;\n /**\n * Aria-label for previous page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n previousPage: string;\n /**\n * Aria-label for previous page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n previousPageWithShortcut: string;\n /**\n * Aria-label for last page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n lastPage: string;\n /**\n * Aria-label for last page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n lastPageWithShortcut: string;\n /**\n * Aria-label for page X action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n pageX: string;\n};\n\nexport type PaginationTexts = {\n /**\n * Aria-label provided for page numbers and page actions group.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n label: string;\n /**\n * Aria-label provided for page size selection.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n pageSize: string;\n /**\n * Text that indicates the number of the first and last element displayed on the current page, out of total items\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n showingXofYofTotal: string;\n /**\n * Aria-labels provided for page action buttons.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n actions: PaginationTextsActions;\n};\n\nexport type PaginationProps = React.HTMLAttributes<HTMLDivElement> &\n usePaginationValues & {\n /** Indicate total number of items that will be paginated */\n length: number;\n /** Page size options */\n pageSizes?: number[];\n /** Shows page controls */\n showPageControls?: boolean;\n /** Shows page numbers between navigation buttons, which allows users to quickly navigate to a specific page */\n showPageNumbers?: boolean;\n /** Shows a dropdown with page sizes, which allows user to change the number of items displayed on the page */\n showPageSize?: boolean;\n /** Enable pagination shortcuts */\n dangerouslyHijackGlobalKeyboardNavigation?: boolean;\n };\n\nconst getShowingLabel = (length: number, pageIndex: number, pageSize: number, texts: LocalizationTexts): string => {\n const minItemIndex = pageIndex * pageSize + 1;\n const maxItemIndex = (pageIndex + 1) * pageSize;\n\n return texts.pagination.showingXofYofTotal\n .replace('[X]', length === 0 ? '0' : String(minItemIndex))\n .replace('[Y]', String(maxItemIndex > length ? length : maxItemIndex))\n .replace('[total]', String(length));\n};\n\nexport const Pagination = React.forwardRef(function Pagination(props: PaginationProps, ref: React.Ref<HTMLDivElement>) {\n const {\n length,\n pageIndex,\n pageSize,\n pageSizes = [10, 25, 50, 100, 500],\n setPageIndex,\n setPageSize,\n showPageControls = true,\n showPageNumbers = true,\n showPageSize = true,\n dangerouslyHijackGlobalKeyboardNavigation = false,\n ...otherProps\n } = props;\n const { texts } = useLocalization();\n\n const maxPageIndex = Math.ceil(length / pageSize) - 1;\n const showShortcutTexts = dangerouslyHijackGlobalKeyboardNavigation;\n\n usePaginationShortcuts({\n setPageIndex,\n maxPageIndex,\n pageIndex,\n dangerouslyHijackGlobalKeyboardNavigation,\n });\n\n const pageCount = Math.ceil(length / pageSize);\n const canPreviousPage = pageIndex > 0;\n const canNextPage = pageIndex < pageCount - 1;\n\n const className = cn('inline-flex relative justify-between items-center', props.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"pagination\" ref={ref}>\n {showPageSize && (\n <span className=\"mr-4\">\n {getShowingLabel(length, pageIndex, pageSize, texts)}\n <Select\n aria-label={texts.pagination.pageSize}\n className=\"ml-4 !w-20\"\n data={pageSizes.map(pageSize => ({\n text: String(pageSize),\n value: pageSize,\n }))}\n onChange={event => {\n setPageIndex(0);\n setPageSize(Number(event.target.value));\n }}\n value={pageSize}\n />\n </span>\n )}\n {showPageControls && (\n <Group as=\"nav\" aria-label={texts.pagination.label}>\n <IconButton\n appearance=\"default\"\n disabled={!canPreviousPage}\n icon=\"arrow-start\"\n onClick={() => setPageIndex(0)}\n aria-label={\n showShortcutTexts\n ? texts.pagination.actions.firstPageWithShortcut\n : texts.pagination.actions.firstPage\n }\n tooltip={\n showShortcutTexts\n ? texts.pagination.actions.firstPageWithShortcut\n : texts.pagination.actions.firstPage\n }\n />\n <IconButton\n appearance=\"default\"\n disabled={!canPreviousPage}\n icon=\"arrow-left\"\n onClick={() => setPageIndex(pageIndex - 1)}\n aria-label={\n showShortcutTexts\n ? texts.pagination.actions.previousPageWithShortcut\n : texts.pagination.actions.previousPage\n }\n tooltip={\n showShortcutTexts\n ? texts.pagination.actions.previousPageWithShortcut\n : texts.pagination.actions.previousPage\n }\n />\n {showPageNumbers && pageCount > 0 && (\n <PageNumbers pageCount={pageCount} currentPageIndex={pageIndex} onClick={setPageIndex} />\n )}\n <IconButton\n appearance=\"default\"\n disabled={!canNextPage}\n icon=\"arrow-right\"\n onClick={() => setPageIndex(pageIndex + 1)}\n aria-label={\n showShortcutTexts ? texts.pagination.actions.nextPageWithShortcut : texts.pagination.actions.nextPage\n }\n tooltip={\n showShortcutTexts ? texts.pagination.actions.nextPageWithShortcut : texts.pagination.actions.nextPage\n }\n />\n <IconButton\n appearance=\"default\"\n disabled={!canNextPage}\n icon=\"arrow-end\"\n onClick={() => setPageIndex(pageCount - 1)}\n aria-label={\n showShortcutTexts ? texts.pagination.actions.lastPageWithShortcut : texts.pagination.actions.lastPage\n }\n tooltip={\n showShortcutTexts ? texts.pagination.actions.lastPageWithShortcut : texts.pagination.actions.lastPage\n }\n />\n </Group>\n )}\n </div>\n );\n});\n","import React from 'react';\n\ninterface Props {\n setPageIndex: (pageIndex: number) => void;\n maxPageIndex: number;\n pageIndex: number;\n dangerouslyHijackGlobalKeyboardNavigation: boolean;\n}\n\nexport const usePaginationShortcuts = ({\n setPageIndex,\n maxPageIndex,\n pageIndex,\n dangerouslyHijackGlobalKeyboardNavigation: useGlobalKeyboardNavigation,\n}: Props) => {\n const onKeyDown = (event: KeyboardEvent): void => {\n if (setPageIndex && event.key === 'Home') {\n event.preventDefault();\n setPageIndex(0);\n return;\n }\n\n if (setPageIndex && event.key === 'End') {\n event.preventDefault();\n setPageIndex(maxPageIndex);\n return;\n }\n\n if (setPageIndex && event.key === 'PageUp') {\n event.preventDefault();\n setPageIndex(Math.max(0, pageIndex - 1));\n return;\n }\n\n if (setPageIndex && event.key === 'PageDown') {\n event.preventDefault();\n setPageIndex(Math.min(maxPageIndex, pageIndex + 1));\n return;\n }\n };\n\n React.useEffect(() => {\n if (useGlobalKeyboardNavigation) {\n window.addEventListener('keydown', onKeyDown);\n }\n\n return () => {\n if (useGlobalKeyboardNavigation) {\n window.removeEventListener('keydown', onKeyDown);\n }\n };\n }, [onKeyDown, useGlobalKeyboardNavigation]);\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { motion, useAnimation } from 'framer-motion';\nimport useTimer from '../../utils/hooks/useTimer';\nimport { getBadgeIcon } from './util';\nimport { State } from '../../types';\nimport { useLocalization } from '../Provider/Localization';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type ToastsTexts = {\n /** Aria-label for the close icon button of toast */\n dismiss: string;\n};\n\nexport type ToastType = Omit<State, 'default'> | 'loading';\nexport type ToastOptions = {\n /** Provide time in milliseconds after which the toast should autoclose */\n autoClose?: number;\n /**\n * State will change the icon displayed in toast and other characteristics,\n * for e.g. `loading` state will display a progress animation.\n * Default value is `default`\n */\n type?: ToastType;\n};\nexport type ToastContent = Omit<React.ReactNode, 'null' | 'undefined'>;\nexport type ToastProps = {\n /** Provide a unique id for toast */\n id: string;\n /**\n * Content can be any valid react node, for e.g. a `div`, or a simple text.\n */\n content: ToastContent;\n /** Additional options to define your toast */\n options: ToastOptions;\n /**\n * Handler called when toast closes.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n onClose: () => void;\n lastUpdated?: number;\n lastDuplicateId?: string;\n};\n\nexport const Toast = ({ content, lastUpdated, onClose: handleClose, options, ...props }: ToastProps): JSX.Element => {\n const { texts } = useLocalization();\n const { autoClose, type = 'default' } = options;\n const className = cn('bg-white relative flex items-center py-1 px-2 mt-3 w-full rounded yt-shadow', {\n 'border border-grey-200': type === 'default' || type === 'loading' || !type,\n 'border border-grey-500': type === 'success',\n 'border border-blue-500': type === 'information',\n 'border border-yellow-700': type === 'warning',\n 'border border-red': type === 'error',\n });\n const timer = useTimer(autoClose, handleClose);\n const controls = useAnimation();\n\n if (!content) {\n console.warn(\n `Toast requires 'content' property, which can't be empty string, null or undefined. Current content value is set to ${\n content === '' ? 'empty string' : content\n }.`\n );\n }\n\n React.useEffect(() => {\n if (autoClose) {\n timer.start();\n }\n }, [autoClose]);\n\n const triggerUpdateAnimation = async () => {\n await controls.start({ scale: 1.05 });\n await controls.start({ scale: 1 });\n };\n\n React.useEffect(() => {\n if (lastUpdated) {\n triggerUpdateAnimation();\n\n if (timer.running) {\n timer.start();\n }\n }\n }, [lastUpdated]);\n\n return (\n <motion.div\n {...props}\n animate={controls}\n className={className}\n data-taco=\"toast\"\n onMouseEnter={timer.pause}\n onMouseLeave={timer.resume}>\n {getBadgeIcon(type)}\n <div className=\"flex-grow\">{content}</div>\n <IconButton\n appearance=\"discrete\"\n className=\"text-grey-700 -mr-2 cursor-pointer self-start !px-0\"\n icon=\"close\"\n aria-label={texts.toasts.dismiss}\n onClick={handleClose}\n />\n </motion.div>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon } from '../Icon/Icon';\nimport { Spinner } from '../Spinner/Spinner';\nimport { ToastType } from './Toast';\n\nexport const getBadgeIcon = (type: ToastType): JSX.Element | null => {\n const css = 'rounded-full flex-shrink-0 mr-2 mt-1 self-start';\n\n switch (type) {\n case 'success':\n return <Icon name=\"tick\" className={cn(css, 'yt-green-solid ')} />;\n\n case 'warning':\n return <Icon name=\"warning\" className={cn(css, 'yt-yellow-solid')} />;\n\n case 'error':\n return <Icon name=\"warning\" className={cn(css, 'yt-red-solid')} />;\n\n case 'information':\n return <Icon name=\"info\" className={cn(css, 'yt-blue-solid')} />;\n\n case 'loading':\n return <Spinner delay={0} className={cn(css, 'h-6 w-6')} />;\n\n default:\n return null;\n }\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { AnimatePresence, motion } from 'framer-motion';\nimport { ToastOptions, Toast, ToastProps, ToastContent } from './Toast';\nimport './Toast.css';\n\nconst DEFAULT_AUTO_CLOSE_TIMEOUT = 7500;\n\ntype ToastCreator<T> = (content: ToastContent | ((close: () => void) => ToastContent), options?: ToastOptions) => T;\n\nexport interface Toaster<T> extends ToastCreator<T> {\n success: ToastCreator<T>;\n error: ToastCreator<T>;\n warning: ToastCreator<T>;\n information: ToastCreator<T>;\n loading: ToastCreator<T>;\n}\n\nexport interface ToastReference {\n /** Show a success toast */\n success: ToastCreator<void>;\n /** Show an error toast */\n error: ToastCreator<void>;\n /** Show a warning toast */\n warning: ToastCreator<void>;\n /** Show an information toast */\n information: ToastCreator<void>;\n /** Show a loading toast */\n loading: ToastCreator<void>;\n /**\n * Close an existing toast.\n * The toast function returns a reference to the active toast,\n * allowing you to programmatically close it when needed\n */\n close: () => void;\n}\n\nconst ToastContext = React.createContext<Toaster<ToastReference>>({} as Toaster<ToastReference>);\n\nexport interface ToastProviderProps {\n children: React.ReactNode;\n}\n\ntype InternalToast = Omit<ToastProps, 'onClose'>;\n\nconst insertToastWithoutDuplicates = (\n currentToasts: InternalToast[],\n id: string,\n content: ToastContent,\n options: ToastOptions,\n close: () => void\n): InternalToast[] => {\n const nextToasts = [...currentToasts];\n const existingToastIndex = currentToasts.findIndex(toast => JSON.stringify(toast.content) === JSON.stringify(content));\n\n if (existingToastIndex > -1) {\n nextToasts[existingToastIndex].lastDuplicateId = id;\n nextToasts[existingToastIndex].lastUpdated = Date.now();\n } else {\n nextToasts.push({\n id,\n content: typeof content === 'function' ? content(close) : content,\n options,\n });\n }\n\n return nextToasts;\n};\n\nexport const ToastProvider = ({ children, ...props }: ToastProviderProps): JSX.Element => {\n const [toasts, setToasts] = React.useState<InternalToast[]>([]);\n\n const handleClose = (id: string): void => {\n setToasts(currentToasts => currentToasts.filter(toast => toast.id !== id));\n };\n\n // memoize (useCallback) this function,\n // it is the value of the context provider and we don't want it to trigger state tree re-renders on provider children\n const toaster = React.useCallback((content: ToastContent, options: ToastOptions): ToastReference => {\n const id = uuid();\n const close = (): void => handleClose(id);\n\n setToasts(currentToasts => insertToastWithoutDuplicates(currentToasts, id, content, options, close));\n\n const update = (content: ToastContent, options: ToastOptions): void => {\n setToasts(currentToasts => {\n const nextToasts = currentToasts.filter(toast => {\n if (toast.lastDuplicateId) {\n return toast.lastDuplicateId !== id;\n }\n\n return toast.id !== id;\n });\n return insertToastWithoutDuplicates(nextToasts, uuid(), content, options, close);\n });\n };\n\n const success = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { autoClose: DEFAULT_AUTO_CLOSE_TIMEOUT, ...options, type: 'success' });\n };\n const error = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'error' });\n };\n const warning = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'warning' });\n };\n const information = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'information' });\n };\n const loading = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'loading' });\n };\n\n return {\n success,\n error,\n warning,\n information,\n loading,\n close,\n };\n }, []) as Toaster<ToastReference>;\n\n // no need to rebind these every render, do them once in an effect\n React.useEffect(() => {\n toaster.success = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { autoClose: DEFAULT_AUTO_CLOSE_TIMEOUT, ...options, type: 'success' });\n toaster.error = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'error' });\n toaster.warning = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'warning' });\n toaster.information = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'information' });\n toaster.loading = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'loading' });\n }, []);\n\n return (\n <ToastContext.Provider {...props} value={toaster}>\n {children}\n <div\n id=\"yt-toast__container\"\n className=\"pointer-events-all absolute bottom-0 right-0 !left-auto z-[1000] mb-4 mr-4 flex max-w-md flex-col items-end justify-end\"\n role=\"log\">\n <AnimatePresence initial={false}>\n {toasts.map((toast: InternalToast) => (\n <motion.div\n key={toast.id}\n transition={{\n type: 'spring',\n damping: 20,\n stiffness: 300,\n }}\n initial={{ opacity: 0, y: 10, scale: 0.5 }}\n animate={{ opacity: 1, y: 0, scale: 1 }}\n exit={{ opacity: 0, scale: 0.5, transition: { duration: 0.2 } }}>\n <Toast {...toast} onClose={() => handleClose(toast.id)} />\n </motion.div>\n ))}\n </AnimatePresence>\n </div>\n </ToastContext.Provider>\n );\n};\n\nexport const useToast = (): Toaster<ToastReference> => React.useContext(ToastContext);\n","export const isAriaSelectionKey = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter' || event.key === ' ' || event.key === 'Tab') {\n return true;\n }\n\n return false;\n};\n\nexport const isAriaDirectionKey = (event: React.KeyboardEvent) => {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'Home' || event.key === 'End') {\n return true;\n }\n\n return false;\n};\n","import React from 'react';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { isAriaDirectionKey } from '../../../utils/aria';\nimport { createCustomKeyboardEvent } from '../../../utils/input';\n\n/* This component provides a keyboard navigable collection primitive for use in lists\n * It is unlikely you need to edit this component\n */\n\nexport type CollectionProps = React.HTMLAttributes<HTMLDivElement> & {\n querySelector: string;\n};\n\nexport type CollectionRef = HTMLDivElement & {\n setActiveIndex: (option: HTMLDivElement) => void;\n};\n\nconst getOptionsFromCollection = (collection: HTMLDivElement, selector: string): NodeListOf<Element> =>\n collection.querySelectorAll(selector);\n\n// we use javascript to set attributes (rather than cloning children and adding them)\n// so that we can support nesting (e.g. groups) - child elements that aren't options.\n// without doing this we would have to unwrap and flatten all groups\nexport const Root = React.forwardRef<CollectionRef, CollectionProps>(function CollectionRoot(props, ref) {\n const { querySelector, tabIndex = 0, ...otherProps } = props;\n const internalRef = useMergedRef<CollectionRef>(ref);\n const [activeIndex, setActiveIndex] = React.useState<number | undefined>();\n const lastLengthRef = React.useRef(0);\n\n const setActiveOption = (index: number, collection: HTMLDivElement, option: Element) => {\n collection.querySelector(`[aria-current]`)?.removeAttribute('aria-current');\n option.setAttribute('aria-current', 'true');\n option.scrollIntoView({ block: 'nearest' });\n setActiveIndex(index);\n };\n\n const setActiveIndexByElement = React.useCallback(\n (option: HTMLDivElement) => {\n if (internalRef.current) {\n if (option.matches(querySelector)) {\n const options = getOptionsFromCollection(internalRef.current, querySelector);\n const nextActiveIndex = Array.from(options).indexOf(option);\n\n if (nextActiveIndex > -1) {\n setActiveOption(nextActiveIndex, internalRef.current, option);\n }\n }\n }\n },\n [internalRef.current, querySelector]\n );\n\n React.useEffect(() => {\n if (internalRef.current) {\n internalRef.current.setActiveIndex = setActiveIndexByElement;\n }\n }, [internalRef.current]);\n\n React.useEffect(() => {\n if (internalRef.current) {\n const options = getOptionsFromCollection(internalRef.current, querySelector);\n\n if (options.length && options.length !== lastLengthRef.current) {\n const selected = internalRef.current.querySelectorAll(`[aria-selected]`);\n\n if (selected.length === 1) {\n if (options) {\n const firstSelected = selected.item(0);\n const selectedIndex = Array.from(options).indexOf(firstSelected);\n\n if (selectedIndex > -1) {\n setActiveOption(selectedIndex, internalRef.current, firstSelected);\n }\n }\n } else {\n // multiple selected or none selected should go to 0\n setActiveOption(0, internalRef.current, options.item(0));\n }\n }\n\n lastLengthRef.current = options.length;\n }\n }, [props.children]);\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>) => {\n const option = event.target as HTMLElement;\n\n if (option.matches(querySelector)) {\n const options = getOptionsFromCollection(event.currentTarget, querySelector);\n const nextActiveIndex = Array.from(options).indexOf(option);\n\n if (nextActiveIndex > -1) {\n setActiveOption(nextActiveIndex, event.currentTarget, option);\n }\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n // this stops the event dispatched to the option rebounding back and starting an infinite loop\n if (event.target !== event.currentTarget) {\n return;\n }\n\n const options = getOptionsFromCollection(event.currentTarget, querySelector);\n\n if (options) {\n if (isAriaDirectionKey(event)) {\n const nextActiveIndex = getNextEnabledItem(event, options, activeIndex);\n\n if (nextActiveIndex !== undefined && nextActiveIndex !== activeIndex) {\n event.preventDefault();\n setActiveOption(nextActiveIndex, event.currentTarget, options.item(nextActiveIndex));\n }\n } else if (activeIndex !== undefined) {\n // forward events onto the underlying option - this lets consumers place onKeyDown handlers on their own components\n options\n .item(activeIndex)\n .dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n }\n }\n };\n\n return <div {...otherProps} onClick={handleClick} onKeyDown={handleKeyDown} ref={internalRef} tabIndex={tabIndex} />;\n});\n\nexport const getNextIndexFromKeycode = (\n event: React.KeyboardEvent,\n length: number,\n activeIndex: number | undefined\n): number | undefined => {\n switch (event.key) {\n case 'ArrowUp':\n return activeIndex === undefined ? length - 1 : activeIndex > 0 ? activeIndex - 1 : activeIndex;\n\n case 'ArrowDown':\n return activeIndex === undefined ? 0 : activeIndex < length - 1 ? activeIndex + 1 : activeIndex;\n\n case 'Home':\n return 0;\n\n case 'End':\n return length - 1;\n\n default:\n return;\n }\n};\n\nexport const getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n options: NodeListOf<Element>,\n activeIndex: number | undefined,\n recurse = true\n): number | undefined => {\n const nextIndex = getNextIndexFromKeycode(event, options.length, activeIndex);\n\n if (nextIndex !== undefined) {\n if (nextIndex === activeIndex) {\n return activeIndex;\n } else if (options.item(nextIndex) && isSkippableItem(options.item(nextIndex))) {\n // check in the other direction if the first or last item is disabled,\n // but prevent infinite loops if all elements are disabled by disabling recursion\n if (recurse) {\n if (nextIndex === 0) {\n return getNextEnabledItem(\n new KeyboardEvent(event.type, { ...(event as any), key: 'ArrowDown' }) as any,\n options,\n nextIndex,\n false\n );\n } else if (nextIndex === options.length - 1) {\n return getNextEnabledItem(\n new KeyboardEvent(event.type, { ...(event as any), key: 'ArrowUp' }) as any,\n options,\n nextIndex,\n false\n );\n }\n }\n\n return getNextEnabledItem(event, options, nextIndex, recurse);\n }\n }\n\n return nextIndex;\n};\n\nconst isSkippableItem = (element: Element) => {\n return (\n element.getAttribute('role') === 'presentation' ||\n !!element.hasAttribute('disabled') ||\n !!element.getAttribute('aria-disabled') ||\n !!element.getAttribute('aria-hidden')\n );\n};\n","import React from 'react';\nimport { Listbox2Value } from '../types';\n\nexport type Listbox2ContextProps = {\n disabled: boolean;\n readOnly: boolean;\n setValue: (value: Listbox2Value) => void;\n value?: Listbox2Value;\n};\n\nexport const Listbox2Context = React.createContext({} as Listbox2ContextProps);\nexport const useListbox2Context = () => React.useContext(Listbox2Context);\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport * as CollectionPrimitive from '../../Collection/Collection';\nimport { Listbox2Value } from '../types';\nimport { Listbox2Context } from './Context';\n\nexport type Listbox2Props = React.HTMLAttributes<HTMLDivElement> & {\n customSelector?: string;\n disabled?: boolean;\n multiple?: boolean;\n readOnly?: boolean;\n setValue: (value: Listbox2Value) => void;\n value?: Listbox2Value;\n};\n\nconst DEFAULT_SELECTOR = '[role=\"option\"]';\n\nexport const Root = React.forwardRef<CollectionPrimitive.CollectionRef, Listbox2Props>(function Listbox2(props, ref) {\n const {\n children,\n customSelector,\n disabled = false,\n id: nativeId,\n multiple,\n readOnly = false,\n setValue,\n title,\n value,\n ...otherProps\n } = props;\n const id = useId(nativeId);\n\n const context = React.useMemo(\n () => ({\n disabled,\n readOnly,\n setValue,\n value,\n }),\n [disabled, readOnly, value]\n );\n\n return (\n <Listbox2Context.Provider value={context}>\n <div data-taco=\"listbox2\">\n <CollectionPrimitive.Root\n {...otherProps}\n aria-multiselectable={multiple ? true : undefined}\n id={id}\n ref={ref}\n role=\"listbox\"\n querySelector={customSelector ? `${DEFAULT_SELECTOR}, ${customSelector}` : DEFAULT_SELECTOR}>\n {children}\n </CollectionPrimitive.Root>\n </div>\n </Listbox2Context.Provider>\n );\n});\n\nexport const createListboxValueSetter =\n (multiple: boolean, setValue: React.Dispatch<React.SetStateAction<Listbox2Value | undefined>>) =>\n (nextValue: Listbox2Value) => {\n setValue(value => {\n if (Array.isArray(nextValue)) {\n return nextValue;\n }\n\n if (multiple) {\n if (value === undefined) {\n return [nextValue];\n } else if (Array.isArray(value)) {\n if (value.includes(nextValue)) {\n return value.filter(v => v !== nextValue);\n }\n\n return [...value, nextValue];\n } else if (value === nextValue) {\n return [];\n }\n\n return [value, nextValue];\n }\n\n return nextValue;\n });\n };\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Listbox2OptionValue } from '../types';\nimport { useListbox2Context } from './Context';\n\nexport type Listbox2OptionProps = React.HTMLAttributes<HTMLDivElement> & {\n disabled?: boolean;\n value: Listbox2OptionValue;\n};\n\nexport const Option = React.forwardRef<HTMLDivElement, Listbox2OptionProps>(function Listbox2Option(props, ref) {\n const { disabled, id: nativeId, title, value, ...otherProps } = props;\n const { disabled: listboxDisabled, readOnly: listboxReadOnly, setValue, value: currentValue } = useListbox2Context();\n const id = useId(nativeId);\n const selected = Array.isArray(currentValue) ? currentValue.includes(value) : currentValue === value;\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>) => {\n if (disabled || listboxDisabled || listboxReadOnly) {\n event.stopPropagation();\n return;\n } else {\n setValue(value);\n }\n\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (disabled || listboxDisabled || listboxReadOnly) {\n event.stopPropagation();\n return;\n } else if (isAriaSelectionKey(event)) {\n setValue(value);\n }\n\n if (typeof props.onKeyDown === 'function') {\n props.onKeyDown(event);\n }\n };\n\n return (\n <div\n {...otherProps}\n aria-disabled={listboxDisabled || disabled ? 'true' : undefined}\n aria-selected={selected ? 'true' : undefined}\n id={id}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n ref={ref}\n role=\"option\"\n />\n );\n});\n","import React from 'react';\n\nexport type Listbox2GroupProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Group = React.forwardRef<HTMLDivElement, Listbox2GroupProps>(function Listbox2Group(props, ref) {\n const [labelledById, setLabelledById] = React.useState<string>();\n\n return (\n <Listbox2GroupContext.Provider value={{ setLabelledById }}>\n <div {...props} aria-labelledby={labelledById} ref={ref} role=\"group\" />\n </Listbox2GroupContext.Provider>\n );\n});\n\nexport type Listbox2GroupContextProps = {\n setLabelledById: (id: string) => void;\n};\n\nexport const Listbox2GroupContext = React.createContext({} as Listbox2GroupContextProps);\nexport const useListbox2GroupContext = () => React.useContext(Listbox2GroupContext);\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport { useListbox2GroupContext } from './Group';\n\nexport type Listbox2TitleProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Title = React.forwardRef<HTMLDivElement, Listbox2TitleProps>(function Listbox2Group(props, ref) {\n const { id: nativeId, ...otherProps } = props;\n const { setLabelledById } = useListbox2GroupContext();\n const id = useId(nativeId);\n\n React.useEffect(() => {\n setLabelledById(id);\n }, [id]);\n\n return <div {...otherProps} id={id} ref={ref} role=\"presentation\" />;\n});\n","export const colors = {\n green: 'bg-green-100 text-green-900',\n yellow: 'bg-yellow-100 text-yellow-900',\n red: 'bg-red-100 text-red-900',\n blue: 'bg-blue-100 text-blue-900',\n purple: 'bg-purple-100 text-purple-900',\n orange: 'bg-orange-100 text-orange-900',\n brown: 'bg-brown-100 text-brown-900',\n pink: 'bg-pink-100 text-pink-900',\n grey: 'bg-grey-200 text-grey-900',\n};\n\nexport type Color = keyof typeof colors;\n","import React from 'react';\nimport cn from 'classnames';\nimport { Color, colors } from '../../utils/colors';\nimport { Icon, IconName, IconProps } from '../Icon/Icon';\n\nexport type TagProps = Omit<React.HTMLAttributes<HTMLSpanElement>, 'children'> & {\n children: string;\n color?: Color;\n disabled?: boolean;\n icon?: React.ReactElement<IconProps> | IconName;\n readOnly?: boolean;\n onDelete?: (event: React.MouseEvent<SVGSVGElement>) => void;\n};\n\nexport const Tag = React.forwardRef<HTMLSpanElement, TagProps>((props, ref) => {\n const { children, color, disabled, icon, readOnly, onDelete, ...otherProps } = props;\n const textRef = React.useRef<HTMLDivElement>(null);\n\n const className = cn(\n 'inline-flex items-center rounded h-6 cursor-default',\n {\n 'opacity-50': disabled,\n 'hover:bg-opacity-75': !disabled,\n 'cursor-pointer': !!otherProps.onClick,\n 'pointer-events-none': disabled || readOnly,\n },\n color ? colors[color] : colors.grey,\n props.className\n );\n\n return (\n <span {...otherProps} className={className} ref={ref}>\n <span className=\"truncate px-2\" ref={textRef}>\n {icon ? (\n typeof icon === 'string' ? (\n <Icon name={icon} className=\"mr-1 -ml-1 -mt-0.5 !h-5 !w-5\" />\n ) : (\n React.cloneElement(icon, { className: 'mr-1 -ml-1 -mt-0.5 !h-5 !w-5' })\n )\n ) : null}\n {children}\n </span>\n {onDelete ? (\n <Icon\n name=\"close\"\n onClick={onDelete}\n className=\"-ml-1.5 !h-6 !w-5 flex-shrink-0 cursor-pointer rounded-r p-0.5 hover:bg-black/5\"\n />\n ) : null}\n </span>\n );\n});\n","import React from 'react';\nimport { CollectionRef } from '../../../primitives/Collection/Collection';\nimport { Color } from '../../../utils/colors';\nimport { Select2OptionValue, Select2Value } from '../types';\nimport { Select2OptionProps } from './Option';\n\nexport type Select2ContextProps = {\n disabled: boolean;\n highlighted: boolean;\n invalid: boolean;\n listboxRef: React.RefObject<CollectionRef>;\n multiple: boolean;\n onCreate?: (text: string, color: Color | undefined) => Promise<Select2OptionProps>;\n onDelete?: (value: Select2OptionValue) => Promise<void>;\n onEdit?: (value: Select2OptionValue, text: string, color: Color | undefined) => Promise<void>;\n open: boolean;\n readOnly: boolean;\n ref: React.RefObject<HTMLButtonElement>;\n searchQuery: string;\n searchRef?: React.RefObject<HTMLInputElement>;\n setOpen: (open: boolean) => void;\n setSearchQuery: (value: string) => void;\n setValidationError: (error: Error | undefined) => void;\n setValue: (value: Select2OptionValue) => void;\n tags?: boolean;\n validationError?: Error;\n value?: Select2Value;\n};\n\nexport const Select2Context = React.createContext({} as Select2ContextProps);\nexport const useSelect2Context = () => React.useContext(Select2Context);\n","// A type of promise-like that resolves synchronously and supports only one observer\nexport const _Pact = /*#__PURE__*/(function() {\n\tfunction _Pact() {}\n\t_Pact.prototype.then = function(onFulfilled, onRejected) {\n\t\tconst result = new _Pact();\n\t\tconst state = this.s;\n\t\tif (state) {\n\t\t\tconst callback = state & 1 ? onFulfilled : onRejected;\n\t\t\tif (callback) {\n\t\t\t\ttry {\n\t\t\t\t\t_settle(result, 1, callback(this.v));\n\t\t\t\t} catch (e) {\n\t\t\t\t\t_settle(result, 2, e);\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t} else {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t}\n\t\tthis.o = function(_this) {\n\t\t\ttry {\n\t\t\t\tconst value = _this.v;\n\t\t\t\tif (_this.s & 1) {\n\t\t\t\t\t_settle(result, 1, onFulfilled ? onFulfilled(value) : value);\n\t\t\t\t} else if (onRejected) {\n\t\t\t\t\t_settle(result, 1, onRejected(value));\n\t\t\t\t} else {\n\t\t\t\t\t_settle(result, 2, value);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\t_settle(result, 2, e);\n\t\t\t}\n\t\t};\n\t\treturn result;\n\t}\n\treturn _Pact;\n})();\n\n// Settles a pact synchronously\nexport function _settle(pact, state, value) {\n\tif (!pact.s) {\n\t\tif (value instanceof _Pact) {\n\t\t\tif (value.s) {\n\t\t\t\tif (state & 1) {\n\t\t\t\t\tstate = value.s;\n\t\t\t\t}\n\t\t\t\tvalue = value.v;\n\t\t\t} else {\n\t\t\t\tvalue.o = _settle.bind(null, pact, state);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\tif (value && value.then) {\n\t\t\tvalue.then(_settle.bind(null, pact, state), _settle.bind(null, pact, 2));\n\t\t\treturn;\n\t\t}\n\t\tpact.s = state;\n\t\tpact.v = value;\n\t\tconst observer = pact.o;\n\t\tif (observer) {\n\t\t\tobserver(pact);\n\t\t}\n\t}\n}\n\nexport function _isSettledPact(thenable) {\n\treturn thenable instanceof _Pact && thenable.s & 1;\n}\n\n// Converts argument to a function that always returns a Promise\nexport function _async(f) {\n\treturn function() {\n\t\tfor (var args = [], i = 0; i < arguments.length; i++) {\n\t\t\targs[i] = arguments[i];\n\t\t}\n\t\ttry {\n\t\t\treturn Promise.resolve(f.apply(this, args));\n\t\t} catch(e) {\n\t\t\treturn Promise.reject(e);\n\t\t}\n\t}\n}\n\n// Awaits on a value that may or may not be a Promise (equivalent to the await keyword in ES2015, with continuations passed explicitly)\nexport function _await(value, then, direct) {\n\tif (direct) {\n\t\treturn then ? then(value) : value;\n\t}\n\tif (!value || !value.then) {\n\t\tvalue = Promise.resolve(value);\n\t}\n\treturn then ? value.then(then) : value;\n}\n\n// Awaits on a value that may or may not be a Promise, then ignores it\nexport function _awaitIgnored(value, direct) {\n\tif (!direct) {\n\t\treturn value && value.then ? value.then(_empty) : Promise.resolve();\n\t}\n}\n\n// Proceeds after a value has resolved, or proceeds immediately if the value is not thenable\nexport function _continue(value, then) {\n\treturn value && value.then ? value.then(then) : then(value);\n}\n\n// Proceeds after a value has resolved, or proceeds immediately if the value is not thenable\nexport function _continueIgnored(value) {\n\tif (value && value.then) {\n\t\treturn value.then(_empty);\n\t}\n}\n\n// Asynchronously iterate through an object that has a length property, passing the index as the first argument to the callback (even as the length property changes)\nexport function _forTo(array, body, check) {\n\tvar i = -1, pact, reject;\n\tfunction _cycle(result) {\n\t\ttry {\n\t\t\twhile (++i < array.length && (!check || !check())) {\n\t\t\t\tresult = body(i);\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.then(_cycle, reject || (reject = _settle.bind(null, pact = new _Pact(), 2)));\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (pact) {\n\t\t\t\t_settle(pact, 1, result);\n\t\t\t} else {\n\t\t\t\tpact = result;\n\t\t\t}\n\t\t} catch (e) {\n\t\t\t_settle(pact || (pact = new _Pact()), 2, e);\n\t\t}\n\t}\n\t_cycle();\n\treturn pact;\n}\n\n// Asynchronously iterate through an object's properties (including properties inherited from the prototype)\n// Uses a snapshot of the object's properties\nexport function _forIn(target, body, check) {\n\tvar keys = [];\n\tfor (var key in target) {\n\t\tkeys.push(key);\n\t}\n\treturn _forTo(keys, function(i) { return body(keys[i]); }, check);\n}\n\n// Asynchronously iterate through an object's own properties (excluding properties inherited from the prototype)\n// Uses a snapshot of the object's properties\nexport function _forOwn(target, body, check) {\n\tvar keys = [];\n\tfor (var key in target) {\n\t\tif (Object.prototype.hasOwnProperty.call(target, key)) {\n\t\t\tkeys.push(key);\n\t\t}\n\t}\n\treturn _forTo(keys, function(i) { return body(keys[i]); }, check);\n}\n\nexport const _iteratorSymbol = /*#__PURE__*/ typeof Symbol !== \"undefined\" ? (Symbol.iterator || (Symbol.iterator = Symbol(\"Symbol.iterator\"))) : \"@@iterator\";\n\n// Asynchronously iterate through an object's values\n// Uses for...of if the runtime supports it, otherwise iterates until length on a copy\nexport function _forOf(target, body, check) {\n\tif (typeof target[_iteratorSymbol] === \"function\") {\n\t\tvar iterator = target[_iteratorSymbol](), step, pact, reject;\n\t\tfunction _cycle(result) {\n\t\t\ttry {\n\t\t\t\twhile (!(step = iterator.next()).done && (!check || !check())) {\n\t\t\t\t\tresult = body(step.value);\n\t\t\t\t\tif (result && result.then) {\n\t\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tresult.then(_cycle, reject || (reject = _settle.bind(null, pact = new _Pact(), 2)));\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (pact) {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t} else {\n\t\t\t\t\tpact = result;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\t_settle(pact || (pact = new _Pact()), 2, e);\n\t\t\t}\n\t\t}\n\t\t_cycle();\n\t\tif (iterator.return) {\n\t\t\tvar _fixup = function(value) {\n\t\t\t\ttry {\n\t\t\t\t\tif (!step.done) {\n\t\t\t\t\t\titerator.return();\n\t\t\t\t\t}\n\t\t\t\t} catch(e) {\n\t\t\t\t}\n\t\t\t\treturn value;\n\t\t\t}\n\t\t\tif (pact && pact.then) {\n\t\t\t\treturn pact.then(_fixup, function(e) {\n\t\t\t\t\tthrow _fixup(e);\n\t\t\t\t});\n\t\t\t}\n\t\t\t_fixup();\n\t\t}\n\t\treturn pact;\n\t}\n\t// No support for Symbol.iterator\n\tif (!(\"length\" in target)) {\n\t\tthrow new TypeError(\"Object is not iterable\");\n\t}\n\t// Handle live collections properly\n\tvar values = [];\n\tfor (var i = 0; i < target.length; i++) {\n\t\tvalues.push(target[i]);\n\t}\n\treturn _forTo(values, function(i) { return body(values[i]); }, check);\n}\n\nexport const _asyncIteratorSymbol = /*#__PURE__*/ typeof Symbol !== \"undefined\" ? (Symbol.asyncIterator || (Symbol.asyncIterator = Symbol(\"Symbol.asyncIterator\"))) : \"@@asyncIterator\";\n\n// Asynchronously iterate on a value using it's async iterator if present, or its synchronous iterator if missing\nexport function _forAwaitOf(target, body, check) {\n\tif (typeof target[_asyncIteratorSymbol] === \"function\") {\n\t\tvar pact = new _Pact();\n\t\tvar iterator = target[_asyncIteratorSymbol]();\n\t\titerator.next().then(_resumeAfterNext).then(void 0, _reject);\n\t\treturn pact;\n\t\tfunction _resumeAfterBody(result) {\n\t\t\tif (check && check()) {\n\t\t\t\treturn _settle(pact, 1, iterator.return ? iterator.return().then(function() { return result; }) : result);\n\t\t\t}\n\t\t\titerator.next().then(_resumeAfterNext).then(void 0, _reject);\n\t\t}\n\t\tfunction _resumeAfterNext(step) {\n\t\t\tif (step.done) {\n\t\t\t\t_settle(pact, 1);\n\t\t\t} else {\n\t\t\t\tPromise.resolve(body(step.value)).then(_resumeAfterBody).then(void 0, _reject);\n\t\t\t}\n\t\t}\n\t\tfunction _reject(error) {\n\t\t\t_settle(pact, 2, iterator.return ? iterator.return().then(function() { return error; }) : error);\n\t\t}\n\t}\n\treturn Promise.resolve(_forOf(target, function(value) { return Promise.resolve(value).then(body); }, check));\n}\n\n// Asynchronously implement a generic for loop\nexport function _for(test, update, body) {\n\tvar stage;\n\tfor (;;) {\n\t\tvar shouldContinue = test();\n\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\tshouldContinue = shouldContinue.v;\n\t\t}\n\t\tif (!shouldContinue) {\n\t\t\treturn result;\n\t\t}\n\t\tif (shouldContinue.then) {\n\t\t\tstage = 0;\n\t\t\tbreak;\n\t\t}\n\t\tvar result = body();\n\t\tif (result && result.then) {\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.s;\n\t\t\t} else {\n\t\t\t\tstage = 1;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tif (update) {\n\t\t\tvar updateValue = update();\n\t\t\tif (updateValue && updateValue.then && !_isSettledPact(updateValue)) {\n\t\t\t\tstage = 2;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\tvar pact = new _Pact();\n\tvar reject = _settle.bind(null, pact, 2);\n\t(stage === 0 ? shouldContinue.then(_resumeAfterTest) : stage === 1 ? result.then(_resumeAfterBody) : updateValue.then(_resumeAfterUpdate)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterBody(value) {\n\t\tresult = value;\n\t\tdo {\n\t\t\tif (update) {\n\t\t\t\tupdateValue = update();\n\t\t\t\tif (updateValue && updateValue.then && !_isSettledPact(updateValue)) {\n\t\t\t\t\tupdateValue.then(_resumeAfterUpdate).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tshouldContinue = test();\n\t\t\tif (!shouldContinue || (_isSettledPact(shouldContinue) && !shouldContinue.v)) {\n\t\t\t\t_settle(pact, 1, result);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.v;\n\t\t\t}\n\t\t} while (!result || !result.then);\n\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t}\n\tfunction _resumeAfterTest(shouldContinue) {\n\t\tif (shouldContinue) {\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t} else {\n\t\t\t\t_resumeAfterBody(result);\n\t\t\t}\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n\tfunction _resumeAfterUpdate() {\n\t\tif (shouldContinue = test()) {\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t} else {\n\t\t\t\t_resumeAfterTest(shouldContinue);\n\t\t\t}\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n}\n\n// Asynchronously implement a do ... while loop\nexport function _do(body, test) {\n\tvar awaitBody;\n\tdo {\n\t\tvar result = body();\n\t\tif (result && result.then) {\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.v;\n\t\t\t} else {\n\t\t\t\tawaitBody = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tvar shouldContinue = test();\n\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\tshouldContinue = shouldContinue.v;\n\t\t}\n\t\tif (!shouldContinue) {\n\t\t\treturn result;\n\t\t}\n\t} while (!shouldContinue.then);\n\tconst pact = new _Pact();\n\tconst reject = _settle.bind(null, pact, 2);\n\t(awaitBody ? result.then(_resumeAfterBody) : shouldContinue.then(_resumeAfterTest)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterBody(value) {\n\t\tresult = value;\n\t\tfor (;;) {\n\t\t\tshouldContinue = test();\n\t\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\t\tshouldContinue = shouldContinue.v;\n\t\t\t}\n\t\t\tif (!shouldContinue) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\tresult = result.v;\n\t\t\t\t} else {\n\t\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t_settle(pact, 1, result);\n\t}\n\tfunction _resumeAfterTest(shouldContinue) {\n\t\tif (shouldContinue) {\n\t\t\tdo {\n\t\t\t\tresult = body();\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tshouldContinue = test();\n\t\t\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\t\t\tshouldContinue = shouldContinue.v;\n\t\t\t\t}\n\t\t\t\tif (!shouldContinue) {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} while (!shouldContinue.then);\n\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n}\n\n// Asynchronously implement a switch statement\nexport function _switch(discriminant, cases) {\n\tvar dispatchIndex = -1;\n\tvar awaitBody;\n\touter: {\n\t\tfor (var i = 0; i < cases.length; i++) {\n\t\t\tvar test = cases[i][0];\n\t\t\tif (test) {\n\t\t\t\tvar testValue = test();\n\t\t\t\tif (testValue && testValue.then) {\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\t\t\t\tif (testValue === discriminant) {\n\t\t\t\t\tdispatchIndex = i;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Found the default case, set it as the pending dispatch case\n\t\t\t\tdispatchIndex = i;\n\t\t\t}\n\t\t}\n\t\tif (dispatchIndex !== -1) {\n\t\t\tdo {\n\t\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\t\twhile (!body) {\n\t\t\t\t\tdispatchIndex++;\n\t\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t\t}\n\t\t\t\tvar result = body();\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tawaitBody = true;\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\t\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\t\tdispatchIndex++;\n\t\t\t} while (fallthroughCheck && !fallthroughCheck());\n\t\t\treturn result;\n\t\t}\n\t}\n\tconst pact = new _Pact();\n\tconst reject = _settle.bind(null, pact, 2);\n\t(awaitBody ? result.then(_resumeAfterBody) : testValue.then(_resumeAfterTest)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterTest(value) {\n\t\tfor (;;) {\n\t\t\tif (value === discriminant) {\n\t\t\t\tdispatchIndex = i;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (++i === cases.length) {\n\t\t\t\tif (dispatchIndex !== -1) {\n\t\t\t\t\tbreak;\n\t\t\t\t} else {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\ttest = cases[i][0];\n\t\t\tif (test) {\n\t\t\t\tvalue = test();\n\t\t\t\tif (value && value.then) {\n\t\t\t\t\tvalue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tdispatchIndex = i;\n\t\t\t}\n\t\t}\n\t\tdo {\n\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\twhile (!body) {\n\t\t\t\tdispatchIndex++;\n\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t}\n\t\t\tvar result = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\tdispatchIndex++;\n\t\t} while (fallthroughCheck && !fallthroughCheck());\n\t\t_settle(pact, 1, result);\n\t}\n\tfunction _resumeAfterBody(result) {\n\t\tfor (;;) {\n\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\tif (!fallthroughCheck || fallthroughCheck()) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tdispatchIndex++;\n\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\twhile (!body) {\n\t\t\t\tdispatchIndex++;\n\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\t_settle(pact, 1, result);\n\t}\n}\n\n// Asynchronously call a function and pass the result to explicitly passed continuations\nexport function _call(body, then, direct) {\n\tif (direct) {\n\t\treturn then ? then(body()) : body();\n\t}\n\ttry {\n\t\tvar result = Promise.resolve(body());\n\t\treturn then ? result.then(then) : result;\n\t} catch (e) {\n\t\treturn Promise.reject(e);\n\t}\n}\n\n// Asynchronously call a function and swallow the result\nexport function _callIgnored(body, direct) {\n\treturn _call(body, _empty, direct);\n}\n\n// Asynchronously call a function and pass the result to explicitly passed continuations\nexport function _invoke(body, then) {\n\tvar result = body();\n\tif (result && result.then) {\n\t\treturn result.then(then);\n\t}\n\treturn then(result);\n}\n\n// Asynchronously call a function and swallow the result\nexport function _invokeIgnored(body) {\n\tvar result = body();\n\tif (result && result.then) {\n\t\treturn result.then(_empty);\n\t}\n}\n\n// Asynchronously call a function and send errors to recovery continuation\nexport function _catch(body, recover) {\n\ttry {\n\t\tvar result = body();\n\t} catch(e) {\n\t\treturn recover(e);\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(void 0, recover);\n\t}\n\treturn result;\n}\n\n// Asynchronously await a promise and pass the result to a finally continuation\nexport function _finallyRethrows(body, finalizer) {\n\ttry {\n\t\tvar result = body();\n\t} catch (e) {\n\t\treturn finalizer(true, e);\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(finalizer.bind(null, false), finalizer.bind(null, true));\n\t}\n\treturn finalizer(false, result);\n}\n\n// Asynchronously await a promise and invoke a finally continuation that always overrides the result\nexport function _finally(body, finalizer) {\n\ttry {\n\t\tvar result = body();\n\t} catch (e) {\n\t\treturn finalizer();\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(finalizer, finalizer);\n\t}\n\treturn finalizer();\n}\n\n// Rethrow or return a value from a finally continuation\nexport function _rethrow(thrown, value) {\n\tif (thrown)\n\t\tthrow value;\n\treturn value;\n}\n\n// Empty function to implement break and other control flow that ignores asynchronous results\nexport function _empty() {\n}\n\n// Sentinel value for early returns in generators \nexport const _earlyReturn = /*#__PURE__*/ {};\n\n// Asynchronously call a function and send errors to recovery continuation, skipping early returns\nexport function _catchInGenerator(body, recover) {\n\treturn _catch(body, function(e) {\n\t\tif (e === _earlyReturn) {\n\t\t\tthrow e;\n\t\t}\n\t\treturn recover(e);\n\t});\n}\n\n// Asynchronous generator class; accepts the entrypoint of the generator, to which it passes itself when the generator should start\nexport const _AsyncGenerator = /*#__PURE__*/(function() {\n\tfunction _AsyncGenerator(entry) {\n\t\tthis._entry = entry;\n\t\tthis._pact = null;\n\t\tthis._resolve = null;\n\t\tthis._return = null;\n\t\tthis._promise = null;\n\t}\n\n\tfunction _wrapReturnedValue(value) {\n\t\treturn { value: value, done: true };\n\t}\n\tfunction _wrapYieldedValue(value) {\n\t\treturn { value: value, done: false };\n\t}\n\n\t_AsyncGenerator.prototype._yield = function(value) {\n\t\t// Yield the value to the pending next call\n\t\tthis._resolve(value && value.then ? value.then(_wrapYieldedValue) : _wrapYieldedValue(value));\n\t\t// Return a pact for an upcoming next/return/throw call\n\t\treturn this._pact = new _Pact();\n\t};\n\t_AsyncGenerator.prototype.next = function(value) {\n\t\t// Advance the generator, starting it if it has yet to be started\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tconst _entry = _this._entry;\n\t\t\t\tif (_entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the next call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Start the generator\n\t\t\t\t_this._entry = null;\n\t\t\t\t_this._resolve = resolve;\n\t\t\t\tfunction returnValue(value) {\n\t\t\t\t\t_this._resolve(value && value.then ? value.then(_wrapReturnedValue) : _wrapReturnedValue(value));\n\t\t\t\t\t_this._pact = null;\n\t\t\t\t\t_this._resolve = null;\n\t\t\t\t}\n\t\t\t\tvar result = _entry(_this);\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tresult.then(returnValue, function(error) {\n\t\t\t\t\t\tif (error === _earlyReturn) {\n\t\t\t\t\t\t\treturnValue(_this._return);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tconst pact = new _Pact();\n\t\t\t\t\t\t\t_this._resolve(pact);\n\t\t\t\t\t\t\t_this._pact = null;\n\t\t\t\t\t\t\t_this._resolve = null;\n\t\t\t\t\t\t\t_resolve(pact, 2, error);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\treturnValue(result);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Generator is started and a yield expression is pending, settle it\n\t\t\t\t_this._pact = null;\n\t\t\t\t_this._resolve = resolve;\n\t\t\t\t_settle(_pact, 1, value);\n\t\t\t}\n\t\t});\n\t};\n\t_AsyncGenerator.prototype.return = function(value) {\n\t\t// Early return from the generator if started, otherwise abandons the generator\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tif (_this._entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the return call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Generator is not started, abandon it and return the specified value\n\t\t\t\t_this._entry = null;\n\t\t\t\treturn resolve(value && value.then ? value.then(_wrapReturnedValue) : _wrapReturnedValue(value));\n\t\t\t}\n\t\t\t// Settle the yield expression with a rejected \"early return\" value\n\t\t\t_this._return = value;\n\t\t\t_this._resolve = resolve;\n\t\t\t_this._pact = null;\n\t\t\t_settle(_pact, 2, _earlyReturn);\n\t\t});\n\t};\n\t_AsyncGenerator.prototype.throw = function(error) {\n\t\t// Inject an exception into the pending yield expression\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve, reject) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tif (_this._entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the throw call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Generator is not started, abandon it and return a rejected Promise containing the error\n\t\t\t\t_this._entry = null;\n\t\t\t\treturn reject(error);\n\t\t\t}\n\t\t\t// Settle the yield expression with the value as a rejection\n\t\t\t_this._resolve = resolve;\n\t\t\t_this._pact = null;\n\t\t\t_settle(_pact, 2, error);\n\t\t});\n\t};\n\n\t_AsyncGenerator.prototype[_asyncIteratorSymbol] = function() {\n\t\treturn this;\n\t};\n\t\n\treturn _AsyncGenerator;\n})();\n","import React from 'react';\nimport cn from 'classnames';\nimport * as RadioGroup from '@radix-ui/react-radio-group';\nimport { Color, colors } from '../../../utils/colors';\nimport { Button } from '../../Button/Button';\nimport { Input } from '../../Input/Input';\nimport { Popover, PopoverProps } from '../../Popover/Popover';\nimport { Icon } from '../../Icon/Icon';\nimport { Select2OptionValue } from '../types';\nimport { useSelect2Context } from './Context';\nimport { Field } from '../../Field/Field';\nimport { Group } from '../../Group/Group';\nimport { useLocalization } from '../../Provider/Localization';\n\nconst AVAILABLE_COLORS = Object.keys(colors);\n\nexport type EditPopoverProps = PopoverProps & {\n color?: Color;\n text: string;\n value: Select2OptionValue;\n};\n\nexport const EditPopover = (props: EditPopoverProps) => {\n const { color: initialColor, text: initialName, value, ...popoverProps } = props;\n const ref = React.useRef<HTMLInputElement>(null);\n const { onDelete, onEdit, searchRef, ref: selectRef } = useSelect2Context();\n const { texts } = useLocalization();\n const [name, setName] = React.useState(initialName);\n const [color, setColor] = React.useState(initialColor);\n const [validationError, setValidationError] = React.useState<Error | undefined>();\n\n const handleInputChange = event => {\n setName(event.target.value);\n setValidationError(undefined);\n };\n\n const handleInputKeyDown = close => async event => {\n event.stopPropagation();\n\n if (event.key === 'Escape') {\n close();\n } else if (event.key === 'Enter') {\n handleSave(close)(event);\n }\n };\n\n const handleDelete = close => async event => {\n event.stopPropagation();\n close();\n\n if (onDelete) {\n await onDelete(value);\n }\n };\n\n const handleSave = close => async event => {\n if (onEdit && (name !== initialName || color !== initialColor)) {\n try {\n await onEdit(value, name, color);\n close();\n } catch (error) {\n event.preventDefault();\n event.stopPropagation();\n setValidationError(error as Error);\n ref.current?.focus();\n }\n } else {\n close();\n }\n };\n\n const handleCloseAutoFocus = event => {\n event.preventDefault();\n setName(initialName);\n setColor(initialColor);\n setValidationError(undefined);\n\n if (searchRef?.current) {\n searchRef.current?.focus();\n } else {\n selectRef.current?.focus();\n }\n };\n\n const handleInteractOutside = () => {\n setName(initialName);\n setColor(initialColor);\n };\n\n const preventKeyDownPropagation = event => {\n if (event.key !== 'Escape') {\n event.stopPropagation();\n }\n };\n\n return (\n <Popover {...popoverProps} modal>\n <Popover.Content\n onCloseAutoFocus={handleCloseAutoFocus}\n onInteractOutside={handleInteractOutside}\n onClick={event => event.stopPropagation()}\n placement=\"right\"\n tabIndex={-1}\n className=\"focus:!shadow-none\">\n {({ close }) => (\n <>\n <div className=\"flex w-32 flex-col space-y-2\">\n {onEdit ? (\n <>\n <Field\n className={cn('!min-h-fit', { '!pb-0': !validationError })}\n invalid={!!validationError}\n message={validationError?.message}>\n <Input\n invalid={!!validationError}\n onChange={handleInputChange}\n onKeyDown={handleInputKeyDown(close)}\n ref={ref}\n value={name}\n />\n </Field>\n {initialColor ? (\n <>\n <h5>Colours</h5>\n <Colours\n color={color}\n onChangeColor={setColor}\n onKeyDown={preventKeyDownPropagation}\n />\n </>\n ) : null}\n <Group>\n <Button onClick={close}>{texts.select2.cancel}</Button>\n <Button appearance=\"primary\" onClick={handleSave(close)}>\n {texts.select2.save}\n </Button>\n </Group>\n </>\n ) : null}\n {onEdit && onDelete ? <hr /> : null}\n {onDelete ? (\n <button\n className=\"hover:text-grey-700 flex items-center justify-start gap-1\"\n onClick={handleDelete(close)}\n onKeyDown={preventKeyDownPropagation}>\n <Icon className=\"!h-5 !w-5\" name=\"delete-permanently\" /> {texts.select2.delete}\n </button>\n ) : null}\n </div>\n </>\n )}\n </Popover.Content>\n </Popover>\n );\n};\n\nconst Colours = props => {\n const { color, onChangeColor, onClick, onKeyDown } = props;\n const { texts } = useLocalization();\n\n return (\n <RadioGroup.Root\n aria-label={texts.select2.chooseColor}\n className=\"grid grid-cols-4 gap-2 focus:outline-none\"\n onClick={onClick}\n onKeyDown={onKeyDown}\n onValueChange={color => onChangeColor(color)}\n value={color}>\n {AVAILABLE_COLORS.map((availableColor: string) => (\n <RadioGroup.Item\n aria-label={color}\n className={cn('flex h-6 w-6 cursor-pointer items-center justify-center rounded', colors[availableColor])}\n key={availableColor}\n onFocus={() => onChangeColor(availableColor)}\n value={availableColor}>\n <RadioGroup.Indicator asChild>\n <Icon name=\"tick\" className=\"!h-5 !w-5\" />\n </RadioGroup.Indicator>\n </RadioGroup.Item>\n ))}\n </RadioGroup.Root>\n );\n};\n","const mobiles = /iPhone|iPad|iPod|Android/i;\n\nexport const isMobileDevice = (navigator: Navigator | undefined) => !!navigator?.userAgent && mobiles.test(navigator.userAgent);\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon, IconName, IconProps } from '../../Icon/Icon';\nimport { Tag } from '../../Tag/Tag';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Color } from '../../../utils/colors';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\nimport { createOptionClassName } from '../utilities';\nimport { useSelect2Context } from './Context';\nimport { IconButton } from '../../IconButton/IconButton';\nimport { EditPopover } from './Edit';\nimport { isMobileDevice } from '../../../utils/device';\n\nexport type Select2OptionProps = Omit<ListboxPrimitive.Listbox2OptionProps, 'children'> & {\n children: string;\n color?: Color;\n icon?: React.ReactElement<IconProps> | IconName;\n textValue?: string;\n};\n\nexport const Option = React.forwardRef<HTMLDivElement, Select2OptionProps>(function Select2Option(props, ref) {\n const { children, color, icon, ...otherProps } = props;\n const className = createOptionClassName();\n const { onDelete, onEdit, listboxRef, multiple, ref: selectRef, setOpen, tags, value } = useSelect2Context();\n\n const hasValue = Array.isArray(value) ? !!value.length : value !== undefined;\n const isTag = tags && !!color;\n\n const handleClick = () => {\n if (!multiple) {\n setOpen(false);\n } else {\n selectRef.current?.focus();\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (isAriaSelectionKey(event)) {\n if (!multiple || event.key === 'Tab') {\n setOpen(false);\n }\n }\n };\n\n const popover =\n onEdit || onDelete\n ? popoverProps => (\n <EditPopover\n {...popoverProps}\n color={props.color}\n key={props.textValue ?? String(props.children)}\n text={props.textValue ?? String(props.children)}\n value={props.value}\n />\n )\n : undefined;\n\n return (\n <ListboxPrimitive.Option {...otherProps} className={className} onClick={handleClick} onKeyDown={handleKeyDown} ref={ref}>\n {hasValue ? (\n <Icon name=\"tick\" className=\"group-aria-selected:visible pointer-events-none invisible -mx-1 !h-4 !w-4\" />\n ) : null}\n {isTag ? (\n <Tag className=\"pointer-events-none\" color={color} icon={icon}>\n {children}\n </Tag>\n ) : (\n <>\n {icon ? typeof icon === 'string' ? <Icon name={icon} /> : icon : null}\n {children}\n </>\n )}\n {popover ? (\n <IconButton\n rounded\n icon=\"ellipsis-vertical\"\n appearance=\"discrete\"\n className={cn('group-aria-current:visible invisible ml-auto -mr-2 focus:!shadow-none group-hover:visible', {\n '!visible': isMobileDevice(window?.navigator),\n })}\n onClick={event => {\n event.stopPropagation();\n listboxRef?.current?.setActiveIndex(event.currentTarget.parentElement as HTMLDivElement);\n }}\n popover={popover}\n tabIndex={-1}\n />\n ) : null}\n </ListboxPrimitive.Option>\n );\n});\n","export const createOptionClassName = () =>\n 'group mb-px flex h-8 w-full text-sm flex-shrink-0 font-normal cursor-pointer items-center rounded bg-white px-2 leading-8 text-black aria-hidden:hidden gap-1.5 bg-white hover:bg-grey-100 aria-current:bg-grey-100 aria-disabled:text-black/25 aria-disabled:pointer-events-none';\n\nexport const createCollectionClassName = () => 'flex flex-col gap-px';\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\nimport { createCollectionClassName } from '../utilities';\n\nexport type Select2GroupProps = ListboxPrimitive.Listbox2GroupProps;\n\nexport const Group = React.forwardRef<HTMLDivElement, Select2GroupProps>(function Select2Group(props, ref) {\n const className = cn(createCollectionClassName(), props.className);\n return <ListboxPrimitive.Group {...props} className={className} ref={ref} />;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\n\nexport type Select2TitleProps = ListboxPrimitive.Listbox2TitleProps;\n\nexport const Title = React.forwardRef<HTMLDivElement, Select2TitleProps>(function Select2Title(props, ref) {\n const className = cn('flex items-center text-xs pl-2 h-8', props.className);\n return <ListboxPrimitive.Title {...props} className={className} ref={ref} />;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area';\n\nconst Bar = props => {\n const className = cn(`flex select-none touch-none transition-colors hover:bg-grey`, {\n 'w-[7px] hover:w-[14px] mr-[2px] hover:px-[2px] hover:mr-0': props.orientation === 'vertical',\n 'flex-col h-[7px] hover:h-[14px] mb-[2px] hover:py-[2px] hover:mb-0': props.orientation === 'horizontal',\n });\n return <ScrollAreaPrimitive.Scrollbar {...props} className={className} />;\n};\n\nconst Thumb = props => <ScrollAreaPrimitive.Thumb {...props} className=\"flex-[1] rounded bg-black opacity-50\" />;\n\nconst Corner = props => <ScrollAreaPrimitive.Corner {...props} classname=\"bg-grey-500\" />;\n\nexport type ScrollbarProps = Omit<ScrollAreaPrimitive.ScrollAreaProps, 'scrollHideDelay'>;\n\nexport const ScrollArea = (props: ScrollbarProps) => {\n const { children, ...otherProps } = props;\n\n return (\n <ScrollAreaPrimitive.Root {...otherProps} className={cn('overflow-hidden', props.className)}>\n <ScrollAreaPrimitive.Viewport className=\"h-full w-full\">{children}</ScrollAreaPrimitive.Viewport>\n <Bar orientation=\"vertical\">\n <Thumb />\n </Bar>\n <Bar orientation=\"horizontal\">\n <Thumb />\n </Bar>\n <Corner />\n </ScrollAreaPrimitive.Root>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { Tag } from '../../Tag/Tag';\nimport { Tooltip } from '../../Tooltip/Tooltip';\nimport { Icon } from '../../Icon/Icon';\nimport { Badge } from '../../Badge/Badge';\nimport { getInputClasses } from '../../Input/util';\nimport { Select2OptionValue } from '../types';\nimport { useSelect2Context } from './Context';\nimport { Select2OptionProps } from './Option';\nimport { getIndexOfFirstChildOverflowingParent } from '../../../utils/dom';\nimport { ScrollArea } from '../../ScrollArea/ScrollArea';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\n\ntype Select2TriggerProps = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n children: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const Trigger = React.forwardRef<HTMLButtonElement, Select2TriggerProps>(function Select2Trigger(props, ref) {\n const { multiple, value } = useSelect2Context();\n\n if (Array.isArray(value) || multiple) {\n const values = Array.isArray(value) ? value : value !== undefined ? [value] : undefined;\n return <Multiple {...props} ref={ref} values={values} />;\n }\n\n return <Single {...props} ref={ref} value={value} />;\n});\n\ntype ButtonProps = React.HTMLAttributes<HTMLButtonElement> &\n Omit<Select2TriggerProps, 'children' | 'open' | 'setValue' | 'value'>;\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(function Select2TriggerButton(props, ref) {\n const { children, onClick, tabIndex = 0, ...otherProps } = props;\n const { disabled, highlighted, invalid, open, readOnly } = useSelect2Context();\n\n const className = cn(\n 'cursor-pointer !px-1.5',\n getInputClasses({ ...props, disabled, highlighted, invalid, readOnly }).replace('w-full', ''),\n { 'w-full': !props.className?.includes('w-') },\n props.className\n );\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n if (disabled || readOnly) {\n event.preventDefault();\n return;\n }\n\n if (typeof onClick === 'function') {\n onClick(event);\n }\n };\n\n return (\n <button\n {...otherProps}\n aria-invalid={invalid ? true : undefined}\n aria-readonly={readOnly ? true : undefined}\n className={className}\n disabled={disabled}\n onClick={handleClick}\n ref={ref}\n role=\"combobox\"\n tabIndex={disabled || readOnly ? -1 : tabIndex}\n type=\"button\">\n {children}\n <Icon name={open ? 'chevron-up' : 'chevron-down'} className=\"pointer-events-none -mr-1 ml-auto\" />\n </button>\n );\n});\n\ntype SingleProps = Omit<Select2TriggerProps, 'value'> & { value?: Select2OptionValue };\n\nconst Single = React.forwardRef<HTMLButtonElement, SingleProps>(function Select2TriggerSingle(props, ref) {\n const { children, value, ...buttonProps } = props;\n const { disabled, readOnly, tags } = useSelect2Context();\n const contentClassName = cn('truncate flex items-center gap-1');\n\n const currentValue = children.find(matchesValue(value));\n\n let output;\n\n if (currentValue) {\n if (tags) {\n output = (\n <Tag\n className=\"truncate\"\n color={currentValue.props.color}\n disabled={disabled}\n icon={currentValue.props.icon}\n readOnly={readOnly}>\n {currentValue.props.children}\n </Tag>\n );\n } else {\n output = (\n <>\n {currentValue.props.icon ? (\n typeof currentValue.props.icon === 'string' ? (\n <Icon name={currentValue.props.icon} />\n ) : (\n currentValue.props.icon\n )\n ) : null}\n {currentValue.props.children}\n </>\n );\n }\n }\n\n return (\n <Button {...buttonProps} ref={ref}>\n <span className={contentClassName}>{output}</span>\n </Button>\n );\n});\n\ntype MultipleProps = Omit<Select2TriggerProps, 'value'> & {\n values?: Select2OptionValue[];\n};\n\nconst Multiple = React.forwardRef<HTMLButtonElement, MultipleProps>(function Select2TriggerMultiple(props, ref) {\n const { children, values = [], ...buttonProps } = props;\n const { disabled, open, readOnly, setValue, tags } = useSelect2Context();\n const buttonRef = useMergedRef<HTMLButtonElement>(ref);\n\n const valuesAsChildren = values.map(value =>\n children.find(c => c.props.value === value)\n ) as React.ReactElement<Select2OptionProps>[];\n\n let content;\n let { className } = buttonProps;\n\n if (open) {\n className = cn('absolute z-20', buttonProps.className);\n content = (\n <ScrollArea className=\"my-1 flex max-h-[5.5rem] flex-col\">\n <span className=\"flex flex-wrap gap-1\">\n {valuesAsChildren.map(child => (\n <Tag\n key={child.props.value}\n className=\"truncate\"\n color={tags ? child.props.color : undefined}\n disabled={disabled}\n icon={child.props.icon}\n onDelete={event => {\n event?.stopPropagation();\n event?.preventDefault();\n\n if (!disabled && !readOnly) {\n setValue(child.props.value);\n }\n }}\n readOnly={readOnly}>\n {child.props.children}\n </Tag>\n ))}\n </span>\n </ScrollArea>\n );\n } else {\n content = <MultipleValue key={String(open)} valuesAsChildren={valuesAsChildren} />;\n }\n\n return (\n <span\n className={cn('relative inline-flex flex-grow', { 'h-8': open })}\n style={{ width: open ? buttonRef.current?.offsetWidth : undefined }}>\n <Button {...buttonProps} className={className} ref={buttonRef}>\n {content}\n </Button>\n </span>\n );\n});\n\nconst MultipleValue = ({ valuesAsChildren }) => {\n const { disabled, open, readOnly, setValue, tags } = useSelect2Context();\n const [contentRef, setContentRef] = React.useState<HTMLSpanElement | null>(null);\n const boundaryIndex = contentRef ? getIndexOfFirstChildOverflowingParent(contentRef, 30) : undefined;\n\n const createClickHandler = tagValue => event => {\n event?.stopPropagation();\n event?.preventDefault();\n\n if (!disabled && !readOnly) {\n setValue(tagValue);\n }\n };\n\n return (\n <span className=\"relative flex items-center gap-1 overflow-hidden\">\n <span className=\"flex gap-1 truncate\" ref={el => setContentRef(el)}>\n {valuesAsChildren.map((child, index) => {\n const tag = (\n <Tag\n key={child.props.value}\n className={cn('cursor-pointer', {\n truncate: index === boundaryIndex,\n hidden: boundaryIndex !== undefined && boundaryIndex !== null ? index > boundaryIndex : false,\n })}\n color={tags ? child.props.color : undefined}\n disabled={disabled}\n icon={child.props.icon}\n onDelete={open ? createClickHandler(child.props.value) : undefined}\n readOnly={readOnly}>\n {child.props.children}\n </Tag>\n );\n\n if (index === boundaryIndex) {\n return (\n <Tooltip key={child.props.value} title={String(child.props.children)}>\n {tag}\n </Tooltip>\n );\n }\n\n return tag;\n })}\n </span>\n {boundaryIndex !== undefined && boundaryIndex !== null && boundaryIndex < valuesAsChildren.length - 1 ? (\n <Tooltip\n title={valuesAsChildren\n .slice(boundaryIndex + 1)\n .map(child => (child ? String(child.props.children) : ''))\n .join(', ')}>\n <Badge className=\"flex-shrink-0\">+{valuesAsChildren.length - (boundaryIndex + 1)}</Badge>\n </Tooltip>\n ) : null}\n </span>\n );\n};\n\nconst matchesValue = (value: undefined | any | any[]) => (child: React.ReactElement<any>) => {\n if (Array.isArray(value)) {\n return value.includes(child.props.value);\n }\n\n return child.props.value === value;\n};\n","export const isOverflowing = (element: HTMLElement | null) =>\n element !== null ? element.scrollWidth > element.offsetWidth : false;\n\nexport const getIndexOfFirstChildOverflowingParent = (element: HTMLElement, overscan = 0) => {\n let index = 0;\n let boundaryChildIndex: number | null = null;\n const clientRect = element.getBoundingClientRect();\n\n for (const child of Array.from(element.children)) {\n const right = child.getBoundingClientRect().right - clientRect.left;\n const width = clientRect.width - overscan;\n\n if (right > width) {\n boundaryChildIndex = index;\n break;\n }\n index++;\n }\n\n return boundaryChildIndex;\n};\n","import React from 'react';\nimport { usePreviousValue } from '../hooks/usePrevious';\n\n// taken from radix - https://github.com/radix-ui/primitives/blob/main/packages/react/select/src/Select.tsx#L1183-L1224\nexport const BubbleSelect = (props: React.SelectHTMLAttributes<HTMLSelectElement>) => {\n const { value, ...selectProps } = props;\n const ref = React.useRef<HTMLSelectElement>(null);\n const prevValue = usePreviousValue(value);\n\n // Bubble value change to parents (e.g form change event)\n React.useEffect(() => {\n const select = ref.current!;\n const descriptor = Object.getOwnPropertyDescriptor(window.HTMLSelectElement.prototype, 'value') as PropertyDescriptor;\n const setValue = descriptor.set;\n\n if (prevValue !== value && setValue) {\n if (Array.isArray(value)) {\n value.forEach(v => {\n const option: HTMLOptionElement | null = select.querySelector(`option[value='${v}']`);\n\n if (option) {\n option.selected = true;\n }\n });\n } else {\n setValue.call(select, value);\n }\n\n const event = new Event('change', { bubbles: true });\n select.dispatchEvent(event);\n }\n }, [prevValue, value]);\n\n /**\n * We purposefully do not use `type=\"hidden\"` here otherwise forms that\n * wrap it will not be able to access its value via the FormData API.\n *\n * We purposefully do not add the `value` attribute here to allow the value\n * to be set programatically and bubble to any parent form `onChange` event.\n * Adding the `value` will cause React to consider the programatic\n * dispatch a duplicate and it will get swallowed.\n */\n return <select {...selectProps} defaultValue={value} ref={ref} style={{ display: 'none' }} />;\n};\n","import React from 'react';\n\n// taken from radix\nfunction usePreviousValue<T>(value: T) {\n // The ref object is a generic container whose current property is mutable ...\n // ... and can hold any value, similar to an instance property on a class\n const ref = React.useRef<T>(value);\n\n // Store current value in ref\n React.useEffect(() => {\n ref.current = value;\n }, [value]); // Only re-run if value changes\n\n // Return previous value (happens before update in useEffect above)\n return ref.current;\n}\n\nexport { usePreviousValue };\n","import React from 'react';\nimport cn from 'classnames';\nimport { createCustomKeyboardEvent } from '../../../utils/input';\nimport { Input, InputProps } from '../../Input/Input';\nimport { useSelect2Context } from './Context';\nimport { Field } from '../../Field/Field';\nimport { isAriaSelectionKey } from '../../../utils/aria';\n\nexport type Select2SearchProps = InputProps & {};\n\nexport const Search = React.forwardRef<HTMLInputElement, Select2SearchProps>(function ListboxSearch(props, ref) {\n const { ...otherProps } = props;\n const { listboxRef, searchQuery, setSearchQuery, setValidationError, validationError } = useSelect2Context();\n\n const handleChange = event => {\n if (validationError) {\n setValidationError(undefined);\n }\n\n setSearchQuery(event.target.value);\n };\n\n const handleKeyDown = event => {\n // space is an aria selection key, so we have to remove it to allow spaces\n if (event.key === ' ') {\n return;\n }\n\n if (isAriaSelectionKey(event) || event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n event.preventDefault();\n // forward navigation events onto the underlying collection - we want arrow keys to work from inside the filter input\n listboxRef?.current?.dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n return;\n }\n };\n\n return (\n <Field\n className={cn('mx-1.5 mb-1.5 !min-h-fit ', { '!pb-0': !validationError })}\n invalid={!!validationError}\n message={validationError?.message}>\n <Input\n {...otherProps}\n aria-hidden\n autoFocus\n invalid={!!validationError}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n ref={ref}\n value={searchQuery}\n />\n </Field>\n );\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Color } from '../../../utils/colors';\nimport { Tag } from '../../Tag/Tag';\nimport { createOptionClassName } from '../utilities';\nimport { useSelect2Context } from './Context';\nimport { Select2OptionProps } from './Option';\nimport { useLocalization } from '../../Provider/Localization';\n\nexport type CreateProps = {\n onCreate: (name: string, color: Color | undefined) => Promise<Select2OptionProps>;\n options: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const getNextColor = (options: React.ReactElement<Select2OptionProps>[]): Color | undefined => {\n const occurences = options.reduce((occurences, option) => {\n if (option.props.color) {\n occurences[option.props.color] = occurences[option.props.color] ? occurences[option.props.color] + 1 : 1;\n }\n return occurences;\n }, {});\n\n const colors = Object.keys(occurences);\n\n if (colors.length) {\n return colors.sort((a, b) => occurences[b] - occurences[a])[0] as Color;\n }\n\n return undefined;\n};\n\nexport const Create = (props: CreateProps) => {\n const { onCreate: handleCreate, options } = props;\n const { multiple, searchQuery, setOpen, setSearchQuery, setValidationError, setValue } = useSelect2Context();\n const { texts } = useLocalization();\n\n // determine what the next color tag should be based on color occurences\n const nextColor = React.useMemo(() => getNextColor(options), [options]);\n\n if (!searchQuery) {\n return null;\n }\n\n const handleClick = async () => {\n try {\n const item = await handleCreate(searchQuery, nextColor);\n setValue(item.value);\n\n if (multiple) {\n setSearchQuery('');\n } else {\n setOpen(false);\n }\n } catch (error) {\n setValidationError(error as Error);\n }\n };\n\n const handleKeyDown = event => {\n if (isAriaSelectionKey(event)) {\n event.currentTarget.click();\n }\n };\n\n const className = cn('!w-[calc(100%_-_theme(spacing.3))] ml-1.5', createOptionClassName());\n return (\n <button className={className} onClick={handleClick} onKeyDown={handleKeyDown}>\n <span className=\"flex items-center gap-1.5\">\n {texts.select2.create}\n <Tag color={nextColor} className=\"cursor-pointer\">\n {searchQuery}\n </Tag>\n </span>\n </button>\n );\n};\n","import React from 'react';\nimport { ScrollArea } from '../../ScrollArea/ScrollArea';\nimport { Select2OptionProps } from './Option';\n\nexport type Select2CollectionProps = {\n children: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const Collection = (props: Select2CollectionProps) => {\n const { children } = props;\n\n return <ScrollArea className=\"flex max-h-[10.3rem] w-full flex-col gap-y-0.5 px-1.5\">{children}</ScrollArea>;\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport * as ListboxPrimitive from '../../primitives/Listbox2/Listbox2';\nimport { Select2OptionValue, Select2Value } from './types';\nimport { Option, Select2OptionProps } from './components/Option';\nimport { Group, Select2GroupProps } from './components/Group';\nimport { Select2TitleProps, Title } from './components/Title';\nimport { Select2Context } from './components/Context';\nimport { createCollectionClassName } from './utilities';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { createCustomKeyboardEvent } from '../../utils/input';\nimport { Trigger } from './components/Trigger';\nimport { useIsFormControl } from '../../hooks/useIsFormControl';\nimport { BubbleSelect } from '../../primitives/BubbleSelect';\nimport { Search } from './components/Search';\nimport { useChildren } from './hooks/useChildren';\nimport { Color } from '../../utils/colors';\nimport { Create } from './components/Create';\nimport { Collection } from './components/Collection';\nimport { CollectionRef } from '../../primitives/Collection/Collection';\nimport { useLocalization } from '../Provider/Localization';\n//import { All } from './components/All';\n\ntype Select2Texts = {\n allSelect: string;\n allDeselect: string;\n cancel: string;\n chooseColor: string;\n create: string;\n delete: string;\n save: string;\n search: string;\n searchOrCreate: string;\n};\n\ntype Select2Props = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n autoFocus?: boolean;\n children: React.ReactElement<Select2OptionProps>[];\n defaultValue?: Select2Value;\n emptyValue?: Select2OptionValue;\n disabled?: boolean;\n disableSearch?: boolean;\n highlighted?: boolean;\n invalid?: boolean;\n multiple?: boolean;\n name?: string;\n onChange?: (value: Select2Value) => void;\n onCreate?: (name: string, color: Color | undefined) => Promise<Select2OptionProps>;\n onDelete?: (value: Select2OptionValue) => Promise<void>;\n onEdit?: (value: Select2OptionValue, text: string, color: Color | undefined) => Promise<void>;\n readOnly?: boolean;\n required?: boolean;\n tags?: boolean;\n value?: Select2Value;\n};\ntype Select2PropsWithStatics = React.ForwardRefExoticComponent<Select2Props & React.RefAttributes<HTMLButtonElement>> & {\n Option: React.ForwardRefExoticComponent<Select2OptionProps>;\n Group: React.ForwardRefExoticComponent<Select2GroupProps>;\n Title: React.ForwardRefExoticComponent<Select2TitleProps>;\n};\n\nconst Select2 = React.forwardRef<HTMLButtonElement, Select2Props>(function Select2(props, ref) {\n const {\n children: initialChildren,\n defaultValue: defaultProp,\n disabled = false,\n disableSearch = false,\n emptyValue = undefined,\n highlighted = false,\n invalid = false,\n multiple = false,\n name,\n onChange,\n onCreate,\n onDelete,\n onEdit,\n readOnly = false,\n tabIndex = 0,\n tags = false,\n value: prop,\n ...otherProps\n } = props;\n\n // refs\n const internalRef = useMergedRef<HTMLButtonElement>(ref);\n const listboxRef = React.useRef<CollectionRef>(null);\n const searchRef = React.useRef<HTMLInputElement>(null);\n const { texts } = useLocalization();\n // align the listbox min width with the width of the input - it should never be smaller\n const dimensions = useBoundingClientRectListener(internalRef);\n\n // state\n const [open, setOpen] = React.useState(false);\n const [value, _setValue] = useControllableState<Select2Value>({\n // uncontrolled\n defaultProp,\n // controlled\n onChange,\n prop,\n });\n const setValue = ListboxPrimitive.createListboxValueSetter(multiple, _setValue);\n const [validationError, setValidationError] = React.useState<Error | undefined>();\n\n const { allChildren, filteredChildren, searchQuery, setSearchQuery } = useChildren({\n children: initialChildren,\n emptyValue,\n multiple,\n open,\n setValue,\n value,\n });\n\n // context\n const context = {\n disabled,\n highlighted,\n invalid,\n listboxRef,\n multiple,\n onCreate,\n onDelete,\n onEdit,\n open,\n readOnly,\n ref: internalRef,\n searchQuery,\n searchRef,\n setOpen,\n setSearchQuery,\n setValidationError,\n setValue,\n tags,\n validationError,\n value,\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLElement>) => {\n if (open) {\n event.preventDefault();\n } else if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n setOpen(true);\n }\n\n // the focus should always remain on the input, so we forward events on to the listbox\n listboxRef.current?.dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n };\n\n const className = cn('border-grey-300 rounded border bg-white py-1.5 shadow-md outline-none', createCollectionClassName());\n\n return (\n <Select2Context.Provider value={context}>\n <PopoverPrimitive.Root open={open} onOpenChange={setOpen}>\n <ControlledHiddenField\n emptyValue={emptyValue}\n multiple={multiple || tags}\n name={name}\n options={allChildren.map(child => child.props.value)}\n parentRef={internalRef}\n setValue={setValue}\n value={value}\n />\n <PopoverPrimitive.Trigger asChild data-taco=\"Select2\">\n <Trigger {...otherProps} aria-haspopup=\"listbox\" onKeyDown={handleKeyDown} ref={internalRef}>\n {allChildren}\n </Trigger>\n </PopoverPrimitive.Trigger>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n asChild\n align=\"start\"\n onOpenAutoFocus={event => {\n event.preventDefault();\n event.stopPropagation();\n internalRef.current?.focus();\n }}\n onCloseAutoFocus={event => {\n event.preventDefault();\n event.stopPropagation();\n internalRef.current?.focus();\n }}\n sideOffset={4}\n tabIndex={-1}>\n <div className={className} style={{ minWidth: dimensions?.width ? `${dimensions.width}px` : undefined }}>\n {!disableSearch && (allChildren.length > 0 || onCreate) ? (\n <Search\n placeholder={onCreate ? texts.select2.searchOrCreate : texts.select2.search}\n ref={searchRef}\n />\n ) : null}\n {allChildren.length <= 0 ? (\n <div className=\"text-grey-700 -mt-0.5 flex h-8 items-center px-2\" role=\"presentation\">\n No results found...\n </div>\n ) : (\n <ListboxPrimitive.Root\n className=\"flex flex-col gap-0.5\"\n customSelector=\":scope > button\"\n disabled={disabled}\n multiple={multiple}\n readOnly={readOnly}\n ref={listboxRef}\n setValue={setValue}\n tabIndex={-1}\n value={value}>\n {/*multiple && !searchQuery && Array.isArray(value) ? (\n <All\n children={allChildren}\n onToggle={_setValue}\n selected={value.length === allChildren.length}\n />\n ) : null*/}\n <Collection>{filteredChildren}</Collection>\n {onCreate ? <Create onCreate={onCreate} options={allChildren} /> : null}\n </ListboxPrimitive.Root>\n )}\n </div>\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n </Select2Context.Provider>\n );\n}) as Select2PropsWithStatics;\nSelect2.Option = Option;\nSelect2.Group = Group;\nSelect2.Title = Title;\n\nconst ControlledHiddenField = props => {\n const { emptyValue, multiple, name, options, parentRef, value, setValue } = props;\n const isFormControl = useIsFormControl(parentRef, () => setValue(multiple ? [] : undefined));\n\n let bubbleValue;\n\n if (isFormControl) {\n if (value !== undefined) {\n if (multiple) {\n bubbleValue = Array.isArray(value) ? value.map(String) : [value === null ? '' : String(value)];\n } else {\n bubbleValue = value === null ? '' : String(value);\n }\n }\n\n return (\n <BubbleSelect aria-hidden key={String(bubbleValue)} multiple={multiple} name={name} value={bubbleValue}>\n {emptyValue !== undefined ? <option value={emptyValue} /> : null}\n {options.map(option => (\n <option key={String(option)} value={String(option)} />\n ))}\n </BubbleSelect>\n );\n }\n\n return null;\n};\nSelect2.displayName = 'Select2';\n\nexport { Select2 };\n\nexport type {\n Select2Texts,\n Select2GroupProps,\n Select2OptionProps,\n Select2OptionValue,\n Select2Value,\n Select2Props,\n Select2TitleProps,\n};\n","import React from 'react';\nimport { Option, Select2OptionProps } from '../components/Option';\nimport { Select2OptionValue, Select2Value } from '../types';\n\nexport type useChildrenArgs = {\n children: React.ReactElement<Select2OptionProps>[];\n emptyValue?: Select2OptionValue;\n multiple?: boolean;\n open?: boolean;\n setValue: (nextValue: Select2OptionValue) => void;\n value?: Select2Value;\n};\nexport const useChildren = ({ children: initialChildren, emptyValue, multiple, open, setValue, value }: useChildrenArgs) => {\n const [searchQuery, setSearchQuery] = React.useState<string>('');\n\n // support empty value - probably a more elegant way to achieve this\n const allChildren: React.ReactElement<Select2OptionProps>[] = React.useMemo(() => {\n const initial = initialChildren || [];\n if (emptyValue !== undefined && !multiple) {\n return [<Option key=\"__empty\" children=\"\" value={emptyValue} />, ...initial];\n }\n\n return initial;\n }, [initialChildren, emptyValue]);\n\n // set an initial value if none is set, we have to trigger state updates for controlled components\n React.useEffect(() => {\n if (!multiple && emptyValue === undefined && value === undefined) {\n setValue(allChildren?.[0]?.props.value);\n }\n }, []);\n\n React.useEffect(() => {\n if (!open) {\n setSearchQuery('');\n }\n }, [open]);\n\n // apply filtering\n const filteredChildren: React.ReactElement<Select2OptionProps>[] = React.useMemo(() => {\n return allChildren.filter(child => {\n if (child.props.textValue) {\n return child.props.textValue.toLowerCase().includes(searchQuery.toLowerCase());\n }\n\n return String(child.props.children).toLowerCase().includes(searchQuery.toLowerCase());\n });\n }, [allChildren, searchQuery]);\n\n return {\n allChildren,\n filteredChildren,\n searchQuery,\n setSearchQuery,\n };\n};\n","import * as React from 'react';\n\n// taken from radix\n// determines whether a given ref is a descendant of a form element\nexport const useIsFormControl = (ref: React.RefObject<HTMLElement>, reset: () => void) => {\n const [isFormControl, setIsFormControl] = React.useState(false);\n\n React.useEffect(() => {\n let formElement: HTMLFormElement | null;\n\n if (ref.current) {\n formElement = ref.current.closest('form');\n setIsFormControl(!!formElement);\n\n if (reset && formElement) {\n formElement.addEventListener('reset', reset);\n }\n\n ref.current.closest('form')?.addEventListener('reset', reset);\n }\n\n return () => {\n if (formElement) {\n formElement.removeEventListener('reset', reset);\n }\n };\n }, [ref]);\n\n return isFormControl;\n};\n","import React from 'react';\nimport { TableRow, TableCell, TableChildren, InternalTableRow, InternalTableColumn, SortRule } from './types';\nimport { SortingRule } from 'react-table';\n\nexport const sanitizeRowProps = (row: InternalTableRow, rowExpansionRenderer: any): TableRow<any> => {\n const props: TableRow<any> = {\n index: row.index,\n indexPath: row.id,\n values: row.original,\n };\n\n if (row.subRows?.length > 0) {\n props.isExpanded = !!row.isExpanded;\n props.depth = row.depth;\n props.toggleRowExpanded = () => row.toggleRowExpanded(!props.isExpanded);\n } else if (rowExpansionRenderer) {\n props.isExpanded = !!row.isExpanded;\n props.toggleRowExpanded = () => row.toggleRowExpanded(!props.isExpanded);\n }\n\n if (row.toggleRowEditing) {\n props.isEditing = !!row.isEditing;\n props.toggleRowEditing = row.toggleRowEditing;\n }\n\n return props;\n};\n\nexport const getColumnsFromChildren = (children: TableChildren<any>, rowExpansionRenderer: any) => {\n const sortRules: SortingRule<any>[] = [];\n\n const columns = React.Children.toArray(children)\n .filter((child: any) => !!child && !child.props.hidden) // skip falsey or hidden columns\n .map(({ props: { children: groupChildren, ...props } }: any) => {\n const column: InternalTableColumn & { disableSortBy: boolean | undefined } = { ...props };\n\n column.sortType = column.sortType || 'auto';\n column.disableSortBy = column.disableSorting;\n\n // this is a Table.Group - TODO: Find a better way to determine the child type\n if (props.title && groupChildren) {\n column.Header = props.title;\n\n const { columns: groupColumns, sortRules: groupSortRules } = getColumnsFromChildren(\n groupChildren,\n rowExpansionRenderer\n );\n column.columns = groupColumns;\n groupSortRules.forEach(sort => sortRules.push(sort));\n } else {\n column.accessor = props.accessor;\n column.Header = props.headRenderer || '';\n column.Cell = (columnProps: any) => {\n const cell: TableCell<any> = {\n accessor: columnProps.cell.column.id,\n row: sanitizeRowProps(columnProps.cell.row, rowExpansionRenderer),\n value: columnProps.cell.value,\n };\n\n if (cell.row.isEditing && typeof props.editRenderer === 'function') {\n return props.editRenderer(cell);\n }\n\n return typeof props.cellRenderer === 'function' ? props.cellRenderer(cell) ?? null : cell.value ?? null;\n };\n\n // custom props\n column.align = props.align;\n column.flex = props.flex;\n\n if (props.sort && !props.disableSorting) {\n sortRules.push({\n id: props.accessor,\n desc: props.sort === 'desc',\n });\n }\n }\n\n return column;\n });\n\n return { columns, sortRules };\n};\n\nexport const getInternalSortRules = <T>(sortRules: SortRule<T>[] | undefined): SortingRule<T>[] | undefined => {\n return sortRules?.map<SortingRule<T>>(rule => ({ id: rule.accessor, desc: rule.desc }));\n};\n","import { SortTypes, TableRow } from '../types';\n\nconst getTime = (value: any): number | undefined => {\n const parsedValue: Date = typeof value === 'string' ? new Date(value) : value;\n return parsedValue?.getTime ? parsedValue.getTime() : undefined;\n};\n\nconst getNumber = (amount = '', decimalSeparator = ','): number | undefined => {\n if (typeof amount === 'number') {\n return amount;\n }\n\n if (amount === null || !amount.length) {\n return undefined;\n }\n\n let value;\n\n if (decimalSeparator === ',') {\n // replace digit seperator then replace decimal separator\n value = Number(amount.replace(/\\./g, '').replace(',', '.'));\n } else {\n // replace digit seperator\n value = Number(amount.replace(/,/g, ''));\n }\n\n return Number.isNaN(value) ? undefined : value;\n};\n\nconst getString = (value: any): string | undefined => {\n if (value) {\n return String(value).toLowerCase();\n }\n\n return undefined;\n};\n\nconst guess = (value: any): any => {\n if (typeof value === 'boolean') {\n return value;\n }\n\n return isNaN(value) ? getString(value) : Number(value);\n};\n\nconst compareBasic = (a: any, b: any) => {\n // places undefined values first in ascending order instead of descending\n if (a !== undefined && b === undefined) {\n return 1;\n }\n\n return a === b ? 0 : a > b ? 1 : -1;\n};\n\nconst stringsLocaleCompare = (a: string, b: string, locale: string): 0 | 1 | -1 => {\n // In some browsers 'localCompare' may return -2 or 2 instead of -1 or 1\n const compareResult = a.localeCompare(b, locale);\n return compareResult === 0 ? 0 : compareResult > 0 ? 1 : -1;\n};\n\nconst compareBasicStrings = (a: string | undefined, b: string | undefined, locale: string): 0 | 1 | -1 => {\n if (a && b) {\n return stringsLocaleCompare(a, b, locale);\n }\n\n return compareBasic(a, b);\n};\n\ntype SortHandler<T> = (rowA: TableRow<T>, rowB: TableRow<T>, columnId: string) => 0 | 1 | -1;\n\nexport const sortTypes = (locale: string): Record<SortTypes, SortHandler<any>> => {\n return {\n datetime: (rowA, rowB, columnId) => {\n const a = getTime(rowA.values[columnId]);\n const b = getTime(rowB.values[columnId]);\n return compareBasic(a, b);\n },\n string: (rowA, rowB, columnId) => {\n const a = getString(rowA.values[columnId]);\n const b = getString(rowB.values[columnId]);\n return compareBasicStrings(a, b, locale);\n },\n number: (rowA, rowB, columnId) => {\n const a = getNumber(rowA.values[columnId]);\n const b = getNumber(rowB.values[columnId]);\n return compareBasic(a, b);\n },\n boolean: (rowA, rowB, columnId) => {\n const a = !!rowA.values[columnId];\n const b = !!rowB.values[columnId];\n return compareBasic(a, b);\n },\n auto: (rowA, rowB, columnId) => {\n const a = guess(rowA.values[columnId]);\n const b = guess(rowB.values[columnId]);\n if (typeof a === 'string' && typeof b === 'string') {\n return compareBasicStrings(a, b, locale);\n } else {\n return compareBasic(a, b);\n }\n },\n };\n};\n","import React from 'react';\nimport { actions, PluginHook } from 'react-table';\n\nconst pluginName = 'useRowEditing';\n\nactions.resetRowEditing = 'resetRowEditing';\nactions.toggleRowEditing = 'toggleRowEditing';\nactions.toggleEditing = 'toggleEditing';\n\nfunction reducer(state: any, action: any): object {\n if (action.type === actions.init) {\n return {\n allowEditing: true,\n editingRowUniqueId: null,\n ...state,\n };\n }\n\n if (action.type === actions.resetRowEditing || action.type === actions.resetPage || action.type === actions.gotoPage) {\n return {\n ...state,\n editingRowUniqueId: null,\n };\n }\n\n if (action.type === actions.toggleRowEditing) {\n const { id } = action;\n return {\n ...state,\n editingRowUniqueId: id,\n };\n }\n\n if (action.type === actions.toggleEditing) {\n return {\n ...state,\n allowEditing: !state.allowEditing,\n };\n }\n\n return state;\n}\n\nfunction useInstance(instance: any): void {\n const { dispatch } = instance;\n\n const resetRowEditing = React.useCallback(() => {\n dispatch({ type: actions.resetRowEditing });\n }, [dispatch]);\n\n const toggleRowEditing = React.useCallback(\n id => {\n dispatch({ type: actions.toggleRowEditing, id });\n },\n [dispatch]\n );\n\n const toggleEditing = React.useCallback(() => {\n dispatch({ type: actions.toggleEditing });\n }, [dispatch]);\n\n Object.assign(instance, {\n resetRowEditing,\n toggleRowEditing,\n toggleEditing,\n });\n}\n\nconst prepareRow =\n <T extends {}>(uniqueId: keyof T) =>\n (row: any, { instance }: any): void => {\n const id = row.original[uniqueId];\n\n row.toggleRowEditing = () => {\n if (instance.state.editingRowUniqueId === id) {\n instance.resetRowEditing();\n } else {\n instance.toggleRowEditing(id);\n }\n };\n\n row.isEditing = row.original._createKey\n ? instance.state.editingRowUniqueId === row.original._createKey\n : instance.state.editingRowUniqueId === id;\n row.canEdit = instance.state.allowEditing && (row.isEditing || !instance.state.editingRowUniqueId);\n };\n\nexport const useRowEditing = <T extends {}>(uniqueId: keyof T | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n if (uniqueId) {\n hooks.stateReducers.push(reducer);\n hooks.useInstance.push(useInstance);\n hooks.prepareRow.push(prepareRow<T>(uniqueId));\n }\n };\n plugin.pluginName = pluginName;\n\n return plugin;\n};\n","import React from 'react';\nimport { PluginHook } from 'react-table';\nimport { InView } from 'react-intersection-observer';\nimport { sanitizeRowProps } from '../../util';\nimport { IconButton } from '../../../IconButton/IconButton';\nimport { LocalizationTexts } from '../../../Provider/Localization';\nimport { Menu } from '../../../Menu/Menu';\nimport { RowAction, RowActionHandler, TableRow } from '../../types';\n\nconst actionGroupClassName = '-mt-1 -mb-1 h-8 flex';\n\nconst hasActions = (inlineEditingUniqueId: any, handlers: any, actions: RowActionHandler<any>[] | undefined): number => {\n return (\n !!actions ||\n handlers.onRowCreate ||\n handlers.onRowCopy ||\n handlers.onRowDelete ||\n !!inlineEditingUniqueId ||\n handlers.onRowEdit\n );\n};\n\nconst getActions = (\n actions: RowActionHandler<any>[] | undefined,\n row: TableRow<any> | undefined = undefined\n): [RowAction<any>[], RowAction<any>[]] => {\n const primary: RowAction<any>[] = [];\n const secondary: RowAction<any>[] = [];\n\n if (actions) {\n let visibleActions = actions.filter(x => !!x && typeof x !== 'boolean') as RowAction<any>[];\n\n if (row) {\n visibleActions = visibleActions.filter(action => {\n if (action.visible !== undefined) {\n if (typeof action.visible === 'function') {\n return action.visible(row);\n }\n\n return action.visible;\n }\n\n return true;\n });\n }\n\n visibleActions.forEach(action => {\n if (action.showOnRow) {\n primary.push(action);\n } else {\n secondary.push(action);\n }\n });\n }\n\n return [primary, secondary];\n};\n\nconst getLength = (inlineEditingUniqueId: any, handlers: any, actions: RowActionHandler<any>[] | undefined): number => {\n const [primaryActions, secondaryActions] = getActions(actions);\n\n let length = primaryActions.length + (secondaryActions.length ? 1 : 0);\n\n if (handlers.onRowCreate) {\n length++;\n }\n\n if (handlers.onRowCopy) {\n length++;\n }\n\n if (handlers.onRowDelete) {\n length++;\n }\n\n if (!!inlineEditingUniqueId || handlers.onRowEdit) {\n length++;\n\n if (length < 2) {\n length++;\n }\n }\n\n return length;\n};\n\nconst getActionProps = (action: RowAction<any>, row: TableRow<any>) => {\n return {\n 'aria-label': typeof action.tooltip === 'function' ? action.tooltip(row) : action.tooltip,\n disabled: typeof action.disabled === 'function' ? action.disabled(row) : action.disabled,\n onClick: (event: React.MouseEvent<HTMLElement>) => {\n action.onClick(row, event);\n },\n };\n};\n\nconst EditModeActions = () => {\n React.useEffect(() => {\n const listener = (event: any) => {\n if (event.key === 'Escape' && event.target?.form?.reset) {\n event.preventDefault();\n event.target.form.reset();\n }\n };\n\n document.addEventListener('keydown', listener);\n\n return () => {\n document.removeEventListener('keydown', listener);\n };\n }, []);\n\n return (\n <div className={actionGroupClassName}>\n <IconButton appearance=\"primary\" icon=\"tick\" type=\"submit\" className=\"mr-2\" />\n <IconButton appearance=\"ghost\" icon=\"close\" type=\"reset\" />\n </div>\n );\n};\n\nexport const useRowActions = <T extends {}>(\n inlineEditingUniqueId: keyof T | undefined,\n handlers: any,\n actions: RowActionHandler<T>[] | undefined,\n rowExpansionRenderer: any,\n texts: LocalizationTexts,\n windowed = false\n): PluginHook<{}> => {\n const inlineEditing = !!inlineEditingUniqueId;\n const actionsLength = getLength(inlineEditingUniqueId, handlers, actions);\n\n const plugin = (hooks: any): void => {\n if (hasActions(inlineEditingUniqueId, handlers, actions)) {\n hooks.visibleColumns.push((columns: any) => [\n ...columns,\n {\n id: '_actions',\n className: 'flex justify-end px-1 overflow-visible',\n flex: `0 0 calc((${actionsLength} * 2rem) + .5rem)`,\n Cell: ({ row }: any) => {\n if (row.isEditing) {\n return <EditModeActions />;\n }\n\n const sanitizedRow = sanitizeRowProps(row, rowExpansionRenderer);\n const [primaryActions, secondaryActions] = getActions(actions, sanitizedRow);\n\n const output = (\n <>\n {handlers.onRowCreate && (\n <IconButton\n appearance=\"discrete\"\n icon=\"circle-plus\"\n aria-label={texts.table.newSubRow}\n tooltip={texts.table.newSubRow}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n\n if (!row.isExpanded) {\n row.toggleRowExpanded();\n }\n\n handlers.onRowCreate(sanitizedRow, event);\n }}\n />\n )}\n {(inlineEditing || handlers.onRowEdit) && (\n <IconButton\n appearance=\"discrete\"\n icon=\"edit\"\n aria-label={texts.table.edit}\n tooltip={texts.table.edit}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n row.setActive();\n\n if (inlineEditing) {\n row.toggleRowEditing();\n } else if (handlers.onRowEdit) {\n event.persist();\n handlers.onRowEdit(sanitizedRow, event);\n }\n }}\n />\n )}\n {handlers.onRowCopy && (\n <IconButton\n appearance=\"discrete\"\n icon=\"copy\"\n aria-label={texts.table.copy}\n tooltip={texts.table.copy}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n handlers.onRowCopy(sanitizedRow, event);\n }}\n />\n )}\n {handlers.onRowDelete && (\n <IconButton\n appearance=\"discrete\"\n icon=\"delete\"\n aria-label={texts.table.del}\n tooltip={texts.table.del}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n handlers.onRowDelete(sanitizedRow, event);\n }}\n />\n )}\n {primaryActions.map((action: RowAction<T>, index: number) => (\n <IconButton\n {...getActionProps(action, sanitizedRow)}\n key={index}\n appearance=\"discrete\"\n icon={typeof action.icon === 'function' ? action.icon(sanitizedRow) : action.icon}\n tooltip={\n typeof action.tooltip === 'function' ? action.tooltip(sanitizedRow) : action.tooltip\n }\n />\n ))}\n {secondaryActions.length ? (\n <Menu>\n <Menu.Trigger>\n <IconButton\n appearance=\"discrete\"\n icon=\"ellipsis-vertical\"\n aria-label={texts.table.actions}\n tooltip={texts.table.actions}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n row.setActive();\n }}\n />\n </Menu.Trigger>\n <Menu.Content>\n {secondaryActions.map((action: RowAction<T>, index: number) => (\n <Menu.Item\n key={index}\n icon={\n typeof action.icon === 'function'\n ? action.icon(sanitizedRow)\n : action.icon\n }\n {...getActionProps(action, sanitizedRow)}>\n {typeof action.text === 'function' ? action.text(sanitizedRow) : action.text}\n </Menu.Item>\n ))}\n </Menu.Content>\n </Menu>\n ) : null}\n </>\n );\n\n if (windowed) {\n return <div className={actionGroupClassName}>{output}</div>;\n }\n\n return (\n <InView rootMargin=\"100px 0px\">\n {({ inView, ref }) => (\n <div className={actionGroupClassName} ref={ref}>\n {inView ? output : null}\n </div>\n )}\n </InView>\n );\n },\n },\n ]);\n }\n };\n plugin.pluginName = 'useRowActions';\n return plugin;\n};\n","import React from 'react';\nimport { actions, PluginHook } from 'react-table';\nimport { Icon } from '../../../Icon/Icon';\nimport { RowDragHandler } from '../../types';\nimport { sanitizeRowProps } from '../../util';\n\nconst pluginName = 'useRowDraggable';\n\nactions.resetRowDragging = 'resetRowDragging';\nactions.toggleRowDragging = 'toggleRowDragging';\n\nfunction reducer(state: any, action: any): object {\n if (action.type === actions.init) {\n return {\n draggingRowIndexPath: null,\n ...state,\n };\n }\n\n if (action.type === actions.resetRowDragging) {\n return {\n ...state,\n draggingRowIndexPath: null,\n };\n }\n\n if (action.type === actions.toggleRowDragging) {\n const { indexPath } = action;\n return {\n ...state,\n draggingRowIndexPath: indexPath,\n };\n }\n\n return state;\n}\n\nconst prepareRow = (row: any, { instance }: any): void => {\n row.toggleRowDragging = () => {\n if (instance.state.draggingRowIndexPath === row.id) {\n instance.dispatch({ type: actions.resetRowDragging });\n } else {\n instance.dispatch({ type: actions.toggleRowDragging, indexPath: row.id });\n }\n };\n\n if (instance.state.draggingRowIndexPath) {\n row.isDragging = instance.state.draggingRowIndexPath === row.id || !!instance.state.selectedRowIds?.[row.id];\n } else {\n row.isDragging = false;\n }\n};\n\nconst visibleColumns = (columns: any) => {\n return [\n {\n id: 'draggable',\n className: 'yt-table__cell--draggable flex-col px-0',\n Cell: () => <Icon name=\"drag\" className=\"text-grey-700 invisible w-[20px] cursor-grab\" />,\n flex: '0 0 20px',\n },\n ...columns,\n ];\n};\n\nconst getRowProps =\n (onRowDrag: RowDragHandler<any>) =>\n (props: any, { instance, row }: any) => {\n const onDragStart = (event: React.DragEvent): void => {\n event.persist();\n row.toggleRowDragging();\n\n const indexPaths = [row.id, ...Object.keys(instance.state.selectedRowIds)];\n const data = instance.rows.filter((r: any) => indexPaths.includes(r.id)).map(sanitizeRowProps);\n\n const showPlaceholder = (placeholder: string) => {\n const element = window.document.createElement('div');\n element.id = 'yt-table__drag__placeholder';\n element.innerText = placeholder;\n window.document.body.appendChild(element);\n\n if (typeof DataTransfer.prototype.setDragImage === 'function') {\n event.dataTransfer.setDragImage(element, 0, 20);\n }\n };\n\n onRowDrag(data, showPlaceholder, event);\n };\n\n const onDragEnd = (): void => {\n const element: HTMLElement | null = document.getElementById('yt-table__drag__placeholder');\n\n if (element && element.parentNode) {\n element.parentNode.removeChild(element);\n }\n\n row.toggleRowDragging();\n };\n\n return [\n props,\n {\n draggable: true,\n onDragStart,\n onDragEnd,\n },\n ];\n };\n\nexport const useRowDraggable = (onRowDrag: RowDragHandler<any> | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n if (onRowDrag) {\n hooks.stateReducers.push(reducer);\n hooks.prepareRow.push(prepareRow);\n hooks.visibleColumns.push(visibleColumns);\n hooks.getRowProps.push(getRowProps(onRowDrag));\n }\n };\n plugin.pluginName = pluginName;\n\n return plugin;\n};\n","import React from 'react';\nimport { useTable as useReactTable, useExpanded, useSortBy, usePagination, useRowState } from 'react-table';\nimport { getColumnsFromChildren, getInternalSortRules } from '../util';\nimport { sortTypes } from '../util/sortTypes';\nimport { useRowEditing } from './plugins/useRowEditing';\nimport { useRowActions } from './plugins/useRowActions';\nimport { useRowSelect } from './plugins/useRowSelect';\nimport {\n InternalTable,\n InternalTableRow,\n PaginationHandler,\n RowActiveHandler,\n SortHandler,\n TableProps,\n TableRef,\n} from '../types';\nimport { useTableKeyboardNavigation } from './useTableKeyboardNavigation';\nimport { useLocalization } from '../../Provider/Localization';\nimport { useRowDraggable } from './plugins/useRowDraggable';\nimport { sanitizeRowProps } from '../util';\n\nconst useTableRowActive = (\n activeIndex: number | undefined,\n rows: InternalTableRow[],\n rowExpansionRenderer: TableProps<any>['rowExpansionRenderer'],\n handleonRowActive: RowActiveHandler<any> | undefined\n) => {\n React.useEffect(() => {\n if (activeIndex !== undefined && rows.length && handleonRowActive) {\n const focusedRow = rows[activeIndex];\n if (focusedRow) {\n const sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);\n handleonRowActive(sanitizedFocusedRow);\n }\n }\n }, [activeIndex, rows]);\n};\n\nconst useTableInstance = (instance: any, ref: React.RefObject<TableRef>): object => {\n const sanitizedInstance = React.useMemo(\n () => ({\n toggleAllRowsExpanded: instance.toggleAllRowsExpanded,\n toggleHideAllColumns: instance.toggleHideAllColumns,\n toggleHideColumn: instance.toggleHideColumn,\n toggleEditing: instance.toggleEditing,\n toggleRowEditing: instance.toggleRowEditing,\n resetRowEditing: instance.resetRowEditing,\n toggleRowExpanded: instance.toggleRowExpanded,\n toggleSortBy: instance.toggleSortBy,\n }),\n []\n );\n\n React.useEffect(() => {\n if (ref?.current) {\n ref.current.instance = sanitizedInstance;\n }\n }, [ref]);\n\n return sanitizedInstance;\n};\n\nconst useTablePaginationListener = (disablePagination: boolean, onPaginate: PaginationHandler | undefined, state: any): void => {\n React.useEffect(() => {\n if (!disablePagination && onPaginate) {\n onPaginate(state.pageIndex, state.pageSize);\n }\n }, [state.pageIndex, state.pageSize]);\n};\n\nconst useTableSortingListener = (\n data: any[],\n sortedRows: any[],\n onSort: SortHandler<any> | undefined,\n manualSorting: boolean,\n state: any\n): void => {\n React.useEffect(() => {\n if (onSort) {\n const sortRules = state.sortBy.map((rule: any) => ({ accessor: rule.id, desc: rule.desc }));\n\n if (manualSorting) {\n onSort(sortRules);\n } else {\n let sortedData;\n\n if (sortRules.length && sortedRows?.length) {\n sortedData = sortedRows.map((row: any) => row.original);\n }\n\n onSort(sortRules, sortedData || data);\n }\n }\n }, [onSort && JSON.stringify(state.sortBy), manualSorting]);\n};\n\nconst DEFAULT_PAGE_SIZE = 10;\n\nexport const useTable = <T extends {}>(\n props: TableProps<T> & { windowed?: boolean },\n ref: React.RefObject<TableRef>\n): InternalTable => {\n const {\n children,\n data,\n dangerouslyHijackGlobalKeyboardNavigation: _,\n onRowClick,\n onRowDrag,\n onSelectedRows,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n selectedRows,\n\n // sorting\n disableSorting,\n manualSorting,\n onSort,\n sortRules,\n\n //index\n activeIndex: _1,\n defaultActiveIndex: _2,\n onChangeActiveIndex: _3,\n\n // pagination\n disablePagination = true,\n length,\n onPaginate,\n pageSize = DEFAULT_PAGE_SIZE,\n pageIndex = 0,\n\n // row editing\n inlineEditingUniqueId = undefined,\n onRowCreate,\n\n // actions\n actions,\n onRowEdit,\n onRowCopy,\n onRowDelete,\n onRowActive,\n\n windowed = false,\n\n ...otherProps\n } = props;\n\n if ((onSelectedRows && !selectedRows) || (!onSelectedRows && selectedRows)) {\n throw new Error(\n 'Selected rows in a Table component are fully controlled - you must pass both the `onSelectedRows` and `selectedRows` props when using row selection'\n );\n }\n\n const { texts, locale } = useLocalization();\n const { columns, sortRules: defaultSortRules } = React.useMemo(\n () => getColumnsFromChildren(children, rowExpansionRenderer),\n [children, rowExpansionRenderer]\n );\n\n const manualPagination = !disablePagination && !!onPaginate && !!length;\n\n const {\n headerGroups,\n rows,\n sortedRows,\n prepareRow: prepareBaseRow,\n state,\n // pagination\n page,\n gotoPage,\n setPageSize,\n ...instance\n }: any = useReactTable(\n {\n columns,\n data,\n initialState: {\n // @ts-expect-error: not sure how to type this correctly right now\n sortBy: getInternalSortRules(sortRules) || defaultSortRules,\n pageSize: !disablePagination ? pageSize : undefined,\n pageIndex: !disablePagination ? pageIndex : undefined,\n },\n manualPagination,\n pageCount: manualPagination && length ? Math.ceil(length / pageSize) : -1,\n manualSortBy: manualSorting,\n disableSortBy: disableSorting,\n // most of these resets preventions are needed for editing mode\n autoResetExpanded: false,\n autoResetSelectedRows: false,\n autoResetSortBy: false,\n autoResetPage: false,\n sortTypes: React.useMemo(() => sortTypes(locale), []),\n useControlledState: currentState => {\n return React.useMemo(\n () => ({\n ...currentState,\n selectedRowIds: selectedRows || [],\n }),\n [currentState, selectedRows]\n );\n },\n },\n useRowState,\n useSortBy,\n useExpanded,\n usePagination,\n useRowSelect(onSelectedRows),\n useRowDraggable(onRowDrag),\n useRowEditing(inlineEditingUniqueId),\n useRowActions(\n inlineEditingUniqueId,\n { onRowCreate, onRowEdit, onRowCopy, onRowDelete },\n actions,\n rowExpansionRenderer,\n texts,\n windowed\n )\n );\n\n useTablePaginationListener(disablePagination, onPaginate, state);\n useTableSortingListener(data, sortedRows, onSort, !!manualSorting, state);\n\n const sanitizedInstance = useTableInstance(instance, ref);\n\n const visibleRows = !disablePagination && !manualPagination ? page : rows;\n\n const [activeIndex, setActiveIndex, handleKeyDown, handleFocus] = useTableKeyboardNavigation<T>(\n props,\n visibleRows,\n { onRowClick, onRowCreate, onRowEdit, onRowCopy, onRowDelete, rowExpansionRenderer },\n ref\n );\n\n useTableRowActive(activeIndex, rows, rowExpansionRenderer, onRowActive);\n\n const prepareRow = React.useCallback(\n (row: any, index: number) => {\n prepareBaseRow(row);\n row.setActive = () => setActiveIndex(index);\n },\n [prepareBaseRow, setActiveIndex]\n );\n\n return {\n rowProps: {\n activeIndex,\n setActiveIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n inlineEditingUniqueId,\n },\n tableProps: {\n ...otherProps,\n headerGroups,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n tabIndex: otherProps.tabIndex ?? 0,\n },\n state,\n pagination: !disablePagination\n ? {\n length: manualPagination && length ? length : data.length,\n pageIndex: state.pageIndex,\n pageSize: state.pageSize,\n setPageIndex: gotoPage,\n setPageSize: setPageSize,\n }\n : null,\n rows: visibleRows,\n prepareRow,\n instance: sanitizedInstance,\n };\n};\n","// this wraps react-table's internal useRowSelect hook\nimport React from 'react';\nimport { useRowSelect as useBaseRowSelect, Row, PluginHook } from 'react-table';\nimport { Checkbox } from '../../../Checkbox/Checkbox';\nimport { SelectedRowsHandler } from '../../types';\n\nconst toggleBetween = (fromRowIndex: number, toRowIndex: number): [number, number] => {\n const fromIndex = toRowIndex < fromRowIndex ? toRowIndex : fromRowIndex;\n const toIndex = toRowIndex > fromRowIndex ? toRowIndex : fromRowIndex;\n\n return [fromIndex, toIndex];\n};\n\n// react-table calls \"index paths\" row ids. we named them indexPaths to reduce confusion with natural ids\n// the selection hook usess react-table's row selection, so this hok references row.id - it is the index path\n\nexport const useRowSelect = (onSelectedRows: SelectedRowsHandler | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useBaseRowSelect(hooks);\n\n if (onSelectedRows) {\n const toggleRowSelected = (indexPath: string, checked: boolean): void =>\n onSelectedRows(state => {\n const nextState = { ...state };\n\n if (checked) {\n nextState[indexPath] = true;\n } else {\n delete nextState[indexPath];\n }\n\n return nextState;\n });\n\n const prepareRow = (row: any) => {\n row.toggleRowSelected = () => toggleRowSelected(row.id, !row.isSelected);\n };\n\n hooks.prepareRow.push(prepareRow);\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const lastSelectedSortedIndex = React.useRef();\n\n hooks.visibleColumns.push((columns: any) => [\n {\n id: 'selection',\n Header: ({ getToggleAllRowsSelectedProps, rows }: any) => {\n const { onChange: _, ...props } = getToggleAllRowsSelectedProps();\n\n const onChange = (checked): void => {\n if (checked) {\n // this intentionally only selects top level rows - sub rows add too much complexity\n onSelectedRows(Object.assign({}, Array(rows.length).fill(true)));\n } else {\n onSelectedRows({});\n }\n };\n\n return <Checkbox {...props} onChange={onChange} />;\n },\n Cell: ({ row, rows }: any) => {\n const { onChange: _, ...props } = row.getToggleRowSelectedProps();\n // row.index refers to the index in the original data, not the current index\n const sortedIndex = rows.findIndex((r: Row) => r.index === row.index);\n\n const onClick = (event: React.MouseEvent): void => {\n if (event.shiftKey) {\n const [fromIndex, toIndex] = toggleBetween(lastSelectedSortedIndex.current || 0, sortedIndex);\n\n for (let i = fromIndex; i <= toIndex; i++) {\n toggleRowSelected(rows[i].id, true);\n }\n } else {\n toggleRowSelected(row.id, !props.checked);\n }\n\n lastSelectedSortedIndex.current = sortedIndex;\n };\n\n return (\n <Checkbox\n {...props}\n className=\"!mt-2.5\"\n onClick={onClick}\n // this is necessary to remove console spam from eslint\n onChange={() => false}\n />\n );\n },\n flex: '0 0 36px',\n className: 'flex-col justify-start !py-0',\n },\n ...columns,\n ]);\n }\n };\n plugin.pluginName = 'useRowSelect';\n return plugin;\n};\n","import React from 'react';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport { getNextIndexFromKey } from '../../../utils/hooks/useListKeyboardNavigation';\nimport { sanitizeRowProps } from '../util';\nimport { TableProps } from '../types';\n\nexport const useTableKeyboardNavigation = <T extends {}>(\n props: TableProps<T>,\n rows: any[],\n rowProps: any,\n ref: React.RefObject<HTMLDivElement>\n): [\n number | undefined,\n (index: number) => void,\n (event: React.KeyboardEvent<HTMLElement>) => void,\n (event: React.FocusEvent<HTMLElement>) => void\n] => {\n const useGlobalKeyboardNavigation = props.dangerouslyHijackGlobalKeyboardNavigation;\n\n const [activeIndex, setActiveIndex] = useControllableState<number | undefined>({\n prop: props.activeIndex,\n defaultProp:\n props.defaultActiveIndex !== undefined ? props.defaultActiveIndex : useGlobalKeyboardNavigation ? 0 : undefined,\n onChange: index => {\n if (index !== undefined) {\n props.onChangeActiveIndex?.(index);\n }\n },\n });\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const isModifierKeyPressed = event.metaKey || event.ctrlKey || event.altKey || event.shiftKey;\n\n if (\n useGlobalKeyboardNavigation &&\n document.activeElement !== ref.current &&\n document.activeElement?.getAttribute('type') !== 'search' &&\n document.activeElement !== document.body\n ) {\n return;\n }\n // abort key handling if other elements inside table are focused and we don't use global keyboard navigation\n if (!useGlobalKeyboardNavigation && document.activeElement !== ref.current) {\n return;\n }\n\n if (activeIndex !== undefined) {\n const currentRow = rows[activeIndex];\n\n if (currentRow) {\n const sanitizedRow = sanitizeRowProps(currentRow, rowProps.rowExpansionRenderer);\n\n if (rowProps.onRowClick && event.key === 'Enter') {\n event.preventDefault();\n rowProps.onRowClick(sanitizedRow);\n return;\n }\n\n if (currentRow.toggleRowSelected && event.key === ' ') {\n event.preventDefault();\n currentRow.toggleRowSelected();\n return;\n }\n\n if (currentRow.toggleRowExpanded) {\n if (currentRow.isExpanded && event.key === 'ArrowLeft') {\n event.preventDefault();\n currentRow.toggleRowExpanded();\n return;\n } else if (!currentRow.isExpanded && event.key === 'ArrowRight') {\n event.preventDefault();\n currentRow.toggleRowExpanded();\n return;\n }\n }\n\n // inline editing\n if (currentRow.toggleRowEditing) {\n if (currentRow.canEdit && !currentRow.isEditing) {\n if (rowProps.onRowCreate && event.shiftKey && event.key === 'n') {\n event.preventDefault();\n\n if (!currentRow.isExpanded) {\n currentRow.toggleRowExpanded();\n }\n\n rowProps.onRowCreate(sanitizedRow, event);\n return;\n }\n\n if (event.key === 'e') {\n event.preventDefault();\n currentRow.toggleRowEditing();\n return;\n }\n }\n }\n\n if (rowProps.onRowEdit && event.key === 'e' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowEdit(sanitizedRow, event);\n return;\n }\n\n if (rowProps.onRowCopy && event.key === 'c' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowCopy(sanitizedRow, event);\n return;\n }\n\n if (rowProps.onRowDelete && event.key === 'Delete' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowDelete(sanitizedRow, event);\n return;\n }\n }\n }\n\n const nextIndex = getNextIndexFromKey(event.key, rows.length, activeIndex);\n\n if (nextIndex !== undefined) {\n event.preventDefault();\n setActiveIndex(nextIndex);\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n if (!useGlobalKeyboardNavigation) {\n onKeyDown(event.nativeEvent);\n }\n };\n\n React.useEffect(() => {\n if (useGlobalKeyboardNavigation) {\n window.addEventListener('keydown', onKeyDown);\n }\n\n return () => {\n if (useGlobalKeyboardNavigation) {\n window.removeEventListener('keydown', onKeyDown);\n }\n };\n }, [onKeyDown]);\n\n const handleFocus = (): void => {\n if (activeIndex === undefined && rows.length) {\n setActiveIndex(0);\n }\n };\n\n return [activeIndex, setActiveIndex, handleKeyDown, handleFocus];\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { FocusScope } from '@react-aria/focus';\nimport { InternalTableCell, TableRow } from '../types';\nimport { sanitizeRowProps } from '../util';\n\nconst renderCell = (cell: InternalTableCell, row: TableRow<any>): JSX.Element => {\n const props = {\n ...cell.getCellProps(),\n className: cn('yt-table__cell flex-1 truncate p-2 align-middle', cell.column.className, {\n 'justify-start text-left': cell.column.align === 'left',\n 'justify-end text-right': cell.column.align === 'right',\n 'text-center': !cell.column.align,\n }),\n style: {\n ...cell.column.style,\n flex: typeof cell.column.flex === 'function' ? cell.column.flex(row) : cell.column.flex,\n },\n };\n return (\n <div {...props} role=\"gridcell\" data-taco=\"table-cell\">\n {cell.render('Cell') || null}\n </div>\n );\n};\n\nexport const Row = React.forwardRef(function TableRow({ row, index, instance, headerGroups, ...rowProps }: any, ref: any) {\n const {\n activeIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n setActiveIndex,\n style,\n inlineEditingUniqueId,\n } = rowProps;\n const sanitizedRow = sanitizeRowProps(row, rowExpansionRenderer);\n\n const props = {\n ...row.getRowProps(),\n style: {\n ...style,\n minHeight: rowHeight ? `${rowHeight}px` : undefined,\n paddingLeft: row.depth ? `${row.depth * 2}rem` : undefined,\n },\n className: cn(\n 'yt-table__row border-grey-100 flex border-b min-h-[2.5rem] hover:bg-grey-100',\n {\n 'yt-table__row--active bg-grey-100 hover:bg-grey-100': activeIndex === index,\n 'yt-table__row--clickable': !!onRowClick,\n 'yt-table__row--dragging': !!row.isDragging,\n 'yt-table__row--editing': !!row.isEditing,\n },\n typeof rowClassName === 'function' ? rowClassName(sanitizedRow) : rowClassName\n ),\n onClick: onRowClick\n ? (event: React.MouseEvent<HTMLElement>) => {\n if (\n event.target === event.currentTarget ||\n (event.target as HTMLElement).classList.contains('yt-table__cell')\n ) {\n event.preventDefault();\n event.persist();\n setActiveIndex(index);\n onRowClick(sanitizedRow);\n }\n }\n : () => {\n setActiveIndex(index);\n },\n };\n\n let cells = row.cells;\n\n if (row.depth > 0) {\n cells = row.cells.filter((cell: any) => !cell.column.hiddenOnSubRows);\n }\n\n const expandedRow = rowExpansionRenderer && row.isExpanded && <div>{rowExpansionRenderer(sanitizedRow, instance)}</div>;\n const rowContent = React.useMemo(() => {\n return (\n <>\n <FocusScope key={row.original._createKey} contain restoreFocus autoFocus>\n <div {...props} role=\"row\" ref={ref}>\n <input type=\"hidden\" name=\"_rowIndexPath\" value={row.id} />\n <input type=\"hidden\" name=\"_inlineEditingUniqueId\" value={row.original[inlineEditingUniqueId]} />\n {cells.map((cell: InternalTableCell) => renderCell(cell, sanitizedRow))}\n </div>\n </FocusScope>\n {expandedRow}\n </>\n );\n }, [row.original._createKey]);\n\n if (row.isEditing) {\n return rowContent;\n }\n\n return (\n <>\n <div {...props} role=\"row\" ref={ref}>\n {cells.map((cell: InternalTableCell) => renderCell(cell, sanitizedRow))}\n </div>\n {expandedRow}\n </>\n );\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon } from '../../Icon/Icon';\n\nexport const Column = ({ cell }: any): any => {\n const props = {\n ...cell.getHeaderProps(),\n ...(cell.getSortByToggleProps && cell.getSortByToggleProps({ title: undefined })),\n className: cn('yt-table__cell flex flex-1 truncate p-2 align-middle text-grey-700 hover:text-black', cell.className, {\n 'yt-table__cell__group': !!cell.columns,\n 'cursor-pointer': !cell.disableSorting,\n 'justify-start text-left': cell.align === 'left',\n 'justify-end text-right': cell.align === 'right',\n 'justify-center text-center': cell.align === 'center' || !cell.align,\n }),\n style: { ...cell.style, flex: cell.flex },\n };\n\n if (cell.isSorted) {\n props['aria-sort'] = cell.isSortedDesc ? 'descending' : 'ascending';\n }\n\n return (\n <div {...props} key={cell.id} data-taco=\"table-column\">\n <span className=\"truncate\">{cell.render('Header')}</span>\n {cell.isSorted ? (\n <Icon name={cell.isSortedDesc ? 'chevron-down-solid' : 'chevron-up-solid'} className=\"-mt-0.5\" />\n ) : null}\n </div>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { HeaderGroup } from 'react-table';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { InternalBaseTable } from '../types';\nimport './Table.css';\nimport { Column } from '../util/renderColumn';\n\nexport const DefaultEmptyState = (): React.ReactNode => null;\n\nexport const BaseTable = React.forwardRef(function BaseTable(props: InternalBaseTable, ref: React.Ref<HTMLDivElement>) {\n const tableRef = useMergedRef<HTMLDivElement>(ref);\n const { autoFocus, children, disableSorting: _, headerGroups, headerRef, bodyRef, ...otherProps } = props;\n\n React.useEffect(() => {\n if (autoFocus && tableRef.current) {\n tableRef.current.focus();\n }\n }, []);\n\n const className = cn('yt-table flex flex-col focus:yt-focus focus:rounded-sm', props.className);\n\n return (\n <div {...otherProps} role=\"table\" className={className} ref={tableRef}>\n <div role=\"rowgroup\" className=\"yt-table__head\" ref={headerRef}>\n {headerGroups?.map((headerGroup: HeaderGroup<object>, index: number) => (\n <div\n key={index}\n role=\"row\"\n className=\"border-grey-300 flex h-auto min-h-[2.5rem] w-full select-none border-t-0 border-b-2 font-bold\">\n {headerGroup.headers.map((cell: any, index: number) => (\n <Column key={index} index={index} cell={cell} />\n ))}\n </div>\n ))}\n </div>\n\n <div role=\"rowgroup\" className=\"yt-table__body\" ref={bodyRef}>\n {children}\n </div>\n </div>\n );\n});\n","import React from 'react';\nimport { PluginHook } from 'react-table';\nimport { TableProps, InternalTableRow, ForwardedGenericTableWithStatics, TableRef } from '../types';\nimport { useTable } from '../hooks/useTable';\nimport { Pagination } from '../../Pagination/Pagination';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { Row } from '../util/renderRow';\nimport { DefaultEmptyState, BaseTable } from './BaseTable';\n\nexport const Table = React.forwardRef(function Table<T>(\n props: TableProps<T> & { plugins: PluginHook<{}>[] },\n ref: React.Ref<TableRef>\n) {\n const { emptyStateRenderer = DefaultEmptyState, ...otherProps } = props;\n const tableRef: any = useMergedRef<HTMLDivElement>(ref);\n const { rowProps, tableProps, rows, prepareRow, pagination, instance } = useTable(otherProps, tableRef);\n\n let paginationElement;\n\n if (pagination) {\n paginationElement = (\n <Pagination\n className=\"my-4 w-full\"\n length={pagination.length}\n pageIndex={pagination.pageIndex}\n pageSize={pagination.pageSize}\n setPageIndex={pagination.setPageIndex}\n setPageSize={pagination.setPageSize}\n showPageControls={pagination.length > pagination.pageSize}\n dangerouslyHijackGlobalKeyboardNavigation={props.dangerouslyHijackGlobalKeyboardNavigation}\n />\n );\n }\n\n return (\n <>\n {paginationElement}\n <BaseTable {...tableProps} ref={tableRef}>\n {rows.length\n ? rows.map((row: InternalTableRow, index: number) => {\n prepareRow(row, index);\n return (\n <Row\n {...rowProps}\n key={index}\n index={index}\n row={row}\n instance={instance}\n headerGroups={tableProps.headerGroups}\n />\n );\n })\n : emptyStateRenderer()}\n </BaseTable>\n {paginationElement}\n </>\n );\n}) as ForwardedGenericTableWithStatics;\n\nTable.Column = () => null;\nTable.Group = () => null;\n","import React from 'react';\nimport { ForwardedGenericTableWithStatics, TableProps, TableRef } from '../types';\nimport { Table } from './Table';\n\nexport const PaginatedTable = React.forwardRef(function PaginatedTable<T>(props: TableProps<T>, ref: React.Ref<TableRef>) {\n return <Table {...props} disablePagination={false} ref={ref} />;\n}) as ForwardedGenericTableWithStatics;\n\nPaginatedTable.Column = () => null;\nPaginatedTable.Group = () => null;\n","import React from 'react';\nimport cn from 'classnames';\nimport { PluginHook } from 'react-table';\nimport { areEqual, VariableSizeList } from 'react-window';\nimport InfiniteLoader from 'react-window-infinite-loader';\nimport { TableProps, ForwardedGenericTableWithStatics, TableRef } from '../types';\nimport { useTable } from '../hooks/useTable';\nimport { useBoundingClientRectListener } from '../../../hooks/useBoundingClientRectListener';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { Row } from '../util/renderRow';\nimport { DefaultEmptyState, BaseTable } from './BaseTable';\nimport { useLocalization } from '../../Provider/Localization';\n\nconst ROW_HEIGHT = 40;\n\nconst VariableRow = React.memo(({ data, index, style: { height: _, ...style } }: any) => {\n const { texts } = useLocalization();\n const { rows, setRowHeight, rowProps, tableProps, instance, prepareRow, rowHeights } = data;\n const row = rows[index];\n const ref = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n if (ref?.current) {\n setRowHeight(index, ref.current.getBoundingClientRect().height);\n }\n }, [rowHeights[index]]);\n\n if (row) {\n prepareRow(row, index);\n\n return (\n <Row\n {...rowProps}\n style={style}\n key={index}\n index={index}\n row={row}\n instance={instance}\n headerGroups={tableProps.headerGroups}\n setRowHeight={setRowHeight}\n ref={ref}\n />\n );\n }\n\n return (\n <div className=\"yt-table__row\" role=\"row\" style={style}>\n <div className=\"yt-table__cell text-grey-300\">{texts.table.loading}</div>\n </div>\n );\n}, areEqual);\n\nconst getAverageRowHeight = (rowHeights = {}) => {\n const keys = Object.keys(rowHeights);\n const estimatedHeight = keys.reduce((p, i) => p + rowHeights[i], 0);\n return estimatedHeight / keys.length;\n};\n\nexport const WindowedTable = React.forwardRef(function WindowedTable<T>(\n props: TableProps<T> & { plugins: PluginHook<{}>[] },\n ref: React.Ref<TableRef>\n) {\n const tableRef: any = useMergedRef<HTMLDivElement>(ref);\n const { emptyStateRenderer = DefaultEmptyState, length, loadMore, ...otherProps } = props;\n const { rowProps, tableProps, rows, prepareRow, instance, state } = useTable<T>({ ...otherProps, windowed: true }, tableRef);\n\n // determine heights for windowing calculations\n const headerRef = React.useRef<HTMLDivElement>(null);\n const [rowsRef, setRowsRef] = React.useState<any>(null);\n const tableDimensions = useBoundingClientRectListener(tableRef);\n const headerDimensions = useBoundingClientRectListener(headerRef);\n const height = tableDimensions && headerDimensions ? tableDimensions.height - headerDimensions.height : null;\n\n // variable row height calculations\n const estimatedRowHeight = rowProps.rowHeight || ROW_HEIGHT;\n const rowHeights = React.useRef<Record<string, number>>({});\n const setRowHeight = React.useCallback((index: number, size: number) => {\n if (rowHeights.current[index] !== size) {\n rowHeights.current = {\n ...rowHeights.current,\n [index]: size,\n };\n\n if (rowsRef) {\n rowsRef.resetAfterIndex(0);\n }\n }\n }, []);\n const getRowHeight = React.useCallback(index => rowHeights.current[index] || estimatedRowHeight, []);\n\n React.useEffect(() => {\n if (rowsRef && rowProps.activeIndex !== undefined) {\n rowsRef.scrollToItem(rowProps.activeIndex, 'start');\n }\n }, [rowsRef, rowProps.activeIndex]);\n\n // trigger recalculation of variable row heights if the data changes\n React.useEffect(() => {\n rowHeights.current = {};\n\n if (rowsRef) {\n rowsRef.resetAfterIndex(0);\n }\n }, [rows.length]);\n\n const contentHeight = estimatedRowHeight * props.data.length || 0;\n const isScrollbarVisible = height !== null ? contentHeight > height : false;\n\n const className = cn(tableProps.className, 'yt-table--windowed', { 'table-with-scrollbar': isScrollbarVisible });\n\n let list;\n\n const itemData = {\n rows,\n setRowHeight,\n rowProps,\n tableProps,\n instance,\n prepareRow,\n state,\n rowHeights: rowHeights.current,\n };\n\n if (height && rows.length) {\n const listProps = {\n height,\n itemData,\n estimatedItemSize: getAverageRowHeight(rowHeights.current),\n itemSize: getRowHeight,\n width: '100%',\n };\n\n if (loadMore && length) {\n const isLoaded = (index: number) => !!rows[index];\n\n list = (\n <InfiniteLoader isItemLoaded={isLoaded} itemCount={length} loadMoreItems={loadMore as any}>\n {({ onItemsRendered, ref }: any) => (\n <VariableSizeList\n {...listProps}\n itemCount={length}\n onItemsRendered={onItemsRendered}\n ref={list => {\n ref(list);\n setRowsRef(list);\n }}>\n {VariableRow}\n </VariableSizeList>\n )}\n </InfiniteLoader>\n );\n } else {\n list = (\n <VariableSizeList\n {...listProps}\n itemCount={rows.length}\n ref={ref => {\n setRowsRef(ref);\n }}>\n {VariableRow}\n </VariableSizeList>\n );\n }\n }\n\n return (\n <BaseTable {...tableProps} className={className} headerRef={headerRef} ref={tableRef}>\n {list ? list : emptyStateRenderer()}\n </BaseTable>\n );\n}) as ForwardedGenericTableWithStatics;\n\nWindowedTable.Column = () => null;\nWindowedTable.Group = () => null;\n","import set from 'lodash/set';\nimport { Row, RowIndexPath } from '../types';\n\nexport const convertRowIndexPathToNumberArray = (rowIndexPath: RowIndexPath): number[] =>\n rowIndexPath?.split('.').map(Number) ?? [];\n\nexport const getByRowIndexPath = <TRow extends {}>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow> | undefined => {\n if (!rowIndexPath) {\n return undefined;\n }\n\n const currenTRow = [...data];\n const indexes = convertRowIndexPathToNumberArray(String(rowIndexPath));\n\n if (indexes.length) {\n const startIndex = indexes.shift() as number;\n return indexes.reduce((value, index) => value?.subRows?.[index] as Row<TRow>, currenTRow[startIndex]);\n }\n\n return undefined;\n};\n\nexport const setByRowIndexPath = <TRow extends {}>(data: Row<TRow>[], rowIndexPath: RowIndexPath, values: any): Row<TRow>[] => {\n const nexTRow = [...data];\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = rowIndexes.shift() as number;\n\n if (rowIndexes.length) {\n const path = rowIndexes.map(index => `subRows[${index}]`).join('.');\n set(nexTRow[rootIndex], path, values);\n } else {\n nexTRow[rootIndex] = values;\n }\n\n return nexTRow;\n};\n\nexport const getParentRowIndexPath = (rowIndexPath: RowIndexPath): RowIndexPath => {\n let parentIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n rowIndexes.pop();\n\n if (rowIndexes.length) {\n parentIndexPath = rowIndexes.join('.');\n }\n }\n\n return parentIndexPath;\n};\n","import React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport set from 'lodash/set';\nimport unset from 'lodash/unset';\nimport get from 'lodash/get';\nimport compact from 'lodash/compact';\nimport pullAt from 'lodash/pullAt';\n\nimport { convertRowIndexPathToNumberArray, getByRowIndexPath, getParentRowIndexPath } from '../util/rowIndexPath';\nimport { Row, RowIndexPath, TableRef } from '../types';\n\nexport const insertChildTableRow = <TRow,>(\n data: Row<TRow>[],\n rowIndexPath: RowIndexPath = undefined,\n values: any = {}\n): [Row<TRow>[], RowIndexPath] => {\n const nexTRow: Row<TRow>[] = JSON.parse(JSON.stringify(data));\n\n let childRowIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const currentRow = getByRowIndexPath(nexTRow, rowIndexes.join('.'));\n const nextSubRows = currentRow?.subRows ?? [];\n\n const path = rowIndexes.map(i => `[${i}]`).join('.subRows') + '.subRows';\n nextSubRows.unshift(values);\n set(nexTRow, path, nextSubRows);\n\n // rebuild the new id\n rowIndexes.push(0);\n childRowIndexPath = rowIndexes.join('.');\n } else {\n nexTRow.unshift(values);\n childRowIndexPath = '0';\n }\n\n return [nexTRow, childRowIndexPath];\n};\n\nexport const removeChildTableRow = <TRow,>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow>[] => {\n const nexTRow = JSON.parse(JSON.stringify(data));\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = Number(rowIndexes.shift());\n\n if (rowIndexes.length) {\n // unset\n const unsetPath = rowIndexes.map(index => `subRows[${index}]`).join('.');\n unset(nexTRow[rootIndex], unsetPath);\n\n // remove empty value from subRows\n rowIndexes.pop();\n const setPath = rowIndexes.length ? rowIndexes.map(index => `subRows[${index}]`).join('.') + '.subRows' : 'subRows';\n set(nexTRow[rootIndex], setPath, compact(get(nexTRow[rootIndex], setPath)));\n } else {\n pullAt(nexTRow, rootIndex);\n }\n\n return nexTRow;\n};\n\nexport type useTableRowCreation<TRow> = {\n data: Row<TRow>[];\n create: (rowIndexPath: RowIndexPath, values?: object | undefined) => RowIndexPath;\n remove: (rowIndexPath: RowIndexPath) => void;\n isCreating: boolean;\n};\n\nexport const useTableRowCreation = <TRow,>(data: Row<TRow>[], tableRef: React.RefObject<TableRef>): useTableRowCreation<TRow> => {\n const [internalData, setInternalData] = React.useState(JSON.parse(JSON.stringify(data)));\n const [activeRowIndexPath, setActiveRowIndexPath] = React.useState<string | undefined>(undefined);\n\n React.useEffect(() => {\n if (activeRowIndexPath !== undefined) {\n // keep the same edit key, so that we don't remount the row/form\n const currentRow: any = getByRowIndexPath(internalData, activeRowIndexPath);\n\n // get the active creation rows parent\n const parentId = getParentRowIndexPath(activeRowIndexPath);\n\n // insert a new empty row in the external data (with the same key)\n const [nexTRow, newRowIndexPath] = insertChildTableRow(JSON.parse(JSON.stringify(data)), parentId, currentRow);\n\n // update and set that row as active, we basically just changed it's position in our internal data\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(currentRow?._createKey);\n }\n } else {\n setInternalData(data);\n }\n }, [JSON.stringify(data)]);\n\n const create = (rowIndexPath: RowIndexPath = undefined, values: object | undefined = {}): RowIndexPath => {\n const _createKey = uuid();\n const [nexTRow, newRowIndexPath] = insertChildTableRow(internalData, rowIndexPath, { ...values, _createKey });\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(_createKey);\n }\n\n return newRowIndexPath;\n };\n\n const remove = (rowIndexPath: any): void => {\n const nexTRow = removeChildTableRow(internalData, rowIndexPath);\n setInternalData(nexTRow);\n setActiveRowIndexPath(undefined);\n };\n\n return {\n data: internalData,\n create,\n remove,\n isCreating: activeRowIndexPath !== undefined,\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as TabsPrimitive from '@radix-ui/react-tabs';\n\nimport { Orientation } from '../../types';\nimport './Tabs.css';\n\nexport type TabsProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * The controlled value of the tab to activate. Should be used in conjunction with `onChange`.\n */\n id?: string;\n /**\n * Set which tab is selected on mount.\n * This has to be one of the existing ids provided for tabs\n */\n defaultId?: string;\n /**\n * Content should be one or an array of `Tabs.Trigger` components inside `Tabs.List` and then\n * followed by one or an array of `Tabs.Content`.\n * *Note* that there can also be tabs that are rendered conditionally.\n */\n children: React.ReactNode;\n /**\n * Define orientation of tabs.\n * @defaultValue horizontal\n */\n orientation?: Orientation;\n /**\n * Callback that is called when tab is changed.\n */\n onChange?: (id: string) => void;\n};\n\nexport type TabListProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type TabTriggerProps = React.HTMLAttributes<HTMLButtonElement> & {\n /**\n * A unique value that associates the trigger with a content.\n */\n id: string;\n /**\n * When true, prevents the user from interacting with the tab.\n */\n disabled?: boolean;\n};\n\nexport type TabContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * A unique value that associates the content with a trigger.\n */\n id: string;\n};\n\nexport type ForwardedTabsWithStatics = React.ForwardRefExoticComponent<TabsProps & React.RefAttributes<HTMLDivElement>> & {\n /** Tab list component containing all tab triggers, rendered in a `Tabs` group component */\n List: React.ForwardRefExoticComponent<TabListProps & React.RefAttributes<HTMLDivElement>>;\n /** Tab trigger component rendered in a `Tabs.List` component */\n Trigger: React.ForwardRefExoticComponent<TabTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n /** Tab content component rendered in a `Tabs` group component */\n Content: React.ForwardRefExoticComponent<TabContentProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Tabs = React.forwardRef(function Tabs(props: TabsProps, ref: React.Ref<HTMLDivElement>) {\n const { id, defaultId, children, onChange, orientation = 'horizontal', ...otherProps } = props;\n const className = cn(\n 'yt-tabs',\n `yt-tabs--${orientation}`,\n {\n 'flex w-full': orientation === 'vertical',\n },\n props.className\n );\n\n return (\n <TabsPrimitive.Root\n {...otherProps}\n className={className}\n data-taco=\"tabs\"\n defaultValue={defaultId}\n dir=\"ltr\"\n onValueChange={onChange}\n orientation={orientation}\n ref={ref}\n value={id}>\n {children}\n </TabsPrimitive.Root>\n );\n}) as ForwardedTabsWithStatics;\n\nconst TabList = React.forwardRef(function Tab(props: TabListProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn('yt-tab__list border-b border-grey-300 flex flex-row m-0 mb-4', props.className);\n\n return <TabsPrimitive.List {...props} className={className} ref={ref} />;\n});\n\nconst TabTrigger = React.forwardRef(function Tab(props: TabTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const { id, disabled, ...otherProps } = props;\n const className = cn(\n 'yt-tab bg-transparent border-b-2 border-transparent text-grey-700 m-0 py-2 px-4',\n disabled\n ? 'cursor-not-allowed !text-grey-500'\n : 'cursor-pointer rounded-t hover:border-grey-300 aria-selected:border-blue-500 aria-selected:text-black aria-selected:hover:border-blue-300 hover:text-black active:yt-focus active:border-blue-500 focus:yt-focus focus:border-blue-500',\n props.className\n );\n\n return (\n <TabsPrimitive.Trigger\n {...otherProps}\n className={className}\n disabled={disabled}\n ref={ref}\n style={{\n transition: 'border 0.2s ease-in',\n }}\n value={id}\n />\n );\n});\n\nconst TabContent = React.forwardRef(function Tab(props: TabContentProps, ref: React.Ref<HTMLDivElement>) {\n const { id, ...otherProps } = props;\n const className = cn('yt-tab__panel outline-none', props.className);\n\n return <TabsPrimitive.Content {...otherProps} className={className} ref={ref} value={id} />;\n});\n\nTabs.List = TabList;\nTabs.Trigger = TabTrigger;\nTabs.Content = TabContent;\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { getInputClasses } from '../Input/util';\n\nexport type TextareaProps = React.TextareaHTMLAttributes<HTMLTextAreaElement> & {\n /** Draws attention to the textarea by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /** Value of the textarea */\n value?: string;\n};\n\nexport const Textarea = React.forwardRef(function Textarea(props: TextareaProps, ref: React.Ref<HTMLTextAreaElement>) {\n const { defaultValue: _, highlighted, invalid, onKeyDown, ...otherProps } = props;\n const classNames = cn(getInputClasses(props), 'py-1 min-h-[75px] disabled:resize-none', props.className);\n\n // home and end keys only navigate to the start/end of textarea value if the textarea container does not scroll\n // if it has scroll height then the browser reverts to native scrolling behaviour only\n // so we manually override it to ensure _our_ desired behaviour remains intact\n const handleKeyDown = (event: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (event.key === 'Home' || event.key === 'End') {\n event.preventDefault();\n const position = event.key === 'End' ? event.currentTarget.value.length : 0;\n event.currentTarget.setSelectionRange(position, position);\n event.currentTarget.scrollTop = event.key === 'End' ? event.currentTarget.scrollHeight : 0;\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n return <textarea {...otherProps} className={classNames} data-taco=\"textarea\" onKeyDown={handleKeyDown} ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PrimitiveSwitch from '@radix-ui/react-switch';\nimport { useId } from '../../hooks/useId';\n\ntype SwitchBaseProps = Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'children' | 'onChange'> & {\n /** Label for the switch */\n label?: React.ReactNode;\n /* Whether user input is required */\n required?: boolean;\n};\n\ninterface UncontrolledSwitchProps extends SwitchBaseProps {\n checked?: never;\n onChange?: never;\n /* The default checked state (uncontrolled) */\n defaultChecked?: boolean;\n}\n\ninterface ControlledSwitchProps extends SwitchBaseProps {\n defaultChecked?: never;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean) => void;\n}\n\nexport type SwitchProps = UncontrolledSwitchProps | ControlledSwitchProps;\n\nexport const Switch = React.forwardRef(function Switch(props: SwitchProps, ref: React.Ref<HTMLButtonElement>) {\n const { label, onChange, ...otherProps } = props;\n const id = useId(props.id);\n\n const className = cn(\n 'group h-5 w-9 flex flex-shrink-0 rounded-full inline-flex',\n {\n 'mr-2': !!label,\n 'bg-grey-500 hover:bg-grey-300 aria-checked:bg-blue-500 aria-checked:hover:bg-blue-300 focus:yt-focus':\n !props.disabled,\n 'bg-grey-100 cursor-not-allowed aria-checked:bg-blue-300': props.disabled,\n },\n props.className\n );\n\n let labelledByProps: Record<string, string> | null = null;\n\n if (label) {\n labelledByProps = {\n 'aria-labelledby': `${id}-label`,\n id,\n };\n }\n\n const element = (\n <PrimitiveSwitch.Root {...otherProps} {...labelledByProps} className={className} onCheckedChange={onChange} ref={ref}>\n <PrimitiveSwitch.Thumb className=\"'will-change-transform mt-0.5 h-4 w-4 translate-x-[0.15rem] rounded-full bg-white transition-transform group-disabled:opacity-50 group-aria-checked:translate-x-[1.1rem]\" />\n </PrimitiveSwitch.Root>\n );\n\n if (label) {\n const labelContainerClassName = cn('flex self-start cursor-pointer', {\n 'cursor-not-allowed text-grey-300': props.disabled,\n });\n\n return (\n <span className={labelContainerClassName}>\n {element}\n <label htmlFor={id} id={`${id}-label`}>\n {label}\n </label>\n </span>\n );\n }\n\n return element;\n});\nSwitch.displayName = 'Switch';\n","import * as React from 'react';\nimport Joyride, { Step, CallBackProps, ACTIONS, LIFECYCLE, Placement, EVENTS, TooltipRenderProps } from 'react-joyride';\n\nimport { Button } from '../Button/Button';\nimport { Group } from '../Group/Group';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type TourTexts = {\n /** Text for back action button */\n back: string;\n /**\n * Text for close button.\n * This button is displayed if tour is not continuous - replacing the `Next` button.\n * It will pause the flow of the tour and close the tooltip\n */\n close: string;\n /**\n * Aria-label and title for close icon button in each step.\n * This button skips and completes the flow entirely\n */\n skip: string;\n /**\n * Text for last action button.\n * This button is displayed when user is on the last step of the tour\n */\n last: string;\n /**\n * Text for next action button.\n * This button is displayed if tour has more than one steps and is continuous\n */\n next: string;\n /** Aria label and title for beacon that will open the tour step */\n open: string;\n};\n\nexport type TourStepProps = {\n /** Content can be any valid react node, for e.g. a `div` */\n children: React.ReactNode;\n /** Define the position of the tour's popup relative to the element is presenting */\n position?: Placement;\n /** The css selector of the html element you want to include in a tour */\n selector: string;\n /**\n * Show beacon for step.\n * A beacon is a styled component which indicates the current element to be presented.\n * For more informations about how to create a beacon, read [Joyride](https://docs.react-joyride.com) docs\n */\n showBeacon?: boolean;\n /** Text displayed above the children/content of the popup */\n title: string;\n};\n\nconst Tooltip = ({\n continuous,\n index,\n isLastStep,\n step,\n backProps,\n primaryProps,\n skipProps,\n tooltipProps,\n size,\n locale,\n disableTourSkipOnEsc,\n}: TooltipRenderProps & { locale: TourTexts; disableTourSkipOnEsc?: boolean }) => {\n const skipButtonRef = React.useRef<HTMLButtonElement>(null);\n\n React.useEffect(() => {\n const onWindowKeyDown = (event: KeyboardEvent): void => {\n if (!disableTourSkipOnEsc) {\n if (event.key === 'Escape' && skipButtonRef.current !== null) {\n event.preventDefault();\n skipButtonRef.current.click();\n return;\n }\n }\n };\n\n window.addEventListener('keydown', onWindowKeyDown);\n\n return () => {\n window.removeEventListener('keydown', onWindowKeyDown);\n };\n }, []);\n\n return (\n <div {...tooltipProps} className=\"yt-tour__step w-88 relative rounded bg-white p-4\">\n <IconButton\n {...skipProps}\n ref={skipButtonRef}\n appearance=\"discrete\"\n icon=\"close\"\n title={locale.skip}\n aria-label={locale.skip}\n className=\"absolute top-0 right-0 mt-1 mr-1\"\n />\n {step.title && <h5>{step.title}</h5>}\n {step.content}\n <Group className=\"mt-4 justify-end\">\n {index > 0 && (\n <Button {...backProps} appearance=\"discrete\">\n {locale.back}\n </Button>\n )}\n <Button {...primaryProps} appearance=\"primary\">\n {continuous\n ? isLastStep\n ? `${locale.last} (${index + 1}/${size})`\n : `${locale.next} (${index + 1}/${size})`\n : locale.close}\n </Button>\n </Group>\n </div>\n );\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport const TourStep = (_props: TourStepProps): null => null;\n\nexport type TourProps = {\n /** Controls if [Joyride](https://docs.react-joyride.com) is active */\n autoStart?: boolean;\n /** Children should be one or more `Tour.Step` components */\n children: any;\n /** Are there more than one steps and should you be able to navigate between them using `Next` and `Previous` buttons */\n continuous?: boolean;\n /** Disable closing of tour when click on `Escape` */\n disableCloseOnEsc?: boolean;\n /** Don't close the presenting popup of the tour step when clicking outside it */\n disableOverlayClose?: boolean;\n /** Allows user to interact with the presented components (mouse and touch events) when the popup is visible */\n disableScrolling?: boolean;\n /* When user clicks on the close icon button, which will close the tour and complete the flow */\n onClose?: (step: TourStepProps) => void;\n /* When user completes the entire flow */\n onComplete?: Function;\n /** When step is ready */\n onReady?: (step: TourStepProps) => void;\n /* Allow mouse and touch events through the spotlight */\n spotlightClicks?: boolean;\n /* Stops the injection of custom overflow styles on parent container. Can be used to prevent remaining overflow styles after tour is done. */\n disableScrollParentFix?: boolean;\n /** The scroll distance from the element scrollTop value. */\n scrollOffset?: number;\n};\n\nexport const Tour = (props: TourProps) => {\n const {\n texts: { tour },\n } = useLocalization();\n\n const {\n autoStart: run,\n onComplete,\n onClose,\n onReady,\n spotlightClicks,\n disableCloseOnEsc: disableTourSkipOnEsc,\n disableScrollParentFix = false,\n scrollOffset,\n ...rest\n } = props;\n\n const steps = React.useMemo(() => {\n return React.Children.map(props.children, child => {\n const step: Step = {\n disableBeacon: !child.props.showBeacon,\n target: child.props.selector,\n placement: child.props.position,\n title: child.props.title,\n content: child.props.children,\n };\n return step;\n });\n }, [props.children]);\n\n const getStep = React.useCallback(\n (selector: string | HTMLElement) => props.children.find((child: any) => child.props.selector === selector)?.props,\n [props.children]\n );\n\n const callback = (state: CallBackProps) => {\n if (state.action === ACTIONS.SKIP && state.lifecycle === LIFECYCLE.COMPLETE) {\n if (onClose) {\n onClose(getStep(state.step.target));\n }\n }\n\n if (state.type === EVENTS.TOUR_END) {\n if (onComplete) {\n onComplete();\n }\n }\n\n if (state.lifecycle === LIFECYCLE.READY) {\n if (onReady) {\n onReady(getStep(state.step.target));\n }\n }\n };\n\n return (\n <Joyride\n {...rest}\n run={run}\n steps={steps}\n showProgress\n floaterProps={{\n disableAnimation: true,\n }}\n tooltipComponent={tooltipProps => (\n <Tooltip {...tooltipProps} locale={tour} disableTourSkipOnEsc={disableTourSkipOnEsc} />\n )}\n locale={tour}\n spotlightPadding={8}\n spotlightClicks={spotlightClicks}\n disableScrollParentFix={disableScrollParentFix}\n callback={callback}\n scrollOffset={scrollOffset}\n styles={{\n /** style beacon */\n options: {\n // tailwind.theme.colors.blue.300\n primaryColor: '#6ba4ff',\n },\n }}\n disableCloseOnEsc\n />\n );\n};\n\nTour.Step = TourStep;\n","import React from 'react';\nimport cn from 'classnames';\nimport './Progress.css';\n\nexport type ProgressProps = React.HTMLAttributes<HTMLSpanElement> & {\n /**\n * Indicates how long (in milliseconds) a progress bar will take to progress through.\n * By default, progress bar has no duration\n */\n duration?: number;\n};\n\nexport const Progress = ({ duration = undefined, ...props }: ProgressProps): JSX.Element => {\n let style;\n\n if (duration) {\n style = {\n animationDuration: `${duration}ms`,\n };\n }\n\n const className = cn('bg-grey-100 rounded block h-1 overflow-hidden w-full', props.className);\n\n const progressClassName = cn('yt-progress__bar block h-1', {\n \"w-full before:h-1 before:bg-grey-300 before:block before:animate-[progress-indeterminate_2s_cubic-bezier(0.4,0,0.2,1)_infinite] before:content-[' ']\":\n !duration,\n [`w-0 bg-grey-300 animate-[progress_linear]`]: duration,\n });\n\n return (\n <span {...props} data-taco=\"progress\" className={className}>\n <span className={progressClassName} data-taco=\"progress-bar\" style={style} />\n </span>\n );\n};\n","import * as React from 'react';\nimport * as Tooltip from '@radix-ui/react-tooltip';\nimport { ToastProvider } from '../Toast/Toaster';\nimport { Localization, LocalizationProvider } from './Localization';\n\nexport type ProviderProps = {\n /** Content would be your application */\n children?: any;\n /** Define localized texts and formatted data in your application */\n localization?: Localization;\n};\n\nexport const Provider = (props: ProviderProps): JSX.Element => {\n const { children, localization } = props;\n\n return (\n <LocalizationProvider localization={localization}>\n <Tooltip.Provider>\n <ToastProvider>{children}</ToastProvider>\n </Tooltip.Provider>\n </LocalizationProvider>\n );\n};\n","import React from 'react';\n\nexport const useOnClickOutside = (\n ref: React.RefObject<HTMLElement> | React.RefObject<HTMLElement>[],\n callback: (event: MouseEvent | TouchEvent) => void\n): void => {\n React.useEffect(() => {\n const listener = (event: MouseEvent | TouchEvent): void => {\n const refs = !Array.isArray(ref) ? [ref] : ref;\n if (refs.some(currentRef => !currentRef.current || currentRef.current.contains(event.target as Node))) {\n return;\n }\n callback(event);\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, callback]);\n};\n","import React from 'react';\n\nexport type usePaginationValues = {\n /** Current page index (zero based) */\n pageIndex: number;\n /** Number of items displayed on a page */\n pageSize: number;\n /** Handler called when navigating through pages */\n setPageIndex: (pageIndex: number) => void;\n /** Handler called when changing the size of the page */\n setPageSize: (size: number) => void;\n};\n\nexport const usePagination = (initialPageIndex = 0, initialPageSize = 10): usePaginationValues => {\n const [pageIndex, setPageIndex] = React.useState(initialPageIndex);\n const [pageSize, setPageSize] = React.useState(initialPageSize);\n\n return {\n pageIndex,\n pageSize,\n setPageIndex,\n setPageSize,\n };\n};\n"],"names":["AlertDialogContext","React","createContext","props","ref","mergeRefs","refs","value","forEach","current","Trigger","externalRef","parentRef","parentProps","useContext","refCallback","AlertDialogPrimitive","asChild","Footer","className","children","Cancel","Action","Backdrop","cn","getDialogSizeClassnames","size","Title","Content","onEscapeKeyDown","event","preventDefault","AlertDialog","defaultOpen","onChange","open","trigger","otherProps","context","Provider","onOpenChange","IconAccountPreview","svgRef","xmlns","viewBox","d","fill","fillRule","IconAccountingYearCancel","IconAccountingYear","IconAccounting","IconArrowBottom","IconArrowDown","IconArrowEnd","IconArrowLeft","IconArrowRight","IconArrowStart","IconArrowTop","IconArrowUp","IconAttachAuto","IconAttachCancel","IconAttach","IconAutotextInsert","IconAutotext","IconBasicTabs","IconBasic","IconBellSolid","IconBook","IconBooking","IconBudget","IconCalendar","IconCashAccount","IconCashReports","IconChatSolid","IconChat","IconChevronDownDouble","IconChevronDownSolid","IconChevronDown","IconChevronLeftDouble","IconChevronLeftSolid","clipRule","IconChevronLeft","IconChevronRightDouble","IconChevronRightSolid","IconChevronRight","IconChevronUpDouble","IconChevronUpSolid","IconChevronUp","IconCircleClose","IconCircleMinus","IconCirclePlus","IconCircleTick","IconClampOpen","IconClamp","IconClose","IconConnectionEnable","IconConnectionRevoke","IconContacts","IconCopy","IconCourses","IconCredit","IconDeletePermanently","IconDelete","IconDepecriate","IconDeveloper","IconDistributionTemplate","IconDocumentApprove","IconDocumentCreateEntry","IconDocumentCut","IconDocumentError","IconDocumentIsolatePage","IconDocumentMerge","IconDocumentMove","IconDocumentPreview","IconDocumentReceived","IconDocumentRejectedRequest","IconDocumentSplit","IconDocumentTime","IconDocument","IconDownload","IconDrag","IconECopedia","IconESignature","IconEdit","IconEllipsisHorizontal","IconEllipsisVertical","IconEntriesOnAccount","IconEntriesOpen","IconEntriesWarning","IconEntryTypeCustomerInvoice","IconEntryTypeCustomerPayment","IconEntryTypeJournalEntry","IconEntryTypeManualCustomerInvoice","IconEntryTypeSupplierInvoice","IconEntryTypeSupplierPayment","IconEnvelopeApproved","IconEnvelope","IconExpandView","IconExpenses","IconExportToExcel","IconExportToPdf","IconExport","IconFilterSolid","IconFilter","IconGraphSolid","IconHash","IconHome","IconImages","IconImport","IconInboxEinvoicing","IconInboxScanning","IconInboxSmart","IconInbox","IconInfo","IconInventoryMatrix","IconInventory","IconJournalPro","IconLayoutBoth","IconLayoutFirst","IconLayoutLast","IconLayoutNone","IconLayout","IconLedgerCardCustomerReminder","IconLedgerCardManualCustomerInvoice","IconLedgerCardObsoleteStock","IconLedgerCardOpeningEntry","IconLedgerCardReservedEntry","IconLedgerCardShrinkagePilferage","IconLedgerCardStockAdjustment","IconLedgerCardTransferredOpeningEntry","IconLedgerCard","IconLightbulb","IconLine","IconListBulleted","IconListSearch","IconList","IconLockOpen","IconLogOut","IconLog","IconMarket","IconMatchAmount","IconMatchEntries","IconMenu","IconMileage","IconModalResize","IconModalShrink","IconMoreSolid","IconMore","IconMove","IconNavigationList","IconNoteFollowUp","IconNoteRead","IconNote","IconNumbers","IconPartnerApi","IconPeriod","IconPersonChange","IconPersonMinus","IconPersonPlus","IconPersonTick","IconPlay","IconPlusMinus","IconPrint","IconProcessPayment","IconProductLedgerCard","IconProfile","IconProjectCards","IconProjects","IconQuicklinks","IconRatingBankruptcy","IconRatingPaymentProblems","IconReconciled","IconRefresh","IconReportSolid","IconReport","IconRestore","IconRotateLeft","IconRotateRight","IconSales","IconSearchBold","IconSearch","IconSecureTick","IconSecure","IconSettingsSolid","IconSettings","IconShortcuts","IconShowAll","IconShowLess","IconShowMore","IconShowTemplate","IconSliders","IconSmartpay","IconSortBy","IconSpinner","IconStarSolid","IconStar","IconSubscriptions","IconSystemEntries","IconTag","IconTemplateOverride","IconTemplates","IconThumbBoth","IconThumbDownSolid","IconThumbDown","IconThumbUpSolid","IconThumbUp","IconTick","IconTime","IconTransferCancel","IconTransferLocked","IconTransfer","IconUndo","stroke","strokeWidth","strokeLinecap","strokeLinejoin","IconUndock","IconUnreconciled","IconWarning","IconWebshop","IconWebsite","IconWorkflow","IconZoom","icons","account-preview","accounting-year-cancel","accounting-year","accounting","arrow-bottom","arrow-down","arrow-end","arrow-left","arrow-right","arrow-start","arrow-top","arrow-up","attach-auto","attach-cancel","attach","autotext-insert","autotext","basic-tabs","basic","bell-solid","book","booking","budget","calendar","cash-account","cash-reports","chat-solid","chat","chevron-down-double","chevron-down-solid","chevron-down","chevron-left-double","chevron-left-solid","chevron-left","chevron-right-double","chevron-right-solid","chevron-right","chevron-up-double","chevron-up-solid","chevron-up","circle-close","circle-minus","circle-plus","circle-tick","clamp-open","clamp","close","connection-enable","connection-revoke","contacts","copy","courses","credit","delete-permanently","delete","depecriate","developer","distribution-template","document-approve","document-create-entry","document-cut","document-error","document-isolate-page","document-merge","document-move","document-preview","document-received","document-rejected-request","document-split","document-time","document","download","drag","e-copedia","e-signature","edit","ellipsis-horizontal","ellipsis-vertical","entries-on-account","entries-open","entries-warning","entry-type-customer-invoice","entry-type-customer-payment","entry-type-journal-entry","entry-type-manual-customer-invoice","entry-type-supplier-invoice","entry-type-supplier-payment","envelope-approved","envelope","expand-view","expenses","export-to-excel","export-to-pdf","export","filter-solid","filter","graph-solid","hash","home","images","import","inbox-einvoicing","inbox-scanning","inbox-smart","inbox","info","inventory-matrix","inventory","journal-pro","layout-both","layout-first","layout-last","layout-none","layout","ledger-card-customer-reminder","ledger-card-manual-customer-invoice","ledger-card-obsolete-stock","ledger-card-opening-entry","ledger-card-reserved-entry","ledger-card-shrinkage-pilferage","ledger-card-stock-adjustment","ledger-card-transferred-opening-entry","ledger-card","lightbulb","line","list-bulleted","list-search","list","lock-open","log-out","log","market","match-amount","match-entries","menu","mileage","modal-resize","modal-shrink","more-solid","more","move","navigation-list","note-follow-up","note-read","note","numbers","partner-api","period","person-change","person-minus","person-plus","person-tick","play","plus-minus","print","process-payment","product-ledger-card","profile","project-cards","projects","quicklinks","rating-bankruptcy","rating-payment-problems","reconciled","refresh","report-solid","report","restore","rotate-left","rotate-right","sales","search-bold","search","secure-tick","secure","settings-solid","settings","shortcuts","show-all","show-less","show-more","show-template","sliders","smartpay","sort-by","spinner","star-solid","star","subscriptions","system-entries","tag","template-override","templates","thumb-both","thumb-down-solid","thumb-down","thumb-up-solid","thumb-up","tick","time","transfer-cancel","transfer-locked","transfer","undo","undock","unreconciled","warning","webshop","website","workflow","zoom","Icon","forwardRef","name","Component","p-[3px]","_props$className","includes","focusable","role","AccordionContext","as","StyledTrigger","isExpanded","Heading","AccordionPrimitive","Accordion","id","defaultId","useMemo","valueProps","defaultValue","undefined","onValueChange","type","Array","isArray","Item","VisuallyHidden","getStateClasses","getOutlineClasses","state","Badge","compact","outline","[object Object]","h-2 w-2 min-w-0","h-5 py-0 px-1.5","title","Button","disabled","target","Tag","href","count","map","child","Tooltip","placement","TooltipPrimitive","delayDuration","side","sideOffset","style","transformOrigin","getAppearanceClasses","icon","createButtonWithTooltip","tooltip","buttonProps","button","ButtonPrimitive","createButtonWithOverlays","buttonBase","dialog","hanger","popover","anchor","Base","rounded","appearance","rounded-full","cursor-not-allowed opacity-50","focus:yt-focus active:focus:yt-focus","data-taco","IconButton","defaultLocalisationTexts","months","weekdaysShort","actions","previousMonth","nextMonth","previousYear","nextYear","today","combobox","datepicker","clear","expand","banner","listbox","loading","empty","allOption","pagination","label","pageSize","showingXofYofTotal","firstPage","firstPageWithShortcut","previousPage","previousPageWithShortcut","nextPage","nextPageWithShortcut","lastPage","lastPageWithShortcut","pageX","table","del","newSubRow","select","allOptionsSelected","select2","allSelect","allDeselect","cancel","chooseColor","create","save","searchOrCreate","toasts","dismiss","tour","back","skip","last","next","searchInput","placeholder","defaultLocalizationContext","locale","texts","formatting","date","LocalizationContext","LocalizationProvider","localization","useLocalization","Banner","onClose","getBannerIcon","onClick","fluid","w-full","key","thisYear","Date","getFullYear","years","i","push","Navbar","onMonthChange","onNextClick","onPreviousClick","handleChange","year","month","form","getMonth","String","Calendar","disabledDays","visibleMonth","setVisibleMonth","ReactDayPicker","selectedDays","substring","firstDayOfWeek","navbarElement","navProps","onDayClick","modifiers","outside","onTodayButtonClick","setHours","setMinutes","setSeconds","captionElement","todayButton","numberOfMonths","externalProps","noPadding","mx-4 mb-4","Card","useId","nativeId","uuid","Checkbox","checked","highlighted","indeterminate","invalid","border-grey-300 text-blue-500 hover:text-blue-300 focus:border-blue-500 focus:hover:border-blue-300","border-grey-200 text-blue-300 cursor-not-allowed","bg-[rgba(255,255,0,0.2)] disabled:bg-[rgba(255,255,0,0.075)]","border-red-500 text-red-500 hover:text-red-300 hover:border-red-300 focus:border-red-500 focus:hover:border-red-300","labelledByProps","aria-labelledby","element","CheckboxPrimitive","onCheckedChange","labelContainerClassName","cursor-not-allowed text-grey-300","htmlFor","displayName","getInputClasses","border-grey-300 focus:border-blue-300 focus:yt-focus","hover:shadow-[0_0_0.1rem_theme(colors.grey.500)] active:border-blue-700","border-grey-200 text-opacity-25 cursor-not-allowed placeholder:text-grey-700","bg-[rgba(255,255,0,0.075)]","bg-[rgba(255,255,0,0.2)]","border-red focus:border-red-300 focus:yt-focus-red active:border-red-700","hover:shadow-[0_0_0.15rem_theme(colors.red.500)]","cursor-not-allowed text-black bg-grey-200","readOnly","debounce","fn","delay","timeoutId","args","clearTimeout","setTimeout","apply","this","getVisibility","Boolean","offsetWidth","offsetHeight","getClientRects","length","useBoundingClientRectListener","dependencies","dimensions","setDimensions","isRefElementVisible","visibility","setVisibility","resize","_ref$current","getBoundingClientRect","timeout","debouncedResize","window","addEventListener","removeEventListener","newRefElementVisibility","_ref$current2","useMergedRef","internalRef","useRef","useEffect","validSetSelectionRangeTypes","InputWithoutDeprecatedFeatures","onKeyDown","postfix","prefix","attributes","handleKeyDown","shiftKey","position","currentTarget","setSelectionRange","prefixRef","prefixRect","postfixRef","postfixRect","pl-8","pr-8","opacity","paddingLeft","width","paddingRight","Affix","text-grey-300","text-grey-700","left-0 [&>button]:!-ml-2","right-0 [&>button]:!-mr-2","Input","buttonClassName","getNextIndexFromKey","index","direction","useListScrollTo","itemRefs","scrollTo","activeRef","parent","clientHeight","scrollHeight","scrollTop","childBottom","offsetTop","scrollToChildElement","Spinner","visible","useState","cx","cy","r","getId","getNextEnabledItem","data","nextIndex","ScrollableList","setCurrentIndex","onFocus","scrollOnFocus","currentIndex","multiselect","selectedIndexes","listRef","_itemRefs$currentInde","_itemRefs$currentInde2","scrollIntoView","block","handleClick","persist","getOptionCheckedState","optionValue","findIndex","options","option","depth","path","split","aria-selected","data-focused","text","sticky top-0 font-bold","hasChildren","yt-list--multiselect","pointer-events-none","cursor-not-allowed","tabIndex","optionProps","createCustomEvent","eventType","customEvent","Event","bubbles","createEvent","initEvent","createCustomKeyboardEvent","customKeyboardEvent","KeyboardEvent","charCode","setInputValueByRef","input","previousValue","tracker","_valueTracker","setValue","dispatchEvent","getValue","setInputValueByRefBase","getIndexFromValue","getSelectedIndexesFromValue","v","o","findByValue","find","searchForString","strategy","_child$props","_child$props2","subChild","_child$props3","toString","toLowerCase","getIndexInRangeByValue","query","firstIndex","lastIndex","slice","getActiveDescendant","useFlattenedData","items","flatten","item","parentPath","parentDisabled","currentPath","isItemDisabled","childItem","childPath","sanitizeItem","rest","getOptionParents","indexes","lastPath","pop","join","debouncer","f","convertToInputValue","Combobox","externalClassName","ariaLabelledBy","unfilteredData","inline","onSearch","inputRef","buttonRef","setOpen","listId","inputValue","setInputValue","shouldFilterData","flattenedData","filteredOptionValues","Set","shouldFilterOption","parents","add","has","filterData","setInputValueByIndex","setCurrentValue","isCurrentValue","aria-expanded","aria-owns","aria-haspopup","aria-controls","aria-autocomplete","aria-activedescendant","onBlur","relatedTarget","detail","click","initialIndex","isDefaultPrevented","useCombobox","selectDimensions","yt-combobox--inline","PopoverPrimitive","autoComplete","_input$ref$current","focus","_input$ref$current2","align","onOpenAutoFocus","minWidth","format","mask","isDate","toDate","isValid","pad","replace","getDate","parseFromCustomString","sanitizedMask","dd","x","mm","yy","day","y","Number","parseInt","inputParts","fullDate","unseparatedMask","indexOf","lastIndexOf","currentDate","Object","is","NaN","UnstyledArrow","offset","height","transform","PopoverContext","_props$children","console","warn","RenderPropWrapper","CustomEvent","popoverContentProps","output","Close","Popover","modal","Portal","Datepicker","onReset","handleReset","shortcutsText","internalValue","setInternalValue","formattedValue","valueAsDate","useDatepicker","shortcut","DialogContext","closeOnEscape","draggable","drawer","toggle","elements","extra","showCloseButton","useCurrentDialog","DialogPrimitive","renderProps","dragging","handleProps","dragHandleProps","setPosition","setDragging","moveProps","useMove","onMoveStart","onMove","rect","left","deltaX","right","innerWidth","top","deltaY","bottom","innerHeight","onMoveEnd","useDraggable","containerClassName","rounded-b-none","onInteractOutside","Drawer","motion","div","_dialog$drawer","variants","display","transition","ease","duration","hidden","transitionEnd","animate","_dialog$drawer2","Extra","Dialog","initialChildren","toArray","_child$type","_child$type2","useSeparatedChildren","drawerOpen","setDrawerOpen","isDrawerOpen","Field","message","messageClassName","text-red-500","opacity-50","Form","horizontal","yt-form--horizontal flex flex-wrap","Group","orientation","flex-col ","HangerContext","Anchor","Hanger","HoverCardPrimitive","HoverCard","openDelay","SearchInput","_internalRef$current","_props$onKeyDown","useTimer","callback","timer","setTracker","remaining","started","running","start","now","pause","resume","useTypeahead","typeaheadQuery","typeaheadQueryTimer","getNextIndex","charKey","activeIndex","findNextIndexByValue","Listbox","externalData","emptyValue","defaultValueIndex","test","_item$path","useListbox","maxHeight","MultiListbox","setAllOptionsSelected","setSelectedIndexes","selectableItemsCount","newInputValue","currentInputValue","_inputRef$current","currentValuesArray","optionAlreadySelected","val","aria-multiselectable","useMultiListbox","MenuContext","useCurrentMenu","DropdownMenuPrimitive","IconPrimitive","useItemStyling","indented","registerIndentation","pl-7","pl-1.5","cursor-pointer hover:bg-grey-100 text-black hover:text-black","cursor-not-allowed hover:bg-white text-grey-300","Shortcut","stopPropagation","onSelect","Link","setMinWidth","getRadioGroupItemValueAsString","values","valueAsString","RadioGroupContext","RadioGroupItem","isDisabled","border-grey-300 hover:border-4 focus:yt-focus aria-checked:bg-blue-500 aria-checked:border-blue-500 hover:aria-checked:border-blue-300","border-grey-200 cursor-not-allowed aria-checked:bg-blue-300 aria-checked:border-blue-300 ","border-red-500 hover:border-4 text-red-500 focus:border-red-500 focus:yt-focus-red aria-checked:bg-red-500 aria-checked:border-red","labelClassName","cursor-pointer","RadioGroupPrimitive","useRadioGroup","radioGroupItemValues","RadioGroup","flex-wrap gap-x-4 ","flex-col","MenuRadioGroupContext","Header","Menu","defaultProp","prop","setIndented","useControllableState","Separator","TreeviewItem","TreeviewGroup","expanded","initialExpanded","fixed","setExpanded","listClassName","flex","itemProps","nextState","Children","cloneElement","Treeview","useDropTarget","onDrop","isDraggedOver","setDraggedOver","handleDragEnter","useCallback","handleDragLeave","handleDragOver","handleDrop","onDragEnter","onDragLeave","onDragOver","active","proxyRef","dropTargetProps","isTreeitem","w-full mb-px py-1 px-3 flex items-center hover:bg-grey-300","bg-white w-full h-10 px-3 flex-shrink-0 flex items-center justify-between cursor-pointer","yt-navigation__item--active","bg-grey-300","yt-navigation__item--dropping bg-blue-500","HTMLAnchorElement","HTMLButtonElement","Panel","MenuGroup","bg-white pb-2","mb-1","cursor-pointer hover:text-blue-500","scrollableAreas","area","Navigation","PageNumbers","currentPageIndex","pageCount","range","pageNumber","lowerLimit","Math","min","upperLimit","b","createPageRange","BaseSelect","autoFocus","aria-label","ariaLabel","listboxInputRef","buttonId","lastValue","setLastValue","selectedValues","_findByValue","useSelect","yt-select--readonly","inputClassname","border-blue-500","commonListboxProps","Select","editable","Pagination","pageIndex","pageSizes","setPageIndex","setPageSize","showPageControls","showPageNumbers","showPageSize","dangerouslyHijackGlobalKeyboardNavigation","maxPageIndex","ceil","showShortcutTexts","useGlobalKeyboardNavigation","max","usePaginationShortcuts","canPreviousPage","canNextPage","maxItemIndex","getShowingLabel","Toast","content","lastUpdated","handleClose","autoClose","border border-grey-200","border border-grey-500","border border-blue-500","border border-yellow-700","border border-red","controls","useAnimation","scale","triggerUpdateAnimation","onMouseEnter","onMouseLeave","css","getBadgeIcon","ToastContext","insertToastWithoutDuplicates","currentToasts","nextToasts","existingToastIndex","toast","JSON","stringify","lastDuplicateId","ToastProvider","setToasts","toaster","update","success","error","information","AnimatePresence","initial","damping","stiffness","exit","isAriaSelectionKey","getOptionsFromCollection","collection","selector","querySelectorAll","Root","querySelector","setActiveIndex","lastLengthRef","setActiveOption","_collection$querySele","removeAttribute","setAttribute","setActiveIndexByElement","matches","nextActiveIndex","from","selected","firstSelected","selectedIndex","isAriaDirectionKey","recurse","getNextIndexFromKeycode","isSkippableItem","getAttribute","hasAttribute","Listbox2Context","customSelector","multiple","CollectionPrimitive","Option","listboxDisabled","listboxReadOnly","currentValue","labelledById","setLabelledById","Listbox2GroupContext","colors","green","yellow","red","blue","purple","orange","brown","pink","grey","color","onDelete","textRef","hover:bg-opacity-75","Select2Context","useSelect2Context","_catch","body","recover","result","e","then","Symbol","iterator","asyncIterator","AVAILABLE_COLORS","keys","EditPopover","initialColor","initialName","popoverProps","onEdit","searchRef","selectRef","setName","setColor","validationError","setValidationError","handleInputChange","handleInputKeyDown","handleSave","handleDelete","preventKeyDownPropagation","onCloseAutoFocus","_searchRef$current","_selectRef$current","!pb-0","Colours","onChangeColor","availableColor","mobiles","listboxRef","tags","hasValue","isTag","textValue","ListboxPrimitive","!visible","navigator","_window","userAgent","_listboxRef$current","parentElement","Bar","w-[7px] hover:w-[14px] mr-[2px] hover:px-[2px] hover:mr-0","flex-col h-[7px] hover:h-[14px] mb-[2px] hover:py-[2px] hover:mb-0","ScrollAreaPrimitive","Thumb","Corner","classname","ScrollArea","Multiple","Single","contentClassName","matchesValue","valuesAsChildren","c","MultipleValue","h-8","_buttonRef$current","contentRef","setContentRef","boundaryIndex","overscan","boundaryChildIndex","clientRect","getIndexOfFirstChildOverflowingParent","el","truncate","tagValue","BubbleSelect","selectProps","prevValue","usePreviousValue","getOwnPropertyDescriptor","HTMLSelectElement","prototype","set","call","Search","searchQuery","setSearchQuery","Create","onCreate","handleCreate","nextColor","occurences","reduce","sort","a","getNextColor","Collection","Select2","disableSearch","_setValue","nextValue","allChildren","filteredChildren","_allChildren$","useChildren","ControlledHiddenField","_internalRef$current2","bubbleValue","reset","isFormControl","setIsFormControl","formElement","closest","_ref$current$closest","useIsFormControl","sanitizeRowProps","row","rowExpansionRenderer","indexPath","original","subRows","_row$subRows","toggleRowExpanded","toggleRowEditing","isEditing","getColumnsFromChildren","sortRules","columns","groupChildren","column","sortType","disableSortBy","disableSorting","groupColumns","groupSortRules","accessor","headRenderer","Cell","columnProps","cell","editRenderer","cellRenderer","desc","getInternalSortRules","rule","getTime","parsedValue","getNumber","amount","decimalSeparator","isNaN","getString","guess","compareBasic","compareBasicStrings","compareResult","localeCompare","stringsLocaleCompare","reducer","action","init","allowEditing","editingRowUniqueId","resetRowEditing","resetPage","gotoPage","toggleEditing","useInstance","instance","dispatch","assign","getActions","primary","secondary","visibleActions","showOnRow","getActionProps","EditModeActions","listener","_event$target","_event$target$form","draggingRowIndexPath","resetRowDragging","toggleRowDragging","prepareRow","isDragging","selectedRowIds","_instance$state$selec","visibleColumns","DEFAULT_PAGE_SIZE","useTable","onRowClick","onRowDrag","onSelectedRows","rowClassName","rowHeight","selectedRows","manualSorting","onSort","disablePagination","onPaginate","inlineEditingUniqueId","onRowCreate","onRowEdit","onRowCopy","onRowDelete","onRowActive","windowed","Error","defaultSortRules","manualPagination","headerGroups","rows","sortedRows","prepareBaseRow","page","useReactTable","initialState","sortBy","manualSortBy","autoResetExpanded","autoResetSelectedRows","autoResetSortBy","autoResetPage","sortTypes","datetime","rowA","rowB","columnId","string","number","boolean","auto","useControlledState","currentState","useRowState","useSortBy","useExpanded","usePagination","plugin","hooks","useBaseRowSelect","toggleRowSelected","isSelected","lastSelectedSortedIndex","getToggleAllRowsSelectedProps","getToggleRowSelectedProps","sortedIndex","fromIndex","toIndex","toRowIndex","fromRowIndex","pluginName","useRowSelect","stateReducers","getRowProps","onDragStart","indexPaths","createElement","innerText","appendChild","DataTransfer","setDragImage","dataTransfer","onDragEnd","getElementById","parentNode","removeChild","useRowDraggable","uniqueId","_createKey","canEdit","useRowEditing","handlers","inlineEditing","actionsLength","primaryActions","secondaryActions","getLength","hasActions","sanitizedRow","setActive","InView","rootMargin","inView","useRowActions","useTablePaginationListener","sortedData","useTableSortingListener","sanitizedInstance","toggleAllRowsExpanded","toggleHideAllColumns","toggleHideColumn","toggleSortBy","useTableInstance","visibleRows","handleFocus","rowProps","defaultActiveIndex","onChangeActiveIndex","_props$onChangeActive","isModifierKeyPressed","metaKey","ctrlKey","altKey","activeElement","_document$activeEleme","currentRow","nativeEvent","useTableKeyboardNavigation","handleonRowActive","focusedRow","sanitizedFocusedRow","useTableRowActive","tableProps","renderCell","getCellProps","justify-start text-left","justify-end text-right","text-center","render","Row","minHeight","yt-table__row--active bg-grey-100 hover:bg-grey-100","yt-table__row--clickable","yt-table__row--dragging","yt-table__row--editing","classList","contains","cells","hiddenOnSubRows","expandedRow","rowContent","FocusScope","contain","restoreFocus","Column","getHeaderProps","getSortByToggleProps","yt-table__cell__group","justify-center text-center","isSorted","isSortedDesc","DefaultEmptyState","BaseTable","tableRef","headerRef","bodyRef","headerGroup","headers","Table","emptyStateRenderer","paginationElement","PaginatedTable","VariableRow","memo","setRowHeight","rowHeights","areEqual","getAverageRowHeight","p","WindowedTable","loadMore","rowsRef","setRowsRef","tableDimensions","headerDimensions","estimatedRowHeight","resetAfterIndex","getRowHeight","scrollToItem","table-with-scrollbar","listProps","itemData","estimatedItemSize","itemSize","InfiniteLoader","isItemLoaded","itemCount","loadMoreItems","onItemsRendered","VariableSizeList","convertRowIndexPathToNumberArray","rowIndexPath","getByRowIndexPath","currenTRow","startIndex","shift","_value$subRows","getParentRowIndexPath","parentIndexPath","rowIndexes","insertChildTableRow","nexTRow","parse","childRowIndexPath","nextSubRows","unshift","removeChildTableRow","rootIndex","unsetPath","unset","setPath","get","pullAt","Tabs","flex w-full","TabsPrimitive","dir","TabList","TabTrigger","TabContent","List","Textarea","classNames","Switch","mr-2","bg-grey-500 hover:bg-grey-300 aria-checked:bg-blue-500 aria-checked:hover:bg-blue-300 focus:yt-focus","bg-grey-100 cursor-not-allowed aria-checked:bg-blue-300","PrimitiveSwitch","continuous","isLastStep","step","backProps","primaryProps","skipProps","tooltipProps","disableTourSkipOnEsc","skipButtonRef","onWindowKeyDown","TourStep","_props","Tour","autoStart","run","onComplete","onReady","spotlightClicks","disableCloseOnEsc","disableScrollParentFix","scrollOffset","steps","disableBeacon","showBeacon","getStep","_props$children$find","Joyride","showProgress","floaterProps","disableAnimation","tooltipComponent","spotlightPadding","ACTIONS","SKIP","lifecycle","LIFECYCLE","COMPLETE","EVENTS","TOUR_END","READY","styles","primaryColor","Step","animationDuration","progressClassName","w-full before:h-1 before:bg-grey-300 before:block before:animate-[progress-indeterminate_2s_cubic-bezier(0.4,0,0.2,1)_infinite] before:content-[' ']","w-0 bg-grey-300 animate-[progress_linear]","tempDate","setIndex","some","currentRef","initialPageIndex","initialPageSize","internalData","setInternalData","activeRowIndexPath","setActiveRowIndexPath","parentId","newRowIndexPath","remove","isCreating"],"mappings":"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MsN5B0N,YzMtNWjR,aAAiBwD,IyMuN5B0N,WxMvNWlR,aAAiByD,IwMwN5B0N,cvMxNWnR,aAAiB0D,IuMyN5B0N,gBtMzNWpR,aAAiB2D,IsM0N5B0N,OrM1NWrR,aAAiB4D,IqM2N5B0N,kBpM3NWtR,aAAiB6D,IoM4N5B0N,SnM5NWvR,aAAiB8D,ImM6N5B0N,alM7NWxR,aAAiB+D,IkM8N5B0N,MjM9NWzR,aAAiBgE,IiM+N5B0N,ahM/NW1R,aAAiBiE,IgMgO5B0N,K/LhOW3R,aAAiBkE,I+LiO5B0N,Q9LjOW5R,aAAiBmE,I8LkO5B0N,O7LlOW7R,aAAiBoE,I6LmO5B0N,S5LnOW9R,aAAiBqE,I4LoO5B0N,e3LrOW/R,aAAiBsE,I2LsO5B0N,e1LrOWhS,aAAiBuE,I0LsO5B0N,azLtOWjS,aAAiBwE,IyLuO5B0N,KxLvOWlS,aAAiByE,IwLwO5B0N,sBvLxOWnS,aAAiB0E,IuLyO5B0N,qBtLzOWpS,aAAiB2E,IsL0O5B0N,erL1OWrS,aAAiB4E,IqL2O5B0N,sBpL3OWtS,aAAiB6E,IoL4O5B0N,qBnL3OWvS,aAAiB8E,ImL4O5B0N,elL7OWxS,aAAiBgF,IkL8O5ByN,uBjL9OWzS,aAAiBiF,IiL+O5ByN,sBhL9OW1S,aAAiBkF,IgL+O5ByN,gB/KhPW3S,aAAiBmF,I+KiP5ByN,oB9KjPW5S,aAAiBoF,I8KkP5ByN,mB7KlPW7S,aAAiBqF,I6KmP5ByN,a5KnPW9S,aAAiBsF,I4KoP5ByN,e3KnPW/S,aAAiBuF,I2KoP5ByN,e1KrPWhT,aAAiBwF,I0KsP5ByN,czKtPWjT,aAAiByF,IyKuP5ByN,cxKvPWlT,aAAiB0F,IwKwP5ByN,avKxPWnT,aAAiB2F,IuKyP5ByN,MtKzPWpT,aAAiB4F,IsK0P5ByN,MrK1PWrT,aAAiB6F,IqK2P5ByN,oBpK5PWtT,aAAiB8F,IoK6P5ByN,oBnK7PWvT,aAAiB+F,ImK8P5ByN,SlK7PWxT,aAAiBgG,IkK8P5ByN,KjK9PWzT,aAAiBiG,IiK+P5ByN,QhKhQW1T,aAAiBkG,IgKiQ5ByN,O/JhQW3T,aAAiBmG,I+JiQ5ByN,qB9JjQW5T,aAAiBoG,I8JkQ5ByN,O7JlQW7T,aAAiBqG,I6JmQ5ByN,W5JnQW9T,aAAiBsG,I4JoQ5ByN,U3JpQW/T,aAAiBuG,I2JqQ5ByN,wB1JrQWhU,aAAiBwG,I0JsQ5ByN,mBzJtQWjU,aAAiByG,IyJuQ5ByN,wBxJvQWlU,aAAiB0G,IwJwQ5ByN,evJxQWnU,aAAiB2G,IuJyQ5ByN,iBtJzQWpU,aAAiB4G,IsJ0Q5ByN,wBrJ1QWrU,aAAiB6G,IqJ2Q5ByN,iBpJ3QWtU,aAAiB8G,IoJ4Q5ByN,gBnJ5QWvU,aAAiB+G,ImJ6Q5ByN,mBlJ7QWxU,aAAiBgH,IkJ8Q5ByN,oBjJ/QWzU,aAAiBiH,IiJgR5ByN,4BhJhRW1U,aAAiBkH,IgJiR5ByN,iB/IhRW3U,aAAiBmH,I+IiR5ByN,gB9IjRW5U,aAAiBoH,I8IkR5ByN,S7InRW7U,aAAiBqH,I6IoR5ByN,S5InRW9U,aAAiBsH,I4IoR5ByN,K3IpRW/U,aAAiBuH,I2IqR5ByN,Y1IrRWhV,aAAiBwH,I0IsR5ByN,czItRWjV,aAAiByH,IyIuR5ByN,KxIvRWlV,aAAiB0H,IwIwR5ByN,sBvIxRWnV,aAAiB2H,IuIyR5ByN,oBtIzRWpV,aAAiB4H,IsI0R5ByN,qBrI1RWrV,aAAiB6H,IqI2R5ByN,epI3RWtV,aAAiB8H,IoI4R5ByN,kBnI5RWvV,aAAiB+H,ImI6R5ByN,8BlI7RWxV,aAAiBgI,IkI8R5ByN,8BjI9RWzV,aAAiBiI,IiI+R5ByN,2BhI/RW1V,aAAiBkI,IgIgS5ByN,qC/H7RW3V,aAAiBmI,I+H8R5ByN,8B9HjSW5V,aAAiBoI,I8HkS5ByN,8B7HlSW7V,aAAiBqI,I6HmS5ByN,oB5HnSW9V,aAAiBsI,I4HoS5ByN,S3HpSW/V,aAAiBuI,I2HqS5ByN,c1HrSWhW,aAAiBwI,I0HsS5ByN,SzHtSWjW,aAAiByI,IyHuS5ByN,kBxHvSWlW,aAAiB0I,IwHwS5ByN,gBvHxSWnW,aAAiB2I,IuHyS5ByN,OtHzSWpW,aAAiB4I,IsH0S5ByN,erH1SWrW,aAAiB6I,IqH2S5ByN,OpH3SWtW,aAAiB8I,IoH4S5ByN,cnH5SWvW,aAAiB+I,ImH6S5ByN,KlH7SWxW,aAAiBgJ,IkH8S5ByN,KjH9SWzW,aAAiBiJ,IiH+S5ByN,OhH/SW1W,aAAiBkJ,IgHgT5ByN,O/GhTW3W,aAAiBmJ,I+GiT5ByN,mB9GhTW5W,aAAiBoJ,I8GiT5ByN,iB7GjTW7W,aAAiBqJ,I6GkT5ByN,c5GlTW9W,aAAiBsJ,I4GmT5ByN,M3GnTW/W,aAAiBuJ,I2GoT5ByN,K1GrTWhX,aAAiBwJ,I0GsT5ByN,mBzGtTWjX,aAAiByJ,IyGuT5ByN,UxGvTWlX,aAAiB0J,IwGwT5ByN,cvGxTWnX,aAAiB2J,IuGyT5ByN,ctGzTWpX,aAAiB4J,IsG0T5ByN,erG1TWrX,aAAiB6J,IqG2T5ByN,cpG3TWtX,aAAiB8J,IoG4T5ByN,cnG5TWvX,aAAiB+J,ImG6T5ByN,OlG7TWxX,aAAiBgK,IkG8T5ByN,gCjG9TWzX,aAAiBiK,IiG+T5ByN,sChG5TW1X,aAAiBkK,IgG6T5ByN,6B/FhUW3X,aAAiBmK,I+FiU5ByN,4B9FjUW5X,aAAiBoK,I8FkU5ByN,6B7FlUW7X,aAAiBqK,I6FmU5ByN,kC5FnUW9X,aAAiBsK,I4FoU5ByN,+B3FpUW/X,aAAiBuK,I2FqU5ByN,wC1FlUWhY,aAAiBwK,I0FmU5ByN,czFtUWjY,aAAiByK,IyFuU5ByN,UxFvUWlY,aAAiB0K,IwFwU5ByN,KvFxUWnY,aAAiB2K,IuFyU5ByN,gBtFzUWpY,aAAiB4K,IsF0U5ByN,crF1UWrY,aAAiB6K,IqF2U5ByN,KpF3UWtY,aAAiB8K,IoF4U5ByN,YnF5UWvY,aAAiB+K,ImF6U5ByN,UlF5UWxY,aAAiBgL,IkF6U5ByN,IjF9UWzY,aAAiBiL,IiF+U5ByN,OhF/UW1Y,aAAiBkL,IgFgV5ByN,e/EhVW3Y,aAAiBmL,I+EiV5ByN,gB9EjVW5Y,aAAiBoL,I8EkV5ByN,K7EnVW7Y,aAAiBqL,I6EoV5ByN,Q5EnVW9Y,aAAiBsL,I4EoV5ByN,e3EpVW/Y,aAAiBuL,I2EqV5ByN,e1ErVWhZ,aAAiBwL,I0EsV5ByN,azEtVWjZ,aAAiByL,IyEuV5ByN,KxEvVWlZ,aAAiB0L,IwEwV5ByN,KvExVWnZ,aAAiB2L,IuEyV5ByN,kBtEzVWpZ,aAAiB4L,IsE0V5ByN,iBrE1VWrZ,aAAiB6L,IqE2V5ByN,YpE3VWtZ,aAAiB8L,IoE4V5ByN,KnE5VWvZ,aAAiB+L,ImE6V5ByN,QlE9VWxZ,aAAiBgM,IkE+V5ByN,cjE9VWzZ,aAAiBiM,IiE+V5ByN,OhE/VW1Z,aAAiBkM,IgEgW5ByN,gB/DhWW3Z,aAAiBmM,I+DiW5ByN,e9DjWW5Z,aAAiBoM,I8DkW5ByN,c7DlWW7Z,aAAiBqM,I6DmW5ByN,c5DnWW9Z,aAAiBsM,I4DoW5ByN,K3DpWW/Z,aAAiBuM,I2DqW5ByN,a1DrWWha,aAAiBwM,I0DsW5ByN,MzDtWWja,aAAiByM,IyDuW5ByN,kBxDvWWla,aAAiB0M,IwDwW5ByN,sBvDxWWna,aAAiB2M,IuDyW5ByN,QtDxWWpa,aAAiB4M,IsDyW5ByN,gBrD1WWra,aAAiB6M,IqD2W5ByN,SpD3WWta,aAAiB8M,IoD4W5ByN,WnD5WWva,aAAiB+M,ImD6W5ByN,oBlD7WWxa,aAAiBgN,IkD8W5ByN,0BjD9WWza,aAAiBiN,IiD+W5ByN,WhD/WW1a,aAAiBkN,IgDgX5ByN,Q/CjXW3a,aAAiBmN,I+CkX5ByN,e9CjXW5a,aAAiBoN,I8CkX5ByN,O7ClXW7a,aAAiBqN,I6CmX5ByN,Q5CnXW9a,aAAiBsN,I4CoX5ByN,c3CrXW/a,aAAiBuN,I2CsX5ByN,e1CtXWhb,aAAiBwN,I0CuX5ByN,MzCtXWjb,aAAiByN,IyCuX5ByN,cxCvXWlb,aAAiB0N,IwCwX5ByN,OvCxXWnb,aAAiB2N,IuCyX5ByN,ctCzXWpb,aAAiB4N,IsC0X5ByN,OrC1XWrb,aAAiB6N,IqC2X5ByN,iBpC3XWtb,aAAiB8N,IoC4X5ByN,SnC5XWvb,aAAiB+N,ImC6X5ByN,UlC7XWxb,aAAiBgO,IkC8X5ByN,WjC9XWzb,aAAiBiO,IiC+X5ByN,YhC/XW1b,aAAiBkO,IgCgY5ByN,Y/BhYW3b,aAAiBmO,I+BiY5ByN,gB9BjYW5b,aAAiBoO,I8BkY5ByN,Q7BlYW7b,aAAiBqO,I6BmY5ByN,S5BnYW9b,aAAiBsO,I4BoY5ByN,U3BpYW/b,aAAiBuO,I2BqY5ByN,Q1BtY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"}
|
1
|
+
{"version":3,"file":"taco.cjs.production.min.js","sources":["../src/components/AlertDialog/Context.tsx","../src/utils/mergeRefs.ts","../src/components/AlertDialog/components/Trigger.tsx","../src/components/AlertDialog/components/Footer.tsx","../src/components/Backdrop/Backdrop.tsx","../src/components/Dialog/util.ts","../src/components/AlertDialog/components/Content.tsx","../src/components/AlertDialog/AlertDialog.tsx","../src/components/Icon/components/AccountPreview.tsx","../src/components/Icon/components/AccountingYearCancel.tsx","../src/components/Icon/components/AccountingYear.tsx","../src/components/Icon/components/Accounting.tsx","../src/components/Icon/components/ArrowBottom.tsx","../src/components/Icon/components/ArrowDown.tsx","../src/components/Icon/components/ArrowEnd.tsx","../src/components/Icon/components/ArrowLeft.tsx","../src/components/Icon/components/ArrowRight.tsx","../src/components/Icon/components/ArrowStart.tsx","../src/components/Icon/components/ArrowTop.tsx","../src/components/Icon/components/ArrowUp.tsx","../src/components/Icon/components/AttachAuto.tsx","../src/components/Icon/components/AttachCancel.tsx","../src/components/Icon/components/Attach.tsx","../src/components/Icon/components/AutotextInsert.tsx","../src/components/Icon/components/Autotext.tsx","../src/components/Icon/components/BasicTabs.tsx","../src/components/Icon/components/Basic.tsx","../src/components/Icon/components/BellSolid.tsx","../src/components/Icon/components/Book.tsx","../src/components/Icon/components/Booking.tsx","../src/components/Icon/components/Budget.tsx","../src/components/Icon/components/Calendar.tsx","../src/components/Icon/components/CashAccount.tsx","../src/components/Icon/components/CashReports.tsx","../src/components/Icon/components/ChatSolid.tsx","../src/components/Icon/components/Chat.tsx","../src/components/Icon/components/ChevronDownDouble.tsx","../src/components/Icon/components/ChevronDownSolid.tsx","../src/components/Icon/components/ChevronDown.tsx","../src/components/Icon/components/ChevronLeftDouble.tsx","../src/components/Icon/components/ChevronLeftSolid.tsx","../src/components/Icon/components/ChevronLeft.tsx","../src/components/Icon/components/ChevronRightDouble.tsx","../src/components/Icon/components/ChevronRightSolid.tsx","../src/components/Icon/components/ChevronRight.tsx","../src/components/Icon/components/ChevronUpDouble.tsx","../src/components/Icon/components/ChevronUpSolid.tsx","../src/components/Icon/components/ChevronUp.tsx","../src/components/Icon/components/CircleClose.tsx","../src/components/Icon/components/CircleMinus.tsx","../src/components/Icon/components/CirclePlus.tsx","../src/components/Icon/components/CircleTick.tsx","../src/components/Icon/components/ClampOpen.tsx","../src/components/Icon/components/Clamp.tsx","../src/components/Icon/components/Close.tsx","../src/components/Icon/components/ConnectionEnable.tsx","../src/components/Icon/components/ConnectionRevoke.tsx","../src/components/Icon/components/Contacts.tsx","../src/components/Icon/components/Copy.tsx","../src/components/Icon/components/Courses.tsx","../src/components/Icon/components/Credit.tsx","../src/components/Icon/components/DeletePermanently.tsx","../src/components/Icon/components/Delete.tsx","../src/components/Icon/components/Depecriate.tsx","../src/components/Icon/components/Developer.tsx","../src/components/Icon/components/DistributionTemplate.tsx","../src/components/Icon/components/DocumentApprove.tsx","../src/components/Icon/components/DocumentCreateEntry.tsx","../src/components/Icon/components/DocumentCut.tsx","../src/components/Icon/components/DocumentError.tsx","../src/components/Icon/components/DocumentIsolatePage.tsx","../src/components/Icon/components/DocumentMerge.tsx","../src/components/Icon/components/DocumentMove.tsx","../src/components/Icon/components/DocumentPreview.tsx","../src/components/Icon/components/DocumentReceived.tsx","../src/components/Icon/components/DocumentRejectedRequest.tsx","../src/components/Icon/components/DocumentSplit.tsx","../src/components/Icon/components/DocumentTime.tsx","../src/components/Icon/components/Document.tsx","../src/components/Icon/components/Download.tsx","../src/components/Icon/components/Drag.tsx","../src/components/Icon/components/ECopedia.tsx","../src/components/Icon/components/ESignature.tsx","../src/components/Icon/components/Edit.tsx","../src/components/Icon/components/EllipsisHorizontal.tsx","../src/components/Icon/components/EllipsisVertical.tsx","../src/components/Icon/components/EntriesOnAccount.tsx","../src/components/Icon/components/EntriesOpen.tsx","../src/components/Icon/components/EntriesWarning.tsx","../src/components/Icon/components/EntryTypeCustomerInvoice.tsx","../src/components/Icon/components/EntryTypeCustomerPayment.tsx","../src/components/Icon/components/EntryTypeJournalEntry.tsx","../src/components/Icon/components/EntryTypeManualCustomerInvoice.tsx","../src/components/Icon/components/EntryTypeSupplierInvoice.tsx","../src/components/Icon/components/EntryTypeSupplierPayment.tsx","../src/components/Icon/components/EnvelopeApproved.tsx","../src/components/Icon/components/Envelope.tsx","../src/components/Icon/components/ExpandView.tsx","../src/components/Icon/components/Expenses.tsx","../src/components/Icon/components/ExportToExcel.tsx","../src/components/Icon/components/ExportToPdf.tsx","../src/components/Icon/components/Export.tsx","../src/components/Icon/components/FilterSolid.tsx","../src/components/Icon/components/Filter.tsx","../src/components/Icon/components/GraphSolid.tsx","../src/components/Icon/components/Hash.tsx","../src/components/Icon/components/Home.tsx","../src/components/Icon/components/Images.tsx","../src/components/Icon/components/Import.tsx","../src/components/Icon/components/InboxEinvoicing.tsx","../src/components/Icon/components/InboxScanning.tsx","../src/components/Icon/components/InboxSmart.tsx","../src/components/Icon/components/Inbox.tsx","../src/components/Icon/components/Info.tsx","../src/components/Icon/components/InventoryMatrix.tsx","../src/components/Icon/components/Inventory.tsx","../src/components/Icon/components/JournalPro.tsx","../src/components/Icon/components/LayoutBoth.tsx","../src/components/Icon/components/LayoutFirst.tsx","../src/components/Icon/components/LayoutLast.tsx","../src/components/Icon/components/LayoutNone.tsx","../src/components/Icon/components/Layout.tsx","../src/components/Icon/components/LedgerCardCustomerReminder.tsx","../src/components/Icon/components/LedgerCardManualCustomerInvoice.tsx","../src/components/Icon/components/LedgerCardObsoleteStock.tsx","../src/components/Icon/components/LedgerCardOpeningEntry.tsx","../src/components/Icon/components/LedgerCardReservedEntry.tsx","../src/components/Icon/components/LedgerCardShrinkagePilferage.tsx","../src/components/Icon/components/LedgerCardStockAdjustment.tsx","../src/components/Icon/components/LedgerCardTransferredOpeningEntry.tsx","../src/components/Icon/components/LedgerCard.tsx","../src/components/Icon/components/Lightbulb.tsx","../src/components/Icon/components/Line.tsx","../src/components/Icon/components/ListBulleted.tsx","../src/components/Icon/components/ListSearch.tsx","../src/components/Icon/components/List.tsx","../src/components/Icon/components/LockOpen.tsx","../src/components/Icon/components/LogOut.tsx","../src/components/Icon/components/Log.tsx","../src/components/Icon/components/Market.tsx","../src/components/Icon/components/MatchAmount.tsx","../src/components/Icon/components/MatchEntries.tsx","../src/components/Icon/components/Menu.tsx","../src/components/Icon/components/Mileage.tsx","../src/components/Icon/components/ModalResize.tsx","../src/components/Icon/components/ModalShrink.tsx","../src/components/Icon/components/MoreSolid.tsx","../src/components/Icon/components/More.tsx","../src/components/Icon/components/Move.tsx","../src/components/Icon/components/NavigationList.tsx","../src/components/Icon/components/NoteFollowUp.tsx","../src/components/Icon/components/NoteRead.tsx","../src/components/Icon/components/Note.tsx","../src/components/Icon/components/Numbers.tsx","../src/components/Icon/components/PartnerApi.tsx","../src/components/Icon/components/Period.tsx","../src/components/Icon/components/PersonChange.tsx","../src/components/Icon/components/PersonMinus.tsx","../src/components/Icon/components/PersonPlus.tsx","../src/components/Icon/components/PersonTick.tsx","../src/components/Icon/components/Play.tsx","../src/components/Icon/components/PlusMinus.tsx","../src/components/Icon/components/Print.tsx","../src/components/Icon/components/ProcessPayment.tsx","../src/components/Icon/components/ProductLedgerCard.tsx","../src/components/Icon/components/Profile.tsx","../src/components/Icon/components/ProjectCards.tsx","../src/components/Icon/components/Projects.tsx","../src/components/Icon/components/Quicklinks.tsx","../src/components/Icon/components/RatingBankruptcy.tsx","../src/components/Icon/components/RatingPaymentProblems.tsx","../src/components/Icon/components/Reconciled.tsx","../src/components/Icon/components/Refresh.tsx","../src/components/Icon/components/ReportSolid.tsx","../src/components/Icon/components/Report.tsx","../src/components/Icon/components/Restore.tsx","../src/components/Icon/components/RotateLeft.tsx","../src/components/Icon/components/RotateRight.tsx","../src/components/Icon/components/Sales.tsx","../src/components/Icon/components/SearchBold.tsx","../src/components/Icon/components/Search.tsx","../src/components/Icon/components/SecureTick.tsx","../src/components/Icon/components/Secure.tsx","../src/components/Icon/components/SettingsSolid.tsx","../src/components/Icon/components/Settings.tsx","../src/components/Icon/components/Shortcuts.tsx","../src/components/Icon/components/ShowAll.tsx","../src/components/Icon/components/ShowLess.tsx","../src/components/Icon/components/ShowMore.tsx","../src/components/Icon/components/ShowTemplate.tsx","../src/components/Icon/components/Sliders.tsx","../src/components/Icon/components/Smartpay.tsx","../src/components/Icon/components/SortBy.tsx","../src/components/Icon/components/StarSolid.tsx","../src/components/Icon/components/Star.tsx","../src/components/Icon/components/Subscriptions.tsx","../src/components/Icon/components/SystemEntries.tsx","../src/components/Icon/components/Tag.tsx","../src/components/Icon/components/TemplateOverride.tsx","../src/components/Icon/components/Templates.tsx","../src/components/Icon/components/ThumbBoth.tsx","../src/components/Icon/components/ThumbDownSolid.tsx","../src/components/Icon/components/ThumbDown.tsx","../src/components/Icon/components/ThumbUpSolid.tsx","../src/components/Icon/components/ThumbUp.tsx","../src/components/Icon/components/Tick.tsx","../src/components/Icon/components/Time.tsx","../src/components/Icon/components/TransferCancel.tsx","../src/components/Icon/components/TransferLocked.tsx","../src/components/Icon/components/Transfer.tsx","../src/components/Icon/components/Undo.tsx","../src/components/Icon/components/Undock.tsx","../src/components/Icon/components/Unreconciled.tsx","../src/components/Icon/components/Warning.tsx","../src/components/Icon/components/Webshop.tsx","../src/components/Icon/components/Website.tsx","../src/components/Icon/components/Workflow.tsx","../src/components/Icon/components/Zoom.tsx","../src/components/Icon/components/index.tsx","../src/components/Icon/Icon.tsx","../src/components/Accordion/Accordion.tsx","../src/components/VisuallyHidden/VisuallyHidden.tsx","../src/utils/taillwind.ts","../src/components/Badge/Badge.tsx","../src/primitives/Button.tsx","../src/components/Tooltip/Tooltip.tsx","../src/components/Button/util.tsx","../src/components/IconButton/IconButton.tsx","../src/components/Provider/Localization.tsx","../src/components/Banner/Banner.tsx","../src/components/Banner/util.tsx","../src/components/Button/Button.tsx","../src/components/Calendar/Calendar.tsx","../src/components/Card/Card.tsx","../src/hooks/useId.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/Input/util.ts","../src/utils/debounce.ts","../src/hooks/useBoundingClientRectListener.ts","../src/hooks/useMergedRef.ts","../src/components/Input/Input.tsx","../src/utils/hooks/useListKeyboardNavigation.ts","../src/utils/hooks/useListScrollTo.ts","../src/components/Spinner/Spinner.tsx","../src/components/Listbox/ScrollableList.tsx","../src/utils/input.ts","../src/components/Listbox/util.ts","../src/components/Combobox/useCombobox.tsx","../src/components/Combobox/Combobox.tsx","../src/utils/date.ts","../src/components/Popover/Primitives.tsx","../src/components/Popover/Popover.tsx","../src/components/Popover/util.ts","../src/components/Datepicker/Datepicker.tsx","../src/components/Datepicker/useDatepicker.tsx","../src/components/Dialog/Context.tsx","../src/components/Dialog/components/Trigger.tsx","../src/components/Dialog/components/Content.tsx","../src/utils/hooks/useDraggable.tsx","../src/components/Dialog/components/Drawer.tsx","../src/components/Dialog/components/Extra.tsx","../src/components/Dialog/Dialog.tsx","../src/components/Field/Field.tsx","../src/components/Form/Form.tsx","../src/components/Group/Group.tsx","../src/components/Hanger/Hanger.tsx","../src/components/HoverCard/Primitives.tsx","../src/components/HoverCard/HoverCard.tsx","../src/components/SearchInput/SearchInput.tsx","../src/utils/hooks/useTimer.ts","../src/components/Listbox/useTypeahead.tsx","../src/components/Listbox/Listbox.tsx","../src/components/Listbox/useListbox.tsx","../src/components/Listbox/useMultiListbox.tsx","../src/components/Menu/Context.tsx","../src/components/Menu/components/Content.tsx","../src/components/Menu/components/Item.tsx","../src/components/Menu/components/Link.tsx","../src/components/Menu/components/Trigger.tsx","../src/components/Menu/components/Checkbox.tsx","../src/components/RadioGroup/RadioGroup.tsx","../src/components/Menu/components/RadioGroup.tsx","../src/components/Menu/components/Header.tsx","../src/components/Menu/Menu.tsx","../src/components/Menu/components/Separator.tsx","../src/components/Treeview/Treeview.tsx","../src/utils/hooks/useDropTarget.ts","../src/components/Navigation/Navigation.tsx","../src/components/Pagination/PageNumbers.tsx","../src/components/Select/Select.tsx","../src/components/Select/useSelect.tsx","../src/components/Pagination/Pagination.tsx","../src/components/Pagination/usePaginationShortcuts.tsx","../src/components/Toast/Toast.tsx","../src/components/Toast/util.tsx","../src/components/Toast/Toaster.tsx","../src/utils/aria.ts","../src/primitives/Collection/components/Root.tsx","../src/primitives/Listbox2/components/Context.tsx","../src/primitives/Listbox2/components/Root.tsx","../src/primitives/Listbox2/components/Option.tsx","../src/primitives/Listbox2/components/Group.tsx","../src/primitives/Listbox2/components/Title.tsx","../src/components/Tag/Tag.tsx","../src/components/Select2/components/Context.tsx","../../../node_modules/babel-plugin-transform-async-to-promises/helpers.mjs","../src/components/Select2/components/Edit.tsx","../src/utils/device.ts","../src/components/Select2/components/Option.tsx","../src/components/Select2/utilities.ts","../src/components/Select2/components/Group.tsx","../src/components/Select2/components/Title.tsx","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select2/components/Trigger.tsx","../src/utils/dom.ts","../src/primitives/BubbleSelect.tsx","../src/hooks/usePrevious.ts","../src/components/Select2/components/Search.tsx","../src/components/Select2/components/Create.tsx","../src/components/Select2/components/Collection.tsx","../src/components/Select2/Select2.tsx","../src/components/Select2/hooks/useChildren.tsx","../src/hooks/useIsFormControl.ts","../src/components/Table/util.ts","../src/components/Table/util/sortTypes.ts","../src/components/Table/hooks/plugins/useRowEditing.tsx","../src/components/Table/hooks/plugins/useRowActions.tsx","../src/components/Table/hooks/plugins/useRowDraggable.tsx","../src/components/Table/hooks/useTable.tsx","../src/components/Table/hooks/plugins/useRowSelect.tsx","../src/components/Table/hooks/useTableKeyboardNavigation.ts","../src/components/Table/util/renderRow.tsx","../src/components/Table/util/renderColumn.tsx","../src/components/Table/components/BaseTable.tsx","../src/components/Table/components/Table.tsx","../src/components/Table/components/PaginatedTable.tsx","../src/components/Table/components/WindowedTable.tsx","../src/components/Table/util/rowIndexPath.ts","../src/components/Table/hooks/useRowCreation.tsx","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/Textarea.tsx","../src/components/Switch/Switch.tsx","../src/components/Tour/Tour.tsx","../src/components/Progress/Progress.tsx","../src/components/Provider/Provider.tsx","../src/utils/hooks/useOnClickOutside.ts","../src/components/Pagination/usePagination.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-empty-function */\nimport React from 'react';\n\nexport type AlertDialogContext = {\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n};\n\nexport const AlertDialogContext = React.createContext<AlertDialogContext>({\n props: {},\n ref: null,\n});\n\nexport const useCurrentAlertDialog = () => {\n return React.useContext(AlertDialogContext);\n};\n","import React from 'react';\n\nexport function mergeRefs<T = any>(refs: Array<React.MutableRefObject<T> | React.LegacyRef<T>>): React.RefCallback<T> {\n return value => {\n refs.forEach(ref => {\n if (typeof ref === 'function') {\n ref(value);\n } else if (ref != null) {\n (ref as React.MutableRefObject<T | null>).current = value;\n }\n });\n };\n}\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport { useCurrentAlertDialog } from '../Context';\nimport { mergeRefs } from '../../../utils/mergeRefs';\n\nexport type AlertDialogTriggerProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Trigger = React.forwardRef(function AlertDialogTrigger(\n props: AlertDialogTriggerProps,\n externalRef: React.Ref<HTMLButtonElement>\n) {\n const { ref: parentRef, props: parentProps } = useCurrentAlertDialog();\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n return <AlertDialogPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild />;\n});\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\n\nexport type AlertDialogFooterProps = React.HTMLAttributes<HTMLDivElement>;\nexport const Footer = React.forwardRef(function AlertDialogFooter(props: AlertDialogFooterProps, ref: React.Ref<HTMLDivElement>) {\n const className = 'flex justify-end gap-2';\n\n return (\n <div {...props} className={className} ref={ref}>\n {props.children}\n </div>\n );\n});\n\nexport type AlertDialogCancelProps = React.HTMLAttributes<HTMLButtonElement>;\nexport const Cancel = React.forwardRef(function AlertDialogCancel(\n props: AlertDialogCancelProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n return <AlertDialogPrimitive.Cancel {...props} ref={ref} asChild />;\n});\n\nexport type AlertDialogActionProps = React.HTMLAttributes<HTMLButtonElement>;\nexport const Action = React.forwardRef(function AlertDialogAction(\n props: AlertDialogActionProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n return <AlertDialogPrimitive.Action {...props} className={props.className} ref={ref} asChild />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\n\nexport type BackdropProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Backdrop = React.forwardRef<HTMLDivElement, BackdropProps>(function Backdrop(props, ref) {\n const className = cn('fixed inset-0 cursor-default overflow-y-auto bg-blue-900/[0.3] aria-hidden:invisible', props.className);\n\n return <div {...props} className={className} data-taco=\"backdrop\" ref={ref} />;\n});\n","import { DialogSize } from './types';\n\nexport const getDialogSizeClassnames = (size: DialogSize) => {\n switch (size) {\n case 'dialog':\n return 'w-128';\n case 'xs':\n return 'w-xs';\n case 'sm':\n return 'w-sm';\n case 'md':\n return 'w-md';\n case 'lg':\n return 'w-lg';\n }\n};\n\nexport const getDialogPositionClassnames = () => 'mt-16 mx-auto';\n\nexport const getDialogStylingClassnames = () =>\n 'bg-white rounded animate-[fade-in_150ms] shadow-[0_6px_9px_0_rgba(89,85,98,0.3),0_0_1px_0_rgba(89,85,98,0.2)]';\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport cn from 'classnames';\nimport { Backdrop } from '../../Backdrop/Backdrop';\nimport { getDialogPositionClassnames, getDialogSizeClassnames, getDialogStylingClassnames } from '../../Dialog/util';\n\nexport type AlertDialogTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function AlertDialogTitle(\n props: AlertDialogTitleProps,\n ref: React.Ref<HTMLHeadingElement>\n) {\n const className = cn('text-center', props.className);\n return <AlertDialogPrimitive.Title {...props} className={className} ref={ref} />;\n});\n\nexport type AlertDialogContentProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & {\n /** An accessible label to be announced when the dialog is opened */\n 'aria-label': string;\n children: React.ReactNode;\n};\nexport const Content = React.forwardRef(function AlertDialogContent(\n props: AlertDialogContentProps,\n ref: React.Ref<HTMLDivElement>\n) {\n const className = cn('p-6', getDialogPositionClassnames(), getDialogStylingClassnames(), getDialogSizeClassnames('dialog'));\n\n return (\n <AlertDialogPrimitive.Portal>\n <AlertDialogPrimitive.Overlay asChild>\n <Backdrop>\n <AlertDialogPrimitive.Content\n {...props}\n ref={ref}\n className={className}\n onEscapeKeyDown={event => event.preventDefault()}>\n {props.children}\n </AlertDialogPrimitive.Content>\n </Backdrop>\n </AlertDialogPrimitive.Overlay>\n </AlertDialogPrimitive.Portal>\n );\n});\n","import * as React from 'react';\nimport * as AlertDialogPrimitive from '@radix-ui/react-alert-dialog';\nimport { AlertDialogContext } from './Context';\nimport { Trigger, AlertDialogTriggerProps } from './components/Trigger';\nimport {\n Cancel,\n Action,\n Footer,\n AlertDialogCancelProps,\n AlertDialogActionProps,\n AlertDialogFooterProps,\n} from './components/Footer';\nimport { Title, Content, AlertDialogContentProps, AlertDialogTitleProps } from './components/Content';\n\nexport type AlertDialogProps = {\n children: React.ReactNode | React.ReactNode[];\n /** Set whether the alert dialog is open by default or not, use when not providing a trigger */\n defaultOpen?: boolean;\n /** Called when the alert dialog opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the dialog from outside the component */\n open?: boolean;\n /** A trigger to be used for the alert dialog, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\n\nexport type ForwardedAlertDialogWithStatics = React.ForwardRefExoticComponent<\n AlertDialogProps & React.RefAttributes<HTMLElement>\n> & {\n Trigger: React.ForwardRefExoticComponent<AlertDialogTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n Content: React.ForwardRefExoticComponent<AlertDialogContentProps & React.RefAttributes<HTMLDivElement>>;\n Title: React.ForwardRefExoticComponent<AlertDialogTitleProps & React.RefAttributes<HTMLHeadingElement>>;\n Footer: React.ForwardRefExoticComponent<AlertDialogFooterProps & React.RefAttributes<HTMLDivElement>>;\n Action: React.ForwardRefExoticComponent<AlertDialogActionProps & React.RefAttributes<HTMLButtonElement>>;\n Cancel: React.ForwardRefExoticComponent<AlertDialogCancelProps & React.RefAttributes<HTMLButtonElement>>;\n};\n\nexport const AlertDialog = React.forwardRef(function AlertDialog(props: AlertDialogProps, ref: React.Ref<HTMLElement>) {\n const { children: initialChildren, defaultOpen, onChange, open, trigger, ...otherProps } = props;\n\n const context = React.useMemo(\n () => ({\n props: otherProps,\n ref,\n }),\n [open, otherProps]\n );\n\n return (\n <AlertDialogContext.Provider value={context}>\n <AlertDialogPrimitive.Root {...props} defaultOpen={defaultOpen} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {props.children}\n </AlertDialogPrimitive.Root>\n </AlertDialogContext.Provider>\n );\n}) as ForwardedAlertDialogWithStatics;\n\nAlertDialog.Trigger = Trigger;\nAlertDialog.Content = Content;\nAlertDialog.Title = Title;\nAlertDialog.Cancel = Cancel;\nAlertDialog.Action = Action;\nAlertDialog.Footer = Footer;\n","import * as React from 'react';\nfunction IconAccountPreview(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v14.5a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-4.5 7.25a4.5 4.5 0 013.632 7.158l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.5 4.5 0 11-2.495-8.245zm0 1.5a3 3 0 100 6 3 3 0 000-6zm-7 3.25a.75.75 0 110 1.5h-.5a.75.75 0 110-1.5h.5zm0-4a.75.75 0 110 1.5h-.5a.75.75 0 110-1.5h.5zm9-4a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5zm-9 0a.75.75 0 010 1.5h-.5a.75.75 0 010-1.5h.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountPreview);\n","import * as React from 'react';\nfunction IconAccountingYearCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M4.5 16.25v3a.25.25 0 00.193.243l.057.007H13V21H4.75A1.75 1.75 0 013 19.25v-3h1.5zm4.946-6.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.718-1.72H3.75a.75.75 0 01-.102-1.493L3.75 13h6.44l-1.72-1.72a.75.75 0 01-.073-.976l.073-.084a.75.75 0 01.976-.073zM16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75V13h-1.5V8h-15v3.25H3v-6.5C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5zm12.804 10.147a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountingYearCancel);\n","import * as React from 'react';\nfunction IconAccountingYear(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25v-3h1.5v3a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V8h-15v3.25H3v-6.5C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zm-6.804 8.147l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H3.75a.75.75 0 01-.102-1.493L3.75 13h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccountingYear);\n","import * as React from 'react';\nfunction IconAccounting(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h12.5zM13 17.5H6.5a.5.5 0 00-.492.41L6 18v1.5a.5.5 0 00.41.492L6.5 20H13a.5.5 0 00.492-.41l.008-.09V18a.5.5 0 00-.41-.492L13 17.5zm4.5 0h-2a.5.5 0 00-.492.41L15 18v1.5a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 19.5V18a.5.5 0 00-.41-.492l-.09-.008zm-9-3.5h-2a.5.5 0 00-.492.41L6 14.5V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L9 16v-1.5a.5.5 0 00-.41-.492L8.5 14zm9 0h-2a.5.5 0 00-.492.41L15 14.5V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 16v-1.5a.5.5 0 00-.41-.492L17.5 14zM13 14h-2a.5.5 0 00-.492.41l-.008.09V16a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L13.5 16v-1.5a.5.5 0 00-.41-.492L13 14zm-4.5-3.5h-2a.5.5 0 00-.492.41L6 11v1.5a.5.5 0 00.41.492L6.5 13h2a.5.5 0 00.492-.41L9 12.5V11a.5.5 0 00-.41-.492L8.5 10.5zm9 0h-2a.5.5 0 00-.492.41L15 11v1.5a.5.5 0 00.41.492l.09.008h2a.5.5 0 00.492-.41L18 12.5V11a.5.5 0 00-.41-.492l-.09-.008zm-4.5 0h-2a.5.5 0 00-.492.41L10.5 11v1.5a.5.5 0 00.41.492L11 13h2a.5.5 0 00.492-.41l.008-.09V11a.5.5 0 00-.41-.492L13 10.5zM17.5 4h-11a.5.5 0 00-.492.41L6 4.5V8a.5.5 0 00.41.492l.09.008h11a.5.5 0 00.492-.41L18 8V4.5a.5.5 0 00-.41-.492L17.5 4zm-1 1a.5.5 0 01.5.5V7a.5.5 0 01-.5.5h-1A.5.5 0 0115 7V5.5a.5.5 0 01.5-.5h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAccounting);\n","import * as React from 'react';\nfunction IconArrowBottom(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.25 18h7.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5zM12 4.5a.75.75 0 01.743.648l.007.102v8.189l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012L12 16l-.029-.002h-.023l-.021-.003-.054-.006-.07-.015-.072-.024-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.22 2.219V5.25A.75.75 0 0112 4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowBottom);\n","import * as React from 'react';\nfunction IconArrowDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 6.25a.75.75 0 01.743.648L12.75 7l-.001 8.189 2.22-2.22a.75.75 0 011.134.977l-.073.084-3.5 3.5-.038.036-.046.037h-.002l-.008.007-.081.051-.134.056-.085.02-.084.011h-.103l-.12-.018-.12-.039-.078-.038-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.219 2.218L11.25 7a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowDown);\n","import * as React from 'react';\nfunction IconArrowEnd(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.75 7.5a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm-6.554.397l.084.073 3.5 3.5c.025.024.048.05.069.078l-.069-.078.04.042.04.052.068.114.038.098.02.084.012.088v.104l-.018.119-.03.098-.047.1-.032.051-.027.038-.064.072-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.219-2.22H5.25a.75.75 0 01-.102-1.493l.102-.007h8.189l-2.22-2.22a.75.75 0 01.977-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowEnd);\n","import * as React from 'react';\nfunction IconArrowLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.03 7.97a.75.75 0 01.073.976l-.073.084-2.219 2.219L17 11.25a.75.75 0 01.102 1.493L17 12.75l-8.19-.001 2.22 2.22a.75.75 0 01-.976 1.134l-.084-.073-3.5-3.5-.08-.094-.051-.081-.05-.116-.027-.103-.01-.089v-.094l.018-.124.03-.099.047-.099.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowLeft);\n","import * as React from 'react';\nfunction IconArrowRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.946 7.897l.084.073 3.5 3.5.036.038.044.056.051.081.05.116.027.103.01.084v.103l-.018.12-.039.12-.038.078-.06.09-.063.071-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.218-2.22H7a.75.75 0 01-.102-1.493L7 11.25h8.189l-2.22-2.22a.75.75 0 01.977-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowRight);\n","import * as React from 'react';\nfunction IconArrowStart(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.25 7.5a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm7.53.47a.75.75 0 01.073.976l-.073.084-2.219 2.22h8.189a.75.75 0 01.102 1.493l-.102.007h-8.189l2.22 2.22a.75.75 0 01-.977 1.133l-.084-.073-3.5-3.5-.055-.06-.046-.065-.049-.088-.044-.12-.018-.089L8 11.965l.019-.136.03-.098.047-.1.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowStart);\n","import * as React from 'react';\nfunction IconArrowTop(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.86 8.013l.067-.01.125-.001.119.018.098.03.1.047.051.032.038.027.072.064 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219v8.189a.75.75 0 01-1.493.102l-.007-.102v-8.189l-2.22 2.22a.75.75 0 01-1.133-.977l.073-.084 3.5-3.5.042-.04.052-.04.114-.068.098-.038.084-.02zM15.75 4.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowTop);\n","import * as React from 'react';\nfunction IconArrowUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.864 6.262l.089-.01h.095l.123.018.12.039.078.038.09.06.071.063 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219V17a.75.75 0 01-1.493.102L11.25 17V8.81l-2.22 2.22a.75.75 0 01-1.133-.976l.073-.084 3.5-3.5.094-.08.081-.051.134-.056.085-.02z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconArrowUp);\n","import * as React from 'react';\nfunction IconAttachAuto(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.916 10.159l1.06 1.06-2.663 2.665a3.75 3.75 0 005.159 5.44l.144-.137 6.657-6.657a.75.75 0 011.128.984l-.067.077-6.657 6.657a5.25 5.25 0 01-7.575-7.269l.15-.156 2.664-2.664zm11.771-6.468a3.75 3.75 0 01.137 5.16l-.137.144-9.132 9.132a2.25 2.25 0 01-3.287-3.07l.105-.112 6.657-6.657a.75.75 0 011.128.984l-.067.076-6.657 6.657a.75.75 0 00.984 1.128l.077-.067 9.132-9.132a2.25 2.25 0 00-3.07-3.287l-.112.105-2.933 2.932-1.061-1.061 2.933-2.932a3.75 3.75 0 015.303 0zM4 9a2 2 0 002 2 2 2 0 00-1.995 1.85L4 13l-.004-.132A2 2 0 002 11a2 2 0 002-2zm6-2.5a2 2 0 002 2 2 2 0 00-1.995 1.85L10 10.5l-.004-.132A2 2 0 008 8.5a2 2 0 002-2zM6.5 2c0 2.21 2.015 4 4.5 4-2.412 0-4.381 1.687-4.495 3.806L6.5 10l-.01-.263C6.338 7.65 4.386 6 2 6c2.485 0 4.5-1.79 4.5-4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttachAuto);\n","import * as React from 'react';\nfunction IconAttachCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.026 18.467a.75.75 0 01-.977 1.133l-.084-.073-2.288-2.288-3.005 3.006a5.25 5.25 0 01-7.574-7.269l.15-.156 3.005-3.005-2.288-2.288a.75.75 0 01.977-1.133l.084.073 12 12zm-9.713-7.592l-3.005 3.006a3.75 3.75 0 005.16 5.44l.144-.137 3.005-3.005-1.061-1.061-3.005 3.005a2.25 2.25 0 01-3.287-3.069l.105-.113 3.005-3.005-1.061-1.061zm2.122 2.122L8.43 16.002a.75.75 0 00.984 1.128l.076-.067 3.005-3.006-1.06-1.06zm7.894-.47a.75.75 0 01.067.984l-.067.077-1.53 1.53-1.061-1.061 1.53-1.53a.75.75 0 011.061 0zm.354-8.839a3.75 3.75 0 01.137 5.16l-.137.144-4.006 4.004-1.06-1.06 4.005-4.005a2.25 2.25 0 00-3.07-3.287l-.112.105-4.005 4.005-1.061-1.061 4.005-4.005a3.75 3.75 0 015.304 0zm-4.596 4.597a.75.75 0 01.067.983l-.067.077-1.531 1.53-1.061-1.061 1.53-1.53a.75.75 0 011.062 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttachCancel);\n","import * as React from 'react';\nfunction IconAttach(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.38 3.688a3.75 3.75 0 015.44 5.16l-.137.144-9.132 9.131a2.25 2.25 0 01-3.287-3.069l.105-.113 6.657-6.656a.75.75 0 011.128.983l-.067.077-6.657 6.657a.75.75 0 00.984 1.128l.076-.067 9.132-9.132a2.25 2.25 0 00-3.07-3.287l-.112.105-9.132 9.132a3.75 3.75 0 005.16 5.44l.144-.137 6.657-6.657a.75.75 0 011.127.984l-.067.077-6.657 6.657a5.25 5.25 0 01-7.574-7.269l.15-.156 9.131-9.132z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAttach);\n","import * as React from 'react';\nfunction IconAutotextInsert(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.75 5.75a.25.25 0 00-.193-.243L14.5 5.5H14a.75.75 0 01-.102-1.493L14 4h.5c.372 0 .718.116 1.001.315.242-.17.53-.28.841-.308L16.5 4h.5l.102.007a.75.75 0 010 1.486L17 5.5h-.5l-.057.007a.25.25 0 00-.184.175l-.009.068V8h4c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 0120.25 16h-4v2.25l.007.057a.25.25 0 00.175.184l.068.009h.5l.102.007a.75.75 0 010 1.486L17 20h-.5l-.144-.006a1.74 1.74 0 01-.856-.308 1.734 1.734 0 01-.856.308L14.5 20H14a.75.75 0 01-.102-1.493L14 18.5h.5a.25.25 0 00.243-.193l.007-.057V5.75zm5.5 3.75h-4v5h4a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L20.25 9.5zM6 11a1 1 0 110 2 1 1 0 010-2zm3.5 0a1 1 0 110 2 1 1 0 010-2zm3.5 0c.087 0 .17.011.25.032v1.936A1.002 1.002 0 0112 12a1 1 0 011-1zm-9.25 5A1.75 1.75 0 012 14.25v-4.5C2 8.784 2.784 8 3.75 8h9.5v1.5h-9.5a.25.25 0 00-.243.193L3.5 9.75v4.5a.25.25 0 00.193.243l.057.007h9.5V16h-9.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAutotextInsert);\n","import * as React from 'react';\nfunction IconAutotext(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 8c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 0120.25 16H3.75A1.75 1.75 0 012 14.25v-4.5C2 8.784 2.784 8 3.75 8h16.5zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 9.75v4.5a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L20.25 9.5zM6 11a1 1 0 110 2 1 1 0 010-2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconAutotext);\n","import * as React from 'react';\nfunction IconBasicTabs(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.5 12.25l1.5 1.5V21a1 1 0 01-1 1H5a1 1 0 01-1-1v-7.25l1.5-1.5v8.25h13v-8.25zm-6.875.582l.375.375.375-.375a1.591 1.591 0 112.25 2.25L12 17.707l-2.625-2.625a1.591 1.591 0 012.25-2.25zm.821-10.685l.084.073L17 6.689V5.5a.5.5 0 01.5-.5h.5a.5.5 0 01.5.5v2.689l3.03 3.03a.75.75 0 01-.976 1.134l-.084-.073L12 3.811l-8.47 8.47a.75.75 0 01-.976.072l-.084-.073a.75.75 0 01-.073-.976l.073-.084 9-9a.75.75 0 01.976-.073z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBasicTabs);\n","import * as React from 'react';\nfunction IconBasic(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M15.25 18.999V21h-2.5v-2.001h2.5zM21 16.75v2.5A1.75 1.75 0 0119.25 21h-2.5v-2.001H19V16.75h2zm-11.5-4c.966 0 1.75.784 1.75 1.75v4.75A1.75 1.75 0 019.5 21H4.75A1.75 1.75 0 013 19.25V14.5c0-.966.784-1.75 1.75-1.75H9.5zm11.5 0v2.5h-2v-2.5h2zm0-4v2.5h-2v-2.5h2zm-16 0v2.5H3v-2.5h2zM19.25 3c.966 0 1.75.784 1.75 1.75v2.5h-2V4.999h-2.25V3h2.5zm-12 0v1.999H5V7.25H3v-2.5C3 3.784 3.784 3 4.75 3h2.5zm4 0v1.999h-2.5V3h2.5zm4 0v1.999h-2.5V3h2.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBasic);\n","import * as React from 'react';\nfunction IconBellSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 19.5a2.5 2.5 0 01-4.995.164L9.5 19.5h5zM12 2c.915 0 1.686.767 1.924 1.815A6.002 6.002 0 0118 9.5V15l1.6 1.2A1 1 0 0119 18H5a1 1 0 01-.6-1.8L6 15V9.5a6.003 6.003 0 014.077-5.685C10.314 2.767 11.085 2 12 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBellSolid);\n","import * as React from 'react';\nfunction IconBook(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 4.5c1.583 0 3.165.45 4.748 1.352a.5.5 0 01.252.435V19.15a.5.5 0 01-.728.445C19.848 18.865 18.424 18.5 17 18.5c-1.667 0-3.333.5-5 1.5-1.667-1-3.333-1.5-5-1.5-1.424 0-2.848.365-4.272 1.095A.5.5 0 012 19.15V6.287a.5.5 0 01.252-.435C3.835 4.951 5.417 4.5 7 4.5c1.667 0 3.333.5 5 1.5 1.667-1 3.333-1.5 5-1.5zM17 6c-1.284 0-2.586.363-3.92 1.108l-.308.178L12 7.75l-.772-.463C9.786 6.421 8.383 6 7 6c-1.11 0-2.232.271-3.378.825l-.122.062v10.739l.056-.02a10.363 10.363 0 013.059-.598L7 17c1.585 0 3.156.382 4.704 1.134l.296.149.296-.149c1.429-.694 2.878-1.073 4.339-1.127L17 17c1.027 0 2.05.16 3.065.48l.435.147V6.887l-.122-.062c-1.041-.504-2.064-.773-3.075-.818L17 6zm0 7.75c.836 0 1.669.115 2.5.344v1.567a7.98 7.98 0 00-2.5-.411c-1.16 0-2.325.266-3.501.804v-1.627A9.628 9.628 0 0117 13.75zm0-3c.836 0 1.669.115 2.5.344v1.567a7.98 7.98 0 00-2.5-.411c-1.16 0-2.325.266-3.501.804v-1.627A9.628 9.628 0 0117 10.75zm0-3c.836 0 1.669.115 2.5.344v1.567A7.98 7.98 0 0017 9.25c-1.16 0-2.325.266-3.501.804V8.427A9.628 9.628 0 0117 7.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBook);\n","import * as React from 'react';\nfunction IconBooking(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 2a.75.75 0 01.743.648L20 2.75v18.5a.75.75 0 01-.648.743L19.25 22H6.75a2.75 2.75 0 01-2.739-3H4V5l.043.001A.749.749 0 014 4.75a2.75 2.75 0 012.582-2.745L6.75 2h12.5zm-.75 16H6.75a1.25 1.25 0 00-.128 2.494l.128.006H18.5v-.75H6.75a.5.5 0 110-1H18.5V18zM5.506 4.622L5.5 4.75a.749.749 0 01-.043.251L5.5 5v11.8a2.732 2.732 0 011-.289V3.525a1.25 1.25 0 00-.994 1.097zM18.5 3.5h-11v13h11v-13zM14.25 9a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm2-3a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBooking);\n","import * as React from 'react';\nfunction IconBudget(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.75 11c.966 0 1.75.784 1.75 1.75v7.5A1.75 1.75 0 0110.75 22h-6A1.75 1.75 0 013 20.25v-7.5c0-.966.784-1.75 1.75-1.75h6zm.25 8.5H9.5v1H11v-1zm-2.5 0h-4v1h4v-1zM14.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v9.836A1.75 1.75 0 0119.25 20H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L14 7.25V3.499L8.25 3.5a.25.25 0 00-.243.193L8 3.75V10H6.5V3.75C6.5 2.784 7.284 2 8.25 2h6.336zM11 17.5H9.5v1H11v-1zm-2.5 0H7v1h1.5v-1zm-2.5 0H4.5v1H6v-1zm10.016-6.984c.152 0 .333.058.371.263l.008.084v.242c.554.063 1.043.247 1.34.536.21.203.32.418.32.644 0 .29-.239.492-.516.492-.242 0-.437-.074-.648-.234-.328-.25-.586-.348-.93-.348-.379 0-.61.23-.61.48 0 .226.168.369.56.457l.14.028.687.121c1 .176 1.508.68 1.508 1.508 0 .908-.638 1.554-1.67 1.741l-.185.029v.175c0 .27-.207.352-.375.352-.157 0-.34-.065-.38-.269l-.007-.083v-.164c-.649-.047-1.211-.242-1.543-.558-.2-.196-.316-.41-.316-.645 0-.347.265-.543.59-.543.159 0 .308.044.495.162l.118.08c.343.254.726.395 1.043.395.48 0 .722-.203.722-.5 0-.217-.177-.353-.617-.458l-.14-.03-.672-.133c-.996-.192-1.489-.703-1.489-1.54 0-.885.638-1.523 1.633-1.683l.18-.023v-.23c0-.274.21-.348.383-.348zM11 15.5H9.5v1H11v-1zm-2.5 0H7v1h1.5v-1zm-2.5 0H4.5v1H6v-1zm5-3H4.5v2H11v-2zm4.5-7.881V7.25a.25.25 0 00.193.243l.057.007h2.631L15.5 4.619z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconBudget);\n","import * as React from 'react';\nfunction IconCalendar(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2c.414 0 .75.294.75.656V3h2.25c.966 0 1.75.83 1.75 1.853v14.294C21 20.17 20.216 21 19.25 21H4.75C3.784 21 3 20.17 3 19.147V4.853C3 3.83 3.784 3 4.75 3H7v-.344C7 2.294 7.336 2 7.75 2s.75.294.75.656V3h7v-.344c0-.362.336-.656.75-.656zm3.25 6h-15v11.147c0 .125.082.23.193.258l.057.007h14.5a.254.254 0 00.243-.204l.007-.06V8zm-11 7a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm-9-4.5a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2A.5.5 0 016 12v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zm4.5 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h2zM7 4.588H4.75a.254.254 0 00-.243.204l-.007.06V6.5h15V4.853a.262.262 0 00-.193-.258l-.057-.007H17v.256c0 .362-.336.656-.75.656s-.75-.294-.75-.656v-.256h-7v.256c0 .362-.336.656-.75.656S7 5.206 7 4.844v-.256z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCalendar);\n","import * as React from 'react';\nfunction IconCashAccount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 8a2 2 0 012 2v9a2 2 0 01-2 2H8a2 2 0 01-2-2v-9a2 2 0 012-2h12zm.5 5h-13v6a.5.5 0 00.41.492L8 19.5h12a.5.5 0 00.492-.41L20.5 19v-6zM12 15a.5.5 0 01.5.5V17a.5.5 0 01-.5.5h-2a.5.5 0 01-.5-.5v-1.5a.5.5 0 01.5-.5h2zm4.607-10.568L17.294 7h-1.553l-.583-2.18a.5.5 0 00-.524-.369l-.089.016L3.92 7.314a.5.5 0 00-.369.523l.016.089L5 13.276v3.905a1.992 1.992 0 01-.812-1.14l-2.07-7.727a2 2 0 011.414-2.45l10.625-2.846a2 2 0 012.45 1.414zM20 9.5H8a.5.5 0 00-.492.41L7.5 10v1.5h13V10a.5.5 0 00-.41-.492L20 9.5z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCashAccount);\n","import * as React from 'react';\nfunction IconCashReports(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm-1.143 6.234c.215 0 .434.097.48.36l.009.107v.387c.714.091 1.353.338 1.75.725.301.285.463.602.463.902 0 .355-.28.602-.618.602-.29 0-.51-.102-.779-.333-.456-.435-.843-.607-1.38-.607-.634 0-1.037.36-1.037.811 0 .372.266.62.843.762l.15.033 1.016.21c1.353.263 2.02.934 2.02 2.035 0 1.218-.86 2.076-2.251 2.304l-.193.027v.338c0 .344-.247.468-.49.468-.214 0-.437-.098-.484-.361l-.01-.107v-.327c-.816-.07-1.535-.322-1.981-.736-.301-.274-.473-.585-.473-.908 0-.419.306-.655.688-.655.236 0 .43.075.735.333.478.435 1.005.66 1.547.66.758 0 1.166-.338 1.166-.853 0-.374-.264-.605-.921-.77l-.159-.036-1.01-.22c-1.3-.269-1.955-.967-1.955-2.063 0-1.187.855-2.034 2.199-2.223l.186-.022v-.376c0-.349.247-.467.489-.467zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCashReports);\n","import * as React from 'react';\nfunction IconChatSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.557 13.056c1.474.7 2.443 1.881 2.443 3.222 0 1.294-.903 2.44-2.292 3.147l.89 1.582a.556.556 0 01-.748.761l-.084-.055-2.059-1.647a7.87 7.87 0 01-1.263.1c-2.853 0-5.205-1.506-5.52-3.444 2.666-.007 5.071-.766 6.817-1.966a7.924 7.924 0 001.802-1.682l.014-.018zM10.889 3.5c4.91 0 8.889 2.736 8.889 6.111 0 3.309-3.825 6.004-8.601 6.108l-.426.003-5.406 4.324a.556.556 0 01-.832-.706l2.398-4.262C3.999 14.074 2 12.003 2 9.61 2 6.236 5.98 3.5 10.889 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChatSolid);\n","import * as React from 'react';\nfunction IconChat(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.313 12.156c.59.664.937 1.466.937 2.344 0 1.01-.467 1.944-1.272 2.68l-.21.179.885 1.77c.174.348.174.753.01 1.096l-.068.125-.084.118c-.352.44-.948.585-1.501.347l-.127-.062-.129-.09-2.446-1.955-.233.021-.19.012-.385.009c-2.065 0-3.908-.798-4.923-2.035a13.97 13.97 0 002.216-.108c.728.397 1.667.643 2.707.643.209 0 .415-.01.619-.03l.303-.037.323-.047 2.059 1.649-.969-1.94.582-.36c.86-.533 1.333-1.252 1.333-1.985 0-.371-.122-.733-.343-1.065.3-.336.562-.69.781-1.06l.125-.219zM11 3.25c4.786 0 8.75 2.725 8.75 6.25 0 3.455-3.81 6.143-8.47 6.247l-.139.001-4.662 3.73a1.25 1.25 0 01-1.567-.004l-.1-.09-.09-.102a1.25 1.25 0 01-.174-1.27l.06-.124 1.737-3.087-.23-.106c-2.193-1.046-3.646-2.768-3.842-4.737l-.017-.228-.006-.23c0-3.525 3.964-6.25 8.75-6.25zm0 1.5c-4.05 0-7.25 2.2-7.25 4.75 0 1.679 1.397 3.263 3.66 4.119l.255.092.85.293-1.969 3.498 4.072-3.255.267.002.384-.002c3.922-.095 6.981-2.253 6.981-4.747 0-2.55-3.2-4.75-7.25-4.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChat);\n","import * as React from 'react';\nfunction IconChevronDownDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 6.47a.75.75 0 01.976-.073l.084.073L12 10.939l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 010-1.06zm0 5a.75.75 0 01.976-.073l.084.073L12 15.939l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 010-1.06z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDownDouble);\n","import * as React from 'react';\nfunction IconChevronDownSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.854 9.354l5.792 5.792a.5.5 0 00.708 0l5.792-5.792a.5.5 0 00-.353-.854H6.207a.5.5 0 00-.353.854z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDownSolid);\n","import * as React from 'react';\nfunction IconChevronDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 10.03a.75.75 0 01.976-1.133l.084.073L12 13.439l4.47-4.47a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronDown);\n","import * as React from 'react';\nfunction IconChevronLeftDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.53 6.47a.75.75 0 01.073.976l-.073.084L13.061 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 011.06 0zm-5 0a.75.75 0 01.073.976l-.073.084L8.061 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeftDouble);\n","import * as React from 'react';\nfunction IconChevronLeftSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M15.5 6.207a.5.5 0 00-.854-.353l-5.792 5.792a.5.5 0 000 .708l5.792 5.792a.5.5 0 00.854-.353V6.207z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeftSolid);\n","import * as React from 'react';\nfunction IconChevronLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.97 6.47a.75.75 0 011.133.976l-.073.084L10.561 12l4.47 4.47a.75.75 0 01.072.976l-.073.084a.75.75 0 01-.976.073l-.084-.073-5-5a.75.75 0 01-.073-.976l.073-.084 5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronLeft);\n","import * as React from 'react';\nfunction IconChevronRightDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.47 6.47a.75.75 0 01.976-.073l.084.073 5 5 .073.084a.75.75 0 01.007.882l-.08.094-5 5-.084.073a.75.75 0 01-.882.007l-.094-.08-.073-.084a.75.75 0 01-.007-.882l.08-.094L15.939 12l-4.47-4.47-.072-.084a.75.75 0 01.073-.976zm-5 0a.75.75 0 01.976-.073l.084.073 5 5 .073.084a.75.75 0 01.007.882l-.08.094-5 5-.084.073a.75.75 0 01-.882.007l-.094-.08-.073-.084a.75.75 0 01-.007-.882l.08-.094L10.939 12l-4.47-4.47-.072-.084a.75.75 0 01.073-.976z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRightDouble);\n","import * as React from 'react';\nfunction IconChevronRightSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M8.5 17.793a.5.5 0 00.854.353l5.792-5.792a.5.5 0 000-.708L9.354 5.854a.5.5 0 00-.854.353v11.586z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRightSolid);\n","import * as React from 'react';\nfunction IconChevronRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.03 6.47a.75.75 0 00-1.133.976l.073.084L13.439 12l-4.47 4.47a.75.75 0 00-.072.976l.073.084a.75.75 0 00.976.073l.084-.073 5-5a.75.75 0 00.073-.976l-.073-.084-5-5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronRight);\n","import * as React from 'react';\nfunction IconChevronUpDouble(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.47 12.53a.75.75 0 01-.073-.976l.073-.084 5-5 .084-.073a.75.75 0 01.882-.007l.094.08 5 5 .073.084a.75.75 0 01.007.882l-.08.094-.084.073a.75.75 0 01-.882.007l-.094-.08L12 8.061l-4.47 4.47-.084.072a.75.75 0 01-.976-.073zm0 5a.75.75 0 01-.073-.976l.073-.084 5-5 .084-.073a.75.75 0 01.882-.007l.094.08 5 5 .073.084a.75.75 0 01.007.882l-.08.094-.084.073a.75.75 0 01-.882.007l-.094-.08L12 13.061l-4.47 4.47-.084.072a.75.75 0 01-.976-.073z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUpDouble);\n","import * as React from 'react';\nfunction IconChevronUpSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.854 14.646l5.792-5.792a.5.5 0 01.708 0l5.792 5.792a.5.5 0 01-.353.854H6.207a.5.5 0 01-.353-.854z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUpSolid);\n","import * as React from 'react';\nfunction IconChevronUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.53 13.97a.75.75 0 01-.976 1.133l-.084-.073L12 10.561l-4.47 4.47a.75.75 0 01-.976.072l-.084-.073a.75.75 0 01-.073-.976l.073-.084 5-5a.75.75 0 01.976-.073l.084.073 5 5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconChevronUp);\n","import * as React from 'react';\nfunction IconCircleClose(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zM8.641 8.641a.75.75 0 01.984-.067l.077.067L12 10.94l2.298-2.298a.75.75 0 011.128.984l-.067.077L13.06 12l2.298 2.298a.75.75 0 01-.984 1.128l-.077-.067L12 13.06l-2.298 2.298a.75.75 0 01-1.128-.984l.067-.077L10.94 12 8.641 9.702a.75.75 0 010-1.06z\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleClose);\n","import * as React from 'react';\nfunction IconCircleMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm4 7.75c.934 0 1.027 1.366.102 1.493-8 0 0 0-8.102.007-.934 0-1.027-1.366-.102-1.493z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleMinus);\n","import * as React from 'react';\nfunction IconCirclePlus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm0 3.75a.75.75 0 01.743.648L12.75 8v3.25H16a.75.75 0 01.102 1.493L16 12.75h-3.25V16a.75.75 0 01-1.493.102L11.25 16v-3.25H8a.75.75 0 01-.102-1.493L8 11.25h3.25V8a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCirclePlus);\n","import * as React from 'react';\nfunction IconCircleTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zm4.403 3.867a.75.75 0 01.282.938l-.052.098-5.091 8a.75.75 0 01-1.145.145l-.074-.08-2.909-3.636a.75.75 0 011.096-1.018l.076.081 2.253 2.817 4.528-7.115a.75.75 0 011.036-.23z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCircleTick);\n","import * as React from 'react';\nfunction IconClampOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.03 12.97a.75.75 0 01.073.976l-.073.084-5.72 5.72H8.5a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007-5.051-.002-.12-.018-.068-.019-.06-.023-.07-.035-.082-.054-.08-.07a.749.749 0 01-.096-.118l-.05-.09-.04-.103a.737.737 0 01-.026-.116L2.75 20.5v-5a.75.75 0 011.493-.102l.007.102-.001 3.189 5.72-5.72a.75.75 0 011.061 0zm4.368-10.213l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L19.75 8.5V5.31l-5.72 5.72a.75.75 0 01-1.133-.976l.073-.084 5.718-5.72H15.5a.75.75 0 01-.743-.648L14.75 3.5a.75.75 0 01.648-.743z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClampOpen);\n","import * as React from 'react';\nfunction IconClamp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.398 12.757l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9.75 18.5v-3.19l-5.72 5.72a.75.75 0 01-1.133-.976l.073-.084 5.718-5.72H5.5a.75.75 0 01-.743-.648L4.75 13.5a.75.75 0 01.648-.743zM21.03 2.97a.75.75 0 01.073.976l-.073.084-5.72 5.72h3.19a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007-5.051-.002-.12-.018-.068-.019-.06-.023-.07-.035-.082-.054-.08-.07a.749.749 0 01-.096-.118l-.05-.09-.04-.103a.737.737 0 01-.026-.116l-.007-.102v-5a.75.75 0 011.493-.102l.007.102v3.188l5.72-5.718a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClamp);\n","import * as React from 'react';\nfunction IconClose(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.554 6.397a.75.75 0 011.049 1.05l-.073.083L13.061 12l4.47 4.47a.75.75 0 01-.977 1.133l-.084-.073L12 13.061l-4.47 4.47-.084.072a.75.75 0 01-1.049-1.05l.073-.083L10.939 12l-4.47-4.47a.75.75 0 01.977-1.133l.084.073L12 10.939l4.47-4.47.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconClose);\n","import * as React from 'react';\nfunction IconConnectionEnable(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19 9a3 3 0 11-2.877 3.854H7.877A3.001 3.001 0 012 12a3 3 0 015.93-.647h8.14A3.001 3.001 0 0119 9zM5 10.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm14 0a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconConnectionEnable);\n","import * as React from 'react';\nfunction IconConnectionRevoke(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.66 4.174a.75.75 0 01.32.933l-.045.091-8.298 14.373a.75.75 0 01-1.344-.659l.045-.091 8.298-14.373a.75.75 0 011.025-.274zM5 9a3.001 3.001 0 012.935 2.374.685.685 0 01.169-.02h1.814l-.866 1.5h-.948a.75.75 0 01-.22-.033A2.998 2.998 0 012 12a3 3 0 013-3zm14 0a3 3 0 11-2.877 3.854h-1.875l.866-1.5.956-.001A3.001 3.001 0 0119 9zM5 10.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm14 0a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconConnectionRevoke);\n","import * as React from 'react';\nfunction IconContacts(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V18h-.5a.75.75 0 110-1.5H4v-3.75h-.5a.75.75 0 110-1.5H4V8h-.5a.75.75 0 010-1.5H4V3.75C4 2.784 4.784 2 5.75 2h12.5zm0 1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6.5H6A.75.75 0 016 8h-.5v3.25H6a.75.75 0 110 1.5h-.5v3.75H6A.75.75 0 116 18h-.5v2.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5zM11.866 12c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0114.482 18H9.25a1.75 1.75 0 01-1.724-2.05c.46-2.634 1.906-3.95 4.34-3.95zm0-5.5c1.104 0 2 1.12 2 2.5s-.896 2.5-2 2.5c-1.105 0-2-1.12-2-2.5s.895-2.5 2-2.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconContacts);\n","import * as React from 'react';\nfunction IconCopy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6 5v1.5h-.25a.25.25 0 00-.243.193L5.5 6.75v13.5a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V20H17v.25A1.75 1.75 0 0115.25 22h-9.5A1.75 1.75 0 014 20.25V6.75C4 5.784 4.784 5 5.75 5H6zm7.586-3a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0118.25 19h-9.5A1.75 1.75 0 017 17.25V3.75C7 2.784 7.784 2 8.75 2h4.836zM13 3.5H8.75a.25.25 0 00-.243.193L8.5 3.75v13.5a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm1.5 1.121V7.25a.25.25 0 00.193.243l.057.007h2.629L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCopy);\n","import * as React from 'react';\nfunction IconCourses(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.441 3.441a1.25 1.25 0 01.983-.058l.135.058 9.598 4.799a.85.85 0 01.464.859l-.001 6.151a.75.75 0 11-1.5 0v-4.971L19 11.339V17.5c0 1.657-3.134 3-7 3-3.772 0-6.847-1.278-6.994-2.88L5 17.5v-6.162L1.842 9.76a.85.85 0 01-.421-1.042l.041-.098a.85.85 0 01.286-.325l.094-.055 9.598-4.799zm-4.942 8.647v5.395c.009.095.385.448 1.217.791C8.82 18.73 10.351 19 12 19c1.689 0 3.253-.284 4.359-.757.472-.203.822-.425 1.023-.629l.11-.117c.003-.003.005-.004.006-.003l.002.006v-5.411l-4.941 2.47a1.25 1.25 0 01-.983.058l-.135-.058-4.942-2.471zM12 4.838L3.677 8.999l8.322 4.162 8.323-4.162L12 4.838z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCourses);\n","import * as React from 'react';\nfunction IconCredit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.499 15l.001 5.25a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057V20H18v.25A1.75 1.75 0 0116.25 22h-9.5A1.75 1.75 0 015 20.25L4.999 15h1.5zm8.087-13a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0119.25 19h-9.5A1.75 1.75 0 018 17.25L7.999 15h1.5l.001 2.25a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193l.007-.057L19.499 9H15.75a1.75 1.75 0 01-1.744-1.606L14 7.25l-.001-3.75H9.75a.25.25 0 00-.243.193L9.5 3.75 9.499 5h-1.5L8 3.75C8 2.784 8.784 2 9.75 2h4.836zM4.392 8.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082L4.341 9.03l.051-.074zM8.25 6a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528A2.5 2.5 0 006.711 8.03a.75.75 0 11-.925-1.181A3.985 3.985 0 018.25 6zm7.249-1.38l.001 2.63a.25.25 0 00.193.243l.057.007h2.629l-2.88-2.88z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconCredit);\n","import * as React from 'react';\nfunction IconDeletePermanently(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2a4.5 4.5 0 014.472 4h-1.514a3 3 0 00-5.917 0H20.25a.75.75 0 110 1.5h-.75V18a4 4 0 01-4 4h-7a4 4 0 01-4-4V7.5h-.75a.75.75 0 010-1.5h3.777A4.5 4.5 0 0112 2zm6 5.5H6V18a2.5 2.5 0 002.336 2.495l.164.005h7a2.5 2.5 0 002.495-2.336L18 18V7.5zm-3.946 3.397a.75.75 0 011.049 1.05l-.073.083L13.061 14l1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073L12 15.061l-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083L10.939 14l-1.97-1.97a.75.75 0 01.977-1.133l.084.073L12 12.939l1.97-1.97.084-.072z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDeletePermanently);\n","import * as React from 'react';\nfunction IconDelete(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2a4.5 4.5 0 014.472 4h3.778a.75.75 0 110 1.5h-.75V18a4 4 0 01-4 4h-7a4 4 0 01-4-4V7.5h-.75a.75.75 0 010-1.5h3.777A4.5 4.5 0 0112 2zm6 5.5H6V18a2.5 2.5 0 002.336 2.495l.164.005h7a2.5 2.5 0 002.495-2.336L18 18V7.5zm-8.25 2a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zm4.5 0a.75.75 0 01.75.75v7.5a.75.75 0 11-1.5 0v-7.5a.75.75 0 01.75-.75zM12 3.5A3 3 0 009.041 6h5.917A3 3 0 0012 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDelete);\n","import * as React from 'react';\nfunction IconDepecriate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 2a.75.75 0 01.75.75V3h2.25c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H17v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V8h-15v11.25a.25.25 0 00.193.243l.057.007H7V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3H7v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM12 11.25a.75.75 0 01.743.648l.007.102v6.439l1.72-1.72a.75.75 0 01.976-.072l.084.073a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 1.72 1.719V12a.75.75 0 01.75-.75zM7 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75V6.5h15V4.75a.25.25 0 00-.193-.243L19.25 4.5H17v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDepecriate);\n","import * as React from 'react';\nfunction IconDeveloper(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.303 2.787a1.25 1.25 0 01.934 1.39l-.024.126-4 16a1.25 1.25 0 01-2.45-.48l.024-.126 4-16a1.25 1.25 0 011.516-.91zM7.05 5.04a1.25 1.25 0 01.242 1.65l-.082.11L2.877 12l4.333 5.2a1.25 1.25 0 01-.06 1.667l-.1.093a1.25 1.25 0 01-1.667-.06l-.093-.1-5-6a1.25 1.25 0 01-.083-1.49l.083-.11 5-6a1.25 1.25 0 011.76-.16zm9.9 0a1.25 1.25 0 011.667.06l.093.1 5 6 .083.11a1.25 1.25 0 010 1.38l-.083.11-5 6-.093.1a1.25 1.25 0 01-1.558.142l-.11-.082-.1-.093a1.25 1.25 0 01-.14-1.558l.08-.11L21.124 12 16.79 6.8l-.082-.11a1.25 1.25 0 01.242-1.65z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDeveloper);\n","import * as React from 'react';\nfunction IconDistributionTemplate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.5 17a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-1 1.5h-2v2h2v-2zm-5-14.75a.75.75 0 01.102 1.493l-.102.007H13a.25.25 0 00-.243.193l-.007.057v5.75h1.75a.75.75 0 01.102 1.493l-.102.007h-1.75v5.75a.25.25 0 00.193.243l.057.007h1.5a.75.75 0 01.102 1.493l-.102.007H13a1.75 1.75 0 01-1.744-1.606l-.006-.144v-5.75H9.5a.75.75 0 01-.102-1.493l.102-.007h1.75V5.5a1.75 1.75 0 011.606-1.744L13 3.75h1.5zm6 5.75a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-13 0a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4A.5.5 0 013 14v-4a.5.5 0 01.5-.5h4zm12 1.5h-2v2h2v-2zm-13 0h-2v2h2v-2zm14-9a.5.5 0 01.5.5v4a.5.5 0 01-.5.5h-4a.5.5 0 01-.5-.5v-4a.5.5 0 01.5-.5h4zm-1 1.5h-2v2h2v-2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDistributionTemplate);\n","import * as React from 'react';\nfunction IconDocumentApprove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm6.194 13.72a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 2.47 2.469 4.47-4.47a.75.75 0 011.06 0zm-2.4-8.22L14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentApprove);\n","import * as React from 'react';\nfunction IconDocumentCreateEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V13h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm2.164 11.5a.75.75 0 01.743.648l.007.102V17h2.75a.75.75 0 01.102 1.493l-.102.007H16.5v2.75a.75.75 0 01-1.493.102L15 21.25V18.5h-2.75a.75.75 0 01-.102-1.493L12.25 17H15v-2.75a.75.75 0 01.75-.75zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentCreateEntry);\n","import * as React from 'react';\nfunction IconDocumentCut(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.95 11.146l2.219 3.843.868.234a2.5 2.5 0 111.826 2.042l-1.633-.438.845 1.464a2.5 2.5 0 11-2.444-1.235l-.45-.778-4.287-1.148a.75.75 0 11.388-1.45l2.839.761-1.47-2.545a.75.75 0 011.3-.75zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V11h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.176 16.675a1 1 0 101 1.732 1 1 0 00-1-1.732zm3.134-4.084a1 1 0 101.932.518 1 1 0 00-1.932-.518zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentCut);\n","import * as React from 'react';\nfunction IconDocumentError(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm-1 12.91c.516 0 .935.333.935.849 0 .515-.42.848-.935.848-.516 0-.94-.333-.94-.848 0-.516.424-.849.94-.849zm0-5.978c.509 0 .883.352.917.807l.001.106-.15 3.62a.754.754 0 01-.768.736.757.757 0 01-.768-.632l-.01-.104-.135-3.62c-.022-.505.37-.913.913-.913zm2.5-5.811V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentError);\n","import * as React from 'react';\nfunction IconDocumentIsolatePage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707v4.336h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h5V22h-5A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm5.664 12.25a.75.75 0 01.743.648L20 15v4.5a.75.75 0 01-1.493.102L18.5 19.5v-2.69l-4.97 4.97a.75.75 0 01-1.133-.976l.073-.084 4.968-4.97H14.75a.75.75 0 01-.743-.648L14 15a.75.75 0 01.648-.743l.102-.007h4.5zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentIsolatePage);\n","import * as React from 'react';\nfunction IconDocumentMerge(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.586 2a1 1 0 01.707.293l3.414 3.414a1 1 0 01.293.707v8.836A1.75 1.75 0 0119.25 17H15v3.25A1.75 1.75 0 0113.25 22h-8.5A1.75 1.75 0 013 20.25V8.75C3 7.784 3.784 7 4.75 7H9V3.75C9 2.784 9.784 2 10.75 2h5.836zM15.5 3.499l-4.75.001a.25.25 0 00-.243.193l-.007.057V7h1v1.5h-1V10H9V8.5H4.75a.25.25 0 00-.243.193L4.5 8.75v11.5a.25.25 0 00.193.243l.057.007h8.5a.25.25 0 00.243-.193l.007-.057V17h-1v-1.5h1V14H15v1.5h4.25a.25.25 0 00.243-.193l.007-.057V7.5h-2.25a1.75 1.75 0 01-1.744-1.606L15.5 5.75V3.499zM10.5 14v1.25a.25.25 0 00.193.243l.057.007h.75V17h-.75A1.75 1.75 0 019 15.25V14h1.5zm4.5-3v2h-1.5v-2H15zm-4.5 0v2H9v-2h1.5zm2-4h.75c.966 0 1.75.784 1.75 1.75V10h-1.5V8.75a.25.25 0 00-.193-.243L13.25 8.5h-.75V7zM17 4.12v1.63a.25.25 0 00.193.243L17.25 6h1.631L17 4.12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentMerge);\n","import * as React from 'react';\nfunction IconDocumentMove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V12h1.5v8.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5h-2V2h2.586zM4.433 7.25a.5.5 0 01-.717.661l-.07-.057-1-1-.057-.07a.5.5 0 010-.568l.057-.07 1-1 .07-.057a.5.5 0 01.568 0l.07.057.057.07a.5.5 0 01.022.535L6.25 5.75V3.933a.5.5 0 01-.534-.022l-.07-.057a.5.5 0 01-.057-.638l.057-.07 1-1 .07-.057a.5.5 0 01.568 0l.07.057 1 1 .057.07a.5.5 0 010 .568l-.057.07-.07.057a.5.5 0 01-.534.022V5.75h1.817a.5.5 0 01.022-.534l.057-.07a.5.5 0 01.638-.057l.07.057 1 1a.5.5 0 01.057.638l-.057.07-1 1a.5.5 0 01-.787-.604H7.75v1.817a.5.5 0 01.534.022l.07.057a.5.5 0 01.057.638l-.057.07-1 1a.5.5 0 01-.638.057l-.07-.057-1-1a.5.5 0 01.605-.787L6.25 7.25H4.433zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentMove);\n","import * as React from 'react';\nfunction IconDocumentPreview(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H10V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm.164 10.75a3 3 0 100 6 3 3 0 000-6zm.75-8.129V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621zm-.75 15.629a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentPreview);\n","import * as React from 'react';\nfunction IconDocumentReceived(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V17H20v3.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.032 9.147a.75.75 0 01.882-.007l.094.08.073.084a.75.75 0 01.007.882l-.08.094L12.811 14h6.439l.102.007a.75.75 0 010 1.486l-.102.007h-6.439l1.72 1.72.072.084a.75.75 0 01-1.05 1.049l-.083-.073-3-3-.073-.084a.75.75 0 01-.007-.882l.08-.094 3-3 .084-.073zm.946-6.526V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentReceived);\n","import * as React from 'react';\nfunction IconDocumentRejectedRequest(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm5.218 13.647a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentRejectedRequest);\n","import * as React from 'react';\nfunction IconDocumentSplit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 14v6.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V14h4v1.5H5.5v4.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V15.5H16V14h4zm-6 0v1.5h-4V14h4zm0-3v1.5h-4V11h4zm.5-6.379V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621zM4 3.75C4 2.784 4.784 2 5.75 2h7.836a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V12.5h-4V11h2.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V11H8v1.5H4V3.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentSplit);\n","import * as React from 'react';\nfunction IconDocumentTime(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V10H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM10 10a6 6 0 110 12 6 6 0 010-12zm0 1.5a4.5 4.5 0 100 9 4.5 4.5 0 000-9zm0 .75a.75.75 0 01.743.648l.007.102v3a.75.75 0 01-.648.743L10 16.75H8a.75.75 0 01-.102-1.493L8 15.25l1.25-.001V13a.75.75 0 01.648-.743L10 12.25zm4.5-7.629V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocumentTime);\n","import * as React from 'react';\nfunction IconDocument(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zM13 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5zm2.5 12.25a.75.75 0 01.102 1.493l-.102.007h-7a.75.75 0 01-.102-1.493l.102-.007h7zm0-4a.75.75 0 01.102 1.493l-.102.007h-7a.75.75 0 01-.102-1.493l.102-.007h7zm-1-7.129V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDocument);\n","import * as React from 'react';\nfunction IconDownload(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 16.25a.75.75 0 01.743.648L21 17v1.25a3.75 3.75 0 01-3.55 3.745l-.2.005H6.75a3.75 3.75 0 01-3.745-3.55L3 18.25V17a.75.75 0 011.493-.102L4.5 17v1.25a2.25 2.25 0 002.096 2.245l.154.005h10.5a2.25 2.25 0 002.245-2.096l.005-.154V17a.75.75 0 01.75-.75zm-3.5.75a.75.75 0 110 1.5h-9.5a.75.75 0 110-1.5h9.5zM12 2a.75.75 0 01.743.648l.007.102v9.189l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012L12 14.5l-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.22 2.219V2.75A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDownload);\n","import * as React from 'react';\nfunction IconDrag(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.5 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconDrag);\n","import * as React from 'react';\nfunction IconECopedia(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 4c1.583 0 3.165.45 4.748 1.352a.5.5 0 01.252.435V18.65a.5.5 0 01-.728.445C19.848 18.365 18.424 18 17 18c-1.667 0-3.333.5-5 1.5-1.667-1-3.333-1.5-5-1.5-1.424 0-2.848.365-4.272 1.095A.5.5 0 012 18.65V5.787a.5.5 0 01.252-.435C3.835 4.451 5.417 4 7 4c1.667 0 3.333.5 5 1.5 1.667-1 3.333-1.5 5-1.5zM7 13.5c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 13.677 8.226 13.5 7 13.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928c-.897-.359-1.96-.536-3.186-.536zm-10-3c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 10.677 8.226 10.5 7 10.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 10.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928c-.897-.359-1.96-.536-3.186-.536zm-10-3c-1.227 0-2.289.177-3.186.536a.5.5 0 00.372.928C4.956 8.656 5.893 8.5 7 8.5s2.044.156 2.814.464a.5.5 0 10.372-.928C9.289 7.677 8.226 7.5 7 7.5zm10 0c-1.227 0-2.289.177-3.186.536a.5.5 0 00.372.928c.77-.308 1.707-.464 2.814-.464s2.044.156 2.814.464a.5.5 0 10.372-.928C19.289 7.677 18.226 7.5 17 7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconECopedia);\n","import * as React from 'react';\nfunction IconESignature(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13 2v5.25l.006.144a1.75 1.75 0 001.593 1.6L14.75 9H20v11.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2H13zm-3 7.75c-1.572 0-2.858 1.745-3.337 3.877l-.048.23-.039.217c-.138.832-.124 1.608.046 2.26l.07.238.055.148-.191.101c-.33.166-.672.305-1.025.413a.75.75 0 00.339 1.457l.1-.023.281-.092c.35-.122.691-.268 1.02-.435l.325-.174.098-.059.02.014c.302.18.66.293 1.074.32L9 18.25l.255-.004c1.076-.038 1.983-.315 2.706-.82l.193-.145.124-.104.014.052c.044.14.098.262.164.369l.069.102.086.107c.579.665 1.275.432 2.018-.32l.117-.122.102-.115.021.104c.043.2.09.356.163.512.209.456.598.755 1.132.708.582-.052 1.196-.55 2.042-1.612l.162-.206.32-.425.17-.23a.75.75 0 00-1.144-.965l-.071.085-.293.396-.28.362-.251.308-.22.256-.187.205-.11.112-.082-.493-.042-.199-.024-.09c-.083-.294-.201-.52-.436-.692-.598-.437-1.122-.163-1.695.514l-.258.312-.107.118-.007-.214a12.73 12.73 0 01.094-1.533c.1-.89-1.135-1.152-1.438-.372l-.033.103-.057.203c-.397 1.321-1.216 2.03-2.562 2.195l-.217.022-.176.009.199-.19a8.876 8.876 0 001.813-2.556c1.013-2.18.695-4.247-1.274-4.247zm0 1.5c.406 0 .531.695-.005 1.934l-.081.181-.116.237a7.434 7.434 0 01-1.401 1.893l-.25.236-.105.089-.032-.177c-.06-.406-.037-.911.077-1.5C8.402 12.53 9.306 11.25 10 11.25zm4.5-4V2L20 7.5h-5.25l-.057-.007a.25.25 0 01-.184-.175L14.5 7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconESignature);\n","import * as React from 'react';\nfunction IconEdit(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 20.5a.75.75 0 110 1.5H3.75a.75.75 0 110-1.5h16.5zM16.013 2.927a1.75 1.75 0 012.35-.114l.124.114 1.586 1.586a1.75 1.75 0 01.114 2.35l-.114.124L8.061 19H4v-4.06L16.013 2.926zM14.499 6.56l-8.999 9v1.94h1.938l9-9-1.939-1.94zm2.928-2.573a.25.25 0 00-.3-.04l-.054.04L15.56 5.5l1.939 1.94 1.514-1.512a.25.25 0 00.065-.24l-.025-.06-.04-.054-1.586-1.586z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEdit);\n","import * as React from 'react';\nfunction IconEllipsisHorizontal(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 10.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm10 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEllipsisHorizontal);\n","import * as React from 'react';\nfunction IconEllipsisVertical(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEllipsisVertical);\n","import * as React from 'react';\nfunction IconEntriesOnAccount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-2.25 9.5a.75.75 0 110 1.5H6.75a.75.75 0 110-1.5h10.5zm0-3.5a.75.75 0 110 1.5H6.75a.75.75 0 110-1.5h10.5zm0-3.5a.75.75 0 110 1.5H6.75a.75.75 0 010-1.5h10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesOnAccount);\n","import * as React from 'react';\nfunction IconEntriesOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-7.25 2a.5.5 0 01.5.5v9a.5.5 0 01-.5.5h-.5a.5.5 0 01-.5-.5v-9a.5.5 0 01.5-.5h.5zm-3.5 7.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 010 1.5h-2a.75.75 0 010-1.5h2zm8.5 0a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesOpen);\n","import * as React from 'react';\nfunction IconEntriesWarning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.75 12.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm.5-9.5c.966 0 1.75.784 1.75 1.75l.001 6.687a5.96 5.96 0 00-1.5-.39L19.5 6h-15v13.25a.25.25 0 00.193.243l.057.007h8.544a5.99 5.99 0 00.985 1.5H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-.5 16a.75.75 0 100 1.5.75.75 0 000-1.5zm0-5.5a.75.75 0 00-.743.648L18 14.25v3.5a.75.75 0 001.493.102l.007-.102v-3.5a.75.75 0 00-.75-.75zM12.25 8a.5.5 0 01.5.5v9a.5.5 0 01-.5.5h-.5a.5.5 0 01-.5-.5v-9a.5.5 0 01.5-.5h.5zm-3.5 7.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm0-3.5a.75.75 0 010 1.5h-2a.75.75 0 010-1.5h2zm8.5 0a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntriesWarning);\n","import * as React from 'react';\nfunction IconEntryTypeCustomerInvoice(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm.25-12.5a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h7.525c.464 0 .91.184 1.238.513l3.974 3.974c.329.329.513.774.513 1.238V18.25A1.75 1.75 0 0119.25 20h-6.038l-.01-.063a11.184 11.184 0 00-.369-1.437h6.417a.25.25 0 00.243-.193l.007-.057v-10h-3a1.75 1.75 0 01-1.744-1.606L14.75 6.5v-3h-7zm-.25 7c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm9.75 3a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zm0-3a.75.75 0 110 1.5h-6a.75.75 0 110-1.5h6zm1.378-3.75L16.25 4.371V6.5a.25.25 0 00.193.243l.057.007h2.128z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeCustomerInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeCustomerPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm14.263-3.75c.155.24.237.491.237.75 0 1.272-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-1.25 0-2.43-.122-3.466-.339a4.583 4.583 0 00-1.063-.672c.175-.294.313-.626.404-.984.945.25 2.042.417 3.225.474l.612.019.288.002.453-.006c3.293-.078 6.014-1.006 6.81-2.243zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm14.263-1.75c.155.24.237.491.237.75 0 1.272-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-1.524 0-2.941-.182-4.125-.494a3.637 3.637 0 00-.68-1.398 3.187 3.187 0 00-.47-.478c1.163.463 2.705.773 4.423.85l.564.018.288.002.453-.006c3.293-.078 6.014-1.006 6.81-2.243zM14.5 3c.77 0 1.514.046 2.214.133l.516.072C20.022 3.642 22 4.728 22 6s-1.978 2.358-4.77 2.795l-.516.072c-.7.087-1.443.133-2.214.133-.77 0-1.514-.046-2.214-.133l-.516-.072C8.978 8.358 7 7.272 7 6s1.978-2.358 4.77-2.795l.516-.072A18.02 18.02 0 0114.5 3zm0 1.5c-1.835 0-3.538.288-4.746.771-.456.183-.81.381-1.042.57L8.538 6l.082.078c.225.212.613.442 1.134.65 1.208.484 2.91.772 4.746.772 1.835 0 3.538-.288 4.746-.771.456-.183.81-.381 1.042-.57L20.461 6l-.081-.078c-.225-.212-.613-.442-1.134-.65-1.208-.484-2.91-.772-4.746-.772z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeCustomerPayment);\n","import * as React from 'react';\nfunction IconEntryTypeJournalEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.275 17.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM14.25 3c.966 0 1.75.784 1.75 1.75V9c-.516 0-1.018.026-1.5.074V5.5h-11v10.75a.25.25 0 00.193.243l.057.007H9V18H3.75A1.75 1.75 0 012 16.25V4.75C2 3.784 2.784 3 3.75 3h10.5zm-3.975 11.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM16 10c3.314 0 6 1.12 6 2.5S19.314 15 16 15s-6-1.12-6-2.5 2.686-2.5 6-2.5zm-8.25 3a.75.75 0 110 1.5h-1.5a.75.75 0 110-1.5h1.5zM16 11.5c-1.425 0-2.742.232-3.666.617a3.354 3.354 0 00-.65.347l-.048.036.048.036c.126.091.292.186.493.278l.157.07c.924.384 2.24.616 3.666.616 1.425 0 2.742-.232 3.666-.617.273-.114.492-.233.65-.347l.047-.037-.047-.035a3.044 3.044 0 00-.493-.278l-.157-.07c-.924-.384-2.24-.616-3.666-.616zM8.25 10a.75.75 0 110 1.5h-2a.75.75 0 110-1.5h2zm3.5-3a.75.75 0 110 1.5h-5.5a.75.75 0 010-1.5h5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeJournalEntry);\n","import * as React from 'react';\nfunction IconEntryTypeManualCustomerInvoice(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.371 18.835l1.564 1.565a.998.998 0 010 1.414l-.392.393a.996.996 0 01-1.414 0l-1.565-1.565 1.807-1.807zM7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zm7.5 2.5l1.498 1.5h-3.286l-.01-.063a11.184 11.184 0 00-.369-1.437H15zm.453-4.586l4.212 4.213-1.808 1.808-4.21-4.213-.005-1.762 1.811-.046zM15.275 2c.464 0 .91.184 1.238.513l3.974 3.974c.329.329.513.774.513 1.238v10.334l-1.5-1.501V8.25h-3a1.75 1.75 0 01-1.744-1.606L14.75 6.5v-3h-7a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h7.525zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm7.25 1a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm1.5-7.129V6.5a.25.25 0 00.193.243l.057.007h2.128L16.25 4.371z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeManualCustomerInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeSupplierInvoice(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.5 8l3 3v8.25A1.75 1.75 0 0120.75 21h-7.5a1.75 1.75 0 01-1.75-1.75v-9.5c0-.966.784-1.75 1.75-1.75h6.25zm-1 1.5h-5.25a.25.25 0 00-.243.193L13 9.75v9.5a.25.25 0 00.193.243l.057.007h7.5a.25.25 0 00.243-.193L21 19.25V12h-2.5V9.5zm.25 7a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM6.25 14a1.5 1.5 0 110 3 1.5 1.5 0 010-3zM18 3a1.75 1.75 0 011.744 1.606l.006.144V7h-6.27a3.11 3.11 0 00-1.955.675l-.152.13a2.654 2.654 0 00-.866 1.757l-.007.188v5.5H8.738a2.5 2.5 0 00-2.324-2.245L6.25 13a2.5 2.5 0 00-2.488 2.25H2.25l-.102-.007a.75.75 0 01-.641-.641L1.5 14.5V9.929l.008-.108a.75.75 0 01.112-.3l.066-.086 3-3.429.076-.075a.75.75 0 01.381-.173l.107-.008h2.5v-1a1.75 1.75 0 011.606-1.744L9.5 3H18zm.75 10.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM7 7.25H5.59L4 9.068V10h3V7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeSupplierInvoice);\n","import * as React from 'react';\nfunction IconEntryTypeSupplierPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.775 17.75c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zm0-3c.702.931 2.675 1.627 5.072 1.735l.378.012.275.003.356-.005c2.53-.061 4.638-.776 5.37-1.745.178.236.274.489.274.75 0 1.38-2.686 2.5-6 2.5s-6-1.12-6-2.5c0-.261.096-.514.275-.75zM6.25 14a1.5 1.5 0 110 3 1.5 1.5 0 010-3zM18 3a1.75 1.75 0 011.744 1.606l.006.144.001 4.617A13.959 13.959 0 0016.5 9c-1.809 0-3.443.316-4.627.81-.695.289-1.247.646-1.628 1.029-.458.46-.695.97-.738 1.488L9.5 12.5v2.75h-.762a2.5 2.5 0 00-2.324-2.245L6.25 13a2.5 2.5 0 00-2.488 2.25H2.25l-.102-.007a.75.75 0 01-.641-.641L1.5 14.5V9.929l.008-.108a.75.75 0 01.112-.3l.066-.086 3-3.429.076-.075a.75.75 0 01.381-.173l.107-.008h2.5v-1a1.75 1.75 0 011.606-1.744L9.5 3H18zm-1.5 7c3.314 0 6 1.12 6 2.5s-2.686 2.5-6 2.5-6-1.12-6-2.5 2.686-2.5 6-2.5zm0 1.5c-1.425 0-2.742.232-3.666.617a3.354 3.354 0 00-.65.347l-.048.036.048.036c.126.091.292.186.493.278l.157.07c.924.384 2.24.616 3.666.616 1.425 0 2.742-.232 3.666-.617.273-.114.492-.233.65-.347l.047-.037-.047-.035a3.044 3.044 0 00-.493-.278l-.157-.07c-.924-.384-2.24-.616-3.666-.616zM7 7.25H5.59L4 9.068V10h3V7.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEntryTypeSupplierPayment);\n","import * as React from 'react';\nfunction IconEnvelopeApproved(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v6.14l-1.5-.001v-5.55l-8.04 6.253a.75.75 0 01-.826.062l-.094-.062L3.5 6.339V18.25a.25.25 0 00.193.243l.057.007H12V20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm1.53 9.72a.75.75 0 01.073.976l-.073.084-5 5a.75.75 0 01-.976.073l-.084-.073-3-3a.75.75 0 01.976-1.133l.084.073 2.47 2.469 4.47-4.47a.75.75 0 011.06 0zM19.134 5.5H4.865L12 11.049 19.134 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEnvelopeApproved);\n","import * as React from 'react';\nfunction IconEnvelope(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm.25 2.339l-8.04 6.253a.75.75 0 01-.826.062l-.094-.062L3.5 6.339V18.25a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V6.339zM19.134 5.5H4.865L12 11.049 19.134 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconEnvelope);\n","import * as React from 'react';\nfunction IconExpandView(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v5.75H3V4.75C3 3.784 3.784 3 4.75 3h14.5zm-9 9c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0110.25 21h-5.5A1.75 1.75 0 013 19.25v-5.5c0-.966.784-1.75 1.75-1.75h5.5zm0 1.5h-5.5a.25.25 0 00-.243.193l-.007.057v5.5a.25.25 0 00.193.243l.057.007h5.5a.25.25 0 00.243-.193l.007-.057v-5.5a.25.25 0 00-.193-.243l-.057-.007zm7.25-7.75a.75.75 0 01.743.648l.007.102V10a.75.75 0 01-1.493.102L16.75 10V8.31l-3.22 3.22a.75.75 0 01-1.133-.976l.073-.084 3.218-3.22H14a.75.75 0 01-.743-.648L13.25 6.5a.75.75 0 01.648-.743L14 5.75h3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExpandView);\n","import * as React from 'react';\nfunction IconExpenses(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2a1.75 1.75 0 011.744 1.606L20 3.75v16a.75.75 0 01-.177.484l-.074.076-1.813 1.613a.75.75 0 01-.908.068l-.089-.068-1.314-1.17-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068L12 20.753l-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068-1.314-1.17-1.314 1.17a.75.75 0 01-.811.121l-.097-.053-.089-.068-1.813-1.613a.75.75 0 01-.243-.454L4 19.75v-16a1.75 1.75 0 011.606-1.744L5.75 2h12.5zm0 1.5H5.75a.25.25 0 00-.243.193L5.5 3.75v15.662l1.063.946 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.313-1.168a.75.75 0 01.812-.122l.096.053.09.069 1.314 1.168 1.062-.945V3.75a.25.25 0 00-.13-.22l-.063-.023-.057-.007zm-2.5 9.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5h7.5zm-3-3.5a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm3-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExpenses);\n","import * as React from 'react';\nfunction IconExportToExcel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H12.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v8.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.648 14.507l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9 20.25v-3.19l-4.72 4.72a.75.75 0 01-1.133-.976l.073-.084L7.938 16H4.75a.75.75 0 01-.743-.648L4 15.25a.75.75 0 01.648-.743zM16.5 16.5v2h-4v-2h4zm0-3v2h-4v-2h4zm-5-3v2h-4v-2h4zm5 0v2h-4v-2h4zm-2-5.879V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExportToExcel);\n","import * as React from 'react';\nfunction IconExportToPdf(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H12.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v8.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.648 14.507l.102-.007h5l.07.003.101.017.068.019.06.023.07.035.082.054.08.07a.749.749 0 01.096.118l.05.09.04.103c.012.037.02.076.026.116l.007.102v5a.75.75 0 01-1.493.102L9 20.25v-3.19l-4.72 4.72a.75.75 0 01-1.133-.976l.073-.084L7.938 16H4.75a.75.75 0 01-.743-.648L4 15.25a.75.75 0 01.648-.743zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExportToPdf);\n","import * as React from 'react';\nfunction IconExport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.5 7.999V9.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5H15.5V7.999L18.25 8c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8l2.75-.001zM11.992 2l.1.006.076.013.08.023.107.047.091.058.084.073 3 3a.75.75 0 01-.976 1.133l-.084-.073-1.72-1.719V15.25a.75.75 0 01-1.493.102l-.007-.102V4.561l-1.72 1.72a.75.75 0 01-1.133-.977l.073-.084 3-3a.753.753 0 01.125-.101l.088-.049.119-.043.106-.021A.754.754 0 0111.992 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconExport);\n","import * as React from 'react';\nfunction IconFilterSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 2a.75.75 0 01.75.75v2a.75.75 0 01-.15.45l-5.7 7.6a.75.75 0 00-.15.45v6.725a.75.75 0 01-.494.705l-4 1.454A.75.75 0 019.5 21.43v-8.163a.75.75 0 00-.168-.473L3.168 5.207A.75.75 0 013 4.734V2.75A.75.75 0 013.75 2h16.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconFilterSolid);\n","import * as React from 'react';\nfunction IconFilter(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 2a.75.75 0 01.75.75v2a.75.75 0 01-.15.45l-5.7 7.6a.75.75 0 00-.15.45v6.725a.75.75 0 01-.494.705l-4 1.454A.75.75 0 019.5 21.43v-8.163a.75.75 0 00-.168-.473L3.168 5.207A.75.75 0 013 4.734V2.75A.75.75 0 013.75 2h16.5zm-.75 1.5h-15v.967l5.996 7.38c.285.351.457.779.496 1.226l.008.193v7.092l2.5-.91V13.25c0-.426.12-.842.347-1.2l.103-.15 5.55-7.401V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconFilter);\n","import * as React from 'react';\nfunction IconGraphSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-.925 3.324a.75.75 0 00-.95.263l-.051.088-4.124 8.591-2.924-6.09-.057-.1a.751.751 0 00-1.238 0l-.057.1-1.724 3.59-.524-1.09-.05-.09a.75.75 0 00-1.34.644l.038.095 1.2 2.5.057.1a.751.751 0 001.238 0l.057-.1L9.6 11.233l2.924 6.092.057.1a.751.751 0 001.238 0l.057-.1 4.8-10 .038-.095a.75.75 0 00-.39-.906z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconGraphSolid);\n","import * as React from 'react';\nfunction IconHash(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.158 2.017a.75.75 0 01.59.79l-.015.102-1.047 4.841H20a.75.75 0 01.102 1.493L20 9.25h-2.638l-1.189 5.5H18.5a.75.75 0 01.102 1.493l-.102.007h-2.652l-1.115 5.159a.75.75 0 01-1.48-.216l.014-.101 1.046-4.842H7.848l-1.115 5.159a.75.75 0 01-1.48-.216l.014-.101 1.046-4.842H4a.75.75 0 01-.102-1.493L4 14.75h2.637l1.189-5.5H5.5a.75.75 0 01-.102-1.493L5.5 7.75h2.651l1.116-5.158a.75.75 0 011.48.216l-.014.1L9.686 7.75h6.465l1.116-5.158a.75.75 0 01.891-.575zM14.637 14.75l1.189-5.5H9.362l-1.189 5.5h6.464z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconHash);\n","import * as React from 'react';\nfunction IconHome(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 6l8 8v7a1 1 0 01-1 1h-5v-5a1 1 0 00-.883-.993L13 16h-2a1 1 0 00-.993.883L10 17v5H5a1 1 0 01-1-1v-7l8-8zm.613-3.79l.094.083L17 6.585V4.75a.5.5 0 01.5-.5h1a.5.5 0 01.5.5v3.835l2.707 2.708a1 1 0 01-1.32 1.497l-.094-.083L12 4.415l-8.293 8.292a1 1 0 01-1.32.083l-.094-.083a1 1 0 01-.083-1.32l.083-.094 9-9a1 1 0 011.32-.083z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconHome);\n","import * as React from 'react';\nfunction IconImages(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.25 6c.966 0 1.75.784 1.75 1.75v11.5A1.75 1.75 0 0116.25 21H4.75A1.75 1.75 0 013 19.25V7.75C3 6.784 3.784 6 4.75 6h11.5zm0 1.5H4.75a.25.25 0 00-.243.193L4.5 7.75v11.5a.25.25 0 00.193.243l.057.007h11.5a.25.25 0 00.243-.193l.007-.057V7.75a.25.25 0 00-.193-.243L16.25 7.5zm-4.264 6.889l3.164 3.961h-9.5l2.375-3.164 1.605 2.148 2.356-2.945zM19.25 3a1.75 1.75 0 011.744 1.606L21 4.75v12.5a.75.75 0 01-1.493.102l-.007-.102V4.75a.25.25 0 00-.193-.243L19.25 4.5H6.75a.75.75 0 01-.102-1.493L6.75 3h12.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconImages);\n","import * as React from 'react';\nfunction IconImport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.5 8v1.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5H15.5V8h2.75c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8H8.5zM12 2a.75.75 0 01.743.648l.007.102v10.689l1.72-1.72a.75.75 0 011.133.977l-.073.084-3 3a.753.753 0 01-.125.101l-.088.049-.119.043-.106.021-.041.004-.07.002-.073-.006-.076-.013-.08-.023-.1-.043a.75.75 0 01-.182-.135l-3-3a.75.75 0 01.976-1.133l.084.073 1.72 1.719V2.75A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconImport);\n","import * as React from 'react';\nfunction IconInboxEinvoicing(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 3.997v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.221a1 1 0 00.916.598h3.694a1 1 0 00.915-.598l.976-2.22a1 1 0 01.915-.599h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.578v3.952a1.75 1.75 0 01-1.607 1.744l-.143.006H3.75A1.75 1.75 0 012 18.247v-3.952c0-.197.033-.393.098-.578L5.09 5.169a1.75 1.75 0 011.652-1.172H12zM17.966 1c2.373 0 4.052 1.688 4.052 3.99 0 .988-.267 1.349-1.03 1.386l-.14.003h-4.72v.404c.01 1.301.836 2.136 2.216 2.136.64 0 1.114-.139 1.502-.41l.403-.307c.267-.196.425-.276.705-.276.483 0 .817.334.817.844 0 .367-.2.72-.554 1.016l-.278.216c-.63.455-1.627.727-2.745.727-2.653 0-4.32-1.515-4.416-4.023l-.005-.23V5.27c0-2.547 1.688-4.27 4.193-4.27zM18 2.763c-1.09 0-1.805.769-1.868 1.932l-.004.186h3.674v-.017c0-1.275-.703-2.101-1.802-2.101z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxEinvoicing);\n","import * as React from 'react';\nfunction IconInboxScanning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.5 4v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.577v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4H13.5zM20 1l3 3v6c0 .51-.388.935-.884.993L22 11h-6.005a.998.998 0 01-.988-.884L15 10l.005-8a1 1 0 01.879-.993L16 1h4zm-1 1v3h3l-3-3z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxScanning);\n","import * as React from 'react';\nfunction IconInboxSmart(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M12 4v2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-.525-1.5h2.118l.428 1.22c.065.185.098.38.098.577v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4H12zm6.167-2.76a.35.35 0 01.631-.074l.036.074 1.145 3.115 3.183.179c.283.016.421.342.286.57l-.043.058-.037.036-2.476 2.104.823 3.226c.073.288-.182.527-.43.46l-.068-.025-.042-.024L18.5 9.121l-2.674 1.816c-.24.163-.535-.018-.552-.286l.003-.075.01-.049.821-3.226-2.475-2.104a.384.384 0 01.088-.637l.068-.02.05-.007 3.183-.179 1.145-3.115z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInboxSmart);\n","import * as React from 'react';\nfunction IconInbox(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M17.258 4c.744 0 1.407.47 1.652 1.172l2.992 8.547c.065.186.098.382.098.578v3.953a1.75 1.75 0 01-1.607 1.744L20.25 20H3.75A1.75 1.75 0 012 18.25v-3.953c0-.197.033-.392.098-.578L5.09 5.172A1.75 1.75 0 016.742 4h10.516zm-.177 2H6.918l-2.8 8h3.229a1 1 0 01.916.598l.974 2.22a1 1 0 00.916.599h3.694a1 1 0 00.915-.598l.976-2.221a1 1 0 01.915-.598h3.228l-2.8-8z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInbox);\n","import * as React from 'react';\nfunction IconInfo(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11.917 9.355c.406-.018.793.073 1.133.31.962.674.524 2.404-.048 3.869l-.158.391-.237.55-.455 1.002-.078.188c-.01.027-.02.051-.027.073-.561 1.637.086 2.057 1.037 1.797l.103-.03-.069.77c-1.848 1.337-4.443.961-3.364-2.283.052-.156.122-.33.204-.52l.176-.393.398-.867.2-.457c.385-.92.675-1.867.453-2.548-.164-.5-.684-.534-1.214-.352l-.114.042.068-.711c.543-.42 1.177-.732 1.79-.813l.202-.018zM13.148 5c.747 0 1.352.609 1.352 1.362 0 .75-.605 1.36-1.352 1.36a1.357 1.357 0 01-1.354-1.36c0-.753.605-1.362 1.354-1.362z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInfo);\n","import * as React from 'react';\nfunction IconInventoryMatrix(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-8 12.25H4.5v4a.25.25 0 00.193.243l.057.007h6.5v-4.25zm8.25-5h-6.75v9.25h6.5a.25.25 0 00.243-.193l.007-.057v-9zm-2.996 2.383c.419 0 .71.26.755.67l.007.115v3.945c0 .442-.23.688-.637.688-.373 0-.597-.207-.635-.573l-.006-.115v-3.511h-.015l-.41.277c-.204.129-.313.168-.442.168a.431.431 0 01-.445-.445c0-.165.086-.314.256-.445l.091-.063.637-.426c.305-.195.582-.285.844-.285zM11.25 4.5h-6.5a.25.25 0 00-.243.193L4.5 4.75v9h6.75V4.5zM7.883 6.57c1.074 0 1.86.657 1.86 1.551 0 .505-.224.954-.764 1.519l-1.268 1.282v.055h1.625c.363 0 .59.195.59.515 0 .285-.18.468-.484.502L9.336 12H6.664c-.379 0-.629-.215-.629-.543 0-.208.102-.392.399-.699l.12-.121 1.352-1.39c.418-.427.594-.708.594-1.005 0-.383-.277-.64-.688-.64-.332 0-.574.168-.746.515-.171.266-.32.367-.546.367-.31 0-.524-.21-.524-.507 0-.727.82-1.407 1.887-1.407zM19.25 4.5h-6.5v4.25h6.75v-4a.25.25 0 00-.193-.243L19.25 4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInventoryMatrix);\n","import * as React from 'react';\nfunction IconInventory(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 15a3.5 3.5 0 110 7 3.5 3.5 0 010-7zm0 2.25a1.25 1.25 0 100 2.5 1.25 1.25 0 000-2.5zm11.518-1.94l.04.121a1.25 1.25 0 01-.762 1.492l-.122.04-6.175 1.654.001-.117a4.48 4.48 0 00-.633-2.302l6.16-1.65a1.25 1.25 0 011.491.762zm-3.375-9.442l1.812 6.762a1 1 0 01-.707 1.224l-5.943 1.592a4.496 4.496 0 00-2.268-1.326L9.45 8.197a1 1 0 01.707-1.224l6.761-1.812a1 1 0 011.225.707zM3.657 1.536l.128.049 2.69 1.184c.304.133.54.381.66.686l.044.134L9.97 14l-.18.005a4.475 4.475 0 00-2.218.706L4.919 4.815l-2.141-.942a1.25 1.25 0 01-.69-1.52l.05-.128c.259-.59.918-.879 1.519-.689zM15.44 7.37a.75.75 0 00-.819-.55l-.1.02-1.449.388a.75.75 0 00.288 1.469l.1-.02 1.45-.388a.75.75 0 00.53-.919z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconInventory);\n","import * as React from 'react';\nfunction IconJournalPro(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.737 3.668c-.055 1.093.226 2.033.894 2.7.668.669 1.608.95 2.7.897a18.08 18.08 0 01-3.09 4.184 27.666 27.666 0 01-3.127 2.706v3.318a.553.553 0 01-.162.39l-3.975 3.975a.553.553 0 01-.943-.39V18.32a.55.55 0 01.162-.39l1.24-1.24a.553.553 0 00.161-.39v-.133c-1.238.463-2.218.487-2.735-.03-.517-.517-.493-1.497-.03-2.735H7.7a.553.553 0 00-.325.105l-.066.057-1.24 1.24a.553.553 0 01-.303.154l-.087.007H2.553a.553.553 0 01-.455-.867l.064-.076 3.975-3.975a.553.553 0 01.304-.155l.086-.007h3.318a27.666 27.666 0 012.706-3.126 18.078 18.078 0 014.186-3.092zM21.93 2.07c.104.105.095.547-.048 1.212l-.083.35-.107.386-.061.204-.142.43c-.154.444-.345.928-.575 1.436-1.073.193-1.96.04-2.501-.5-.523-.523-.684-1.37-.52-2.395l.019-.107a16.762 16.762 0 011.654-.649l.416-.13.197-.055.368-.095c.76-.18 1.27-.2 1.383-.087z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconJournalPro);\n","import * as React from 'react';\nfunction IconLayoutBoth(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 3a1 1 0 011 1v16a1 1 0 01-1 1H4a1 1 0 01-1-1V4a1 1 0 011-1h6zm10 0a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutBoth);\n","import * as React from 'react';\nfunction IconLayoutFirst(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 3a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6zM10 3a1 1 0 011 1v16a1 1 0 01-1 1H4a1 1 0 01-1-1V4a1 1 0 011-1h6zm9.5 1.5h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutFirst);\n","import * as React from 'react';\nfunction IconLayoutLast(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 3a1 1 0 01.993.883L11 4v16a1 1 0 01-.883.993L10 21H4a1 1 0 01-.993-.883L3 20V4a1 1 0 01.883-.993L4 3h6zm10 0a1 1 0 01.993.883L21 4v16a1 1 0 01-.883.993L20 21h-6a1 1 0 01-.993-.883L13 20V4a1 1 0 01.883-.993L14 3h6zM9.5 4.5h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutLast);\n","import * as React from 'react';\nfunction IconLayoutNone(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20 3a1 1 0 011 1v16a1 1 0 01-1 1h-6a1 1 0 01-1-1V4a1 1 0 011-1h6zM10 3a1 1 0 01.993.883L11 4v16a1 1 0 01-.883.993L10 21H4a1 1 0 01-.993-.883L3 20V4a1 1 0 01.883-.993L4 3h6zm9.5 1.5h-5v15h5v-15zm-10 0h-5v15h5v-15z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayoutNone);\n","import * as React from 'react';\nfunction IconLayout(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM16.326 2.676a1.752 1.752 0 012.349-.113l.125.113.594.593c.59.589.676 1.502.21 2.216l-.094.131-.115.128-7.504 7.5-3 .008-.078-3.067 7.513-7.509zm-.796 2.916l-5.202 5.199.025.957.914-.002 5.209-5.207-.946-.947zM20 9v2.25h-1.5V9H20zM5.5 7.5v3.75H4V7.5h1.5zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm9.687 1.697a.252.252 0 00-.248 0l-.053.04-.796.795.946.947.82-.82a.248.248 0 00.043-.216l-.021-.053-.044-.06-.594-.593-.053-.04zM13 2v1.499L9.5 3.5V2H13z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLayout);\n","import * as React from 'react';\nfunction IconLedgerCardCustomerReminder(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.69 0 3.093.4 4.212 1.198a4.49 4.49 0 00-.83 1.255C12.996 13.307 11.875 13 10.5 13c-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007h6.506L12.5 22H5.993a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm8.725 9.474A1.259 1.259 0 0118 22c-.605 0-1.11-.44-1.225-1.026h2.45zM18 12c.456 0 .841.392.961.927A3 3 0 0121 15.769v2.898l.835.642a.5.5 0 01-.213.888l-.092.008h-7.06a.5.5 0 01-.305-.896l.835-.642v-2.898c0-1.32.854-2.442 2.04-2.843.119-.534.504-.926.96-.926zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardCustomerReminder);\n","import * as React from 'react';\nfunction IconLedgerCardManualCustomerInvoice(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-8.75 9.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardManualCustomerInvoice);\n","import * as React from 'react';\nfunction IconLedgerCardObsoleteStock(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.25 16.5V18h-2.5a.75.75 0 110-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5v-1.5h2.5zm-7.75 0V18H8.25v-1.5h3.25zm4.25 0V18H12.5v-1.5h3.25zm-8.5-3.501v1.5l-2.5.001a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zM7.25 9.5V11h-2.5a.75.75 0 110-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5V9.5h2.5zm-7.75 0V11H8.25V9.5h3.25zm4.25 0V11H12.5V9.5h3.25zM7.25 6v1.5h-2.5a.75.75 0 010-1.5h2.5zm12 0a.75.75 0 110 1.5h-2.5V6h2.5zM11.5 6v1.5H8.25V6h3.25zm4.25 0v1.5H12.5V6h3.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardObsoleteStock);\n","import * as React from 'react';\nfunction IconLedgerCardOpeningEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.567 12.105a.4.4 0 01.1.309l-.29 2.798 2.434 1.41a.4.4 0 01-.116.737l-2.752.587-.587 2.752a.4.4 0 01-.738.116L15.21 18.38l-2.798.292a.4.4 0 01-.339-.666l1.88-2.092-1.141-2.571a.4.4 0 01.528-.528l2.57 1.141 2.093-1.88a.4.4 0 01.565.03zM19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V6h-15v13.25a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm-8.5 12.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm0-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm0-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardOpeningEntry);\n","import * as React from 'react';\nfunction IconLedgerCardReservedEntry(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75a1.75 1.75 0 01-1.732-1.499L19.25 19.5a.25.25 0 00.243-.193l.007-.057L19.499 6h-15v3.5h-1.5L3 4.75C3 3.784 3.784 3 4.75 3h14.5zM6.28 10.97a.75.75 0 01.073.976l-.073.084-1.719 1.719 5.689.001a.75.75 0 110 1.5l-5.69-.001 1.72 1.72a.75.75 0 01-.976 1.134l-.084-.073-3-3-.08-.094-.051-.081-.05-.116-.027-.103-.01-.089v-.094l.018-.124.03-.099.047-.099.054-.082.069-.08 3-3a.75.75 0 011.06 0zm10.97 4.53a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-8.5a.75.75 0 010-1.5h8.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardReservedEntry);\n","import * as React from 'react';\nfunction IconLedgerCardShrinkagePilferage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.25a.75.75 0 01.743.648l.007.102v3.439l1.22-1.22a.75.75 0 011.133.977l-.073.084-2.5 2.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.116.026-.056.006h-.104l-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-2.5-2.5a.75.75 0 01.977-1.133l.084.073 1.22 1.219V16a.75.75 0 01.75-.75zm-4.75-2.751v1.5L4.75 14a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zm-8.5-3.5v1.5l-2.5.001a.75.75 0 110-1.5l2.5-.001zm12 .001a.75.75 0 110 1.5l-2.5-.001v-1.5l2.5.001zm-7.75-.001v1.5H8.25v-1.5h3.25zm4.25 0v1.5H12.5v-1.5h3.25zm3.5-3.499a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardShrinkagePilferage);\n","import * as React from 'react';\nfunction IconLedgerCardStockAdjustment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 20.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-3.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm-2.5-8a.75.75 0 01.743.648l.007.102v3.439l1.22-1.22a.75.75 0 011.133.977l-.073.084-2.5 2.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012-.052.002-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-2.5-2.5a.75.75 0 01.977-1.133l.084.073L16 6.189V2.75a.75.75 0 01.75-.75zm-9.576.004l.128-.002.119.018.098.03.1.047.051.032.038.027.072.064 2.5 2.5a.75.75 0 01-.976 1.133L9.22 5.78 7.999 4.56 8 8a.75.75 0 01-1.493.102L6.5 8l-.001-3.438L5.28 5.78a.75.75 0 01-1.133-.976l.073-.084 2.5-2.5.042-.04.052-.04.114-.068.098-.038.084-.02a.75.75 0 01.064-.01z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardStockAdjustment);\n","import * as React from 'react';\nfunction IconLedgerCardTransferredOpeningEntry(\n props: React.SVGProps<SVGSVGElement>,\n svgRef?: React.Ref<SVGSVGElement>\n): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.567 12.105a.4.4 0 01.1.309l-.29 2.798 2.434 1.41a.4.4 0 01-.116.737l-2.752.587-.587 2.752a.4.4 0 01-.738.116L15.21 18.38l-2.798.292a.4.4 0 01-.339-.666l1.88-2.092-1.141-2.571a.4.4 0 01.528-.528l2.57 1.141 2.093-1.88a.4.4 0 01.565.03zM4.5 15v4.25a.25.25 0 00.193.243l.057.007H11V21H4.75A1.75 1.75 0 013 19.25V15h1.5zm6.28-1.72l-3 3-.084.073a.75.75 0 01-1.049-1.05l.073-.083 1.718-1.72H2.75a.75.75 0 110-1.5h5.689l-1.72-1.72a.75.75 0 01.977-1.133l.084.073 3 3a.754.754 0 01.092.11l.054.095.035.086.027.103.01.084-.001.121-.017.102-.019.068-.023.06-.035.07-.06.09-.063.071zM19.25 3c.966 0 1.75.784 1.75 1.75V11h-1.5V6h-15v4.5H3V4.75C3 3.784 3.784 3 4.75 3h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCardTransferredOpeningEntry);\n","import * as React from 'react';\nfunction IconLedgerCard(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0110.116 22H4.884a1.75 1.75 0 01-1.724-2.05C3.62 17.315 5.066 16 7.5 16zM19.25 2c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 20h-6.038l-.01-.063a11.184 11.184 0 00-.369-1.437h6.417a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L19.25 3.5H7.75a.25.25 0 00-.243.193L7.5 3.75V9.5c-.54 0-1.053.164-1.5.464V3.75C6 2.784 6.784 2 7.75 2h11.5zM7.5 10.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zm9.75 3.5a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-4a.75.75 0 110 1.5h-6a.75.75 0 110-1.5h6zm0-4a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLedgerCard);\n","import * as React from 'react';\nfunction IconLightbulb(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.598 20.501a2.999 2.999 0 01-5.196 0h5.196zm.152-2.251a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zM12 4.5c3.314 0 6 2.716 6 6.067 0 1.502-.517 2.528-1.087 3.398l-.265.392-.39.561c-.418.614-.761 1.208-.82 1.929l-.01.22c0 .256-.112.4-.338.428L15 17.5H9c-.254 0-.395-.114-.423-.342l-.006-.091c0-.774-.328-1.414-.75-2.064l-.262-.392-.273-.402-.24-.364C6.492 12.978 6 11.973 6 10.567 6 7.217 8.686 4.5 12 4.5zM12 6c-2.482 0-4.5 2.04-4.5 4.567 0 .931.245 1.599.876 2.573l.647.96.152.234c.322.512.56.988.709 1.474l.052.192h4.128l.054-.192c.126-.402.314-.796.561-1.208l.156-.25.235-.352.408-.587c.736-1.07 1.022-1.78 1.022-2.844C16.5 8.04 14.482 6 12 6zm-5.846 7.875a.75.75 0 01-.19.968l-.084.057-.866.5a.75.75 0 01-.835-1.243l.085-.057.866-.5a.75.75 0 011.024.275zm12.625-.32l.091.045.866.5a.75.75 0 01-.658 1.344l-.092-.044-.866-.5a.75.75 0 01.659-1.344zm2.33-4.661a.75.75 0 01-.509.844l-.099.025-.985.173a.75.75 0 01-.36-1.453l.1-.024.985-.174a.75.75 0 01.868.609zm-17.451-.62l.101.011.985.174a.75.75 0 01-.159 1.488l-.101-.01-.985-.174a.75.75 0 01.159-1.489zm14.288-4.86a.75.75 0 01.152.974l-.06.083-.643.766a.75.75 0 01-1.209-.882l.06-.082.643-.766a.75.75 0 011.057-.093zM7.04 3.433l.07.074.644.766A.75.75 0 016.675 5.31l-.07-.073-.643-.766A.75.75 0 017.04 3.433zM12 1.25a.75.75 0 01.743.648L12.75 2v1a.75.75 0 01-1.493.102L11.25 3V2a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLightbulb);\n","import * as React from 'react';\nfunction IconLine(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 11.25a.75.75 0 01.102 1.493L18 12.75H6a.75.75 0 01-.102-1.493L6 11.25h12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLine);\n","import * as React from 'react';\nfunction IconListBulleted(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.25 16a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5a.75.75 0 01-.75-.75v-2.5a.75.75 0 01.75-.75h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 17.25h10.25zM6.25 10a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5a.75.75 0 01-.75-.75v-2.5a.75.75 0 01.75-.75h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 11.25h10.25zM6.25 4a.75.75 0 01.75.75v2.5a.75.75 0 01-.75.75h-2.5A.75.75 0 013 7.25v-2.5A.75.75 0 013.75 4h2.5zm14 1.25a.75.75 0 01.102 1.493l-.102.007H10a.75.75 0 01-.102-1.493L10 5.25h10.25z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconListBulleted);\n","import * as React from 'react';\nfunction IconListSearch(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17.5 11a4.5 4.5 0 013.632 7.158l.036-.05 1.862 1.862a.75.75 0 01-.976 1.133l-.084-.073-1.863-1.862-.112.077A4.5 4.5 0 1117.5 11zm-6.25 7.5a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm6.25-6a3 3 0 100 6 3 3 0 000-6zm-7.25 1.167a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5zm3-4.834a.75.75 0 110 1.5H2.75a.75.75 0 110-1.5h10.5zm8-4.833a.75.75 0 110 1.5H2.75a.75.75 0 010-1.5h18.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconListSearch);\n","import * as React from 'react';\nfunction IconList(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 18a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 110-1.5h14.5zm0-4.5a.75.75 0 110 1.5H4.75a.75.75 0 010-1.5h14.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconList);\n","import * as React from 'react';\nfunction IconLockOpen(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 1a5.001 5.001 0 014.87 3.863.75.75 0 01-1.461.34 3.502 3.502 0 00-6.904.605L8.5 6v2h9.75c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V9.75C4 8.784 4.784 8 5.75 8H7V6a5 5 0 015-5zm6.25 8.5H5.75a.25.25 0 00-.243.193L5.5 9.75v10.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9.75a.25.25 0 00-.193-.243L18.25 9.5zM12 13a1.5 1.5 0 01.751 2.799l-.001.951a.75.75 0 11-1.5 0v-.95A1.5 1.5 0 0112 13z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLockOpen);\n","import * as React from 'react';\nfunction IconLogOut(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M13.25 4.5H6.5v15h6.75a1.25 1.25 0 110 2.5h-7A2.25 2.25 0 014 19.75V4.25A2.25 2.25 0 016.25 2h7a1.25 1.25 0 110 2.5zm6.384 2.616l-.102-.091a1.25 1.25 0 00-1.666 1.859l1.867 1.866H11.75l-.128.007a1.25 1.25 0 00.128 2.493h7.982l-1.866 1.866-.091.102a1.25 1.25 0 001.859 1.666l4-4 .08-.089.05-.063.068-.106.058-.112.049-.127.03-.108.016-.088.012-.112L24 12l-.004-.096-.016-.13-.03-.127-.03-.087-.046-.107-.046-.086-.065-.1a1.267 1.267 0 00-.13-.15l-4-4zm4.084 4.094l-.084-.094c.03.03.058.061.084.094z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLogOut);\n","import * as React from 'react';\nfunction IconLog(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V10.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v16.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V19H20v1.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V3.75C4 2.784 4.784 2 5.75 2h7.836zm-.105 10.074c1.447 0 2.3.875 2.367 2.279l.004.178v.621c0 1.5-.863 2.446-2.371 2.446-1.444 0-2.304-.872-2.371-2.268l-.004-.178v-.62c0-1.516.871-2.458 2.375-2.458zm5.362 0c1.328 0 2.058.776 2.172 1.653l.012.132h-1.25c-.074-.414-.406-.734-.945-.734-.638 0-1.007.443-1.05 1.222l-.005.16v.626c0 .805.293 1.414 1.09 1.414.598 0 .914-.34.956-.745l.005-.095v-.234h-.93v-.903h2.14v1.04c0 1.038-.667 1.988-2.199 1.988-1.57 0-2.3-.987-2.355-2.296l-.004-.165v-.64c0-1.427.84-2.423 2.363-2.423zm-10.182.094v4.262h2.141v1.07H7.376v-5.332h1.285zm4.82.95c-.597 0-1.012.415-1.062 1.23l-.005.168v.64c0 .926.43 1.399 1.067 1.399.593 0 1.008-.416 1.057-1.23l.005-.169v-.64c0-.926-.43-1.399-1.062-1.399zM14.5 4.62v2.63a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconLog);\n","import * as React from 'react';\nfunction IconMarket(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7 17.5a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H3.5a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5H7zm5.5 0a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H9a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5h3.5zm5.5 0a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5h-3.5a.5.5 0 01-.5-.5V18a.5.5 0 01.5-.5H18zM7 12a.5.5 0 01.5.5V16a.5.5 0 01-.5.5H3.5A.5.5 0 013 16v-3.5a.5.5 0 01.5-.5H7zm5.5 0a.5.5 0 01.5.5V16a.5.5 0 01-.5.5H9a.5.5 0 01-.5-.5v-3.5A.5.5 0 019 12h3.5zm6.97-2.523l.906 3.381a.5.5 0 01-.353.612l-3.381.906a.5.5 0 01-.612-.353l-.906-3.381a.5.5 0 01.353-.612l3.381-.906a.5.5 0 01.612.353zM7 6.5a.5.5 0 01.5.5v3.5a.5.5 0 01-.5.5H3.5a.5.5 0 01-.5-.5V7a.5.5 0 01.5-.5H7zm3.642-2.376l3.38.906a.5.5 0 01.354.612l-.906 3.38a.5.5 0 01-.612.354l-3.38-.906a.5.5 0 01-.354-.612l.906-3.38a.5.5 0 01.612-.354zM20 2a.5.5 0 01.5.5V6a.5.5 0 01-.5.5h-3.5A.5.5 0 0116 6V2.5a.5.5 0 01.5-.5H20z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMarket);\n","import * as React from 'react';\nfunction IconMatchAmount(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H13l-.001-1.5h5.251a.25.25 0 00.243-.193l.007-.057L18.499 9H14.75a1.75 1.75 0 01-1.744-1.606L13 7.25l-.001-3.75H5.75a.25.25 0 00-.243.193L5.5 3.75 5.499 13H4V3.75C4 2.784 4.784 2 5.75 2h7.836zM4.142 16.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074zM8 14a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 018 14zm6.499-9.38l.001 2.63a.25.25 0 00.193.243l.057.007h2.629l-2.88-2.88z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMatchAmount);\n","import * as React from 'react';\nfunction IconMatchEntries(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3a1.75 1.75 0 011.744 1.606L21 4.75v14.5a1.75 1.75 0 01-1.606 1.744L19.25 21H12v-1.5h7.25a.25.25 0 00.243-.193l.007-.057V5.996L19.406 6H4.5l.001 6H3V4.75a1.75 1.75 0 011.606-1.744L4.75 3h14.5zM3.696 15.809l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074a.5.5 0 01.55-.147zM7.002 13a4.001 4.001 0 013.92 3.197l.357-.62a.5.5 0 01.602-.221l.081.038a.5.5 0 01.221.601l-.038.082-1.237 2.143a.5.5 0 01-.601.221l-.082-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.034-1.798.75.75 0 11-.924-1.181A3.985 3.985 0 017.002 13zm10.248 2a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm-.125-3.5c.483 0 .875.336.875.75s-.392.75-.875.75h-5.25c-.483 0-.875-.336-.875-.75s.392-.75.875-.75h5.25zM17.25 8a.75.75 0 110 1.5H6.75a.75.75 0 010-1.5h10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMatchEntries);\n","import * as React from 'react';\nfunction IconMenu(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M4 19h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1s.45 1 1 1zm0-6h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1s.45 1 1 1zM3 6c0 .55.45 1 1 1h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMenu);\n","import * as React from 'react';\nfunction IconMileage(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10 0 1.806-.479 3.5-1.316 4.962L20.66 17a.75.75 0 01-.933.32l-.091-.045-1.516-.875a.75.75 0 01.659-1.344l.091.044.84.485c.406-.874.67-1.83.757-2.834l-.967-.001a.75.75 0 01-.102-1.493l.102-.007h.967a8.447 8.447 0 00-.757-2.834l-.84.484a.75.75 0 01-.835-1.243l.085-.057.838-.483a8.548 8.548 0 00-2.075-2.075l-.483.838a.75.75 0 01-1.344-.659l.044-.091.484-.84a8.447 8.447 0 00-2.833-.757l-.001.967a.75.75 0 01-1.493.102L11.25 4.5v-.967a8.447 8.447 0 00-2.834.757l.484.84a.75.75 0 01-1.243.835L7.6 5.88l-.483-.838a8.548 8.548 0 00-2.075 2.075l.838.483a.75.75 0 01-.659 1.344L5.13 8.9l-.84-.484a8.447 8.447 0 00-.757 2.834H4.5a.75.75 0 01.102 1.493l-.102.007h-.967a8.427 8.427 0 00.758 2.835l.839-.485a.75.75 0 01.835 1.243l-.085.057-1.516.875A.75.75 0 013.34 17l-.02-.04-.003.003A9.954 9.954 0 012 12C2 6.477 6.477 2 12 2zm4.03 5.97a.75.75 0 01.073.976l-.073.084-2.792 2.794a1.25 1.25 0 11-1.061-1.061L14.97 7.97a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMileage);\n","import * as React from 'react';\nfunction IconModalResize(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 15.5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm-10 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm5 0a1.5 1.5 0 110 3 1.5 1.5 0 010-3zm0-5a1.5 1.5 0 110 3 1.5 1.5 0 010-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconModalResize);\n","import * as React from 'react';\nfunction IconModalShrink(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H13.5v-1.5h5.75a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5H4.75a.25.25 0 00-.243.193L4.5 4.75v5.75H3V4.75C3 3.784 3.784 3 4.75 3h14.5zm-9 9c.966 0 1.75.784 1.75 1.75v5.5A1.75 1.75 0 0110.25 21h-5.5A1.75 1.75 0 013 19.25v-5.5c0-.966.784-1.75 1.75-1.75h5.5zm0 1.5h-5.5a.25.25 0 00-.243.193l-.007.057v5.5a.25.25 0 00.193.243l.057.007h5.5a.25.25 0 00.243-.193l.007-.057v-5.5a.25.25 0 00-.193-.243l-.057-.007zm7.78-7.53a.75.75 0 01.073.976l-.073.084-3.22 3.22h1.69a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743l-.102.007H13a.75.75 0 01-.743-.648L12.25 11V7.5a.75.75 0 011.493-.102l.007.102v1.688l3.22-3.218a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconModalShrink);\n","import * as React from 'react';\nfunction IconMoreSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 8.5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm0 5a1.5 1.5 0 100 3 1.5 1.5 0 000-3zm0-10a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMoreSolid);\n","import * as React from 'react';\nfunction IconMore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 10a2 2 0 110 4 2 2 0 010-4zm0 6.5a2 2 0 110 4 2 2 0 010-4zm0-13a2 2 0 110 4 2 2 0 010-4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMore);\n","import * as React from 'react';\nfunction IconMove(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.924 6.254l.128-.002.119.018.098.03.1.047.051.032.038.027.072.064 3.5 3.5a.75.75 0 01-.976 1.133l-.084-.073-2.22-2.219V17a.75.75 0 01-1.493.102L6.25 17V8.811l-2.22 2.22a.75.75 0 01-1.133-.977l.073-.084 3.5-3.5.042-.04.052-.04.114-.068.098-.038.084-.02a.75.75 0 01.064-.01zM17 6.25a.75.75 0 01.743.648L17.75 7l-.001 8.19 2.22-2.22a.75.75 0 011.134.976l-.073.084-3.5 3.5a.754.754 0 01-.078.069l.078-.069-.042.04-.052.04-.114.068-.098.038-.084.02-.088.012-.052.002-.052-.002-.119-.018-.098-.03-.1-.047-.082-.054-.08-.069-3.5-3.5a.75.75 0 01.977-1.133l.084.073 2.219 2.218L16.25 7a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconMove);\n","import * as React from 'react';\nfunction IconNavigationList(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 22v-.018A1.75 1.75 0 014 20.25V3.75c0-.882.652-1.61 1.5-1.732V2h12.75c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H5.5zM9 18.3H5.5v1.95a.25.25 0 00.193.243l.057.007H9v-2.2zm9.25-14.8H10.5v17h7.75a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5zM9 14.6H5.5v2.2H9v-2.2zm0-3.7H5.5v2.2H9v-2.2zm0-3.7H5.5v2.2H9V7.2zm0-3.7H5.75a.25.25 0 00-.243.193L5.5 3.75V5.7H9V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNavigationList);\n","import * as React from 'react';\nfunction IconNoteFollowUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H14v-1.5h4.25a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V11H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM9.225 20.974A1.259 1.259 0 018 22c-.605 0-1.11-.44-1.225-1.026h2.45zM8 12c.456 0 .841.392.961.927A3 3 0 0111 15.769v2.898l.835.642a.5.5 0 01-.305.896H4.47a.5.5 0 01-.305-.896L5 18.667v-2.898c0-1.32.854-2.442 2.04-2.843.119-.534.504-.926.96-.926zm7.25 2.5a.75.75 0 110 1.5h-1.5a.75.75 0 110-1.5h1.5zm0-3.5a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-3.5a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNoteFollowUp);\n","import * as React from 'react';\nfunction IconNoteRead(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2a.75.75 0 01.75.75V3h1.75a1.75 1.75 0 011.744 1.606L21 4.75v14.5a1.75 1.75 0 01-1.606 1.744L19.25 21H4.75a1.75 1.75 0 01-1.744-1.606L3 19.25V4.75a1.75 1.75 0 011.606-1.744L4.75 3H6.5v-.25a.75.75 0 011.5 0V3h3.25v-.25a.75.75 0 111.5 0V3H16v-.25a.75.75 0 01.75-.75zM6.499 4.5H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v14.5l.007.057a.25.25 0 00.175.184l.068.009h14.5l.057-.007a.25.25 0 00.184-.175l.009-.068V4.75l-.007-.057a.25.25 0 00-.175-.184L19.25 4.5H17.5v.25a.75.75 0 11-1.5 0V4.5h-3.25v.25a.75.75 0 11-1.5 0V4.5H7.999L8 4.75a.75.75 0 01-1.5 0l-.001-.25zM16.25 12a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm0-3a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNoteRead);\n","import * as React from 'react';\nfunction IconNote(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2a.75.75 0 01.75.75V3h1.75a1.75 1.75 0 011.744 1.606L21 4.75V14h-1.5V4.75l-.007-.057a.25.25 0 00-.175-.184L19.25 4.5H17.5v.25a.75.75 0 11-1.5 0V4.5h-3.25v.25a.75.75 0 11-1.5 0V4.5H7.999L8 4.75a.75.75 0 01-1.5 0l-.001-.25H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v14.5l.007.057a.25.25 0 00.175.184l.068.009H14V21H4.75a1.75 1.75 0 01-1.744-1.606L3 19.25V4.75a1.75 1.75 0 011.606-1.744L4.75 3H6.5v-.25a.75.75 0 011.5 0V3h3.25v-.25a.75.75 0 111.5 0V3H16v-.25a.75.75 0 01.75-.75zm-3.94 7.75l7.513 7.513a1.75 1.75 0 01.114 2.35l-.114.124-.586.586a1.75 1.75 0 01-2.35.114l-.124-.114-7.513-7.512V9.75h3.06zm5.697 7.818l-.938.94.754.755a.25.25 0 00.24.065l.06-.025.054-.04.586-.586a.25.25 0 00.04-.3l-.04-.054-.756-.755zm-6.318-6.318h-.939v.939l5.258 5.258.938-.94-5.257-5.257z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNote);\n","import * as React from 'react';\nfunction IconNumbers(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.203 16.625c0 .602.328.96.875.96.555 0 .875-.35.875-.96V7.898c0-.671-.437-1.132-1.078-1.132-.375 0-.742.14-1.273.515L1.125 8.344c-.367.25-.54.508-.54.789 0 .367.282.656.65.656.195 0 .382-.07.663-.266l1.258-.898h.047v8zm4.149.031c0 .516.414.844 1.046.844h5.22c.53 0 .843-.281.843-.734 0-.461-.328-.743-.844-.743H9.648v-.101l2.665-2.953c1.367-1.492 1.812-2.313 1.812-3.36 0-1.742-1.43-2.984-3.422-2.984-2.086 0-3.492 1.375-3.492 2.742 0 .485.312.813.766.813.367 0 .617-.211.804-.657.266-.906.93-1.43 1.82-1.43 1.063 0 1.774.665 1.774 1.657 0 .688-.344 1.313-1.21 2.266l-3.071 3.406c-.563.601-.742.89-.742 1.234zm8.562-1.375c0 1.242 1.555 2.446 3.617 2.446 2.274 0 3.867-1.297 3.867-3.141 0-1.352-.992-2.484-2.296-2.617v-.11c1.078-.171 1.953-1.257 1.953-2.421 0-1.649-1.461-2.813-3.524-2.813-1.984 0-3.414 1.156-3.414 2.39 0 .454.305.766.742.766.344 0 .578-.164.782-.578.367-.742 1.007-1.156 1.851-1.156 1.086 0 1.828.648 1.828 1.61 0 .952-.758 1.64-1.804 1.64h-.813c-.43 0-.726.305-.726.71 0 .423.304.735.726.735h.86c1.25 0 2.085.719 2.085 1.79 0 1.077-.82 1.765-2.093 1.765-.961 0-1.711-.422-2.14-1.188-.25-.414-.47-.57-.782-.57-.422 0-.719.313-.719.742z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconNumbers);\n","import * as React from 'react';\nfunction IconPartnerApi(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.884 11.616a1.25 1.25 0 01.091 1.666l-.091.102-1.868 1.866H19a1.25 1.25 0 01.128 2.494L19 17.75H8.017l1.867 1.866a1.25 1.25 0 01-1.666 1.859l-.102-.091-4-4a1.26 1.26 0 01-.13-.152l-.068-.106-.042-.079-.046-.107-.03-.087-.03-.127-.016-.126-.004-.1.002-.08.013-.111.016-.088.03-.108.05-.127.086-.16.062-.088.064-.076 4.043-4.046a1.25 1.25 0 011.768 0zm5.898-9.091l.102.091 4 4c.03.03.058.061.084.094l-.084-.094c.048.048.09.099.13.152l.064.099.046.086.046.107.03.087.03.127.016.13.004.096-.002.08-.013.111-.016.088-.03.108-.05.127-.057.112-.069.106-.048.063-.081.089-4 4a1.25 1.25 0 01-1.859-1.666l.091-.102 1.866-1.866H5a1.25 1.25 0 01-.128-2.494L5 6.25h10.983l-1.867-1.866a1.25 1.25 0 011.666-1.859z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPartnerApi);\n","import * as React from 'react';\nfunction IconPeriod(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 6c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 22H7.75A1.75 1.75 0 016 20.25V19h1.5v1.25a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V7.75a.25.25 0 00-.193-.243L20.25 7.5H19V6h1.25zm-7-5a.75.75 0 01.75.75V2h2.25c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0116.25 18H3.75A1.75 1.75 0 012 16.25V3.75C2 2.784 2.784 2 3.75 2H6v-.25a.75.75 0 011.5 0V2h5v-.25a.75.75 0 01.75-.75zm3.25 6.5h-13v8.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V7.5zm-6.195 1.277c.38 0 .62.21.662.554l.006.107v4.554c0 .356-.235.59-.582.59-.313 0-.538-.19-.58-.487l-.006-.103V9.957H9.78l-.824.574a.48.48 0 01-.312.106.402.402 0 01-.415-.422c0-.15.05-.267.172-.377l.082-.065L9.602 9a1.09 1.09 0 01.703-.223zM6 3.5H3.75a.25.25 0 00-.243.193L3.5 3.75V6h13V3.75a.25.25 0 00-.193-.243L16.25 3.5H14v.25a.75.75 0 11-1.5 0V3.5h-5v.25a.75.75 0 01-1.5 0V3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPeriod);\n","import * as React from 'react';\nfunction IconPersonChange(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.75 11.5c4.166 0 6.596 2.43 7.291 7.29A2.813 2.813 0 0119.257 22h-9.014a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm0 1.5c-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007h9.014a1.313 1.313 0 001.3-1.498C19.96 14.84 18.12 13 14.75 13zM6.446 6.397l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H1.75a.75.75 0 01-.102-1.493l.102-.007h5.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM14.75 2c1.933 0 3.5 1.903 3.5 4.25s-1.567 4.25-3.5 4.25-3.5-1.903-3.5-4.25S12.817 2 14.75 2zm0 1.5c-1.033 0-2 1.174-2 2.75s.967 2.75 2 2.75 2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonChange);\n","import * as React from 'react';\nfunction IconPersonMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm2.25 3.75h-4.5a.75.75 0 00-.102 1.493l.102.007h4.5a.75.75 0 00.102-1.493l-.102-.007zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonMinus);\n","import * as React from 'react';\nfunction IconPersonPlus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm0 1.5a.75.75 0 00-.743.648l-.007.102v1.5h-1.5a.75.75 0 00-.743.648l-.007.102c0 .38.282.693.648.743l.102.007h1.5v1.5c0 .38.282.693.648.743l.102.007a.75.75 0 00.743-.648l.007-.102v-1.5h1.5a.75.75 0 00.743-.648l.007-.102a.75.75 0 00-.648-.743l-.102-.007h-1.5v-1.5a.75.75 0 00-.648-.743L17.5 14.5zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonPlus);\n","import * as React from 'react';\nfunction IconPersonTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.5 11.5c1.486 0 2.751.31 3.796.928-.462.29-.881.644-1.246 1.047-.726-.32-1.574-.475-2.55-.475-3.37 0-5.211 1.84-5.806 6.002a1.313 1.313 0 001.165 1.491l.134.007 6.31.001a6.027 6.027 0 001.23 1.5L5.992 22a2.813 2.813 0 01-2.784-3.21c.695-4.86 3.125-7.29 7.291-7.29zm7 1.5a4.5 4.5 0 110 9 4.5 4.5 0 010-9zm2.403 1.867a.75.75 0 00-.97.141l-.066.09-1.983 3.114-.798-.999-.076-.081a.75.75 0 00-1.159.927l.063.091 1.455 1.819.073.079a.75.75 0 001.081-.059l.064-.086 2.546-4 .052-.098a.75.75 0 00-.282-.938zM10.5 2C12.433 2 14 3.903 14 6.25s-1.567 4.25-3.5 4.25S7 8.597 7 6.25 8.567 2 10.5 2zm0 1.5c-1.033 0-2 1.174-2 2.75S9.467 9 10.5 9s2-1.174 2-2.75-.967-2.75-2-2.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPersonTick);\n","import * as React from 'react';\nfunction IconPlay(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 1.5a8.5 8.5 0 100 17 8.5 8.5 0 000-17zM9.8 8a.7.7 0 011.05-.606l.084.057 4.86 3.84a.7.7 0 01.081 1.023l-.081.075-4.86 3.84a.7.7 0 01-1.127-.449l-.007-.1V8zm1.4 1.445v4.789l3.03-2.395-3.03-2.394z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPlay);\n","import * as React from 'react';\nfunction IconPlusMinus(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.169 17.055c.43 0 .734-.305.734-.75V13.43h2.649c.453 0 .757-.297.757-.72 0-.429-.304-.726-.757-.726H6.903V9.258c0-.445-.304-.758-.734-.758s-.727.313-.727.758v2.726H2.825c-.445 0-.758.297-.758.727 0 .422.313.719.758.719h2.617v2.875c0 .445.305.75.727.75zm5.598 2.453c.352 0 .64-.211.735-.555l3.453-12.25a1.17 1.17 0 00.047-.258c.007-.406-.336-.75-.766-.75-.36 0-.648.211-.742.547l-3.446 12.25a.749.749 0 00.719 1.016zm9.388-6.11c.578 0 .882-.32.882-.78 0-.462-.304-.766-.882-.766h-3.68c-.57 0-.883.312-.883.765 0 .461.305.781.883.781h3.68z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPlusMinus);\n","import * as React from 'react';\nfunction IconPrint(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.75 2c.966 0 1.75.784 1.75 1.75v1.758A3.75 3.75 0 0122 9.25v7.5a1.75 1.75 0 01-1.75 1.75H18.5v1.75A1.75 1.75 0 0116.75 22h-9.5a1.75 1.75 0 01-1.75-1.75V18.5H3.75A1.75 1.75 0 012 16.75v-7.5a3.75 3.75 0 013.5-3.742V3.75C5.5 2.784 6.284 2 7.25 2h9.5zM17 14.5H7v5.75a.25.25 0 00.193.243l.057.007h9.5a.25.25 0 00.243-.193L17 20.25V14.5zM18.25 7H5.75a2.25 2.25 0 00-2.245 2.096L3.5 9.25v7.5a.25.25 0 00.193.243L3.75 17H5.5v-3.25a.75.75 0 01.75-.75h11.5a.75.75 0 01.75.75V17h1.75a.25.25 0 00.243-.193l.007-.057v-7.5a2.25 2.25 0 00-2.096-2.245L18.25 7zm-.5 3a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm-1-6.5h-9.5a.25.25 0 00-.243.193L7 3.75V5.5h10V3.75a.25.25 0 00-.193-.243L16.75 3.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconPrint);\n","import * as React from 'react';\nfunction IconProcessPayment(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.247 2a.75.75 0 01.75.75l-.001.25h2.25c.967 0 1.75.784 1.75 1.75v14.5a1.75 1.75 0 01-1.75 1.75h-7.25v-1.5h7.25a.25.25 0 00.244-.193l.007-.057L19.496 8h-15v4h-1.5V4.75c0-.966.784-1.75 1.75-1.75h2.25v-.25a.75.75 0 011.5 0V3h7v-.25a.75.75 0 01.75-.75zM3.139 15.956a.5.5 0 01.631-.11l2.144 1.238.073.052a.5.5 0 01.11.631l-.052.074a.5.5 0 01-.631.11l-.878-.506a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.814-.574l1.237-2.143zM6.997 13a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.601.221l-.082-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 016.997 13zm-.001-8.5h-2.25a.25.25 0 00-.243.193l-.006.057-.001 1.75h15V4.75a.25.25 0 00-.192-.243l-.057-.007h-2.251v.25a.75.75 0 11-1.5 0V4.5h-7v.25a.75.75 0 01-1.5 0V4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProcessPayment);\n","import * as React from 'react';\nfunction IconProductLedgerCard(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.797 9c.464 0 .91.184 1.237.513l6.229 6.228a1.75 1.75 0 010 2.475l-4.047 4.047a1.75 1.75 0 01-2.475 0l-6.228-6.229A1.75 1.75 0 012 14.797V10.75C2 9.784 2.784 9 3.75 9h4.047zM18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H14.5v-1.5h3.75a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75V8H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM7.797 10.5H3.75a.25.25 0 00-.243.193l-.007.057v4.047a.25.25 0 00.033.125l.04.052 6.228 6.228a.25.25 0 00.3.04l.054-.04 4.047-4.047a.25.25 0 00.04-.3l-.04-.054-6.228-6.228a.25.25 0 00-.112-.064l-.065-.009zm-2.504 1.793a1 1 0 111.414 1.414 1 1 0 01-1.414-1.414zM15.75 9.5a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProductLedgerCard);\n","import * as React from 'react';\nfunction IconProfile(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M22 12c0-5.523-4.477-10-10-10S2 6.477 2 12a9.97 9.97 0 003.047 7.187A9.967 9.967 0 0012 22a9.967 9.967 0 006.953-2.813A9.97 9.97 0 0022 12zM5.704 16.936A7.986 7.986 0 0012 20a7.986 7.986 0 006.296-3.064A7 7 0 0012 13a7 7 0 00-6.296 3.936zM12 12a3.5 3.5 0 100-7 3.5 3.5 0 000 7z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProfile);\n","import * as React from 'react';\nfunction IconProjectCards(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm0 1.5H4.75a.25.25 0 00-.243.193L4.5 4.75v14.5a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V4.75a.25.25 0 00-.193-.243L19.25 4.5zM8.25 15a.75.75 0 01.75.75v1a.75.75 0 01-.75.75h-1a.75.75 0 01-.75-.75v-1a.75.75 0 01.75-.75h1zm8.5 1a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-3.167a.75.75 0 010 1.5h-4.5a.75.75 0 110-1.5h4.5zm0-3.166a.75.75 0 110 1.5h-4.5a.75.75 0 010-1.5h4.5zM8.25 6.5a.75.75 0 01.75.75v1a.75.75 0 01-.75.75h-1a.75.75 0 01-.75-.75v-1a.75.75 0 01.75-.75h1zm8.5 0a.75.75 0 110 1.5h-4.5a.75.75 0 110-1.5h4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProjectCards);\n","import * as React from 'react';\nfunction IconProjects(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm0 3a1 1 0 00-.993.883L11 6v6.02l.01.118.022.113.023.077.03.075.047.093.062.096.07.085.072.071.096.075.099.06.075.036 3.5 1.5.11.04a1 1 0 00.782-1.826l-.104-.052L13 11.34V6l-.007-.117A1 1 0 0012 5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconProjects);\n","import * as React from 'react';\nfunction IconQuicklinks(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M7.102 11.125c.753 0 1.472.295 2.007.817l.142.148 4.806 5.407c.183.206.434.337.705.37l.136.008h3.416L17.22 16.78l-.073-.084a.75.75 0 011.05-1.049l.083.073 2.5 2.5a.753.753 0 01.097.118l.053.094.028.07.023.08.013.075.006.102-.002.042-.009.075-.027.111-.043.102-.038.066-.027.04-.035.043-.039.042-2.5 2.5-.084.073a.75.75 0 01-1.049-1.05l.073-.083 1.095-1.096-3.417.001a2.875 2.875 0 01-2.007-.817l-.142-.148-4.806-5.407a1.125 1.125 0 00-.705-.37l-.136-.008H3.75a.875.875 0 01-.11-1.743l.11-.007h3.352zm11.094-8.978l.084.073 2.5 2.5a.63.63 0 01.101.125l.049.088.043.119.021.106.004.042.002.069-.006.073-.013.076-.023.08-.047.107-.058.091-.073.084-2.5 2.5a.75.75 0 01-1.133-.976l.073-.084 1.095-1.096-3.426.001-.136.008c-.223.027-.433.12-.603.268l-.096.095-2.905 3.215-.085.083a.875.875 0 01-1.287-1.162l.074-.094 2.904-3.215.141-.146a2.875 2.875 0 011.79-.795l.203-.007 3.424-.001L17.22 3.28a.75.75 0 01.976-1.133z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconQuicklinks);\n","import * as React from 'react';\nfunction IconRatingBankruptcy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2c5.523 0 10 4.477 10 10s-4.477 10-10 10S2 17.523 2 12 6.477 2 12 2zm.035 4.982c-.264 0-.533.13-.533.51v.41C9.92 8.05 8.9 8.998 8.9 10.352c0 1.135.646 1.88 1.926 2.202l1.309.288c.844.181 1.178.44 1.178.879 0 .562-.446.931-1.272.931-.592 0-1.166-.246-1.687-.72-.334-.282-.545-.364-.803-.364-.416 0-.75.258-.75.715 0 .352.187.692.515.99.487.452 1.272.727 2.163.803v.358c0 .375.275.51.539.51.263 0 .533-.135.533-.51v-.37c1.64-.193 2.666-1.154 2.666-2.543 0-1.143-.66-1.862-1.997-2.176l-1.314-.273c-.744-.146-1.084-.427-1.084-.867 0-.492.44-.885 1.131-.885.586 0 1.008.188 1.506.662.293.252.533.364.85.364.369 0 .673-.27.673-.657 0-.328-.175-.673-.503-.984-.434-.422-1.131-.691-1.91-.79v-.423c0-.375-.27-.51-.534-.51z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRatingBankruptcy);\n","import * as React from 'react';\nfunction IconRatingPaymentProblems(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M21.25 11.25A.75.75 0 0122 12c0 5.523-4.477 10-10 10a9.986 9.986 0 01-7.638-3.545l-.038 1.071a.75.75 0 01-1.496.05l-.003-.102.099-2.827a.75.75 0 01.775-.723l2.827.098a.75.75 0 01.05 1.496l-.102.004-.966-.034A8.5 8.5 0 0020.5 12a.75.75 0 01.75-.75zm-9.215-4.268c.237 0 .48.11.526.405l.007.105v.422c.78.1 1.477.37 1.91.791.329.31.504.656.504.984 0 .387-.304.657-.673.657-.317 0-.557-.112-.85-.364-.498-.474-.92-.662-1.506-.662-.691 0-1.13.393-1.13.885 0 .406.289.677.919.831l.164.036 1.108.229c1.476.287 2.203 1.02 2.203 2.22 0 1.331-.942 2.27-2.464 2.515l-.202.028v.37c0 .375-.27.51-.533.51-.238 0-.485-.11-.532-.405l-.007-.105v-.358c-.891-.076-1.676-.351-2.163-.803-.328-.298-.515-.638-.515-.99 0-.457.334-.715.75-.715.258 0 .469.082.803.364.521.474 1.095.72 1.687.72.826 0 1.271-.369 1.271-.931 0-.41-.29-.662-1.015-.842l-.162-.037-1.102-.24c-1.418-.293-2.133-1.055-2.133-2.25 0-1.298.937-2.223 2.407-2.427l.195-.023v-.41c0-.38.27-.51.533-.51zM12 2c3 0 5.77 1.332 7.639 3.545l.037-1.071a.75.75 0 011.496-.05l.003.102-.099 2.827a.75.75 0 01-.674.72l-.101.003-2.827-.098a.75.75 0 01-.05-1.496l.102-.004.966.034A8.5 8.5 0 003.5 12 .75.75 0 112 12C2 6.477 6.477 2 12 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRatingPaymentProblems);\n","import * as React from 'react';\nfunction IconReconciled(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M17 7a5 5 0 01.217 9.995L17 17h-2.5a.75.75 0 01-.102-1.493l.102-.007H17a3.5 3.5 0 00.192-6.995L17 8.5h-2.5a.75.75 0 01-.102-1.493L14.5 7H17zM9.5 7a.75.75 0 01.102 1.493L9.5 8.5H7a3.5 3.5 0 00-.192 6.995L7 15.5h2.5a.75.75 0 01.102 1.493L9.5 17H7a5 5 0 01-.217-9.995L7 7h2.5zm7.5 4.25a.75.75 0 110 1.5H7a.75.75 0 110-1.5h10z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReconciled);\n","import * as React from 'react';\nfunction IconRefresh(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.268 21.246L12 21.25l-.323-.006-.32-.016-.3-.025-.329-.04a9.166 9.166 0 01-2.067-.534l-.288-.117-.353-.16-.237-.117-.358-.193-.385-.233-.263-.173-.3-.215-.23-.177-.238-.196-.356-.319a9.308 9.308 0 01-.345-.343l-.151-.162a9.197 9.197 0 01-1.662-2.58l-.126-.311-.134-.372-.087-.268-.08-.285A9.229 9.229 0 012.75 12c0-.893.127-1.757.363-2.574l.137-.431.077-.218.169-.421a9.17 9.17 0 01.768-1.431l.171-.25c.213-.303.447-.595.701-.876l.168-.18c.174-.183.356-.36.545-.528l.197-.17.345-.278.328-.239.302-.202.117-.072a8.88 8.88 0 01.664-.375l.484-.23.37-.152.427-.153.353-.11.263-.071.145-.036A9.232 9.232 0 0112 2.75l.24.003.317.014.389.031.284.033.487.079.43.091.287.073.39.116.293.099.336.127.17.07.379.172.259.129.25.135.416.248.255.166a9.12 9.12 0 011.14.911V3.222a.75.75 0 01.638-.742l.111-.008a.75.75 0 01.742.639l.008.11v3.83a.75.75 0 01-.64.741l-.11.008h-3.828a.75.75 0 01-.111-1.492l.11-.008h2.009l-.197-.177-.22-.182-.131-.102-.2-.147-.225-.156-.235-.15-.236-.139-.149-.081-.222-.115-.268-.126-.121-.053a7.709 7.709 0 00-1.013-.352l-.263-.067-.258-.055-.262-.047-.278-.04-.349-.036-.353-.02L12 4.25l-.183.002-.376.018-.294.026-.248.032-.335.055-.344.073-.243.061-.202.058a7.72 7.72 0 00-.54.183l-.282.114-.204.09-.317.156-.24.13a7.755 7.755 0 00-.629.397l-.383.285-.21.174-.075.064a7.796 7.796 0 00-.195.178l-.18.174-.239.25-.175.198-.152.184a7.778 7.778 0 00-.59.84l-.174.305-.116.222-.112.232a7.079 7.079 0 00-.15.346l-.11.29-.122.368-.046.16c-.084.304-.15.612-.197.923l-.05.409.01-.098c-.05.453-.06.91-.03 1.364l.024.285c.031.307.081.611.15.913l.073.3.058.204c.072.245.157.486.255.724l.085.2c.05.112.102.223.156.332l.091.175.137.245.148.246.058.088a7.766 7.766 0 00.436.604l.141.173.093.107.174.191.174.18.18.175.246.22.324.264.349.255.123.083.24.151.2.118.259.14.257.128.33.146.24.095c.195.073.393.139.594.196l.359.094.136.03.124.026.297.053.329.045.246.024.097.008c.091.006.183.011.275.014l.275.005A7.75 7.75 0 0019.75 12a.75.75 0 111.5 0 9.25 9.25 0 01-8.982 9.246z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRefresh);\n","import * as React from 'react';\nfunction IconReportSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.5 12a1 1 0 011 1v6a1 1 0 01-1 1H4a1 1 0 01-1-1v-6a1 1 0 011-1h2.5zm6.75-5a1 1 0 011 1v11a1 1 0 01-1 1h-2.5a1 1 0 01-1-1V8a1 1 0 011-1h2.5zM20 4a1 1 0 011 1v14a1 1 0 01-1 1h-2.5a1 1 0 01-1-1V5a1 1 0 011-1H20z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReportSolid);\n","import * as React from 'react';\nfunction IconReport(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M6.25 12c.966 0 1.75.784 1.75 1.75v4.5A1.75 1.75 0 016.25 20h-1.5A1.75 1.75 0 013 18.25v-4.5c0-.966.784-1.75 1.75-1.75h1.5zm6.5-5c.966 0 1.75.784 1.75 1.75v9.5A1.75 1.75 0 0112.75 20h-1.5a1.75 1.75 0 01-1.75-1.75v-9.5c0-.966.784-1.75 1.75-1.75h1.5zm6.5-3c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0119.25 20h-1.5A1.75 1.75 0 0116 18.25V5.75c0-.966.784-1.75 1.75-1.75h1.5zm-13 9.5h-1.5a.25.25 0 00-.243.193l-.007.057v4.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193l.007-.057v-4.5a.25.25 0 00-.193-.243L6.25 13.5zm6.5-5h-1.5a.25.25 0 00-.243.193L11 8.75v9.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193L13 18.25v-9.5a.25.25 0 00-.193-.243L12.75 8.5zm6.5-3h-1.5a.25.25 0 00-.243.193l-.007.057v12.5a.25.25 0 00.193.243l.057.007h1.5a.25.25 0 00.243-.193l.007-.057V5.75a.25.25 0 00-.193-.243L19.25 5.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconReport);\n","import * as React from 'react';\nfunction IconRestore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 9.25a.75.75 0 01.743.648l.007.102v8.25a3.75 3.75 0 01-3.55 3.745L15 22h-5a3.75 3.75 0 01-3.745-3.55l-.005-.2V10a.75.75 0 01.648-.743L7 9.25h11zm-.75 1.5h-9.5v7.5a2.25 2.25 0 001.938 2.229l.158.016.154.005h5a2.25 2.25 0 002.245-2.096l.005-.154v-7.5zm-6.75 1.5a.75.75 0 01.743.648l.007.102v5.25a.75.75 0 01-1.493.102l-.007-.102V13a.75.75 0 01.75-.75zm4 0a.75.75 0 01.743.648l.007.102v5.25a.75.75 0 01-1.493.102l-.007-.102V13a.75.75 0 01.75-.75zm2.372-9.849a3.847 3.847 0 012.03 4.45l2.668 1.302a.75.75 0 01-.563 1.386l-.094-.038L9.086 3.732a.75.75 0 01.563-1.386l.094.038 2.373 1.157a3.847 3.847 0 014.756-1.14zM3 4.25a.75.75 0 01.743.648L3.75 5v.63c2.434-1.684 5.714-1.245 7.542 1.11a.75.75 0 11-1.185.919C8.819 6 6.547 5.647 4.777 6.749l.723.001a.75.75 0 01.743.648l.007.102a.75.75 0 01-.648.743L5.5 8.25H3a.75.75 0 01-.743-.648L2.25 7.5V5A.75.75 0 013 4.25zm10.507-.031l4.005 1.953a2.347 2.347 0 00-4.005-1.953z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRestore);\n","import * as React from 'react';\nfunction IconRotateLeft(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2.75a9.25 9.25 0 016.54 15.79.75.75 0 11-1.06-1.06 7.75 7.75 0 10-13.224-5.797l.714-.713.084-.073a.75.75 0 011.049 1.05l-.073.083-2 2-.084.073a.75.75 0 01-.882.007l-.094-.08-2-2-.073-.084a.75.75 0 01-.007-.882l.08-.094.084-.073a.75.75 0 01.882-.007l.094.08.725.724A9.25 9.25 0 0112 2.75z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRotateLeft);\n","import * as React from 'react';\nfunction IconRotateRight(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 2.75a9.25 9.25 0 019.245 8.944l.725-.724a.75.75 0 01.976-.073l.084.073a.75.75 0 01.073.976l-.073.084-2 2a.75.75 0 01-.976.073l-.084-.073-2-2a.75.75 0 01.976-1.133l.084.073.714.712A7.75 7.75 0 106.52 17.48a.75.75 0 11-1.06 1.06A9.25 9.25 0 0112 2.75z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconRotateRight);\n","import * as React from 'react';\nfunction IconSales(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.021 23.316c.594 0 1.121-.33 1.121-1.12V21.14c3.546-.382 5.761-2.465 5.761-5.498 0-2.61-1.569-4.192-4.825-4.904l-2.676-.606C9.727 9.763 8.91 8.999 8.91 7.878c0-1.344 1.16-2.32 2.98-2.32 1.476 0 2.504.5 3.651 1.78.58.606 1.029.83 1.635.83.738 0 1.305-.514 1.305-1.279 0-.738-.435-1.542-1.173-2.267-.976-.923-2.439-1.53-4.087-1.74V1.787c0-.777-.527-1.107-1.134-1.107-.593 0-1.12.316-1.12 1.107v1.055c-3.415.317-5.59 2.36-5.59 5.287 0 2.557 1.569 4.258 4.575 4.93l2.676.62c1.951.461 2.755 1.147 2.755 2.307 0 1.503-1.173 2.452-3.27 2.452-1.568 0-2.873-.593-4.06-1.872-.672-.672-1.041-.817-1.542-.817-.805 0-1.411.514-1.411 1.397 0 .778.448 1.582 1.252 2.281 1.055.962 2.703 1.556 4.536 1.727v1.042c0 .79.527 1.12 1.133 1.12z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSales);\n","import * as React from 'react';\nfunction IconSearchBold(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.75 2a7.75 7.75 0 016.292 12.275l5.592 5.591a1.25 1.25 0 01-1.666 1.859l-.102-.091-5.59-5.592A7.75 7.75 0 119.75 2zm0 2.5a5.25 5.25 0 100 10.5 5.25 5.25 0 000-10.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSearchBold);\n","import * as React from 'react';\nfunction IconSearch(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 2.25a7.75 7.75 0 015.985 12.674l5.545 5.546a.75.75 0 01-.976 1.133l-.084-.073-5.546-5.545A7.75 7.75 0 1110 2.25zm0 1.5a6.25 6.25 0 100 12.5 6.25 6.25 0 000-12.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSearch);\n","import * as React from 'react';\nfunction IconSecureTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.01 2.25a.75.75 0 01.665.402c.72 1.376 3.174 2.323 7.389 2.683a.75.75 0 01.686.748c0 7.747-1.54 11.378-5.945 14.213l-.502.312-.525.306a26.51 26.51 0 01-.834.452l-.29.148-.323.16a.75.75 0 01-.654.003c-6.293-3-8.427-6.542-8.427-15.594a.75.75 0 01.686-.748c4.215-.36 6.67-1.307 7.389-2.683a.75.75 0 01.56-.395l.126-.007zM12 4.245l-.064.067C10.702 5.54 8.479 6.317 5.277 6.705l-.523.058.01.54c.012.53.033 1.039.063 1.525l.052.713c.472 5.577 2.312 8.141 6.618 10.372l.272.139.228.113.262-.133c4.685-2.43 6.538-5.033 6.915-11.21l.038-.743.025-.778.007-.402.001-.136-.522-.058c-3.068-.372-5.238-1.1-6.5-2.242l-.159-.15L12 4.244zm4.903 4.104l.077.067a.75.75 0 01.067.984l-.067.077-5.52 5.52-3.382-3.38a.75.75 0 01.984-1.129l.076.067 2.32 2.322 4.461-4.46a.75.75 0 01.984-.068z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSecureTick);\n","import * as React from 'react';\nfunction IconSecure(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.01 2.25a.75.75 0 01.665.402c.72 1.376 3.174 2.323 7.389 2.683a.75.75 0 01.686.748c0 7.747-1.54 11.378-5.945 14.213l-.502.312-.525.306a26.51 26.51 0 01-.834.452l-.29.148-.323.16a.75.75 0 01-.654.003c-6.293-3-8.427-6.542-8.427-15.594a.75.75 0 01.686-.748c4.215-.36 6.67-1.307 7.389-2.683a.75.75 0 01.56-.395l.126-.007zM12 4.245l-.064.067C10.702 5.54 8.479 6.317 5.277 6.705l-.523.058.01.54c.012.53.033 1.039.063 1.525l.052.713c.472 5.577 2.312 8.141 6.618 10.372l.272.139.228.113.262-.133c4.685-2.43 6.538-5.033 6.915-11.21l.038-.743.025-.778.007-.402.001-.136-.522-.058c-3.068-.372-5.238-1.1-6.5-2.242l-.159-.15L12 4.244zM12 8l.15.005a2 2 0 01.98 3.645L14 16h-4l.87-4.35a2 2 0 01.982-3.644L11.999 8z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSecure);\n","import * as React from 'react';\nfunction IconSettingsSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13 2a1 1 0 011 1v1.77a7.44 7.44 0 011.698.703l1.252-1.251a1 1 0 011.414 0l1.414 1.414a1 1 0 010 1.414l-1.251 1.252c.3.53.538 1.099.703 1.698H21a1 1 0 011 1v2a1 1 0 01-1 1h-1.77a7.454 7.454 0 01-.703 1.698l1.251 1.252a1 1 0 010 1.414l-1.414 1.414a1 1 0 01-1.414 0l-1.252-1.251a7.47 7.47 0 01-1.697.703L14 21a1 1 0 01-1 1h-2a1 1 0 01-1-1v-1.77a7.454 7.454 0 01-1.698-.703L7.05 19.778a1 1 0 01-1.414 0l-1.414-1.414a1 1 0 010-1.414l1.251-1.252A7.454 7.454 0 014.77 14H3a1 1 0 01-1-1v-2a1 1 0 011-1h1.77a7.44 7.44 0 01.703-1.698L4.222 7.05a1 1 0 010-1.414l1.414-1.414a1 1 0 011.414 0l1.252 1.251c.53-.3 1.099-.538 1.698-.703V3a1 1 0 011-1h2zm-1 6a4 4 0 100 8 4 4 0 000-8z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSettingsSolid);\n","import * as React from 'react';\nfunction IconSettings(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.056 2c.918 0 1.67.707 1.744 1.606l.006.144v.787l.243.093.154.063.093.042.554-.553a1.75 1.75 0 012.217-.212l.133.1.125.113 1.492 1.492a1.75 1.75 0 01.114 2.35l-.113.125-.524.523.046.1.068.156.064.157.039.108h.74a1.75 1.75 0 011.725 1.459l.018.148.006.143v2.112a1.75 1.75 0 01-1.606 1.744l-.144.006h-.739l-.04.108-.063.158-.068.156-.047.098.524.524c.553.551.663 1.389.29 2.08l-.08.136-.095.131-.115.128-1.492 1.492c-.59.59-1.502.676-2.216.21l-.131-.095-.128-.115-.554-.554-.093.043-.154.064-.243.092v.789a1.752 1.752 0 01-1.459 1.725l-.148.018-.143.006h-2.111A1.75 1.75 0 019.2 20.393l-.006-.143v-.848l-.08-.03-.148-.06-.214-.097-.602.603a1.75 1.75 0 01-2.217.212l-.133-.1-.125-.113-1.492-1.492a1.75 1.75 0 01-.114-2.35l.114-.125.632-.634-.09-.204-.079-.206h-.897a1.752 1.752 0 01-1.725-1.459l-.018-.148L2 13.056v-2.112A1.75 1.75 0 013.606 9.2l.144-.006h.896l.08-.206.089-.205-.632-.633a1.75 1.75 0 01-.213-2.217l.099-.133.114-.125 1.492-1.492c.59-.59 1.502-.676 2.216-.21l.131.095.128.115.602.601.214-.095.149-.062.079-.03V3.75c0-.791.528-1.469 1.294-1.684l.146-.035.151-.023.16-.008h2.111zm-2.069 1.499l-.073.003a.25.25 0 00-.212.186l-.007.062v1.377a.75.75 0 01-.528.717c-.417.129-.818.3-1.2.51a.75.75 0 01-.809-.054l-.083-.071-.952-.954-.058-.053a.25.25 0 00-.27-.023l-.059.044-1.493 1.493a.25.25 0 00-.04.3l.04.054 1.009 1.008a.75.75 0 01.132.883c-.2.375-.361.769-.483 1.177a.75.75 0 01-.61.528l-.108.008H3.75a.25.25 0 00-.243.193l-.007.057v2.11c0 .12.083.22.193.245l.057.007h1.433a.75.75 0 01.719.537c.121.408.283.802.482 1.176a.75.75 0 01-.061.8l-.071.083-1.009 1.008a.25.25 0 00-.04.3l.04.054 1.493 1.493a.25.25 0 00.3.04l.054-.04.985-.986a.75.75 0 01.893-.126c.38.21.782.382 1.199.511a.75.75 0 01.52.609l.008.108v1.377a.25.25 0 00.192.243l.057.007h2.111a.251.251 0 00.244-.193l.007-.057v-1.331a.75.75 0 01.545-.721 6.398 6.398 0 001.247-.503.75.75 0 01.8.06l.083.072.896.898.058.053a.25.25 0 00.27.023l.059-.044 1.462-1.46.052-.057a.25.25 0 00.023-.27l-.044-.06-.907-.905a.75.75 0 01-.126-.894 6.4 6.4 0 00.533-1.269.75.75 0 01.61-.528l.108-.008h1.275a.25.25 0 00.243-.193l.007-.057v-2.111a.25.25 0 00-.193-.244l-.057-.007h-1.275a.75.75 0 01-.718-.536 6.4 6.4 0 00-.533-1.269.75.75 0 01.055-.81l.071-.083.907-.906a.25.25 0 00.04-.3l-.04-.054-1.493-1.493a.25.25 0 00-.3-.04l-.054.04-.93.93a.75.75 0 01-.882.132 6.398 6.398 0 00-1.247-.503.75.75 0 01-.536-.611l-.008-.11-.001-1.33a.251.251 0 00-.194-.244l-.056-.007-2.069-.001zM12 7.533a4.467 4.467 0 110 8.934 4.467 4.467 0 010-8.934zm0 1.5a2.967 2.967 0 100 5.934 2.967 2.967 0 000-5.934z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSettings);\n","import * as React from 'react';\nfunction IconShortcuts(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 5c.966 0 1.75.784 1.75 1.75v10.5A1.75 1.75 0 0120.25 19H3.75A1.75 1.75 0 012 17.25V6.75C2 5.784 2.784 5 3.75 5h16.5zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 6.75v10.5a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V6.75a.25.25 0 00-.193-.243L20.25 6.5zM6.5 14a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm9 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-7a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h7zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm-12-3a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm-12-3a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1zm3 0a.5.5 0 01.5.5v1a.5.5 0 01-.5.5h-1a.5.5 0 01-.5-.5v-1a.5.5 0 01.5-.5h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShortcuts);\n","import * as React from 'react';\nfunction IconShowAll(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 6a1.75 1.75 0 011.744 1.606L21 7.75V11h-1.5V7.75l-.007-.057a.25.25 0 00-.175-.184L19.25 7.5H7.75l-.057.007a.25.25 0 00-.184.175L7.5 7.75v11.5l.007.057a.25.25 0 00.175.184l.068.009H11V21H7.75a1.75 1.75 0 01-1.744-1.606L6 19.25V7.75a1.75 1.75 0 011.606-1.744L7.75 6h11.5zm-2-3l.102.007a.75.75 0 010 1.486l-.102.007H4.75l-.057.007a.25.25 0 00-.184.175L4.5 4.75v12.5l-.007.102a.75.75 0 01-1.486 0L3 17.25V4.75l.006-.144a1.75 1.75 0 011.593-1.6L4.75 3h12.5zm-2.5 8.75a3 3 0 100 6 3 3 0 000-6zm0 7.5a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowAll);\n","import * as React from 'react';\nfunction IconShowLess(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.75 4a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 013.75 4zm3.5 0a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 017.25 4zm7.78 3.97a.75.75 0 01.073.976l-.073.084-2.219 2.22h7.439a.75.75 0 01.102 1.493l-.102.007h-7.439l2.22 2.22a.75.75 0 01-.977 1.133l-.084-.073-3.5-3.5-.055-.06-.046-.065-.049-.088-.044-.12-.018-.089-.007-.143.019-.136.03-.098.047-.1.054-.082.069-.08 3.5-3.5a.75.75 0 011.06 0z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowLess);\n","import * as React from 'react';\nfunction IconShowMore(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.75 4a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 013.75 4zm3.5 0a.75.75 0 01.75.75v14.5a.75.75 0 11-1.5 0V4.75A.75.75 0 017.25 4zm3.5 0a.75.75 0 01.75.75v6.5h6.939l-2.22-2.22a.75.75 0 01.977-1.133l.084.073 3.5 3.5c.025.024.048.05.069.078l-.069-.078.04.042.04.052.068.114.038.098.02.084.012.088v.104l-.003.02-.006.055-.015.07-.024.072-.047.1-.032.051-.027.038-.064.072-3.5 3.5a.75.75 0 01-1.133-.976l.073-.084 2.219-2.22h-6.94l.001 6.5a.75.75 0 11-1.5 0V4.75a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowMore);\n","import * as React from 'react';\nfunction IconShowTemplate(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 18v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zm8.25-5.25a3 3 0 100 6 3 3 0 000-6zm-8.25 0v3.75H4v-3.75h1.5zM20 7.5v3.75h-1.5V7.5H20zm-14.5 0v3.75H4V7.5h1.5zM18.25 2c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5zm-.75 18.25a4.5 4.5 0 113.632-1.842l.036-.05 2.362 2.362a.75.75 0 01-.976 1.133l-.084-.073-2.363-2.362-.112.077a4.479 4.479 0 01-2.495.755z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconShowTemplate);\n","import * as React from 'react';\nfunction IconSliders(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M2.5 12.75H7a.75.75 0 110 1.5H5.5v7a.75.75 0 11-1.5 0v-7H2.5a.75.75 0 110-1.5zm9.5-2a.75.75 0 01.75.75v9.75a.75.75 0 11-1.5 0V11.5a.75.75 0 01.75-.75zm9.5 4a.75.75 0 110 1.5H20v5a.75.75 0 11-1.5 0v-5H17a.75.75 0 110-1.5h4.5zM19.25 2a.75.75 0 01.75.75v9.75a.75.75 0 11-1.5 0V2.75a.75.75 0 01.75-.75zM4.75 2a.75.75 0 01.75.75v7.75a.75.75 0 11-1.5 0V2.75A.75.75 0 014.75 2zM12 2a.75.75 0 01.75.75v5h1.5a.75.75 0 110 1.5h-4.5a.75.75 0 010-1.5h1.5v-5A.75.75 0 0112 2z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSliders);\n","import * as React from 'react';\nfunction IconSmartpay(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75V7.5h-5a5 5 0 00-4.995 4.783L11 12.5a5 5 0 004.783 4.995L16 17.5h5v1.75A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm1.5 6c.69 0 1.25.56 1.25 1.25v4.5c0 .69-.56 1.25-1.25 1.25H16a3.5 3.5 0 010-7h4.75zM16 11a1.5 1.5 0 100 3 1.5 1.5 0 000-3z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSmartpay);\n","import * as React from 'react';\nfunction IconSortBy(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.25 18a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm12.5-13.5a.75.75 0 01.743.648l.007.102v11.689l2.22-2.22a.75.75 0 011.133.977l-.073.084-3.5 3.5a.753.753 0 01-.125.101l-.088.049-.119.043-.106.021-.041.004-.07.002-.073-.006-.076-.013-.08-.023-.1-.043a.75.75 0 01-.182-.135l-3.5-3.5a.75.75 0 01.976-1.133l.084.073L17 16.939V5.25a.75.75 0 01.75-.75zm-9.5 9a.75.75 0 110 1.5h-5.5a.75.75 0 110-1.5h5.5zm3-4.5a.75.75 0 110 1.5h-8.5a.75.75 0 110-1.5h8.5zm3-4.5a.75.75 0 110 1.5H2.75a.75.75 0 010-1.5h11.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSortBy);\n","import * as React from 'react';\nfunction IconStarSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.895 8.726l-6.683.358-.105.012c-.608.114-.833.91-.328 1.319l5.197 4.217-1.725 6.467-.02.098c-.085.616.605 1.08 1.152.725L12 18.28l5.617 3.64.087.05c.56.27 1.214-.242 1.045-.872l-1.726-6.467 5.198-4.217.077-.072c.425-.45.14-1.225-.51-1.26l-6.684-.357L12.7 2.481a.75.75 0 00-1.4 0L8.895 8.726z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconStarSolid);\n","import * as React from 'react';\nfunction IconStar(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M8.895 8.726l-6.683.358-.105.012c-.608.114-.833.91-.328 1.319l5.197 4.217-1.725 6.467-.02.098c-.085.616.605 1.08 1.152.725L12 18.28l5.617 3.64.087.05c.56.27 1.214-.242 1.045-.872l-1.726-6.467 5.198-4.217.077-.072c.425-.45.14-1.225-.51-1.26l-6.684-.357L12.7 2.481a.75.75 0 00-1.4 0L8.895 8.726zM12 4.836l1.88 4.883.046.1a.75.75 0 00.614.38l5.223.278-4.062 3.297-.08.075a.75.75 0 00-.172.7l1.349 5.055-4.39-2.845-.096-.053a.75.75 0 00-.72.053l-4.391 2.845 1.35-5.054.02-.108a.75.75 0 00-.272-.668l-4.063-3.297 5.224-.278a.75.75 0 00.66-.48L12 4.836z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconStar);\n","import * as React from 'react';\nfunction IconSubscriptions(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18.25 2c.966 0 1.75.784 1.75 1.75v16.5A1.75 1.75 0 0118.25 22H13l-.001-1.5h5.251a.25.25 0 00.243-.193l.007-.057V3.75a.25.25 0 00-.193-.243L18.25 3.5H5.75a.25.25 0 00-.243.193L5.5 3.75 5.499 13H4V3.75C4 2.784 4.784 2 5.75 2h12.5zM4.142 16.956a.5.5 0 01.55-.147l.082.038 2.143 1.237.074.052a.5.5 0 01.147.55l-.038.081-.052.074a.5.5 0 01-.55.147l-.081-.038-.878-.505a2.5 2.5 0 004 1.525.75.75 0 11.925 1.181 4.002 4.002 0 01-6.343-2.173l-.402.695-.052.074a.5.5 0 01-.852-.492l.038-.082 1.238-2.143.051-.074zM8 14a4.001 4.001 0 013.92 3.197l.358-.62a.5.5 0 01.6-.221l.083.038a.5.5 0 01.22.601l-.037.082-1.238 2.143a.5.5 0 01-.6.221l-.083-.038-2.143-1.237a.5.5 0 01.418-.904l.082.038.914.528a2.5 2.5 0 00-4.033-1.798.75.75 0 11-.925-1.181A3.985 3.985 0 018 14zm7.75-1a.75.75 0 110 1.5h-2.5a.75.75 0 110-1.5h2.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 110-1.5h7.5zm0-3.5a.75.75 0 110 1.5h-7.5a.75.75 0 010-1.5h7.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSubscriptions);\n","import * as React from 'react';\nfunction IconSystemEntries(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.25 3c.966 0 1.75.784 1.75 1.75v14.5A1.75 1.75 0 0119.25 21H4.75A1.75 1.75 0 013 19.25V4.75C3 3.784 3.784 3 4.75 3h14.5zm.25 3h-15v13.25a.25.25 0 00.193.243l.057.007h14.5a.25.25 0 00.243-.193l.007-.057V6zm-8.75 9.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4zm-6.5-3.5a.75.75 0 110 1.5h-4a.75.75 0 010-1.5h4zm6.5 0a.75.75 0 110 1.5h-4a.75.75 0 110-1.5h4z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconSystemEntries);\n","import * as React from 'react';\nfunction IconTag(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10.356 2c.464 0 .909.184 1.237.513l9.92 9.919a1.75 1.75 0 010 2.475l-6.606 6.606a1.75 1.75 0 01-2.475 0l-9.92-9.92A1.75 1.75 0 012 10.356V3.75C2 2.784 2.784 2 3.75 2h6.606zm0 1.5H3.75a.25.25 0 00-.243.193L3.5 3.75v6.606a.25.25 0 00.033.125l.04.051 9.92 9.92a.25.25 0 00.3.04l.053-.04 6.606-6.606a.25.25 0 00.04-.3l-.04-.053-9.92-9.92a.25.25 0 00-.111-.064l-.065-.009zm1.57 5.394c.365-.007.652.086.852.287.256.255.225.645-.02.89-.215.215-.453.322-.78.366-.512.07-.826.211-1.13.515-.335.335-.335.742-.114.963.203.203.484.176.923-.106l.123-.084.715-.5c1.04-.729 1.934-.732 2.666 0 .809.809.81 1.956.044 3.041l-.12.163.155.155c.238.238.128.494-.02.642-.14.14-.364.246-.581.093l-.072-.062-.145-.145c-.615.532-1.285.857-1.858.87-.349.004-.642-.082-.85-.29-.306-.307-.244-.714.042-1 .145-.146.32-.24.605-.301l.151-.028c.529-.08.991-.293 1.271-.573.425-.425.46-.818.197-1.08-.193-.194-.473-.155-.963.148l-.139.09-.71.476c-1.05.711-1.938.694-2.677-.045-.789-.79-.783-1.929-.026-2.957l.12-.154-.204-.203c-.242-.242-.121-.494.03-.646.138-.137.353-.246.57-.09l.073.062.214.214c.546-.435 1.14-.704 1.657-.71zM6.042 6.043a1 1 0 111.414 1.414 1 1 0 01-1.414-1.414z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTag);\n","import * as React from 'react';\nfunction IconTemplateOverride(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM20 7.5v3.75h-1.5V7.5H20zM4 11.25V7.5h9.25a.75.75 0 01.75.75v2.25a.75.75 0 01-.75.75H4zM18.25 2c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTemplateOverride);\n","import * as React from 'react';\nfunction IconTemplates(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.5 20.5V22h-5v-1.5h5zm-9-2.5v2.25a.25.25 0 00.193.243l.057.007H8V22H5.75A1.75 1.75 0 014 20.25V18h1.5zM20 18v2.25A1.75 1.75 0 0118.25 22H16v-1.5h2.25a.25.25 0 00.243-.193l.007-.057V18H20zm0-5.25v3.75h-1.5v-3.75H20zm-14.5 0v3.75H4v-3.75h1.5zM12.25 14a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zm0-4a.75.75 0 110 1.5h-3.5a.75.75 0 110-1.5h3.5zM20 7.5v3.75h-1.5V7.5H20zm-14.5 0v3.75H4V7.5h1.5zM15.25 6a.75.75 0 110 1.5h-6.5a.75.75 0 010-1.5h6.5zm3-4c.966 0 1.75.784 1.75 1.75V6h-1.5V3.75a.25.25 0 00-.193-.243L18.25 3.5 16 3.499V2h2.25zM8 2v1.5H5.75a.25.25 0 00-.243.193L5.5 3.75V6H4V3.75C4 2.784 4.784 2 5.75 2H8zm6.5 0v1.499l-5 .001V2h5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTemplates);\n","import * as React from 'react';\nfunction IconThumbBoth(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M18 11.25a1.75 1.75 0 011.744 1.606l.006.144v4.586c0 .406-.141.797-.396 1.109l-.117.128-3.304 3.305a1.25 1.25 0 01-2.114-1.11l.032-.133.642-2.135H12.5a1.75 1.75 0 01-1.726-1.458l-.018-.148L10.75 17c0-.173.026-.345.076-.51l.059-.163 1.666-4a1.75 1.75 0 011.465-1.07l.15-.007H18zm0 1.5h-3.833a.25.25 0 00-.202.102l-.03.052-1.666 4a.25.25 0 00.174.34l.057.006h2.866a.85.85 0 01.838.99l-.024.104-.606 2.023 2.603-2.604a.25.25 0 00.064-.112l.009-.065V13a.25.25 0 00-.193-.243L18 12.75zm4-1.5c.513 0 .94.441.994 1.003l.006.122v4.5c0 .619-.45 1.125-1 1.125-.513 0-.94-.441-.994-1.003L21 16.875v-4.5c0-.619.45-1.125 1-1.125zM2 6c.513 0 .94.441.994 1.003L3 7.125v4.5c0 .619-.45 1.125-1 1.125-.513 0-.94-.441-.994-1.003L1 11.625v-4.5C1 6.506 1.45 6 2 6zm6.067-4.128a1.25 1.25 0 012.114 1.11l-.032.133-.642 2.135H11.5c.867 0 1.587.63 1.726 1.458l.018.148.006.144c0 .173-.026.345-.076.51l-.059.163-1.666 4a1.75 1.75 0 01-1.465 1.07l-.15.007H6a1.75 1.75 0 01-1.744-1.606L4.25 11V6.414c0-.406.141-.797.396-1.109l.117-.128 3.304-3.305zm.359 1.761L5.823 6.237a.25.25 0 00-.064.112l-.009.065V11a.25.25 0 00.193.243L6 11.25h3.833a.25.25 0 00.202-.102l.03-.052 1.666-4a.25.25 0 00-.174-.34L11.5 6.75H8.634c-.123-.006-.123-.006-.244-.036a.85.85 0 01-.594-.954l.024-.104.606-2.023z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbBoth);\n","import * as React from 'react';\nfunction IconThumbDownSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.839 4c.935 0 1.709.754 1.784 1.705l.006.152v9.277c0 .438-.149.86-.414 1.19l-.105.12-4.96 5.144a1.298 1.298 0 01-1.888.01 1.427 1.427 0 01-.389-1.118l.022-.155.85-4.253H4.687c-1.868 0-3.145-1.925-2.531-3.719l.06-.163 2.919-7.066c.266-.63.84-1.06 1.495-1.117L6.782 4h8.057zm5.37 0c.936 0 1.71.754 1.785 1.705l.006.152v7.43c0 1.02-.806 1.856-1.79 1.856-.936 0-1.71-.754-1.785-1.705l-.006-.152V5.857c0-1.021.806-1.857 1.79-1.857z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbDownSolid);\n","import * as React from 'react';\nfunction IconThumbDown(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.839 4c.935 0 1.709.754 1.784 1.705l.006.152v9.277c0 .438-.149.86-.414 1.19l-.105.12-4.96 5.144a1.298 1.298 0 01-1.888.01 1.427 1.427 0 01-.389-1.118l.022-.155.85-4.253H4.687c-1.868 0-3.145-1.925-2.531-3.719l.06-.163 2.919-7.066c.266-.63.84-1.06 1.495-1.117L6.782 4h8.057zm0 1.5H6.782a.284.284 0 00-.223.129l-.038.067-2.916 7.062c-.34.83.192 1.728.97 1.808l.112.006h6.888l-1.114 5.57 4.569-4.74a.373.373 0 00.092-.19l.007-.078V5.857c0-.18-.112-.318-.237-.35L14.84 5.5zm5.37-1.5c.936 0 1.71.754 1.785 1.705l.006.152v7.43c0 1.02-.806 1.856-1.79 1.856-.936 0-1.71-.754-1.785-1.705l-.006-.152V5.857c0-1.021.806-1.857 1.79-1.857z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbDown);\n","import * as React from 'react';\nfunction IconThumbUpSolid(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12.85 2.412a1.298 1.298 0 011.888-.01c.287.298.425.705.389 1.118l-.022.155-.85 4.253h5.058c1.868 0 3.145 1.925 2.531 3.719l-.06.163-2.919 7.066a1.811 1.811 0 01-1.495 1.117l-.152.007H9.161c-.935 0-1.709-.754-1.784-1.705l-.006-.152V8.866c0-.438.149-.86.414-1.19l.105-.12 4.96-5.144zM3.79 8.857c.936 0 1.71.754 1.785 1.705l.006.152v7.429C5.58 19.164 4.775 20 3.79 20c-.936 0-1.71-.754-1.785-1.705L2 18.143v-7.43c0-1.02.806-1.856 1.79-1.856z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbUpSolid);\n","import * as React from 'react';\nfunction IconThumbUp(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M14.738 2.403c.287.297.425.704.389 1.117l-.022.155-.85 4.253h5.058c1.868 0 3.145 1.925 2.531 3.719l-.06.163-2.919 7.066a1.811 1.811 0 01-1.495 1.117l-.152.007H9.161c-.935 0-1.709-.754-1.784-1.705l-.006-.152V8.866c0-.438.149-.86.414-1.19l.105-.12 4.96-5.144a1.298 1.298 0 011.888-.01zM3.79 8.857c.936 0 1.71.754 1.785 1.705l.006.152v7.429C5.58 19.164 4.775 20 3.79 20c-.936 0-1.71-.754-1.785-1.705L2 18.143v-7.43c0-1.02.806-1.856 1.79-1.856zm9.749-4.999L8.97 8.598a.373.373 0 00-.092.19l-.007.078v9.277c0 .18.112.318.237.35l.053.007h8.057c.08 0 .166-.047.223-.129l.038-.067 2.916-7.062c.34-.83-.192-1.728-.97-1.808l-.112-.006h-6.888l1.114-5.57z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconThumbUp);\n","import * as React from 'react';\nfunction IconTick(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.867 6.097a.75.75 0 011.318.708l-.052.098-7 11a.75.75 0 01-1.145.145l-.074-.08-4-5A.75.75 0 017.01 11.95l.076.081 3.344 4.181 6.437-10.115z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTick);\n","import * as React from 'react';\nfunction IconTime(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M16.5 16c2.434 0 3.88 1.316 4.34 3.95A1.75 1.75 0 0119.116 22h-5.232a1.75 1.75 0 01-1.724-2.05c.46-2.634 1.906-3.95 4.34-3.95zM12 2c5.523 0 10 4.477 10 10a9.96 9.96 0 01-1.005 4.374 5.097 5.097 0 00-1.182-1.017A8.488 8.488 0 0020.5 12a8.5 8.5 0 10-9.996 8.369c.02.578.196 1.118.487 1.58C5.942 21.444 2 17.183 2 12 2 6.477 6.477 2 12 2zm4.5 8.5c1.105 0 2 1.12 2 2.5s-.895 2.5-2 2.5-2-1.12-2-2.5.895-2.5 2-2.5zM12 5.25a.75.75 0 01.743.648L12.75 6v6a.75.75 0 01-.648.743L12 12.75H7.5a.75.75 0 01-.102-1.493l.102-.007h3.75V6a.75.75 0 01.75-.75z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTime);\n","import * as React from 'react';\nfunction IconTransferCancel(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n d=\"M18.804 15.647a.75.75 0 011.049 1.05l-.073.083-1.969 1.97 1.97 1.97a.75.75 0 01-.977 1.133l-.084-.073-1.97-1.969-1.97 1.97-.084.072a.75.75 0 01-1.049-1.05l.073-.083 1.969-1.97-1.97-1.97a.75.75 0 01.977-1.133l.084.073 1.97 1.969 1.97-1.97.084-.072z\"\n fill=\"#CF3C16\"\n fillRule=\"nonzero\"\n />\n <path\n d=\"M5.5 16.5v3.75a.25.25 0 00.193.243l.057.007H12V22H5.75A1.75 1.75 0 014 20.25V16.5h1.5zm2.946-6.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V14h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm.914 2.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n />\n </g>\n </svg>\n );\n}\nexport default React.forwardRef(IconTransferCancel);\n","import * as React from 'react';\nfunction IconTransferLocked(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M5.5 16.5v3.75a.25.25 0 00.193.243l.057.007h4.75V22H5.75A1.75 1.75 0 014 20.25V16.5h1.5zM16 12a3 3 0 013 3v1a1 1 0 011 1v4a1 1 0 01-1 1h-6a1 1 0 01-1-1v-4a1 1 0 011-1v-1a3 3 0 013-3zm0 5.5a1 1 0 00-.5 1.866V20a.5.5 0 00.992.09L16.5 20l.001-.634A1 1 0 0016 17.5zm-7.554-7.103l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM16 13.5a1.5 1.5 0 00-1.493 1.356L14.5 15v1h3v-1a1.5 1.5 0 00-1.356-1.493L16 13.5zM13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V11.5h-1.5V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm.914 2.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTransferLocked);\n","import * as React from 'react';\nfunction IconTransfer(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M13.586 2a1 1 0 01.707.293l5.414 5.414a1 1 0 01.293.707V20.25A1.75 1.75 0 0118.25 22H5.75A1.75 1.75 0 014 20.25V16.5h1.5v3.75a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V9h-3.75a1.75 1.75 0 01-1.744-1.606L13 7.25V3.5H5.75a.25.25 0 00-.243.193L5.5 3.75v7.75H4V3.75C4 2.784 4.784 2 5.75 2h7.836zm-5.14 8.397l.084.073 3 3a.75.75 0 01.073.976l-.073.084-3 3a.75.75 0 01-1.133-.976l.073-.084 1.719-1.72H2.75a.75.75 0 01-.102-1.493l.102-.007h6.439l-1.72-1.72a.75.75 0 01-.072-.976l.073-.084a.75.75 0 01.976-.073zM14.5 4.621V7.25a.25.25 0 00.193.243l.057.007h2.63L14.5 4.621z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconTransfer);\n","import * as React from 'react';\nfunction IconUndo(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path d=\"M6.75 4.75l-4 4 4 4\" stroke=\"currentColor\" strokeWidth={1.5} strokeLinecap=\"round\" strokeLinejoin=\"round\" />\n <path\n d=\"M3 8.75h13c2.9 0 5.25 2.35 5.25 5.25v0c0 2.9-2.35 5.25-5.25 5.25h-5.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUndo);\n","import * as React from 'react';\nfunction IconUndock(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M12 5v1.5H4.75a.25.25 0 00-.243.193L4.5 6.75v12.5a.25.25 0 00.193.243l.057.007h12.5a.25.25 0 00.243-.193l.007-.057V12H19v7.25A1.75 1.75 0 0117.25 21H4.75A1.75 1.75 0 013 19.25V6.75C3 5.784 3.784 5 4.75 5H12zm8.25-2a.75.75 0 01.743.648L21 3.75v4.5a.75.75 0 01-1.493.102L19.5 8.25V5.56l-4.97 4.97a.75.75 0 01-1.133-.976l.073-.084 4.968-4.97H15.75a.75.75 0 01-.743-.648L15 3.75a.75.75 0 01.648-.743L15.75 3h4.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUndock);\n","import * as React from 'react';\nfunction IconUnreconciled(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M3.368 4.346l.092.062 18 14a.75.75 0 01-.828 1.246l-.092-.062-3.34-2.597L17 17h-2.5a.75.75 0 01-.102-1.493l.102-.007h.778l-3.536-2.75H7a.75.75 0 110-1.5h2.814l-3.46-2.69a3.501 3.501 0 00.454 6.935L7 15.5h2.5a.75.75 0 01.102 1.493L9.5 17H7a5 5 0 01-2.074-9.55L2.54 5.591a.75.75 0 01.828-1.246zM17 7a5 5 0 013.39 8.676l-1.208-.94a3.5 3.5 0 00-1.99-6.231L17 8.5h-2.5a.75.75 0 01-.102-1.493L14.5 7H17zm0 4.25a.75.75 0 110 1.5h-.372l-1.929-1.5H17z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconUnreconciled);\n","import * as React from 'react';\nfunction IconWarning(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M9.527 17.197c.157-.827.938-1.344 1.771-1.177a1.515 1.515 0 011.213 1.772c-.157.826-.939 1.343-1.771 1.177a1.515 1.515 0 01-1.213-1.772zm2.265-11.05c.164-.863.784-1.276 1.607-1.112.815.163 1.23.782 1.066 1.646l-.038.183-.025.097-1.368 6.473c-.179.793-.67 1.182-1.43 1.03-.712-.142-1.032-.634-.96-1.356l.02-.147 1.1-6.628.028-.185z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWarning);\n","import * as React from 'react';\nfunction IconWebshop(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M11 15.5a2.25 2.25 0 110 4.5 2.25 2.25 0 010-4.5zm5.831 0a2.25 2.25 0 110 4.5 2.25 2.25 0 010-4.5zM11 17a.75.75 0 100 1.5.75.75 0 000-1.5zm5.831 0a.75.75 0 100 1.5.75.75 0 000-1.5zM5.287 4a1.75 1.75 0 011.56.955l.062.138 3.24 8a.25.25 0 00.173.15l.06.007h7.743a.25.25 0 00.204-.105l.028-.054 2.159-5.496a.25.25 0 00-.141-.324l-.045-.013-.047-.005-10.04-.003a.75.75 0 01-.102-1.493l.102-.007 10.04.003A1.75 1.75 0 0121.962 8l-.049.143-2.158 5.497a1.75 1.75 0 01-1.476 1.103l-.153.007h-7.743a1.75 1.75 0 01-1.56-.955l-.062-.138-3.24-8a.25.25 0 00-.173-.15l-.06-.007H2.75a.75.75 0 01-.102-1.493L2.75 4h2.537z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWebshop);\n","import * as React from 'react';\nfunction IconWebsite(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M20.25 4c.966 0 1.75.784 1.75 1.75v12.5A1.75 1.75 0 0120.25 20H3.75A1.75 1.75 0 012 18.25V5.75C2 4.784 2.784 4 3.75 4h16.5zm.25 6h-17v8.25a.25.25 0 00.193.243l.057.007h16.5a.25.25 0 00.243-.193l.007-.057V10zm-.25-4.5H3.75a.25.25 0 00-.243.193L3.5 5.75V8.5h17V5.75a.25.25 0 00-.193-.243L20.25 5.5zM5.5 6.5v1h-1v-1h1zm2 0v1h-1v-1h1zm2 0v1h-1v-1h1z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWebsite);\n","import * as React from 'react';\nfunction IconWorkflow(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M19.144 16.292a2.853 2.853 0 00-2.754 2.144H7.722a2.857 2.857 0 01-2.856-2.858 2.857 2.857 0 012.856-2.859h1.53a2.842 2.842 0 005.508 0h1.529a4.286 4.286 0 004.283-4.287 4.286 4.286 0 00-4.283-4.288H7.62A2.856 2.856 0 002 4.859a2.856 2.856 0 005.62.715h8.669a2.857 2.857 0 012.855 2.858 2.857 2.857 0 01-2.855 2.858h-1.53a2.842 2.842 0 00-5.508 0h-1.53a4.286 4.286 0 00-4.283 4.288 4.286 4.286 0 004.284 4.287h8.668a2.85 2.85 0 005.6-.964 2.852 2.852 0 00-2.846-2.609zM4.866 6.288a1.429 1.429 0 11.002-2.857 1.429 1.429 0 01-.002 2.857zm7.14 4.287a1.429 1.429 0 11-.002 2.857 1.429 1.429 0 01.001-2.857zm7.138 10.005a1.429 1.429 0 11.002-2.857 1.429 1.429 0 01-.002 2.857z\"\n fill=\"currentColor\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconWorkflow);\n","import * as React from 'react';\nfunction IconZoom(props: React.SVGProps<SVGSVGElement>, svgRef?: React.Ref<SVGSVGElement>): JSX.Element {\n return (\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" ref={svgRef} {...props}>\n <path\n d=\"M10 2.25a7.75 7.75 0 015.985 12.674l5.545 5.546a.75.75 0 01-.976 1.133l-.084-.073-5.546-5.545A7.75 7.75 0 1110 2.25zm0 1.5a6.25 6.25 0 100 12.5 6.25 6.25 0 000-12.5zm0 2.75a.75.75 0 01.75.75v2h2a.75.75 0 110 1.5h-2v2a.75.75 0 11-1.5 0v-2h-2a.75.75 0 110-1.5h2v-2A.75.75 0 0110 6.5z\"\n fill=\"currentColor\"\n fillRule=\"evenodd\"\n />\n </svg>\n );\n}\nexport default React.forwardRef(IconZoom);\n","import AccountPreview from './AccountPreview';\nimport AccountingYearCancel from './AccountingYearCancel';\nimport AccountingYear from './AccountingYear';\nimport Accounting from './Accounting';\nimport ArrowBottom from './ArrowBottom';\nimport ArrowDown from './ArrowDown';\nimport ArrowEnd from './ArrowEnd';\nimport ArrowLeft from './ArrowLeft';\nimport ArrowRight from './ArrowRight';\nimport ArrowStart from './ArrowStart';\nimport ArrowTop from './ArrowTop';\nimport ArrowUp from './ArrowUp';\nimport AttachAuto from './AttachAuto';\nimport AttachCancel from './AttachCancel';\nimport Attach from './Attach';\nimport AutotextInsert from './AutotextInsert';\nimport Autotext from './Autotext';\nimport BasicTabs from './BasicTabs';\nimport Basic from './Basic';\nimport BellSolid from './BellSolid';\nimport Book from './Book';\nimport Booking from './Booking';\nimport Budget from './Budget';\nimport Calendar from './Calendar';\nimport CashAccount from './CashAccount';\nimport CashReports from './CashReports';\nimport ChatSolid from './ChatSolid';\nimport Chat from './Chat';\nimport ChevronDownDouble from './ChevronDownDouble';\nimport ChevronDownSolid from './ChevronDownSolid';\nimport ChevronDown from './ChevronDown';\nimport ChevronLeftDouble from './ChevronLeftDouble';\nimport ChevronLeftSolid from './ChevronLeftSolid';\nimport ChevronLeft from './ChevronLeft';\nimport ChevronRightDouble from './ChevronRightDouble';\nimport ChevronRightSolid from './ChevronRightSolid';\nimport ChevronRight from './ChevronRight';\nimport ChevronUpDouble from './ChevronUpDouble';\nimport ChevronUpSolid from './ChevronUpSolid';\nimport ChevronUp from './ChevronUp';\nimport CircleClose from './CircleClose';\nimport CircleMinus from './CircleMinus';\nimport CirclePlus from './CirclePlus';\nimport CircleTick from './CircleTick';\nimport ClampOpen from './ClampOpen';\nimport Clamp from './Clamp';\nimport Close from './Close';\nimport ConnectionEnable from './ConnectionEnable';\nimport ConnectionRevoke from './ConnectionRevoke';\nimport Contacts from './Contacts';\nimport Copy from './Copy';\nimport Courses from './Courses';\nimport Credit from './Credit';\nimport DeletePermanently from './DeletePermanently';\nimport Delete from './Delete';\nimport Depecriate from './Depecriate';\nimport Developer from './Developer';\nimport DistributionTemplate from './DistributionTemplate';\nimport DocumentApprove from './DocumentApprove';\nimport DocumentCreateEntry from './DocumentCreateEntry';\nimport DocumentCut from './DocumentCut';\nimport DocumentError from './DocumentError';\nimport DocumentIsolatePage from './DocumentIsolatePage';\nimport DocumentMerge from './DocumentMerge';\nimport DocumentMove from './DocumentMove';\nimport DocumentPreview from './DocumentPreview';\nimport DocumentReceived from './DocumentReceived';\nimport DocumentRejectedRequest from './DocumentRejectedRequest';\nimport DocumentSplit from './DocumentSplit';\nimport DocumentTime from './DocumentTime';\nimport Document from './Document';\nimport Download from './Download';\nimport Drag from './Drag';\nimport ECopedia from './ECopedia';\nimport ESignature from './ESignature';\nimport Edit from './Edit';\nimport EllipsisHorizontal from './EllipsisHorizontal';\nimport EllipsisVertical from './EllipsisVertical';\nimport EntriesOnAccount from './EntriesOnAccount';\nimport EntriesOpen from './EntriesOpen';\nimport EntriesWarning from './EntriesWarning';\nimport EntryTypeCustomerInvoice from './EntryTypeCustomerInvoice';\nimport EntryTypeCustomerPayment from './EntryTypeCustomerPayment';\nimport EntryTypeJournalEntry from './EntryTypeJournalEntry';\nimport EntryTypeManualCustomerInvoice from './EntryTypeManualCustomerInvoice';\nimport EntryTypeSupplierInvoice from './EntryTypeSupplierInvoice';\nimport EntryTypeSupplierPayment from './EntryTypeSupplierPayment';\nimport EnvelopeApproved from './EnvelopeApproved';\nimport Envelope from './Envelope';\nimport ExpandView from './ExpandView';\nimport Expenses from './Expenses';\nimport ExportToExcel from './ExportToExcel';\nimport ExportToPdf from './ExportToPdf';\nimport Export from './Export';\nimport FilterSolid from './FilterSolid';\nimport Filter from './Filter';\nimport GraphSolid from './GraphSolid';\nimport Hash from './Hash';\nimport Home from './Home';\nimport Images from './Images';\nimport Import from './Import';\nimport InboxEinvoicing from './InboxEinvoicing';\nimport InboxScanning from './InboxScanning';\nimport InboxSmart from './InboxSmart';\nimport Inbox from './Inbox';\nimport Info from './Info';\nimport InventoryMatrix from './InventoryMatrix';\nimport Inventory from './Inventory';\nimport JournalPro from './JournalPro';\nimport LayoutBoth from './LayoutBoth';\nimport LayoutFirst from './LayoutFirst';\nimport LayoutLast from './LayoutLast';\nimport LayoutNone from './LayoutNone';\nimport Layout from './Layout';\nimport LedgerCardCustomerReminder from './LedgerCardCustomerReminder';\nimport LedgerCardManualCustomerInvoice from './LedgerCardManualCustomerInvoice';\nimport LedgerCardObsoleteStock from './LedgerCardObsoleteStock';\nimport LedgerCardOpeningEntry from './LedgerCardOpeningEntry';\nimport LedgerCardReservedEntry from './LedgerCardReservedEntry';\nimport LedgerCardShrinkagePilferage from './LedgerCardShrinkagePilferage';\nimport LedgerCardStockAdjustment from './LedgerCardStockAdjustment';\nimport LedgerCardTransferredOpeningEntry from './LedgerCardTransferredOpeningEntry';\nimport LedgerCard from './LedgerCard';\nimport Lightbulb from './Lightbulb';\nimport Line from './Line';\nimport ListBulleted from './ListBulleted';\nimport ListSearch from './ListSearch';\nimport List from './List';\nimport LockOpen from './LockOpen';\nimport LogOut from './LogOut';\nimport Log from './Log';\nimport Market from './Market';\nimport MatchAmount from './MatchAmount';\nimport MatchEntries from './MatchEntries';\nimport Menu from './Menu';\nimport Mileage from './Mileage';\nimport ModalResize from './ModalResize';\nimport ModalShrink from './ModalShrink';\nimport MoreSolid from './MoreSolid';\nimport More from './More';\nimport Move from './Move';\nimport NavigationList from './NavigationList';\nimport NoteFollowUp from './NoteFollowUp';\nimport NoteRead from './NoteRead';\nimport Note from './Note';\nimport Numbers from './Numbers';\nimport PartnerApi from './PartnerApi';\nimport Period from './Period';\nimport PersonChange from './PersonChange';\nimport PersonMinus from './PersonMinus';\nimport PersonPlus from './PersonPlus';\nimport PersonTick from './PersonTick';\nimport Play from './Play';\nimport PlusMinus from './PlusMinus';\nimport Print from './Print';\nimport ProcessPayment from './ProcessPayment';\nimport ProductLedgerCard from './ProductLedgerCard';\nimport Profile from './Profile';\nimport ProjectCards from './ProjectCards';\nimport Projects from './Projects';\nimport Quicklinks from './Quicklinks';\nimport RatingBankruptcy from './RatingBankruptcy';\nimport RatingPaymentProblems from './RatingPaymentProblems';\nimport Reconciled from './Reconciled';\nimport Refresh from './Refresh';\nimport ReportSolid from './ReportSolid';\nimport Report from './Report';\nimport Restore from './Restore';\nimport RotateLeft from './RotateLeft';\nimport RotateRight from './RotateRight';\nimport Sales from './Sales';\nimport SearchBold from './SearchBold';\nimport Search from './Search';\nimport SecureTick from './SecureTick';\nimport Secure from './Secure';\nimport SettingsSolid from './SettingsSolid';\nimport Settings from './Settings';\nimport Shortcuts from './Shortcuts';\nimport ShowAll from './ShowAll';\nimport ShowLess from './ShowLess';\nimport ShowMore from './ShowMore';\nimport ShowTemplate from './ShowTemplate';\nimport Sliders from './Sliders';\nimport Smartpay from './Smartpay';\nimport SortBy from './SortBy';\nimport StarSolid from './StarSolid';\nimport Star from './Star';\nimport Subscriptions from './Subscriptions';\nimport SystemEntries from './SystemEntries';\nimport Tag from './Tag';\nimport TemplateOverride from './TemplateOverride';\nimport Templates from './Templates';\nimport ThumbBoth from './ThumbBoth';\nimport ThumbDownSolid from './ThumbDownSolid';\nimport ThumbDown from './ThumbDown';\nimport ThumbUpSolid from './ThumbUpSolid';\nimport ThumbUp from './ThumbUp';\nimport Tick from './Tick';\nimport Time from './Time';\nimport TransferCancel from './TransferCancel';\nimport TransferLocked from './TransferLocked';\nimport Transfer from './Transfer';\nimport Undo from './Undo';\nimport Undock from './Undock';\nimport Unreconciled from './Unreconciled';\nimport Warning from './Warning';\nimport Webshop from './Webshop';\nimport Website from './Website';\nimport Workflow from './Workflow';\nimport Zoom from './Zoom';\n\nexport const icons: Record<\n IconName,\n React.ForwardRefExoticComponent<React.SVGAttributes<SVGSVGElement> & React.RefAttributes<SVGSVGElement>>\n> = {\n 'account-preview': AccountPreview,\n 'accounting-year-cancel': AccountingYearCancel,\n 'accounting-year': AccountingYear,\n accounting: Accounting,\n 'arrow-bottom': ArrowBottom,\n 'arrow-down': ArrowDown,\n 'arrow-end': ArrowEnd,\n 'arrow-left': ArrowLeft,\n 'arrow-right': ArrowRight,\n 'arrow-start': ArrowStart,\n 'arrow-top': ArrowTop,\n 'arrow-up': ArrowUp,\n 'attach-auto': AttachAuto,\n 'attach-cancel': AttachCancel,\n attach: Attach,\n 'autotext-insert': AutotextInsert,\n autotext: Autotext,\n 'basic-tabs': BasicTabs,\n basic: Basic,\n 'bell-solid': BellSolid,\n book: Book,\n booking: Booking,\n budget: Budget,\n calendar: Calendar,\n 'cash-account': CashAccount,\n 'cash-reports': CashReports,\n 'chat-solid': ChatSolid,\n chat: Chat,\n 'chevron-down-double': ChevronDownDouble,\n 'chevron-down-solid': ChevronDownSolid,\n 'chevron-down': ChevronDown,\n 'chevron-left-double': ChevronLeftDouble,\n 'chevron-left-solid': ChevronLeftSolid,\n 'chevron-left': ChevronLeft,\n 'chevron-right-double': ChevronRightDouble,\n 'chevron-right-solid': ChevronRightSolid,\n 'chevron-right': ChevronRight,\n 'chevron-up-double': ChevronUpDouble,\n 'chevron-up-solid': ChevronUpSolid,\n 'chevron-up': ChevronUp,\n 'circle-close': CircleClose,\n 'circle-minus': CircleMinus,\n 'circle-plus': CirclePlus,\n 'circle-tick': CircleTick,\n 'clamp-open': ClampOpen,\n clamp: Clamp,\n close: Close,\n 'connection-enable': ConnectionEnable,\n 'connection-revoke': ConnectionRevoke,\n contacts: Contacts,\n copy: Copy,\n courses: Courses,\n credit: Credit,\n 'delete-permanently': DeletePermanently,\n delete: Delete,\n depecriate: Depecriate,\n developer: Developer,\n 'distribution-template': DistributionTemplate,\n 'document-approve': DocumentApprove,\n 'document-create-entry': DocumentCreateEntry,\n 'document-cut': DocumentCut,\n 'document-error': DocumentError,\n 'document-isolate-page': DocumentIsolatePage,\n 'document-merge': DocumentMerge,\n 'document-move': DocumentMove,\n 'document-preview': DocumentPreview,\n 'document-received': DocumentReceived,\n 'document-rejected-request': DocumentRejectedRequest,\n 'document-split': DocumentSplit,\n 'document-time': DocumentTime,\n document: Document,\n download: Download,\n drag: Drag,\n 'e-copedia': ECopedia,\n 'e-signature': ESignature,\n edit: Edit,\n 'ellipsis-horizontal': EllipsisHorizontal,\n 'ellipsis-vertical': EllipsisVertical,\n 'entries-on-account': EntriesOnAccount,\n 'entries-open': EntriesOpen,\n 'entries-warning': EntriesWarning,\n 'entry-type-customer-invoice': EntryTypeCustomerInvoice,\n 'entry-type-customer-payment': EntryTypeCustomerPayment,\n 'entry-type-journal-entry': EntryTypeJournalEntry,\n 'entry-type-manual-customer-invoice': EntryTypeManualCustomerInvoice,\n 'entry-type-supplier-invoice': EntryTypeSupplierInvoice,\n 'entry-type-supplier-payment': EntryTypeSupplierPayment,\n 'envelope-approved': EnvelopeApproved,\n envelope: Envelope,\n 'expand-view': ExpandView,\n expenses: Expenses,\n 'export-to-excel': ExportToExcel,\n 'export-to-pdf': ExportToPdf,\n export: Export,\n 'filter-solid': FilterSolid,\n filter: Filter,\n 'graph-solid': GraphSolid,\n hash: Hash,\n home: Home,\n images: Images,\n import: Import,\n 'inbox-einvoicing': InboxEinvoicing,\n 'inbox-scanning': InboxScanning,\n 'inbox-smart': InboxSmart,\n inbox: Inbox,\n info: Info,\n 'inventory-matrix': InventoryMatrix,\n inventory: Inventory,\n 'journal-pro': JournalPro,\n 'layout-both': LayoutBoth,\n 'layout-first': LayoutFirst,\n 'layout-last': LayoutLast,\n 'layout-none': LayoutNone,\n layout: Layout,\n 'ledger-card-customer-reminder': LedgerCardCustomerReminder,\n 'ledger-card-manual-customer-invoice': LedgerCardManualCustomerInvoice,\n 'ledger-card-obsolete-stock': LedgerCardObsoleteStock,\n 'ledger-card-opening-entry': LedgerCardOpeningEntry,\n 'ledger-card-reserved-entry': LedgerCardReservedEntry,\n 'ledger-card-shrinkage-pilferage': LedgerCardShrinkagePilferage,\n 'ledger-card-stock-adjustment': LedgerCardStockAdjustment,\n 'ledger-card-transferred-opening-entry': LedgerCardTransferredOpeningEntry,\n 'ledger-card': LedgerCard,\n lightbulb: Lightbulb,\n line: Line,\n 'list-bulleted': ListBulleted,\n 'list-search': ListSearch,\n list: List,\n 'lock-open': LockOpen,\n 'log-out': LogOut,\n log: Log,\n market: Market,\n 'match-amount': MatchAmount,\n 'match-entries': MatchEntries,\n menu: Menu,\n mileage: Mileage,\n 'modal-resize': ModalResize,\n 'modal-shrink': ModalShrink,\n 'more-solid': MoreSolid,\n more: More,\n move: Move,\n 'navigation-list': NavigationList,\n 'note-follow-up': NoteFollowUp,\n 'note-read': NoteRead,\n note: Note,\n numbers: Numbers,\n 'partner-api': PartnerApi,\n period: Period,\n 'person-change': PersonChange,\n 'person-minus': PersonMinus,\n 'person-plus': PersonPlus,\n 'person-tick': PersonTick,\n play: Play,\n 'plus-minus': PlusMinus,\n print: Print,\n 'process-payment': ProcessPayment,\n 'product-ledger-card': ProductLedgerCard,\n profile: Profile,\n 'project-cards': ProjectCards,\n projects: Projects,\n quicklinks: Quicklinks,\n 'rating-bankruptcy': RatingBankruptcy,\n 'rating-payment-problems': RatingPaymentProblems,\n reconciled: Reconciled,\n refresh: Refresh,\n 'report-solid': ReportSolid,\n report: Report,\n restore: Restore,\n 'rotate-left': RotateLeft,\n 'rotate-right': RotateRight,\n sales: Sales,\n 'search-bold': SearchBold,\n search: Search,\n 'secure-tick': SecureTick,\n secure: Secure,\n 'settings-solid': SettingsSolid,\n settings: Settings,\n shortcuts: Shortcuts,\n 'show-all': ShowAll,\n 'show-less': ShowLess,\n 'show-more': ShowMore,\n 'show-template': ShowTemplate,\n sliders: Sliders,\n smartpay: Smartpay,\n 'sort-by': SortBy,\n 'star-solid': StarSolid,\n star: Star,\n subscriptions: Subscriptions,\n 'system-entries': SystemEntries,\n tag: Tag,\n 'template-override': TemplateOverride,\n templates: Templates,\n 'thumb-both': ThumbBoth,\n 'thumb-down-solid': ThumbDownSolid,\n 'thumb-down': ThumbDown,\n 'thumb-up-solid': ThumbUpSolid,\n 'thumb-up': ThumbUp,\n tick: Tick,\n time: Time,\n 'transfer-cancel': TransferCancel,\n 'transfer-locked': TransferLocked,\n transfer: Transfer,\n undo: Undo,\n undock: Undock,\n unreconciled: Unreconciled,\n warning: Warning,\n webshop: Webshop,\n website: Website,\n workflow: Workflow,\n zoom: Zoom,\n};\n\n// the prop extraction tool can't handle this\n//export type IconName = keyof typeof icons;\nexport type IconName =\n | 'account-preview'\n | 'accounting-year-cancel'\n | 'accounting-year'\n | 'accounting'\n | 'arrow-bottom'\n | 'arrow-down'\n | 'arrow-end'\n | 'arrow-left'\n | 'arrow-right'\n | 'arrow-start'\n | 'arrow-top'\n | 'arrow-up'\n | 'attach-auto'\n | 'attach-cancel'\n | 'attach'\n | 'autotext-insert'\n | 'autotext'\n | 'basic-tabs'\n | 'basic'\n | 'bell-solid'\n | 'book'\n | 'booking'\n | 'budget'\n | 'calendar'\n | 'cash-account'\n | 'cash-reports'\n | 'chat-solid'\n | 'chat'\n | 'chevron-down-double'\n | 'chevron-down-solid'\n | 'chevron-down'\n | 'chevron-left-double'\n | 'chevron-left-solid'\n | 'chevron-left'\n | 'chevron-right-double'\n | 'chevron-right-solid'\n | 'chevron-right'\n | 'chevron-up-double'\n | 'chevron-up-solid'\n | 'chevron-up'\n | 'circle-close'\n | 'circle-minus'\n | 'circle-plus'\n | 'circle-tick'\n | 'clamp-open'\n | 'clamp'\n | 'close'\n | 'connection-enable'\n | 'connection-revoke'\n | 'contacts'\n | 'copy'\n | 'courses'\n | 'credit'\n | 'delete-permanently'\n | 'delete'\n | 'depecriate'\n | 'developer'\n | 'distribution-template'\n | 'document-approve'\n | 'document-create-entry'\n | 'document-cut'\n | 'document-error'\n | 'document-isolate-page'\n | 'document-merge'\n | 'document-move'\n | 'document-preview'\n | 'document-received'\n | 'document-rejected-request'\n | 'document-split'\n | 'document-time'\n | 'document'\n | 'download'\n | 'drag'\n | 'e-copedia'\n | 'e-signature'\n | 'edit'\n | 'ellipsis-horizontal'\n | 'ellipsis-vertical'\n | 'entries-on-account'\n | 'entries-open'\n | 'entries-warning'\n | 'entry-type-customer-invoice'\n | 'entry-type-customer-payment'\n | 'entry-type-journal-entry'\n | 'entry-type-manual-customer-invoice'\n | 'entry-type-supplier-invoice'\n | 'entry-type-supplier-payment'\n | 'envelope-approved'\n | 'envelope'\n | 'expand-view'\n | 'expenses'\n | 'export-to-excel'\n | 'export-to-pdf'\n | 'export'\n | 'filter-solid'\n | 'filter'\n | 'graph-solid'\n | 'hash'\n | 'home'\n | 'images'\n | 'import'\n | 'inbox-einvoicing'\n | 'inbox-scanning'\n | 'inbox-smart'\n | 'inbox'\n | 'info'\n | 'inventory-matrix'\n | 'inventory'\n | 'journal-pro'\n | 'layout-both'\n | 'layout-first'\n | 'layout-last'\n | 'layout-none'\n | 'layout'\n | 'ledger-card-customer-reminder'\n | 'ledger-card-manual-customer-invoice'\n | 'ledger-card-obsolete-stock'\n | 'ledger-card-opening-entry'\n | 'ledger-card-reserved-entry'\n | 'ledger-card-shrinkage-pilferage'\n | 'ledger-card-stock-adjustment'\n | 'ledger-card-transferred-opening-entry'\n | 'ledger-card'\n | 'lightbulb'\n | 'line'\n | 'list-bulleted'\n | 'list-search'\n | 'list'\n | 'lock-open'\n | 'log-out'\n | 'log'\n | 'market'\n | 'match-amount'\n | 'match-entries'\n | 'menu'\n | 'mileage'\n | 'modal-resize'\n | 'modal-shrink'\n | 'more-solid'\n | 'more'\n | 'move'\n | 'navigation-list'\n | 'note-follow-up'\n | 'note-read'\n | 'note'\n | 'numbers'\n | 'partner-api'\n | 'period'\n | 'person-change'\n | 'person-minus'\n | 'person-plus'\n | 'person-tick'\n | 'play'\n | 'plus-minus'\n | 'print'\n | 'process-payment'\n | 'product-ledger-card'\n | 'profile'\n | 'project-cards'\n | 'projects'\n | 'quicklinks'\n | 'rating-bankruptcy'\n | 'rating-payment-problems'\n | 'reconciled'\n | 'refresh'\n | 'report-solid'\n | 'report'\n | 'restore'\n | 'rotate-left'\n | 'rotate-right'\n | 'sales'\n | 'search-bold'\n | 'search'\n | 'secure-tick'\n | 'secure'\n | 'settings-solid'\n | 'settings'\n | 'shortcuts'\n | 'show-all'\n | 'show-less'\n | 'show-more'\n | 'show-template'\n | 'sliders'\n | 'smartpay'\n | 'sort-by'\n | 'star-solid'\n | 'star'\n | 'subscriptions'\n | 'system-entries'\n | 'tag'\n | 'template-override'\n | 'templates'\n | 'thumb-both'\n | 'thumb-down-solid'\n | 'thumb-down'\n | 'thumb-up-solid'\n | 'thumb-up'\n | 'tick'\n | 'time'\n | 'transfer-cancel'\n | 'transfer-locked'\n | 'transfer'\n | 'undo'\n | 'undock'\n | 'unreconciled'\n | 'warning'\n | 'webshop'\n | 'website'\n | 'workflow'\n | 'zoom';\n","import React from 'react';\nimport cn from 'classnames';\nimport { IconName, icons } from './components/index';\n\nexport { icons } from './components/index';\nexport type { IconName } from './components/index';\n\nexport type IconProps = React.SVGAttributes<SVGSVGElement> & {\n /** Set what svg icon should be rendered */\n name: IconName; // this dynamic type causes the type extraction for props to fail\n};\n\nexport const Icon = React.forwardRef(function Icon(props: IconProps, ref: React.Ref<SVGSVGElement>) {\n const { name, ...otherProps } = props;\n const Component = icons[name];\n /* 24x24 _at the base body font_ - must be em so that they scale with font size - tailwind spacing uses rem */\n const className = cn('inline-flex h-[1.715em] w-[1.715em] flex-shrink-0', props.className, {\n 'p-[3px]': props.className?.includes('rounded-full'),\n });\n\n return Component ? (\n <Component {...otherProps} className={className} data-taco=\"icon\" focusable=\"false\" ref={ref} role=\"img\" />\n ) : null;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as AccordionPrimitive from '@radix-ui/react-accordion';\nimport { Icon } from '../Icon/Icon';\n\ntype AccordionContext = {\n as: 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n};\nconst AccordionContext = React.createContext<AccordionContext>({\n as: 'h2',\n});\n\nexport type AccordionTriggerProps = React.HTMLAttributes<HTMLElement>;\n\nconst StyledTrigger = React.forwardRef(function AccordionStyledTrigger(\n props: AccordionPrimitive.AccordionTriggerProps,\n ref: React.Ref<HTMLButtonElement>\n) {\n const isExpanded = !!props['aria-expanded'];\n\n const className = cn(\n 'w-full inline-flex justify-between items-center align-middle',\n 'focus:rounded-sm focus:border-blue-500 focus:yt-focus',\n props.className\n );\n\n return (\n <button {...props} ref={ref} className={className}>\n {props.children}\n <Icon name={isExpanded ? 'chevron-up' : 'chevron-down'} />\n </button>\n );\n});\n\nconst Trigger = React.forwardRef(function AccordionTrigger(props: AccordionTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const { children } = props;\n const { as: Heading } = React.useContext(AccordionContext);\n\n return (\n <AccordionPrimitive.Header asChild>\n <Heading className=\"my-3\">\n <AccordionPrimitive.Trigger ref={ref} asChild>\n <StyledTrigger>{children}</StyledTrigger>\n </AccordionPrimitive.Trigger>\n </Heading>\n </AccordionPrimitive.Header>\n );\n});\n\nexport type AccordionContentProps = React.HTMLAttributes<HTMLElement>;\nconst Content = React.forwardRef(function AccordionContent(props: AccordionContentProps, ref: React.Ref<HTMLDivElement>) {\n return <AccordionPrimitive.Content {...props} ref={ref} />;\n});\n\nexport type AccordionItemProps = React.HTMLAttributes<HTMLDivElement> & {\n id: string;\n disabled?: boolean;\n};\nconst Item = (props: AccordionItemProps) => {\n const { id, ...otherProps } = props;\n return <AccordionPrimitive.Item {...otherProps} value={id} />;\n};\n\ntype AccordionBaseProps = {\n children: React.ReactNode[];\n\n /** Change what heading element accordion regions will render */\n as?: 'h2' | 'h3' | 'h4' | 'h5' | 'h6';\n\n /** Additional classes for Accordion root element */\n className?: string;\n};\n\nexport interface AccordionUncontrolledProps extends AccordionBaseProps {\n /** Default expanded accordion(s) */\n defaultId: string | string[];\n\n id?: never;\n onChange?: never;\n}\n\nexport interface AccordionMultipleControlledProps extends AccordionBaseProps {\n /** Expanded accordions */\n id: string[];\n\n /** onChange function to receive ids of expanded accordions */\n onChange: (id: string[]) => void;\n\n defaultId?: never;\n}\nexport interface AccordionSingleControlledProps extends AccordionBaseProps {\n /** Expanded accordion */\n id: string;\n\n /** onChange function to receive id of expanded accordion */\n onChange: (id: string) => void;\n\n defaultId?: never;\n}\n\nexport type AccordionProps = AccordionUncontrolledProps | AccordionMultipleControlledProps | AccordionSingleControlledProps;\n\nexport const Accordion = (props: AccordionProps) => {\n const { id, defaultId, onChange, as = 'h2', ...otherProps } = props;\n const context = React.useMemo(() => ({ as }), [as]);\n\n let valueProps;\n\n if (defaultId) {\n valueProps = {\n defaultValue: defaultId || undefined,\n };\n } else {\n valueProps = {\n onValueChange: onChange,\n value: id || undefined,\n };\n }\n\n const type = Array.isArray(valueProps.defaultValue) || Array.isArray(valueProps.value) ? 'multiple' : 'single';\n const className = cn('divide-y divide-grey-200', props.className);\n\n return (\n <AccordionContext.Provider value={context}>\n <AccordionPrimitive.Root {...otherProps} {...valueProps} data-taco=\"accordion\" className={className} type={type} />\n </AccordionContext.Provider>\n );\n};\n\nAccordion.Item = Item;\nAccordion.Trigger = Trigger;\nAccordion.Content = Content;\n","import * as React from 'react';\n\ntype Props = React.HTMLAttributes<HTMLSpanElement>;\n\nexport const VisuallyHidden = React.forwardRef(function VisuallyHidden(props: Props, ref: React.Ref<HTMLSpanElement>) {\n return <span {...props} className=\"sr-only\" ref={ref} />;\n});\n","import { State, Appearance } from '../types';\n\nexport const getAppearanceClasses = (value: Appearance | undefined): string => {\n switch (value) {\n case 'primary':\n return 'yt-blue-solid';\n\n case 'danger':\n return 'yt-red-solid';\n\n case 'ghost':\n return 'yt-blue-inverted';\n\n case 'discrete':\n return 'yt-transparent';\n\n default:\n return 'yt-grey-solid';\n }\n};\n\nexport const getStateClasses = (value: State | undefined): string => {\n switch (value) {\n case 'information':\n return 'yt-blue-solid';\n\n case 'warning':\n return 'yt-yellow-solid';\n\n case 'error':\n return 'yt-red-solid';\n\n case 'success':\n return 'yt-green-solid';\n\n default:\n return 'yt-grey-solid';\n }\n};\n\nexport const getOutlineClasses = (state: Appearance | State | undefined): string => {\n switch (state) {\n case 'information':\n case 'primary':\n return 'yt-blue-inverted';\n\n case 'warning':\n return 'yt-yellow-inverted';\n\n case 'error':\n case 'danger':\n return 'yt-red-inverted';\n\n case 'success':\n return 'yt-green-inverted';\n\n default:\n return 'yt-grey-inverted';\n }\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { VisuallyHidden } from '../VisuallyHidden/VisuallyHidden';\nimport { State } from '../../types';\nimport { getStateClasses, getOutlineClasses } from '../../utils/taillwind';\nimport './Badge.css';\n\nexport type BadgeProps = React.HTMLAttributes<HTMLSpanElement> & {\n /** Content should be a numerical value or tag/status like text **/\n children: React.ReactNode;\n /** Show compact version **/\n compact?: boolean;\n /** Show outlined version **/\n outline?: boolean;\n /** State will change the style of the badge **/\n state?: State;\n};\n\nexport const Badge = React.forwardRef(function Badge(props: BadgeProps, ref: React.Ref<HTMLSpanElement>) {\n const { children, compact = false, outline = false, state, ...otherProps } = props;\n const className = cn(\n 'rounded-full border font-bold text-xs uppercase overflow-hidden whitespace-nowrap inline-flex items-center justify-center',\n {\n [getOutlineClasses(state)]: outline,\n [`border-transparent ${getStateClasses(state)}`]: !outline,\n 'h-2 w-2 min-w-0': compact,\n 'h-5 py-0 px-1.5': !compact, // custom padding keeps single digits in a perfect circle\n },\n props.className\n );\n\n return (\n <span\n {...otherProps}\n aria-atomic=\"true\"\n aria-live=\"polite\"\n className={className}\n data-taco=\"badge\"\n ref={ref}\n role=\"status\"\n title={props['aria-label']}>\n {compact ? <VisuallyHidden>{children}</VisuallyHidden> : children}\n </span>\n );\n});\n","import * as React from 'react';\n\ntype ButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement | HTMLAnchorElement> & {\n /** Content should be a text */\n children: React.ReactNode;\n /** Provides url for buttons being used as a link */\n href?: string;\n /** Provides target for buttons being used as a link */\n target?: '_self' | '_blank' | '_parent' | '_top';\n};\n\nconst Button = React.forwardRef(function Button(props: ButtonProps, ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>) {\n const { disabled, target, type = 'button', ...otherProps } = props;\n\n const Tag = props.href ? 'a' : 'button';\n\n return (\n <Tag\n {...otherProps}\n aria-disabled={disabled ? 'true' : undefined}\n disabled={disabled}\n target={Tag === 'a' ? target : undefined}\n type={Tag !== 'a' ? type : undefined}\n ref={ref as any}>\n {React.Children.count(props.children) > 1\n ? React.Children.map(props.children, child => (typeof child === 'string' ? <span>{child}</span> : child))\n : props.children}\n </Tag>\n );\n});\n\nexport { Button };\nexport type { ButtonProps };\n","import * as React from 'react';\nimport * as TooltipPrimitive from '@radix-ui/react-tooltip';\nimport cn from 'classnames';\n\nexport type TooltipProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'title'> & {\n /** The element which activates the tooltip when hovered. Should be a single React/HTML element */\n children: React.ReactElement | any;\n /** Text displayed in the tooltip */\n title: string | JSX.Element;\n /**\n * Placement of the tooltip relative to the reference element. Placement will be reversed if a collision occurs\n * @defaultValue bottom\n */\n placement?: 'top' | 'right' | 'bottom' | 'left';\n};\n\nexport const Tooltip = React.forwardRef(function Tooltip(props: TooltipProps, ref: React.Ref<HTMLElement>) {\n const { title, children, placement, ...otherProps } = props;\n const className = cn(otherProps.className);\n\n return (\n <TooltipPrimitive.Root delayDuration={250}>\n <TooltipPrimitive.Trigger asChild ref={ref as any}>\n {children}\n </TooltipPrimitive.Trigger>\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content {...otherProps} asChild className={className} side={placement} sideOffset={3}>\n <div\n className=\"xs:max-w-[theme(spacing.56)] max-w-[theme(spacing.32)] animate-[fade-in_150ms] rounded-sm bg-blue-900/90 px-2 py-1 text-xs font-bold text-white opacity-90\"\n data-taco=\"tooltip\"\n style={{\n transformOrigin: 'var(--radix-tooltip-content-transform-origin)',\n }}>\n <TooltipPrimitive.Arrow className=\"-mt-px fill-blue-900/90 stroke-blue-900/90\" />\n {title}\n </div>\n </TooltipPrimitive.Content>\n </TooltipPrimitive.Portal>\n </TooltipPrimitive.Root>\n );\n});\n","import React from 'react';\nimport { Appearance } from '../../types';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { Tooltip } from '../Tooltip/Tooltip';\n\nexport const getButtonClasses = () => {\n return 'flex-shrink-0 min-h-[theme(spacing.8)] min-w-[theme(spacing.8)] gap-1 h-max leading-5 inline-flex items-center justify-center';\n};\n\nexport const getAppearanceClasses = (value: Appearance | undefined, icon = false): string => {\n switch (value) {\n case 'primary':\n return `wcag-blue-500 focus:bg-blue-500 focus:text-white focus:yt-focus active:bg-blue-700 active:text-white hover:bg-blue-300 hover:text-white hover:focus:bg-blue-300 hover:focus:border-blue-300 hover:focus:text-white disabled:hover:wcag-blue-500 disabled:hover:hover:border-blue-500`;\n\n case 'danger':\n return `wcag-red-500 focus:bg-red-500 focus:text-white focus:yt-focus-red active:bg-red-700 active:text-white hover:bg-red-300 hover:text-white hover:focus:bg-red-300 hover:focus:text-white disabled:hover:wcag-red-500`;\n\n case 'ghost':\n return `bg-white shadow-[inset_0_0_0_1px_theme(colors.blue.500)] text-blue-500 focus:bg-transparent focus:text-blue-500 active:bg-blue-100 focus:!shadow-[inset_0_0_0_1px_theme(colors.blue.500),0_0_0_2px_rgba(0,99,255,0.25)] active:text-blue-700 hover:bg-blue-100 hover:shadow-[inset_0_0_0_1px_theme(colors.blue.300)] hover:text-blue-300 hover:focus:bg-blue-100 hover:focus:!shadow-[inset_0_0_0_1px_theme(colors.blue.300),0_0_0_2px_rgba(0,99,255,0.25)] hover:focus:text-blue-300`;\n\n case 'discrete': {\n if (icon) {\n return `bg-transparent text-black border-transparent focus:text-black focus:yt-focus active:text-black hover:text-grey-700 hover:focus:text-grey-700 disabled:hover:text-black `;\n }\n\n return `yt-transparent focus:text-blue-500 focus:yt-focus active:text-blue-700 hover:text-blue-300 hover:focus:text-blue-300 disabled:hover:yt-transparent`;\n }\n\n default:\n return `wcag-grey-200 focus:bg-grey-200 focus:yt-focus active:bg-grey-300 active:text-black hover:bg-grey-100 hover:text-grey-700 hover:focus:bg-grey-100 hover:focus:text-grey-700 disabled:hover:wcag-grey-200`;\n }\n};\n\nexport const createButtonWithTooltip = (\n props: any,\n className: string,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n): JSX.Element => {\n const { tooltip, ...buttonProps } = props;\n const button = <ButtonPrimitive.Button {...buttonProps} className={className} ref={ref} />;\n\n if (tooltip) {\n return <Tooltip title={tooltip}>{button}</Tooltip>;\n }\n\n return button;\n};\n\nexport const createButtonWithOverlays = (props: any, buttonBase: JSX.Element) => {\n const { dialog, hanger, menu, popover } = props;\n let button = buttonBase;\n\n if (typeof dialog === 'function') {\n button = dialog({ trigger: button });\n } else if (typeof menu === 'function') {\n button = menu({ trigger: button });\n } else if (typeof popover === 'function') {\n button = popover({ trigger: button });\n }\n\n if (typeof hanger === 'function') {\n button = hanger({ anchor: button });\n }\n\n return button;\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { Icon, IconName } from '../Icon/Icon';\nimport { getAppearanceClasses, getButtonClasses, createButtonWithTooltip, createButtonWithOverlays } from '../Button/util';\nimport { Appearance } from '../../types';\nimport { DialogProps, HangerProps, MenuProps, PopoverProps } from '../..';\n\nexport type IconButtonProps = Omit<ButtonPrimitive.ButtonProps, 'children'> & {\n /** Appearance will change the style of the button */\n appearance?: Appearance;\n /**\n * Dialog component associated with the button, clicking the button will open the dialog.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated dialog when clicked.\n */\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n /** Hanger component associated with the button. */\n hanger?: (props: Partial<HangerProps>) => JSX.Element;\n /** Set which icon should be rendered within button */\n icon: IconName; // this dynamic type causes the type extraction for props to fail\n /** Menu component associated with the button. */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n /**\n * Popover component associated with the button, clicking the button will open the popover.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated popover when clicked.\n */\n popover?: (props: Partial<PopoverProps>) => JSX.Element;\n /**\n * Set whether the button is rounded.\n * Default value is `false`\n */\n rounded?: boolean;\n /** A tooltip to show when hovering over the button */\n tooltip?: string;\n};\n\nexport const Base = React.forwardRef(function IconButtonBase(\n props: IconButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { icon, rounded = false, ...otherProps } = props;\n\n const className = cn(\n 'w-8',\n getButtonClasses(),\n getAppearanceClasses(otherProps.appearance, true),\n {\n 'rounded-full': rounded,\n rounded: !rounded,\n 'cursor-not-allowed opacity-50': props.disabled,\n 'focus:yt-focus active:focus:yt-focus': !props.disabled,\n },\n props.className\n );\n\n if (!icon) {\n return null;\n }\n\n return createButtonWithTooltip(\n { ...otherProps, children: <Icon name={icon} className=\"m-0 p-0\" />, 'data-taco': 'icon-button' },\n className,\n ref\n );\n});\n\nexport const IconButton = React.forwardRef(function Button(\n props: IconButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { dialog, hanger, menu, popover, ...buttonProps } = props;\n const button = <Base {...buttonProps} ref={ref} />;\n\n return createButtonWithOverlays({ dialog, hanger, menu, popover }, button);\n});\n","import * as React from 'react';\nimport { Locale } from '../../types';\nimport { CalendarTexts } from '../Calendar/Calendar';\nimport { ComboboxTexts } from '../Combobox/Combobox';\nimport { DialogTexts } from '../Dialog/Dialog';\nimport { PaginationTexts } from '../Pagination/Pagination';\nimport { ListboxTexts } from '../Listbox/Listbox';\nimport { ToastsTexts } from '../Toast/Toast';\nimport { DatepickerTexts } from '../Datepicker/Datepicker';\nimport { HangerTexts } from '../Hanger/Hanger';\nimport { SelectTexts } from '../Select/Select';\nimport { TourTexts } from '../Tour/Tour';\nimport { TableTexts } from '../Table/Table';\nimport { SearchInputTexts } from '../SearchInput/SearchInput';\nimport { Select2Texts } from '../Select2/Select2';\nimport { BannerTexts } from '../Banner/Banner';\n\nexport type LocalizationTexts = {\n /** Localized texts and aria-labels for [Calendar](component:calendar) component */\n calendar: CalendarTexts;\n /** Localized texts and aria-labels for [Combobox](component:combobox) component */\n combobox: ComboboxTexts;\n /** Localized texts and aria-labels for [DatePicker](component:datepicker) component */\n datepicker: DatepickerTexts;\n /** Localized texts and aria-labels for [Hanger](component:hanger) component */\n hanger: HangerTexts;\n /** Localized texts and aria-labels for [Banner](component:banner) component */\n banner: BannerTexts;\n /** Localized texts and aria-labels for [Listbox](component:listbox) component */\n listbox: ListboxTexts;\n /** Localized texts and aria-labels for [Dialog](component:dialog) component */\n dialog: DialogTexts;\n /** Localized texts and aria-labels for [Pagination](component:pagination) component */\n pagination: PaginationTexts;\n /** Localized texts and aria-labels for [Table](component:table) component */\n table: TableTexts;\n /** Localized texts and aria-labels for [Select](component:select) component */\n select: SelectTexts;\n /** Localized texts and aria-labels for [Select2](component:select2) component */\n select2: Select2Texts;\n /** Localized texts and aria-labels for [Toast](component:toast) component */\n toasts: ToastsTexts;\n /** Localized texts and aria-labels for [Tour](component:tour) component */\n tour: TourTexts;\n /** Localized texts and aria-labels for [SearchInput](component:searchinput) component */\n searchInput: SearchInputTexts;\n};\n\nexport type Localization = {\n /**\n * Provide the language code used in application.\n * Default value is `en-GB`\n */\n locale: Locale;\n /** Provide the texts and aria-labels for components used within the provider */\n texts: LocalizationTexts;\n /** Provide the formatting */\n formatting: {\n /** Default value is `dd.mm.yy` */\n date: string;\n };\n};\n\nexport const defaultLocalisationTexts = {\n calendar: {\n months: [\n 'January',\n 'February',\n 'March',\n 'April',\n 'May',\n 'June',\n 'July',\n 'August',\n 'September',\n 'October',\n 'November',\n 'December',\n ],\n weekdaysShort: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],\n actions: {\n previousMonth: 'Previous month',\n nextMonth: 'Next month',\n previousYear: 'Previous year',\n nextYear: 'Next year',\n today: 'Today',\n },\n },\n combobox: {\n tooltip: 'Search in list',\n },\n datepicker: {\n calendar: 'Calendar',\n clear: 'Clear',\n expand: 'Show calendar',\n shortcuts: 'Shortcuts',\n },\n hanger: {\n close: 'Close',\n },\n banner: {\n close: 'Close',\n },\n listbox: {\n loading: 'Loading results...',\n empty: 'No results found',\n allOption: 'All',\n },\n dialog: {\n close: 'Close',\n drag: 'Drag',\n },\n pagination: {\n label: 'Pagination',\n pageSize: 'Items per page',\n showingXofYofTotal: 'Showing [X] - [Y] of [total]',\n actions: {\n firstPage: 'Goto first page',\n firstPageWithShortcut: 'Goto first page (Home)',\n previousPage: 'Goto previous page',\n previousPageWithShortcut: 'Goto previous page (Page Up)',\n nextPage: 'Goto next page',\n nextPageWithShortcut: 'Goto next page (Page Down)',\n lastPage: 'Goto last page',\n lastPageWithShortcut: 'Goto last page (End)',\n pageX: 'Goto page [X]',\n },\n },\n table: {\n actions: 'Other actions',\n edit: 'Edit (e)',\n copy: 'Copy (c)',\n del: 'Delete (del)',\n newSubRow: 'New row (shift + n)',\n loading: 'Loading...',\n },\n select: {\n allOptionsSelected: 'All',\n },\n select2: {\n allSelect: 'Select all',\n allDeselect: 'Deselect all',\n cancel: 'Cancel',\n chooseColor: 'Pick a color',\n create: 'Create',\n delete: 'Delete',\n save: 'Save',\n search: 'Search...',\n searchOrCreate: 'Search or create...',\n },\n toasts: {\n dismiss: 'Dismiss',\n },\n tour: {\n back: 'Back',\n close: 'Close',\n skip: 'Close and complete',\n last: 'Done',\n next: 'Next',\n open: 'Open',\n },\n searchInput: {\n button: 'Search',\n placeholder: 'Search...',\n clear: 'Clear',\n },\n};\n\nconst defaultLocalizationContext: Localization = {\n locale: 'en-GB',\n texts: defaultLocalisationTexts,\n formatting: {\n date: 'dd.mm.yy',\n },\n};\n\nexport const LocalizationContext = React.createContext<Localization>(defaultLocalizationContext);\nexport interface LocalizationProviderProps {\n children: React.ReactNode;\n localization?: Localization;\n}\nexport const LocalizationProvider: React.FC<LocalizationProviderProps> = ({ localization, children }) => {\n return (\n <LocalizationContext.Provider value={localization || defaultLocalizationContext}>{children}</LocalizationContext.Provider>\n );\n};\n\nexport const useLocalization = () => React.useContext(LocalizationContext);\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { State } from '../../types';\nimport { getBannerIcon } from './util';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type BannerProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Content can be any react element, for e.g. a `div` */\n children: React.ReactNode;\n /** State will change the icon displayed in banner */\n state: State;\n onClose?: () => void;\n};\n\nexport type BannerTexts = {\n /** Aria-label for the close icon button of banner */\n close: string;\n};\n\nexport const Banner = React.forwardRef(function Banner(props: BannerProps, ref: React.Ref<HTMLDivElement>) {\n const { children, state, onClose } = props;\n const { texts } = useLocalization();\n const className = cn('bg-white relative flex items-center gap-2 py-2 px-4 leading-6 shadow-md z-10', props.className);\n\n return (\n <div className={className} data-taco=\"banner\" ref={ref}>\n {getBannerIcon(state)}\n {children}\n {onClose ? (\n <IconButton\n aria-label={texts.banner.close}\n className=\"ml-auto -mr-2 self-start\"\n icon=\"close\"\n appearance=\"discrete\"\n onClick={onClose}\n />\n ) : null}\n </div>\n );\n});\n","import React from 'react';\nimport { Icon } from '../Icon/Icon';\nimport { State } from '../../types';\n\nexport const getBannerIcon = (type: State): JSX.Element | null => {\n switch (type) {\n case 'success':\n return <Icon name=\"tick\" className=\"yt-green-solid mt-1 self-start rounded-full\" />;\n\n case 'error':\n return <Icon name=\"warning\" className=\"yt-red-solid mt-1 self-start rounded-full\" />;\n\n case 'warning':\n return <Icon name=\"warning\" className=\"yt-yellow-solid mt-1 self-start rounded-full\" />;\n\n case 'information':\n return <Icon name=\"info\" className=\"yt-blue-solid mt-1 self-start rounded-full\" />;\n\n default:\n return null;\n }\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Appearance } from '../../types';\nimport * as ButtonPrimitive from '../../primitives/Button';\nimport { getAppearanceClasses, getButtonClasses, createButtonWithTooltip, createButtonWithOverlays } from './util';\nimport { HangerProps } from '../Hanger/Hanger';\nimport { MenuProps } from '../Menu/Menu';\nimport { DialogProps } from '../Dialog/Dialog';\nimport { PopoverProps } from '../Popover/Popover';\nimport './Button.css';\nimport { Icon } from '../Icon/Icon';\n\nexport type ButtonProps = ButtonPrimitive.ButtonProps & {\n /** Appearance will change the style of the button */\n appearance?: Appearance;\n /**\n * Dialog component associated with the button, clicking the button will open the dialog.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated dialog when clicked.\n */\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n /** If fluid, button expands to the width of it's container */\n fluid?: boolean;\n /** Hanger component associated with the button. */\n hanger?: (props: Partial<HangerProps>) => JSX.Element;\n /** Menu component associated with the button. */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n /**\n * Popover component associated with the button, clicking the button will open the popover.\n * *Note* that `onClick` event on button won't be handled, as in this case, the purpose of\n * the button should be only to open the associated popover when clicked.\n */\n popover?: (props: Partial<PopoverProps>) => JSX.Element;\n /** A tooltip to show when hovering over the button */\n tooltip?: string | JSX.Element;\n};\n\nconst Base = React.forwardRef(function ButtonBase(props: ButtonProps, ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>) {\n const { fluid, ...otherProps } = props;\n const className = cn(\n getButtonClasses(),\n getAppearanceClasses(otherProps.appearance),\n 'rounded px-3',\n {\n 'cursor-not-allowed opacity-50': props.disabled,\n 'focus:yt-focus active:focus:yt-focus': !props.disabled,\n 'w-full': fluid,\n },\n props.className\n );\n\n return createButtonWithTooltip({ ...otherProps, 'data-taco': 'button' }, className, ref);\n});\n\nexport const Button = React.forwardRef(function Button(\n props: ButtonProps,\n ref: React.Ref<HTMLButtonElement | HTMLAnchorElement>\n) {\n const { dialog, hanger, menu, popover, ...buttonProps } = props;\n\n let children = buttonProps.children;\n\n // add a chevron icon to menu buttons\n if (typeof menu === 'function') {\n children = Array.isArray(children)\n ? [...children, <Icon key=\"chevron-down\" name=\"chevron-down\" />]\n : [children, <Icon key=\"chevron-down\" name=\"chevron-down\" />];\n }\n\n const button = (\n <Base {...buttonProps} ref={ref}>\n {children}\n </Base>\n );\n\n return createButtonWithOverlays({ dialog, hanger, menu, popover }, button);\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport ReactDayPicker, { NavbarElementProps, Modifier } from 'react-day-picker';\nimport { useLocalization } from '../Provider/Localization';\nimport './Calendar.css';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type CalendarTextsActions = {\n /** Aria-label for previous month action button */\n previousMonth: string;\n /** Aria-label for next month action button */\n nextMonth: string;\n /** Aria-label for previous year action button */\n previousYear: string;\n /** Aria-label for next year action button */\n nextYear: string;\n /** Text displayed within today action button */\n today: string;\n};\n\nexport type CalendarTexts = {\n /** Text and aria-label for action buttons in Calendar */\n actions: CalendarTextsActions;\n /** Text abbreviation for months in Calendar's header, starting with January */\n months: string[];\n /** Text abbreviation for days in Calendar's header, starting with Sunday */\n weekdaysShort: string[];\n};\n\n/** @internal */\ntype CustomNavbarElementProps = NavbarElementProps & {\n onMonthChange: (month: Date) => void;\n value?: Date;\n};\n\nconst thisYear = new Date().getFullYear();\nconst years: number[] = [];\n\nfor (let i = thisYear - 50; i <= thisYear + 10; i += 1) {\n years.push(i);\n}\n\nconst Navbar = React.memo(\n ({ onMonthChange, onNextClick, onPreviousClick, value = new Date() }: CustomNavbarElementProps): JSX.Element => {\n const {\n texts: {\n calendar: { actions, months },\n },\n } = useLocalization();\n\n const handleChange = function handleChange(event) {\n const { year, month } = event.target.form;\n onMonthChange(new Date(year.value, month.value));\n };\n\n return (\n <div className=\"mb-2 flex items-center justify-between\">\n <form className=\"inline-flex space-x-1\">\n <select className=\"h-8 px-2\" name=\"month\" onChange={handleChange} value={value.getMonth()}>\n {months.map((month, i) => (\n <option key={month} value={i}>\n {month}\n </option>\n ))}\n </select>\n <select className=\"h-8 px-2\" name=\"year\" onChange={handleChange} value={value.getFullYear()}>\n {years.map(year => (\n <option key={year} value={year}>\n {String(year)}\n </option>\n ))}\n </select>\n </form>\n <div>\n <IconButton\n appearance=\"discrete\"\n icon=\"chevron-left\"\n aria-label={actions.previousMonth}\n onClick={() => onPreviousClick()}\n rounded\n />\n <IconButton\n appearance=\"discrete\"\n icon=\"chevron-right\"\n aria-label={actions.nextMonth}\n onClick={() => onNextClick()}\n rounded\n />\n </div>\n </div>\n );\n }\n);\n\nexport type CalendarProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onChange' | 'value'> & {\n /** Handler called when a day is clicked in calendar */\n onChange: (date: Date, event?: React.MouseEvent<HTMLDivElement>) => void;\n value?: Date;\n disabledDays?: Modifier[];\n};\n\nexport const Calendar = React.forwardRef(function Calendar(props: CalendarProps, ref: React.Ref<ReactDayPicker>) {\n const { onChange: handleChange, value, disabledDays, ...otherProps } = props;\n const { locale, texts } = useLocalization();\n const [visibleMonth, setVisibleMonth] = React.useState(value ?? new Date());\n\n React.useEffect(() => {\n if (visibleMonth !== value) {\n setVisibleMonth(value ?? new Date());\n }\n }, [value]);\n\n const handleDayClick = (date, modifiers, event) => {\n if (modifiers.outside || modifiers.disabled) {\n return;\n }\n\n handleChange(date, event);\n };\n\n const handleCalendarClickToday = (): void => {\n const today = new Date();\n\n // set to midday to avoid UTC offset causing dates to be mismatched server side\n today.setHours(12);\n today.setMinutes(0);\n today.setSeconds(0);\n\n handleChange(today);\n };\n\n const className = cn('flex bg-white text-xs p-4', otherProps.className);\n\n return (\n <div data-taco=\"calendar\">\n <ReactDayPicker\n {...otherProps}\n className={className}\n month={visibleMonth}\n selectedDays={value}\n locale={locale.substring(0, 2)}\n firstDayOfWeek={1}\n months={texts.calendar.months}\n weekdaysShort={texts.calendar.weekdaysShort}\n navbarElement={navProps => <Navbar {...navProps} onMonthChange={setVisibleMonth} value={visibleMonth} />}\n onDayClick={handleDayClick}\n onMonthChange={setVisibleMonth}\n onTodayButtonClick={handleCalendarClickToday}\n captionElement={() => null}\n todayButton={texts.calendar.actions.today}\n numberOfMonths={1}\n ref={ref}\n disabledDays={disabledDays}\n />\n </div>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\n\nimport { MenuProps } from '../Menu/Menu';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type CardContentProps = React.HTMLAttributes<HTMLDivElement> & {\n noPadding?: boolean;\n};\n\nconst Content = React.forwardRef<HTMLDivElement, CardContentProps>(function CardContent(externalProps, ref) {\n const { noPadding, ...props } = externalProps;\n const className = cn(\n 'flex-grow overflow-auto',\n {\n 'mx-4 mb-4': !noPadding,\n },\n props.className\n );\n return <div {...props} className={className} ref={ref} />;\n});\n\nexport type CardProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Title of the Card */\n title: string | React.ReactElement;\n /** Menu component associated with the Card */\n menu?: (props: Partial<MenuProps>) => JSX.Element;\n};\n\nexport const Card = React.forwardRef<HTMLDivElement, CardProps>(function Card(props, ref) {\n const { title, menu, children } = props;\n const className = cn(\n 'bg-white flex flex-col rounded-xl shadow-[0px_0px_1px_rgba(0,0,0,0.1),0px_6px_18px_rgba(47,51,68,0.2)]',\n props.className\n );\n\n return (\n <div className={className} data-taco=\"card\" ref={ref}>\n <div className=\"mx-4 mt-4 mb-2 flex\">\n {title && <h4 className=\"mb-0 flex-grow text-left\">{title}</h4>}\n {menu ? <IconButton icon=\"ellipsis-horizontal\" appearance=\"discrete\" menu={menu} className=\"-mt-[4px]\" /> : null}\n </div>\n {children}\n </div>\n );\n}) as React.ForwardRefExoticComponent<CardProps> & {\n Content: React.ForwardRefExoticComponent<CardContentProps>;\n};\nCard.Content = Content;\n","import { v4 as uuid } from 'uuid';\nimport React from 'react';\n\n// React 18 has this built-in, when we upgrade this hook should be removed and the uuid dependency should be removed\n\nexport const useId = (nativeId: string | undefined) => {\n return React.useMemo(() => nativeId ?? uuid(), []);\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox';\nimport { Icon } from '../Icon/Icon';\nimport { useId } from '../../hooks/useId';\n\ntype CheckedState = boolean | 'indeterminate';\n\ntype CheckboxBaseProps = Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'children' | 'onChange'> & {\n /* Increases visual prominenance of the checkbox */\n highlighted?: boolean;\n /**\n * Indeterminate state should only be used with sub-checkboxes. The indeterminate state is shown if not all\n * sub-checkboxes are selected. This only affects the style, changing the icon in the checkbox.\n */\n indeterminate?: boolean;\n /* Whether the checkbox is in an invalid state */\n invalid?: boolean;\n /** Label for the checkbox */\n label?: React.ReactNode;\n /* Whether user input is required */\n required?: boolean;\n};\n\ninterface UncontrolledCheckboxProps extends CheckboxBaseProps {\n checked?: never;\n onChange?: never;\n /* The default checked state (uncontrolled) */\n defaultChecked?: boolean;\n}\n\ninterface ControlledCheckboxProps extends CheckboxBaseProps {\n defaultChecked?: never;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean) => void;\n}\n\nexport type CheckboxProps = UncontrolledCheckboxProps | ControlledCheckboxProps;\n\nexport const Checkbox = React.forwardRef(function Checkbox(props: CheckboxProps, ref: React.Ref<HTMLButtonElement>) {\n const { checked, highlighted, indeterminate, invalid, label, onChange, ...otherProps } = props;\n const id = useId(props.id);\n\n const className = cn(\n 'bg-white h-5 w-5 border rounded text-sm flex-shrink-0 self-start mt-[0.1rem] focus:yt-focus', //hover:shadow-[0_0_0_1px_rgba(235,235,235,1)]\n props.className,\n {\n 'border-grey-300 text-blue-500 hover:text-blue-300 focus:border-blue-500 focus:hover:border-blue-300':\n !props.disabled && !invalid,\n 'border-grey-200 text-blue-300 cursor-not-allowed': props.disabled,\n 'bg-[rgba(255,255,0,0.2)] disabled:bg-[rgba(255,255,0,0.075)]': highlighted,\n 'border-red-500 text-red-500 hover:text-red-300 hover:border-red-300 focus:border-red-500 focus:hover:border-red-300':\n invalid && !props.disabled,\n }\n );\n\n let handleChange: ((checked: CheckedState) => void) | undefined;\n\n if (onChange) {\n handleChange = (checked: CheckedState) => onChange(checked === 'indeterminate' ? false : checked);\n }\n\n let labelledByProps: Record<string, string> | null = null;\n\n if (label) {\n labelledByProps = {\n 'aria-labelledby': `${id}-label`,\n id,\n };\n }\n\n const element = (\n <CheckboxPrimitive.Root\n {...otherProps}\n {...labelledByProps}\n data-taco=\"checkbox\"\n checked={indeterminate ? 'indeterminate' : checked}\n className={className}\n onCheckedChange={handleChange}\n ref={ref}>\n <CheckboxPrimitive.Indicator className=\"flex h-full w-full\">\n <Icon name={indeterminate ? 'line' : 'tick'} className=\"!h-full !w-full\" />\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n );\n\n if (label) {\n const labelContainerClassName = cn(\n 'flex items-center cursor-pointer gap-2',\n {\n 'cursor-not-allowed text-grey-300': props.disabled,\n },\n props.className\n );\n\n return (\n <span className={labelContainerClassName}>\n {element}\n <label htmlFor={id} id={`${id}-label`}>\n {label}\n </label>\n </span>\n );\n }\n\n return element;\n});\nCheckbox.displayName = 'Checkbox';\n","import cn from 'classnames';\n\nexport const getInputClasses = props => {\n const disabled = props.disabled || !!props['aria-disabled'];\n const readOnly = props.readOnly || !!props['aria-readonly'];\n const invalid = props.invalid || !!props['aria-invalid'];\n\n return cn(\n 'peer bg-white text-black text-sm border font-normal not-italic no-underline rounded flex items-center leading-6 px-2 relative w-full text-ellipsis transition-colors transition-opacity ease-in min-h-[theme(spacing.8)]',\n {\n // default\n 'border-grey-300 focus:border-blue-300 focus:yt-focus': !invalid,\n 'hover:shadow-[0_0_0.1rem_theme(colors.grey.500)] active:border-blue-700': !invalid && !disabled,\n // disabled\n 'border-grey-200 text-opacity-25 cursor-not-allowed placeholder:text-grey-700': disabled,\n // highlighted\n 'bg-[rgba(255,255,0,0.075)]': props.highlighted && disabled,\n 'bg-[rgba(255,255,0,0.2)]': props.highlighted && !disabled,\n // invalid\n 'border-red focus:border-red-300 focus:yt-focus-red active:border-red-700': invalid,\n 'hover:shadow-[0_0_0.15rem_theme(colors.red.500)]': invalid && !disabled,\n // readOnly\n 'cursor-not-allowed text-black bg-grey-200': readOnly,\n }\n );\n};\n\nexport const getButtonStateClasses = (invalid: boolean | undefined): string => {\n if (invalid) {\n return 'border !border-red-500 group-peer-focus:!border-red-300 focus:yt-focus-red group-focus:group-active:!border-red-300 transition-colors ease-in';\n }\n\n return 'border border-grey-300 focus:!border-blue-300 group-peer-focus:!border-blue-300 group-peer-focus:group-peer-active:!border-blue-700 transition-colors transition-opacity ease-in';\n};\n","export const debounce = (fn: Function, delay: number) => {\n let timeoutId: ReturnType<typeof setTimeout>;\n\n return function (this: any, ...args: any[]) {\n clearTimeout(timeoutId);\n timeoutId = setTimeout(() => fn.apply(this, args), delay);\n };\n};\n","import * as React from 'react';\nimport { debounce } from '../utils/debounce';\n\nconst getVisibility = (element: HTMLElement | null): boolean =>\n Boolean(element && (element.offsetWidth || element.offsetHeight || element.getClientRects().length));\n\nexport const useBoundingClientRectListener = (\n ref: React.RefObject<HTMLElement>,\n dependencies?: Array<any>\n): DOMRectReadOnly | undefined => {\n const [dimensions, setDimensions] = React.useState<DOMRectReadOnly | undefined>(undefined);\n const isRefElementVisible = getVisibility(ref.current);\n const [visibility, setVisibility] = React.useState(isRefElementVisible);\n\n const resize = () => {\n if (visibility) {\n setDimensions(ref.current?.getBoundingClientRect());\n }\n };\n\n React.useEffect(() => {\n const timeout = setTimeout(resize, 0);\n const debouncedResize = debounce(resize, 250);\n\n window.addEventListener('resize', debouncedResize);\n\n return () => {\n clearTimeout(timeout);\n window.removeEventListener('resize', debouncedResize);\n };\n }, [ref.current, visibility]);\n\n React.useEffect(() => {\n const newRefElementVisibility = getVisibility(ref.current);\n\n if (visibility !== newRefElementVisibility) {\n // When visibility of an element changes, then the new visibility of the element can only be checked after the\n // component has rendered. That's why the visibility check is inside the useEffect. This useEffect will cause\n // the consumer to rerender and that will cause the above hook to recalculate the dimensions\n setVisibility(newRefElementVisibility);\n }\n });\n\n React.useEffect(() => {\n if (dependencies) {\n setDimensions(ref.current?.getBoundingClientRect());\n }\n }, dependencies);\n\n return dimensions;\n};\n","import React from 'react';\n\n// merges an external ref (optional) with an internal ref (required)\nexport const useMergedRef = <T extends HTMLElement>(ref: React.Ref<HTMLElement>): React.RefObject<T> => {\n const internalRef = React.useRef<T>(null);\n\n React.useEffect(() => {\n if (ref) {\n if (typeof ref === 'function') {\n ref(internalRef.current);\n } else {\n (ref as React.MutableRefObject<HTMLElement | null>).current = internalRef.current;\n }\n }\n }, [ref]);\n\n return internalRef;\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Icon, IconName } from '../Icon/Icon';\nimport { getButtonStateClasses, getInputClasses } from './util';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { useMergedRef } from '../../hooks/useMergedRef';\n\nexport type InputWithoutDeprecatedFeaturesProps = Omit<React.InputHTMLAttributes<HTMLInputElement>, 'prefix'> & {\n /** Draws attention to the input by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n postfix?: string | JSX.Element;\n prefix?: string | JSX.Element;\n};\n\nconst validSetSelectionRangeTypes = ['text', 'search', 'url', 'tel', 'password'];\n\nconst InputWithoutDeprecatedFeatures = React.forwardRef(function InputWithoutDeprecatedFeatures(\n props: InputWithoutDeprecatedFeaturesProps,\n ref: React.Ref<HTMLInputElement>\n) {\n const { highlighted, invalid, onKeyDown, postfix, prefix, type = 'text', ...attributes } = props;\n const internalRef = useMergedRef<HTMLInputElement>(ref);\n\n let handleKeyDown = onKeyDown;\n\n // home and end keys only navigate to the start/end of input value if the input container does not scroll\n // if it has scroll height then the browser reverts to native scrolling behaviour only\n // so we manually override it to ensure _our_ desired behaviour remains intact\n // only the 'text', 'search', 'url', 'tel', 'password' input types support setSelectionRange\n if (validSetSelectionRangeTypes.includes(type)) {\n handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (!event.shiftKey && (event.key === 'Home' || event.key === 'End')) {\n event.preventDefault();\n const position = event.key === 'End' ? event.currentTarget.value.length : 0;\n event.currentTarget.setSelectionRange(position, position);\n }\n\n if (typeof onKeyDown === 'function') {\n onKeyDown(event);\n }\n };\n }\n\n const prefixRef = React.useRef<HTMLDivElement>(null);\n const prefixRect = useBoundingClientRectListener(prefixRef);\n const postfixRef = React.useRef<HTMLDivElement>(null);\n const postfixRect = useBoundingClientRectListener(postfixRef);\n\n const className = cn(\n getInputClasses(props),\n {\n 'pl-8': !!prefix,\n 'pr-8': !!postfix,\n },\n attributes.className\n );\n\n return (\n <div className=\"relative inline-flex w-full\" data-taco=\"input-container\" style={{ opacity: 0.999 }}>\n <input\n {...attributes}\n className={className}\n data-taco=\"input\"\n onKeyDown={handleKeyDown}\n ref={internalRef}\n style={{\n paddingLeft: prefixRect ? `${prefixRect.width - 1}px` : undefined,\n paddingRight: postfixRect ? `${postfixRect.width - 1}px` : undefined,\n }}\n type={type}\n />\n {prefix ? <Affix type=\"prefix\" children={prefix} disabled={attributes.disabled} ref={prefixRef} /> : null}\n {postfix ? <Affix type=\"postfix\" children={postfix} disabled={attributes.disabled} ref={postfixRef} /> : null}\n </div>\n );\n});\n\ntype AffixProps = {\n children?: string | JSX.Element;\n disabled?: boolean;\n type: 'prefix' | 'postfix';\n};\nconst Affix = React.memo(\n React.forwardRef(function Affix(props: AffixProps, ref: React.Ref<HTMLDivElement>) {\n const { children, disabled, type } = props;\n\n if (children) {\n return (\n <div\n className={cn(\n 'group absolute top-0 flex h-full items-center justify-center px-2',\n // icon\n '[&_[data-taco=\"icon\"]]:!h-5 [&_[data-taco=\"icon\"]]:!w-5',\n {\n 'text-grey-300': disabled,\n 'text-grey-700': !disabled,\n 'left-0 [&>button]:!-ml-2': type === 'prefix',\n 'right-0 [&>button]:!-mr-2': type === 'postfix',\n }\n )}\n ref={ref}>\n {children}\n </div>\n );\n }\n\n return null;\n })\n);\n\nexport type InputProps = InputWithoutDeprecatedFeaturesProps & {\n /** Shows a button within the input field */\n button?: React.ReactElement;\n /** Shows an icon within the input field */\n icon?: IconName | JSX.Element;\n};\n\nexport const Input = React.forwardRef(function LegacyInput(props: InputProps, ref: React.Ref<HTMLInputElement>) {\n const { button, icon, ...attributes } = props;\n\n let postfix;\n\n if (button) {\n const disabled = button.props.disabled || attributes.disabled;\n const buttonClassName = cn(\n 'items-center focus:z-10 flex justify-center rounded-l-none rounded-r h-full focus:rounded focus:outline-none',\n getButtonStateClasses(attributes.invalid),\n button.props.className\n );\n postfix = React.cloneElement(button, {\n className: buttonClassName,\n disabled,\n });\n } else if (icon) {\n postfix = typeof icon === 'string' ? <Icon name={icon} /> : icon;\n }\n\n return <InputWithoutDeprecatedFeatures {...attributes} postfix={attributes.postfix ?? postfix} ref={ref} />;\n});\n","import React from 'react';\nimport { Orientation } from '../../types';\n\nexport const getNextIndexFromKey = (\n key: string,\n length: number,\n index: number | undefined,\n direction: Orientation = 'vertical'\n): number | undefined => {\n const previousKey = direction === 'horizontal' ? 'ArrowLeft' : 'ArrowUp';\n const nextKey = direction === 'horizontal' ? 'ArrowRight' : 'ArrowDown';\n\n switch (key) {\n case previousKey:\n return index !== undefined ? (index - 1 < 0 ? 0 : index - 1) : index;\n\n case nextKey:\n return index !== undefined ? (index + 1 >= length ? index : index + 1) : index;\n\n case 'Home':\n return 0;\n\n case 'End':\n return length - 1;\n\n default:\n return;\n }\n};\n\nexport type useListKeyboardNavigationOptions = {\n direction?: Orientation;\n initialIndex?: number;\n};\n\nexport const useListKeyboardNavigation = (\n length = 0,\n options: useListKeyboardNavigationOptions = {\n direction: 'vertical',\n }\n): [number | undefined, (index: number | undefined) => void, (event: React.KeyboardEvent<HTMLElement>) => number | undefined] => {\n const [index, setIndex] = React.useState<number | undefined>(options.initialIndex);\n\n const getNextIndex = (event: React.KeyboardEvent<HTMLElement>): number | undefined => {\n const nextIndex = getNextIndexFromKey(event.key, length, index, options.direction);\n\n if (nextIndex !== undefined) {\n event.preventDefault();\n }\n\n return nextIndex;\n };\n\n return [index, setIndex, getNextIndex];\n};\n","const scrollToChildElement = (parent: HTMLElement, child: HTMLElement): void => {\n const clientHeight = parent.clientHeight;\n\n if (parent.scrollHeight > clientHeight) {\n const scrollTop = parent.scrollTop;\n const scrollBottom = clientHeight + scrollTop;\n const childBottom = child.offsetTop + child.offsetHeight;\n\n if (childBottom > scrollBottom) {\n parent.scrollTop = childBottom - clientHeight;\n } else if (child.offsetTop < scrollTop) {\n parent.scrollTop = child.offsetTop;\n }\n }\n};\n\nexport const useListScrollTo = (internalRef: any, itemRefs: any[]): any => {\n const scrollTo = (index: number | undefined): void => {\n if (internalRef && internalRef.current) {\n if (index !== undefined) {\n const activeRef = itemRefs[index];\n\n if (activeRef && activeRef.current) {\n scrollToChildElement(internalRef.current, activeRef.current);\n }\n } else {\n internalRef.current.scrollTop = 0;\n }\n }\n };\n\n return { scrollTo };\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport './Spinner.css';\n\nexport type SpinnerProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * Define a delay in milliseconds after which the spinner is shown.\n * Default value is `500`ms\n */\n delay?: number;\n /** Define a text that will be displayed below spinner */\n label?: string;\n};\n\nexport const Spinner = React.forwardRef(function Spinner(props: SpinnerProps, ref: React.Ref<HTMLDivElement>) {\n const { delay = 500, label, ...otherProps } = props;\n const [visible, setVisibility] = React.useState(!delay);\n\n React.useEffect(() => {\n let timeout: number;\n\n if (delay) {\n timeout = window.setTimeout(() => setVisibility(true), delay);\n }\n\n return () => {\n if (timeout) {\n clearTimeout(timeout);\n }\n };\n }, [delay]);\n\n if (!visible) {\n return null;\n }\n\n const className = cn('inline-flex flex-col relative items-center', otherProps.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"spinner\" ref={ref}>\n <svg\n className=\"h-10 w-10 animate-[spinnerRotation_2s_linear_infinite]\"\n viewBox=\"0 0 100 100\"\n xmlns=\"http://www.w3.org/2000/svg\">\n <circle cx=\"50\" cy=\"50\" r=\"45\"></circle>\n </svg>\n {label && <span className=\"mt-4\">{label}</span>}\n </div>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { getNextIndexFromKey } from '../../utils/hooks/useListKeyboardNavigation';\nimport { useListScrollTo } from '../../utils/hooks/useListScrollTo';\nimport './ScrollableList.css';\nimport { Spinner } from '../Spinner/Spinner';\nimport { useLocalization } from '../Provider/Localization';\nimport { Checkbox } from '../Checkbox/Checkbox';\nimport { getInputClasses } from '../Input/util';\n\nexport type ScrollableListItemValue = string | number | boolean | null;\n\nexport type ScrollableListItem = {\n /**\n * Set whether the item is disabled.\n * This will both change the style and make the item unselectable\n */\n disabled?: boolean;\n /* Specifies whether the item has child items -- intended for internal use only */\n hasChildren?: boolean;\n /** Place an icon before the item's text */\n icon?: React.ReactElement;\n /* The index path to the item -- intended for internal use only */\n path?: string;\n /** Text describing the item */\n text: string | JSX.Element;\n /** Value of the item */\n value: ScrollableListItemValue;\n /** Child items to show hierarchical data */\n children?: ScrollableListItem[];\n};\n\n/** @internal */\nexport type ScrollableListProps = Omit<\n React.HTMLAttributes<HTMLUListElement>,\n 'defaultValue' | 'id' | 'onChange' | 'onClick' | 'onKeyDown'\n> & {\n /** Data indicating the options in scrollable list */\n data: ScrollableListItem[];\n /** Sets the list to be disabled */\n disabled?: boolean;\n /** Draws attention to the scrollable list by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Set an id for the scrollable list */\n id: string;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in `Provider` component.\n */\n loading?: boolean;\n /**\n * Handler called when current active/selected option changes in a scrollable list.\n * @param index indicates the index of the current active option\n */\n onChange: (index: number) => void;\n /** Handler called when option is clicked */\n onClick?: (event: React.MouseEvent<HTMLLIElement>, index: number) => void;\n /**\n * Set whether the selected item should be scrolled into view when listbox is focused.\n * Default value is `false`\n */\n scrollOnFocus?: boolean;\n /** Handler called when a key is pressed */\n onKeyDown?: (event: React.KeyboardEvent<HTMLUListElement>, index: number | undefined) => void;\n /* Sets the list to read only mode */\n readOnly?: boolean;\n /**\n * Value of the scrollable list representing the selected item.\n * It needs to be an existing value from the provided data.\n */\n value: number | undefined;\n /**\n * Allows to select multiple items from the list\n */\n multiselect?: boolean;\n /**\n * Contains the currently selected values when multiselect mode is ON.\n */\n selectedIndexes?: number[];\n /**\n * True when all available (not disabled) options are selected\n */\n allOptionsSelected?: boolean;\n};\n\n/** @internal */\nexport type ScrollableListPropsWithRef = ScrollableListProps & React.RefAttributes<HTMLUListElement>;\n\nexport const getId = (id: string, value: ScrollableListItemValue): string => `${id}_${value}`;\n\nconst getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n data: ScrollableListItem[],\n index: number | undefined\n): number | undefined => {\n const nextIndex = getNextIndexFromKey(event.key, data.length, index);\n\n if (nextIndex) {\n if (nextIndex === index) {\n return index;\n } else if (data[nextIndex] && data[nextIndex].disabled) {\n return getNextEnabledItem(event, data, nextIndex);\n }\n }\n\n return nextIndex;\n};\n\nexport const ScrollableList = React.forwardRef(function ScrollableList(\n props: ScrollableListProps,\n ref: React.Ref<HTMLUListElement>\n) {\n const {\n data,\n disabled,\n highlighted,\n id,\n invalid: _,\n loading,\n onChange: setCurrentIndex,\n onClick,\n onFocus,\n onKeyDown,\n readOnly,\n scrollOnFocus = false,\n value: currentIndex,\n multiselect,\n selectedIndexes = [],\n allOptionsSelected = false,\n ...otherProps\n } = props;\n const listRef = useMergedRef<HTMLUListElement>(ref);\n const itemRefs = React.useMemo(() => data.map(() => React.createRef<HTMLLIElement>()), [data]);\n const { texts } = useLocalization();\n const { scrollTo } = useListScrollTo(listRef, itemRefs);\n\n React.useEffect(() => {\n if (currentIndex && itemRefs[currentIndex]?.current) {\n itemRefs[currentIndex].current?.scrollIntoView({\n block: 'center',\n });\n }\n }, []);\n\n React.useEffect(() => {\n scrollTo(currentIndex);\n }, [currentIndex]);\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLUListElement>): void => {\n const nextIndex = getNextEnabledItem(event, data, currentIndex);\n\n if (nextIndex !== undefined && nextIndex !== currentIndex) {\n event.preventDefault();\n scrollTo(nextIndex);\n setCurrentIndex(nextIndex);\n }\n\n if (onKeyDown) {\n event.persist();\n const index = nextIndex !== undefined ? nextIndex : currentIndex;\n onKeyDown(event, index);\n }\n };\n\n const handleClick = (index: number) => (event: React.MouseEvent<HTMLLIElement>) => {\n setCurrentIndex(index);\n\n if (onClick) {\n event.persist();\n onClick(event, index);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLUListElement>): void => {\n if (scrollOnFocus) {\n scrollTo(currentIndex);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const getOptionCheckedState = (optionValue: string, index: number): boolean => {\n if (optionValue === '#ALL-OPTIONS#') {\n return allOptionsSelected;\n } else if (!optionValue || !selectedIndexes) {\n return false;\n } else {\n return selectedIndexes.findIndex(i => i === index) !== -1;\n }\n };\n\n const options = data.map((option, index) => {\n const depth = option.path ? option.path.split('.').length - 1 : 0;\n\n return {\n 'aria-selected': multiselect ? getOptionCheckedState(String(option.value), index) : currentIndex === index,\n 'data-focused': currentIndex === index,\n children: option.text,\n className: cn(\n 'flex items-center px-3 w-full cursor-pointer bg-white flex-[0_0_2rem] focus:wcag-blue-500 focus:border-blue-500',\n {\n 'sticky top-0 font-bold': depth === 0 && !!option.hasChildren,\n }\n ),\n disabled: option.disabled,\n icon: option.icon,\n id: getId(id, option.value),\n key: getId(id, option.value),\n onClick: !disabled && !readOnly ? handleClick(index) : undefined,\n ref: itemRefs[index],\n role: 'option',\n style:\n depth > 0\n ? {\n paddingLeft: `${depth + 1}rem`,\n }\n : undefined,\n };\n });\n\n const list: React.HTMLAttributes<HTMLUListElement> &\n React.RefAttributes<HTMLUListElement> & { disabled?: boolean; readOnly?: boolean } = {\n ...otherProps,\n className: cn(\n 'inline-flex flex-col list-none !p-0 m-0 overflow-y-auto h-auto',\n getInputClasses(props),\n {\n 'yt-list--multiselect': multiselect,\n 'pointer-events-none': disabled,\n 'cursor-not-allowed': disabled || readOnly,\n },\n otherProps.className\n ),\n disabled,\n id,\n onFocus: !disabled && !readOnly ? handleFocus : undefined,\n onKeyDown: !disabled && !readOnly ? handleKeyDown : undefined,\n readOnly,\n ref: listRef,\n role: options.length <= 0 || loading ? 'presentation' : 'listbox',\n tabIndex: otherProps.tabIndex || 0,\n };\n\n return (\n <ul {...list} data-taco=\"scrollable-list\">\n {loading ? (\n <li className=\"yt-list__empty\">\n <span>\n <Spinner delay={0} />\n </span>\n <span>{texts.listbox.loading}</span>\n </li>\n ) : options.length ? (\n options.map(({ children, icon, ...optionProps }) => (\n <li {...optionProps}>\n {icon}\n <span className=\"flex-grow truncate text-left\">{children}</span>\n {multiselect && (\n <Checkbox\n // In multiselect variant, this checkbox only acts as visual representation of item being selected,\n // so need to be taken out of screen reader scope.\n aria-hidden\n tabIndex={-1}\n checked={optionProps['aria-selected']}\n onChange={() => null}\n className=\"pointer-events-none ml-2 self-center p-px\"\n />\n )}\n </li>\n ))\n ) : (\n <li className=\"yt-list__empty\">\n <span>{texts.listbox.empty}</span>\n </li>\n )}\n </ul>\n );\n});\n","// returns a custom event compatible with all browsers\nexport const createCustomEvent = (eventType: string) => {\n let customEvent;\n\n if (typeof Event === 'function') {\n customEvent = new Event(eventType, { bubbles: true });\n } else {\n customEvent = document.createEvent('Event');\n customEvent.initEvent(eventType, true, true);\n }\n return customEvent;\n};\n\n// returns a custom keyboard event compatible with all browsers\nexport const createCustomKeyboardEvent = (event: React.KeyboardEvent<HTMLInputElement>) => {\n let customKeyboardEvent;\n\n if (typeof KeyboardEvent === 'function') {\n customKeyboardEvent = new KeyboardEvent(event.type, event as any);\n } else {\n customKeyboardEvent = document.createEvent('Event') as any;\n customKeyboardEvent.initEvent(event.type, true, true);\n customKeyboardEvent.key = event.key;\n customKeyboardEvent.charCode = event.charCode;\n }\n\n return customKeyboardEvent;\n};\n\nexport const setInputValueByRef = (input: HTMLInputElement | null, value: string | undefined, event = 'change'): void => {\n if (!input) {\n return;\n }\n\n const previousValue = input.value;\n input.value = value || '';\n\n const tracker = (input as any)._valueTracker;\n\n if (tracker) {\n tracker.setValue(previousValue);\n }\n\n // 'change' instead of 'input', see https://github.com/facebook/react/issues/11488#issuecomment-381590324\n input.dispatchEvent(createCustomEvent(event));\n};\n","import React from 'react';\nimport { ScrollableListItem, ScrollableListItemValue, getId } from './ScrollableList';\nimport { setInputValueByRef as setInputValueByRefBase } from '../../utils/input';\n\nconst getValue = (value: ScrollableListItemValue | undefined): string => String(value ?? '');\n\nexport const setInputValueByRef = (input: HTMLInputElement | null, value: ScrollableListItemValue, event = 'change'): void => {\n setInputValueByRefBase(input, getValue(value), event);\n};\n\nexport const getIndexFromValue = (data: ScrollableListItem[], value: ScrollableListItemValue | undefined): number | undefined => {\n const index = data.findIndex(option => getValue(option.value) === getValue(value));\n return index > -1 ? index : undefined;\n};\n\nexport const getSelectedIndexesFromValue = (data: ScrollableListItem[], value: ScrollableListItemValue | undefined): number[] => {\n if (typeof value !== 'string') return [];\n\n return value\n .split(',')\n .map(v => data.findIndex(o => String(o.value) === v))\n .filter(v => v !== -1);\n};\n\nexport const findByValue = (data: ScrollableListItem[], value: ScrollableListItemValue): ScrollableListItem | undefined => {\n return data.find(option => getValue(option.value) === getValue(value));\n};\n\nexport const searchForString = (child: JSX.Element | string, value: string, strategy = 'includes'): boolean => {\n try {\n if (typeof child !== 'string' && child.props?.children) {\n if (Array.isArray(child.props?.children)) {\n return !!child.props.children.find((subChild: JSX.Element | string) =>\n searchForString(subChild, value, strategy)\n );\n }\n\n return searchForString(child.props?.children, value, strategy);\n } else {\n return child.toString().toLowerCase()[strategy](String(value).toLowerCase());\n }\n } catch {\n return false;\n }\n};\n\nconst getIndexInRangeByValue = (\n data: ScrollableListItem[],\n query: string,\n firstIndex: number,\n lastIndex: number = data.length\n): number => {\n const index = data.slice(firstIndex, lastIndex).findIndex(option => {\n if (option.disabled) {\n return false;\n }\n\n return searchForString(option.text, query, 'startsWith');\n });\n\n return index > -1 ? index + firstIndex : -1;\n};\n\nexport const findNextIndexByValue = (data: ScrollableListItem[], query: string, activeIndex: number | undefined): number => {\n const firstIndex = activeIndex === undefined ? 0 : activeIndex + 1;\n let index = getIndexInRangeByValue(data, query, firstIndex);\n\n if (index === -1) {\n index = getIndexInRangeByValue(data, query, 0, activeIndex);\n }\n\n return index;\n};\n\nexport const getActiveDescendant = (data: ScrollableListItem[], currentIndex: number | undefined, id: string): any => {\n return currentIndex !== undefined && data[currentIndex] ? getId(id, data[currentIndex].value) : undefined;\n};\n\nexport const useFlattenedData = (data: ScrollableListItem[]): ScrollableListItem[] => {\n return React.useMemo(() => {\n const items: ScrollableListItem[] = [];\n\n const flatten = (item: ScrollableListItem, path: number, parentPath?: string, parentDisabled?: boolean) => {\n const currentPath = parentPath ? `${parentPath}.${path}` : `${path}`;\n const isItemDisabled = parentDisabled || item.disabled;\n\n items.push({\n ...item,\n disabled: isItemDisabled,\n path: currentPath,\n hasChildren: !!item.children,\n });\n\n if (item.children) {\n item.children.forEach((childItem: ScrollableListItem, childPath: number) =>\n flatten(childItem, childPath, currentPath, isItemDisabled)\n );\n }\n };\n\n data.forEach((item, index) => {\n flatten(item, index);\n });\n\n return items;\n }, [data]);\n};\n\nexport const sanitizeItem = (item: ScrollableListItem | undefined) => {\n if (item) {\n const { hasChildren: _1, path: _2, ...rest } = item;\n return rest;\n }\n\n return undefined;\n};\n\nexport const getOptionParents = (data: ScrollableListItem[], path?: string) => {\n const indexes = path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n return indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(data.find((i: ScrollableListItem) => i.path === lastPath));\n });\n }\n\n return null;\n};\n\nexport const filterData = (data: ScrollableListItem[], value: ScrollableListItemValue = ''): ScrollableListItem[] => {\n if (value === '' || value === null) {\n return data;\n }\n\n const filteredOptionValues = new Set();\n const shouldFilterOption = (option: ScrollableListItem): boolean => {\n if (option.disabled) {\n return false;\n }\n\n return searchForString(option.text, String(value));\n };\n\n data.forEach(option => {\n if (shouldFilterOption(option)) {\n const parents = getOptionParents(data, option.path);\n\n filteredOptionValues.add(option.value);\n\n if (parents !== null) {\n parents.forEach(option => filteredOptionValues.add(option?.value));\n }\n }\n });\n\n return data.filter(({ value }) => filteredOptionValues.has(value));\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport debounce from 'lodash/debounce';\nimport { ComboboxProps } from './Combobox';\nimport {\n setInputValueByRef,\n getIndexFromValue,\n findByValue,\n useFlattenedData,\n sanitizeItem,\n getOptionParents,\n filterData,\n} from '../Listbox/util';\nimport { createCustomKeyboardEvent } from '../../utils/input';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { getId, ScrollableListItemValue, ScrollableListPropsWithRef } from '../Listbox/ScrollableList';\nimport { InputProps } from '../Input/Input';\n\nconst debouncer = debounce(f => f(), 200);\n\nconst convertToInputValue = (value: ScrollableListItemValue | undefined) => String(value ?? '');\n\ntype useCombobox = React.HTMLAttributes<HTMLDivElement> & {\n combobox: React.HTMLAttributes<HTMLSpanElement>;\n input: Omit<InputProps, 'defaultValue'> & { ref: React.RefObject<HTMLInputElement> };\n list: ScrollableListPropsWithRef;\n button: { ref: any };\n popover: { open: boolean; onOpenChange: (open: boolean) => void };\n};\n\nexport const useCombobox = (\n {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data: unfilteredData = [],\n defaultValue,\n disabled,\n id: nativeId,\n inline,\n loading: __,\n onChange,\n onClick,\n onKeyDown,\n onSearch,\n readOnly,\n value,\n ...props\n }: Omit<ComboboxProps, 'dialog'>,\n ref: React.Ref<HTMLInputElement>\n): useCombobox => {\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const buttonRef = React.useRef<HTMLButtonElement>(null);\n const listRef = React.useRef<HTMLUListElement>(null);\n const [open, setOpen] = React.useState(false);\n const listId = React.useMemo(() => uuid(), []);\n const [inputValue, setInputValue] = React.useState<string>(convertToInputValue(value));\n const shouldFilterData = !onSearch && (!inline || (inline && inputValue !== convertToInputValue(value)));\n const flattenedData = useFlattenedData(unfilteredData);\n const data = React.useMemo(\n () => (shouldFilterData ? filterData(flattenedData, inputValue) : flattenedData),\n [shouldFilterData, inputValue, flattenedData]\n );\n // listbox/select change value _with_ the index, but combobox changes on select of an index (click/enter), so we need state\n const [currentIndex, setCurrentIndex] = React.useState<number | undefined>(\n inputValue !== undefined ? getIndexFromValue(data, inputValue) : undefined\n );\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n setInputValueByRef(inputRef.current, option.value, 'focusout');\n }\n }\n };\n\n const setCurrentValue = (index: number | undefined) => {\n if (index === undefined) {\n return;\n }\n\n const option = data[index];\n\n // if the selected option is not already selected, trigger blur event\n if (option.value !== value) {\n setInputValueByIndex(index);\n } else {\n // if the selected option is already selected, refill input with its value\n setInputValue(convertToInputValue(value));\n }\n };\n\n // ensure the external value is synced with the internal value when mounting, e.g. incase a default value was set\n React.useEffect(() => {\n if (defaultValue && !value) {\n setInputValueByIndex(getIndexFromValue(data, defaultValue));\n }\n }, [data]);\n\n // update input value if it changed 'externally', e.g. clicking/entering an item in the listbox, from a modal etc\n React.useEffect(() => {\n if (value !== undefined && value !== inputValue) {\n setInputValue(convertToInputValue(value));\n }\n }, [value]);\n\n React.useEffect(() => {\n if (onSearch) {\n debouncer(() => {\n onSearch(inputValue);\n });\n }\n }, [inputValue]);\n\n // show listbox based on input value\n React.useEffect(() => {\n // don't show the popover if the internal (input) value already is the current value\n // this prevents the popover showing after selecting a value or pressing escape\n const isCurrentValue = value !== undefined && value !== null && inputValue === String(value);\n\n if (inputValue && data.length && !isCurrentValue) {\n setCurrentIndex(0);\n\n if (!open) {\n setOpen(true);\n }\n } else {\n setOpen(false);\n }\n }, [inputValue, data]);\n\n React.useEffect(() => {\n if (open) {\n setCurrentIndex(getIndexFromValue(data, inputValue) || 0);\n } else {\n setCurrentIndex(undefined);\n }\n }, [open]);\n\n // event handlers\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (event.relatedTarget === listRef.current) {\n event.preventDefault();\n return;\n }\n\n if (onChange && event.target.value !== value) {\n const item = findByValue(flattenedData, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const parents = getOptionParents(flattenedData, item?.path);\n\n if (parents !== null && parents.length > 0) {\n (event as any).detail.parents = parents;\n }\n\n onChange(event);\n }\n\n if (props.onBlur) {\n props.onBlur(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n setInputValue(event.target.value);\n };\n\n const handleInputClick = (event: React.MouseEvent<HTMLInputElement>): void => {\n if (inline || (!open && inputValue && data.length)) {\n setOpen(true);\n }\n\n if (onClick) {\n event.persist();\n onClick(event);\n }\n };\n\n const handleInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\n event.persist();\n\n switch (event.key) {\n case 'Backspace': {\n return;\n }\n\n case 'Escape': {\n event.preventDefault();\n setInputValue(convertToInputValue(value));\n setOpen(false);\n return;\n }\n\n case 'Tab':\n case 'Enter': {\n if (event.key !== 'Tab') {\n event.preventDefault();\n }\n\n setCurrentValue(currentIndex);\n setOpen(false);\n return;\n }\n\n case 'ArrowDown':\n if (open) {\n event.preventDefault();\n } else {\n if (!inline && buttonRef.current) {\n buttonRef.current.click();\n }\n }\n break;\n\n case 'ArrowUp':\n case 'Home':\n case 'End': {\n if (open) {\n event.preventDefault();\n }\n break;\n }\n\n default:\n }\n\n // we aren't focused on the list, so manually forward the keydown event to it\n if (listRef.current) {\n listRef.current.dispatchEvent(createCustomKeyboardEvent(event));\n }\n\n if (inline && !open) {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {\n event.preventDefault();\n const initialIndex = event.key === 'ArrowUp' ? data.length - 1 : 0;\n setCurrentIndex(currentIndex !== undefined ? currentIndex : initialIndex);\n setOpen(true);\n }\n }\n\n if (!event.isDefaultPrevented() && onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxChange = (index: number): void => {\n setCurrentIndex(index);\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>, index: number): void => {\n event.preventDefault();\n setCurrentValue(index);\n setOpen(false);\n };\n\n const combobox = {\n 'aria-expanded': open,\n 'aria-owns': listId,\n 'aria-haspopup': 'listbox' as const,\n role: 'combobox',\n };\n\n const input = {\n ...props,\n 'aria-controls': listId,\n // Indicates that the autocomplete behavior of the text input is to suggest a list of possible values in a popup and that the suggestions\n // are related to the string that is present in the textbox\n 'aria-autocomplete': 'list' as const,\n // Enables assistive technologies to know which element the application regards as focused while DOM focus remains on the input element\n 'aria-activedescendant':\n currentIndex !== undefined && data[currentIndex] ? getId(listId, String(data[currentIndex].value)) : undefined,\n 'aria-labelledby': ariaLabelledBy,\n disabled,\n onBlur: !disabled && !readOnly ? handleInputBlur : undefined,\n onChange: !disabled && !readOnly ? handleInputChange : undefined,\n onClick: !disabled && !readOnly ? handleInputClick : undefined,\n onKeyDown: !disabled && !readOnly ? handleInputKeyDown : undefined,\n readOnly,\n ref: inputRef,\n type: 'text',\n value: inputValue ?? '',\n };\n\n const list: ScrollableListPropsWithRef = {\n 'aria-labelledby': ariaLabelledBy,\n data,\n disabled,\n id: listId,\n onChange: handleListboxChange,\n onClick: handleListboxClick,\n ref: listRef,\n scrollOnFocus: false,\n tabIndex: -1,\n value: currentIndex,\n };\n\n const button = {\n ref: buttonRef,\n };\n\n return {\n combobox,\n input,\n list,\n button,\n popover: {\n open,\n onOpenChange: setOpen,\n //visible: !data.length ? false : open,\n },\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Input, InputProps } from '../Input/Input';\nimport { useCombobox } from './useCombobox';\nimport { ScrollableList, ScrollableListItem, ScrollableListItemValue } from '../Listbox/ScrollableList';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { IconButton } from '../IconButton/IconButton';\nimport './Combobox.css';\nimport { DialogProps } from '../Dialog/Dialog';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type ComboboxTexts = {\n /* Tooltip shown for the dialog button */\n tooltip: string;\n};\n\nexport type ComboboxItem = ScrollableListItem;\nexport type ComboboxValue = ScrollableListItemValue;\n\ntype ComboboxBaseProps = Omit<InputProps, 'defaultValue' | 'button' | 'onChange' | 'value'> & {\n /** Array of options in combobox */\n data?: ComboboxItem[];\n /**\n * Initial value of the input in combobox.\n * This is used when combobox is mounted, if no value is provided.\n * *Note* that combobox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ComboboxValue;\n /** Set what value should have an empty option in combobox */\n emptyValue?: ComboboxValue;\n /** Draws attention to the combobox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /** Displays loading state in listbox */\n loading?: boolean;\n /**\n * Handler called when user chooses an option from the provided suggestions.\n * Suggestions will be calculated based on the input value.\n * There are two ways to choose an option: either click on it, or navigate using keyboard and press `enter`\n */\n onChange?: React.ChangeEventHandler<HTMLInputElement>;\n /** Handler called when the user enters a query **/\n onSearch?: (query: string) => void | Promise<void>;\n /** Value of the input in combobox */\n value?: ComboboxValue;\n};\n\ninterface InlineComboboxProps extends ComboboxBaseProps {\n dialog?: never;\n /**\n * Combobox will display its data when input is clicked/focused, even if the input is empty.\n * *Note* that default combobox will display matching data only when user starts typing in input.\n */\n inline: boolean; // Example 3 on https://www.w3.org/TR/wai-aria-practices/examples/combobox/aria1.1pattern/listbox-combo.html\n}\n\ninterface DialogComboboxProps extends ComboboxBaseProps {\n dialog: (props: Partial<DialogProps>) => JSX.Element;\n inline?: never;\n}\n\nexport type ComboboxProps = InlineComboboxProps | DialogComboboxProps;\n\nexport const Combobox = React.forwardRef(function Combobox(props: ComboboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, dialog, style, ...otherProps } = props;\n const { combobox, button, input, popover, list } = useCombobox(otherProps, ref);\n const internalRef = React.useRef<HTMLDivElement>(null);\n const { texts } = useLocalization();\n const selectDimensions = useBoundingClientRectListener(internalRef);\n const className = cn(\n 'inline-flex relative',\n {\n 'yt-combobox--inline': props.inline,\n },\n externalClassName\n );\n\n return (\n <span className={className} data-taco=\"combobox\" style={style}>\n <PopoverPrimitive.Root {...popover}>\n <PopoverPrimitive.Anchor asChild ref={internalRef}>\n <div {...combobox} className=\"inline w-full\" ref={ref}>\n <Input\n {...input}\n autoComplete=\"off\"\n button={\n props.inline ? (\n <IconButton\n // In case of inline combobox, this icon button acts only as visual chevron representation,\n // so should be taken out of screen reader scope.\n aria-hidden\n appearance=\"discrete\"\n className=\"!border-l-0 focus:!border-none focus:!shadow-none active:!border-none\"\n icon={popover.open ? 'chevron-up' : 'chevron-down'}\n onClick={() => {\n popover.onOpenChange(true);\n input.ref.current?.focus();\n }}\n tabIndex={-1}\n />\n ) : dialog ? (\n <IconButton\n aria-label={texts.combobox.tooltip}\n icon=\"list-search\"\n disabled={props.readOnly || props.disabled}\n dialog={dialog}\n onFocus={(event: React.FocusEvent<HTMLButtonElement>) => {\n // Prevents the default focus behaviour of showing the tooltip, on parent tooltip element\n event.preventDefault();\n input.ref.current?.focus();\n }}\n ref={button.ref}\n tabIndex={-1}\n tooltip={texts.combobox.tooltip}\n />\n ) : undefined\n }\n />\n </div>\n </PopoverPrimitive.Anchor>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n align=\"start\"\n onOpenAutoFocus={event => {\n event.preventDefault();\n }}\n sideOffset={4}>\n <ScrollableList\n {...list}\n className={cn('max-h-[calc(12rem+2px)] w-auto max-w-[theme(spacing.96)] !border-blue-500')}\n style={{ minWidth: selectDimensions?.width }}\n tabIndex={popover.open ? 0 : -1}\n />\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n </span>\n );\n});\n","import { isDate, toDate, isValid } from 'date-fns';\n\nexport const format = (date: Date | undefined, mask = 'dd.mm.yy'): string | undefined => {\n if (!date) {\n return undefined;\n }\n\n const value = isDate(date) ? date : toDate(date);\n\n if (!isValid(value)) {\n return undefined;\n }\n\n const pad = (v: number): string => (String(v).length === 1 ? `0${v}` : v.toString());\n\n return mask\n .replace('dd', pad(value.getDate()))\n .replace('mm', pad(value.getMonth() + 1))\n .replace('yy', String(value.getFullYear()).slice(2));\n};\n\nexport const parseFromCustomString = (date = '', mask = 'dd.mm.yy'): Date | undefined => {\n if (!date || !date.length) {\n return undefined;\n }\n\n const sanitizedMask = mask.split(/[^dmy]/);\n const dd = sanitizedMask.findIndex(x => x === 'dd');\n const mm = sanitizedMask.findIndex(x => x === 'mm');\n const yy = sanitizedMask.findIndex(x => x === 'yy' || x === 'yyyy');\n\n let day;\n let month;\n let year;\n\n const getFullYear = (y: string): string => {\n if (y && y.length === 2) {\n const z = Number.parseInt(y, 10);\n\n return z > 50 ? `19${y}` : `20${y}`;\n }\n\n return y;\n };\n\n const inputParts = date.split(/\\D/);\n\n if (inputParts.length === 1) {\n const fullDate = inputParts[0];\n const unseparatedMask = mask.replace(/[^dmy]/g, '');\n\n day = fullDate.slice(unseparatedMask.indexOf('d'), unseparatedMask.lastIndexOf('d') + 1);\n month = fullDate.slice(unseparatedMask.indexOf('m'), unseparatedMask.lastIndexOf('m') + 1);\n year = getFullYear(fullDate.slice(unseparatedMask.indexOf('y'), unseparatedMask.lastIndexOf('y') + 3)); // account for full years\n } else {\n day = inputParts[dd];\n month = inputParts[mm];\n year = getFullYear(inputParts[yy]);\n }\n\n day = Number.parseInt(day, 10);\n month = Number.parseInt(month, 10);\n year = Number.parseInt(year, 10);\n\n const currentDate = new Date();\n\n return new Date(\n /* year */ Object.is(year, NaN) ? currentDate.getFullYear() : year,\n /* month */ Object.is(month, NaN) ? currentDate.getMonth() : month - 1, // months are zero based in javascript, so subtract a day\n /* day */ Object.is(day, NaN) ? currentDate.getDate() : day,\n /* hours */ 12,\n /* minutes */ 0 // set to midday to avoid UTC offset causing dates to be mismatched server side\n );\n};\n\nexport const parseFromISOString = (date: string): Date | undefined => {\n const tempDate = new Date(date);\n return isValid(tempDate) ? parseFromCustomString(format(new Date(date))) : undefined;\n};\n","import * as React from 'react';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\n\nexport const UnstyledArrow = React.forwardRef<SVGSVGElement, React.SVGAttributes<SVGElement>>(function PopoverArrow(props, ref) {\n return (\n <PopoverPrimitive.Arrow className=\"pointer-events-none -mt-px\" asChild offset={2} width={30} height={11}>\n <svg {...props} ref={ref} viewBox=\"0 19 30 11\" style={{ transform: 'rotateZ(180deg)' }}>\n <path\n className=\"text-grey-300 fill-current group-focus:text-blue-300\"\n d=\"M23.7,27.1L17,19.9C16.5,19.3,15.8,19,15,19s-1.6,0.3-2.1,0.9l-6.6,7.2C5.3,28.1,3.4,29,2,29h26 C26.7,29,24.6,28.1,23.7,27.1z\"></path>\n <path\n className=\"fill-current\"\n d=\"M23,27.8c1.1,1.2,3.4,2.2,5,2.2h2H0h2c1.7,0,3.9-1,5-2.2l6.6-7.2c0.7-0.8,2-0.8,2.7,0L23,27.8L23,27.8z\"></path>\n </svg>\n </PopoverPrimitive.Arrow>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from './Primitives';\nimport { mergeRefs } from '../../utils/mergeRefs';\nimport { getPopoverStyleClassnames } from './util';\n\ntype PopoverContextValue = { props: any; ref: React.Ref<HTMLElement> };\n\nconst PopoverContext = React.createContext<PopoverContextValue>({\n props: {},\n ref: null,\n});\n\nexport type PopoverTriggerProps = React.HTMLAttributes<HTMLElement>;\nconst Trigger = React.forwardRef(function PopoverAnchor(props: PopoverTriggerProps, externalRef: React.Ref<HTMLElement>) {\n const { ref: parentRef, props: parentProps } = React.useContext(PopoverContext);\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n let children = props.children;\n\n if (React.isValidElement(props.children) && typeof props.children?.type === 'function') {\n console.warn(\n `Popover.Trigger requires its child to forwardRef so that it can attach to the dom element. Did you mean to wrap '${props.children.type.name}' in React.forwardRef()? Taco has wrapped '${props.children.type.name}' in a 'span' to maintain functionality, but this may cause unintended behaviour`\n );\n children = <span>{props.children}</span>;\n }\n\n return (\n <PopoverPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild>\n {children}\n </PopoverPrimitive.Trigger>\n );\n});\n\nconst RenderPropWrapper = React.forwardRef(function RenderPropWrapper({ children, onClick }: any, ref) {\n const close = () => {\n onClick(new CustomEvent('hide'));\n };\n\n return children({ close, ref });\n});\n\nexport type PopoverContentRenderProps = { close: () => void };\nexport type PopoverContentProps = Omit<PopoverPrimitive.PopoverContentProps, 'side'> & {\n children: React.ReactNode | ((props: PopoverContentRenderProps) => React.ReactNode);\n /** Set the position of the Popover relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\nconst Content = React.forwardRef(function PopoverContent(props: PopoverContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side, ...popoverContentProps } = props;\n const className = cn(getPopoverStyleClassnames(), props.className);\n\n let output;\n\n if (typeof props.children === 'function') {\n output = (\n <PopoverPrimitive.Close asChild>\n <RenderPropWrapper>{props.children}</RenderPropWrapper>\n </PopoverPrimitive.Close>\n );\n } else {\n output = props.children;\n }\n\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n {...popoverContentProps}\n className={className}\n data-taco=\"popover\"\n side={side}\n sideOffset={1}\n ref={ref}>\n {output}\n <UnstyledArrow className=\"text-white\" />\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n );\n});\n\nexport type PopoverCloseProps = React.HTMLAttributes<HTMLButtonElement>;\nconst Close = React.forwardRef(\n (props: PopoverCloseProps, ref: React.Ref<HTMLButtonElement>): JSX.Element => (\n <PopoverPrimitive.Close {...props} ref={ref} asChild />\n )\n);\n\nexport type PopoverProps = React.PropsWithChildren<{\n modal?: boolean;\n /** A trigger to be used for the popover, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n /** Set whether the popover is open by default or not, use when not providing a trigger */\n defaultOpen?: boolean;\n /** Control the open state of the popover from outside the component */\n open?: boolean;\n /** Called when the popover opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n}>;\nexport type ForwardedPopoverWithStatics = React.ForwardRefExoticComponent<PopoverProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<PopoverTriggerProps>;\n Content: React.ForwardRefExoticComponent<PopoverContentProps>;\n Close: React.ForwardRefExoticComponent<PopoverCloseProps>;\n Portal: React.FunctionComponent<PopoverPrimitive.PortalProps>;\n};\n\nexport const Popover = React.forwardRef<HTMLElement, PopoverProps>(function Popover(props, ref) {\n const { children, defaultOpen, modal = false, open, onChange, trigger, ...otherProps } = props;\n const context = React.useMemo(() => ({ props: otherProps, ref }), [otherProps]);\n\n return (\n <PopoverContext.Provider value={context}>\n <PopoverPrimitive.Root defaultOpen={defaultOpen} modal={modal} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {children}\n </PopoverPrimitive.Root>\n </PopoverContext.Provider>\n );\n}) as ForwardedPopoverWithStatics;\nPopover.Trigger = Trigger;\nPopover.Content = Content;\nPopover.Close = Close;\nPopover.Portal = PopoverPrimitive.Portal;\n","export const getPopoverStyleClassnames = () =>\n 'bg-white focus:border-blue-300 border border-transparent rounded p-3 yt-shadow focus:yt-focus outline-none group';\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { Input, InputProps } from '../Input/Input';\nimport { useLocalization } from '../Provider/Localization';\nimport { useDatepicker } from './useDatepicker';\nimport { IconButton } from '../IconButton/IconButton';\nimport { Popover } from '../Popover/Popover';\n\nexport type DatepickerTexts = {\n /** Aria-label for calendar */\n calendar: string;\n /** Clear button text */\n clear: string;\n /**\n * Aria-label for calendar icon button in the input.\n * Calendar will open when user clicks this icon button.\n */\n expand: string;\n /** Shortcut heading text */\n shortcuts: string;\n};\n\nexport type DatePickerShortcut = {\n onClick: (event: React.MouseEvent) => void;\n text: string;\n};\n\nexport type DatepickerProps = Omit<InputProps, 'value'> & {\n /** [Calendar](component:calendar) component associated with the DatePicker */\n calendar?: CalendarProps;\n /** List of shortcuts */\n shortcuts?: DatePickerShortcut[];\n /** Title for the shortcuts panel */\n shortcutsText?: string;\n /** Handler to be called when the clear button is clicked */\n onReset?: (event: React.MouseEvent<HTMLButtonElement>) => void;\n /**\n * Date value of the calendar.\n * This will be displayed in DatePicker's input in the format given to the [Provider](component:provider) component\n */\n value?: Date;\n};\n\nexport const Datepicker = React.forwardRef(function Datepicker(props: DatepickerProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, onReset: handleReset, style, shortcuts, shortcutsText, ...otherProps } = props;\n const { calendar, input } = useDatepicker(otherProps, ref);\n const { texts } = useLocalization();\n const className = cn('inline-flex w-full text-black font-normal', externalClassName);\n\n return (\n <span className={className} data-taco=\"datepicker\" style={style}>\n <Input\n {...input}\n button={\n <IconButton\n aria-label={texts.datepicker.expand}\n disabled={input.disabled || input.readOnly}\n icon=\"calendar\"\n popover={props => (\n <Popover {...props}>\n <Popover.Content>\n {({ close }) => (\n <div className=\"-m-3 flex\">\n <Calendar\n {...calendar}\n onChange={(date: Date, event?: React.MouseEvent<HTMLDivElement>) => {\n calendar.onChange(date, event);\n close();\n }}\n tabIndex={-1}\n />\n {shortcuts && (\n <div className=\"border-grey-300 flex flex-col border-l\">\n <span className=\"m-4 mb-3 flex h-8 w-32 items-center text-xs font-semibold\">\n {shortcutsText ?? texts.datepicker.shortcuts}\n </span>\n <ul>\n {shortcuts.map(shortcut => (\n <li key={shortcut.text}>\n <button\n type=\"button\"\n className=\"hover:wcag-grey-200 flex w-full items-start px-4 py-1 text-xs\"\n onClick={event => {\n event.persist();\n shortcut.onClick(event);\n close();\n }}>\n {shortcut.text}\n </button>\n </li>\n ))}\n </ul>\n {handleReset && (\n <button\n type=\"button\"\n className=\"my-4 mx-auto mt-auto inline-flex cursor-pointer border-none bg-transparent text-xs text-blue-500 hover:text-blue-300\"\n onClick={event => {\n event.persist();\n handleReset(event);\n close();\n }}>\n {texts.datepicker.clear}\n </button>\n )}\n </div>\n )}\n </div>\n )}\n </Popover.Content>\n </Popover>\n )}\n />\n }\n />\n </span>\n );\n});\nDatepicker.displayName = 'Datepicker';\n","import * as React from 'react';\nimport { parseFromCustomString, format } from '../../utils/date';\nimport { useLocalization } from '../Provider/Localization';\nimport { setInputValueByRef } from '../../utils/input';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { DatepickerProps } from './Datepicker';\nimport { CalendarProps } from '../Calendar/Calendar';\nimport { InputProps as BaseInputProps } from '../Input/Input';\n\ntype InputProps = BaseInputProps & { ref: React.RefObject<HTMLInputElement> };\ntype useDatepicker = React.HTMLAttributes<HTMLDivElement> & {\n calendar: CalendarProps;\n input: InputProps;\n};\n\nexport const useDatepicker = (\n { defaultValue: _, calendar, onBlur, onChange, value, ...props }: DatepickerProps,\n ref: React.Ref<HTMLInputElement>\n): useDatepicker => {\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const { formatting } = useLocalization();\n const [internalValue, setInternalValue] = React.useState(value ? format(value, formatting.date) : '');\n\n // update internal value if it changed 'externally'\n React.useEffect(() => {\n if (value) {\n const formattedValue = format(value, formatting.date);\n\n if (formattedValue !== internalValue) {\n setInternalValue(formattedValue);\n }\n } else {\n setInternalValue('');\n }\n }, [value]);\n\n // event handlers\n const handleInputBlur = (event: React.FocusEvent<HTMLInputElement>): void => {\n event.persist();\n\n const valueAsDate = parseFromCustomString(event.target.value);\n const formattedValue = valueAsDate ? format(valueAsDate) || '' : '';\n\n event.target.value = formattedValue;\n\n if (onChange) {\n (event as any).detail = valueAsDate;\n onChange(event);\n } else {\n // update the internal value to use the formatted date\n setInternalValue(formattedValue);\n }\n\n if (onBlur) {\n onBlur(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n setInternalValue(event.target.value);\n };\n\n const handleChange = date => {\n setInputValueByRef(inputRef.current, format(date, formatting.date), 'focusout');\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (event.key === 'Enter') {\n event.target.dispatchEvent(new Event('focusout', { bubbles: true }));\n }\n };\n\n const inputProps: InputProps = {\n ...props,\n autoComplete: 'off',\n onBlur: handleInputBlur,\n onChange: handleInputChange,\n onKeyDown: handleKeyDown,\n ref: inputRef,\n type: 'text',\n value: internalValue,\n };\n\n const calendarProps: CalendarProps = {\n ...calendar,\n onChange: handleChange,\n value,\n };\n\n return {\n input: inputProps,\n calendar: calendarProps,\n };\n};\n","/* eslint-disable @typescript-eslint/no-empty-function */\nimport * as React from 'react';\nimport { DialogSize } from './types';\n\nexport type DialogContext = {\n closeOnEscape: boolean;\n draggable: boolean;\n drawer: {\n open: boolean;\n toggle: () => void;\n };\n elements: {\n drawer?: React.ReactNode;\n extra?: React.ReactNode;\n };\n onClose?: () => void;\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n showCloseButton: boolean;\n size: DialogSize;\n};\n\nexport const DialogContext = React.createContext<DialogContext>({\n closeOnEscape: true,\n draggable: false,\n drawer: {\n open: false,\n toggle: () => {},\n },\n elements: {\n drawer: undefined,\n extra: undefined,\n },\n onClose: () => {},\n props: {},\n ref: null,\n showCloseButton: true,\n size: 'sm',\n});\n\nexport const useCurrentDialog = () => {\n return React.useContext(DialogContext);\n};\n","import * as React from 'react';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { useCurrentDialog } from '../Context';\nimport { mergeRefs } from '../../../utils/mergeRefs';\n\nexport type DialogTriggerProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Trigger = React.forwardRef(function DialogTrigger(\n props: DialogTriggerProps,\n externalRef: React.Ref<HTMLButtonElement>\n) {\n const { ref: parentRef, props: parentProps } = useCurrentDialog();\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n return <DialogPrimitive.Trigger {...parentProps} {...props} ref={refCallback} asChild />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useDraggable } from '../../../utils/hooks/useDraggable';\nimport { DialogContext, useCurrentDialog } from '../Context';\nimport { useLocalization } from '../../Provider/Localization';\nimport { IconButton } from '../../IconButton/IconButton';\nimport { Backdrop } from '../../Backdrop/Backdrop';\nimport { getDialogPositionClassnames, getDialogSizeClassnames } from '../util';\n\nexport type DialogContentDrawerRenderProps = DialogContext['drawer'];\n\nexport type DialogContentRenderProps = {\n close: () => void;\n drawer?: DialogContentDrawerRenderProps;\n};\n\nexport type DialogTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function DialogTitle(props: DialogTitleProps, ref: React.Ref<HTMLHeadingElement>) {\n const className = cn('text-center', props.className);\n return <DialogPrimitive.Title {...props} className={className} ref={ref} />;\n});\n\nexport type DialogFooterProps = React.HTMLAttributes<HTMLDivElement>;\nexport const Footer = React.forwardRef(function DialogFooter(props: DialogFooterProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn('mt-8 flex justify-end', props.className);\n return (\n <div {...props} className={className} ref={ref}>\n {props.children}\n </div>\n );\n});\n\nexport type DialogCloseProps = React.HTMLAttributes<HTMLButtonElement>;\n\nexport const Close = React.forwardRef(function DialogClose(props: DialogCloseProps, ref: React.Ref<HTMLButtonElement>) {\n const dialog = useCurrentDialog();\n\n return <DialogPrimitive.Close onClick={dialog.onClose} {...props} ref={ref} asChild />;\n});\n\nconst RenderPropWrapper = React.forwardRef(function RenderPropWrapper({ children, onClick, renderProps }: any, ref) {\n const close = () => {\n onClick(new CustomEvent('close'));\n };\n\n return children({ close, ref, ...renderProps });\n});\n\nexport type DialogContentProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children'> & {\n /** An accessible label to be announced when the dialog is opened */\n 'aria-label': string;\n children: Omit<React.ReactNode, 'Function'> | ((props: DialogContentRenderProps) => JSX.Element);\n};\nexport const Content = React.forwardRef(function DialogContent(props: DialogContentProps, ref: React.Ref<HTMLDivElement>) {\n const dialog = useCurrentDialog();\n const internalRef = useMergedRef<HTMLDivElement>(ref);\n const { position, dragging, handleProps: dragHandleProps } = useDraggable(internalRef);\n const { texts } = useLocalization();\n\n const className = cn(\n 'relative bg-white animate-[fade-in_150ms]',\n getDialogPositionClassnames(),\n getDialogSizeClassnames(dialog.size)\n );\n\n const containerClassName = cn(\n 'bg-white p-6 rounded relative z-10',\n 'shadow-[0_6px_9px_0_rgba(89,85,98,0.3),0_0_1px_0_rgba(89,85,98,0.2)]',\n {\n 'rounded-b-none': !!dialog.elements.extra,\n },\n props.className\n );\n\n const handleEscapeKeyDown = (event: KeyboardEvent) => {\n if (!dialog.closeOnEscape) {\n event.preventDefault();\n } else if (dialog.onClose) {\n dialog.onClose();\n }\n };\n\n // the chosen behaviour in taco is that outside clicks do not close the dialog\n const handleInteractOutside = event => event.preventDefault();\n\n let output;\n\n if (typeof props.children === 'function') {\n output = (\n <DialogPrimitive.Close asChild>\n <RenderPropWrapper renderProps={{ drawer: dialog.drawer }}>{props.children}</RenderPropWrapper>\n </DialogPrimitive.Close>\n );\n } else {\n output = props.children;\n }\n\n return (\n <DialogPrimitive.Portal>\n <DialogPrimitive.Overlay asChild>\n <Backdrop>\n <DialogPrimitive.Content\n {...props}\n className={className}\n onEscapeKeyDown={handleEscapeKeyDown}\n onInteractOutside={handleInteractOutside}\n ref={internalRef}\n style={{\n ...props.style,\n left: dialog.draggable ? `${position.x}px` : undefined,\n top: dialog.draggable ? `${position.y}px` : undefined,\n }}>\n <div className={containerClassName} data-taco=\"dialog\">\n {output}\n {dialog.draggable && (\n <div\n {...dragHandleProps}\n role=\"button\"\n draggable\n aria-grabbed={dragging}\n aria-label={texts.dialog.drag}\n className=\"yt-dialog__drag absolute-center-x bg-grey-100 top-1.5 h-3 w-24 cursor-move rounded text-center\"\n />\n )}\n {dialog.showCloseButton ? (\n <DialogPrimitive.Close onClick={dialog.onClose} asChild>\n <IconButton\n appearance=\"discrete\"\n aria-label={texts.dialog.close}\n className=\"absolute top-0 right-0 mt-2 mr-2\"\n icon=\"close\"\n />\n </DialogPrimitive.Close>\n ) : null}\n </div>\n {dialog.elements.drawer}\n {dialog.elements.extra}\n </DialogPrimitive.Content>\n </Backdrop>\n </DialogPrimitive.Overlay>\n </DialogPrimitive.Portal>\n );\n});\n","import React from 'react';\nimport { useMove } from '@react-aria/interactions';\n\nexport const useDraggable = (ref: React.MutableRefObject<HTMLDivElement | null>): any => {\n const [position, setPosition] = React.useState({\n x: 0,\n y: 0,\n });\n\n const [dragging, setDragging] = React.useState(false);\n\n const { moveProps } = useMove({\n onMoveStart() {\n setDragging(true);\n },\n onMove(event) {\n const rect = ref.current?.getBoundingClientRect();\n\n // Prevent dragging out of bounds\n if (\n rect &&\n (rect.left + event.deltaX < 0 ||\n rect.right + event.deltaX > window.innerWidth ||\n rect.top + event.deltaY < 0 ||\n rect.bottom + event.deltaY > window.innerHeight)\n ) {\n return;\n }\n\n setPosition(({ x, y }) => {\n x += event.deltaX;\n y += event.deltaY;\n return { x, y };\n });\n },\n onMoveEnd() {\n setDragging(false);\n },\n });\n\n return {\n position,\n dragging,\n handleProps: moveProps,\n };\n};\n","import * as React from 'react';\nimport { motion } from 'framer-motion';\nimport cn from 'classnames';\nimport { DialogContext, useCurrentDialog } from '../Context';\n\nexport type DialogDrawerRenderProps = DialogContext['drawer'];\n\nexport type DialogDrawerProps = Omit<\n React.HTMLAttributes<HTMLDivElement>,\n 'onAnimationStart' | 'onDragStart' | 'onDragEnd' | 'onDrag'\n> & {\n children: Omit<React.ReactNode, 'Function'> | ((props: DialogDrawerRenderProps) => React.ReactNode);\n};\n\nconst Drawer = React.forwardRef(function DialogDrawer(props: DialogDrawerProps, ref: React.Ref<HTMLDivElement>) {\n const dialog = useCurrentDialog();\n const className = cn(\n 'absolute top-0 -ml-[4px] hidden h-full w-full overflow-y-auto rounded-r bg-white p-6 text-left',\n props.className\n );\n\n return (\n <motion.div\n {...props}\n className={className}\n data-taco=\"dialog-drawer\"\n aria-hidden={!dialog.drawer?.open}\n variants={{\n visible: {\n left: '100%',\n display: 'block',\n transition: { ease: 'easeOut', duration: 0.2 },\n },\n hidden: {\n left: '0%',\n transition: { ease: 'easeOut', duration: 0.2 },\n transitionEnd: {\n display: 'none',\n },\n },\n }}\n animate={dialog.drawer?.open ? 'visible' : 'hidden'}\n ref={ref}>\n {typeof props.children === 'function' ? props.children(dialog.drawer) : props.children}\n </motion.div>\n );\n});\nDrawer.displayName = 'DialogDrawer';\n\nexport { Drawer };\n","import * as React from 'react';\nimport cn from 'classnames';\n\nexport type DialogExtraProps = React.HTMLAttributes<HTMLDivElement>;\n\nconst Extra = React.forwardRef(function DialogExtra(props: DialogExtraProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn(\n 'bg-grey-100 yt-shadow-inset absolute top-full left-0 -mt-px w-full rounded-t-none rounded-b p-6 text-left',\n props.className\n );\n\n return <div {...props} className={className} data-taco=\"dialog-extra\" ref={ref} />;\n});\nExtra.displayName = 'DialogExtra';\n\nexport { Extra };\n","import * as React from 'react';\nimport * as DialogPrimitive from '@radix-ui/react-dialog';\nimport './Dialog.css';\nimport { DialogTriggerProps, Trigger } from './components/Trigger';\nimport {\n Content,\n Title,\n Footer,\n Close,\n DialogContentProps,\n DialogContentRenderProps,\n DialogContentDrawerRenderProps,\n DialogTitleProps,\n DialogFooterProps,\n DialogCloseProps,\n} from './components/Content';\nimport { DialogDrawerProps, DialogDrawerRenderProps, Drawer } from './components/Drawer';\nimport { DialogExtraProps, Extra } from './components/Extra';\nimport { DialogContext } from './Context';\nimport { DialogSize } from './types';\n\nexport type {\n DialogCloseProps,\n DialogContentDrawerRenderProps,\n DialogContentProps,\n DialogContentRenderProps,\n DialogDrawerProps,\n DialogDrawerRenderProps,\n DialogFooterProps,\n DialogSize,\n DialogTitleProps,\n};\n\nexport type DialogTexts = {\n /**\n * Aria-label for close icon button in dialog.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n close: string;\n drag: string;\n};\n\nexport type DialogProps = {\n children: React.ReactNode | React.ReactNode[];\n /** When `true`, pressing escape will close the dialog */\n closeOnEscape?: boolean;\n /** Set whether the dialog is open by default or not */\n defaultOpen?: boolean;\n /** Allows dragging the dialog around the screen (window constrained) */\n draggable?: boolean;\n /** Handler called when dialog closes by user interaction */\n onClose?: () => void;\n /** Called when the dialog opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the dialog from outside the component */\n open?: boolean;\n /** Shows the close icon button of the dialog */\n showCloseButton?: boolean;\n /** Size of the dialog. This is the recommended way to set a size for dialog component. */\n size?: DialogSize;\n /** A trigger to be used for the dialog, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\n\nconst useSeparatedChildren = initialChildren => {\n return React.useMemo(() => {\n const children: any[] = [];\n let drawer;\n let extra;\n\n React.Children.toArray(initialChildren).forEach((child: any) => {\n if (child.type?.displayName === Drawer.displayName) {\n drawer = child;\n } else if (child.type?.displayName === Extra.displayName) {\n extra = child;\n } else {\n children.push(child);\n }\n });\n\n return [children, drawer, extra];\n }, [initialChildren]);\n};\n\nexport type ForwardedDialogWithStatics = React.ForwardRefExoticComponent<DialogProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<DialogTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n Content: React.ForwardRefExoticComponent<DialogContentProps & React.RefAttributes<HTMLDivElement>>;\n Title: React.ForwardRefExoticComponent<DialogTitleProps & React.RefAttributes<HTMLHeadingElement>>;\n Footer: React.ForwardRefExoticComponent<DialogFooterProps & React.RefAttributes<HTMLDivElement>>;\n Extra: React.ForwardRefExoticComponent<DialogExtraProps & React.RefAttributes<HTMLDivElement>>;\n Drawer: React.ForwardRefExoticComponent<DialogDrawerProps & React.RefAttributes<HTMLDivElement>>;\n Close: React.ForwardRefExoticComponent<DialogCloseProps & React.RefAttributes<HTMLButtonElement>>;\n};\n\nexport const Dialog = React.forwardRef(function Dialog(props: DialogProps, ref: React.Ref<HTMLElement>) {\n const {\n children: initialChildren,\n closeOnEscape = true,\n defaultOpen,\n draggable = false,\n onChange,\n onClose,\n open,\n showCloseButton = true,\n size = 'sm',\n trigger,\n ...otherProps\n } = props;\n const [children, drawer, extra] = useSeparatedChildren(initialChildren);\n const [drawerOpen, setDrawerOpen] = React.useState(false);\n\n const context = React.useMemo(\n () => ({\n closeOnEscape,\n draggable,\n drawer: {\n open: drawerOpen,\n toggle: () => setDrawerOpen(isDrawerOpen => !isDrawerOpen),\n },\n elements: {\n drawer,\n extra,\n },\n onClose,\n props: otherProps,\n showCloseButton,\n size,\n ref,\n }),\n [closeOnEscape, drawerOpen, draggable, drawer, extra, open, otherProps, showCloseButton]\n );\n\n return (\n <DialogContext.Provider value={context}>\n <DialogPrimitive.Root defaultOpen={defaultOpen} open={open} onOpenChange={onChange}>\n {trigger && <Trigger>{trigger}</Trigger>}\n {children}\n </DialogPrimitive.Root>\n </DialogContext.Provider>\n );\n}) as ForwardedDialogWithStatics;\n\nDialog.Trigger = Trigger;\nDialog.Content = Content;\nDialog.Title = Title;\nDialog.Footer = Footer;\nDialog.Extra = Extra;\nDialog.Drawer = Drawer;\nDialog.Close = Close;\n","import * as React from 'react';\nimport cn from 'classnames';\n\nimport './Field.css';\n\nexport type FieldProps = React.LabelHTMLAttributes<HTMLLabelElement> & {\n /** Content of the field */\n children: React.ReactNode;\n /**\tChanges the style to indicate the element is disabled */\n disabled?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Text displayed below the children of Field.\n * Should be a short text that indicates feedback for user.\n */\n message?: string;\n};\n\nexport const Field = React.forwardRef(function Field(props: FieldProps, ref: React.Ref<HTMLLabelElement>) {\n const { disabled, children, invalid = false, message, ...otherProps } = props;\n const className = cn(\n 'flex flex-col font-bold text-xs leading-loose pb-4 min-h-[theme(spacing.18)]',\n {\n 'text-grey-300': disabled,\n },\n props.className\n );\n const messageClassName = cn(\n 'h-4 text-xs text-left leading-normal font-normal truncate -mb-4',\n {\n 'text-grey-700': !invalid,\n 'text-red-500': invalid,\n 'opacity-50': disabled,\n },\n props.className\n );\n\n return (\n <label {...otherProps} className={className} data-taco=\"label\" ref={ref}>\n {children}\n {message && (\n <span className={messageClassName} role={invalid ? 'alert' : undefined}>\n {message}\n </span>\n )}\n </label>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport './Form.css';\n\nexport type FormProps = React.FormHTMLAttributes<HTMLFormElement> & {\n /** Content should be composed of other Taco form elements */\n children: React.ReactNode;\n /** Display the form fields in a horizontal layout */\n horizontal?: boolean;\n};\n\nexport const Form = React.forwardRef(function Form(props: FormProps, ref: React.Ref<HTMLFormElement>) {\n const { horizontal = false, ...otherProps } = props;\n const className = cn(\n 'yt-form',\n {\n 'yt-form--horizontal flex flex-wrap': horizontal,\n },\n props.className\n );\n\n return <form {...otherProps} className={className} data-taco=\"form\" ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { Orientation } from '../../types';\n\nexport type GroupProps = React.HTMLAttributes<HTMLElement> & {\n /**\n * Change what html tag element will render.\n * Default value is `span`\n */\n as?: 'div' | 'span' | 'nav';\n /** Content should be composed of other Taco elements */\n children: React.ReactNode;\n /**\n * Define orientation of grouping.\n * @defaultValue horizontal\n */\n orientation?: Orientation;\n};\n\nexport const Group = React.forwardRef(function Group(props: GroupProps, ref: React.Ref<HTMLDivElement>) {\n const { as: Tag = 'span', orientation = 'horizontal', ...otherProps } = props;\n const className = cn('flex ', 'gap-2', { 'flex-col ': orientation === 'vertical' }, props.className);\n return <Tag {...otherProps} className={className} data-taco=\"group\" ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { IconButton } from '../IconButton/IconButton';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from '../Popover/Primitives';\nimport { useLocalization } from '../Provider/Localization';\nimport './Hanger.css';\nimport { mergeRefs } from '../../utils/mergeRefs';\n\ntype HangerContextValue = {\n /** Handler called when hanger closes by user interaction */\n onClose?: () => void;\n props: Record<string, any>;\n ref: React.Ref<HTMLElement>;\n};\nconst HangerContext = React.createContext<HangerContextValue>({\n onClose: undefined,\n props: {},\n ref: null,\n});\n\nexport type HangerTexts = {\n /** Aria-label for the close icon button of hanger */\n close: string;\n};\n\nexport type HangerAnchorProps = React.HTMLAttributes<HTMLDivElement>;\nconst Anchor = React.forwardRef(function HangerAnchor(props: HangerAnchorProps, externalRef: React.Ref<HTMLDivElement>) {\n const { ref: parentRef, props: parentProps } = React.useContext(HangerContext);\n const refCallback = mergeRefs([parentRef, externalRef]);\n\n let children = props.children;\n\n if (React.isValidElement(props.children) && typeof props.children?.type === 'function') {\n console.warn(\n `Hanger.Anchor requires its child to forwardRef so that it can attach to the dom element. Did you mean to wrap '${props.children.type.name}' in React.forwardRef()? Taco has wrapped '${props.children.type.name}' in a 'span' to maintain functionality, but this may cause unintended behaviour`\n );\n children = <span>{props.children}</span>;\n }\n\n return (\n <PopoverPrimitive.Anchor {...parentProps} {...props} ref={refCallback} asChild>\n {children}\n </PopoverPrimitive.Anchor>\n );\n});\n\nexport type HangerTitleProps = React.HTMLAttributes<HTMLHeadingElement>;\nexport const Title = React.forwardRef(function DialogTitle(props: HangerTitleProps, ref: React.Ref<HTMLHeadingElement>) {\n const className = cn('mb-1 text-base font-bold flex w-full', props.className);\n return <span {...props} className={className} ref={ref} />;\n});\n\nexport type HangerContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Set the position of the Hanger relative to its achor. Default value is `bottom` */\n placement?: Placement;\n};\n\nconst Content = React.forwardRef(function HangerContent(props: HangerContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side } = props;\n const context = React.useContext(HangerContext);\n const { texts } = useLocalization();\n const className = cn(\n 'wcag-blue-500 border border-transparent rounded p-3 pr-12 yt-shadow focus:border-transparent max-w-sm',\n props.className\n );\n const handleInteractOutside = (event: CustomEvent): void => {\n event.preventDefault();\n };\n\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n className={className}\n data-taco=\"hanger\"\n onInteractOutside={handleInteractOutside}\n side={side}\n sideOffset={1}\n ref={ref}>\n {props.children}\n <UnstyledArrow className=\"text-blue-500\" />\n <PopoverPrimitive.Close asChild>\n <IconButton\n appearance=\"primary\"\n aria-label={texts.hanger.close}\n className=\"absolute top-0 right-0 ml-2 mr-2 mt-2 text-white\"\n icon=\"close\"\n onClick={context.onClose}\n />\n </PopoverPrimitive.Close>\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n );\n});\n\nexport type HangerProps = React.PropsWithChildren<{\n /** An anchor to be used for the hanger, should not be set if `children` already contains an anchor */\n anchor?: JSX.Element;\n /**\n * Shows or hides hanger depending on the value\n * @defaultValue true\n */\n defaultOpen?: boolean;\n /** Handler called when user closes the hanger */\n onClose?: () => void;\n}>;\n\nexport type ForwardedHangerWithStatics = React.ForwardRefExoticComponent<HangerProps & React.RefAttributes<HTMLElement>> & {\n Anchor: React.ForwardRefExoticComponent<HangerAnchorProps>;\n Content: React.ForwardRefExoticComponent<HangerContentProps>;\n Title: React.ForwardRefExoticComponent<HangerTitleProps>;\n};\n\nexport const Hanger = React.forwardRef<HTMLElement, HangerProps>(function Hanger(props, ref) {\n const { anchor, children, defaultOpen = true, onClose, ...otherProps } = props;\n const context = React.useMemo(() => ({ onClose, props: otherProps, ref }), [onClose, otherProps]);\n\n // we do this to ensure hangers are mounted after their containers, e.g. if the container is another portal\n const [open, setOpen] = React.useState(false);\n React.useEffect(() => {\n if (defaultOpen) {\n setOpen(defaultOpen);\n }\n }, []);\n\n return (\n <HangerContext.Provider value={context}>\n <PopoverPrimitive.Root key={String(open)} defaultOpen={open}>\n {anchor && <Anchor>{anchor}</Anchor>}\n {children}\n </PopoverPrimitive.Root>\n </HangerContext.Provider>\n );\n}) as ForwardedHangerWithStatics;\nHanger.Anchor = Anchor;\nHanger.Content = Content;\nHanger.Title = Title;\n","import * as React from 'react';\nimport * as HoverCardPrimitive from '@radix-ui/react-hover-card';\n\nexport const UnstyledArrow = React.forwardRef(function HoverCardArrow(\n props: React.SVGAttributes<SVGElement>,\n ref: React.Ref<SVGSVGElement>\n) {\n return (\n <HoverCardPrimitive.Arrow className=\"pointer-events-none -mt-px\" asChild offset={2} width={30} height={11}>\n <svg {...props} ref={ref} viewBox=\"0 19 30 11\" style={{ transform: 'rotateZ(180deg)' }}>\n <path\n className=\"text-grey-300 fill-current group-focus:text-blue-300\"\n d=\"M23.7,27.1L17,19.9C16.5,19.3,15.8,19,15,19s-1.6,0.3-2.1,0.9l-6.6,7.2C5.3,28.1,3.4,29,2,29h26 C26.7,29,24.6,28.1,23.7,27.1z\"></path>\n <path\n className=\"fill-current\"\n d=\"M23,27.8c1.1,1.2,3.4,2.2,5,2.2h2H0h2c1.7,0,3.9-1,5-2.2l6.6-7.2c0.7-0.8,2-0.8,2.7,0L23,27.8L23,27.8z\"></path>\n </svg>\n </HoverCardPrimitive.Arrow>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as HoverCardPrimitive from '@radix-ui/react-hover-card';\nimport { Placement } from '../..';\nimport { UnstyledArrow } from './Primitives';\nimport { getPopoverStyleClassnames } from '../Popover/util';\n\nexport type HoverCardTriggerProps = React.HTMLAttributes<HTMLAnchorElement>;\nconst Trigger = React.forwardRef(function HoverCardTrigger(props: HoverCardTriggerProps, ref: React.Ref<HTMLAnchorElement>) {\n return <HoverCardPrimitive.Trigger {...props} asChild ref={ref} />;\n});\n\nexport type HoverCardContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /** Set the position of the HoverCard relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\nconst Content = React.forwardRef(function HoverCardContent(props: HoverCardContentProps, ref: React.Ref<HTMLDivElement>) {\n const { placement: side } = props;\n const className = cn(getPopoverStyleClassnames(), 'min-w-[theme(spacing.40)] max-w-[theme(spacing.96)]', props.className);\n\n return (\n <HoverCardPrimitive.Portal>\n <HoverCardPrimitive.Content className={className} data-taco=\"hover-card\" side={side} sideOffset={1} ref={ref}>\n {props.children}\n <UnstyledArrow className=\"text-white\" />\n </HoverCardPrimitive.Content>\n </HoverCardPrimitive.Portal>\n );\n});\n\nexport type HoverCardProps = React.PropsWithChildren<{}>;\n\nexport const HoverCard = (props: HoverCardProps) => {\n return <HoverCardPrimitive.Root {...props} openDelay={300} />;\n};\nHoverCard.Trigger = Trigger;\nHoverCard.Content = Content;\n","import * as React from 'react';\nimport { Input, InputProps } from '../Input/Input';\nimport { useLocalization } from '../Provider/Localization';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef } from '../../utils/input';\n\nexport type SearchInputTexts = {\n button: string;\n clear: string;\n placeholder: string;\n};\n\nexport type SearchInputProps = Omit<InputProps, 'button' | 'icon' | 'prefix' | 'postfix'> & {\n /** Current input value will be passed to the method. In order to get the value, the component must be controlled otherwise value will always be undefined */\n onSearch?: (value: string | number | readonly string[] | undefined) => void;\n};\n\nexport const SearchInput = React.forwardRef(function SearchInput(\n { onSearch, ...props }: SearchInputProps,\n ref: React.Ref<HTMLInputElement>\n) {\n const internalRef = useMergedRef<HTMLInputElement>(ref);\n const { texts } = useLocalization();\n\n const handleClick = (): void => {\n onSearch?.(internalRef.current?.value ?? '');\n };\n\n const handleCancelClick = (): void => {\n setInputValueByRef(internalRef.current, '');\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLInputElement>): void => {\n if (event.key === 'Enter') {\n event.preventDefault();\n handleClick();\n return;\n }\n\n props.onKeyDown?.(event);\n };\n\n return (\n <Input\n aria-label={texts.searchInput.placeholder}\n placeholder={texts.searchInput.placeholder}\n {...props}\n onKeyDown={handleKeyDown}\n postfix={\n <>\n {props.disabled || props.readOnly || !props.value ? null : (\n <IconButton\n aria-hidden\n className=\"group-peer-focus:visible group-peer-hover:visible !text-grey-700 invisible mr-0.5 !h-5 !min-h-[theme(spacing.4)] !w-5 !min-w-[theme(spacing.4)] text-xs hover:visible group-hover:visible\"\n icon=\"close\"\n onClick={handleCancelClick}\n rounded\n tabIndex={-1}\n tooltip={texts.searchInput.clear}\n />\n )}\n <IconButton\n aria-label={texts.searchInput.button}\n icon=\"search\"\n className=\"group-peer-focus:!border-transparent group-peer-focus:group-peer-active:!border-transparent -mr-2 !border-transparent !bg-transparent focus:!border-transparent\"\n disabled={props.disabled || props.readOnly}\n onClick={handleClick}\n tooltip={texts.searchInput.button}\n />\n </>\n }\n ref={internalRef}\n type=\"search\"\n />\n );\n});\n","import * as React from 'react';\n\nexport interface Timer {\n running: boolean;\n start: () => void;\n pause: () => void;\n resume: () => void;\n}\n\ntype Tracker = {\n remaining: number;\n started: number | null;\n};\n\nexport default function useTimer(duration = 0, callback: () => void): Timer {\n const timer = React.useRef<number>();\n const [tracker, setTracker] = React.useState<Tracker>({\n remaining: duration,\n started: null,\n });\n\n React.useEffect(() => {\n if (duration) {\n if (tracker.started) {\n timer.current = window.setTimeout(callback, tracker.remaining);\n } else {\n clearTimeout(timer.current);\n }\n }\n\n return () => {\n clearTimeout(timer.current);\n };\n }, [tracker.started]);\n\n return {\n running: !!tracker.started,\n start: () => {\n setTracker({\n remaining: duration,\n started: Date.now(),\n });\n },\n pause: () => {\n if (tracker.started) {\n setTracker({\n remaining: tracker.remaining - (Date.now() - tracker.started),\n started: null,\n });\n }\n },\n resume: () => {\n if (tracker.remaining && !tracker.started) {\n setTracker({\n remaining: tracker.remaining,\n started: Date.now(),\n });\n }\n },\n };\n}\n","import * as React from 'react';\nimport useTimer from '../../utils/hooks/useTimer';\nimport { findNextIndexByValue } from './util';\nimport { ScrollableListItem } from './ScrollableList';\n\ntype useTypeahead = {\n getNextIndex: (key: string) => number;\n};\n\ntype useTypeaheadProps = {\n data: ScrollableListItem[];\n currentIndex: number | undefined;\n};\n\nexport const useTypeahead = ({ data, currentIndex }: useTypeaheadProps): useTypeahead => {\n const typeaheadQuery = React.useRef<string | undefined>();\n const typeaheadQueryTimer = useTimer(1000, () => {\n typeaheadQuery.current = undefined;\n });\n\n const getNextIndex = (charKey: string): number => {\n const query = (typeaheadQuery.current ? typeaheadQuery.current + charKey : charKey).toLowerCase();\n const nextIndex = findNextIndexByValue(data, query, currentIndex);\n\n typeaheadQueryTimer.start();\n typeaheadQuery.current = query;\n\n return nextIndex;\n };\n\n return { getNextIndex };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { useListbox } from './useListbox';\nimport { useMultiListbox } from './useMultiListbox';\nimport { ScrollableList, ScrollableListItemValue, ScrollableListItem } from './ScrollableList';\n\nexport type ListboxItem = ScrollableListItem;\nexport type ListboxValue = ScrollableListItemValue;\n\nexport type ListboxTexts = {\n /**\n * Text displayed in the listbox if no data provided.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n empty: string;\n /**\n * Text displayed in the listbox to indicate the data is loading.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading: string;\n /**\n * The first option displayed in a multiselect listbox that selects all available options.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n allOption: string;\n};\n\nexport type ListboxProps = Pick<React.InputHTMLAttributes<HTMLInputElement>, 'onChange' | 'onFocus'> &\n Omit<React.InputHTMLAttributes<HTMLElement>, 'defaultValue' | 'onChange' | 'value'> & {\n /** Data indicating the options in listbox */\n data?: ListboxItem[];\n /**\n * Initial value of the listbox.\n * This is used when listbox is mounted, if no value is provided.\n * *Note* that listbox is a controlled component, setting this will also trigger the `onChange` event\n */\n defaultValue?: ListboxValue;\n /** Set what value should have an empty option in listbox */\n emptyValue?: ListboxValue;\n /** Draws attention to the listbox by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /**\n * Shows a loading indicator with a text next to it.\n * Read more about how to provide the text in [Provider](component:provider) component\n */\n loading?: boolean;\n /**\n * Value of the listbox representing the selected item.\n * It needs to be an existing value from the provided data\n */\n value?: ListboxValue;\n };\n\nexport const Listbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{ ...list.style, maxHeight: 'calc(12rem + 2px)' /* (6 * option height) + listbox border */ }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n\nexport const MultiListbox = React.forwardRef(function Listbox(props: ListboxProps, ref: React.Ref<HTMLInputElement>) {\n const { className: externalClassName, ...otherProps } = props;\n const { list, input } = useMultiListbox(otherProps, ref);\n const className = cn('bg-white inline-flex relative w-full', externalClassName);\n\n return (\n <span data-taco=\"listbox\" className={className}>\n <ScrollableList\n {...list}\n style={{\n ...list.style,\n maxHeight: 'calc(12rem + 2px + 2px)' /* (6 * option height) + listbox border + ALL_OPTIONS bottom border */,\n }}\n />\n <input {...input} className=\"hidden\" type=\"text\" />\n </span>\n );\n});\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { ListboxProps } from './Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, getIndexFromValue, findByValue, getActiveDescendant, useFlattenedData, sanitizeItem } from './util';\nimport { ScrollableListProps } from './ScrollableList';\nimport { useTypeahead } from './useTypeahead';\n\ntype useListbox = {\n list: ScrollableListProps;\n input: Omit<React.HTMLAttributes<HTMLInputElement>, 'defaultValue'>;\n};\n\nexport const useListbox = (\n {\n data: externalData = [],\n defaultValue,\n disabled,\n emptyValue,\n id: nativeId,\n invalid,\n name,\n onChange,\n onFocus,\n onKeyDown,\n value = emptyValue,\n ...otherProps\n }: ListboxProps,\n ref: React.Ref<HTMLInputElement>\n): useListbox => {\n const data = useFlattenedData(emptyValue !== undefined ? [{ text: '', value: emptyValue }, ...externalData] : externalData);\n const id = React.useMemo(() => nativeId || uuid(), [nativeId]);\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const currentIndex = value !== undefined ? getIndexFromValue(data, value) : undefined;\n const { getNextIndex } = useTypeahead({ data, currentIndex });\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n setInputValueByRef(inputRef.current, option.value);\n }\n }\n };\n\n const handleListboxChange = (index: number): void => {\n setInputValueByIndex(index);\n };\n\n React.useEffect(() => {\n if (data.length && currentIndex === undefined) {\n if (defaultValue !== undefined) {\n const defaultValueIndex = getIndexFromValue(data, defaultValue);\n\n if (defaultValueIndex !== undefined) {\n setInputValueByIndex(defaultValueIndex);\n }\n } else {\n setInputValueByIndex(0);\n }\n }\n }, [data]);\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n const charKey = event.key;\n\n // event.key always returns the whole string (String.fromCharCode(event.keyCode) does not)\n // We need to filter out only alphabetical or numeric letters, that's why that condition has been changed\n if (charKey.length === 1 && /(\\w)/g.test(charKey)) {\n const nextIndex = getNextIndex(charKey);\n\n if (nextIndex > -1 && nextIndex !== currentIndex) {\n setInputValueByIndex(nextIndex);\n }\n return;\n }\n\n if (onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxFocus = (event: React.FocusEvent<HTMLElement>): void => {\n if (currentIndex === undefined && data.length) {\n setInputValueByIndex(0);\n }\n\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (onChange) {\n const item = findByValue(data, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const indexes = item?.path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n (event as any).detail.parents = indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(data.find(i => i.path === lastPath));\n });\n }\n\n onChange(event);\n }\n };\n\n const list: ScrollableListProps = {\n ...otherProps,\n 'aria-activedescendant': getActiveDescendant(data, currentIndex, id),\n data,\n disabled,\n id,\n invalid,\n onChange: handleListboxChange,\n onFocus: handleListboxFocus,\n onKeyDown: handleListboxKeyDown,\n scrollOnFocus: true,\n tabIndex: disabled ? -1 : otherProps.tabIndex ? otherProps.tabIndex : 0,\n value: currentIndex,\n };\n\n const input = {\n name,\n onChange: handleInputChange,\n ref: inputRef,\n tabIndex: -1,\n value: value ?? '',\n };\n\n return { list, input };\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { useLocalization } from '../Provider/Localization';\nimport { ListboxProps } from './Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, getIndexFromValue, getSelectedIndexesFromValue, findByValue, getActiveDescendant } from './util';\nimport { ScrollableListProps, ScrollableListItem, ScrollableListItemValue } from './ScrollableList';\nimport { useTypeahead } from './useTypeahead';\n\ntype useListbox = {\n list: ScrollableListProps;\n input: Omit<React.HTMLAttributes<HTMLInputElement>, 'defaultValue'>;\n};\n\nexport const useMultiListbox = (\n {\n data: externalData = [],\n defaultValue,\n disabled,\n emptyValue: _,\n id: nativeId,\n name,\n onClick,\n onChange,\n onFocus,\n onKeyDown,\n value,\n ...otherProps\n }: ListboxProps,\n ref: React.Ref<HTMLInputElement>\n): useListbox => {\n const { texts } = useLocalization();\n const id = React.useMemo(() => nativeId || uuid(), [nativeId]);\n const inputRef = useMergedRef<HTMLInputElement>(ref);\n const data = React.useMemo(() => {\n return [{ text: texts.listbox.allOption, value: '#ALL-OPTIONS#' }, ...externalData];\n }, [externalData]);\n const [currentIndex, setCurrentIndex] = React.useState(getIndexFromValue(data, value) || 0);\n const [allOptionsSelected, setAllOptionsSelected] = React.useState(false);\n const { getNextIndex } = useTypeahead({ data, currentIndex });\n const [selectedIndexes, setSelectedIndexes] = React.useState(getSelectedIndexesFromValue(data, value));\n\n React.useEffect(() => {\n if (defaultValue && !value) {\n setInputValueByRef(inputRef.current, defaultValue.toString());\n }\n }, []);\n\n React.useEffect(() => {\n const selectableItemsCount = data.filter(item => !item.disabled).length - 1;\n\n if (selectableItemsCount === selectedIndexes.length) {\n setAllOptionsSelected(true);\n } else {\n setAllOptionsSelected(false);\n }\n }, [selectedIndexes, data]);\n\n const setInputValueByIndex = (index: number | undefined): void => {\n if (index !== undefined) {\n const option = data[index];\n\n if (option && !option.disabled) {\n let newInputValue: ScrollableListItemValue = '';\n const currentInputValue = inputRef.current?.value;\n const currentValuesArray = currentInputValue?.split(',') || [];\n const optionAlreadySelected = currentValuesArray.findIndex(val => val === String(option.value)) !== -1;\n\n // Handling the select_all option\n if (option.value === '#ALL-OPTIONS#') {\n if (!allOptionsSelected) {\n newInputValue = data\n .filter((option, index) => index !== 0 && !option.disabled)\n .map(option => option.value)\n .join(',');\n } else {\n newInputValue = '';\n }\n } else {\n // Handling rest options\n if (optionAlreadySelected) {\n newInputValue = currentValuesArray.filter(val => val !== String(option.value)).join(',');\n } else {\n newInputValue = currentInputValue ? `${currentInputValue},${option.value}` : option.value;\n }\n }\n\n setInputValueByRef(inputRef.current, newInputValue);\n }\n }\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>, index: number): void => {\n event.preventDefault();\n\n if (!data[index].disabled) {\n setCurrentIndex(index);\n setInputValueByIndex(index);\n }\n\n if (onClick) {\n onClick(event);\n }\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>, index?: number): void => {\n const charKey = event.key;\n\n // event.key always returns the whole string (String.fromCharCode(event.keyCode) does not)\n // We need to filter out only alphabetical or numeric letters, that's why that condition has been changed\n if (charKey.length === 1 && /(\\w)/g.test(charKey)) {\n const nextIndex = getNextIndex(charKey);\n\n if (nextIndex > -1 && nextIndex !== currentIndex) {\n setCurrentIndex(nextIndex);\n }\n return;\n }\n\n switch (event.key) {\n case ' ': {\n event.preventDefault();\n setInputValueByIndex(index);\n break;\n }\n\n case 'Enter': {\n setInputValueByIndex(index);\n break;\n }\n\n default:\n }\n setCurrentIndex(index !== undefined ? index : 0);\n\n if (onKeyDown) {\n event.persist();\n onKeyDown(event);\n }\n };\n\n const handleListboxFocus = (event: React.FocusEvent<HTMLElement>): void => {\n if (onFocus) {\n event.persist();\n onFocus(event);\n }\n };\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n setSelectedIndexes(getSelectedIndexesFromValue(data, event.target.value));\n\n if (onChange) {\n const detail: ScrollableListItem[] = [];\n const valuesArray = event.target.value.split(',');\n\n valuesArray.forEach(val => {\n const item = findByValue(data, val);\n if (item) {\n detail.push(item);\n }\n });\n (event as any).detail = detail;\n\n onChange(event);\n }\n };\n\n const list = {\n ...otherProps,\n 'aria-activedescendant': getActiveDescendant(data, currentIndex, id),\n 'aria-multiselectable': true,\n data,\n disabled,\n id,\n onChange: () => null,\n onClick: handleListboxClick,\n onFocus: handleListboxFocus,\n onKeyDown: handleListboxKeyDown,\n scrollOnFocus: false,\n tabIndex: disabled ? -1 : otherProps.tabIndex ? otherProps.tabIndex : 0,\n value: currentIndex,\n selectedIndexes,\n multiselect: true,\n allOptionsSelected,\n };\n\n const input = {\n name,\n onChange: handleInputChange,\n ref: inputRef,\n tabIndex: -1,\n value: value ?? '',\n };\n\n return { list, input };\n};\n","import * as React from 'react';\n\nexport const MenuContext = React.createContext<\n | {\n indented: boolean;\n registerIndentation: () => void;\n minWidth?: number;\n setMinWidth: (width: number) => void;\n close: () => void;\n }\n | undefined\n>(undefined);\n\nexport const useCurrentMenu = () => {\n return React.useContext(MenuContext);\n};\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { Align, Placement } from '../../../types';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuContentProps = Omit<DropdownMenuPrimitive.DropdownMenuContentProps, 'children' | 'side'> & {\n align?: Align;\n children: React.ReactNode;\n /** Set the position of the Menu relative to its trigger. Default value is `bottom` */\n placement?: Placement;\n};\n\nexport const Content = React.forwardRef(function MenuContent(props: MenuContentProps, ref: React.Ref<HTMLDivElement>) {\n const internalRef = useMergedRef<any>(ref);\n const menu = useCurrentMenu();\n const { align = 'start', children, placement: side, ...otherProps } = props;\n const className = cn('border border-transparent rounded block outline-none p-1 yt-shadow wcag-white', props.className);\n\n return (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n {...otherProps}\n align={align}\n className={className}\n data-taco=\"menu\"\n side={side}\n sideOffset={3}\n style={{ minWidth: menu?.minWidth }}\n ref={internalRef}>\n {children}\n </DropdownMenuPrimitive.Content>\n </DropdownMenuPrimitive.Portal>\n );\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { IconName } from '../../Icon/Icon';\nimport { Icon as IconPrimitive } from '../../Icon/Icon';\nimport { useCurrentMenu } from '../Context';\nimport { DialogProps } from '../../Dialog/Dialog';\n\nexport const Icon = ({ name }) => (\n <span className=\"absolute left-0 ml-1\">\n <IconPrimitive className=\"-ml-px -mt-px !h-5 !w-5\" name={name} />\n </span>\n);\n\nexport const useItemStyling = ({ disabled, indented, className }) => {\n const menu = useCurrentMenu();\n\n React.useEffect(() => {\n if (indented && !menu?.indented) {\n menu?.registerIndentation();\n }\n }, [indented]);\n\n return cn(\n 'flex items-center justify-start h-8 pr-1.5 relative rounded w-full focus:outline-none group',\n {\n 'pl-7': menu?.indented,\n 'pl-1.5': !menu?.indented,\n 'cursor-pointer hover:wcag-grey-200 text-black': !disabled,\n 'cursor-not-allowed hover:bg-white text-grey-300': disabled,\n },\n className\n );\n};\n\nexport const Shortcut = props => {\n return <span {...props} className=\"text-grey-700 ml-auto pl-3\" />;\n};\n\nexport type MenuItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n dialog?: (props: Partial<DialogProps>) => JSX.Element;\n disabled?: boolean;\n icon?: IconName;\n onClick?: (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void;\n shortcut?: string;\n};\n\nexport const Item = React.forwardRef(function MenuItem(props: MenuItemProps, ref: React.Ref<HTMLDivElement>) {\n const { dialog, icon, onClick, shortcut, ...otherProps } = props;\n const menu = useCurrentMenu();\n const className = useItemStyling({\n disabled: props.disabled,\n indented: !!icon,\n className: props.className,\n });\n\n const disabled = props.disabled ?? props['aria-disabled'];\n\n let handleClick;\n\n // radix has a bug that does not disable clicks when disabled is set on items\n if (disabled) {\n handleClick = event => {\n event.preventDefault();\n event.stopPropagation();\n };\n }\n\n const handleSelect = event => {\n if (onClick) {\n onClick(event);\n }\n\n if (props['aria-haspopup'] || typeof dialog === 'function') {\n event.preventDefault();\n }\n };\n\n let button = (\n <DropdownMenuPrimitive.Item {...otherProps} className={className} onClick={handleClick} onSelect={handleSelect} ref={ref}>\n {icon && <Icon name={icon} />}\n {props.children}\n {shortcut && <Shortcut>{shortcut}</Shortcut>}\n </DropdownMenuPrimitive.Item>\n );\n\n if (typeof dialog === 'function') {\n button = dialog({ trigger: button, onClose: menu?.close });\n }\n\n return button;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { IconName } from '../../Icon/Icon';\nimport { Icon, useItemStyling } from './Item';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuLinkItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n disabled?: boolean;\n icon?: IconName;\n href: string;\n onClick?: (event: React.MouseEvent<HTMLDivElement, MouseEvent>) => void;\n};\n\nexport const Link = React.forwardRef(function MenuLink(props: MenuLinkItemProps, ref: React.Ref<HTMLDivElement>) {\n const { href, icon, onClick, ...otherProps } = props;\n const menu = useCurrentMenu();\n\n const className = useItemStyling({\n disabled: props.disabled,\n indented: !!icon,\n className: props.className,\n });\n\n const handleClick: React.MouseEventHandler<HTMLDivElement> = event => {\n onClick?.(event);\n menu?.close();\n };\n\n return (\n <DropdownMenuPrimitive.Item {...otherProps} asChild className={className} ref={ref} onClick={handleClick}>\n <a href={href} target=\"_blank\">\n {icon && <Icon name={icon} />}\n {props.children}\n </a>\n </DropdownMenuPrimitive.Item>\n );\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuTriggerProps = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children'> & {\n children: React.ReactElement;\n};\n\nexport const Trigger = React.forwardRef(function MenuTrigger(props: MenuTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const menu = useCurrentMenu();\n const internalRef = useMergedRef<HTMLButtonElement>(ref);\n\n React.useEffect(() => {\n if (internalRef.current) {\n menu?.setMinWidth(internalRef.current.getBoundingClientRect().width);\n }\n }, [internalRef]);\n\n return <DropdownMenuPrimitive.Trigger {...props} asChild ref={internalRef} />;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { Icon } from '../../Icon/Icon';\nimport { useItemStyling } from './Item';\n\nexport type MenuCheckboxItemProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'onSelect'> & {\n /* Whether the checkbox item is disabled */\n disabled?: boolean;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean | 'indeterminate') => void;\n};\n\nexport const Checkbox = React.forwardRef<HTMLDivElement, MenuCheckboxItemProps>(function MenuCheckboxItem(props, ref) {\n const { checked, children, onChange, ...otherProps } = props;\n const className = useItemStyling({\n disabled: props.disabled,\n indented: true,\n className: props.className,\n });\n\n return (\n <DropdownMenuPrimitive.CheckboxItem\n {...otherProps}\n checked={checked}\n className={className}\n onCheckedChange={onChange}\n ref={ref}>\n <DropdownMenuPrimitive.ItemIndicator className=\"absolute left-0 ml-1.5\">\n <Icon name=\"tick\" className=\"-ml-px !h-4 !w-4\" />\n </DropdownMenuPrimitive.ItemIndicator>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n );\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group';\nimport { Orientation } from '../../types';\n\nexport type RadioGroupItemValue = string | number | boolean | null;\n\nexport const getRadioGroupItemValueAsString = (value: RadioGroupItemValue): string => String(value ?? '');\n\nexport const findByValue = (values: RadioGroupItemValue[], valueAsString: string): RadioGroupItemValue =>\n values.find(value => getRadioGroupItemValueAsString(value) === valueAsString) as RadioGroupItemValue;\n\nconst RadioGroupContext = React.createContext({ disabled: false, invalid: false });\n\nexport type RadioGroupItemProps<T = HTMLButtonElement> = Omit<\n React.ButtonHTMLAttributes<T>,\n 'children' | 'onSelect' | 'value'\n> & {\n /** Label for the radio group item */\n children: React.ReactNode;\n /* Whether the radio group item is disabled */\n disabled?: boolean;\n /** Value of the radio button */\n value: RadioGroupItemValue;\n};\n\nconst RadioGroupItem = React.forwardRef(function RadioGroupItem(props: RadioGroupItemProps, ref: React.Ref<HTMLButtonElement>) {\n const context = React.useContext(RadioGroupContext);\n const { children, value, ...otherProps } = props;\n\n const isDisabled = context.disabled || props.disabled;\n\n const className = cn(\n 'flex flex-shrink-0 self-start items-center justify-center h-4 w-4 mt-[0.2rem] rounded-full bg-white border-2',\n {\n 'border-grey-300 hover:border-4 focus:yt-focus aria-checked:bg-blue-500 aria-checked:border-blue-500 hover:aria-checked:border-blue-300':\n !isDisabled && !context.invalid,\n 'border-grey-200 cursor-not-allowed aria-checked:bg-blue-300 aria-checked:border-blue-300 ': isDisabled,\n 'border-red-500 hover:border-4 text-red-500 focus:border-red-500 focus:yt-focus-red aria-checked:bg-red-500 aria-checked:border-red':\n context.invalid && !isDisabled,\n }\n );\n const labelClassName = cn(\n 'flex items-center gap-2',\n {\n 'cursor-pointer': !isDisabled,\n 'cursor-not-allowed text-grey-300': isDisabled,\n },\n props.className\n );\n\n return (\n <label className={labelClassName}>\n <RadioGroupPrimitive.Item\n {...otherProps}\n className={className}\n disabled={isDisabled}\n ref={ref}\n value={getRadioGroupItemValueAsString(value)}>\n <RadioGroupPrimitive.Indicator className=\"h-2 w-2 rounded-full bg-white\" />\n </RadioGroupPrimitive.Item>\n {children}\n </label>\n );\n});\n\ntype ReactGroupBaseChild = React.ReactElement<RadioGroupItemProps> | boolean | null;\n\ntype RadioGroupBaseProps = Omit<React.HTMLAttributes<HTMLDivElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n children: ReactGroupBaseChild[];\n /* Whether the radio group is disabled */\n disabled?: boolean;\n /* Whether the radio group is in an invalid state */\n invalid?: boolean;\n /** The name of the radio group, used when submitting an HTML form */\n name?: string;\n /**\n * Orientation of the radio group\n * @defaultValue vertical\n */\n orientation?: Orientation;\n /* Whether the radio group requires user input */\n required?: boolean;\n};\n\ninterface UncontrolledRadioGroupProps extends RadioGroupBaseProps {\n /* The default value (uncontrolled) */\n defaultValue?: RadioGroupItemValue;\n onChange?: never;\n value?: never;\n}\n\ninterface ControlledRadioGroupProps extends RadioGroupBaseProps {\n defaultValue?: never;\n /** Handler called when the value changes */\n onChange: (value: RadioGroupItemValue) => void;\n /** The current value (controlled) */\n value?: RadioGroupItemValue;\n}\n\nexport type RadioGroupProps = UncontrolledRadioGroupProps | ControlledRadioGroupProps;\n\nexport type ForwardedRadioGroupWithStatics = React.ForwardRefExoticComponent<\n RadioGroupProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Item component rendered in a `RadioGroup` component */\n Item: React.ForwardRefExoticComponent<RadioGroupItemProps>;\n};\n\nexport const useRadioGroup = (props: RadioGroupProps) => {\n const { children, defaultValue, disabled, invalid, onChange, orientation = 'vertical', value, ...otherProps } = props;\n\n const values = React.useMemo<RadioGroupItemValue[]>(() => {\n const radioGroupItemValues: RadioGroupItemValue[] = [];\n\n React.Children.forEach(children, child => {\n if (React.isValidElement(child)) {\n radioGroupItemValues.push(child.props.value);\n }\n });\n\n return radioGroupItemValues;\n }, [children]);\n\n const context = React.useMemo(() => ({ disabled: disabled ?? false, invalid: invalid ?? false }), [disabled, invalid]);\n\n let valueProps;\n\n if (onChange !== undefined) {\n const handleChange = (value: string): void => onChange(findByValue(values, value));\n\n valueProps = {\n onValueChange: handleChange,\n value: value !== undefined ? getRadioGroupItemValueAsString(value) : undefined,\n };\n } else {\n valueProps = {\n defaultValue: defaultValue !== undefined ? getRadioGroupItemValueAsString(defaultValue) : undefined,\n };\n }\n\n return {\n context,\n props: {\n ...otherProps,\n ...valueProps,\n children,\n disabled,\n orientation,\n },\n };\n};\n\nexport const RadioGroup = React.forwardRef(function RadioGroup(props: RadioGroupProps, ref: React.Ref<HTMLDivElement>) {\n const { context, props: otherProps } = useRadioGroup(props);\n const className = cn(\n 'flex items-start gap-y-2',\n {\n 'flex-wrap gap-x-4 ': otherProps.orientation === 'horizontal',\n 'flex-col': otherProps.orientation === 'vertical',\n },\n otherProps.className\n );\n\n return (\n <RadioGroupContext.Provider value={context}>\n <RadioGroupPrimitive.Root {...otherProps} className={className} data-taco=\"radio-group\" ref={ref} />\n </RadioGroupContext.Provider>\n );\n}) as ForwardedRadioGroupWithStatics;\nRadioGroup.Item = RadioGroupItem;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { getRadioGroupItemValueAsString, RadioGroupItemProps, RadioGroupProps, useRadioGroup } from '../../RadioGroup/RadioGroup';\nimport { useItemStyling } from './Item';\n\nexport type MenuRadioGroupItemProps = RadioGroupItemProps<HTMLDivElement>;\n\nexport const RadioItem = (props: MenuRadioGroupItemProps) => {\n const context = React.useContext(MenuRadioGroupContext);\n const { children, value, ...otherProps } = props;\n const disabled = context.disabled || props.disabled;\n const className = useItemStyling({\n disabled: disabled,\n indented: true,\n className: props.className,\n });\n\n return (\n <DropdownMenuPrimitive.RadioItem\n {...otherProps}\n className={className}\n disabled={disabled}\n value={getRadioGroupItemValueAsString(value)}>\n <DropdownMenuPrimitive.ItemIndicator className=\"absolute left-0 ml-1.5\">\n <span className=\"ml-1 flex h-1.5 w-1.5 rounded-full bg-current \" />\n </DropdownMenuPrimitive.ItemIndicator>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n );\n};\n\nconst MenuRadioGroupContext = React.createContext({ disabled: false });\n\nexport type MenuRadioGroupProps = RadioGroupProps;\n\nexport type ForwardedMenuRadioGroupWithStatics = React.ForwardRefExoticComponent<\n MenuRadioGroupProps & React.RefAttributes<HTMLElement>\n> & {\n Item: React.FunctionComponent<MenuRadioGroupItemProps>;\n};\n\nexport const RadioGroup = React.forwardRef<HTMLDivElement, MenuRadioGroupProps>(function MenuRadioItem(props, ref) {\n const { context, props: otherProps } = useRadioGroup(props);\n const className = cn('flex flex-col', props.className);\n\n return (\n <MenuRadioGroupContext.Provider value={context}>\n <DropdownMenuPrimitive.RadioGroup {...otherProps} className={className} ref={ref} />\n </MenuRadioGroupContext.Provider>\n );\n}) as ForwardedMenuRadioGroupWithStatics;\nRadioGroup.Item = RadioItem;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport cn from 'classnames';\nimport { useCurrentMenu } from '../Context';\n\nexport type MenuHeaderProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Header = React.forwardRef<HTMLDivElement, MenuHeaderProps>(function MenuHeader(props, ref) {\n const menu = useCurrentMenu();\n const className = cn(\n 'flex items-center justify-start h-7 pr-1.5 text-xs text-grey-700',\n {\n 'pl-7': menu?.indented,\n 'pl-1.5': !menu?.indented,\n },\n props.className\n );\n\n return <DropdownMenuPrimitive.Label {...props} className={className} ref={ref} />;\n});\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport { MenuContext } from './Context';\nimport { Content, MenuContentProps } from './components/Content';\nimport { Item, MenuItemProps } from './components/Item';\nimport { Link, MenuLinkItemProps } from './components/Link';\nimport { Trigger, MenuTriggerProps } from './components/Trigger';\nimport { Checkbox, MenuCheckboxItemProps } from './components/Checkbox';\nimport { ForwardedMenuRadioGroupWithStatics, RadioGroup } from './components/RadioGroup';\nimport { Separator } from './components/Separator';\nimport { Header, MenuHeaderProps } from './components/Header';\n\nexport type MenuProps = {\n children: React.ReactNode;\n /** Set whether the menu is open by default or not */\n defaultOpen?: boolean;\n /** Called when the menu opens or closes, must be used in conjunction with open */\n onChange?: (open: boolean) => void;\n /** Control the open state of the menu from outside the component */\n open?: boolean;\n /** A trigger to be used for the menu, should not be set if `children` already contains a trigger */\n trigger?: JSX.Element;\n};\nexport type ForwardedMenuWithStatics = React.ForwardRefExoticComponent<MenuProps & React.RefAttributes<HTMLElement>> & {\n Trigger: React.ForwardRefExoticComponent<MenuTriggerProps>;\n Content: React.ForwardRefExoticComponent<MenuContentProps>;\n Item: React.ForwardRefExoticComponent<MenuItemProps>;\n Link: React.ForwardRefExoticComponent<MenuLinkItemProps>;\n Checkbox: React.ForwardRefExoticComponent<MenuCheckboxItemProps>;\n Separator: React.FunctionComponent;\n Header: React.ForwardRefExoticComponent<MenuHeaderProps>;\n RadioGroup: ForwardedMenuRadioGroupWithStatics;\n};\n\nexport const Menu = React.forwardRef<HTMLButtonElement, MenuProps>(function Menu(externalProps, ref) {\n const { children, defaultOpen: defaultProp, onChange, open: prop, trigger, ...props } = externalProps;\n const [indented, setIndented] = React.useState(false);\n const [minWidth, setMinWidth] = React.useState<number | undefined>(undefined);\n\n const [open, setOpen] = useControllableState<boolean>({\n // uncontrolled\n defaultProp,\n // controlled\n onChange,\n prop,\n });\n\n const context = React.useMemo(\n () => ({\n indented,\n registerIndentation: () => setIndented(true),\n minWidth,\n setMinWidth: (width: number) => setMinWidth(width),\n close: () => setOpen(false),\n }),\n [indented, minWidth]\n );\n\n return (\n <MenuContext.Provider value={context}>\n <DropdownMenuPrimitive.Root {...props} modal={false} open={open} onOpenChange={setOpen}>\n {trigger && <Trigger ref={ref}>{trigger}</Trigger>}\n {children}\n </DropdownMenuPrimitive.Root>\n </MenuContext.Provider>\n );\n}) as ForwardedMenuWithStatics;\nMenu.Trigger = Trigger;\nMenu.Content = Content;\nMenu.Item = Item;\nMenu.Link = Link;\nMenu.Checkbox = Checkbox;\nMenu.Separator = Separator;\nMenu.Header = Header;\nMenu.RadioGroup = RadioGroup;\n","import * as React from 'react';\nimport * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu';\n\nexport const Separator = () => {\n return <DropdownMenuPrimitive.Separator className=\"bg-grey-300 my-1 h-px\" />;\n};\n","import React from 'react';\nimport cn from 'classnames';\n\nexport type TreeviewItemProps = React.LinkHTMLAttributes<HTMLAnchorElement>;\n\nconst TreeviewItem = React.forwardRef(function TreeviewItem(props: TreeviewItemProps, ref: React.Ref<HTMLAnchorElement>) {\n return <a {...props} ref={ref} />;\n});\n\nexport type TreeviewGroupProps = Omit<React.LinkHTMLAttributes<HTMLDivElement>, 'className' | 'onClick' | 'title'> & {\n /** Add a classname to the treeview */\n className?: string | ((expanded: boolean) => string);\n /**\n * Set wheter the region is expanded, showing the children, or collapsed.\n * Default value is `false`\n */\n expanded?: boolean;\n /** Region is expanded at mount and can't be collapsed */\n fixed?: boolean;\n /** Handler called when user clicks the title of the group */\n onClick?: (event: React.MouseEvent<HTMLDivElement>, expanded: boolean) => void;\n /** Text displayed in the group's header */\n title: React.ReactNode | ((expanded: boolean) => React.ReactNode);\n};\n\nconst TreeviewGroup = React.forwardRef(function TreeviewGroup(props: TreeviewGroupProps, ref: React.Ref<HTMLDivElement>) {\n const {\n children,\n className: externalClassName,\n expanded: initialExpanded = false,\n title,\n fixed,\n onClick,\n ...otherProps\n } = props;\n const [expanded, setExpanded] = React.useState(fixed || initialExpanded);\n\n React.useEffect(() => {\n if (!fixed) {\n setExpanded(fixed || initialExpanded);\n }\n }, [fixed, initialExpanded]);\n\n const listClassName = cn('flex-col mb-0', {\n flex: expanded,\n hidden: !expanded,\n });\n\n const itemProps = {\n ...otherProps,\n 'aria-expanded': expanded,\n role: 'treeitem',\n tabIndex: -1,\n };\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>): void => {\n const nextState = !expanded;\n\n if (!fixed) {\n setExpanded(nextState);\n }\n\n if (onClick) {\n onClick(event, nextState);\n }\n };\n\n const className = typeof externalClassName === 'function' ? externalClassName(expanded) : externalClassName;\n\n return (\n <div {...itemProps} className={className} ref={ref}>\n <div onClick={handleClick}>{typeof title === 'function' ? title(expanded) : title}</div>\n <ul role=\"group\" className={listClassName}>\n {React.Children.toArray(children)\n .filter(item => !!item)\n .map((item, i) => (\n <li key={i} role=\"none\">\n {React.cloneElement(item as React.ReactElement<any>, { role: 'treeitem' })}\n </li>\n ))}\n </ul>\n </div>\n );\n});\n\nexport type TreeviewProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type ForwardedTreeviewWithStatics = React.ForwardRefExoticComponent<\n TreeviewProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Navigable link */\n Item: React.ForwardRefExoticComponent<TreeviewItemProps & React.RefAttributes<HTMLAnchorElement>>;\n /** Container for a set of related links, usually expandable */\n Group: React.ForwardRefExoticComponent<TreeviewGroupProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Treeview = React.forwardRef(function Treeview(props: TreeviewProps, ref: React.Ref<HTMLDivElement>) {\n return <div {...props} ref={ref} role=\"tree\" />;\n}) as ForwardedTreeviewWithStatics;\n\nTreeview.Group = TreeviewGroup;\nTreeview.Item = TreeviewItem;\n","import React from 'react';\n\nexport type useDropTarget = [\n boolean,\n (\n | undefined\n | {\n onDragEnter: React.DragEventHandler;\n onDragLeave: React.DragEventHandler;\n onDragOver: React.DragEventHandler;\n onDrop: React.DragEventHandler;\n }\n )\n];\n\nexport const useDropTarget = (onDrop: React.DragEventHandler | undefined): useDropTarget => {\n const [isDraggedOver, setDraggedOver] = React.useState(false);\n\n const handleDragEnter = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n setDraggedOver(true);\n }, []);\n\n const handleDragLeave = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n\n if (event.target === event.currentTarget) {\n setDraggedOver(false);\n }\n }, []);\n\n const handleDragOver = React.useCallback((event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n }, []);\n\n const handleDrop = React.useCallback(\n (event: React.DragEvent<HTMLElement>) => {\n event.preventDefault();\n event.persist();\n\n setDraggedOver(false);\n\n if (onDrop) {\n onDrop(event);\n }\n },\n [onDrop]\n );\n\n const props = onDrop\n ? {\n onDragEnter: handleDragEnter,\n onDragLeave: handleDragLeave,\n onDragOver: handleDragOver,\n onDrop: handleDrop,\n }\n : undefined;\n\n return [isDraggedOver, props];\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { TreeviewProps, Treeview, TreeviewGroupProps, TreeviewItemProps } from '../Treeview/Treeview';\nimport { Icon } from '../Icon/Icon';\nimport { useDropTarget } from '../../utils/hooks/useDropTarget';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport './Navigation.css';\n\n// Item\nexport type NavigationItemProps = Omit<TreeviewItemProps, 'prefix'> & {\n /** Change the style to indicate the link is selected */\n active?: boolean;\n /** Handler to be used when dropping a dragged element over the navigation link */\n onDrop?: React.DragEventHandler;\n /**\n * Small amount of information placed next to the text of the link.\n * This can be any valid react element, for e.g. a `span`.\n * Should be used to indicate a relevant information of the link,\n * for e.g. the number of unread notifications\n */\n postfix?: React.ReactNode;\n /**\n * Small amount of information placed before the text of the link.\n * This can be any valid react element, for e.g. a `span`.\n * Should be used to indicate a feedback for user,\n * for e.g. display some sort of visual informational state or a relevant icon.\n */\n prefix?: React.ReactNode;\n /** Target of the link */\n target?: string;\n};\n\nconst Item = React.forwardRef(function Item(props: NavigationItemProps, ref: React.Ref<HTMLAnchorElement>) {\n const { active, children, onDrop, postfix, prefix, role, ...otherProps } = props;\n const proxyRef = useMergedRef<HTMLAnchorElement>(ref);\n const [isDraggedOver, dropTargetProps] = useDropTarget(onDrop);\n const isTreeitem = role === 'treeitem';\n const className = cn(\n 'yt-navigation__item cursor-pointer',\n {\n 'w-full mb-px py-1 px-3 flex items-center hover:bg-grey-300': isTreeitem,\n 'bg-white w-full h-10 px-3 flex-shrink-0 flex items-center justify-between cursor-pointer': !isTreeitem,\n 'yt-navigation__item--active': active && !isDraggedOver,\n 'bg-grey-300': isTreeitem && active && !isDraggedOver,\n 'yt-navigation__item--dropping bg-blue-500': isDraggedOver,\n },\n props.className\n );\n\n const handleClick = (event: React.MouseEvent<HTMLSpanElement>): void => {\n if (event.target instanceof HTMLAnchorElement || event.target instanceof HTMLButtonElement) {\n return;\n }\n\n if (proxyRef.current) {\n proxyRef.current.click();\n }\n };\n\n return (\n <span {...dropTargetProps} className={className} onClick={handleClick} role={role}>\n {prefix && <span className=\"yt-navigation__item__prefix flex items-center\">{prefix}</span>}\n <a {...otherProps} className=\"block flex-grow truncate\" ref={proxyRef}>\n {children}\n </a>\n {postfix && <span className=\"yt-navigation__item__postfix ml-1\">{postfix}</span>}\n </span>\n );\n});\n\n// Panel\nexport type NavigationPanelProps = React.HTMLAttributes<HTMLDivElement>;\n\nconst Panel = React.forwardRef(function Panel(props: NavigationPanelProps, ref: React.Ref<HTMLDivElement>) {\n return <div {...props} className={cn('w-full bg-white p-3', props.className)} ref={ref} />;\n});\n\n// Group\nexport type NavigationMenuGroupProps = TreeviewGroupProps;\n\nconst MenuGroup = React.forwardRef(function MenuGroup(props: NavigationMenuGroupProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn(\n 'flex-shrink-0 space-y-1 outline-none',\n {\n 'bg-white pb-2': props.fixed,\n },\n typeof props.className === 'function' ? props.className(false) : props.className\n );\n const title = (expanded: boolean): JSX.Element => {\n const className = cn('bg-white h-10 pl-3 pr-1 flex items-center justify-between w-full', {\n 'mb-1': expanded,\n 'cursor-pointer hover:text-blue-500': !props.fixed,\n });\n\n return (\n <span className={className}>\n {typeof props.title === 'function' ? props.title(expanded) : props.title}\n {!props.fixed && <Icon name={expanded ? 'chevron-up' : 'chevron-down'} />}\n </span>\n );\n };\n\n return <Treeview.Group {...props} className={className} title={title} ref={ref} />;\n});\n\n// Menu\nexport type NavigationMenuProps = React.PropsWithChildren<TreeviewProps>;\n\nexport type ForwardedNavigationMenuWithStatics = React.ForwardRefExoticComponent<\n NavigationMenuProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Expandable region reprezenting a group of related links */\n Group: React.ForwardRefExoticComponent<NavigationMenuGroupProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nconst Menu = React.forwardRef(function Menu(props: NavigationMenuProps, ref: React.Ref<HTMLDivElement>) {\n const scrollableAreas = React.useMemo(() => {\n const scrollableAreas: React.ReactNode[] = [];\n\n const children = React.Children.toArray(props.children).filter(\n child => !!child\n ) as React.ReactElement<NavigationMenuGroupProps>[];\n\n children.forEach(child => {\n if (child.props.fixed) {\n scrollableAreas.push(child);\n } else {\n const x = scrollableAreas[scrollableAreas.length - 1];\n if (Array.isArray(x)) {\n x.push(child);\n } else {\n scrollableAreas.push([child]);\n }\n }\n });\n\n return scrollableAreas;\n }, [props.children]);\n\n return (\n <Treeview\n {...props}\n className={cn('divide-grey-100 flex flex-grow flex-col divide-y-2 overflow-y-auto', props.className)}\n ref={ref}>\n {scrollableAreas.map((area, i) =>\n Array.isArray(area) ? (\n <div\n className=\"divide-grey-100 flex h-0 flex-auto flex-shrink-0 flex-grow flex-col divide-y-2 overflow-y-auto\"\n key={i}>\n {area}\n </div>\n ) : (\n area\n )\n )}\n </Treeview>\n );\n}) as ForwardedNavigationMenuWithStatics;\n\nMenu.Group = MenuGroup;\n\n// Navigation\nexport type NavigationProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type ForwardedNavigationWithStatics = React.ForwardRefExoticComponent<\n NavigationProps & React.RefAttributes<HTMLDivElement>\n> & {\n /** Navigation link */\n Item: React.ForwardRefExoticComponent<NavigationItemProps & React.RefAttributes<HTMLAnchorElement>>;\n /**\n * Container for the expandable groups that hold navigation links.\n * Should be used as a direct child of Navigation component, e.g. `Navigation.Menu`.\n * Should have the menu groups as a direct child, e.g. `Navigation.Menu.Group`\n */\n Menu: ForwardedNavigationMenuWithStatics;\n /**\n * Isolated container within the Navigation.\n * This can be used to create a region in the Navigation that is usually not scrollable, nor expandable,\n * containing useful information for user and quick actions\n */\n Panel: React.ForwardRefExoticComponent<NavigationPanelProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Navigation = React.forwardRef(function Navigation(props: NavigationProps, ref: React.Ref<HTMLDivElement>) {\n const { children, ...otherProps } = props;\n const className = cn('h-full flex flex-col bg-grey-100 divide-y-2 divide-grey-100', props.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"navigation\" ref={ref}>\n {children}\n </div>\n );\n}) as ForwardedNavigationWithStatics;\n\nNavigation.Menu = Menu;\nNavigation.Item = Item;\nNavigation.Panel = Panel;\n","import * as React from 'react';\nimport { Button } from '../Button/Button';\nimport { useLocalization } from '../Provider/Localization';\n\ntype PageNumberProps = {\n currentPageIndex: number;\n onClick: (pageIndex: number) => void;\n pageCount: number;\n};\n\nconst createPageRange = (pageCount: number, pageNumber: number): number[] => {\n let lowerLimit = Math.min(pageNumber, pageCount);\n let upperLimit = Math.min(pageNumber, pageCount);\n\n for (let b = 1; b < 5 && b < pageCount; ) {\n if (lowerLimit > 1) {\n lowerLimit--;\n b++;\n }\n if (b < 5 && upperLimit < pageCount) {\n upperLimit++;\n b++;\n }\n }\n\n const range: number[] = [];\n\n for (let i = lowerLimit; i <= upperLimit; i++) {\n range.push(i);\n }\n\n return range;\n};\n\nexport const PageNumbers = ({ currentPageIndex = 0, onClick: handleClick, pageCount }: PageNumberProps): JSX.Element => {\n const range = createPageRange(pageCount, currentPageIndex + 1);\n const { texts } = useLocalization();\n\n return (\n <>\n {range.map((pageNumber: number) => (\n <Button\n appearance={pageNumber === currentPageIndex + 1 ? 'primary' : 'default'}\n aria-current={pageNumber === currentPageIndex + 1 ? 'page' : undefined}\n key={pageNumber}\n onClick={() => handleClick(pageNumber - 1)}\n aria-label={texts.pagination.actions.pageX.replace('[X]', String(pageNumber))}\n tooltip={texts.pagination.actions.pageX.replace('[X]', String(pageNumber))}>\n {pageNumber}\n </Button>\n ))}\n </>\n );\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { Icon } from '../Icon/Icon';\nimport { Listbox, MultiListbox, ListboxProps } from '../Listbox/Listbox';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { useSelect } from './useSelect';\nimport { Combobox, ComboboxProps } from '../Combobox/Combobox';\nimport { Badge } from '../Badge/Badge';\nimport { getInputClasses } from '../Input/util';\n\nexport type SelectTexts = {\n /**\n * The text displayed when all options are selected when multiselect mode in on.\n */\n allOptionsSelected: string;\n};\n\nexport type BaseSelectProps = Omit<ListboxProps, 'dialog'> &\n Omit<ComboboxProps, 'inline'> & {\n /**\n * Allows to select multiple values.\n * All the selected values will be combined in a comma-seperated string as the value of the input.\n */\n multiselect?: boolean;\n };\n\nexport type SelectProps = BaseSelectProps & {\n /**\n * Creates an editable select.\n * Setting this will render a inline Combobox which will display the provided data on click/focus,\n * even if there is no value in the input.\n * After user starts typing, matching data will be displayed.\n */\n editable?: boolean;\n};\n\nconst BaseSelect = React.forwardRef(function BaseSelect(props: BaseSelectProps, ref: React.Ref<HTMLInputElement>) {\n const { autoFocus, className: externalClassName, highlighted, style, ...otherProps } = props;\n const { button, listbox, popover, input, text, more = 0 } = useSelect(otherProps, ref);\n const internalRef = React.useRef<HTMLButtonElement>(null);\n const selectDimensions = useBoundingClientRectListener(internalRef);\n const className = cn('inline-flex relative w-full', { 'yt-select--readonly': props.readOnly }, externalClassName);\n const inputClassname = cn(getInputClasses(props), 'h-8 text-left !pr-0', {\n 'border-blue-500': popover.open,\n });\n\n React.useEffect(() => {\n if (autoFocus && internalRef.current) {\n internalRef.current.focus();\n }\n }, []);\n\n const renderMultiSelection = (): React.ReactNode => {\n return (\n <>\n <span className=\"flex-grow truncate text-left\">{text}</span>\n {more > 0 && <Badge className=\"ml-2\">{`+${more}`}</Badge>}\n </>\n );\n };\n\n const commonListboxProps: ListboxProps = {\n ...listbox,\n className: 'w-auto',\n invalid: undefined,\n style: { minWidth: selectDimensions?.width },\n tabIndex: popover.open ? 0 : -1,\n };\n\n return (\n <span className={className} data-taco=\"select\" style={style}>\n <PopoverPrimitive.Root {...popover}>\n <PopoverPrimitive.Trigger {...button} className={inputClassname} ref={internalRef}>\n {props.multiselect ? renderMultiSelection() : <span className=\"flex-grow truncate text-left\">{text}</span>}\n <span className=\"flex h-8 w-8 items-center justify-center\">\n <Icon className=\"pointer-events-none\" name={popover.open ? 'chevron-up' : 'chevron-down'} />\n </span>\n </PopoverPrimitive.Trigger>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content align=\"start\" sideOffset={4}>\n {props.multiselect ? <MultiListbox {...commonListboxProps} /> : <Listbox {...commonListboxProps} />}\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n <input {...input} className=\"hidden\" type=\"text\" />\n </PopoverPrimitive.Root>\n </span>\n );\n});\n\nexport const Select = React.forwardRef(function Select(props: SelectProps, ref: React.Ref<HTMLInputElement>) {\n const { editable, ...otherProps } = props;\n\n if (editable) {\n return <Combobox {...otherProps} dialog={undefined} inline ref={ref} />;\n }\n\n return <BaseSelect {...otherProps} ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { v4 as uuid } from 'uuid';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport { useLocalization } from '../Provider/Localization';\nimport { SelectProps } from './Select';\nimport { ListboxProps } from '../Listbox/Listbox';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { setInputValueByRef, findByValue, useFlattenedData, sanitizeItem } from '../Listbox/util';\nimport { ScrollableListItemValue } from '../Listbox/ScrollableList';\nimport { createCustomEvent } from '../../utils/input';\n\ntype InternalButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement>;\ntype InternalListboxProps = ListboxProps & { ref: React.ForwardedRef<HTMLInputElement> };\ntype InternalInputProps = React.InputHTMLAttributes<HTMLInputElement> & { ref: React.ForwardedRef<HTMLInputElement> };\n\ntype useSelect = React.HtmlHTMLAttributes<HTMLDivElement> & {\n button: InternalButtonProps;\n listbox: InternalListboxProps;\n input: InternalInputProps;\n popover: Pick<PopoverPrimitive.PopoverProps, 'onOpenChange' | 'open'>;\n text: string | JSX.Element;\n more?: number;\n};\n\nexport const useSelect = (\n {\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data = [],\n defaultValue,\n disabled,\n emptyValue,\n id: nativeId,\n multiselect,\n onBlur,\n onClick,\n onChange,\n readOnly,\n value,\n ...otherProps\n }: SelectProps,\n ref: React.Ref<HTMLInputElement>\n): useSelect => {\n const { texts } = useLocalization();\n const flattenedData = useFlattenedData(data);\n const listboxInputRef = useMergedRef<HTMLInputElement>(ref);\n const [open, setOpen] = React.useState(false);\n const id = React.useMemo(() => nativeId || `select_${uuid()}`, [nativeId]);\n const inputRef = React.useRef<HTMLInputElement>(null);\n const buttonId = `${id}-button`;\n // support 'escape' resetting to the value that was set when the listbox opened\n const [lastValue, setLastValue] = React.useState<ScrollableListItemValue | undefined>(value);\n\n React.useEffect(() => {\n setLastValue(value);\n }, [open]);\n\n React.useEffect(() => {\n if (value === undefined) {\n if (defaultValue !== undefined && findByValue(flattenedData, defaultValue)) {\n setInputValueByRef(inputRef.current, defaultValue);\n } else {\n if (emptyValue !== undefined) {\n setInputValueByRef(inputRef.current, emptyValue);\n } else if (data.length > 0) {\n setInputValueByRef(inputRef.current, data[0].value);\n }\n }\n } else {\n if (!multiselect && !findByValue(flattenedData, value)) {\n if (emptyValue !== undefined) {\n setInputValueByRef(inputRef.current, emptyValue);\n } else if (data.length > 0) {\n setInputValueByRef(inputRef.current, data[0].value);\n }\n }\n }\n }, []);\n\n // event handlers\n const handleButtonKeyDown = (event: React.KeyboardEvent<HTMLButtonElement>): void => {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {\n event.preventDefault();\n setOpen(true);\n }\n };\n\n const handleListboxKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n switch (event.key) {\n case 'Escape': {\n event.preventDefault();\n if (lastValue !== undefined) {\n setInputValueByRef(listboxInputRef.current, lastValue);\n }\n\n setOpen(false);\n break;\n }\n\n case 'Tab':\n case 'Enter': {\n if (event.key !== 'Tab') {\n event.preventDefault();\n }\n setOpen(false);\n break;\n }\n\n default:\n }\n\n if (otherProps.onKeyDown) {\n otherProps.onKeyDown(event);\n }\n };\n\n const handleListboxClick = (event: React.MouseEvent<HTMLLIElement>): void => {\n event.preventDefault();\n if (!multiselect) {\n setOpen(false);\n if (onBlur) {\n onBlur(createCustomEvent('blur'));\n }\n }\n };\n\n let text: string | JSX.Element = '';\n let more = 0;\n\n if (value !== undefined) {\n if (multiselect) {\n const selectedValues = value?.toString().split(',') || [];\n\n if (selectedValues.length === flattenedData.filter(item => !item.disabled).length) {\n text = texts.select.allOptionsSelected;\n } else {\n text = findByValue(flattenedData, selectedValues[0])?.text ?? '';\n more = selectedValues.length > 1 ? selectedValues.length - 1 : 0;\n }\n } else {\n const item = findByValue(flattenedData, value);\n\n if (item) {\n text = item.icon ? (\n <>\n {React.cloneElement(item.icon, {\n className: cn(item.icon.props.className, 'mr-1 -mt-px'),\n })}\n {item.text}\n </>\n ) : (\n item.text\n );\n }\n }\n }\n\n const handleInputChange = (event: React.ChangeEvent<HTMLInputElement>): void => {\n event.persist();\n\n if (onChange) {\n const item = findByValue(flattenedData, event.target.value);\n (event as any).detail = sanitizeItem(item);\n\n const indexes = item?.path?.split('.') ?? [];\n\n if (indexes.length > 1) {\n // we don't want to map the current item\n indexes.pop();\n // we need to rebuild the path as we map\n let lastPath: string;\n\n (event as any).detail.parents = indexes.map(i => {\n lastPath = lastPath ? [lastPath, i].join('.') : i;\n return sanitizeItem(flattenedData.find(i => i.path === lastPath));\n });\n }\n\n onChange(event);\n }\n };\n\n const button: InternalButtonProps = {\n 'aria-haspopup': 'listbox' as const,\n 'aria-label': ariaLabel ? `${ariaLabel} ${text}` : undefined,\n 'aria-labelledby': ariaLabelledBy ? `${ariaLabelledBy} ${buttonId}` : undefined,\n disabled: disabled || readOnly,\n id: buttonId,\n onKeyDown: !disabled && !readOnly ? handleButtonKeyDown : undefined,\n type: 'button',\n };\n\n const listbox: InternalListboxProps = {\n ...otherProps,\n 'aria-label': ariaLabel,\n 'aria-labelledby': ariaLabelledBy,\n data,\n disabled,\n emptyValue,\n onBlur,\n onClick: handleListboxClick,\n onChange: event => {\n setInputValueByRef(inputRef.current, event.target.value);\n },\n onKeyDown: handleListboxKeyDown,\n ref: listboxInputRef,\n value,\n };\n\n const input: InternalInputProps = {\n onChange: handleInputChange,\n ref: inputRef,\n value: String(value ?? ''),\n };\n\n return {\n button,\n listbox,\n input,\n popover: {\n open,\n onOpenChange: open => {\n if (!open && onBlur) {\n onBlur(createCustomEvent('blur'));\n }\n setOpen(open);\n },\n },\n text,\n more,\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { PageNumbers } from './PageNumbers';\nimport { LocalizationTexts, useLocalization } from '../Provider/Localization';\nimport { Select } from '../Select/Select';\nimport { Group } from '../Group/Group';\nimport { IconButton } from '../IconButton/IconButton';\nimport { usePaginationValues } from './usePagination';\nimport { usePaginationShortcuts } from './usePaginationShortcuts';\n\nexport * from './usePagination';\n\nexport type PaginationTextsActions = {\n /**\n * Aria-label for first page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n firstPage: string;\n /**\n * Aria-label for first page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n firstPageWithShortcut: string;\n /**\n * Aria-label for next page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n nextPage: string;\n /**\n * Aria-label for next page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n nextPageWithShortcut: string;\n /**\n * Aria-label for previous page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n previousPage: string;\n /**\n * Aria-label for previous page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n previousPageWithShortcut: string;\n /**\n * Aria-label for last page action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n lastPage: string;\n /**\n * Aria-label for last page action button with shortcut.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n lastPageWithShortcut: string;\n /**\n * Aria-label for page X action button.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n pageX: string;\n};\n\nexport type PaginationTexts = {\n /**\n * Aria-label provided for page numbers and page actions group.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n label: string;\n /**\n * Aria-label provided for page size selection.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n pageSize: string;\n /**\n * Text that indicates the number of the first and last element displayed on the current page, out of total items\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n showingXofYofTotal: string;\n /**\n * Aria-labels provided for page action buttons.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n actions: PaginationTextsActions;\n};\n\nexport type PaginationProps = React.HTMLAttributes<HTMLDivElement> &\n usePaginationValues & {\n /** Indicate total number of items that will be paginated */\n length: number;\n /** Page size options */\n pageSizes?: number[];\n /** Shows page controls */\n showPageControls?: boolean;\n /** Shows page numbers between navigation buttons, which allows users to quickly navigate to a specific page */\n showPageNumbers?: boolean;\n /** Shows a dropdown with page sizes, which allows user to change the number of items displayed on the page */\n showPageSize?: boolean;\n /** Enable pagination shortcuts */\n dangerouslyHijackGlobalKeyboardNavigation?: boolean;\n };\n\nconst getShowingLabel = (length: number, pageIndex: number, pageSize: number, texts: LocalizationTexts): string => {\n const minItemIndex = pageIndex * pageSize + 1;\n const maxItemIndex = (pageIndex + 1) * pageSize;\n\n return texts.pagination.showingXofYofTotal\n .replace('[X]', length === 0 ? '0' : String(minItemIndex))\n .replace('[Y]', String(maxItemIndex > length ? length : maxItemIndex))\n .replace('[total]', String(length));\n};\n\nexport const Pagination = React.forwardRef(function Pagination(props: PaginationProps, ref: React.Ref<HTMLDivElement>) {\n const {\n length,\n pageIndex,\n pageSize,\n pageSizes = [10, 25, 50, 100, 500],\n setPageIndex,\n setPageSize,\n showPageControls = true,\n showPageNumbers = true,\n showPageSize = true,\n dangerouslyHijackGlobalKeyboardNavigation = false,\n ...otherProps\n } = props;\n const { texts } = useLocalization();\n\n const maxPageIndex = Math.ceil(length / pageSize) - 1;\n const showShortcutTexts = dangerouslyHijackGlobalKeyboardNavigation;\n\n usePaginationShortcuts({\n setPageIndex,\n maxPageIndex,\n pageIndex,\n dangerouslyHijackGlobalKeyboardNavigation,\n });\n\n const pageCount = Math.ceil(length / pageSize);\n const canPreviousPage = pageIndex > 0;\n const canNextPage = pageIndex < pageCount - 1;\n\n const className = cn('inline-flex relative justify-between items-center', props.className);\n\n return (\n <div {...otherProps} className={className} data-taco=\"pagination\" ref={ref}>\n {showPageSize && (\n <span className=\"mr-4\">\n {getShowingLabel(length, pageIndex, pageSize, texts)}\n <Select\n aria-label={texts.pagination.pageSize}\n className=\"ml-4 !w-20\"\n data={pageSizes.map(pageSize => ({\n text: String(pageSize),\n value: pageSize,\n }))}\n onChange={event => {\n setPageIndex(0);\n setPageSize(Number(event.target.value));\n }}\n value={pageSize}\n />\n </span>\n )}\n {showPageControls && (\n <Group as=\"nav\" aria-label={texts.pagination.label}>\n <IconButton\n appearance=\"default\"\n disabled={!canPreviousPage}\n icon=\"arrow-start\"\n onClick={() => setPageIndex(0)}\n aria-label={\n showShortcutTexts\n ? texts.pagination.actions.firstPageWithShortcut\n : texts.pagination.actions.firstPage\n }\n tooltip={\n showShortcutTexts\n ? texts.pagination.actions.firstPageWithShortcut\n : texts.pagination.actions.firstPage\n }\n />\n <IconButton\n appearance=\"default\"\n disabled={!canPreviousPage}\n icon=\"arrow-left\"\n onClick={() => setPageIndex(pageIndex - 1)}\n aria-label={\n showShortcutTexts\n ? texts.pagination.actions.previousPageWithShortcut\n : texts.pagination.actions.previousPage\n }\n tooltip={\n showShortcutTexts\n ? texts.pagination.actions.previousPageWithShortcut\n : texts.pagination.actions.previousPage\n }\n />\n {showPageNumbers && pageCount > 0 && (\n <PageNumbers pageCount={pageCount} currentPageIndex={pageIndex} onClick={setPageIndex} />\n )}\n <IconButton\n appearance=\"default\"\n disabled={!canNextPage}\n icon=\"arrow-right\"\n onClick={() => setPageIndex(pageIndex + 1)}\n aria-label={\n showShortcutTexts ? texts.pagination.actions.nextPageWithShortcut : texts.pagination.actions.nextPage\n }\n tooltip={\n showShortcutTexts ? texts.pagination.actions.nextPageWithShortcut : texts.pagination.actions.nextPage\n }\n />\n <IconButton\n appearance=\"default\"\n disabled={!canNextPage}\n icon=\"arrow-end\"\n onClick={() => setPageIndex(pageCount - 1)}\n aria-label={\n showShortcutTexts ? texts.pagination.actions.lastPageWithShortcut : texts.pagination.actions.lastPage\n }\n tooltip={\n showShortcutTexts ? texts.pagination.actions.lastPageWithShortcut : texts.pagination.actions.lastPage\n }\n />\n </Group>\n )}\n </div>\n );\n});\n","import React from 'react';\n\ninterface Props {\n setPageIndex: (pageIndex: number) => void;\n maxPageIndex: number;\n pageIndex: number;\n dangerouslyHijackGlobalKeyboardNavigation: boolean;\n}\n\nexport const usePaginationShortcuts = ({\n setPageIndex,\n maxPageIndex,\n pageIndex,\n dangerouslyHijackGlobalKeyboardNavigation: useGlobalKeyboardNavigation,\n}: Props) => {\n const onKeyDown = (event: KeyboardEvent): void => {\n if (setPageIndex && event.key === 'Home') {\n event.preventDefault();\n setPageIndex(0);\n return;\n }\n\n if (setPageIndex && event.key === 'End') {\n event.preventDefault();\n setPageIndex(maxPageIndex);\n return;\n }\n\n if (setPageIndex && event.key === 'PageUp') {\n event.preventDefault();\n setPageIndex(Math.max(0, pageIndex - 1));\n return;\n }\n\n if (setPageIndex && event.key === 'PageDown') {\n event.preventDefault();\n setPageIndex(Math.min(maxPageIndex, pageIndex + 1));\n return;\n }\n };\n\n React.useEffect(() => {\n if (useGlobalKeyboardNavigation) {\n window.addEventListener('keydown', onKeyDown);\n }\n\n return () => {\n if (useGlobalKeyboardNavigation) {\n window.removeEventListener('keydown', onKeyDown);\n }\n };\n }, [onKeyDown, useGlobalKeyboardNavigation]);\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { motion, useAnimation } from 'framer-motion';\nimport useTimer from '../../utils/hooks/useTimer';\nimport { getBadgeIcon } from './util';\nimport { State } from '../../types';\nimport { useLocalization } from '../Provider/Localization';\nimport { IconButton } from '../IconButton/IconButton';\n\nexport type ToastsTexts = {\n /** Aria-label for the close icon button of toast */\n dismiss: string;\n};\n\nexport type ToastType = Omit<State, 'default'> | 'loading';\nexport type ToastOptions = {\n /** Provide time in milliseconds after which the toast should autoclose */\n autoClose?: number;\n /**\n * State will change the icon displayed in toast and other characteristics,\n * for e.g. `loading` state will display a progress animation.\n * Default value is `default`\n */\n type?: ToastType;\n};\nexport type ToastContent = Omit<React.ReactNode, 'null' | 'undefined'>;\nexport type ToastProps = {\n /** Provide a unique id for toast */\n id: string;\n /**\n * Content can be any valid react node, for e.g. a `div`, or a simple text.\n */\n content: ToastContent;\n /** Additional options to define your toast */\n options: ToastOptions;\n /**\n * Handler called when toast closes.\n * To read more about how to provide the text, see [Provider](component:provider) component\n */\n onClose: () => void;\n lastUpdated?: number;\n lastDuplicateId?: string;\n};\n\nexport const Toast = ({ content, lastUpdated, onClose: handleClose, options, ...props }: ToastProps): JSX.Element => {\n const { texts } = useLocalization();\n const { autoClose, type = 'default' } = options;\n const className = cn('bg-white relative flex items-center py-1 px-2 mt-3 w-full rounded yt-shadow', {\n 'border border-grey-200': type === 'default' || type === 'loading' || !type,\n 'border border-grey-500': type === 'success',\n 'border border-blue-500': type === 'information',\n 'border border-yellow-700': type === 'warning',\n 'border border-red': type === 'error',\n });\n const timer = useTimer(autoClose, handleClose);\n const controls = useAnimation();\n\n if (!content) {\n console.warn(\n `Toast requires 'content' property, which can't be empty string, null or undefined. Current content value is set to ${\n content === '' ? 'empty string' : content\n }.`\n );\n }\n\n React.useEffect(() => {\n if (autoClose) {\n timer.start();\n }\n }, [autoClose]);\n\n const triggerUpdateAnimation = async () => {\n await controls.start({ scale: 1.05 });\n await controls.start({ scale: 1 });\n };\n\n React.useEffect(() => {\n if (lastUpdated) {\n triggerUpdateAnimation();\n\n if (timer.running) {\n timer.start();\n }\n }\n }, [lastUpdated]);\n\n return (\n <motion.div\n {...props}\n animate={controls}\n className={className}\n data-taco=\"toast\"\n onMouseEnter={timer.pause}\n onMouseLeave={timer.resume}>\n {getBadgeIcon(type)}\n <div className=\"flex-grow\">{content}</div>\n <IconButton\n appearance=\"discrete\"\n className=\"text-grey-700 -mr-2 cursor-pointer self-start !px-0\"\n icon=\"close\"\n aria-label={texts.toasts.dismiss}\n onClick={handleClose}\n />\n </motion.div>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon } from '../Icon/Icon';\nimport { Spinner } from '../Spinner/Spinner';\nimport { ToastType } from './Toast';\n\nexport const getBadgeIcon = (type: ToastType): JSX.Element | null => {\n const css = 'rounded-full flex-shrink-0 mr-2 mt-1 self-start';\n\n switch (type) {\n case 'success':\n return <Icon name=\"tick\" className={cn(css, 'yt-green-solid ')} />;\n\n case 'warning':\n return <Icon name=\"warning\" className={cn(css, 'yt-yellow-solid')} />;\n\n case 'error':\n return <Icon name=\"warning\" className={cn(css, 'yt-red-solid')} />;\n\n case 'information':\n return <Icon name=\"info\" className={cn(css, 'yt-blue-solid')} />;\n\n case 'loading':\n return <Spinner delay={0} className={cn(css, 'h-6 w-6')} />;\n\n default:\n return null;\n }\n};\n","import * as React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport { AnimatePresence, motion } from 'framer-motion';\nimport { ToastOptions, Toast, ToastProps, ToastContent } from './Toast';\nimport './Toast.css';\n\nconst DEFAULT_AUTO_CLOSE_TIMEOUT = 7500;\n\ntype ToastCreator<T> = (content: ToastContent | ((close: () => void) => ToastContent), options?: ToastOptions) => T;\n\nexport interface Toaster<T> extends ToastCreator<T> {\n success: ToastCreator<T>;\n error: ToastCreator<T>;\n warning: ToastCreator<T>;\n information: ToastCreator<T>;\n loading: ToastCreator<T>;\n}\n\nexport interface ToastReference {\n /** Show a success toast */\n success: ToastCreator<void>;\n /** Show an error toast */\n error: ToastCreator<void>;\n /** Show a warning toast */\n warning: ToastCreator<void>;\n /** Show an information toast */\n information: ToastCreator<void>;\n /** Show a loading toast */\n loading: ToastCreator<void>;\n /**\n * Close an existing toast.\n * The toast function returns a reference to the active toast,\n * allowing you to programmatically close it when needed\n */\n close: () => void;\n}\n\nconst ToastContext = React.createContext<Toaster<ToastReference>>({} as Toaster<ToastReference>);\n\nexport interface ToastProviderProps {\n children: React.ReactNode;\n}\n\ntype InternalToast = Omit<ToastProps, 'onClose'>;\n\nconst insertToastWithoutDuplicates = (\n currentToasts: InternalToast[],\n id: string,\n content: ToastContent,\n options: ToastOptions,\n close: () => void\n): InternalToast[] => {\n const nextToasts = [...currentToasts];\n const existingToastIndex = currentToasts.findIndex(toast => JSON.stringify(toast.content) === JSON.stringify(content));\n\n if (existingToastIndex > -1) {\n nextToasts[existingToastIndex].lastDuplicateId = id;\n nextToasts[existingToastIndex].lastUpdated = Date.now();\n } else {\n nextToasts.push({\n id,\n content: typeof content === 'function' ? content(close) : content,\n options,\n });\n }\n\n return nextToasts;\n};\n\nexport const ToastProvider = ({ children, ...props }: ToastProviderProps): JSX.Element => {\n const [toasts, setToasts] = React.useState<InternalToast[]>([]);\n\n const handleClose = (id: string): void => {\n setToasts(currentToasts => currentToasts.filter(toast => toast.id !== id));\n };\n\n // memoize (useCallback) this function,\n // it is the value of the context provider and we don't want it to trigger state tree re-renders on provider children\n const toaster = React.useCallback((content: ToastContent, options: ToastOptions): ToastReference => {\n const id = uuid();\n const close = (): void => handleClose(id);\n\n setToasts(currentToasts => insertToastWithoutDuplicates(currentToasts, id, content, options, close));\n\n const update = (content: ToastContent, options: ToastOptions): void => {\n setToasts(currentToasts => {\n const nextToasts = currentToasts.filter(toast => {\n if (toast.lastDuplicateId) {\n return toast.lastDuplicateId !== id;\n }\n\n return toast.id !== id;\n });\n return insertToastWithoutDuplicates(nextToasts, uuid(), content, options, close);\n });\n };\n\n const success = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { autoClose: DEFAULT_AUTO_CLOSE_TIMEOUT, ...options, type: 'success' });\n };\n const error = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'error' });\n };\n const warning = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'warning' });\n };\n const information = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'information' });\n };\n const loading = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): void => {\n update(content, { ...options, type: 'loading' });\n };\n\n return {\n success,\n error,\n warning,\n information,\n loading,\n close,\n };\n }, []) as Toaster<ToastReference>;\n\n // no need to rebind these every render, do them once in an effect\n React.useEffect(() => {\n toaster.success = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { autoClose: DEFAULT_AUTO_CLOSE_TIMEOUT, ...options, type: 'success' });\n toaster.error = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'error' });\n toaster.warning = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'warning' });\n toaster.information = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'information' });\n toaster.loading = (content: ToastContent, options?: Omit<ToastOptions, 'type'>): ToastReference =>\n toaster(content, { ...options, type: 'loading' });\n }, []);\n\n return (\n <ToastContext.Provider {...props} value={toaster}>\n {children}\n <div\n id=\"yt-toast__container\"\n className=\"pointer-events-all absolute bottom-0 right-0 !left-auto z-[1000] mb-4 mr-4 flex max-w-md flex-col items-end justify-end\"\n role=\"log\">\n <AnimatePresence initial={false}>\n {toasts.map((toast: InternalToast) => (\n <motion.div\n key={toast.id}\n transition={{\n type: 'spring',\n damping: 20,\n stiffness: 300,\n }}\n initial={{ opacity: 0, y: 10, scale: 0.5 }}\n animate={{ opacity: 1, y: 0, scale: 1 }}\n exit={{ opacity: 0, scale: 0.5, transition: { duration: 0.2 } }}>\n <Toast {...toast} onClose={() => handleClose(toast.id)} />\n </motion.div>\n ))}\n </AnimatePresence>\n </div>\n </ToastContext.Provider>\n );\n};\n\nexport const useToast = (): Toaster<ToastReference> => React.useContext(ToastContext);\n","export const isAriaSelectionKey = (event: React.KeyboardEvent) => {\n if (event.key === 'Enter' || event.key === ' ' || event.key === 'Tab') {\n return true;\n }\n\n return false;\n};\n\nexport const isAriaDirectionKey = (event: React.KeyboardEvent) => {\n if (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'Home' || event.key === 'End') {\n return true;\n }\n\n return false;\n};\n","import React from 'react';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { isAriaDirectionKey } from '../../../utils/aria';\nimport { createCustomKeyboardEvent } from '../../../utils/input';\n\n/* This component provides a keyboard navigable collection primitive for use in lists\n * It is unlikely you need to edit this component\n */\n\nexport type CollectionProps = React.HTMLAttributes<HTMLDivElement> & {\n querySelector: string;\n};\n\nexport type CollectionRef = HTMLDivElement & {\n setActiveIndex: (option: HTMLDivElement) => void;\n};\n\nconst getOptionsFromCollection = (collection: HTMLDivElement, selector: string): NodeListOf<Element> =>\n collection.querySelectorAll(selector);\n\n// we use javascript to set attributes (rather than cloning children and adding them)\n// so that we can support nesting (e.g. groups) - child elements that aren't options.\n// without doing this we would have to unwrap and flatten all groups\nexport const Root = React.forwardRef<CollectionRef, CollectionProps>(function CollectionRoot(props, ref) {\n const { querySelector, tabIndex = 0, ...otherProps } = props;\n const internalRef = useMergedRef<CollectionRef>(ref);\n const [activeIndex, setActiveIndex] = React.useState<number | undefined>();\n const lastLengthRef = React.useRef(0);\n\n const setActiveOption = (index: number, collection: HTMLDivElement, option: Element) => {\n collection.querySelector(`[aria-current]`)?.removeAttribute('aria-current');\n option.setAttribute('aria-current', 'true');\n option.scrollIntoView({ block: 'nearest' });\n setActiveIndex(index);\n };\n\n const setActiveIndexByElement = React.useCallback(\n (option: HTMLDivElement) => {\n if (internalRef.current) {\n if (option.matches(querySelector)) {\n const options = getOptionsFromCollection(internalRef.current, querySelector);\n const nextActiveIndex = Array.from(options).indexOf(option);\n\n if (nextActiveIndex > -1) {\n setActiveOption(nextActiveIndex, internalRef.current, option);\n }\n }\n }\n },\n [internalRef.current, querySelector]\n );\n\n React.useEffect(() => {\n if (internalRef.current) {\n internalRef.current.setActiveIndex = setActiveIndexByElement;\n }\n }, [internalRef.current]);\n\n React.useEffect(() => {\n if (internalRef.current) {\n const options = getOptionsFromCollection(internalRef.current, querySelector);\n\n if (options.length && options.length !== lastLengthRef.current) {\n const selected = internalRef.current.querySelectorAll(`[aria-selected]`);\n\n if (selected.length === 1) {\n if (options) {\n const firstSelected = selected.item(0);\n const selectedIndex = Array.from(options).indexOf(firstSelected);\n\n if (selectedIndex > -1) {\n setActiveOption(selectedIndex, internalRef.current, firstSelected);\n }\n }\n } else {\n // multiple selected or none selected should go to 0\n setActiveOption(0, internalRef.current, options.item(0));\n }\n }\n\n lastLengthRef.current = options.length;\n }\n }, [props.children]);\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>) => {\n const option = event.target as HTMLElement;\n\n if (option.matches(querySelector)) {\n const options = getOptionsFromCollection(event.currentTarget, querySelector);\n const nextActiveIndex = Array.from(options).indexOf(option);\n\n if (nextActiveIndex > -1) {\n setActiveOption(nextActiveIndex, event.currentTarget, option);\n }\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n // this stops the event dispatched to the option rebounding back and starting an infinite loop\n if (event.target !== event.currentTarget) {\n return;\n }\n\n const options = getOptionsFromCollection(event.currentTarget, querySelector);\n\n if (options) {\n if (isAriaDirectionKey(event)) {\n const nextActiveIndex = getNextEnabledItem(event, options, activeIndex);\n\n if (nextActiveIndex !== undefined && nextActiveIndex !== activeIndex) {\n event.preventDefault();\n setActiveOption(nextActiveIndex, event.currentTarget, options.item(nextActiveIndex));\n }\n } else if (activeIndex !== undefined) {\n // forward events onto the underlying option - this lets consumers place onKeyDown handlers on their own components\n options\n .item(activeIndex)\n .dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n }\n }\n };\n\n return <div {...otherProps} onClick={handleClick} onKeyDown={handleKeyDown} ref={internalRef} tabIndex={tabIndex} />;\n});\n\nexport const getNextIndexFromKeycode = (\n event: React.KeyboardEvent,\n length: number,\n activeIndex: number | undefined\n): number | undefined => {\n switch (event.key) {\n case 'ArrowUp':\n return activeIndex === undefined ? length - 1 : activeIndex > 0 ? activeIndex - 1 : activeIndex;\n\n case 'ArrowDown':\n return activeIndex === undefined ? 0 : activeIndex < length - 1 ? activeIndex + 1 : activeIndex;\n\n case 'Home':\n return 0;\n\n case 'End':\n return length - 1;\n\n default:\n return;\n }\n};\n\nexport const getNextEnabledItem = (\n event: React.KeyboardEvent<HTMLElement>,\n options: NodeListOf<Element>,\n activeIndex: number | undefined,\n recurse = true\n): number | undefined => {\n const nextIndex = getNextIndexFromKeycode(event, options.length, activeIndex);\n\n if (nextIndex !== undefined) {\n if (nextIndex === activeIndex) {\n return activeIndex;\n } else if (options.item(nextIndex) && isSkippableItem(options.item(nextIndex))) {\n // check in the other direction if the first or last item is disabled,\n // but prevent infinite loops if all elements are disabled by disabling recursion\n if (recurse) {\n if (nextIndex === 0) {\n return getNextEnabledItem(\n new KeyboardEvent(event.type, { ...(event as any), key: 'ArrowDown' }) as any,\n options,\n nextIndex,\n false\n );\n } else if (nextIndex === options.length - 1) {\n return getNextEnabledItem(\n new KeyboardEvent(event.type, { ...(event as any), key: 'ArrowUp' }) as any,\n options,\n nextIndex,\n false\n );\n }\n }\n\n return getNextEnabledItem(event, options, nextIndex, recurse);\n }\n }\n\n return nextIndex;\n};\n\nconst isSkippableItem = (element: Element) => {\n return (\n element.getAttribute('role') === 'presentation' ||\n !!element.hasAttribute('disabled') ||\n !!element.getAttribute('aria-disabled') ||\n !!element.getAttribute('aria-hidden')\n );\n};\n","import React from 'react';\nimport { Listbox2Value } from '../types';\n\nexport type Listbox2ContextProps = {\n disabled: boolean;\n readOnly: boolean;\n setValue: (value: Listbox2Value) => void;\n value?: Listbox2Value;\n};\n\nexport const Listbox2Context = React.createContext({} as Listbox2ContextProps);\nexport const useListbox2Context = () => React.useContext(Listbox2Context);\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport * as CollectionPrimitive from '../../Collection/Collection';\nimport { Listbox2Value } from '../types';\nimport { Listbox2Context } from './Context';\n\nexport type Listbox2Props = React.HTMLAttributes<HTMLDivElement> & {\n customSelector?: string;\n disabled?: boolean;\n multiple?: boolean;\n readOnly?: boolean;\n setValue: (value: Listbox2Value) => void;\n value?: Listbox2Value;\n};\n\nconst DEFAULT_SELECTOR = '[role=\"option\"]';\n\nexport const Root = React.forwardRef<CollectionPrimitive.CollectionRef, Listbox2Props>(function Listbox2(props, ref) {\n const {\n children,\n customSelector,\n disabled = false,\n id: nativeId,\n multiple,\n readOnly = false,\n setValue,\n title,\n value,\n ...otherProps\n } = props;\n const id = useId(nativeId);\n\n const context = React.useMemo(\n () => ({\n disabled,\n readOnly,\n setValue,\n value,\n }),\n [disabled, readOnly, value]\n );\n\n return (\n <Listbox2Context.Provider value={context}>\n <div data-taco=\"listbox2\">\n <CollectionPrimitive.Root\n {...otherProps}\n aria-multiselectable={multiple ? true : undefined}\n id={id}\n ref={ref}\n role=\"listbox\"\n querySelector={customSelector ? `${DEFAULT_SELECTOR}, ${customSelector}` : DEFAULT_SELECTOR}>\n {children}\n </CollectionPrimitive.Root>\n </div>\n </Listbox2Context.Provider>\n );\n});\n\nexport const createListboxValueSetter =\n (multiple: boolean, setValue: React.Dispatch<React.SetStateAction<Listbox2Value | undefined>>) =>\n (nextValue: Listbox2Value) => {\n setValue(value => {\n if (Array.isArray(nextValue)) {\n return nextValue;\n }\n\n if (multiple) {\n if (value === undefined) {\n return [nextValue];\n } else if (Array.isArray(value)) {\n if (value.includes(nextValue)) {\n return value.filter(v => v !== nextValue);\n }\n\n return [...value, nextValue];\n } else if (value === nextValue) {\n return [];\n }\n\n return [value, nextValue];\n }\n\n return nextValue;\n });\n };\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Listbox2OptionValue } from '../types';\nimport { useListbox2Context } from './Context';\n\nexport type Listbox2OptionProps = React.HTMLAttributes<HTMLDivElement> & {\n disabled?: boolean;\n value: Listbox2OptionValue;\n};\n\nexport const Option = React.forwardRef<HTMLDivElement, Listbox2OptionProps>(function Listbox2Option(props, ref) {\n const { disabled, id: nativeId, title, value, ...otherProps } = props;\n const { disabled: listboxDisabled, readOnly: listboxReadOnly, setValue, value: currentValue } = useListbox2Context();\n const id = useId(nativeId);\n const selected = Array.isArray(currentValue) ? currentValue.includes(value) : currentValue === value;\n\n const handleClick = (event: React.MouseEvent<HTMLDivElement>) => {\n if (disabled || listboxDisabled || listboxReadOnly) {\n event.stopPropagation();\n return;\n } else {\n setValue(value);\n }\n\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLDivElement>) => {\n if (disabled || listboxDisabled || listboxReadOnly) {\n event.stopPropagation();\n return;\n } else if (isAriaSelectionKey(event)) {\n setValue(value);\n }\n\n if (typeof props.onKeyDown === 'function') {\n props.onKeyDown(event);\n }\n };\n\n return (\n <div\n {...otherProps}\n aria-disabled={listboxDisabled || disabled ? 'true' : undefined}\n aria-selected={selected ? 'true' : undefined}\n id={id}\n onClick={handleClick}\n onKeyDown={handleKeyDown}\n ref={ref}\n role=\"option\"\n />\n );\n});\n","import React from 'react';\n\nexport type Listbox2GroupProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Group = React.forwardRef<HTMLDivElement, Listbox2GroupProps>(function Listbox2Group(props, ref) {\n const [labelledById, setLabelledById] = React.useState<string>();\n\n return (\n <Listbox2GroupContext.Provider value={{ setLabelledById }}>\n <div {...props} aria-labelledby={labelledById} ref={ref} role=\"group\" />\n </Listbox2GroupContext.Provider>\n );\n});\n\nexport type Listbox2GroupContextProps = {\n setLabelledById: (id: string) => void;\n};\n\nexport const Listbox2GroupContext = React.createContext({} as Listbox2GroupContextProps);\nexport const useListbox2GroupContext = () => React.useContext(Listbox2GroupContext);\n","import React from 'react';\nimport { useId } from '../../../hooks/useId';\nimport { useListbox2GroupContext } from './Group';\n\nexport type Listbox2TitleProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport const Title = React.forwardRef<HTMLDivElement, Listbox2TitleProps>(function Listbox2Group(props, ref) {\n const { id: nativeId, ...otherProps } = props;\n const { setLabelledById } = useListbox2GroupContext();\n const id = useId(nativeId);\n\n React.useEffect(() => {\n setLabelledById(id);\n }, [id]);\n\n return <div {...otherProps} id={id} ref={ref} role=\"presentation\" />;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon, IconName, IconProps } from '../Icon/Icon';\n\nexport const TAG_COLORS = {\n green: 'wcag-green-100',\n yellow: 'wcag-yellow-100',\n red: 'wcag-red-100',\n blue: 'wcag-blue-100',\n purple: 'wcag-purple-100',\n orange: 'wcag-orange-100',\n brown: 'wcag-brown-100',\n pink: 'wcag-pink-100',\n grey: 'wcag-grey-200',\n};\n\nexport type TagColor = keyof typeof TAG_COLORS;\n\nexport type TagProps = Omit<React.HTMLAttributes<HTMLSpanElement>, 'children'> & {\n children: string;\n color?: TagColor;\n disabled?: boolean;\n icon?: React.ReactElement<IconProps> | IconName;\n readOnly?: boolean;\n onDelete?: (event: React.MouseEvent<SVGSVGElement>) => void;\n};\n\nexport const Tag = React.forwardRef<HTMLSpanElement, TagProps>((props, ref) => {\n const { children, color, disabled, icon, readOnly, onDelete, ...otherProps } = props;\n const textRef = React.useRef<HTMLDivElement>(null);\n\n const className = cn(\n 'inline-flex items-center rounded h-6 cursor-default',\n {\n 'opacity-50': disabled,\n 'hover:bg-opacity-75': !disabled,\n 'cursor-pointer': !!otherProps.onClick,\n 'pointer-events-none': disabled || readOnly,\n },\n color ? TAG_COLORS[color] : TAG_COLORS.grey,\n props.className\n );\n\n return (\n <span {...otherProps} className={className} ref={ref}>\n <span className=\"truncate px-2\" ref={textRef}>\n {icon ? (\n typeof icon === 'string' ? (\n <Icon name={icon} className=\"mr-1 -ml-1 -mt-0.5 !h-5 !w-5\" />\n ) : (\n React.cloneElement(icon, { className: 'mr-1 -ml-1 -mt-0.5 !h-5 !w-5' })\n )\n ) : null}\n {children}\n </span>\n {onDelete ? (\n <Icon\n name=\"close\"\n onClick={onDelete}\n className=\"-ml-1.5 !h-6 !w-5 flex-shrink-0 cursor-pointer rounded-r p-0.5 hover:bg-black/5\"\n />\n ) : null}\n </span>\n );\n});\n","import React from 'react';\nimport { CollectionRef } from '../../../primitives/Collection/Collection';\nimport { Color } from '../../../utils/colors';\nimport { Select2OptionValue, Select2Value } from '../types';\nimport { Select2OptionProps } from './Option';\n\nexport type Select2ContextProps = {\n disabled: boolean;\n highlighted: boolean;\n invalid: boolean;\n listboxRef: React.RefObject<CollectionRef>;\n multiple: boolean;\n onCreate?: (text: string, color: Color | undefined) => Promise<Select2OptionProps>;\n onDelete?: (value: Select2OptionValue) => Promise<void>;\n onEdit?: (value: Select2OptionValue, text: string, color: Color | undefined) => Promise<void>;\n open: boolean;\n readOnly: boolean;\n ref: React.RefObject<HTMLButtonElement>;\n searchQuery: string;\n searchRef?: React.RefObject<HTMLInputElement>;\n setOpen: (open: boolean) => void;\n setSearchQuery: (value: string) => void;\n setValidationError: (error: Error | undefined) => void;\n setValue: (value: Select2OptionValue) => void;\n tags?: boolean;\n validationError?: Error;\n value?: Select2Value;\n};\n\nexport const Select2Context = React.createContext({} as Select2ContextProps);\nexport const useSelect2Context = () => React.useContext(Select2Context);\n","// A type of promise-like that resolves synchronously and supports only one observer\nexport const _Pact = /*#__PURE__*/(function() {\n\tfunction _Pact() {}\n\t_Pact.prototype.then = function(onFulfilled, onRejected) {\n\t\tconst result = new _Pact();\n\t\tconst state = this.s;\n\t\tif (state) {\n\t\t\tconst callback = state & 1 ? onFulfilled : onRejected;\n\t\t\tif (callback) {\n\t\t\t\ttry {\n\t\t\t\t\t_settle(result, 1, callback(this.v));\n\t\t\t\t} catch (e) {\n\t\t\t\t\t_settle(result, 2, e);\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t} else {\n\t\t\t\treturn this;\n\t\t\t}\n\t\t}\n\t\tthis.o = function(_this) {\n\t\t\ttry {\n\t\t\t\tconst value = _this.v;\n\t\t\t\tif (_this.s & 1) {\n\t\t\t\t\t_settle(result, 1, onFulfilled ? onFulfilled(value) : value);\n\t\t\t\t} else if (onRejected) {\n\t\t\t\t\t_settle(result, 1, onRejected(value));\n\t\t\t\t} else {\n\t\t\t\t\t_settle(result, 2, value);\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\t_settle(result, 2, e);\n\t\t\t}\n\t\t};\n\t\treturn result;\n\t}\n\treturn _Pact;\n})();\n\n// Settles a pact synchronously\nexport function _settle(pact, state, value) {\n\tif (!pact.s) {\n\t\tif (value instanceof _Pact) {\n\t\t\tif (value.s) {\n\t\t\t\tif (state & 1) {\n\t\t\t\t\tstate = value.s;\n\t\t\t\t}\n\t\t\t\tvalue = value.v;\n\t\t\t} else {\n\t\t\t\tvalue.o = _settle.bind(null, pact, state);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\tif (value && value.then) {\n\t\t\tvalue.then(_settle.bind(null, pact, state), _settle.bind(null, pact, 2));\n\t\t\treturn;\n\t\t}\n\t\tpact.s = state;\n\t\tpact.v = value;\n\t\tconst observer = pact.o;\n\t\tif (observer) {\n\t\t\tobserver(pact);\n\t\t}\n\t}\n}\n\nexport function _isSettledPact(thenable) {\n\treturn thenable instanceof _Pact && thenable.s & 1;\n}\n\n// Converts argument to a function that always returns a Promise\nexport function _async(f) {\n\treturn function() {\n\t\tfor (var args = [], i = 0; i < arguments.length; i++) {\n\t\t\targs[i] = arguments[i];\n\t\t}\n\t\ttry {\n\t\t\treturn Promise.resolve(f.apply(this, args));\n\t\t} catch(e) {\n\t\t\treturn Promise.reject(e);\n\t\t}\n\t}\n}\n\n// Awaits on a value that may or may not be a Promise (equivalent to the await keyword in ES2015, with continuations passed explicitly)\nexport function _await(value, then, direct) {\n\tif (direct) {\n\t\treturn then ? then(value) : value;\n\t}\n\tif (!value || !value.then) {\n\t\tvalue = Promise.resolve(value);\n\t}\n\treturn then ? value.then(then) : value;\n}\n\n// Awaits on a value that may or may not be a Promise, then ignores it\nexport function _awaitIgnored(value, direct) {\n\tif (!direct) {\n\t\treturn value && value.then ? value.then(_empty) : Promise.resolve();\n\t}\n}\n\n// Proceeds after a value has resolved, or proceeds immediately if the value is not thenable\nexport function _continue(value, then) {\n\treturn value && value.then ? value.then(then) : then(value);\n}\n\n// Proceeds after a value has resolved, or proceeds immediately if the value is not thenable\nexport function _continueIgnored(value) {\n\tif (value && value.then) {\n\t\treturn value.then(_empty);\n\t}\n}\n\n// Asynchronously iterate through an object that has a length property, passing the index as the first argument to the callback (even as the length property changes)\nexport function _forTo(array, body, check) {\n\tvar i = -1, pact, reject;\n\tfunction _cycle(result) {\n\t\ttry {\n\t\t\twhile (++i < array.length && (!check || !check())) {\n\t\t\t\tresult = body(i);\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.then(_cycle, reject || (reject = _settle.bind(null, pact = new _Pact(), 2)));\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (pact) {\n\t\t\t\t_settle(pact, 1, result);\n\t\t\t} else {\n\t\t\t\tpact = result;\n\t\t\t}\n\t\t} catch (e) {\n\t\t\t_settle(pact || (pact = new _Pact()), 2, e);\n\t\t}\n\t}\n\t_cycle();\n\treturn pact;\n}\n\n// Asynchronously iterate through an object's properties (including properties inherited from the prototype)\n// Uses a snapshot of the object's properties\nexport function _forIn(target, body, check) {\n\tvar keys = [];\n\tfor (var key in target) {\n\t\tkeys.push(key);\n\t}\n\treturn _forTo(keys, function(i) { return body(keys[i]); }, check);\n}\n\n// Asynchronously iterate through an object's own properties (excluding properties inherited from the prototype)\n// Uses a snapshot of the object's properties\nexport function _forOwn(target, body, check) {\n\tvar keys = [];\n\tfor (var key in target) {\n\t\tif (Object.prototype.hasOwnProperty.call(target, key)) {\n\t\t\tkeys.push(key);\n\t\t}\n\t}\n\treturn _forTo(keys, function(i) { return body(keys[i]); }, check);\n}\n\nexport const _iteratorSymbol = /*#__PURE__*/ typeof Symbol !== \"undefined\" ? (Symbol.iterator || (Symbol.iterator = Symbol(\"Symbol.iterator\"))) : \"@@iterator\";\n\n// Asynchronously iterate through an object's values\n// Uses for...of if the runtime supports it, otherwise iterates until length on a copy\nexport function _forOf(target, body, check) {\n\tif (typeof target[_iteratorSymbol] === \"function\") {\n\t\tvar iterator = target[_iteratorSymbol](), step, pact, reject;\n\t\tfunction _cycle(result) {\n\t\t\ttry {\n\t\t\t\twhile (!(step = iterator.next()).done && (!check || !check())) {\n\t\t\t\t\tresult = body(step.value);\n\t\t\t\t\tif (result && result.then) {\n\t\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tresult.then(_cycle, reject || (reject = _settle.bind(null, pact = new _Pact(), 2)));\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif (pact) {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t} else {\n\t\t\t\t\tpact = result;\n\t\t\t\t}\n\t\t\t} catch (e) {\n\t\t\t\t_settle(pact || (pact = new _Pact()), 2, e);\n\t\t\t}\n\t\t}\n\t\t_cycle();\n\t\tif (iterator.return) {\n\t\t\tvar _fixup = function(value) {\n\t\t\t\ttry {\n\t\t\t\t\tif (!step.done) {\n\t\t\t\t\t\titerator.return();\n\t\t\t\t\t}\n\t\t\t\t} catch(e) {\n\t\t\t\t}\n\t\t\t\treturn value;\n\t\t\t}\n\t\t\tif (pact && pact.then) {\n\t\t\t\treturn pact.then(_fixup, function(e) {\n\t\t\t\t\tthrow _fixup(e);\n\t\t\t\t});\n\t\t\t}\n\t\t\t_fixup();\n\t\t}\n\t\treturn pact;\n\t}\n\t// No support for Symbol.iterator\n\tif (!(\"length\" in target)) {\n\t\tthrow new TypeError(\"Object is not iterable\");\n\t}\n\t// Handle live collections properly\n\tvar values = [];\n\tfor (var i = 0; i < target.length; i++) {\n\t\tvalues.push(target[i]);\n\t}\n\treturn _forTo(values, function(i) { return body(values[i]); }, check);\n}\n\nexport const _asyncIteratorSymbol = /*#__PURE__*/ typeof Symbol !== \"undefined\" ? (Symbol.asyncIterator || (Symbol.asyncIterator = Symbol(\"Symbol.asyncIterator\"))) : \"@@asyncIterator\";\n\n// Asynchronously iterate on a value using it's async iterator if present, or its synchronous iterator if missing\nexport function _forAwaitOf(target, body, check) {\n\tif (typeof target[_asyncIteratorSymbol] === \"function\") {\n\t\tvar pact = new _Pact();\n\t\tvar iterator = target[_asyncIteratorSymbol]();\n\t\titerator.next().then(_resumeAfterNext).then(void 0, _reject);\n\t\treturn pact;\n\t\tfunction _resumeAfterBody(result) {\n\t\t\tif (check && check()) {\n\t\t\t\treturn _settle(pact, 1, iterator.return ? iterator.return().then(function() { return result; }) : result);\n\t\t\t}\n\t\t\titerator.next().then(_resumeAfterNext).then(void 0, _reject);\n\t\t}\n\t\tfunction _resumeAfterNext(step) {\n\t\t\tif (step.done) {\n\t\t\t\t_settle(pact, 1);\n\t\t\t} else {\n\t\t\t\tPromise.resolve(body(step.value)).then(_resumeAfterBody).then(void 0, _reject);\n\t\t\t}\n\t\t}\n\t\tfunction _reject(error) {\n\t\t\t_settle(pact, 2, iterator.return ? iterator.return().then(function() { return error; }) : error);\n\t\t}\n\t}\n\treturn Promise.resolve(_forOf(target, function(value) { return Promise.resolve(value).then(body); }, check));\n}\n\n// Asynchronously implement a generic for loop\nexport function _for(test, update, body) {\n\tvar stage;\n\tfor (;;) {\n\t\tvar shouldContinue = test();\n\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\tshouldContinue = shouldContinue.v;\n\t\t}\n\t\tif (!shouldContinue) {\n\t\t\treturn result;\n\t\t}\n\t\tif (shouldContinue.then) {\n\t\t\tstage = 0;\n\t\t\tbreak;\n\t\t}\n\t\tvar result = body();\n\t\tif (result && result.then) {\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.s;\n\t\t\t} else {\n\t\t\t\tstage = 1;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tif (update) {\n\t\t\tvar updateValue = update();\n\t\t\tif (updateValue && updateValue.then && !_isSettledPact(updateValue)) {\n\t\t\t\tstage = 2;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\tvar pact = new _Pact();\n\tvar reject = _settle.bind(null, pact, 2);\n\t(stage === 0 ? shouldContinue.then(_resumeAfterTest) : stage === 1 ? result.then(_resumeAfterBody) : updateValue.then(_resumeAfterUpdate)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterBody(value) {\n\t\tresult = value;\n\t\tdo {\n\t\t\tif (update) {\n\t\t\t\tupdateValue = update();\n\t\t\t\tif (updateValue && updateValue.then && !_isSettledPact(updateValue)) {\n\t\t\t\t\tupdateValue.then(_resumeAfterUpdate).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tshouldContinue = test();\n\t\t\tif (!shouldContinue || (_isSettledPact(shouldContinue) && !shouldContinue.v)) {\n\t\t\t\t_settle(pact, 1, result);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.v;\n\t\t\t}\n\t\t} while (!result || !result.then);\n\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t}\n\tfunction _resumeAfterTest(shouldContinue) {\n\t\tif (shouldContinue) {\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t} else {\n\t\t\t\t_resumeAfterBody(result);\n\t\t\t}\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n\tfunction _resumeAfterUpdate() {\n\t\tif (shouldContinue = test()) {\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t} else {\n\t\t\t\t_resumeAfterTest(shouldContinue);\n\t\t\t}\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n}\n\n// Asynchronously implement a do ... while loop\nexport function _do(body, test) {\n\tvar awaitBody;\n\tdo {\n\t\tvar result = body();\n\t\tif (result && result.then) {\n\t\t\tif (_isSettledPact(result)) {\n\t\t\t\tresult = result.v;\n\t\t\t} else {\n\t\t\t\tawaitBody = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\tvar shouldContinue = test();\n\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\tshouldContinue = shouldContinue.v;\n\t\t}\n\t\tif (!shouldContinue) {\n\t\t\treturn result;\n\t\t}\n\t} while (!shouldContinue.then);\n\tconst pact = new _Pact();\n\tconst reject = _settle.bind(null, pact, 2);\n\t(awaitBody ? result.then(_resumeAfterBody) : shouldContinue.then(_resumeAfterTest)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterBody(value) {\n\t\tresult = value;\n\t\tfor (;;) {\n\t\t\tshouldContinue = test();\n\t\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\t\tshouldContinue = shouldContinue.v;\n\t\t\t}\n\t\t\tif (!shouldContinue) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (shouldContinue.then) {\n\t\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\tresult = result.v;\n\t\t\t\t} else {\n\t\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t_settle(pact, 1, result);\n\t}\n\tfunction _resumeAfterTest(shouldContinue) {\n\t\tif (shouldContinue) {\n\t\t\tdo {\n\t\t\t\tresult = body();\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tif (_isSettledPact(result)) {\n\t\t\t\t\t\tresult = result.v;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\t\t\treturn;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tshouldContinue = test();\n\t\t\t\tif (_isSettledPact(shouldContinue)) {\n\t\t\t\t\tshouldContinue = shouldContinue.v;\n\t\t\t\t}\n\t\t\t\tif (!shouldContinue) {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} while (!shouldContinue.then);\n\t\t\tshouldContinue.then(_resumeAfterTest).then(void 0, reject);\n\t\t} else {\n\t\t\t_settle(pact, 1, result);\n\t\t}\n\t}\n}\n\n// Asynchronously implement a switch statement\nexport function _switch(discriminant, cases) {\n\tvar dispatchIndex = -1;\n\tvar awaitBody;\n\touter: {\n\t\tfor (var i = 0; i < cases.length; i++) {\n\t\t\tvar test = cases[i][0];\n\t\t\tif (test) {\n\t\t\t\tvar testValue = test();\n\t\t\t\tif (testValue && testValue.then) {\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\t\t\t\tif (testValue === discriminant) {\n\t\t\t\t\tdispatchIndex = i;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Found the default case, set it as the pending dispatch case\n\t\t\t\tdispatchIndex = i;\n\t\t\t}\n\t\t}\n\t\tif (dispatchIndex !== -1) {\n\t\t\tdo {\n\t\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\t\twhile (!body) {\n\t\t\t\t\tdispatchIndex++;\n\t\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t\t}\n\t\t\t\tvar result = body();\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tawaitBody = true;\n\t\t\t\t\tbreak outer;\n\t\t\t\t}\n\t\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\t\tdispatchIndex++;\n\t\t\t} while (fallthroughCheck && !fallthroughCheck());\n\t\t\treturn result;\n\t\t}\n\t}\n\tconst pact = new _Pact();\n\tconst reject = _settle.bind(null, pact, 2);\n\t(awaitBody ? result.then(_resumeAfterBody) : testValue.then(_resumeAfterTest)).then(void 0, reject);\n\treturn pact;\n\tfunction _resumeAfterTest(value) {\n\t\tfor (;;) {\n\t\t\tif (value === discriminant) {\n\t\t\t\tdispatchIndex = i;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (++i === cases.length) {\n\t\t\t\tif (dispatchIndex !== -1) {\n\t\t\t\t\tbreak;\n\t\t\t\t} else {\n\t\t\t\t\t_settle(pact, 1, result);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\ttest = cases[i][0];\n\t\t\tif (test) {\n\t\t\t\tvalue = test();\n\t\t\t\tif (value && value.then) {\n\t\t\t\t\tvalue.then(_resumeAfterTest).then(void 0, reject);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tdispatchIndex = i;\n\t\t\t}\n\t\t}\n\t\tdo {\n\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\twhile (!body) {\n\t\t\t\tdispatchIndex++;\n\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t}\n\t\t\tvar result = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\tdispatchIndex++;\n\t\t} while (fallthroughCheck && !fallthroughCheck());\n\t\t_settle(pact, 1, result);\n\t}\n\tfunction _resumeAfterBody(result) {\n\t\tfor (;;) {\n\t\t\tvar fallthroughCheck = cases[dispatchIndex][2];\n\t\t\tif (!fallthroughCheck || fallthroughCheck()) {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tdispatchIndex++;\n\t\t\tvar body = cases[dispatchIndex][1];\n\t\t\twhile (!body) {\n\t\t\t\tdispatchIndex++;\n\t\t\t\tbody = cases[dispatchIndex][1];\n\t\t\t}\n\t\t\tresult = body();\n\t\t\tif (result && result.then) {\n\t\t\t\tresult.then(_resumeAfterBody).then(void 0, reject);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\t_settle(pact, 1, result);\n\t}\n}\n\n// Asynchronously call a function and pass the result to explicitly passed continuations\nexport function _call(body, then, direct) {\n\tif (direct) {\n\t\treturn then ? then(body()) : body();\n\t}\n\ttry {\n\t\tvar result = Promise.resolve(body());\n\t\treturn then ? result.then(then) : result;\n\t} catch (e) {\n\t\treturn Promise.reject(e);\n\t}\n}\n\n// Asynchronously call a function and swallow the result\nexport function _callIgnored(body, direct) {\n\treturn _call(body, _empty, direct);\n}\n\n// Asynchronously call a function and pass the result to explicitly passed continuations\nexport function _invoke(body, then) {\n\tvar result = body();\n\tif (result && result.then) {\n\t\treturn result.then(then);\n\t}\n\treturn then(result);\n}\n\n// Asynchronously call a function and swallow the result\nexport function _invokeIgnored(body) {\n\tvar result = body();\n\tif (result && result.then) {\n\t\treturn result.then(_empty);\n\t}\n}\n\n// Asynchronously call a function and send errors to recovery continuation\nexport function _catch(body, recover) {\n\ttry {\n\t\tvar result = body();\n\t} catch(e) {\n\t\treturn recover(e);\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(void 0, recover);\n\t}\n\treturn result;\n}\n\n// Asynchronously await a promise and pass the result to a finally continuation\nexport function _finallyRethrows(body, finalizer) {\n\ttry {\n\t\tvar result = body();\n\t} catch (e) {\n\t\treturn finalizer(true, e);\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(finalizer.bind(null, false), finalizer.bind(null, true));\n\t}\n\treturn finalizer(false, result);\n}\n\n// Asynchronously await a promise and invoke a finally continuation that always overrides the result\nexport function _finally(body, finalizer) {\n\ttry {\n\t\tvar result = body();\n\t} catch (e) {\n\t\treturn finalizer();\n\t}\n\tif (result && result.then) {\n\t\treturn result.then(finalizer, finalizer);\n\t}\n\treturn finalizer();\n}\n\n// Rethrow or return a value from a finally continuation\nexport function _rethrow(thrown, value) {\n\tif (thrown)\n\t\tthrow value;\n\treturn value;\n}\n\n// Empty function to implement break and other control flow that ignores asynchronous results\nexport function _empty() {\n}\n\n// Sentinel value for early returns in generators \nexport const _earlyReturn = /*#__PURE__*/ {};\n\n// Asynchronously call a function and send errors to recovery continuation, skipping early returns\nexport function _catchInGenerator(body, recover) {\n\treturn _catch(body, function(e) {\n\t\tif (e === _earlyReturn) {\n\t\t\tthrow e;\n\t\t}\n\t\treturn recover(e);\n\t});\n}\n\n// Asynchronous generator class; accepts the entrypoint of the generator, to which it passes itself when the generator should start\nexport const _AsyncGenerator = /*#__PURE__*/(function() {\n\tfunction _AsyncGenerator(entry) {\n\t\tthis._entry = entry;\n\t\tthis._pact = null;\n\t\tthis._resolve = null;\n\t\tthis._return = null;\n\t\tthis._promise = null;\n\t}\n\n\tfunction _wrapReturnedValue(value) {\n\t\treturn { value: value, done: true };\n\t}\n\tfunction _wrapYieldedValue(value) {\n\t\treturn { value: value, done: false };\n\t}\n\n\t_AsyncGenerator.prototype._yield = function(value) {\n\t\t// Yield the value to the pending next call\n\t\tthis._resolve(value && value.then ? value.then(_wrapYieldedValue) : _wrapYieldedValue(value));\n\t\t// Return a pact for an upcoming next/return/throw call\n\t\treturn this._pact = new _Pact();\n\t};\n\t_AsyncGenerator.prototype.next = function(value) {\n\t\t// Advance the generator, starting it if it has yet to be started\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tconst _entry = _this._entry;\n\t\t\t\tif (_entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the next call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Start the generator\n\t\t\t\t_this._entry = null;\n\t\t\t\t_this._resolve = resolve;\n\t\t\t\tfunction returnValue(value) {\n\t\t\t\t\t_this._resolve(value && value.then ? value.then(_wrapReturnedValue) : _wrapReturnedValue(value));\n\t\t\t\t\t_this._pact = null;\n\t\t\t\t\t_this._resolve = null;\n\t\t\t\t}\n\t\t\t\tvar result = _entry(_this);\n\t\t\t\tif (result && result.then) {\n\t\t\t\t\tresult.then(returnValue, function(error) {\n\t\t\t\t\t\tif (error === _earlyReturn) {\n\t\t\t\t\t\t\treturnValue(_this._return);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tconst pact = new _Pact();\n\t\t\t\t\t\t\t_this._resolve(pact);\n\t\t\t\t\t\t\t_this._pact = null;\n\t\t\t\t\t\t\t_this._resolve = null;\n\t\t\t\t\t\t\t_resolve(pact, 2, error);\n\t\t\t\t\t\t}\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\treturnValue(result);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// Generator is started and a yield expression is pending, settle it\n\t\t\t\t_this._pact = null;\n\t\t\t\t_this._resolve = resolve;\n\t\t\t\t_settle(_pact, 1, value);\n\t\t\t}\n\t\t});\n\t};\n\t_AsyncGenerator.prototype.return = function(value) {\n\t\t// Early return from the generator if started, otherwise abandons the generator\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tif (_this._entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the return call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Generator is not started, abandon it and return the specified value\n\t\t\t\t_this._entry = null;\n\t\t\t\treturn resolve(value && value.then ? value.then(_wrapReturnedValue) : _wrapReturnedValue(value));\n\t\t\t}\n\t\t\t// Settle the yield expression with a rejected \"early return\" value\n\t\t\t_this._return = value;\n\t\t\t_this._resolve = resolve;\n\t\t\t_this._pact = null;\n\t\t\t_settle(_pact, 2, _earlyReturn);\n\t\t});\n\t};\n\t_AsyncGenerator.prototype.throw = function(error) {\n\t\t// Inject an exception into the pending yield expression\n\t\tconst _this = this;\n\t\treturn _this._promise = new Promise(function (resolve, reject) {\n\t\t\tconst _pact = _this._pact;\n\t\t\tif (_pact === null) {\n\t\t\t\tif (_this._entry === null) {\n\t\t\t\t\t// Generator is started, but not awaiting a yield expression\n\t\t\t\t\t// Abandon the throw call!\n\t\t\t\t\treturn resolve(_this._promise);\n\t\t\t\t}\n\t\t\t\t// Generator is not started, abandon it and return a rejected Promise containing the error\n\t\t\t\t_this._entry = null;\n\t\t\t\treturn reject(error);\n\t\t\t}\n\t\t\t// Settle the yield expression with the value as a rejection\n\t\t\t_this._resolve = resolve;\n\t\t\t_this._pact = null;\n\t\t\t_settle(_pact, 2, error);\n\t\t});\n\t};\n\n\t_AsyncGenerator.prototype[_asyncIteratorSymbol] = function() {\n\t\treturn this;\n\t};\n\t\n\treturn _AsyncGenerator;\n})();\n","import React from 'react';\nimport cn from 'classnames';\nimport * as RadioGroup from '@radix-ui/react-radio-group';\nimport { Button } from '../../Button/Button';\nimport { Input } from '../../Input/Input';\nimport { Popover, PopoverProps } from '../../Popover/Popover';\nimport { Icon } from '../../Icon/Icon';\nimport { Select2OptionValue } from '../types';\nimport { useSelect2Context } from './Context';\nimport { Field } from '../../Field/Field';\nimport { Group } from '../../Group/Group';\nimport { useLocalization } from '../../Provider/Localization';\nimport { TagColor, TAG_COLORS } from '../../Tag/Tag';\n\nconst AVAILABLE_COLORS = Object.keys(TAG_COLORS);\n\nexport type EditPopoverProps = PopoverProps & {\n color?: TagColor;\n text: string;\n value: Select2OptionValue;\n};\n\nexport const EditPopover = (props: EditPopoverProps) => {\n const { color: initialColor, text: initialName, value, ...popoverProps } = props;\n const ref = React.useRef<HTMLInputElement>(null);\n const { onDelete, onEdit, searchRef, ref: selectRef } = useSelect2Context();\n const { texts } = useLocalization();\n const [name, setName] = React.useState(initialName);\n const [color, setColor] = React.useState(initialColor);\n const [validationError, setValidationError] = React.useState<Error | undefined>();\n\n const handleInputChange = event => {\n setName(event.target.value);\n setValidationError(undefined);\n };\n\n const handleInputKeyDown = close => async event => {\n event.stopPropagation();\n\n if (event.key === 'Escape') {\n close();\n } else if (event.key === 'Enter') {\n handleSave(close)(event);\n }\n };\n\n const handleDelete = close => async event => {\n event.stopPropagation();\n close();\n\n if (onDelete) {\n await onDelete(value);\n }\n };\n\n const handleSave = close => async event => {\n if (onEdit && (name !== initialName || color !== initialColor)) {\n try {\n await onEdit(value, name, color);\n close();\n } catch (error) {\n event.preventDefault();\n event.stopPropagation();\n setValidationError(error as Error);\n ref.current?.focus();\n }\n } else {\n close();\n }\n };\n\n const handleCloseAutoFocus = event => {\n event.preventDefault();\n setName(initialName);\n setColor(initialColor);\n setValidationError(undefined);\n\n if (searchRef?.current) {\n searchRef.current?.focus();\n } else {\n selectRef.current?.focus();\n }\n };\n\n const handleInteractOutside = () => {\n setName(initialName);\n setColor(initialColor);\n };\n\n const preventKeyDownPropagation = event => {\n if (event.key !== 'Escape') {\n event.stopPropagation();\n }\n };\n\n return (\n <Popover {...popoverProps} modal>\n <Popover.Content\n onCloseAutoFocus={handleCloseAutoFocus}\n onInteractOutside={handleInteractOutside}\n onClick={event => event.stopPropagation()}\n placement=\"right\"\n tabIndex={-1}\n className=\"focus:!shadow-none\">\n {({ close }) => (\n <>\n <div className=\"flex w-32 flex-col space-y-2\">\n {onEdit ? (\n <>\n <Field\n className={cn('!min-h-fit', { '!pb-0': !validationError })}\n invalid={!!validationError}\n message={validationError?.message}>\n <Input\n invalid={!!validationError}\n onChange={handleInputChange}\n onKeyDown={handleInputKeyDown(close)}\n ref={ref}\n value={name}\n />\n </Field>\n {initialColor ? (\n <>\n <h5>Colours</h5>\n <Colours\n color={color}\n onChangeColor={setColor}\n onKeyDown={preventKeyDownPropagation}\n />\n </>\n ) : null}\n <Group>\n <Button onClick={close}>{texts.select2.cancel}</Button>\n <Button appearance=\"primary\" onClick={handleSave(close)}>\n {texts.select2.save}\n </Button>\n </Group>\n </>\n ) : null}\n {onEdit && onDelete ? <hr /> : null}\n {onDelete ? (\n <button\n className=\"hover:text-grey-700 flex items-center justify-start gap-1\"\n onClick={handleDelete(close)}\n onKeyDown={preventKeyDownPropagation}>\n <Icon className=\"!h-5 !w-5\" name=\"delete-permanently\" /> {texts.select2.delete}\n </button>\n ) : null}\n </div>\n </>\n )}\n </Popover.Content>\n </Popover>\n );\n};\n\nconst Colours = props => {\n const { color, onChangeColor, onClick, onKeyDown } = props;\n const { texts } = useLocalization();\n\n return (\n <RadioGroup.Root\n aria-label={texts.select2.chooseColor}\n className=\"grid grid-cols-4 gap-2 focus:outline-none\"\n onClick={onClick}\n onKeyDown={onKeyDown}\n onValueChange={color => onChangeColor(color)}\n value={color}>\n {AVAILABLE_COLORS.map((availableColor: string) => (\n <RadioGroup.Item\n aria-label={color}\n className={cn('flex h-6 w-6 cursor-pointer items-center justify-center rounded', TAG_COLORS[availableColor])}\n key={availableColor}\n onFocus={() => onChangeColor(availableColor)}\n value={availableColor}>\n <RadioGroup.Indicator asChild>\n <Icon name=\"tick\" className=\"!h-5 !w-5\" />\n </RadioGroup.Indicator>\n </RadioGroup.Item>\n ))}\n </RadioGroup.Root>\n );\n};\n","const mobiles = /iPhone|iPad|iPod|Android/i;\n\nexport const isMobileDevice = (navigator: Navigator | undefined) => !!navigator?.userAgent && mobiles.test(navigator.userAgent);\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon, IconName, IconProps } from '../../Icon/Icon';\nimport { Tag } from '../../Tag/Tag';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Color } from '../../../utils/colors';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\nimport { createOptionClassName } from '../utilities';\nimport { useSelect2Context } from './Context';\nimport { IconButton } from '../../IconButton/IconButton';\nimport { EditPopover } from './Edit';\nimport { isMobileDevice } from '../../../utils/device';\n\nexport type Select2OptionProps = Omit<ListboxPrimitive.Listbox2OptionProps, 'children'> & {\n children: string;\n color?: Color;\n icon?: React.ReactElement<IconProps> | IconName;\n textValue?: string;\n};\n\nexport const Option = React.forwardRef<HTMLDivElement, Select2OptionProps>(function Select2Option(props, ref) {\n const { children, color, icon, ...otherProps } = props;\n const className = createOptionClassName();\n const { onDelete, onEdit, listboxRef, multiple, ref: selectRef, setOpen, tags, value } = useSelect2Context();\n\n const hasValue = Array.isArray(value) ? !!value.length : value !== undefined;\n const isTag = tags && !!color;\n\n const handleClick = () => {\n if (!multiple) {\n setOpen(false);\n } else {\n selectRef.current?.focus();\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent) => {\n if (isAriaSelectionKey(event)) {\n if (!multiple || event.key === 'Tab') {\n setOpen(false);\n }\n }\n };\n\n const popover =\n onEdit || onDelete\n ? popoverProps => (\n <EditPopover\n {...popoverProps}\n color={props.color}\n key={props.textValue ?? String(props.children)}\n text={props.textValue ?? String(props.children)}\n value={props.value}\n />\n )\n : undefined;\n\n return (\n <ListboxPrimitive.Option {...otherProps} className={className} onClick={handleClick} onKeyDown={handleKeyDown} ref={ref}>\n {hasValue ? (\n <Icon name=\"tick\" className=\"group-aria-selected:visible pointer-events-none invisible -mx-1 !h-4 !w-4\" />\n ) : null}\n {isTag ? (\n <Tag className=\"pointer-events-none\" color={color} icon={icon}>\n {children}\n </Tag>\n ) : (\n <>\n {icon ? typeof icon === 'string' ? <Icon name={icon} /> : icon : null}\n {children}\n </>\n )}\n {popover ? (\n <IconButton\n rounded\n icon=\"ellipsis-vertical\"\n appearance=\"discrete\"\n className={cn('group-aria-current:visible invisible ml-auto -mr-2 focus:!shadow-none group-hover:visible', {\n '!visible': isMobileDevice(window?.navigator),\n })}\n onClick={event => {\n event.stopPropagation();\n listboxRef?.current?.setActiveIndex(event.currentTarget.parentElement as HTMLDivElement);\n }}\n popover={popover}\n tabIndex={-1}\n />\n ) : null}\n </ListboxPrimitive.Option>\n );\n});\n","export const createOptionClassName = () =>\n 'group mb-px flex h-8 w-full text-sm flex-shrink-0 font-normal cursor-pointer items-center rounded bg-white px-2 leading-8 text-black aria-hidden:hidden gap-1.5 bg-white hover:wcag-grey-200 aria-current:wcag-grey-200 aria-disabled:text-black/25 aria-disabled:pointer-events-none';\n\nexport const createCollectionClassName = () => 'flex flex-col gap-px';\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\nimport { createCollectionClassName } from '../utilities';\n\nexport type Select2GroupProps = ListboxPrimitive.Listbox2GroupProps;\n\nexport const Group = React.forwardRef<HTMLDivElement, Select2GroupProps>(function Select2Group(props, ref) {\n const className = cn(createCollectionClassName(), props.className);\n return <ListboxPrimitive.Group {...props} className={className} ref={ref} />;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ListboxPrimitive from '../../../primitives/Listbox2/Listbox2';\n\nexport type Select2TitleProps = ListboxPrimitive.Listbox2TitleProps;\n\nexport const Title = React.forwardRef<HTMLDivElement, Select2TitleProps>(function Select2Title(props, ref) {\n const className = cn('flex items-center text-xs pl-2 h-8', props.className);\n return <ListboxPrimitive.Title {...props} className={className} ref={ref} />;\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport * as ScrollAreaPrimitive from '@radix-ui/react-scroll-area';\n\nconst Bar = props => {\n const className = cn(`flex select-none touch-none transition-colors hover:bg-grey`, {\n 'w-[7px] hover:w-[14px] mr-[2px] hover:px-[2px] hover:mr-0': props.orientation === 'vertical',\n 'flex-col h-[7px] hover:h-[14px] mb-[2px] hover:py-[2px] hover:mb-0': props.orientation === 'horizontal',\n });\n return <ScrollAreaPrimitive.Scrollbar {...props} className={className} />;\n};\n\nconst Thumb = props => <ScrollAreaPrimitive.Thumb {...props} className=\"flex-[1] rounded bg-black opacity-50\" />;\n\nconst Corner = props => <ScrollAreaPrimitive.Corner {...props} classname=\"bg-grey-500\" />;\n\nexport type ScrollbarProps = Omit<ScrollAreaPrimitive.ScrollAreaProps, 'scrollHideDelay'>;\n\nexport const ScrollArea = (props: ScrollbarProps) => {\n const { children, ...otherProps } = props;\n\n return (\n <ScrollAreaPrimitive.Root {...otherProps} className={cn('overflow-hidden', props.className)}>\n <ScrollAreaPrimitive.Viewport className=\"h-full w-full\">{children}</ScrollAreaPrimitive.Viewport>\n <Bar orientation=\"vertical\">\n <Thumb />\n </Bar>\n <Bar orientation=\"horizontal\">\n <Thumb />\n </Bar>\n <Corner />\n </ScrollAreaPrimitive.Root>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { Tag } from '../../Tag/Tag';\nimport { Tooltip } from '../../Tooltip/Tooltip';\nimport { Icon } from '../../Icon/Icon';\nimport { Badge } from '../../Badge/Badge';\nimport { getInputClasses } from '../../Input/util';\nimport { Select2OptionValue } from '../types';\nimport { useSelect2Context } from './Context';\nimport { Select2OptionProps } from './Option';\nimport { getIndexOfFirstChildOverflowingParent } from '../../../utils/dom';\nimport { ScrollArea } from '../../ScrollArea/ScrollArea';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\n\ntype Select2TriggerProps = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n children: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const Trigger = React.forwardRef<HTMLButtonElement, Select2TriggerProps>(function Select2Trigger(props, ref) {\n const { multiple, value } = useSelect2Context();\n\n if (Array.isArray(value) || multiple) {\n const values = Array.isArray(value) ? value : value !== undefined ? [value] : undefined;\n return <Multiple {...props} ref={ref} values={values} />;\n }\n\n return <Single {...props} ref={ref} value={value} />;\n});\n\ntype ButtonProps = React.HTMLAttributes<HTMLButtonElement> &\n Omit<Select2TriggerProps, 'children' | 'open' | 'setValue' | 'value'>;\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(function Select2TriggerButton(props, ref) {\n const { children, onClick, tabIndex = 0, ...otherProps } = props;\n const { disabled, highlighted, invalid, open, readOnly } = useSelect2Context();\n\n const className = cn(\n 'cursor-pointer !px-1.5',\n getInputClasses({ ...props, disabled, highlighted, invalid, readOnly }).replace('w-full', ''),\n { 'w-full': !props.className?.includes('w-') },\n props.className\n );\n\n const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n if (disabled || readOnly) {\n event.preventDefault();\n return;\n }\n\n if (typeof onClick === 'function') {\n onClick(event);\n }\n };\n\n return (\n <button\n {...otherProps}\n aria-invalid={invalid ? true : undefined}\n aria-readonly={readOnly ? true : undefined}\n className={className}\n disabled={disabled}\n onClick={handleClick}\n ref={ref}\n role=\"combobox\"\n tabIndex={disabled || readOnly ? -1 : tabIndex}\n type=\"button\">\n {children}\n <Icon name={open ? 'chevron-up' : 'chevron-down'} className=\"pointer-events-none -mr-1 ml-auto\" />\n </button>\n );\n});\n\ntype SingleProps = Omit<Select2TriggerProps, 'value'> & { value?: Select2OptionValue };\n\nconst Single = React.forwardRef<HTMLButtonElement, SingleProps>(function Select2TriggerSingle(props, ref) {\n const { children, value, ...buttonProps } = props;\n const { disabled, readOnly, tags } = useSelect2Context();\n const contentClassName = cn('truncate items-center gap-1');\n\n const currentValue = children.find(matchesValue(value));\n\n let output;\n\n if (currentValue) {\n if (tags) {\n output = (\n <Tag\n className=\"truncate\"\n color={currentValue.props.color}\n disabled={disabled}\n icon={currentValue.props.icon}\n readOnly={readOnly}>\n {currentValue.props.children}\n </Tag>\n );\n } else {\n output = (\n <>\n {currentValue.props.icon ? (\n typeof currentValue.props.icon === 'string' ? (\n <Icon name={currentValue.props.icon} />\n ) : (\n currentValue.props.icon\n )\n ) : null}\n {currentValue.props.children}\n </>\n );\n }\n }\n\n return (\n <Button {...buttonProps} ref={ref}>\n <div className={contentClassName}>{output}</div>\n </Button>\n );\n});\n\ntype MultipleProps = Omit<Select2TriggerProps, 'value'> & {\n values?: Select2OptionValue[];\n};\n\nconst Multiple = React.forwardRef<HTMLButtonElement, MultipleProps>(function Select2TriggerMultiple(props, ref) {\n const { children, values = [], ...buttonProps } = props;\n const { disabled, open, readOnly, setValue, tags } = useSelect2Context();\n const buttonRef = useMergedRef<HTMLButtonElement>(ref);\n\n const valuesAsChildren = values.map(value =>\n children.find(c => c.props.value === value)\n ) as React.ReactElement<Select2OptionProps>[];\n\n let content;\n let { className } = buttonProps;\n\n if (open) {\n className = cn('!absolute z-20', buttonProps.className);\n content = (\n <ScrollArea className=\"my-1 flex max-h-[5.5rem] flex-col\">\n <div className=\"flex flex-wrap gap-1\">\n {valuesAsChildren.map(child => (\n <Tag\n key={child.props.value}\n className=\"truncate\"\n color={tags ? child.props.color : undefined}\n disabled={disabled}\n icon={child.props.icon}\n onDelete={event => {\n event?.stopPropagation();\n event?.preventDefault();\n\n if (!disabled && !readOnly) {\n setValue(child.props.value);\n }\n }}\n readOnly={readOnly}>\n {child.props.children}\n </Tag>\n ))}\n </div>\n </ScrollArea>\n );\n } else {\n content = <MultipleValue key={String(open)} valuesAsChildren={valuesAsChildren} />;\n }\n\n return (\n <div\n className={cn('relative inline-flex flex-grow', { 'h-8': open })}\n style={{ width: open ? buttonRef.current?.offsetWidth : undefined }}>\n <Button {...buttonProps} className={className} ref={buttonRef}>\n {content}\n </Button>\n </div>\n );\n});\n\nconst MultipleValue = ({ valuesAsChildren }) => {\n const { disabled, open, readOnly, setValue, tags } = useSelect2Context();\n const [contentRef, setContentRef] = React.useState<HTMLDivElement | null>(null);\n const boundaryIndex = contentRef ? getIndexOfFirstChildOverflowingParent(contentRef, 30) : undefined;\n\n const createClickHandler = tagValue => event => {\n event?.stopPropagation();\n event?.preventDefault();\n\n if (!disabled && !readOnly) {\n setValue(tagValue);\n }\n };\n\n return (\n <div className=\"relative flex items-center gap-1 overflow-hidden\">\n <div className=\"flex gap-1 truncate\" ref={el => setContentRef(el)}>\n {valuesAsChildren.map((child, index) => {\n const tag = (\n <Tag\n key={child.props.value}\n className={cn('cursor-pointer', {\n truncate: index === boundaryIndex,\n hidden: boundaryIndex !== undefined && boundaryIndex !== null ? index > boundaryIndex : false,\n })}\n color={tags ? child.props.color : undefined}\n disabled={disabled}\n icon={child.props.icon}\n onDelete={open ? createClickHandler(child.props.value) : undefined}\n readOnly={readOnly}>\n {child.props.children}\n </Tag>\n );\n\n if (index === boundaryIndex) {\n return (\n <Tooltip key={child.props.value} title={String(child.props.children)}>\n {tag}\n </Tooltip>\n );\n }\n\n return tag;\n })}\n </div>\n {boundaryIndex !== undefined && boundaryIndex !== null && boundaryIndex < valuesAsChildren.length - 1 ? (\n <Tooltip\n title={valuesAsChildren\n .slice(boundaryIndex + 1)\n .map(child => (child ? String(child.props.children) : ''))\n .join(', ')}>\n <Badge className=\"flex-shrink-0\">+{valuesAsChildren.length - (boundaryIndex + 1)}</Badge>\n </Tooltip>\n ) : null}\n </div>\n );\n};\n\nconst matchesValue = (value: undefined | any | any[]) => (child: React.ReactElement<any>) => {\n if (Array.isArray(value)) {\n return value.includes(child.props.value);\n }\n\n return child.props.value === value;\n};\n","export const isOverflowing = (element: HTMLElement | null) =>\n element !== null ? element.scrollWidth > element.offsetWidth : false;\n\nexport const getIndexOfFirstChildOverflowingParent = (element: HTMLElement, overscan = 0) => {\n let index = 0;\n let boundaryChildIndex: number | null = null;\n const clientRect = element.getBoundingClientRect();\n\n for (const child of Array.from(element.children)) {\n const right = child.getBoundingClientRect().right - clientRect.left;\n const width = clientRect.width - overscan;\n\n if (right > width) {\n boundaryChildIndex = index;\n break;\n }\n index++;\n }\n\n return boundaryChildIndex;\n};\n","import React from 'react';\nimport { usePreviousValue } from '../hooks/usePrevious';\n\n// taken from radix - https://github.com/radix-ui/primitives/blob/main/packages/react/select/src/Select.tsx#L1183-L1224\nexport const BubbleSelect = (props: React.SelectHTMLAttributes<HTMLSelectElement>) => {\n const { value, ...selectProps } = props;\n const ref = React.useRef<HTMLSelectElement>(null);\n const prevValue = usePreviousValue(value);\n\n // Bubble value change to parents (e.g form change event)\n React.useEffect(() => {\n const select = ref.current!;\n const descriptor = Object.getOwnPropertyDescriptor(window.HTMLSelectElement.prototype, 'value') as PropertyDescriptor;\n const setValue = descriptor.set;\n\n if (prevValue !== value && setValue) {\n if (Array.isArray(value)) {\n value.forEach(v => {\n const option: HTMLOptionElement | null = select.querySelector(`option[value='${v}']`);\n\n if (option) {\n option.selected = true;\n }\n });\n } else {\n setValue.call(select, value);\n }\n\n const event = new Event('change', { bubbles: true });\n select.dispatchEvent(event);\n }\n }, [prevValue, value]);\n\n /**\n * We purposefully do not use `type=\"hidden\"` here otherwise forms that\n * wrap it will not be able to access its value via the FormData API.\n *\n * We purposefully do not add the `value` attribute here to allow the value\n * to be set programatically and bubble to any parent form `onChange` event.\n * Adding the `value` will cause React to consider the programatic\n * dispatch a duplicate and it will get swallowed.\n */\n return <select {...selectProps} defaultValue={value} ref={ref} style={{ display: 'none' }} />;\n};\n","import React from 'react';\n\n// taken from radix\nfunction usePreviousValue<T>(value: T) {\n // The ref object is a generic container whose current property is mutable ...\n // ... and can hold any value, similar to an instance property on a class\n const ref = React.useRef<T>(value);\n\n // Store current value in ref\n React.useEffect(() => {\n ref.current = value;\n }, [value]); // Only re-run if value changes\n\n // Return previous value (happens before update in useEffect above)\n return ref.current;\n}\n\nexport { usePreviousValue };\n","import React from 'react';\nimport cn from 'classnames';\nimport { createCustomKeyboardEvent } from '../../../utils/input';\nimport { Input, InputProps } from '../../Input/Input';\nimport { useSelect2Context } from './Context';\nimport { Field } from '../../Field/Field';\nimport { isAriaSelectionKey } from '../../../utils/aria';\n\nexport type Select2SearchProps = InputProps & {};\n\nexport const Search = React.forwardRef<HTMLInputElement, Select2SearchProps>(function ListboxSearch(props, ref) {\n const { ...otherProps } = props;\n const { listboxRef, searchQuery, setSearchQuery, setValidationError, validationError } = useSelect2Context();\n\n const handleChange = event => {\n if (validationError) {\n setValidationError(undefined);\n }\n\n setSearchQuery(event.target.value);\n };\n\n const handleKeyDown = event => {\n // space is an aria selection key, so we have to remove it to allow spaces\n if (event.key === ' ') {\n return;\n }\n\n if (isAriaSelectionKey(event) || event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n event.preventDefault();\n // forward navigation events onto the underlying collection - we want arrow keys to work from inside the filter input\n listboxRef?.current?.dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n return;\n }\n };\n\n return (\n <Field\n className={cn('mx-1.5 mb-1.5 !min-h-fit ', { '!pb-0': !validationError })}\n invalid={!!validationError}\n message={validationError?.message}>\n <Input\n {...otherProps}\n aria-hidden\n autoFocus\n invalid={!!validationError}\n onChange={handleChange}\n onKeyDown={handleKeyDown}\n ref={ref}\n value={searchQuery}\n />\n </Field>\n );\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport { isAriaSelectionKey } from '../../../utils/aria';\nimport { Color } from '../../../utils/colors';\nimport { Tag } from '../../Tag/Tag';\nimport { createOptionClassName } from '../utilities';\nimport { useSelect2Context } from './Context';\nimport { Select2OptionProps } from './Option';\nimport { useLocalization } from '../../Provider/Localization';\n\nexport type CreateProps = {\n onCreate: (name: string, color: Color | undefined) => Promise<Select2OptionProps>;\n options: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const getNextColor = (options: React.ReactElement<Select2OptionProps>[]): Color | undefined => {\n const occurences = options.reduce((occurences, option) => {\n if (option.props.color) {\n occurences[option.props.color] = occurences[option.props.color] ? occurences[option.props.color] + 1 : 1;\n }\n return occurences;\n }, {});\n\n const colors = Object.keys(occurences);\n\n if (colors.length) {\n return colors.sort((a, b) => occurences[b] - occurences[a])[0] as Color;\n }\n\n return undefined;\n};\n\nexport const Create = (props: CreateProps) => {\n const { onCreate: handleCreate, options } = props;\n const { multiple, searchQuery, setOpen, setSearchQuery, setValidationError, setValue } = useSelect2Context();\n const { texts } = useLocalization();\n\n // determine what the next color tag should be based on color occurences\n const nextColor = React.useMemo(() => getNextColor(options), [options]);\n\n if (!searchQuery) {\n return null;\n }\n\n const handleClick = async () => {\n try {\n const item = await handleCreate(searchQuery, nextColor);\n setValue(item.value);\n\n if (multiple) {\n setSearchQuery('');\n } else {\n setOpen(false);\n }\n } catch (error) {\n setValidationError(error as Error);\n }\n };\n\n const handleKeyDown = event => {\n if (isAriaSelectionKey(event)) {\n event.currentTarget.click();\n }\n };\n\n const className = cn('!w-[calc(100%_-_theme(spacing.3))] ml-1.5', createOptionClassName());\n return (\n <button className={className} onClick={handleClick} onKeyDown={handleKeyDown}>\n <span className=\"flex items-center gap-1.5\">\n {texts.select2.create}\n <Tag color={nextColor} className=\"cursor-pointer\">\n {searchQuery}\n </Tag>\n </span>\n </button>\n );\n};\n","import React from 'react';\nimport { ScrollArea } from '../../ScrollArea/ScrollArea';\nimport { Select2OptionProps } from './Option';\n\nexport type Select2CollectionProps = {\n children: React.ReactElement<Select2OptionProps>[];\n};\n\nexport const Collection = (props: Select2CollectionProps) => {\n const { children } = props;\n\n return <ScrollArea className=\"flex max-h-[10.3rem] w-full flex-col gap-y-0.5 px-1.5\">{children}</ScrollArea>;\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport * as PopoverPrimitive from '@radix-ui/react-popover';\nimport * as ListboxPrimitive from '../../primitives/Listbox2/Listbox2';\nimport { Select2OptionValue, Select2Value } from './types';\nimport { Option, Select2OptionProps } from './components/Option';\nimport { Group, Select2GroupProps } from './components/Group';\nimport { Select2TitleProps, Title } from './components/Title';\nimport { Select2Context } from './components/Context';\nimport { createCollectionClassName } from './utilities';\nimport { useMergedRef } from '../../hooks/useMergedRef';\nimport { useBoundingClientRectListener } from '../../hooks/useBoundingClientRectListener';\nimport { createCustomKeyboardEvent } from '../../utils/input';\nimport { Trigger } from './components/Trigger';\nimport { useIsFormControl } from '../../hooks/useIsFormControl';\nimport { BubbleSelect } from '../../primitives/BubbleSelect';\nimport { Search } from './components/Search';\nimport { useChildren } from './hooks/useChildren';\nimport { Color } from '../../utils/colors';\nimport { Create } from './components/Create';\nimport { Collection } from './components/Collection';\nimport { CollectionRef } from '../../primitives/Collection/Collection';\nimport { useLocalization } from '../Provider/Localization';\n//import { All } from './components/All';\n\ntype Select2Texts = {\n allSelect: string;\n allDeselect: string;\n cancel: string;\n chooseColor: string;\n create: string;\n delete: string;\n save: string;\n search: string;\n searchOrCreate: string;\n};\n\ntype Select2Props = Omit<React.HTMLAttributes<HTMLButtonElement>, 'children' | 'defaultValue' | 'onChange' | 'value'> & {\n autoFocus?: boolean;\n children: React.ReactElement<Select2OptionProps>[];\n defaultValue?: Select2Value;\n emptyValue?: Select2OptionValue;\n disabled?: boolean;\n disableSearch?: boolean;\n highlighted?: boolean;\n invalid?: boolean;\n multiple?: boolean;\n name?: string;\n onChange?: (value: Select2Value) => void;\n onCreate?: (name: string, color: Color | undefined) => Promise<Select2OptionProps>;\n onDelete?: (value: Select2OptionValue) => Promise<void>;\n onEdit?: (value: Select2OptionValue, text: string, color: Color | undefined) => Promise<void>;\n readOnly?: boolean;\n required?: boolean;\n tags?: boolean;\n value?: Select2Value;\n};\ntype Select2PropsWithStatics = React.ForwardRefExoticComponent<Select2Props & React.RefAttributes<HTMLButtonElement>> & {\n Option: React.ForwardRefExoticComponent<Select2OptionProps>;\n Group: React.ForwardRefExoticComponent<Select2GroupProps>;\n Title: React.ForwardRefExoticComponent<Select2TitleProps>;\n};\n\nconst Select2 = React.forwardRef<HTMLButtonElement, Select2Props>(function Select2(props, ref) {\n const {\n children: initialChildren,\n defaultValue: defaultProp,\n disabled = false,\n disableSearch = false,\n emptyValue = undefined,\n highlighted = false,\n invalid = false,\n multiple = false,\n name,\n onChange,\n onCreate,\n onDelete,\n onEdit,\n readOnly = false,\n tabIndex = 0,\n tags = false,\n value: prop,\n ...otherProps\n } = props;\n\n // refs\n const internalRef = useMergedRef<HTMLButtonElement>(ref);\n const listboxRef = React.useRef<CollectionRef>(null);\n const searchRef = React.useRef<HTMLInputElement>(null);\n const { texts } = useLocalization();\n // align the listbox min width with the width of the input - it should never be smaller\n const dimensions = useBoundingClientRectListener(internalRef);\n\n // state\n const [open, setOpen] = React.useState(false);\n const [value, _setValue] = useControllableState<Select2Value>({\n // uncontrolled\n defaultProp,\n // controlled\n onChange,\n prop,\n });\n const setValue = ListboxPrimitive.createListboxValueSetter(multiple, _setValue);\n const [validationError, setValidationError] = React.useState<Error | undefined>();\n\n const { allChildren, filteredChildren, searchQuery, setSearchQuery } = useChildren({\n children: initialChildren,\n emptyValue,\n multiple,\n open,\n setValue,\n value,\n });\n\n // context\n const context = {\n disabled,\n highlighted,\n invalid,\n listboxRef,\n multiple,\n onCreate,\n onDelete,\n onEdit,\n open,\n readOnly,\n ref: internalRef,\n searchQuery,\n searchRef,\n setOpen,\n setSearchQuery,\n setValidationError,\n setValue,\n tags,\n validationError,\n value,\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLElement>) => {\n if (open) {\n event.preventDefault();\n } else if (event.key === 'ArrowDown' || event.key === 'ArrowUp') {\n setOpen(true);\n }\n\n // the focus should always remain on the input, so we forward events on to the listbox\n listboxRef.current?.dispatchEvent(createCustomKeyboardEvent(event as React.KeyboardEvent<HTMLInputElement>));\n };\n\n let handleBlur;\n\n if (otherProps.onBlur) {\n // we might be focusing on an input or something inside the dropdown that was triggered by the select\n // so see if the element gaining focus is inside a portal and look up its controller\n // if we don't do this, things like validate on blur occur while simply opening the select\n handleBlur = (event: React.FocusEvent<HTMLButtonElement>) => {\n const elementGainingFocus = event.relatedTarget;\n\n if (elementGainingFocus === undefined) {\n return;\n }\n\n const portalId = elementGainingFocus?.closest('[data-radix-popper-content-wrapper] > :first-child')?.id;\n\n if (!portalId || event.currentTarget.getAttribute(`aria-controls`) !== portalId) {\n otherProps.onBlur?.(event);\n }\n };\n }\n\n const className = cn('border-grey-300 rounded border bg-white py-1.5 shadow-md outline-none', createCollectionClassName());\n\n return (\n <Select2Context.Provider value={context}>\n <PopoverPrimitive.Root open={open} onOpenChange={setOpen}>\n <ControlledHiddenField\n emptyValue={emptyValue}\n multiple={multiple || tags}\n name={name}\n options={allChildren.map(child => child.props.value)}\n parentRef={internalRef}\n setValue={setValue}\n value={value}\n />\n <PopoverPrimitive.Trigger asChild data-taco=\"Select2\">\n <Trigger\n {...otherProps}\n aria-haspopup=\"listbox\"\n onBlur={handleBlur}\n onKeyDown={handleKeyDown}\n ref={internalRef}>\n {allChildren}\n </Trigger>\n </PopoverPrimitive.Trigger>\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n asChild\n align=\"start\"\n onOpenAutoFocus={event => {\n event.preventDefault();\n event.stopPropagation();\n internalRef.current?.focus();\n }}\n onCloseAutoFocus={event => {\n event.preventDefault();\n event.stopPropagation();\n internalRef.current?.focus();\n }}\n sideOffset={4}\n tabIndex={-1}>\n <div className={className} style={{ minWidth: dimensions?.width ? `${dimensions.width}px` : undefined }}>\n {!disableSearch && (allChildren.length > 0 || onCreate) ? (\n <Search\n placeholder={onCreate ? texts.select2.searchOrCreate : texts.select2.search}\n ref={searchRef}\n />\n ) : null}\n {allChildren.length <= 0 ? (\n <div className=\"text-grey-700 -mt-0.5 flex h-8 items-center px-2\" role=\"presentation\">\n No results found...\n </div>\n ) : (\n <ListboxPrimitive.Root\n className=\"flex flex-col gap-0.5\"\n customSelector=\":scope > button\"\n disabled={disabled}\n multiple={multiple}\n readOnly={readOnly}\n ref={listboxRef}\n setValue={setValue}\n tabIndex={-1}\n value={value}>\n {/*multiple && !searchQuery && Array.isArray(value) ? (\n <All\n children={allChildren}\n onToggle={_setValue}\n selected={value.length === allChildren.length}\n />\n ) : null*/}\n <Collection>{filteredChildren}</Collection>\n {onCreate ? <Create onCreate={onCreate} options={allChildren} /> : null}\n </ListboxPrimitive.Root>\n )}\n </div>\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n </Select2Context.Provider>\n );\n}) as Select2PropsWithStatics;\nSelect2.Option = Option;\nSelect2.Group = Group;\nSelect2.Title = Title;\n\nconst ControlledHiddenField = props => {\n const { emptyValue, multiple, name, options, parentRef, value, setValue } = props;\n const isFormControl = useIsFormControl(parentRef, () => setValue(multiple ? [] : undefined));\n\n let bubbleValue;\n\n if (isFormControl) {\n if (value !== undefined) {\n if (multiple) {\n bubbleValue = Array.isArray(value) ? value.map(String) : [value === null ? '' : String(value)];\n } else {\n bubbleValue = value === null ? '' : String(value);\n }\n }\n\n return (\n <BubbleSelect aria-hidden key={String(bubbleValue)} multiple={multiple} name={name} value={bubbleValue}>\n {emptyValue !== undefined ? <option value={emptyValue} /> : null}\n {options.map(option => (\n <option key={String(option)} value={String(option)} />\n ))}\n </BubbleSelect>\n );\n }\n\n return null;\n};\nSelect2.displayName = 'Select2';\n\nexport { Select2 };\n\nexport type {\n Select2Texts,\n Select2GroupProps,\n Select2OptionProps,\n Select2OptionValue,\n Select2Value,\n Select2Props,\n Select2TitleProps,\n};\n","import React from 'react';\nimport { Option, Select2OptionProps } from '../components/Option';\nimport { Select2OptionValue, Select2Value } from '../types';\n\nexport type useChildrenArgs = {\n children: React.ReactElement<Select2OptionProps>[];\n emptyValue?: Select2OptionValue;\n multiple?: boolean;\n open?: boolean;\n setValue: (nextValue: Select2OptionValue) => void;\n value?: Select2Value;\n};\nexport const useChildren = ({ children: initialChildren, emptyValue, multiple, open, setValue, value }: useChildrenArgs) => {\n const [searchQuery, setSearchQuery] = React.useState<string>('');\n\n // support empty value - probably a more elegant way to achieve this\n const allChildren: React.ReactElement<Select2OptionProps>[] = React.useMemo(() => {\n const initial = initialChildren || [];\n if (emptyValue !== undefined && !multiple) {\n return [<Option key=\"__empty\" children=\"\" value={emptyValue} />, ...initial];\n }\n\n return initial;\n }, [initialChildren, emptyValue]);\n\n // set an initial value if none is set, we have to trigger state updates for controlled components\n React.useEffect(() => {\n if (!multiple && emptyValue === undefined && value === undefined) {\n setValue(allChildren?.[0]?.props.value);\n }\n }, []);\n\n React.useEffect(() => {\n if (!open) {\n setSearchQuery('');\n }\n }, [open]);\n\n // apply filtering\n const filteredChildren: React.ReactElement<Select2OptionProps>[] = React.useMemo(() => {\n return allChildren.filter(child => {\n if (child.props.textValue) {\n return child.props.textValue.toLowerCase().includes(searchQuery.toLowerCase());\n }\n\n return String(child.props.children).toLowerCase().includes(searchQuery.toLowerCase());\n });\n }, [allChildren, searchQuery]);\n\n return {\n allChildren,\n filteredChildren,\n searchQuery,\n setSearchQuery,\n };\n};\n","import * as React from 'react';\n\n// taken from radix\n// determines whether a given ref is a descendant of a form element\nexport const useIsFormControl = (ref: React.RefObject<HTMLElement>, reset: () => void) => {\n const [isFormControl, setIsFormControl] = React.useState(false);\n\n React.useEffect(() => {\n let formElement: HTMLFormElement | null;\n\n if (ref.current) {\n formElement = ref.current.closest('form');\n setIsFormControl(!!formElement);\n\n if (reset && formElement) {\n formElement.addEventListener('reset', reset);\n }\n\n ref.current.closest('form')?.addEventListener('reset', reset);\n }\n\n return () => {\n if (formElement) {\n formElement.removeEventListener('reset', reset);\n }\n };\n }, [ref]);\n\n return isFormControl;\n};\n","import React from 'react';\nimport { TableRow, TableCell, TableChildren, InternalTableRow, InternalTableColumn, SortRule } from './types';\nimport { SortingRule } from 'react-table';\n\nexport const sanitizeRowProps = (row: InternalTableRow, rowExpansionRenderer: any): TableRow<any> => {\n const props: TableRow<any> = {\n index: row.index,\n indexPath: row.id,\n values: row.original,\n };\n\n if (row.subRows?.length > 0) {\n props.isExpanded = !!row.isExpanded;\n props.depth = row.depth;\n props.toggleRowExpanded = () => row.toggleRowExpanded(!props.isExpanded);\n } else if (rowExpansionRenderer) {\n props.isExpanded = !!row.isExpanded;\n props.toggleRowExpanded = () => row.toggleRowExpanded(!props.isExpanded);\n }\n\n if (row.toggleRowEditing) {\n props.isEditing = !!row.isEditing;\n props.toggleRowEditing = row.toggleRowEditing;\n }\n\n return props;\n};\n\nexport const getColumnsFromChildren = (children: TableChildren<any>, rowExpansionRenderer: any) => {\n const sortRules: SortingRule<any>[] = [];\n\n const columns = React.Children.toArray(children)\n .filter((child: any) => !!child && !child.props.hidden) // skip falsey or hidden columns\n .map(({ props: { children: groupChildren, ...props } }: any) => {\n const column: InternalTableColumn & { disableSortBy: boolean | undefined } = { ...props };\n\n column.sortType = column.sortType || 'auto';\n column.disableSortBy = column.disableSorting;\n\n // this is a Table.Group - TODO: Find a better way to determine the child type\n if (props.title && groupChildren) {\n column.Header = props.title;\n\n const { columns: groupColumns, sortRules: groupSortRules } = getColumnsFromChildren(\n groupChildren,\n rowExpansionRenderer\n );\n column.columns = groupColumns;\n groupSortRules.forEach(sort => sortRules.push(sort));\n } else {\n column.accessor = props.accessor;\n column.Header = props.headRenderer || '';\n column.Cell = (columnProps: any) => {\n const cell: TableCell<any> = {\n accessor: columnProps.cell.column.id,\n row: sanitizeRowProps(columnProps.cell.row, rowExpansionRenderer),\n value: columnProps.cell.value,\n };\n\n if (cell.row.isEditing && typeof props.editRenderer === 'function') {\n return props.editRenderer(cell);\n }\n\n return typeof props.cellRenderer === 'function' ? props.cellRenderer(cell) ?? null : cell.value ?? null;\n };\n\n // custom props\n column.align = props.align;\n column.flex = props.flex;\n\n if (props.sort && !props.disableSorting) {\n sortRules.push({\n id: props.accessor,\n desc: props.sort === 'desc',\n });\n }\n }\n\n return column;\n });\n\n return { columns, sortRules };\n};\n\nexport const getInternalSortRules = <T>(sortRules: SortRule<T>[] | undefined): SortingRule<T>[] | undefined => {\n return sortRules?.map<SortingRule<T>>(rule => ({ id: rule.accessor, desc: rule.desc }));\n};\n","import { SortTypes, TableRow } from '../types';\n\nconst getTime = (value: any): number | undefined => {\n const parsedValue: Date = typeof value === 'string' ? new Date(value) : value;\n return parsedValue?.getTime ? parsedValue.getTime() : undefined;\n};\n\nconst getNumber = (amount = '', decimalSeparator = ','): number | undefined => {\n if (typeof amount === 'number') {\n return amount;\n }\n\n if (amount === null || !amount.length) {\n return undefined;\n }\n\n let value;\n\n if (decimalSeparator === ',') {\n // replace digit seperator then replace decimal separator\n value = Number(amount.replace(/\\./g, '').replace(',', '.'));\n } else {\n // replace digit seperator\n value = Number(amount.replace(/,/g, ''));\n }\n\n return Number.isNaN(value) ? undefined : value;\n};\n\nconst getString = (value: any): string | undefined => {\n if (value) {\n return String(value).toLowerCase();\n }\n\n return undefined;\n};\n\nconst guess = (value: any): any => {\n if (typeof value === 'boolean') {\n return value;\n }\n\n return isNaN(value) ? getString(value) : Number(value);\n};\n\nconst compareBasic = (a: any, b: any) => {\n // places undefined values first in ascending order instead of descending\n if (a !== undefined && b === undefined) {\n return 1;\n }\n\n return a === b ? 0 : a > b ? 1 : -1;\n};\n\nconst stringsLocaleCompare = (a: string, b: string, locale: string): 0 | 1 | -1 => {\n // In some browsers 'localCompare' may return -2 or 2 instead of -1 or 1\n const compareResult = a.localeCompare(b, locale);\n return compareResult === 0 ? 0 : compareResult > 0 ? 1 : -1;\n};\n\nconst compareBasicStrings = (a: string | undefined, b: string | undefined, locale: string): 0 | 1 | -1 => {\n if (a && b) {\n return stringsLocaleCompare(a, b, locale);\n }\n\n return compareBasic(a, b);\n};\n\ntype SortHandler<T> = (rowA: TableRow<T>, rowB: TableRow<T>, columnId: string) => 0 | 1 | -1;\n\nexport const sortTypes = (locale: string): Record<SortTypes, SortHandler<any>> => {\n return {\n datetime: (rowA, rowB, columnId) => {\n const a = getTime(rowA.values[columnId]);\n const b = getTime(rowB.values[columnId]);\n return compareBasic(a, b);\n },\n string: (rowA, rowB, columnId) => {\n const a = getString(rowA.values[columnId]);\n const b = getString(rowB.values[columnId]);\n return compareBasicStrings(a, b, locale);\n },\n number: (rowA, rowB, columnId) => {\n const a = getNumber(rowA.values[columnId]);\n const b = getNumber(rowB.values[columnId]);\n return compareBasic(a, b);\n },\n boolean: (rowA, rowB, columnId) => {\n const a = !!rowA.values[columnId];\n const b = !!rowB.values[columnId];\n return compareBasic(a, b);\n },\n auto: (rowA, rowB, columnId) => {\n const a = guess(rowA.values[columnId]);\n const b = guess(rowB.values[columnId]);\n if (typeof a === 'string' && typeof b === 'string') {\n return compareBasicStrings(a, b, locale);\n } else {\n return compareBasic(a, b);\n }\n },\n };\n};\n","import React from 'react';\nimport { actions, PluginHook } from 'react-table';\n\nconst pluginName = 'useRowEditing';\n\nactions.resetRowEditing = 'resetRowEditing';\nactions.toggleRowEditing = 'toggleRowEditing';\nactions.toggleEditing = 'toggleEditing';\n\nfunction reducer(state: any, action: any): object {\n if (action.type === actions.init) {\n return {\n allowEditing: true,\n editingRowUniqueId: null,\n ...state,\n };\n }\n\n if (action.type === actions.resetRowEditing || action.type === actions.resetPage || action.type === actions.gotoPage) {\n return {\n ...state,\n editingRowUniqueId: null,\n };\n }\n\n if (action.type === actions.toggleRowEditing) {\n const { id } = action;\n return {\n ...state,\n editingRowUniqueId: id,\n };\n }\n\n if (action.type === actions.toggleEditing) {\n return {\n ...state,\n allowEditing: !state.allowEditing,\n };\n }\n\n return state;\n}\n\nfunction useInstance(instance: any): void {\n const { dispatch } = instance;\n\n const resetRowEditing = React.useCallback(() => {\n dispatch({ type: actions.resetRowEditing });\n }, [dispatch]);\n\n const toggleRowEditing = React.useCallback(\n id => {\n dispatch({ type: actions.toggleRowEditing, id });\n },\n [dispatch]\n );\n\n const toggleEditing = React.useCallback(() => {\n dispatch({ type: actions.toggleEditing });\n }, [dispatch]);\n\n Object.assign(instance, {\n resetRowEditing,\n toggleRowEditing,\n toggleEditing,\n });\n}\n\nconst prepareRow =\n <T extends {}>(uniqueId: keyof T) =>\n (row: any, { instance }: any): void => {\n const id = row.original[uniqueId];\n\n row.toggleRowEditing = () => {\n if (instance.state.editingRowUniqueId === id) {\n instance.resetRowEditing();\n } else {\n instance.toggleRowEditing(id);\n }\n };\n\n row.isEditing = row.original._createKey\n ? instance.state.editingRowUniqueId === row.original._createKey\n : instance.state.editingRowUniqueId === id;\n row.canEdit = instance.state.allowEditing && (row.isEditing || !instance.state.editingRowUniqueId);\n };\n\nexport const useRowEditing = <T extends {}>(uniqueId: keyof T | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n if (uniqueId) {\n hooks.stateReducers.push(reducer);\n hooks.useInstance.push(useInstance);\n hooks.prepareRow.push(prepareRow<T>(uniqueId));\n }\n };\n plugin.pluginName = pluginName;\n\n return plugin;\n};\n","import React from 'react';\nimport { PluginHook } from 'react-table';\nimport { InView } from 'react-intersection-observer';\nimport { sanitizeRowProps } from '../../util';\nimport { IconButton } from '../../../IconButton/IconButton';\nimport { LocalizationTexts } from '../../../Provider/Localization';\nimport { Menu } from '../../../Menu/Menu';\nimport { RowAction, RowActionHandler, TableRow } from '../../types';\n\nconst actionGroupClassName = '-mt-1 -mb-1 h-8 flex';\n\nconst hasActions = (inlineEditingUniqueId: any, handlers: any, actions: RowActionHandler<any>[] | undefined): number => {\n return (\n !!actions ||\n handlers.onRowCreate ||\n handlers.onRowCopy ||\n handlers.onRowDelete ||\n !!inlineEditingUniqueId ||\n handlers.onRowEdit\n );\n};\n\nconst getActions = (\n actions: RowActionHandler<any>[] | undefined,\n row: TableRow<any> | undefined = undefined\n): [RowAction<any>[], RowAction<any>[]] => {\n const primary: RowAction<any>[] = [];\n const secondary: RowAction<any>[] = [];\n\n if (actions) {\n let visibleActions = actions.filter(x => !!x && typeof x !== 'boolean') as RowAction<any>[];\n\n if (row) {\n visibleActions = visibleActions.filter(action => {\n if (action.visible !== undefined) {\n if (typeof action.visible === 'function') {\n return action.visible(row);\n }\n\n return action.visible;\n }\n\n return true;\n });\n }\n\n visibleActions.forEach(action => {\n if (action.showOnRow) {\n primary.push(action);\n } else {\n secondary.push(action);\n }\n });\n }\n\n return [primary, secondary];\n};\n\nconst getLength = (inlineEditingUniqueId: any, handlers: any, actions: RowActionHandler<any>[] | undefined): number => {\n const [primaryActions, secondaryActions] = getActions(actions);\n\n let length = primaryActions.length + (secondaryActions.length ? 1 : 0);\n\n if (handlers.onRowCreate) {\n length++;\n }\n\n if (handlers.onRowCopy) {\n length++;\n }\n\n if (handlers.onRowDelete) {\n length++;\n }\n\n if (!!inlineEditingUniqueId || handlers.onRowEdit) {\n length++;\n\n if (length < 2) {\n length++;\n }\n }\n\n return length;\n};\n\nconst getActionProps = (action: RowAction<any>, row: TableRow<any>) => {\n return {\n 'aria-label': typeof action.tooltip === 'function' ? action.tooltip(row) : action.tooltip,\n disabled: typeof action.disabled === 'function' ? action.disabled(row) : action.disabled,\n onClick: (event: React.MouseEvent<HTMLElement>) => {\n action.onClick(row, event);\n },\n };\n};\n\nconst EditModeActions = () => {\n React.useEffect(() => {\n const listener = (event: any) => {\n if (event.key === 'Escape' && event.target?.form?.reset) {\n event.preventDefault();\n event.target.form.reset();\n }\n };\n\n document.addEventListener('keydown', listener);\n\n return () => {\n document.removeEventListener('keydown', listener);\n };\n }, []);\n\n return (\n <div className={actionGroupClassName}>\n <IconButton appearance=\"primary\" icon=\"tick\" type=\"submit\" className=\"mr-2\" />\n <IconButton appearance=\"ghost\" icon=\"close\" type=\"reset\" />\n </div>\n );\n};\n\nexport const useRowActions = <T extends {}>(\n inlineEditingUniqueId: keyof T | undefined,\n handlers: any,\n actions: RowActionHandler<T>[] | undefined,\n rowExpansionRenderer: any,\n texts: LocalizationTexts,\n windowed = false\n): PluginHook<{}> => {\n const inlineEditing = !!inlineEditingUniqueId;\n const actionsLength = getLength(inlineEditingUniqueId, handlers, actions);\n\n const plugin = (hooks: any): void => {\n if (hasActions(inlineEditingUniqueId, handlers, actions)) {\n hooks.visibleColumns.push((columns: any) => [\n ...columns,\n {\n id: '_actions',\n className: 'flex justify-end px-1 overflow-visible',\n flex: `0 0 calc((${actionsLength} * 2rem) + .5rem)`,\n Cell: ({ row }: any) => {\n if (row.isEditing) {\n return <EditModeActions />;\n }\n\n const sanitizedRow = sanitizeRowProps(row, rowExpansionRenderer);\n const [primaryActions, secondaryActions] = getActions(actions, sanitizedRow);\n\n const output = (\n <>\n {handlers.onRowCreate && (\n <IconButton\n appearance=\"discrete\"\n icon=\"circle-plus\"\n aria-label={texts.table.newSubRow}\n tooltip={texts.table.newSubRow}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n\n if (!row.isExpanded) {\n row.toggleRowExpanded();\n }\n\n handlers.onRowCreate(sanitizedRow, event);\n }}\n />\n )}\n {(inlineEditing || handlers.onRowEdit) && (\n <IconButton\n appearance=\"discrete\"\n icon=\"edit\"\n aria-label={texts.table.edit}\n tooltip={texts.table.edit}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n row.setActive();\n\n if (inlineEditing) {\n row.toggleRowEditing();\n } else if (handlers.onRowEdit) {\n event.persist();\n handlers.onRowEdit(sanitizedRow, event);\n }\n }}\n />\n )}\n {handlers.onRowCopy && (\n <IconButton\n appearance=\"discrete\"\n icon=\"copy\"\n aria-label={texts.table.copy}\n tooltip={texts.table.copy}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n handlers.onRowCopy(sanitizedRow, event);\n }}\n />\n )}\n {handlers.onRowDelete && (\n <IconButton\n appearance=\"discrete\"\n icon=\"delete\"\n aria-label={texts.table.del}\n tooltip={texts.table.del}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n event.persist();\n row.setActive();\n handlers.onRowDelete(sanitizedRow, event);\n }}\n />\n )}\n {primaryActions.map((action: RowAction<T>, index: number) => (\n <IconButton\n {...getActionProps(action, sanitizedRow)}\n key={index}\n appearance=\"discrete\"\n icon={typeof action.icon === 'function' ? action.icon(sanitizedRow) : action.icon}\n tooltip={\n typeof action.tooltip === 'function' ? action.tooltip(sanitizedRow) : action.tooltip\n }\n />\n ))}\n {secondaryActions.length ? (\n <Menu>\n <Menu.Trigger>\n <IconButton\n appearance=\"discrete\"\n icon=\"ellipsis-vertical\"\n aria-label={texts.table.actions}\n tooltip={texts.table.actions}\n disabled={inlineEditing && !row.canEdit}\n onClick={(event: React.MouseEvent) => {\n event.stopPropagation();\n row.setActive();\n }}\n />\n </Menu.Trigger>\n <Menu.Content>\n {secondaryActions.map((action: RowAction<T>, index: number) => (\n <Menu.Item\n key={index}\n icon={\n typeof action.icon === 'function'\n ? action.icon(sanitizedRow)\n : action.icon\n }\n {...getActionProps(action, sanitizedRow)}>\n {typeof action.text === 'function' ? action.text(sanitizedRow) : action.text}\n </Menu.Item>\n ))}\n </Menu.Content>\n </Menu>\n ) : null}\n </>\n );\n\n if (windowed) {\n return <div className={actionGroupClassName}>{output}</div>;\n }\n\n return (\n <InView rootMargin=\"100px 0px\">\n {({ inView, ref }) => (\n <div className={actionGroupClassName} ref={ref}>\n {inView ? output : null}\n </div>\n )}\n </InView>\n );\n },\n },\n ]);\n }\n };\n plugin.pluginName = 'useRowActions';\n return plugin;\n};\n","import React from 'react';\nimport { actions, PluginHook } from 'react-table';\nimport { Icon } from '../../../Icon/Icon';\nimport { RowDragHandler } from '../../types';\nimport { sanitizeRowProps } from '../../util';\n\nconst pluginName = 'useRowDraggable';\n\nactions.resetRowDragging = 'resetRowDragging';\nactions.toggleRowDragging = 'toggleRowDragging';\n\nfunction reducer(state: any, action: any): object {\n if (action.type === actions.init) {\n return {\n draggingRowIndexPath: null,\n ...state,\n };\n }\n\n if (action.type === actions.resetRowDragging) {\n return {\n ...state,\n draggingRowIndexPath: null,\n };\n }\n\n if (action.type === actions.toggleRowDragging) {\n const { indexPath } = action;\n return {\n ...state,\n draggingRowIndexPath: indexPath,\n };\n }\n\n return state;\n}\n\nconst prepareRow = (row: any, { instance }: any): void => {\n row.toggleRowDragging = () => {\n if (instance.state.draggingRowIndexPath === row.id) {\n instance.dispatch({ type: actions.resetRowDragging });\n } else {\n instance.dispatch({ type: actions.toggleRowDragging, indexPath: row.id });\n }\n };\n\n if (instance.state.draggingRowIndexPath) {\n row.isDragging = instance.state.draggingRowIndexPath === row.id || !!instance.state.selectedRowIds?.[row.id];\n } else {\n row.isDragging = false;\n }\n};\n\nconst visibleColumns = (columns: any) => {\n return [\n {\n id: 'draggable',\n className: 'yt-table__cell--draggable flex-col px-0',\n Cell: () => <Icon name=\"drag\" className=\"text-grey-700 invisible w-[20px] cursor-grab\" />,\n flex: '0 0 20px',\n },\n ...columns,\n ];\n};\n\nconst getRowProps =\n (onRowDrag: RowDragHandler<any>) =>\n (props: any, { instance, row }: any) => {\n const onDragStart = (event: React.DragEvent): void => {\n event.persist();\n row.toggleRowDragging();\n\n const indexPaths = [row.id, ...Object.keys(instance.state.selectedRowIds)];\n const data = instance.rows.filter((r: any) => indexPaths.includes(r.id)).map(sanitizeRowProps);\n\n const showPlaceholder = (placeholder: string) => {\n const element = window.document.createElement('div');\n element.id = 'yt-table__drag__placeholder';\n element.innerText = placeholder;\n window.document.body.appendChild(element);\n\n if (typeof DataTransfer.prototype.setDragImage === 'function') {\n event.dataTransfer.setDragImage(element, 0, 20);\n }\n };\n\n onRowDrag(data, showPlaceholder, event);\n };\n\n const onDragEnd = (): void => {\n const element: HTMLElement | null = document.getElementById('yt-table__drag__placeholder');\n\n if (element && element.parentNode) {\n element.parentNode.removeChild(element);\n }\n\n row.toggleRowDragging();\n };\n\n return [\n props,\n {\n draggable: true,\n onDragStart,\n onDragEnd,\n },\n ];\n };\n\nexport const useRowDraggable = (onRowDrag: RowDragHandler<any> | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n if (onRowDrag) {\n hooks.stateReducers.push(reducer);\n hooks.prepareRow.push(prepareRow);\n hooks.visibleColumns.push(visibleColumns);\n hooks.getRowProps.push(getRowProps(onRowDrag));\n }\n };\n plugin.pluginName = pluginName;\n\n return plugin;\n};\n","import React from 'react';\nimport { useTable as useReactTable, useExpanded, useSortBy, usePagination, useRowState } from 'react-table';\nimport { getColumnsFromChildren, getInternalSortRules } from '../util';\nimport { sortTypes } from '../util/sortTypes';\nimport { useRowEditing } from './plugins/useRowEditing';\nimport { useRowActions } from './plugins/useRowActions';\nimport { useRowSelect } from './plugins/useRowSelect';\nimport {\n InternalTable,\n InternalTableRow,\n PaginationHandler,\n RowActiveHandler,\n SortHandler,\n TableProps,\n TableRef,\n} from '../types';\nimport { useTableKeyboardNavigation } from './useTableKeyboardNavigation';\nimport { useLocalization } from '../../Provider/Localization';\nimport { useRowDraggable } from './plugins/useRowDraggable';\nimport { sanitizeRowProps } from '../util';\n\nconst useTableRowActive = (\n activeIndex: number | undefined,\n rows: InternalTableRow[],\n rowExpansionRenderer: TableProps<any>['rowExpansionRenderer'],\n handleonRowActive: RowActiveHandler<any> | undefined\n) => {\n React.useEffect(() => {\n if (activeIndex !== undefined && rows.length && handleonRowActive) {\n const focusedRow = rows[activeIndex];\n if (focusedRow) {\n const sanitizedFocusedRow = sanitizeRowProps(focusedRow, rowExpansionRenderer);\n handleonRowActive(sanitizedFocusedRow);\n }\n }\n }, [activeIndex, rows]);\n};\n\nconst useTableInstance = (instance: any, ref: React.RefObject<TableRef>): object => {\n const sanitizedInstance = React.useMemo(\n () => ({\n toggleAllRowsExpanded: instance.toggleAllRowsExpanded,\n toggleHideAllColumns: instance.toggleHideAllColumns,\n toggleHideColumn: instance.toggleHideColumn,\n toggleEditing: instance.toggleEditing,\n toggleRowEditing: instance.toggleRowEditing,\n resetRowEditing: instance.resetRowEditing,\n toggleRowExpanded: instance.toggleRowExpanded,\n toggleSortBy: instance.toggleSortBy,\n }),\n []\n );\n\n React.useEffect(() => {\n if (ref?.current) {\n ref.current.instance = sanitizedInstance;\n }\n }, [ref]);\n\n return sanitizedInstance;\n};\n\nconst useTablePaginationListener = (disablePagination: boolean, onPaginate: PaginationHandler | undefined, state: any): void => {\n React.useEffect(() => {\n if (!disablePagination && onPaginate) {\n onPaginate(state.pageIndex, state.pageSize);\n }\n }, [state.pageIndex, state.pageSize]);\n};\n\nconst useTableSortingListener = (\n data: any[],\n sortedRows: any[],\n onSort: SortHandler<any> | undefined,\n manualSorting: boolean,\n state: any\n): void => {\n React.useEffect(() => {\n if (onSort) {\n const sortRules = state.sortBy.map((rule: any) => ({ accessor: rule.id, desc: rule.desc }));\n\n if (manualSorting) {\n onSort(sortRules);\n } else {\n let sortedData;\n\n if (sortRules.length && sortedRows?.length) {\n sortedData = sortedRows.map((row: any) => row.original);\n }\n\n onSort(sortRules, sortedData || data);\n }\n }\n }, [onSort && JSON.stringify(state.sortBy), manualSorting]);\n};\n\nconst DEFAULT_PAGE_SIZE = 10;\n\nexport const useTable = <T extends {}>(\n props: TableProps<T> & { windowed?: boolean },\n ref: React.RefObject<TableRef>\n): InternalTable => {\n const {\n children,\n data,\n dangerouslyHijackGlobalKeyboardNavigation: _,\n onRowClick,\n onRowDrag,\n onSelectedRows,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n selectedRows,\n\n // sorting\n disableSorting,\n manualSorting,\n onSort,\n sortRules,\n\n //index\n activeIndex: _1,\n defaultActiveIndex: _2,\n onChangeActiveIndex: _3,\n\n // pagination\n disablePagination = true,\n length,\n onPaginate,\n pageSize = DEFAULT_PAGE_SIZE,\n pageIndex = 0,\n\n // row editing\n inlineEditingUniqueId = undefined,\n onRowCreate,\n\n // actions\n actions,\n onRowEdit,\n onRowCopy,\n onRowDelete,\n onRowActive,\n\n windowed = false,\n\n ...otherProps\n } = props;\n\n if ((onSelectedRows && !selectedRows) || (!onSelectedRows && selectedRows)) {\n throw new Error(\n 'Selected rows in a Table component are fully controlled - you must pass both the `onSelectedRows` and `selectedRows` props when using row selection'\n );\n }\n\n const { texts, locale } = useLocalization();\n const { columns, sortRules: defaultSortRules } = React.useMemo(\n () => getColumnsFromChildren(children, rowExpansionRenderer),\n [children, rowExpansionRenderer]\n );\n\n const manualPagination = !disablePagination && !!onPaginate && !!length;\n\n const {\n headerGroups,\n rows,\n sortedRows,\n prepareRow: prepareBaseRow,\n state,\n // pagination\n page,\n gotoPage,\n setPageSize,\n ...instance\n }: any = useReactTable(\n {\n columns,\n data,\n initialState: {\n // @ts-expect-error: not sure how to type this correctly right now\n sortBy: getInternalSortRules(sortRules) || defaultSortRules,\n pageSize: !disablePagination ? pageSize : undefined,\n pageIndex: !disablePagination ? pageIndex : undefined,\n },\n manualPagination,\n pageCount: manualPagination && length ? Math.ceil(length / pageSize) : -1,\n manualSortBy: manualSorting,\n disableSortBy: disableSorting,\n // most of these resets preventions are needed for editing mode\n autoResetExpanded: false,\n autoResetSelectedRows: false,\n autoResetSortBy: false,\n autoResetPage: false,\n sortTypes: React.useMemo(() => sortTypes(locale), []),\n useControlledState: currentState => {\n return React.useMemo(\n () => ({\n ...currentState,\n selectedRowIds: selectedRows || [],\n }),\n [currentState, selectedRows]\n );\n },\n },\n useRowState,\n useSortBy,\n useExpanded,\n usePagination,\n useRowSelect(onSelectedRows),\n useRowDraggable(onRowDrag),\n useRowEditing(inlineEditingUniqueId),\n useRowActions(\n inlineEditingUniqueId,\n { onRowCreate, onRowEdit, onRowCopy, onRowDelete },\n actions,\n rowExpansionRenderer,\n texts,\n windowed\n )\n );\n\n useTablePaginationListener(disablePagination, onPaginate, state);\n useTableSortingListener(data, sortedRows, onSort, !!manualSorting, state);\n\n const sanitizedInstance = useTableInstance(instance, ref);\n\n const visibleRows = !disablePagination && !manualPagination ? page : rows;\n\n const [activeIndex, setActiveIndex, handleKeyDown, handleFocus] = useTableKeyboardNavigation<T>(\n props,\n visibleRows,\n { onRowClick, onRowCreate, onRowEdit, onRowCopy, onRowDelete, rowExpansionRenderer },\n ref\n );\n\n useTableRowActive(activeIndex, rows, rowExpansionRenderer, onRowActive);\n\n const prepareRow = React.useCallback(\n (row: any, index: number) => {\n prepareBaseRow(row);\n row.setActive = () => setActiveIndex(index);\n },\n [prepareBaseRow, setActiveIndex]\n );\n\n return {\n rowProps: {\n activeIndex,\n setActiveIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n inlineEditingUniqueId,\n },\n tableProps: {\n ...otherProps,\n headerGroups,\n onFocus: handleFocus,\n onKeyDown: handleKeyDown,\n tabIndex: otherProps.tabIndex ?? 0,\n },\n state,\n pagination: !disablePagination\n ? {\n length: manualPagination && length ? length : data.length,\n pageIndex: state.pageIndex,\n pageSize: state.pageSize,\n setPageIndex: gotoPage,\n setPageSize: setPageSize,\n }\n : null,\n rows: visibleRows,\n prepareRow,\n instance: sanitizedInstance,\n };\n};\n","// this wraps react-table's internal useRowSelect hook\nimport React from 'react';\nimport { useRowSelect as useBaseRowSelect, Row, PluginHook } from 'react-table';\nimport { Checkbox } from '../../../Checkbox/Checkbox';\nimport { SelectedRowsHandler } from '../../types';\n\nconst toggleBetween = (fromRowIndex: number, toRowIndex: number): [number, number] => {\n const fromIndex = toRowIndex < fromRowIndex ? toRowIndex : fromRowIndex;\n const toIndex = toRowIndex > fromRowIndex ? toRowIndex : fromRowIndex;\n\n return [fromIndex, toIndex];\n};\n\n// react-table calls \"index paths\" row ids. we named them indexPaths to reduce confusion with natural ids\n// the selection hook usess react-table's row selection, so this hok references row.id - it is the index path\n\nexport const useRowSelect = (onSelectedRows: SelectedRowsHandler | undefined): PluginHook<{}> => {\n const plugin = (hooks: any): void => {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n useBaseRowSelect(hooks);\n\n if (onSelectedRows) {\n const toggleRowSelected = (indexPath: string, checked: boolean): void =>\n onSelectedRows(state => {\n const nextState = { ...state };\n\n if (checked) {\n nextState[indexPath] = true;\n } else {\n delete nextState[indexPath];\n }\n\n return nextState;\n });\n\n const prepareRow = (row: any) => {\n row.toggleRowSelected = () => toggleRowSelected(row.id, !row.isSelected);\n };\n\n hooks.prepareRow.push(prepareRow);\n\n // eslint-disable-next-line react-hooks/rules-of-hooks\n const lastSelectedSortedIndex = React.useRef();\n\n hooks.visibleColumns.push((columns: any) => [\n {\n id: 'selection',\n Header: ({ getToggleAllRowsSelectedProps, rows }: any) => {\n const { onChange: _, ...props } = getToggleAllRowsSelectedProps();\n\n const onChange = (checked): void => {\n if (checked) {\n // this intentionally only selects top level rows - sub rows add too much complexity\n onSelectedRows(Object.assign({}, Array(rows.length).fill(true)));\n } else {\n onSelectedRows({});\n }\n };\n\n return <Checkbox {...props} onChange={onChange} />;\n },\n Cell: ({ row, rows }: any) => {\n const { onChange: _, ...props } = row.getToggleRowSelectedProps();\n // row.index refers to the index in the original data, not the current index\n const sortedIndex = rows.findIndex((r: Row) => r.index === row.index);\n\n const onClick = (event: React.MouseEvent): void => {\n if (event.shiftKey) {\n const [fromIndex, toIndex] = toggleBetween(lastSelectedSortedIndex.current || 0, sortedIndex);\n\n for (let i = fromIndex; i <= toIndex; i++) {\n toggleRowSelected(rows[i].id, true);\n }\n } else {\n toggleRowSelected(row.id, !props.checked);\n }\n\n lastSelectedSortedIndex.current = sortedIndex;\n };\n\n return (\n <Checkbox\n {...props}\n className=\"!mt-2.5\"\n onClick={onClick}\n // this is necessary to remove console spam from eslint\n onChange={() => false}\n />\n );\n },\n flex: '0 0 36px',\n className: 'flex-col justify-start !py-0',\n },\n ...columns,\n ]);\n }\n };\n plugin.pluginName = 'useRowSelect';\n return plugin;\n};\n","import React from 'react';\nimport { useControllableState } from '@radix-ui/react-use-controllable-state';\nimport { getNextIndexFromKey } from '../../../utils/hooks/useListKeyboardNavigation';\nimport { sanitizeRowProps } from '../util';\nimport { TableProps } from '../types';\n\nexport const useTableKeyboardNavigation = <T extends {}>(\n props: TableProps<T>,\n rows: any[],\n rowProps: any,\n ref: React.RefObject<HTMLDivElement>\n): [\n number | undefined,\n (index: number) => void,\n (event: React.KeyboardEvent<HTMLElement>) => void,\n (event: React.FocusEvent<HTMLElement>) => void\n] => {\n const useGlobalKeyboardNavigation = props.dangerouslyHijackGlobalKeyboardNavigation;\n\n const [activeIndex, setActiveIndex] = useControllableState<number | undefined>({\n prop: props.activeIndex,\n defaultProp:\n props.defaultActiveIndex !== undefined ? props.defaultActiveIndex : useGlobalKeyboardNavigation ? 0 : undefined,\n onChange: index => {\n if (index !== undefined) {\n props.onChangeActiveIndex?.(index);\n }\n },\n });\n\n const onKeyDown = (event: KeyboardEvent): void => {\n const isModifierKeyPressed = event.metaKey || event.ctrlKey || event.altKey || event.shiftKey;\n\n if (\n useGlobalKeyboardNavigation &&\n document.activeElement !== ref.current &&\n document.activeElement?.getAttribute('type') !== 'search' &&\n document.activeElement !== document.body\n ) {\n return;\n }\n // abort key handling if other elements inside table are focused and we don't use global keyboard navigation\n if (!useGlobalKeyboardNavigation && document.activeElement !== ref.current) {\n return;\n }\n\n if (activeIndex !== undefined) {\n const currentRow = rows[activeIndex];\n\n if (currentRow) {\n const sanitizedRow = sanitizeRowProps(currentRow, rowProps.rowExpansionRenderer);\n\n if (rowProps.onRowClick && event.key === 'Enter') {\n event.preventDefault();\n rowProps.onRowClick(sanitizedRow);\n return;\n }\n\n if (currentRow.toggleRowSelected && event.key === ' ') {\n event.preventDefault();\n currentRow.toggleRowSelected();\n return;\n }\n\n if (currentRow.toggleRowExpanded) {\n if (currentRow.isExpanded && event.key === 'ArrowLeft') {\n event.preventDefault();\n currentRow.toggleRowExpanded();\n return;\n } else if (!currentRow.isExpanded && event.key === 'ArrowRight') {\n event.preventDefault();\n currentRow.toggleRowExpanded();\n return;\n }\n }\n\n // inline editing\n if (currentRow.toggleRowEditing) {\n if (currentRow.canEdit && !currentRow.isEditing) {\n if (rowProps.onRowCreate && event.shiftKey && event.key === 'n') {\n event.preventDefault();\n\n if (!currentRow.isExpanded) {\n currentRow.toggleRowExpanded();\n }\n\n rowProps.onRowCreate(sanitizedRow, event);\n return;\n }\n\n if (event.key === 'e') {\n event.preventDefault();\n currentRow.toggleRowEditing();\n return;\n }\n }\n }\n\n if (rowProps.onRowEdit && event.key === 'e' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowEdit(sanitizedRow, event);\n return;\n }\n\n if (rowProps.onRowCopy && event.key === 'c' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowCopy(sanitizedRow, event);\n return;\n }\n\n if (rowProps.onRowDelete && event.key === 'Delete' && !isModifierKeyPressed) {\n event.preventDefault();\n rowProps.onRowDelete(sanitizedRow, event);\n return;\n }\n }\n }\n\n const nextIndex = getNextIndexFromKey(event.key, rows.length, activeIndex);\n\n if (nextIndex !== undefined) {\n event.preventDefault();\n setActiveIndex(nextIndex);\n }\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLElement>): void => {\n if (!useGlobalKeyboardNavigation) {\n onKeyDown(event.nativeEvent);\n }\n };\n\n React.useEffect(() => {\n if (useGlobalKeyboardNavigation) {\n window.addEventListener('keydown', onKeyDown);\n }\n\n return () => {\n if (useGlobalKeyboardNavigation) {\n window.removeEventListener('keydown', onKeyDown);\n }\n };\n }, [onKeyDown]);\n\n const handleFocus = (): void => {\n if (activeIndex === undefined && rows.length) {\n setActiveIndex(0);\n }\n };\n\n return [activeIndex, setActiveIndex, handleKeyDown, handleFocus];\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { FocusScope } from '@react-aria/focus';\nimport { InternalTableCell, TableRow } from '../types';\nimport { sanitizeRowProps } from '../util';\n\nconst renderCell = (cell: InternalTableCell, row: TableRow<any>): JSX.Element => {\n const props = {\n ...cell.getCellProps(),\n className: cn('yt-table__cell flex-1 truncate p-2 align-middle', cell.column.className, {\n 'justify-start text-left': cell.column.align === 'left',\n 'justify-end text-right': cell.column.align === 'right',\n 'text-center': !cell.column.align,\n }),\n style: {\n ...cell.column.style,\n flex: typeof cell.column.flex === 'function' ? cell.column.flex(row) : cell.column.flex,\n },\n };\n return (\n <div {...props} role=\"gridcell\" data-taco=\"table-cell\">\n {cell.render('Cell') || null}\n </div>\n );\n};\n\nexport const Row = React.forwardRef(function TableRow({ row, index, instance, headerGroups, ...rowProps }: any, ref: any) {\n const {\n activeIndex,\n onRowClick,\n rowClassName,\n rowExpansionRenderer,\n rowHeight,\n setActiveIndex,\n style,\n inlineEditingUniqueId,\n } = rowProps;\n const sanitizedRow = sanitizeRowProps(row, rowExpansionRenderer);\n\n const props = {\n ...row.getRowProps(),\n style: {\n ...style,\n minHeight: rowHeight ? `${rowHeight}px` : undefined,\n paddingLeft: row.depth ? `${row.depth * 2}rem` : undefined,\n },\n className: cn(\n 'yt-table__row border-grey-100 flex border-b min-h-[2.5rem] hover:bg-grey-100',\n {\n 'yt-table__row--active bg-grey-100 hover:bg-grey-100': activeIndex === index,\n 'yt-table__row--clickable': !!onRowClick,\n 'yt-table__row--dragging': !!row.isDragging,\n 'yt-table__row--editing': !!row.isEditing,\n },\n typeof rowClassName === 'function' ? rowClassName(sanitizedRow) : rowClassName\n ),\n onClick: onRowClick\n ? (event: React.MouseEvent<HTMLElement>) => {\n if (\n event.target === event.currentTarget ||\n (event.target as HTMLElement).classList.contains('yt-table__cell')\n ) {\n event.preventDefault();\n event.persist();\n setActiveIndex(index);\n onRowClick(sanitizedRow);\n }\n }\n : () => {\n setActiveIndex(index);\n },\n };\n\n let cells = row.cells;\n\n if (row.depth > 0) {\n cells = row.cells.filter((cell: any) => !cell.column.hiddenOnSubRows);\n }\n\n const expandedRow = rowExpansionRenderer && row.isExpanded && <div>{rowExpansionRenderer(sanitizedRow, instance)}</div>;\n const rowContent = React.useMemo(() => {\n return (\n <>\n <FocusScope key={row.original._createKey} contain restoreFocus autoFocus>\n <div {...props} role=\"row\" ref={ref}>\n <input type=\"hidden\" name=\"_rowIndexPath\" value={row.id} />\n <input type=\"hidden\" name=\"_inlineEditingUniqueId\" value={row.original[inlineEditingUniqueId]} />\n {cells.map((cell: InternalTableCell) => renderCell(cell, sanitizedRow))}\n </div>\n </FocusScope>\n {expandedRow}\n </>\n );\n }, [row.original._createKey]);\n\n if (row.isEditing) {\n return rowContent;\n }\n\n return (\n <>\n <div {...props} role=\"row\" ref={ref}>\n {cells.map((cell: InternalTableCell) => renderCell(cell, sanitizedRow))}\n </div>\n {expandedRow}\n </>\n );\n});\n","import React from 'react';\nimport cn from 'classnames';\nimport { Icon } from '../../Icon/Icon';\n\nexport const Column = ({ cell }: any): any => {\n const props = {\n ...cell.getHeaderProps(),\n ...(cell.getSortByToggleProps && cell.getSortByToggleProps({ title: undefined })),\n className: cn('yt-table__cell flex flex-1 truncate p-2 align-middle text-grey-700 hover:text-black', cell.className, {\n 'yt-table__cell__group': !!cell.columns,\n 'cursor-pointer': !cell.disableSorting,\n 'justify-start text-left': cell.align === 'left',\n 'justify-end text-right': cell.align === 'right',\n 'justify-center text-center': cell.align === 'center' || !cell.align,\n }),\n style: { ...cell.style, flex: cell.flex },\n };\n\n if (cell.isSorted) {\n props['aria-sort'] = cell.isSortedDesc ? 'descending' : 'ascending';\n }\n\n return (\n <div {...props} key={cell.id} data-taco=\"table-column\">\n <span className=\"truncate\">{cell.render('Header')}</span>\n {cell.isSorted ? (\n <Icon name={cell.isSortedDesc ? 'chevron-down-solid' : 'chevron-up-solid'} className=\"-mt-0.5\" />\n ) : null}\n </div>\n );\n};\n","import React from 'react';\nimport cn from 'classnames';\nimport { HeaderGroup } from 'react-table';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { InternalBaseTable } from '../types';\nimport './Table.css';\nimport { Column } from '../util/renderColumn';\n\nexport const DefaultEmptyState = (): React.ReactNode => null;\n\nexport const BaseTable = React.forwardRef(function BaseTable(props: InternalBaseTable, ref: React.Ref<HTMLDivElement>) {\n const tableRef = useMergedRef<HTMLDivElement>(ref);\n const { autoFocus, children, disableSorting: _, headerGroups, headerRef, bodyRef, ...otherProps } = props;\n\n React.useEffect(() => {\n if (autoFocus && tableRef.current) {\n tableRef.current.focus();\n }\n }, []);\n\n const className = cn('yt-table flex flex-col focus:yt-focus focus:rounded-sm', props.className);\n\n return (\n <div {...otherProps} role=\"table\" className={className} ref={tableRef}>\n <div role=\"rowgroup\" className=\"yt-table__head\" ref={headerRef}>\n {headerGroups?.map((headerGroup: HeaderGroup<object>, index: number) => (\n <div\n key={index}\n role=\"row\"\n className=\"border-grey-300 flex h-auto min-h-[2.5rem] w-full select-none border-t-0 border-b-2 font-bold\">\n {headerGroup.headers.map((cell: any, index: number) => (\n <Column key={index} index={index} cell={cell} />\n ))}\n </div>\n ))}\n </div>\n\n <div role=\"rowgroup\" className=\"yt-table__body\" ref={bodyRef}>\n {children}\n </div>\n </div>\n );\n});\n","import React from 'react';\nimport { PluginHook } from 'react-table';\nimport { TableProps, InternalTableRow, ForwardedGenericTableWithStatics, TableRef } from '../types';\nimport { useTable } from '../hooks/useTable';\nimport { Pagination } from '../../Pagination/Pagination';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { Row } from '../util/renderRow';\nimport { DefaultEmptyState, BaseTable } from './BaseTable';\n\nexport const Table = React.forwardRef(function Table<T>(\n props: TableProps<T> & { plugins: PluginHook<{}>[] },\n ref: React.Ref<TableRef>\n) {\n const { emptyStateRenderer = DefaultEmptyState, ...otherProps } = props;\n const tableRef: any = useMergedRef<HTMLDivElement>(ref);\n const { rowProps, tableProps, rows, prepareRow, pagination, instance } = useTable(otherProps, tableRef);\n\n let paginationElement;\n\n if (pagination) {\n paginationElement = (\n <Pagination\n className=\"my-4 w-full\"\n length={pagination.length}\n pageIndex={pagination.pageIndex}\n pageSize={pagination.pageSize}\n setPageIndex={pagination.setPageIndex}\n setPageSize={pagination.setPageSize}\n showPageControls={pagination.length > pagination.pageSize}\n dangerouslyHijackGlobalKeyboardNavigation={props.dangerouslyHijackGlobalKeyboardNavigation}\n />\n );\n }\n\n return (\n <>\n {paginationElement}\n <BaseTable {...tableProps} ref={tableRef}>\n {rows.length\n ? rows.map((row: InternalTableRow, index: number) => {\n prepareRow(row, index);\n return (\n <Row\n {...rowProps}\n key={index}\n index={index}\n row={row}\n instance={instance}\n headerGroups={tableProps.headerGroups}\n />\n );\n })\n : emptyStateRenderer()}\n </BaseTable>\n {paginationElement}\n </>\n );\n}) as ForwardedGenericTableWithStatics;\n\nTable.Column = () => null;\nTable.Group = () => null;\n","import React from 'react';\nimport { ForwardedGenericTableWithStatics, TableProps, TableRef } from '../types';\nimport { Table } from './Table';\n\nexport const PaginatedTable = React.forwardRef(function PaginatedTable<T>(props: TableProps<T>, ref: React.Ref<TableRef>) {\n return <Table {...props} disablePagination={false} ref={ref} />;\n}) as ForwardedGenericTableWithStatics;\n\nPaginatedTable.Column = () => null;\nPaginatedTable.Group = () => null;\n","import React from 'react';\nimport cn from 'classnames';\nimport { PluginHook } from 'react-table';\nimport { areEqual, VariableSizeList } from 'react-window';\nimport InfiniteLoader from 'react-window-infinite-loader';\nimport { TableProps, ForwardedGenericTableWithStatics, TableRef } from '../types';\nimport { useTable } from '../hooks/useTable';\nimport { useBoundingClientRectListener } from '../../../hooks/useBoundingClientRectListener';\nimport { useMergedRef } from '../../../hooks/useMergedRef';\nimport { Row } from '../util/renderRow';\nimport { DefaultEmptyState, BaseTable } from './BaseTable';\nimport { useLocalization } from '../../Provider/Localization';\n\nconst ROW_HEIGHT = 40;\n\nconst VariableRow = React.memo(({ data, index, style: { height: _, ...style } }: any) => {\n const { texts } = useLocalization();\n const { rows, setRowHeight, rowProps, tableProps, instance, prepareRow, rowHeights } = data;\n const row = rows[index];\n const ref = React.useRef<HTMLDivElement>(null);\n\n React.useEffect(() => {\n if (ref?.current) {\n setRowHeight(index, ref.current.getBoundingClientRect().height);\n }\n }, [rowHeights[index]]);\n\n if (row) {\n prepareRow(row, index);\n\n return (\n <Row\n {...rowProps}\n style={style}\n key={index}\n index={index}\n row={row}\n instance={instance}\n headerGroups={tableProps.headerGroups}\n setRowHeight={setRowHeight}\n ref={ref}\n />\n );\n }\n\n return (\n <div className=\"yt-table__row\" role=\"row\" style={style}>\n <div className=\"yt-table__cell text-grey-300\">{texts.table.loading}</div>\n </div>\n );\n}, areEqual);\n\nconst getAverageRowHeight = (rowHeights = {}) => {\n const keys = Object.keys(rowHeights);\n const estimatedHeight = keys.reduce((p, i) => p + rowHeights[i], 0);\n return estimatedHeight / keys.length;\n};\n\nexport const WindowedTable = React.forwardRef(function WindowedTable<T>(\n props: TableProps<T> & { plugins: PluginHook<{}>[] },\n ref: React.Ref<TableRef>\n) {\n const tableRef: any = useMergedRef<HTMLDivElement>(ref);\n const { emptyStateRenderer = DefaultEmptyState, length, loadMore, ...otherProps } = props;\n const { rowProps, tableProps, rows, prepareRow, instance, state } = useTable<T>({ ...otherProps, windowed: true }, tableRef);\n\n // determine heights for windowing calculations\n const headerRef = React.useRef<HTMLDivElement>(null);\n const [rowsRef, setRowsRef] = React.useState<any>(null);\n const tableDimensions = useBoundingClientRectListener(tableRef);\n const headerDimensions = useBoundingClientRectListener(headerRef);\n const height = tableDimensions && headerDimensions ? tableDimensions.height - headerDimensions.height : null;\n\n // variable row height calculations\n const estimatedRowHeight = rowProps.rowHeight || ROW_HEIGHT;\n const rowHeights = React.useRef<Record<string, number>>({});\n const setRowHeight = React.useCallback((index: number, size: number) => {\n if (rowHeights.current[index] !== size) {\n rowHeights.current = {\n ...rowHeights.current,\n [index]: size,\n };\n\n if (rowsRef) {\n rowsRef.resetAfterIndex(0);\n }\n }\n }, []);\n const getRowHeight = React.useCallback(index => rowHeights.current[index] || estimatedRowHeight, []);\n\n React.useEffect(() => {\n if (rowsRef && rowProps.activeIndex !== undefined) {\n rowsRef.scrollToItem(rowProps.activeIndex, 'start');\n }\n }, [rowsRef, rowProps.activeIndex]);\n\n // trigger recalculation of variable row heights if the data changes\n React.useEffect(() => {\n rowHeights.current = {};\n\n if (rowsRef) {\n rowsRef.resetAfterIndex(0);\n }\n }, [rows.length]);\n\n const contentHeight = estimatedRowHeight * props.data.length || 0;\n const isScrollbarVisible = height !== null ? contentHeight > height : false;\n\n const className = cn(tableProps.className, 'yt-table--windowed', { 'table-with-scrollbar': isScrollbarVisible });\n\n let list;\n\n const itemData = {\n rows,\n setRowHeight,\n rowProps,\n tableProps,\n instance,\n prepareRow,\n state,\n rowHeights: rowHeights.current,\n };\n\n if (height && rows.length) {\n const listProps = {\n height,\n itemData,\n estimatedItemSize: getAverageRowHeight(rowHeights.current),\n itemSize: getRowHeight,\n width: '100%',\n };\n\n if (loadMore && length) {\n const isLoaded = (index: number) => !!rows[index];\n\n list = (\n <InfiniteLoader isItemLoaded={isLoaded} itemCount={length} loadMoreItems={loadMore as any}>\n {({ onItemsRendered, ref }: any) => (\n <VariableSizeList\n {...listProps}\n itemCount={length}\n onItemsRendered={onItemsRendered}\n ref={list => {\n ref(list);\n setRowsRef(list);\n }}>\n {VariableRow}\n </VariableSizeList>\n )}\n </InfiniteLoader>\n );\n } else {\n list = (\n <VariableSizeList\n {...listProps}\n itemCount={rows.length}\n ref={ref => {\n setRowsRef(ref);\n }}>\n {VariableRow}\n </VariableSizeList>\n );\n }\n }\n\n return (\n <BaseTable {...tableProps} className={className} headerRef={headerRef} ref={tableRef}>\n {list ? list : emptyStateRenderer()}\n </BaseTable>\n );\n}) as ForwardedGenericTableWithStatics;\n\nWindowedTable.Column = () => null;\nWindowedTable.Group = () => null;\n","import set from 'lodash/set';\nimport { Row, RowIndexPath } from '../types';\n\nexport const convertRowIndexPathToNumberArray = (rowIndexPath: RowIndexPath): number[] =>\n rowIndexPath?.split('.').map(Number) ?? [];\n\nexport const getByRowIndexPath = <TRow extends {}>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow> | undefined => {\n if (!rowIndexPath) {\n return undefined;\n }\n\n const currenTRow = [...data];\n const indexes = convertRowIndexPathToNumberArray(String(rowIndexPath));\n\n if (indexes.length) {\n const startIndex = indexes.shift() as number;\n return indexes.reduce((value, index) => value?.subRows?.[index] as Row<TRow>, currenTRow[startIndex]);\n }\n\n return undefined;\n};\n\nexport const setByRowIndexPath = <TRow extends {}>(data: Row<TRow>[], rowIndexPath: RowIndexPath, values: any): Row<TRow>[] => {\n const nexTRow = [...data];\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = rowIndexes.shift() as number;\n\n if (rowIndexes.length) {\n const path = rowIndexes.map(index => `subRows[${index}]`).join('.');\n set(nexTRow[rootIndex], path, values);\n } else {\n nexTRow[rootIndex] = values;\n }\n\n return nexTRow;\n};\n\nexport const getParentRowIndexPath = (rowIndexPath: RowIndexPath): RowIndexPath => {\n let parentIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n rowIndexes.pop();\n\n if (rowIndexes.length) {\n parentIndexPath = rowIndexes.join('.');\n }\n }\n\n return parentIndexPath;\n};\n","import React from 'react';\nimport { v4 as uuid } from 'uuid';\nimport set from 'lodash/set';\nimport unset from 'lodash/unset';\nimport get from 'lodash/get';\nimport compact from 'lodash/compact';\nimport pullAt from 'lodash/pullAt';\n\nimport { convertRowIndexPathToNumberArray, getByRowIndexPath, getParentRowIndexPath } from '../util/rowIndexPath';\nimport { Row, RowIndexPath, TableRef } from '../types';\n\nexport const insertChildTableRow = <TRow,>(\n data: Row<TRow>[],\n rowIndexPath: RowIndexPath = undefined,\n values: any = {}\n): [Row<TRow>[], RowIndexPath] => {\n const nexTRow: Row<TRow>[] = JSON.parse(JSON.stringify(data));\n\n let childRowIndexPath;\n\n if (rowIndexPath) {\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const currentRow = getByRowIndexPath(nexTRow, rowIndexes.join('.'));\n const nextSubRows = currentRow?.subRows ?? [];\n\n const path = rowIndexes.map(i => `[${i}]`).join('.subRows') + '.subRows';\n nextSubRows.unshift(values);\n set(nexTRow, path, nextSubRows);\n\n // rebuild the new id\n rowIndexes.push(0);\n childRowIndexPath = rowIndexes.join('.');\n } else {\n nexTRow.unshift(values);\n childRowIndexPath = '0';\n }\n\n return [nexTRow, childRowIndexPath];\n};\n\nexport const removeChildTableRow = <TRow,>(data: Row<TRow>[], rowIndexPath: RowIndexPath): Row<TRow>[] => {\n const nexTRow = JSON.parse(JSON.stringify(data));\n\n const rowIndexes = convertRowIndexPathToNumberArray(rowIndexPath);\n const rootIndex = Number(rowIndexes.shift());\n\n if (rowIndexes.length) {\n // unset\n const unsetPath = rowIndexes.map(index => `subRows[${index}]`).join('.');\n unset(nexTRow[rootIndex], unsetPath);\n\n // remove empty value from subRows\n rowIndexes.pop();\n const setPath = rowIndexes.length ? rowIndexes.map(index => `subRows[${index}]`).join('.') + '.subRows' : 'subRows';\n set(nexTRow[rootIndex], setPath, compact(get(nexTRow[rootIndex], setPath)));\n } else {\n pullAt(nexTRow, rootIndex);\n }\n\n return nexTRow;\n};\n\nexport type useTableRowCreation<TRow> = {\n data: Row<TRow>[];\n create: (rowIndexPath: RowIndexPath, values?: object | undefined) => RowIndexPath;\n remove: (rowIndexPath: RowIndexPath) => void;\n isCreating: boolean;\n};\n\nexport const useTableRowCreation = <TRow,>(data: Row<TRow>[], tableRef: React.RefObject<TableRef>): useTableRowCreation<TRow> => {\n const [internalData, setInternalData] = React.useState(JSON.parse(JSON.stringify(data)));\n const [activeRowIndexPath, setActiveRowIndexPath] = React.useState<string | undefined>(undefined);\n\n React.useEffect(() => {\n if (activeRowIndexPath !== undefined) {\n // keep the same edit key, so that we don't remount the row/form\n const currentRow: any = getByRowIndexPath(internalData, activeRowIndexPath);\n\n // get the active creation rows parent\n const parentId = getParentRowIndexPath(activeRowIndexPath);\n\n // insert a new empty row in the external data (with the same key)\n const [nexTRow, newRowIndexPath] = insertChildTableRow(JSON.parse(JSON.stringify(data)), parentId, currentRow);\n\n // update and set that row as active, we basically just changed it's position in our internal data\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(currentRow?._createKey);\n }\n } else {\n setInternalData(data);\n }\n }, [JSON.stringify(data)]);\n\n const create = (rowIndexPath: RowIndexPath = undefined, values: object | undefined = {}): RowIndexPath => {\n const _createKey = uuid();\n const [nexTRow, newRowIndexPath] = insertChildTableRow(internalData, rowIndexPath, { ...values, _createKey });\n setActiveRowIndexPath(newRowIndexPath);\n setInternalData(nexTRow);\n\n if (tableRef?.current) {\n tableRef.current.instance.toggleRowEditing(_createKey);\n }\n\n return newRowIndexPath;\n };\n\n const remove = (rowIndexPath: any): void => {\n const nexTRow = removeChildTableRow(internalData, rowIndexPath);\n setInternalData(nexTRow);\n setActiveRowIndexPath(undefined);\n };\n\n return {\n data: internalData,\n create,\n remove,\n isCreating: activeRowIndexPath !== undefined,\n };\n};\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as TabsPrimitive from '@radix-ui/react-tabs';\n\nimport { Orientation } from '../../types';\nimport './Tabs.css';\n\nexport type TabsProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * The controlled value of the tab to activate. Should be used in conjunction with `onChange`.\n */\n id?: string;\n /**\n * Set which tab is selected on mount.\n * This has to be one of the existing ids provided for tabs\n */\n defaultId?: string;\n /**\n * Content should be one or an array of `Tabs.Trigger` components inside `Tabs.List` and then\n * followed by one or an array of `Tabs.Content`.\n * *Note* that there can also be tabs that are rendered conditionally.\n */\n children: React.ReactNode;\n /**\n * Define orientation of tabs.\n * @defaultValue horizontal\n */\n orientation?: Orientation;\n /**\n * Callback that is called when tab is changed.\n */\n onChange?: (id: string) => void;\n};\n\nexport type TabListProps = React.HTMLAttributes<HTMLDivElement>;\n\nexport type TabTriggerProps = React.HTMLAttributes<HTMLButtonElement> & {\n /**\n * A unique value that associates the trigger with a content.\n */\n id: string;\n /**\n * When true, prevents the user from interacting with the tab.\n */\n disabled?: boolean;\n};\n\nexport type TabContentProps = React.HTMLAttributes<HTMLDivElement> & {\n /**\n * A unique value that associates the content with a trigger.\n */\n id: string;\n};\n\nexport type ForwardedTabsWithStatics = React.ForwardRefExoticComponent<TabsProps & React.RefAttributes<HTMLDivElement>> & {\n /** Tab list component containing all tab triggers, rendered in a `Tabs` group component */\n List: React.ForwardRefExoticComponent<TabListProps & React.RefAttributes<HTMLDivElement>>;\n /** Tab trigger component rendered in a `Tabs.List` component */\n Trigger: React.ForwardRefExoticComponent<TabTriggerProps & React.RefAttributes<HTMLButtonElement>>;\n /** Tab content component rendered in a `Tabs` group component */\n Content: React.ForwardRefExoticComponent<TabContentProps & React.RefAttributes<HTMLDivElement>>;\n};\n\nexport const Tabs = React.forwardRef(function Tabs(props: TabsProps, ref: React.Ref<HTMLDivElement>) {\n const { id, defaultId, children, onChange, orientation = 'horizontal', ...otherProps } = props;\n const className = cn(\n 'yt-tabs',\n `yt-tabs--${orientation}`,\n {\n 'flex w-full': orientation === 'vertical',\n },\n props.className\n );\n\n return (\n <TabsPrimitive.Root\n {...otherProps}\n className={className}\n data-taco=\"tabs\"\n defaultValue={defaultId}\n dir=\"ltr\"\n onValueChange={onChange}\n orientation={orientation}\n ref={ref}\n value={id}>\n {children}\n </TabsPrimitive.Root>\n );\n}) as ForwardedTabsWithStatics;\n\nconst TabList = React.forwardRef(function Tab(props: TabListProps, ref: React.Ref<HTMLDivElement>) {\n const className = cn('yt-tab__list border-b border-grey-300 flex flex-row m-0 mb-4', props.className);\n\n return <TabsPrimitive.List {...props} className={className} ref={ref} />;\n});\n\nconst TabTrigger = React.forwardRef(function Tab(props: TabTriggerProps, ref: React.Ref<HTMLButtonElement>) {\n const { id, disabled, ...otherProps } = props;\n const className = cn(\n 'yt-tab bg-transparent border-b-2 border-transparent text-grey-700 m-0 py-2 px-4',\n disabled\n ? 'cursor-not-allowed !text-grey-500'\n : 'cursor-pointer rounded-t hover:border-grey-300 aria-selected:border-blue-500 aria-selected:text-black aria-selected:hover:border-blue-300 hover:text-black active:yt-focus active:border-blue-500 focus:yt-focus focus:border-blue-500',\n props.className\n );\n\n return (\n <TabsPrimitive.Trigger\n {...otherProps}\n className={className}\n disabled={disabled}\n ref={ref}\n style={{\n transition: 'border 0.2s ease-in',\n }}\n value={id}\n />\n );\n});\n\nconst TabContent = React.forwardRef(function Tab(props: TabContentProps, ref: React.Ref<HTMLDivElement>) {\n const { id, ...otherProps } = props;\n const className = cn('yt-tab__panel outline-none', props.className);\n\n return <TabsPrimitive.Content {...otherProps} className={className} ref={ref} value={id} />;\n});\n\nTabs.List = TabList;\nTabs.Trigger = TabTrigger;\nTabs.Content = TabContent;\n","import * as React from 'react';\nimport cn from 'classnames';\nimport { getInputClasses } from '../Input/util';\n\nexport type TextareaProps = React.TextareaHTMLAttributes<HTMLTextAreaElement> & {\n /** Draws attention to the textarea by changing its style and making it visually prominent */\n highlighted?: boolean;\n /* Whether the input is in an invalid state */\n invalid?: boolean;\n /** Value of the textarea */\n value?: string;\n};\n\nexport const Textarea = React.forwardRef(function Textarea(props: TextareaProps, ref: React.Ref<HTMLTextAreaElement>) {\n const { defaultValue: _, highlighted, invalid, onKeyDown, ...otherProps } = props;\n const classNames = cn(getInputClasses(props), 'py-1 min-h-[75px] disabled:resize-none', props.className);\n\n // home and end keys only navigate to the start/end of textarea value if the textarea container does not scroll\n // if it has scroll height then the browser reverts to native scrolling behaviour only\n // so we manually override it to ensure _our_ desired behaviour remains intact\n const handleKeyDown = (event: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (event.key === 'Home' || event.key === 'End') {\n event.preventDefault();\n const position = event.key === 'End' ? event.currentTarget.value.length : 0;\n event.currentTarget.setSelectionRange(position, position);\n event.currentTarget.scrollTop = event.key === 'End' ? event.currentTarget.scrollHeight : 0;\n }\n\n if (onKeyDown) {\n onKeyDown(event);\n }\n };\n\n return <textarea {...otherProps} className={classNames} data-taco=\"textarea\" onKeyDown={handleKeyDown} ref={ref} />;\n});\n","import * as React from 'react';\nimport cn from 'classnames';\nimport * as PrimitiveSwitch from '@radix-ui/react-switch';\nimport { useId } from '../../hooks/useId';\n\ntype SwitchBaseProps = Omit<React.ButtonHTMLAttributes<HTMLButtonElement>, 'children' | 'onChange'> & {\n /** Label for the switch */\n label?: React.ReactNode;\n /* Whether user input is required */\n required?: boolean;\n};\n\ninterface UncontrolledSwitchProps extends SwitchBaseProps {\n checked?: never;\n onChange?: never;\n /* The default checked state (uncontrolled) */\n defaultChecked?: boolean;\n}\n\ninterface ControlledSwitchProps extends SwitchBaseProps {\n defaultChecked?: never;\n /* The current checked state (controlled) */\n checked: boolean;\n /* Handler called when the checked state changes */\n onChange: (checked: boolean) => void;\n}\n\nexport type SwitchProps = UncontrolledSwitchProps | ControlledSwitchProps;\n\nexport const Switch = React.forwardRef(function Switch(props: SwitchProps, ref: React.Ref<HTMLButtonElement>) {\n const { label, onChange, ...otherProps } = props;\n const id = useId(props.id);\n\n const className = cn(\n 'group h-5 w-9 flex flex-shrink-0 rounded-full inline-flex',\n {\n 'mr-2': !!label,\n 'bg-grey-500 hover:bg-grey-300 aria-checked:bg-blue-500 aria-checked:hover:bg-blue-300 focus:yt-focus':\n !props.disabled,\n 'bg-grey-100 cursor-not-allowed aria-checked:bg-blue-300': props.disabled,\n },\n props.className\n );\n\n let labelledByProps: Record<string, string> | null = null;\n\n if (label) {\n labelledByProps = {\n 'aria-labelledby': `${id}-label`,\n id,\n };\n }\n\n const element = (\n <PrimitiveSwitch.Root {...otherProps} {...labelledByProps} className={className} onCheckedChange={onChange} ref={ref}>\n <PrimitiveSwitch.Thumb className=\"'will-change-transform mt-0.5 h-4 w-4 translate-x-[0.15rem] rounded-full bg-white transition-transform group-disabled:opacity-50 group-aria-checked:translate-x-[1.1rem]\" />\n </PrimitiveSwitch.Root>\n );\n\n if (label) {\n const labelContainerClassName = cn('flex self-start cursor-pointer', {\n 'cursor-not-allowed text-grey-300': props.disabled,\n });\n\n return (\n <span className={labelContainerClassName}>\n {element}\n <label htmlFor={id} id={`${id}-label`}>\n {label}\n </label>\n </span>\n );\n }\n\n return element;\n});\nSwitch.displayName = 'Switch';\n","import * as React from 'react';\nimport Joyride, { Step, CallBackProps, ACTIONS, LIFECYCLE, Placement, EVENTS, TooltipRenderProps } from 'react-joyride';\n\nimport { Button } from '../Button/Button';\nimport { Group } from '../Group/Group';\nimport { IconButton } from '../IconButton/IconButton';\nimport { useLocalization } from '../Provider/Localization';\n\nexport type TourTexts = {\n /** Text for back action button */\n back: string;\n /**\n * Text for close button.\n * This button is displayed if tour is not continuous - replacing the `Next` button.\n * It will pause the flow of the tour and close the tooltip\n */\n close: string;\n /**\n * Aria-label and title for close icon button in each step.\n * This button skips and completes the flow entirely\n */\n skip: string;\n /**\n * Text for last action button.\n * This button is displayed when user is on the last step of the tour\n */\n last: string;\n /**\n * Text for next action button.\n * This button is displayed if tour has more than one steps and is continuous\n */\n next: string;\n /** Aria label and title for beacon that will open the tour step */\n open: string;\n};\n\nexport type TourStepProps = {\n /** Content can be any valid react node, for e.g. a `div` */\n children: React.ReactNode;\n /** Define the position of the tour's popup relative to the element is presenting */\n position?: Placement;\n /** The css selector of the html element you want to include in a tour */\n selector: string;\n /**\n * Show beacon for step.\n * A beacon is a styled component which indicates the current element to be presented.\n * For more informations about how to create a beacon, read [Joyride](https://docs.react-joyride.com) docs\n */\n showBeacon?: boolean;\n /** Text displayed above the children/content of the popup */\n title: string;\n};\n\nconst Tooltip = ({\n continuous,\n index,\n isLastStep,\n step,\n backProps,\n primaryProps,\n skipProps,\n tooltipProps,\n size,\n locale,\n disableTourSkipOnEsc,\n}: TooltipRenderProps & { locale: TourTexts; disableTourSkipOnEsc?: boolean }) => {\n const skipButtonRef = React.useRef<HTMLButtonElement>(null);\n\n React.useEffect(() => {\n const onWindowKeyDown = (event: KeyboardEvent): void => {\n if (!disableTourSkipOnEsc) {\n if (event.key === 'Escape' && skipButtonRef.current !== null) {\n event.preventDefault();\n skipButtonRef.current.click();\n return;\n }\n }\n };\n\n window.addEventListener('keydown', onWindowKeyDown);\n\n return () => {\n window.removeEventListener('keydown', onWindowKeyDown);\n };\n }, []);\n\n return (\n <div {...tooltipProps} className=\"yt-tour__step w-88 relative rounded bg-white p-4\">\n <IconButton\n {...skipProps}\n ref={skipButtonRef}\n appearance=\"discrete\"\n icon=\"close\"\n title={locale.skip}\n aria-label={locale.skip}\n className=\"absolute top-0 right-0 mt-1 mr-1\"\n />\n {step.title && <h5>{step.title}</h5>}\n {step.content}\n <Group className=\"mt-4 justify-end\">\n {index > 0 && (\n <Button {...backProps} appearance=\"discrete\">\n {locale.back}\n </Button>\n )}\n <Button {...primaryProps} appearance=\"primary\">\n {continuous\n ? isLastStep\n ? `${locale.last} (${index + 1}/${size})`\n : `${locale.next} (${index + 1}/${size})`\n : locale.close}\n </Button>\n </Group>\n </div>\n );\n};\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nexport const TourStep = (_props: TourStepProps): null => null;\n\nexport type TourProps = {\n /** Controls if [Joyride](https://docs.react-joyride.com) is active */\n autoStart?: boolean;\n /** Children should be one or more `Tour.Step` components */\n children: any;\n /** Are there more than one steps and should you be able to navigate between them using `Next` and `Previous` buttons */\n continuous?: boolean;\n /** Disable closing of tour when click on `Escape` */\n disableCloseOnEsc?: boolean;\n /** Don't close the presenting popup of the tour step when clicking outside it */\n disableOverlayClose?: boolean;\n /** Allows user to interact with the presented components (mouse and touch events) when the popup is visible */\n disableScrolling?: boolean;\n /* When user clicks on the close icon button, which will close the tour and complete the flow */\n onClose?: (step: TourStepProps) => void;\n /* When user completes the entire flow */\n onComplete?: Function;\n /** When step is ready */\n onReady?: (step: TourStepProps) => void;\n /* Allow mouse and touch events through the spotlight */\n spotlightClicks?: boolean;\n /* Stops the injection of custom overflow styles on parent container. Can be used to prevent remaining overflow styles after tour is done. */\n disableScrollParentFix?: boolean;\n /** The scroll distance from the element scrollTop value. */\n scrollOffset?: number;\n};\n\nexport const Tour = (props: TourProps) => {\n const {\n texts: { tour },\n } = useLocalization();\n\n const {\n autoStart: run,\n onComplete,\n onClose,\n onReady,\n spotlightClicks,\n disableCloseOnEsc: disableTourSkipOnEsc,\n disableScrollParentFix = false,\n scrollOffset,\n ...rest\n } = props;\n\n const steps = React.useMemo(() => {\n return React.Children.map(props.children, child => {\n const step: Step = {\n disableBeacon: !child.props.showBeacon,\n target: child.props.selector,\n placement: child.props.position,\n title: child.props.title,\n content: child.props.children,\n };\n return step;\n });\n }, [props.children]);\n\n const getStep = React.useCallback(\n (selector: string | HTMLElement) => props.children.find((child: any) => child.props.selector === selector)?.props,\n [props.children]\n );\n\n const callback = (state: CallBackProps) => {\n if (state.action === ACTIONS.SKIP && state.lifecycle === LIFECYCLE.COMPLETE) {\n if (onClose) {\n onClose(getStep(state.step.target));\n }\n }\n\n if (state.type === EVENTS.TOUR_END) {\n if (onComplete) {\n onComplete();\n }\n }\n\n if (state.lifecycle === LIFECYCLE.READY) {\n if (onReady) {\n onReady(getStep(state.step.target));\n }\n }\n };\n\n return (\n <Joyride\n {...rest}\n run={run}\n steps={steps}\n showProgress\n floaterProps={{\n disableAnimation: true,\n }}\n tooltipComponent={tooltipProps => (\n <Tooltip {...tooltipProps} locale={tour} disableTourSkipOnEsc={disableTourSkipOnEsc} />\n )}\n locale={tour}\n spotlightPadding={8}\n spotlightClicks={spotlightClicks}\n disableScrollParentFix={disableScrollParentFix}\n callback={callback}\n scrollOffset={scrollOffset}\n styles={{\n /** style beacon */\n options: {\n // tailwind.theme.colors.blue.300\n primaryColor: '#6ba4ff',\n },\n }}\n disableCloseOnEsc\n />\n );\n};\n\nTour.Step = TourStep;\n","import React from 'react';\nimport cn from 'classnames';\nimport './Progress.css';\n\nexport type ProgressProps = React.HTMLAttributes<HTMLSpanElement> & {\n /**\n * Indicates how long (in milliseconds) a progress bar will take to progress through.\n * By default, progress bar has no duration\n */\n duration?: number;\n};\n\nexport const Progress = ({ duration = undefined, ...props }: ProgressProps): JSX.Element => {\n let style;\n\n if (duration) {\n style = {\n animationDuration: `${duration}ms`,\n };\n }\n\n const className = cn('bg-grey-100 rounded block h-1 overflow-hidden w-full', props.className);\n\n const progressClassName = cn('yt-progress__bar block h-1', {\n \"w-full before:h-1 before:bg-grey-300 before:block before:animate-[progress-indeterminate_2s_cubic-bezier(0.4,0,0.2,1)_infinite] before:content-[' ']\":\n !duration,\n [`w-0 bg-grey-300 animate-[progress_linear]`]: duration,\n });\n\n return (\n <span {...props} data-taco=\"progress\" className={className}>\n <span className={progressClassName} data-taco=\"progress-bar\" style={style} />\n </span>\n );\n};\n","import * as React from 'react';\nimport * as Tooltip from '@radix-ui/react-tooltip';\nimport { ToastProvider } from '../Toast/Toaster';\nimport { Localization, LocalizationProvider } from './Localization';\n\nexport type ProviderProps = {\n /** Content would be your application */\n children?: any;\n /** Define localized texts and formatted data in your application */\n localization?: Localization;\n};\n\nexport const Provider = (props: ProviderProps): JSX.Element => {\n const { children, localization } = props;\n\n return (\n <LocalizationProvider localization={localization}>\n <Tooltip.Provider>\n <ToastProvider>{children}</ToastProvider>\n </Tooltip.Provider>\n </LocalizationProvider>\n );\n};\n","import React from 'react';\n\nexport const useOnClickOutside = (\n ref: React.RefObject<HTMLElement> | React.RefObject<HTMLElement>[],\n callback: (event: MouseEvent | TouchEvent) => void\n): void => {\n React.useEffect(() => {\n const listener = (event: MouseEvent | TouchEvent): void => {\n const refs = !Array.isArray(ref) ? [ref] : ref;\n if (refs.some(currentRef => !currentRef.current || currentRef.current.contains(event.target as Node))) {\n return;\n }\n callback(event);\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, callback]);\n};\n","import React from 'react';\n\nexport type usePaginationValues = {\n /** Current page index (zero based) */\n pageIndex: number;\n /** Number of items displayed on a page */\n pageSize: number;\n /** Handler called when navigating through pages */\n setPageIndex: (pageIndex: number) => void;\n /** Handler called when changing the size of the page */\n setPageSize: (size: number) => void;\n};\n\nexport const usePagination = (initialPageIndex = 0, initialPageSize = 10): usePaginationValues => {\n const [pageIndex, setPageIndex] = React.useState(initialPageIndex);\n const [pageSize, setPageSize] = React.useState(initialPageSize);\n\n return {\n pageIndex,\n pageSize,\n setPageIndex,\n setPageSize,\n };\n};\n"],"names":["AlertDialogContext","React","createContext","props","ref","mergeRefs","refs","value","forEach","current","Trigger","externalRef","parentRef","parentProps","useContext","refCallback","AlertDialogPrimitive","asChild","Footer","className","children","Cancel","Action","Backdrop","cn","getDialogSizeClassnames","size","Title","Content","onEscapeKeyDown","event","preventDefault","AlertDialog","defaultOpen","onChange","open","trigger","otherProps","context","Provider","onOpenChange","IconAccountPreview","svgRef","xmlns","viewBox","d","fill","fillRule","IconAccountingYearCancel","IconAccountingYear","IconAccounting","IconArrowBottom","IconArrowDown","IconArrowEnd","IconArrowLeft","IconArrowRight","IconArrowStart","IconArrowTop","IconArrowUp","IconAttachAuto","IconAttachCancel","IconAttach","IconAutotextInsert","IconAutotext","IconBasicTabs","IconBasic","IconBellSolid","IconBook","IconBooking","IconBudget","IconCalendar","IconCashAccount","IconCashReports","IconChatSolid","IconChat","IconChevronDownDouble","IconChevronDownSolid","IconChevronDown","IconChevronLeftDouble","IconChevronLeftSolid","clipRule","IconChevronLeft","IconChevronRightDouble","IconChevronRightSolid","IconChevronRight","IconChevronUpDouble","IconChevronUpSolid","IconChevronUp","IconCircleClose","IconCircleMinus","IconCirclePlus","IconCircleTick","IconClampOpen","IconClamp","IconClose","IconConnectionEnable","IconConnectionRevoke","IconContacts","IconCopy","IconCourses","IconCredit","IconDeletePermanently","IconDelete","IconDepecriate","IconDeveloper","IconDistributionTemplate","IconDocumentApprove","IconDocumentCreateEntry","IconDocumentCut","IconDocumentError","IconDocumentIsolatePage","IconDocumentMerge","IconDocumentMove","IconDocumentPreview","IconDocumentReceived","IconDocumentRejectedRequest","IconDocumentSplit","IconDocumentTime","IconDocument","IconDownload","IconDrag","IconECopedia","IconESignature","IconEdit","IconEllipsisHorizontal","IconEllipsisVertical","IconEntriesOnAccount","IconEntriesOpen","IconEntriesWarning","IconEntryTypeCustomerInvoice","IconEntryTypeCustomerPayment","IconEntryTypeJournalEntry","IconEntryTypeManualCustomerInvoice","IconEntryTypeSupplierInvoice","IconEntryTypeSupplierPayment","IconEnvelopeApproved","IconEnvelope","IconExpandView","IconExpenses","IconExportToExcel","IconExportToPdf","IconExport","IconFilterSolid","IconFilter","IconGraphSolid","IconHash","IconHome","IconImages","IconImport","IconInboxEinvoicing","IconInboxScanning","IconInboxSmart","IconInbox","IconInfo","IconInventoryMatrix","IconInventory","IconJournalPro","IconLayoutBoth","IconLayoutFirst","IconLayoutLast","IconLayoutNone","IconLayout","IconLedgerCardCustomerReminder","IconLedgerCardManualCustomerInvoice","IconLedgerCardObsoleteStock","IconLedgerCardOpeningEntry","IconLedgerCardReservedEntry","IconLedgerCardShrinkagePilferage","IconLedgerCardStockAdjustment","IconLedgerCardTransferredOpeningEntry","IconLedgerCard","IconLightbulb","IconLine","IconListBulleted","IconListSearch","IconList","IconLockOpen","IconLogOut","IconLog","IconMarket","IconMatchAmount","IconMatchEntries","IconMenu","IconMileage","IconModalResize","IconModalShrink","IconMoreSolid","IconMore","IconMove","IconNavigationList","IconNoteFollowUp","IconNoteRead","IconNote","IconNumbers","IconPartnerApi","IconPeriod","IconPersonChange","IconPersonMinus","IconPersonPlus","IconPersonTick","IconPlay","IconPlusMinus","IconPrint","IconProcessPayment","IconProductLedgerCard","IconProfile","IconProjectCards","IconProjects","IconQuicklinks","IconRatingBankruptcy","IconRatingPaymentProblems","IconReconciled","IconRefresh","IconReportSolid","IconReport","IconRestore","IconRotateLeft","IconRotateRight","IconSales","IconSearchBold","IconSearch","IconSecureTick","IconSecure","IconSettingsSolid","IconSettings","IconShortcuts","IconShowAll","IconShowLess","IconShowMore","IconShowTemplate","IconSliders","IconSmartpay","IconSortBy","IconStarSolid","IconStar","IconSubscriptions","IconSystemEntries","IconTag","IconTemplateOverride","IconTemplates","IconThumbBoth","IconThumbDownSolid","IconThumbDown","IconThumbUpSolid","IconThumbUp","IconTick","IconTime","IconTransferCancel","IconTransferLocked","IconTransfer","IconUndo","stroke","strokeWidth","strokeLinecap","strokeLinejoin","IconUndock","IconUnreconciled","IconWarning","IconWebshop","IconWebsite","IconWorkflow","IconZoom","icons","account-preview","accounting-year-cancel","accounting-year","accounting","arrow-bottom","arrow-down","arrow-end","arrow-left","arrow-right","arrow-start","arrow-top","arrow-up","attach-auto","attach-cancel","attach","autotext-insert","autotext","basic-tabs","basic","bell-solid","book","booking","budget","calendar","cash-account","cash-reports","chat-solid","chat","chevron-down-double","chevron-down-solid","chevron-down","chevron-left-double","chevron-left-solid","chevron-left","chevron-right-double","chevron-right-solid","chevron-right","chevron-up-double","chevron-up-solid","chevron-up","circle-close","circle-minus","circle-plus","circle-tick","clamp-open","clamp","close","connection-enable","connection-revoke","contacts","copy","courses","credit","delete-permanently","delete","depecriate","developer","distribution-template","document-approve","document-create-entry","document-cut","document-error","document-isolate-page","document-merge","document-move","document-preview","document-received","document-rejected-request","document-split","document-time","document","download","drag","e-copedia","e-signature","edit","ellipsis-horizontal","ellipsis-vertical","entries-on-account","entries-open","entries-warning","entry-type-customer-invoice","entry-type-customer-payment","entry-type-journal-entry","entry-type-manual-customer-invoice","entry-type-supplier-invoice","entry-type-supplier-payment","envelope-approved","envelope","expand-view","expenses","export-to-excel","export-to-pdf","export","filter-solid","filter","graph-solid","hash","home","images","import","inbox-einvoicing","inbox-scanning","inbox-smart","inbox","info","inventory-matrix","inventory","journal-pro","layout-both","layout-first","layout-last","layout-none","layout","ledger-card-customer-reminder","ledger-card-manual-customer-invoice","ledger-card-obsolete-stock","ledger-card-opening-entry","ledger-card-reserved-entry","ledger-card-shrinkage-pilferage","ledger-card-stock-adjustment","ledger-card-transferred-opening-entry","ledger-card","lightbulb","line","list-bulleted","list-search","list","lock-open","log-out","log","market","match-amount","match-entries","menu","mileage","modal-resize","modal-shrink","more-solid","more","move","navigation-list","note-follow-up","note-read","note","numbers","partner-api","period","person-change","person-minus","person-plus","person-tick","play","plus-minus","print","process-payment","product-ledger-card","profile","project-cards","projects","quicklinks","rating-bankruptcy","rating-payment-problems","reconciled","refresh","report-solid","report","restore","rotate-left","rotate-right","sales","search-bold","search","secure-tick","secure","settings-solid","settings","shortcuts","show-all","show-less","show-more","show-template","sliders","smartpay","sort-by","star-solid","star","subscriptions","system-entries","tag","template-override","templates","thumb-both","thumb-down-solid","thumb-down","thumb-up-solid","thumb-up","tick","time","transfer-cancel","transfer-locked","transfer","undo","undock","unreconciled","warning","webshop","website","workflow","zoom","Icon","forwardRef","name","Component","p-[3px]","_props$className","includes","focusable","role","AccordionContext","as","StyledTrigger","isExpanded","Heading","AccordionPrimitive","Accordion","id","defaultId","useMemo","valueProps","defaultValue","undefined","onValueChange","type","Array","isArray","Item","VisuallyHidden","getStateClasses","getOutlineClasses","state","Badge","compact","outline","[object Object]","h-2 w-2 min-w-0","h-5 py-0 px-1.5","title","Button","disabled","target","Tag","href","count","map","child","Tooltip","placement","TooltipPrimitive","delayDuration","side","sideOffset","style","transformOrigin","getAppearanceClasses","icon","createButtonWithTooltip","tooltip","buttonProps","button","ButtonPrimitive","createButtonWithOverlays","buttonBase","dialog","hanger","popover","anchor","Base","rounded","appearance","rounded-full","cursor-not-allowed opacity-50","focus:yt-focus active:focus:yt-focus","data-taco","IconButton","defaultLocalisationTexts","months","weekdaysShort","actions","previousMonth","nextMonth","previousYear","nextYear","today","combobox","datepicker","clear","expand","banner","listbox","loading","empty","allOption","pagination","label","pageSize","showingXofYofTotal","firstPage","firstPageWithShortcut","previousPage","previousPageWithShortcut","nextPage","nextPageWithShortcut","lastPage","lastPageWithShortcut","pageX","table","del","newSubRow","select","allOptionsSelected","select2","allSelect","allDeselect","cancel","chooseColor","create","save","searchOrCreate","toasts","dismiss","tour","back","skip","last","next","searchInput","placeholder","defaultLocalizationContext","locale","texts","formatting","date","LocalizationContext","LocalizationProvider","localization","useLocalization","Banner","onClose","getBannerIcon","onClick","fluid","w-full","key","thisYear","Date","getFullYear","years","i","push","Navbar","onMonthChange","onNextClick","onPreviousClick","handleChange","year","month","form","getMonth","String","Calendar","disabledDays","visibleMonth","setVisibleMonth","ReactDayPicker","selectedDays","substring","firstDayOfWeek","navbarElement","navProps","onDayClick","modifiers","outside","onTodayButtonClick","setHours","setMinutes","setSeconds","captionElement","todayButton","numberOfMonths","externalProps","noPadding","mx-4 mb-4","Card","useId","nativeId","uuid","Checkbox","checked","highlighted","indeterminate","invalid","border-grey-300 text-blue-500 hover:text-blue-300 focus:border-blue-500 focus:hover:border-blue-300","border-grey-200 text-blue-300 cursor-not-allowed","bg-[rgba(255,255,0,0.2)] disabled:bg-[rgba(255,255,0,0.075)]","border-red-500 text-red-500 hover:text-red-300 hover:border-red-300 focus:border-red-500 focus:hover:border-red-300","labelledByProps","aria-labelledby","element","CheckboxPrimitive","onCheckedChange","labelContainerClassName","cursor-not-allowed text-grey-300","htmlFor","displayName","getInputClasses","border-grey-300 focus:border-blue-300 focus:yt-focus","hover:shadow-[0_0_0.1rem_theme(colors.grey.500)] active:border-blue-700","border-grey-200 text-opacity-25 cursor-not-allowed placeholder:text-grey-700","bg-[rgba(255,255,0,0.075)]","bg-[rgba(255,255,0,0.2)]","border-red focus:border-red-300 focus:yt-focus-red active:border-red-700","hover:shadow-[0_0_0.15rem_theme(colors.red.500)]","cursor-not-allowed text-black bg-grey-200","readOnly","debounce","fn","delay","timeoutId","args","clearTimeout","setTimeout","apply","this","getVisibility","Boolean","offsetWidth","offsetHeight","getClientRects","length","useBoundingClientRectListener","dependencies","dimensions","setDimensions","isRefElementVisible","visibility","setVisibility","resize","_ref$current","getBoundingClientRect","timeout","debouncedResize","window","addEventListener","removeEventListener","newRefElementVisibility","_ref$current2","useMergedRef","internalRef","useRef","useEffect","validSetSelectionRangeTypes","InputWithoutDeprecatedFeatures","onKeyDown","postfix","prefix","attributes","handleKeyDown","shiftKey","position","currentTarget","setSelectionRange","prefixRef","prefixRect","postfixRef","postfixRect","pl-8","pr-8","opacity","paddingLeft","width","paddingRight","Affix","text-grey-300","text-grey-700","left-0 [&>button]:!-ml-2","right-0 [&>button]:!-mr-2","Input","buttonClassName","getNextIndexFromKey","index","direction","useListScrollTo","itemRefs","scrollTo","activeRef","parent","clientHeight","scrollHeight","scrollTop","childBottom","offsetTop","scrollToChildElement","Spinner","visible","useState","cx","cy","r","getId","getNextEnabledItem","data","nextIndex","ScrollableList","setCurrentIndex","onFocus","scrollOnFocus","currentIndex","multiselect","selectedIndexes","listRef","_itemRefs$currentInde","_itemRefs$currentInde2","scrollIntoView","block","handleClick","persist","getOptionCheckedState","optionValue","findIndex","options","option","depth","path","split","aria-selected","data-focused","text","sticky top-0 font-bold","hasChildren","yt-list--multiselect","pointer-events-none","cursor-not-allowed","tabIndex","optionProps","createCustomEvent","eventType","customEvent","Event","bubbles","createEvent","initEvent","createCustomKeyboardEvent","customKeyboardEvent","KeyboardEvent","charCode","setInputValueByRef","input","previousValue","tracker","_valueTracker","setValue","dispatchEvent","getValue","setInputValueByRefBase","getIndexFromValue","getSelectedIndexesFromValue","v","o","findByValue","find","searchForString","strategy","_child$props","_child$props2","subChild","_child$props3","toString","toLowerCase","getIndexInRangeByValue","query","firstIndex","lastIndex","slice","getActiveDescendant","useFlattenedData","items","flatten","item","parentPath","parentDisabled","currentPath","isItemDisabled","childItem","childPath","sanitizeItem","rest","getOptionParents","indexes","lastPath","pop","join","debouncer","f","convertToInputValue","Combobox","externalClassName","ariaLabelledBy","unfilteredData","inline","onSearch","inputRef","buttonRef","setOpen","listId","inputValue","setInputValue","shouldFilterData","flattenedData","filteredOptionValues","Set","shouldFilterOption","parents","add","has","filterData","setInputValueByIndex","setCurrentValue","isCurrentValue","aria-expanded","aria-owns","aria-haspopup","aria-controls","aria-autocomplete","aria-activedescendant","onBlur","relatedTarget","detail","click","initialIndex","isDefaultPrevented","useCombobox","selectDimensions","yt-combobox--inline","PopoverPrimitive","autoComplete","_input$ref$current","focus","_input$ref$current2","align","onOpenAutoFocus","minWidth","format","mask","isDate","toDate","isValid","pad","replace","getDate","parseFromCustomString","sanitizedMask","dd","x","mm","yy","day","y","Number","parseInt","inputParts","fullDate","unseparatedMask","indexOf","lastIndexOf","currentDate","Object","is","NaN","UnstyledArrow","offset","height","transform","PopoverContext","_props$children","console","warn","RenderPropWrapper","CustomEvent","popoverContentProps","output","Close","Popover","modal","Portal","Datepicker","onReset","handleReset","shortcutsText","internalValue","setInternalValue","formattedValue","valueAsDate","useDatepicker","shortcut","DialogContext","closeOnEscape","draggable","drawer","toggle","elements","extra","showCloseButton","useCurrentDialog","DialogPrimitive","renderProps","dragging","handleProps","dragHandleProps","setPosition","setDragging","moveProps","useMove","onMoveStart","onMove","rect","left","deltaX","right","innerWidth","top","deltaY","bottom","innerHeight","onMoveEnd","useDraggable","containerClassName","rounded-b-none","onInteractOutside","Drawer","motion","div","_dialog$drawer","variants","display","transition","ease","duration","hidden","transitionEnd","animate","_dialog$drawer2","Extra","Dialog","initialChildren","toArray","_child$type","_child$type2","useSeparatedChildren","drawerOpen","setDrawerOpen","isDrawerOpen","Field","message","messageClassName","text-red-500","opacity-50","Form","horizontal","yt-form--horizontal flex flex-wrap","Group","orientation","flex-col ","HangerContext","Anchor","Hanger","HoverCardPrimitive","HoverCard","openDelay","SearchInput","_internalRef$current","_props$onKeyDown","useTimer","callback","timer","setTracker","remaining","started","running","start","now","pause","resume","useTypeahead","typeaheadQuery","typeaheadQueryTimer","getNextIndex","charKey","activeIndex","findNextIndexByValue","Listbox","externalData","emptyValue","defaultValueIndex","test","_item$path","useListbox","maxHeight","MultiListbox","setAllOptionsSelected","setSelectedIndexes","selectableItemsCount","newInputValue","currentInputValue","_inputRef$current","currentValuesArray","optionAlreadySelected","val","aria-multiselectable","useMultiListbox","MenuContext","useCurrentMenu","DropdownMenuPrimitive","IconPrimitive","useItemStyling","indented","registerIndentation","pl-7","pl-1.5","cursor-pointer hover:wcag-grey-200 text-black","cursor-not-allowed hover:bg-white text-grey-300","Shortcut","stopPropagation","onSelect","Link","setMinWidth","getRadioGroupItemValueAsString","values","valueAsString","RadioGroupContext","RadioGroupItem","isDisabled","border-grey-300 hover:border-4 focus:yt-focus aria-checked:bg-blue-500 aria-checked:border-blue-500 hover:aria-checked:border-blue-300","border-grey-200 cursor-not-allowed aria-checked:bg-blue-300 aria-checked:border-blue-300 ","border-red-500 hover:border-4 text-red-500 focus:border-red-500 focus:yt-focus-red aria-checked:bg-red-500 aria-checked:border-red","labelClassName","cursor-pointer","RadioGroupPrimitive","useRadioGroup","radioGroupItemValues","RadioGroup","flex-wrap gap-x-4 ","flex-col","MenuRadioGroupContext","Header","Menu","defaultProp","prop","setIndented","useControllableState","Separator","TreeviewItem","TreeviewGroup","expanded","initialExpanded","fixed","setExpanded","listClassName","flex","itemProps","nextState","Children","cloneElement","Treeview","useDropTarget","onDrop","isDraggedOver","setDraggedOver","handleDragEnter","useCallback","handleDragLeave","handleDragOver","handleDrop","onDragEnter","onDragLeave","onDragOver","active","proxyRef","dropTargetProps","isTreeitem","w-full mb-px py-1 px-3 flex items-center hover:bg-grey-300","bg-white w-full h-10 px-3 flex-shrink-0 flex items-center justify-between cursor-pointer","yt-navigation__item--active","bg-grey-300","yt-navigation__item--dropping bg-blue-500","HTMLAnchorElement","HTMLButtonElement","Panel","MenuGroup","bg-white pb-2","mb-1","cursor-pointer hover:text-blue-500","scrollableAreas","area","Navigation","PageNumbers","currentPageIndex","pageCount","range","pageNumber","lowerLimit","Math","min","upperLimit","b","createPageRange","BaseSelect","autoFocus","aria-label","ariaLabel","listboxInputRef","buttonId","lastValue","setLastValue","selectedValues","_findByValue","useSelect","yt-select--readonly","inputClassname","border-blue-500","commonListboxProps","Select","editable","Pagination","pageIndex","pageSizes","setPageIndex","setPageSize","showPageControls","showPageNumbers","showPageSize","dangerouslyHijackGlobalKeyboardNavigation","maxPageIndex","ceil","showShortcutTexts","useGlobalKeyboardNavigation","max","usePaginationShortcuts","canPreviousPage","canNextPage","maxItemIndex","getShowingLabel","Toast","content","lastUpdated","handleClose","autoClose","border border-grey-200","border border-grey-500","border border-blue-500","border border-yellow-700","border border-red","controls","useAnimation","scale","triggerUpdateAnimation","onMouseEnter","onMouseLeave","css","getBadgeIcon","ToastContext","insertToastWithoutDuplicates","currentToasts","nextToasts","existingToastIndex","toast","JSON","stringify","lastDuplicateId","ToastProvider","setToasts","toaster","update","success","error","information","AnimatePresence","initial","damping","stiffness","exit","isAriaSelectionKey","getOptionsFromCollection","collection","selector","querySelectorAll","Root","querySelector","setActiveIndex","lastLengthRef","setActiveOption","_collection$querySele","removeAttribute","setAttribute","setActiveIndexByElement","matches","nextActiveIndex","from","selected","firstSelected","selectedIndex","isAriaDirectionKey","recurse","getNextIndexFromKeycode","isSkippableItem","getAttribute","hasAttribute","Listbox2Context","customSelector","multiple","CollectionPrimitive","Option","listboxDisabled","listboxReadOnly","currentValue","labelledById","setLabelledById","Listbox2GroupContext","TAG_COLORS","green","yellow","red","blue","purple","orange","brown","pink","grey","color","onDelete","textRef","hover:bg-opacity-75","Select2Context","useSelect2Context","_catch","body","recover","result","e","then","Symbol","iterator","asyncIterator","AVAILABLE_COLORS","keys","EditPopover","initialColor","initialName","popoverProps","onEdit","searchRef","selectRef","setName","setColor","validationError","setValidationError","handleInputChange","handleInputKeyDown","handleSave","handleDelete","preventKeyDownPropagation","onCloseAutoFocus","_searchRef$current","_selectRef$current","!pb-0","Colours","onChangeColor","availableColor","mobiles","listboxRef","tags","hasValue","isTag","textValue","ListboxPrimitive","!visible","navigator","_window","userAgent","_listboxRef$current","parentElement","Bar","w-[7px] hover:w-[14px] mr-[2px] hover:px-[2px] hover:mr-0","flex-col h-[7px] hover:h-[14px] mb-[2px] hover:py-[2px] hover:mb-0","ScrollAreaPrimitive","Thumb","Corner","classname","ScrollArea","Multiple","Single","contentClassName","matchesValue","valuesAsChildren","c","MultipleValue","h-8","_buttonRef$current","contentRef","setContentRef","boundaryIndex","overscan","boundaryChildIndex","clientRect","getIndexOfFirstChildOverflowingParent","el","truncate","tagValue","BubbleSelect","selectProps","prevValue","usePreviousValue","getOwnPropertyDescriptor","HTMLSelectElement","prototype","set","call","Search","searchQuery","setSearchQuery","Create","onCreate","handleCreate","nextColor","occurences","reduce","colors","sort","a","getNextColor","Collection","Select2","disableSearch","_setValue","nextValue","allChildren","filteredChildren","_allChildren$","useChildren","handleBlur","elementGainingFocus","portalId","closest","_elementGainingFocus$","_otherProps$onBlur","ControlledHiddenField","_internalRef$current2","bubbleValue","reset","isFormControl","setIsFormControl","formElement","_ref$current$closest","useIsFormControl","sanitizeRowProps","row","rowExpansionRenderer","indexPath","original","subRows","_row$subRows","toggleRowExpanded","toggleRowEditing","isEditing","getColumnsFromChildren","sortRules","columns","groupChildren","column","sortType","disableSortBy","disableSorting","groupColumns","groupSortRules","accessor","headRenderer","Cell","columnProps","cell","editRenderer","cellRenderer","desc","getInternalSortRules","rule","getTime","parsedValue","getNumber","amount","decimalSeparator","isNaN","getString","guess","compareBasic","compareBasicStrings","compareResult","localeCompare","stringsLocaleCompare","reducer","action","init","allowEditing","editingRowUniqueId","resetRowEditing","resetPage","gotoPage","toggleEditing","useInstance","instance","dispatch","assign","getActions","primary","secondary","visibleActions","showOnRow","getActionProps","EditModeActions","listener","_event$target","_event$target$form","draggingRowIndexPath","resetRowDragging","toggleRowDragging","prepareRow","isDragging","selectedRowIds","_instance$state$selec","visibleColumns","DEFAULT_PAGE_SIZE","useTable","onRowClick","onRowDrag","onSelectedRows","rowClassName","rowHeight","selectedRows","manualSorting","onSort","disablePagination","onPaginate","inlineEditingUniqueId","onRowCreate","onRowEdit","onRowCopy","onRowDelete","onRowActive","windowed","Error","defaultSortRules","manualPagination","headerGroups","rows","sortedRows","prepareBaseRow","page","useReactTable","initialState","sortBy","manualSortBy","autoResetExpanded","autoResetSelectedRows","autoResetSortBy","autoResetPage","sortTypes","datetime","rowA","rowB","columnId","string","number","boolean","auto","useControlledState","currentState","useRowState","useSortBy","useExpanded","usePagination","plugin","hooks","useBaseRowSelect","toggleRowSelected","isSelected","lastSelectedSortedIndex","getToggleAllRowsSelectedProps","getToggleRowSelectedProps","sortedIndex","fromIndex","toIndex","toRowIndex","fromRowIndex","pluginName","useRowSelect","stateReducers","getRowProps","onDragStart","indexPaths","createElement","innerText","appendChild","DataTransfer","setDragImage","dataTransfer","onDragEnd","getElementById","parentNode","removeChild","useRowDraggable","uniqueId","_createKey","canEdit","useRowEditing","handlers","inlineEditing","actionsLength","primaryActions","secondaryActions","getLength","hasActions","sanitizedRow","setActive","InView","rootMargin","inView","useRowActions","useTablePaginationListener","sortedData","useTableSortingListener","sanitizedInstance","toggleAllRowsExpanded","toggleHideAllColumns","toggleHideColumn","toggleSortBy","useTableInstance","visibleRows","handleFocus","rowProps","defaultActiveIndex","onChangeActiveIndex","_props$onChangeActive","isModifierKeyPressed","metaKey","ctrlKey","altKey","activeElement","_document$activeEleme","currentRow","nativeEvent","useTableKeyboardNavigation","handleonRowActive","focusedRow","sanitizedFocusedRow","useTableRowActive","tableProps","renderCell","getCellProps","justify-start text-left","justify-end text-right","text-center","render","Row","minHeight","yt-table__row--active bg-grey-100 hover:bg-grey-100","yt-table__row--clickable","yt-table__row--dragging","yt-table__row--editing","classList","contains","cells","hiddenOnSubRows","expandedRow","rowContent","FocusScope","contain","restoreFocus","Column","getHeaderProps","getSortByToggleProps","yt-table__cell__group","justify-center text-center","isSorted","isSortedDesc","DefaultEmptyState","BaseTable","tableRef","headerRef","bodyRef","headerGroup","headers","Table","emptyStateRenderer","paginationElement","PaginatedTable","VariableRow","memo","setRowHeight","rowHeights","areEqual","getAverageRowHeight","p","WindowedTable","loadMore","rowsRef","setRowsRef","tableDimensions","headerDimensions","estimatedRowHeight","resetAfterIndex","getRowHeight","scrollToItem","table-with-scrollbar","listProps","itemData","estimatedItemSize","itemSize","InfiniteLoader","isItemLoaded","itemCount","loadMoreItems","onItemsRendered","VariableSizeList","convertRowIndexPathToNumberArray","rowIndexPath","getByRowIndexPath","currenTRow","startIndex","shift","_value$subRows","getParentRowIndexPath","parentIndexPath","rowIndexes","insertChildTableRow","nexTRow","parse","childRowIndexPath","nextSubRows","unshift","removeChildTableRow","rootIndex","unsetPath","unset","setPath","get","pullAt","Tabs","flex w-full","TabsPrimitive","dir","TabList","TabTrigger","TabContent","List","Textarea","classNames","Switch","mr-2","bg-grey-500 hover:bg-grey-300 aria-checked:bg-blue-500 aria-checked:hover:bg-blue-300 focus:yt-focus","bg-grey-100 cursor-not-allowed aria-checked:bg-blue-300","PrimitiveSwitch","continuous","isLastStep","step","backProps","primaryProps","skipProps","tooltipProps","disableTourSkipOnEsc","skipButtonRef","onWindowKeyDown","TourStep","_props","Tour","autoStart","run","onComplete","onReady","spotlightClicks","disableCloseOnEsc","disableScrollParentFix","scrollOffset","steps","disableBeacon","showBeacon","getStep","_props$children$find","Joyride","showProgress","floaterProps","disableAnimation","tooltipComponent","spotlightPadding","ACTIONS","SKIP","lifecycle","LIFECYCLE","COMPLETE","EVENTS","TOUR_END","READY","styles","primaryColor","Step","animationDuration","progressClassName","w-full before:h-1 before:bg-grey-300 before:block before:animate-[progress-indeterminate_2s_cubic-bezier(0.4,0,0.2,1)_infinite] before:content-[' ']","w-0 bg-grey-300 animate-[progress_linear]","tempDate","setIndex","some","currentRef","initialPageIndex","initialPageSize","internalData","setInternalData","activeRowIndexPath","setActiveRowIndexPath","parentId","newRowIndexPath","remove","isCreating"],"mappings":"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ImM2N5ByN,SlM3NWtR,aAAiB8D,IkM4N5ByN,ajM5NWvR,aAAiB+D,IiM6N5ByN,MhM7NWxR,aAAiBgE,IgM8N5ByN,a/L9NWzR,aAAiBiE,I+L+N5ByN,K9L/NW1R,aAAiBkE,I8LgO5ByN,Q7LhOW3R,aAAiBmE,I6LiO5ByN,O5LjOW5R,aAAiBoE,I4LkO5ByN,S3LlOW7R,aAAiBqE,I2LmO5ByN,e1LpOW9R,aAAiBsE,I0LqO5ByN,ezLpOW/R,aAAiBuE,IyLqO5ByN,axLrOWhS,aAAiBwE,IwLsO5ByN,KvLtOWjS,aAAiByE,IuLuO5ByN,sBtLvOWlS,aAAiB0E,IsLwO5ByN,qBrLxOWnS,aAAiB2E,IqLyO5ByN,epLzOWpS,aAAiB4E,IoL0O5ByN,sBnL1OWrS,aAAiB6E,ImL2O5ByN,qBlL1OWtS,aAAiB8E,IkL2O5ByN,ejL5OWvS,aAAiBgF,IiL6O5BwN,uBhL7OWxS,aAAiBiF,IgL8O5BwN,sB/K7OWzS,aAAiBkF,I+K8O5BwN,gB9K/OW1S,aAAiBmF,I8KgP5BwN,oB7KhPW3S,aAAiBoF,I6KiP5BwN,mB5KjPW5S,aAAiBqF,I4KkP5BwN,a3KlPW7S,aAAiBsF,I2KmP5BwN,e1KlPW9S,aAAiBuF,I0KmP5BwN,ezKpPW/S,aAAiBwF,IyKqP5BwN,cxKrPWhT,aAAiByF,IwKsP5BwN,cvKtPWjT,aAAiB0F,IuKuP5BwN,atKvPWlT,aAAiB2F,IsKwP5BwN,MrKxPWnT,aAAiB4F,IqKyP5BwN,MpKzPWpT,aAAiB6F,IoK0P5BwN,oBnK3PWrT,aAAiB8F,ImK4P5BwN,oBlK5PWtT,aAAiB+F,IkK6P5BwN,SjK5PWvT,aAAiBgG,IiK6P5BwN,KhK7PWxT,aAAiBiG,IgK8P5BwN,Q/J/PWzT,aAAiBkG,I+JgQ5BwN,O9J/PW1T,aAAiBmG,I8JgQ5BwN,qB7JhQW3T,aAAiBoG,I6JiQ5BwN,O5JjQW5T,aAAiBqG,I4JkQ5BwN,W3JlQW7T,aAAiBsG,I2JmQ5BwN,U1JnQW9T,aAAiBuG,I0JoQ5BwN,wBzJpQW/T,aAAiBwG,IyJqQ5BwN,mBxJrQWhU,aAAiByG,IwJsQ5BwN,wBvJtQWjU,aAAiB0G,IuJuQ5BwN,etJvQWlU,aAAiB2G,IsJwQ5BwN,iBrJxQWnU,aAAiB4G,IqJyQ5BwN,wBpJzQWpU,aAAiB6G,IoJ0Q5BwN,iBnJ1QWrU,aAAiB8G,ImJ2Q5BwN,gBlJ3QWtU,aAAiB+G,IkJ4Q5BwN,mBjJ5QWvU,aAAiBgH,IiJ6Q5BwN,oBhJ9QWxU,aAAiBiH,IgJ+Q5BwN,4B/I/QWzU,aAAiBkH,I+IgR5BwN,iB9I/QW1U,aAAiBmH,I8IgR5BwN,gB7IhRW3U,aAAiBoH,I6IiR5BwN,S5IlRW5U,aAAiBqH,I4ImR5BwN,S3IlRW7U,aAAiBsH,I2ImR5BwN,K1InRW9U,aAAiBuH,I0IoR5BwN,YzIpRW/U,aAAiBwH,IyIqR5BwN,cxIrRWhV,aAAiByH,IwIsR5BwN,KvItRWjV,aAAiB0H,IuIuR5BwN,sBtIvRWlV,aAAiB2H,IsIwR5BwN,oBrIxRWnV,aAAiB4H,IqIyR5BwN,qBpIzRWpV,aAAiB6H,IoI0R5BwN,enI1RWrV,aAAiB8H,ImI2R5BwN,kBlI3RWtV,aAAiB+H,IkI4R5BwN,8BjI5RWvV,aAAiBgI,IiI6R5BwN,8BhI7RWxV,aAAiBiI,IgI8R5BwN,2B/H9RWzV,aAAiBkI,I+H+R5BwN,qC9H5RW1V,aAAiBmI,I8H6R5BwN,8B7HhSW3V,aAAiBoI,I6HiS5BwN,8B5HjSW5V,aAAiBqI,I4HkS5BwN,oB3HlSW7V,aAAiBsI,I2HmS5BwN,S1HnSW9V,aAAiBuI,I0HoS5BwN,czHpSW/V,aAAiBwI,IyHqS5BwN,SxHrSWhW,aAAiByI,IwHsS5BwN,kBvHtSWjW,aAAiB0I,IuHuS5BwN,gBtHvSWlW,aAAiB2I,IsHwS5BwN,OrHxSWnW,aAAiB4I,IqHyS5BwN,epHzSWpW,aAAiB6I,IoH0S5BwN,OnH1SWrW,aAAiB8I,ImH2S5BwN,clH3SWtW,aAAiB+I,IkH4S5BwN,KjH5SWvW,aAAiBgJ,IiH6S5BwN,KhH7SWxW,aAAiBiJ,IgH8S5BwN,O/G9SWzW,aAAiBkJ,I+G+S5BwN,O9G/SW1W,aAAiBmJ,I8GgT5BwN,mB7G/SW3W,aAAiBoJ,I6GgT5BwN,iB5GhTW5W,aAAiBqJ,I4GiT5BwN,c3GjTW7W,aAAiBsJ,I2GkT5BwN,M1GlTW9W,aAAiBuJ,I0GmT5BwN,KzGpTW/W,aAAiBwJ,IyGqT5BwN,mBxGrTWhX,aAAiByJ,IwGsT5BwN,UvGtTWjX,aAAiB0J,IuGuT5BwN,ctGvTWlX,aAAiB2J,IsGwT5BwN,crGxTWnX,aAAiB4J,IqGyT5BwN,epGzTWpX,aAAiB6J,IoG0T5BwN,cnG1TWrX,aAAiB8J,ImG2T5BwN,clG3TWtX,aAAiB+J,IkG4T5BwN,OjG5TWvX,aAAiBgK,IiG6T5BwN,gChG7TWxX,aAAiBiK,IgG8T5BwN,sC/F3TWzX,aAAiBkK,I+F4T5BwN,6B9F/TW1X,aAAiBmK,I8FgU5BwN,4B7FhUW3X,aAAiBoK,I6FiU5BwN,6B5FjUW5X,aAAiBqK,I4FkU5BwN,kC3FlUW7X,aAAiBsK,I2FmU5BwN,+B1FnUW9X,aAAiBuK,I0FoU5BwN,wCzFjUW/X,aAAiBwK,IyFkU5BwN,cxFrUWhY,aAAiByK,IwFsU5BwN,UvFtUWjY,aAAiB0K,IuFuU5BwN,KtFvUWlY,aAAiB2K,IsFwU5BwN,gBrFxUWnY,aAAiB4K,IqFyU5BwN,cpFzUWpY,aAAiB6K,IoF0U5BwN,KnF1UWrY,aAAiB8K,ImF2U5BwN,YlF3UWtY,aAAiB+K,IkF4U5BwN,UjF3UWvY,aAAiBgL,IiF4U5BwN,IhF7UWxY,aAAiBiL,IgF8U5BwN,O/E9UWzY,aAAiBkL,I+E+U5BwN,e9E/UW1Y,aAAiBmL,I8EgV5BwN,gB7EhVW3Y,aAAiBoL,I6EiV5BwN,K5ElVW5Y,aAAiBqL,I4EmV5BwN,Q3ElVW7Y,aAAiBsL,I2EmV5BwN,e1EnVW9Y,aAAiBuL,I0EoV5BwN,ezEpVW/Y,aAAiBwL,IyEqV5BwN,axErVWhZ,aAAiByL,IwEsV5BwN,KvEtVWjZ,aAAiB0L,IuEuV5BwN,KtEvVWlZ,aAAiB2L,IsEwV5BwN,kBrExVWnZ,aAAiB4L,IqEyV5BwN,iBpEzVWpZ,aAAiB6L,IoE0V5BwN,YnE1VWrZ,aAAiB8L,ImE2V5BwN,KlE3VWtZ,aAAiB+L,IkE4V5BwN,QjE7VWvZ,aAAiBgM,IiE8V5BwN,chE7VWxZ,aAAiBiM,IgE8V5BwN,O/D9VWzZ,aAAiBkM,I+D+V5BwN,gB9D/VW1Z,aAAiBmM,I8DgW5BwN,e7DhWW3Z,aAAiBoM,I6DiW5BwN,c5DjWW5Z,aAAiBqM,I4DkW5BwN,c3DlWW7Z,aAAiBsM,I2DmW5BwN,K1DnWW9Z,aAAiBuM,I0DoW5BwN,azDpWW/Z,aAAiBwM,IyDqW5BwN,MxDrWWha,aAAiByM,IwDsW5BwN,kBvDtWWja,aAAiB0M,IuDuW5BwN,sBtDvWWla,aAAiB2M,IsDwW5BwN,QrDvWWna,aAAiB4M,IqDwW5BwN,gBpDzWWpa,aAAiB6M,IoD0W5BwN,SnD1WWra,aAAiB8M,ImD2W5BwN,WlD3WWta,aAAiB+M,IkD4W5BwN,oBjD5WWva,aAAiBgN,IiD6W5BwN,0BhD7WWxa,aAAiBiN,IgD8W5BwN,W/C9WWza,aAAiBkN,I+C+W5BwN,Q9ChXW1a,aAAiBmN,I8CiX5BwN,e7ChXW3a,aAAiBoN,I6CiX5BwN,O5CjXW5a,aAAiBqN,I4CkX5BwN,Q3ClXW7a,aAAiBsN,I2CmX5BwN,c1CpXW9a,aAAiBuN,I0CqX5BwN,ezCrXW/a,aAAiBwN,IyCsX5BwN,MxCrXWhb,aAAiByN,IwCsX5BwN,cvCtXWjb,aAAiB0N,IuCuX5BwN,OtCvXWlb,aAAiB2N,IsCwX5BwN,crCxXWnb,aAAiB4N,IqCyX5BwN,OpCzXWpb,aAAiB6N,IoC0X5BwN,iBnC1XWrb,aAAiB8N,ImC2X5BwN,SlC3XWtb,aAAiB+N,IkC4X5BwN,UjC5XWvb,aAAiBgO,IiC6X5BwN,WhC7XWxb,aAAiBiO,IgC8X5BwN,Y/B9XWzb,aAAiBkO,I+B+X5BwN,Y9B/XW1b,aAAiBmO,I8BgY5BwN,gB7BhYW3b,aAAiBoO,I6BiY5BwN,Q5BjYW5b,aAAiBqO,I4BkY5BwN,S3BlYW7b,aAAiBsO,I2BmY5BwN,U1BnYW9b,aAAiBuO,I0BoY5BwN,azBpYW/b,aAAiBwO,IyBqY5BwN,KxBrYWhc,aAAiByO,IwBsY5BwN,cvBtYWjc,aAAiB0O,IuBuY5BwN,iBtBvYWlc,aAAiB2O,IsBwY5BwN,IrBxYWnc,aAAiB4O,IqByY5BwN,oBpBzYWpc,aAAiB6O,IoB0Y5BwN,UnB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"}
|