@makeswift/runtime 0.0.16 → 0.0.19
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/api.cjs.js +1 -0
- package/dist/api.cjs.js.map +1 -1
- package/dist/api.es.js +1 -0
- package/dist/api.es.js.map +1 -1
- package/dist/builder.cjs.js +1 -1
- package/dist/builder.es.js +1 -1
- package/dist/components.cjs.js +6 -4
- package/dist/components.cjs.js.map +1 -1
- package/dist/components.es.js +6 -4
- package/dist/components.es.js.map +1 -1
- package/dist/constants.cjs.js +10 -363
- package/dist/constants.cjs.js.map +1 -1
- package/dist/constants.es.js +1 -354
- package/dist/constants.es.js.map +1 -1
- package/dist/control-serialization.cjs.js +43 -3
- package/dist/control-serialization.cjs.js.map +1 -1
- package/dist/control-serialization.es.js +41 -1
- package/dist/control-serialization.es.js.map +1 -1
- package/dist/controls.cjs.js +12 -9
- package/dist/controls.cjs.js.map +1 -1
- package/dist/controls.es.js +3 -2
- package/dist/controls.es.js.map +1 -1
- package/dist/descriptors.cjs.js.map +1 -1
- package/dist/descriptors.es.js.map +1 -1
- package/dist/graphql.cjs.js +365 -0
- package/dist/graphql.cjs.js.map +1 -0
- package/dist/graphql.es.js +356 -0
- package/dist/graphql.es.js.map +1 -0
- package/dist/image.cjs.js +14 -0
- package/dist/image.cjs.js.map +1 -0
- package/dist/image.es.js +10 -0
- package/dist/image.es.js.map +1 -0
- package/dist/index.cjs.js +404 -152
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.es.js +358 -106
- package/dist/index.es.js.map +1 -1
- package/dist/main.cjs.js +1 -0
- package/dist/main.cjs.js.map +1 -1
- package/dist/main.es.js +1 -0
- package/dist/main.es.js.map +1 -1
- package/dist/next.cjs.js +6 -4
- package/dist/next.cjs.js.map +1 -1
- package/dist/next.es.js +6 -4
- package/dist/next.es.js.map +1 -1
- package/dist/react-builder-preview.cjs.js +8 -6
- package/dist/react-builder-preview.cjs.js.map +1 -1
- package/dist/react-builder-preview.es.js +9 -7
- package/dist/react-builder-preview.es.js.map +1 -1
- package/dist/react-page.cjs.js +260 -0
- package/dist/react-page.cjs.js.map +1 -1
- package/dist/react-page.es.js +254 -1
- package/dist/react-page.es.js.map +1 -1
- package/dist/react.cjs.js +6 -4
- package/dist/react.cjs.js.map +1 -1
- package/dist/react.es.js +6 -4
- package/dist/react.es.js.map +1 -1
- package/dist/shape.cjs.js +20 -0
- package/dist/shape.cjs.js.map +1 -0
- package/dist/shape.es.js +14 -0
- package/dist/shape.es.js.map +1 -0
- package/dist/text-input.cjs.js +0 -18
- package/dist/text-input.cjs.js.map +1 -1
- package/dist/text-input.es.js +1 -13
- package/dist/text-input.es.js.map +1 -1
- package/dist/types/api/introspection.d.ts +10 -0
- package/dist/types/api/introspection.d.ts.map +1 -0
- package/dist/types/api/react.d.ts +0 -1
- package/dist/types/api/react.d.ts.map +1 -1
- package/dist/types/builder/serialization/control-serialization.d.ts +3 -3
- package/dist/types/builder/serialization/control-serialization.d.ts.map +1 -1
- package/dist/types/builder/serialization/controls/combobox.d.ts +5 -0
- package/dist/types/builder/serialization/controls/combobox.d.ts.map +1 -0
- package/dist/types/builder/serialization/controls/shape.d.ts +5 -0
- package/dist/types/builder/serialization/controls/shape.d.ts.map +1 -0
- package/dist/types/components/builtin/Box/Box.d.ts.map +1 -1
- package/dist/types/components/builtin/Button/Button.d.ts.map +1 -1
- package/dist/types/components/builtin/Carousel/Carousel.d.ts.map +1 -1
- package/dist/types/components/builtin/Countdown/Countdown.d.ts.map +1 -1
- package/dist/types/components/builtin/Divider/Divider.d.ts.map +1 -1
- package/dist/types/components/builtin/Embed/Embed.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/Form.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/Checkbox/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/Input/index.d.ts +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/Input/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/Label/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/PlaceholderTableField/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/RadioButton/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/SingleSelectTableField/components/TableColumnSingleSelect/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/components/TextArea/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Form/components/Field/services/cssField.d.ts +1 -1
- package/dist/types/components/builtin/Form/components/Placeholder/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Image/Image.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/Navigation.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/components/DropDownButton/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/components/LinksPlaceholder/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/components/MobileMenu/components/MobileDropDownButton/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Navigation/components/MobileMenu/index.d.ts.map +1 -1
- package/dist/types/components/builtin/Root/Root.d.ts.map +1 -1
- package/dist/types/components/builtin/SocialLinks/SocialLinks.d.ts.map +1 -1
- package/dist/types/components/builtin/Text/Text.d.ts.map +1 -1
- package/dist/types/components/builtin/Video/Video.d.ts.map +1 -1
- package/dist/types/components/hooks/useIsomorphicLayoutEffect.d.ts +3 -0
- package/dist/types/components/hooks/useIsomorphicLayoutEffect.d.ts.map +1 -0
- package/dist/types/components/hooks/useMediaQuery.d.ts.map +1 -1
- package/dist/types/components/shared/BackgroundsContainer/components/BackgroundVideo/index.d.ts.map +1 -1
- package/dist/types/components/shared/BackgroundsContainer/components/Backgrounds/index.d.ts.map +1 -1
- package/dist/types/components/shared/BackgroundsContainer/components/Parallax/index.d.ts.map +1 -1
- package/dist/types/components/utils/queries.d.ts +2 -0
- package/dist/types/components/utils/queries.d.ts.map +1 -1
- package/dist/types/controls/combobox.d.ts +22 -0
- package/dist/types/controls/combobox.d.ts.map +1 -0
- package/dist/types/controls/control.d.ts +3 -2
- package/dist/types/controls/control.d.ts.map +1 -1
- package/dist/types/controls/index.d.ts +1 -0
- package/dist/types/controls/index.d.ts.map +1 -1
- package/dist/types/controls/types.d.ts +3 -0
- package/dist/types/controls/types.d.ts.map +1 -1
- package/dist/types/prop-controllers/descriptors.d.ts +4 -3
- package/dist/types/prop-controllers/descriptors.d.ts.map +1 -1
- package/dist/types/prop-controllers/introspection.d.ts +5 -0
- package/dist/types/prop-controllers/introspection.d.ts.map +1 -1
- package/dist/types/runtimes/react/controls/combobox.d.ts +4 -0
- package/dist/types/runtimes/react/controls/combobox.d.ts.map +1 -0
- package/dist/types/runtimes/react/controls/control.d.ts +3 -2
- package/dist/types/runtimes/react/controls/control.d.ts.map +1 -1
- package/dist/types/runtimes/react/controls.d.ts.map +1 -1
- package/dist/types/runtimes/react/index.d.ts +1 -1
- package/dist/types/runtimes/react/index.d.ts.map +1 -1
- package/dist/types/state/react-page.d.ts +1 -0
- package/dist/types/state/react-page.d.ts.map +1 -1
- package/package.json +1 -1
- package/dist/list.cjs.js +0 -8
- package/dist/list.cjs.js.map +0 -1
- package/dist/list.es.js +0 -6
- package/dist/list.es.js.map +0 -1
package/dist/index.es.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.es.js","sources":["../src/components/builtin/Box/components/Placeholder/index.tsx","../src/components/utils/queries.ts","../src/components/utils/isNonNullable.ts","../src/api/react.tsx","../src/components/hooks/useBackgrounds.ts","../src/components/hooks/useBorder.ts","../src/components/hooks/useBoxShadow.ts","../src/components/hooks/useResponsiveColor.ts","../src/components/hooks/useFile.ts","../src/utils/keys.ts","../src/utils/coalesce.ts","../src/utils/shallowMerge.ts","../src/components/utils/devices.ts","../src/components/hooks/useMediaQuery.ts","../src/components/hooks/usePage.ts","../src/components/hooks/useTable.ts","../src/components/builtin/Box/animations.tsx","../src/components/utils/columns.ts","../src/components/utils/colorToString.ts","../src/components/utils/cssMediaRules.ts","../src/utils/clamp.ts","../src/components/shared/BackgroundsContainer/components/Parallax/index.tsx","../src/components/shared/BackgroundsContainer/components/BackgroundVideo/index.tsx","../src/components/shared/BackgroundsContainer/components/Backgrounds/index.tsx","../src/components/shared/BackgroundsContainer/index.tsx","../src/components/builtin/Box/Box.tsx","../src/components/shared/Link/index.tsx","../src/components/utils/responsive-style.ts","../src/components/builtin/Button/Button.tsx","../src/components/utils/placeholders.ts","../src/components/builtin/Image/Image.tsx","../src/components/builtin/Carousel/Carousel.tsx","../src/components/builtin/Countdown/Countdown.tsx","../src/components/builtin/Divider/Divider.tsx","../src/components/builtin/Embed/Embed.tsx","../src/components/icons/check-12.svg","../src/components/builtin/Form/context/FormContext.ts","../src/components/builtin/Form/components/Field/services/cssField.ts","../src/components/builtin/Form/components/Field/components/Input/index.tsx","../src/components/builtin/Form/components/Placeholder/index.tsx","../src/components/builtin/Form/components/Field/components/Label/index.tsx","../src/components/builtin/Form/components/Field/components/SingleLineTextTableField/index.tsx","../src/components/builtin/Form/components/Field/components/TextArea/index.tsx","../src/components/builtin/Form/components/Field/components/LongTextTableField/index.tsx","../src/components/builtin/Form/components/Field/components/Checkbox/index.tsx","../src/components/builtin/Form/components/Field/components/CheckboxTableField/index.tsx","../src/components/builtin/Form/components/Field/components/MultipleSelectTableField/index.tsx","../src/components/builtin/Form/components/Field/components/RadioButton/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/components/TableColumnRadioButtonGroup/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/components/TableColumnSingleSelect/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/index.tsx","../src/components/builtin/Form/components/Field/components/PhoneNumberTableField/index.tsx","../src/components/builtin/Form/components/Field/components/EmailTableField/index.tsx","../src/components/builtin/Form/components/Field/components/URLTableField/index.tsx","../src/components/builtin/Form/components/Field/components/NumberTableField/index.tsx","../src/components/builtin/Form/components/Field/components/PlaceholderTableField/index.tsx","../src/components/builtin/Form/components/Field/index.tsx","../src/components/icons/spinner-20.svg","../src/components/builtin/Form/components/Spinner/index.tsx","../src/components/hooks/useTableFormFieldRefs.ts","../src/components/builtin/Form/Form.tsx","../src/components/icons/mobile-menu-28.svg","../src/components/shared/GutterContainer/index.tsx","../src/components/builtin/Navigation/components/LinksPlaceholder/index.tsx","../src/components/icons/caret-down-8.svg","../src/components/icons/plus-8.svg","../src/components/icons/arrow-down-8.svg","../src/components/icons/chevron-down-8.svg","../src/components/builtin/Navigation/components/DropDownButton/index.tsx","../src/components/icons/times-16.svg","../src/components/builtin/Navigation/components/MobileMenu/components/MobileDropDownButton/index.tsx","../src/components/builtin/Navigation/components/MobileMenu/index.tsx","../src/components/builtin/Navigation/Navigation.tsx","../src/components/builtin/Root/components/Placeholder/index.tsx","../src/components/builtin/Root/Root.tsx","../src/components/icons/logo-angellist-20.svg","../src/components/icons/logo-codepen-20.svg","../src/components/icons/logo-dribbble-20.svg","../src/components/icons/logo-facebook-20.svg","../src/components/icons/logo-github-20.svg","../src/components/icons/logo-instagram-20.svg","../src/components/icons/logo-linkedin-20.svg","../src/components/icons/logo-medium-20.svg","../src/components/icons/logo-pinterest-20.svg","../src/components/icons/logo-reddit-20.svg","../src/components/icons/logo-rss-20.svg","../src/components/icons/logo-snapchat-20.svg","../src/components/icons/logo-soundcloud-20.svg","../src/components/icons/logo-spotify-20.svg","../src/components/icons/logo-telegram-20.svg","../src/components/icons/logo-tumblr-20.svg","../src/components/icons/logo-twitch-20.svg","../src/components/icons/logo-twitter-20.svg","../src/components/icons/logo-whatsapp-20.svg","../src/components/icons/logo-vimeo-20.svg","../src/components/icons/logo-yelp-20.svg","../src/components/icons/logo-youtube-20.svg","../src/components/builtin/SocialLinks/options.tsx","../src/components/builtin/SocialLinks/components/SocialLinksPlaceholder/index.tsx","../src/components/builtin/SocialLinks/SocialLinks.tsx","../src/components/hooks/useTypography.ts","../src/components/builtin/Text/components/RichTextEditor/components/Mark/hooks/useTypographyMark.ts","../src/components/builtin/Text/components/RichTextEditor/components/Mark/index.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/DeviceOverridesMarks.tsx","../src/components/builtin/Text/components/RichTextEditor/components/Block/index.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/DeviceOverridesBlocks.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/Link.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/Inlines.tsx","../src/components/builtin/Text/components/RichTextEditor/index.tsx","../src/components/builtin/Text/Text.tsx","../src/components/builtin/Video/Video.tsx","../src/components/builtin/index.ts","../src/components/page/BodySnippet.tsx","../src/utils/is.ts","../src/utils/shallowEqual.ts","../src/utils/deepEqual.ts","../src/components/page/Page.tsx","../src/components/icons/warning-20.svg","../src/components/shared/FallbackComponent/FallbackComponent.tsx","../../../node_modules/@emotion/hash/dist/hash.browser.esm.js","../../../node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../../../node_modules/@emotion/memoize/dist/emotion-memoize.browser.esm.js","../../../node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js","../../../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../src/runtimes/react/controls/style.ts","../src/runtimes/react/components/render-hook.ts","../src/runtimes/react/controls/checkbox.ts","../src/runtimes/react/controls/color.ts","../src/runtimes/react/controls/image.ts","../src/runtimes/react/controls/list.tsx","../src/runtimes/react/controls/number.ts","../src/runtimes/react/controls/select.ts","../src/runtimes/react/controls/shape.tsx","../src/runtimes/react/controls/text-area.ts","../src/runtimes/react/controls/text-input.ts","../src/runtimes/react/controls/control.tsx","../src/runtimes/react/controls.tsx","../src/runtimes/react/find-dom-node.tsx","../src/runtimes/react/index.tsx"],"sourcesContent":["import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\n\nconst PlaceholderBase = styled.div<{ hide: boolean }>`\n width: 100%;\n background: rgba(161, 168, 194, 0.18);\n height: 80px;\n padding: 8px;\n visibility: ${({ hide }) => (hide === true ? 'hidden' : 'initial')};\n`\n\ntype Props = { hide?: boolean }\n\nexport default forwardRef(function Placeholder(\n { hide = false, ...restOfProps }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <PlaceholderBase {...restOfProps} hide={hide} ref={ref}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"100%\"\n height=\"100%\"\n style={{ overflow: 'visible' }}\n >\n <rect\n x={0}\n y={0}\n width=\"100%\"\n height=\"100%\"\n strokeWidth={2}\n strokeDasharray=\"4 2\"\n fill=\"none\"\n stroke=\"rgba(161, 168, 194, 0.40)\"\n rx=\"4\"\n ry=\"4\"\n />\n </svg>\n </PlaceholderBase>\n )\n})\n","import { gql } from '@apollo/client'\n\nexport const SWATCHES_BY_ID = gql`\n query SwatchesById($ids: [ID!]!) {\n swatches(ids: $ids) {\n id\n hue\n saturation\n lightness\n }\n }\n`\n\nexport const FILE_BY_ID = gql`\n query FileById($id: ID!) {\n file(id: $id) {\n id\n name\n publicUrl\n extension\n dimensions {\n width\n height\n }\n }\n }\n`\n\nexport const FILES_BY_ID = gql`\n query FilesById($ids: [ID!]!) {\n files(ids: $ids) {\n id\n name\n publicUrl\n extension\n dimensions {\n width\n height\n }\n }\n }\n`\n\nexport const PAGE_PATHNAMES_BY_ID = gql`\n query PagePathnamesById($ids: [ID!]!) {\n pagePathnamesById(ids: $ids) {\n id\n pathname\n }\n }\n`\n\nexport const TYPOGRAPHY_FRAGMENT = gql`\n fragment Typography on Typography {\n id\n name\n style {\n deviceId\n value {\n fontFamily\n fontSize {\n value\n unit\n }\n color {\n swatchId\n alpha\n }\n lineHeight\n letterSpacing\n fontWeight\n textAlign\n uppercase\n underline\n strikethrough\n italic\n }\n }\n }\n`\n\nexport const TYPOGRAPHIES_BY_ID = gql`\n query TypographiesById($ids: [ID!]!) {\n typographies(ids: $ids) {\n ...Typography\n }\n }\n\n ${TYPOGRAPHY_FRAGMENT}\n`\n\nexport const TABLE_BY_ID = gql`\n query TableById($id: ID!) {\n table(id: $id) {\n id\n name\n columns {\n id\n name\n ... on MultipleSelectTableColumn {\n options {\n id\n name\n }\n }\n ... on SingleSelectTableColumn {\n options {\n id\n name\n }\n }\n }\n }\n }\n`\n","export function isNonNullable<T>(value: T): value is NonNullable<T> {\n return value != null\n}\n","import {\n ApolloClient,\n DocumentNode,\n NormalizedCacheObject,\n OperationVariables,\n QueryHookOptions,\n QueryResult,\n TypedDocumentNode,\n useQuery as useApolloQuery,\n useMutation as useApolloMutation,\n DefaultContext,\n ApolloCache,\n MutationHookOptions,\n MutationTuple,\n InMemoryCache,\n TypePolicies,\n} from '@apollo/client'\nimport { getDataFromTree } from '@apollo/client/react/ssr'\nexport { gql } from '@apollo/client'\nimport { createContext, ReactNode, useContext } from 'react'\nimport { KeyUtils } from 'slate'\nimport uuid from 'uuid/v4'\n\nimport { DocumentReference, RuntimeProvider } from '../react'\nimport { createDocumentReference, Element } from '../state/react-page'\n\nconst typePolicies: TypePolicies = {\n Query: {\n fields: {\n swatches(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'Swatch', id }, true))\n )\n },\n file(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'File', id: args?.id }, true)\n },\n files(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'File', id }, true))\n )\n },\n typographies(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'Typography', id }, true))\n )\n },\n pagePathnamesById(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'PagePathnameSlice', id }, true))\n )\n },\n globalElement(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'GlobalElement', id: args?.id }, true)\n },\n table(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Table', id: args?.id }, true)\n },\n page(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Page', id: args?.id }, true)\n },\n site(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Site', id: args?.id }, true)\n },\n },\n },\n}\n\nconst PrefetchContext = createContext(false)\n\nexport function useIsPrefetching(): boolean {\n return useContext(PrefetchContext)\n}\n\ntype CreateApolloClientParams = {\n uri?: string\n cacheData?: NormalizedCacheObject\n}\n\nexport function createApolloClient({ uri, cacheData }: CreateApolloClientParams) {\n const cache = new InMemoryCache({ typePolicies })\n\n if (cacheData) cache.restore(cacheData)\n\n return new ApolloClient({ uri, cache })\n}\n\nexport type MakeswiftClientOptions = {\n uri?: string\n cacheData?: NormalizedCacheObject\n}\n\nexport class MakeswiftClient {\n apolloClient: ApolloClient<NormalizedCacheObject>\n\n constructor({ uri, cacheData }: MakeswiftClientOptions) {\n this.apolloClient = createApolloClient({ uri, cacheData })\n }\n\n async prefetch(element: Element): Promise<NormalizedCacheObject> {\n const id = uuid()\n\n await getDataFromTree(\n <PrefetchContext.Provider value={true}>\n <RuntimeProvider client={this} rootElements={new Map([[id, element]])}>\n <DocumentReference documentReference={createDocumentReference(id)} />\n </RuntimeProvider>\n </PrefetchContext.Provider>,\n )\n\n KeyUtils.resetGenerator()\n\n return this.apolloClient.cache.extract()\n }\n\n updateCacheData(cacheData: NormalizedCacheObject): void {\n this.apolloClient.cache.restore(cacheData)\n }\n}\n\nconst Context = createContext<MakeswiftClient | undefined>(undefined)\n\nexport function useQuery<TData = any, TVariables = OperationVariables>(\n query: DocumentNode | TypedDocumentNode<TData, TVariables>,\n options?: QueryHookOptions<TData, TVariables>,\n): QueryResult<TData, TVariables> {\n const client = useContext(Context)\n\n return useApolloQuery(query, { client: client?.apolloClient, ...options })\n}\n\nexport function useMutation<\n TData = any,\n TVariables = OperationVariables,\n TContext = DefaultContext,\n TCache extends ApolloCache<any> = ApolloCache<any>,\n>(\n mutation: DocumentNode | TypedDocumentNode<TData, TVariables>,\n options?: MutationHookOptions<TData, TVariables, TContext>,\n): MutationTuple<TData, TVariables, TContext, TCache> {\n const client = useContext(Context)\n\n return useApolloMutation(mutation, { client: client?.apolloClient, ...options })\n}\n\ntype MakeswiftProviderProps = {\n client: MakeswiftClient\n children: ReactNode\n}\n\nexport function MakeswiftProvider({ client, children }: MakeswiftProviderProps) {\n return <Context.Provider value={client}>{children}</Context.Provider>\n}\n","import { useMemo } from 'react'\n\nimport { ColorValue as Color } from '../utils/types'\nimport { ResponsiveValue } from '../../prop-controllers'\nimport { FILES_BY_ID, SWATCHES_BY_ID } from '../utils/queries'\nimport { isNonNullable } from '../utils/isNonNullable'\nimport { BackgroundsValue as ResponsiveBackgroundsValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\ntype BackgroundColorData = Color\n\ntype BackgroundGradientStopData = {\n id: string\n location: number\n color: Color | null | undefined\n}\n\ntype BackgroundGradientData = {\n angle: number\n isRadial: boolean\n stops: Array<BackgroundGradientStopData>\n}\n\ntype BackgroundImageData = {\n publicUrl?: string\n dimensions: { width: number; height: number } | null\n position: {\n x: number\n y: number\n }\n size: 'cover' | 'contain' | 'auto'\n repeat: 'no-repeat' | 'repeat-x' | 'repeat-y' | 'repeat'\n opacity?: number\n parallax?: number\n}\n\ntype BackgroundVideoData = {\n url: string\n maskColor: Color | null | undefined\n aspectRatio: 'wide' | 'standard'\n opacity: number\n zoom: number\n parallax: number\n}\n\ntype BackgroundData =\n | { id: string; type: 'color'; payload: BackgroundColorData | null | undefined }\n | { id: string; type: 'image'; payload: BackgroundImageData | null | undefined }\n | { id: string; type: 'gradient'; payload: BackgroundGradientData | null | undefined }\n | { id: string; type: 'video'; payload: BackgroundVideoData | null | undefined }\n\ntype BackgroundsData = Array<BackgroundData>\n\nexport type BackgroundsPropControllerData = ResponsiveValue<BackgroundsData>\n\nexport function useBackgrounds(\n value: ResponsiveBackgroundsValue | null | undefined,\n): BackgroundsPropControllerData | null | undefined {\n const fileIds =\n value == null\n ? []\n : value\n .map(({ value: backgrounds }) =>\n backgrounds\n .map(background =>\n background.type === 'image' && background.payload != null\n ? background.payload.imageId\n : null,\n )\n .filter(isNonNullable)\n .reduce((a, b) => a.concat(b), [] as string[]),\n )\n .reduce((a, b) => a.concat(b), [])\n const swatchIds =\n value == null\n ? []\n : value\n .map(({ value: backgrounds }) =>\n backgrounds\n .map(background => {\n if (background.type === 'color' && background.payload != null) {\n return [background.payload.swatchId]\n }\n\n if (background.type === 'gradient' && background.payload != null) {\n return background.payload.stops\n .map(stop => stop.color && stop.color.swatchId)\n .filter(isNonNullable)\n }\n\n if (background.type === 'video' && background.payload != null) {\n return [background.payload.maskColor && background.payload.maskColor.swatchId]\n }\n\n return null\n })\n .filter(isNonNullable)\n .reduce((a, b) => a.concat(b), []),\n )\n .reduce((a, b) => a.concat(b), [])\n .filter(isNonNullable)\n const skip = value == null\n const filesResult = useQuery(FILES_BY_ID, {\n skip: skip || fileIds.length === 0,\n variables: { ids: fileIds },\n })\n const swatchesResult = useQuery(SWATCHES_BY_ID, {\n skip: skip || swatchIds.length === 0,\n variables: { ids: swatchIds },\n })\n\n return useMemo(() => {\n const { data: filesData = {} } = filesResult\n const { data: swatchesData = {} } = swatchesResult\n\n if (value == null || filesResult.error != null || swatchesResult.error != null) {\n return null\n }\n\n const { files = [] } = filesData\n const { swatches = [] } = swatchesData\n\n return value.map(({ value: backgrounds, ...restOfValue }) => ({\n ...restOfValue,\n value: backgrounds\n .map(bg => {\n if (bg.type === 'image' && bg.payload != null && bg.payload.imageId != null) {\n const { imageId, ...restOfPayload } = bg.payload\n const file = files.find((f: any) => f && f.id === imageId)\n\n return (\n file && {\n id: bg.id,\n type: 'image',\n payload: {\n ...restOfPayload,\n publicUrl: file.publicUrl,\n dimensions: file.dimensions,\n },\n }\n )\n }\n\n if (bg.type === 'color' && bg.payload != null) {\n const { swatchId, alpha } = bg.payload\n const swatch = swatches.find((s: any) => s && s.id === swatchId)\n\n return { id: bg.id, type: 'color', payload: { swatch, alpha } }\n }\n\n if (bg.type === 'gradient' && bg.payload != null && bg.payload.stops.length > 0) {\n return {\n id: bg.id,\n type: 'gradient',\n payload: {\n angle: bg.payload.angle,\n isRadial: bg.payload.isRadial,\n stops: bg.payload.stops.map(({ color, ...restOfStop }) => ({\n ...restOfStop,\n color: color && {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n },\n })),\n },\n }\n }\n\n if (bg.type === 'video' && bg.payload != null) {\n const { maskColor, ...restOfPayload } = bg.payload\n const swatch = maskColor && swatches.find((s: any) => s && s.id === maskColor.swatchId)\n\n return {\n id: bg.id,\n type: 'video',\n payload: {\n ...restOfPayload,\n maskColor: swatch && maskColor && { swatch, alpha: maskColor.alpha },\n },\n }\n }\n\n return null\n })\n .filter(Boolean),\n }))\n }, [filesResult, swatchesResult, value])\n}\n","import { BorderStyleProperty } from 'csstype'\n\nimport { isNonNullable } from '../utils/isNonNullable'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport type { ColorValue as Color } from '../utils/types'\nimport { ResponsiveValue } from '../../prop-controllers'\nimport { BorderValue as ResponsiveBorderValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\nfunction mapSideColor(swatches: any, { color, ...restOfSide }: any) {\n return {\n ...restOfSide,\n color: color && {\n alpha: color.alpha,\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n },\n }\n}\n\nexport type BorderSide = {\n width: number | null | undefined\n style: BorderStyleProperty\n color: Color | null | undefined\n}\n\ntype BorderData = {\n borderTop: BorderSide | null | undefined\n borderRight: BorderSide | null | undefined\n borderBottom: BorderSide | null | undefined\n borderLeft: BorderSide | null | undefined\n}\n\nexport type BorderPropControllerData = ResponsiveValue<BorderData>\n\nexport function useBorder(\n value: ResponsiveBorderValue | null | undefined,\n): BorderPropControllerData | null | undefined {\n const swatchIds =\n value == null\n ? []\n : [\n ...Array.from(\n new Set(\n value\n .map(({ value: { borderTop, borderLeft, borderBottom, borderRight } }) => [\n borderTop && borderTop.color && borderTop.color.swatchId,\n borderBottom && borderBottom.color && borderBottom.color.swatchId,\n borderLeft && borderLeft.color && borderLeft.color.swatchId,\n borderRight && borderRight.color && borderRight.color.swatchId,\n ])\n .reduce((a, b) => a.concat(b))\n .filter(isNonNullable),\n ),\n ),\n ]\n const skip = value == null || swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (value == null || error != null) return null\n\n const { swatches = [] } = data\n\n return value.map(({ value: { borderTop, borderBottom, borderLeft, borderRight }, ...rest }) => ({\n ...rest,\n value: {\n borderTop: borderTop && mapSideColor(swatches, borderTop),\n borderBottom: borderBottom && mapSideColor(swatches, borderBottom),\n borderLeft: borderLeft && mapSideColor(swatches, borderLeft),\n borderRight: borderRight && mapSideColor(swatches, borderRight),\n },\n }))\n}\n","import { isNonNullable } from '../utils/isNonNullable'\nimport type { ColorValue as Color } from '../utils/types'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport type { ResponsiveValue } from '../../prop-controllers'\nimport type { ShadowsValue as ResponsiveShadowsValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\ntype ShadowData = {\n id: string\n payload: {\n inset: boolean\n offsetX: number\n offsetY: number\n blurRadius: number\n spreadRadius: number\n color: Color | null | undefined\n }\n}\n\nconst ShadowDefaultValue = {\n inset: false,\n offsetX: 0,\n offsetY: 2,\n blurRadius: 4,\n spreadRadius: 0,\n color: null,\n} as const\n\nexport type BoxShadowData = Array<ShadowData>\n\nexport type BoxShadowPropControllerData = ResponsiveValue<BoxShadowData>\n\nexport function useBoxShadow(\n value: ResponsiveShadowsValue | null | undefined,\n): BoxShadowPropControllerData | null | undefined {\n const swatchIds =\n value == null\n ? []\n : [\n ...Array.from(\n new Set(\n value\n .map(({ value: shadows }) =>\n shadows.map(({ payload: { color } }) => color && color.swatchId),\n )\n .reduce((a, b) => a.concat(b), [])\n .filter(isNonNullable),\n ),\n ),\n ]\n\n const skip = value == null || swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (value == null || error != null) return null\n\n const { swatches = [] } = data\n\n return value.map(({ value: shadows, ...restOfValue }) => ({\n ...restOfValue,\n value: shadows.map(\n ({\n payload: { color, inset, offsetX, offsetY, blurRadius, spreadRadius },\n ...restOfShadow\n }) => ({\n ...restOfShadow,\n payload: {\n color:\n color != null\n ? {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n }\n : null,\n inset: inset ?? ShadowDefaultValue.inset,\n offsetX: offsetX ?? ShadowDefaultValue.offsetX,\n offsetY: offsetY ?? ShadowDefaultValue.offsetY,\n blurRadius: blurRadius ?? ShadowDefaultValue.blurRadius,\n spreadRadius: spreadRadius ?? ShadowDefaultValue.spreadRadius,\n },\n }),\n ),\n }))\n}\n","import type { ResponsiveValue } from '../../prop-controllers'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport { isNonNullable } from '../utils/isNonNullable'\nimport type { ColorValue as Color } from '../utils/types'\nimport { useQuery } from '../../api/react'\n\nexport function useResponsiveColor(\n color:\n | ResponsiveValue<{\n swatchId: string\n alpha: number\n }>\n | null\n | undefined,\n): ResponsiveValue<Color> | null | undefined {\n const swatchIds =\n color == null\n ? []\n : [...Array.from(new Set(color.map(({ value: v }) => v && v.swatchId).filter(isNonNullable)))]\n const skip = swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (color == null || error != null) return null\n\n const { swatches = [] } = data\n\n return color\n .map(({ value: v, ...rest }) => {\n const { swatchId, alpha } = v\n const swatch = swatches.find((s: any) => s && s.id === swatchId)\n\n return swatch == null ? null : { ...rest, value: { swatch, alpha } }\n })\n .filter(isNonNullable)\n}\n","import { useQuery } from '../../api/react'\nimport { FILE_BY_ID } from '../utils/queries'\n\ntype File = {\n id: string\n name: string\n publicUrl: string\n extension: string\n dimensions: { width: number; height: number } | null\n}\n\nexport function useFile(fileId: string | null | undefined): File | null | undefined {\n const { error, data = {} } = useQuery(FILE_BY_ID, {\n skip: fileId == null,\n variables: { id: fileId },\n })\n\n if (fileId == null || error != null) return null\n\n return data.file\n}\n","const keys = <O extends { [key: string]: unknown }>(o: O): (keyof O)[] => Object.keys(o)\n\nexport default keys\n","const coalesce = <T>(...args: Array<T>): T => {\n let i: number\n\n for (i = 0; i < args.length - 1; i += 1) {\n if (args[i] != null) return args[i]\n }\n\n return args[i]\n}\n\nexport default coalesce\n","import keys from './keys'\nimport coalesce from './coalesce'\n\nexport default function shallowMerge<\n A extends Record<string, unknown>,\n B extends Record<string, unknown>,\n>(a: A, b: B): A & B {\n const bKeys = keys(b)\n const merged = { ...a } as A & B\n\n bKeys.forEach(key => {\n // @ts-expect-error: `coalesce` returns `null | undefined` regardless of input guarantees.\n merged[key] = coalesce(merged[key], b[key])\n })\n\n return merged\n}\n","import type { Device as DeviceID, DeviceOverride, ResponsiveValue } from '../../prop-controllers'\nimport shallowMerge from '../../utils/shallowMerge'\n\nexport type Device = {\n id: DeviceID\n minWidth?: number\n maxWidth?: number\n}\n\nexport const DEVICES: Array<Device> = [\n { id: 'desktop', minWidth: 769 },\n { id: 'tablet', minWidth: 576, maxWidth: 768 },\n { id: 'mobile', maxWidth: 575 },\n]\n\nexport const getDevice = (deviceId: DeviceID): Device => {\n const device = DEVICES.find(({ id }) => id === deviceId)\n\n if (device == null) throw new Error(`Unrecognized device ID: \"${deviceId}\".`)\n\n return device\n}\n\nexport type FallbackStrategy<V> = (\n arg0: DeviceOverride<V> | undefined,\n arg1: ResponsiveValue<V>,\n) => DeviceOverride<V> | undefined\n\nfunction defaultStrategy<V>(\n value: DeviceOverride<V> | undefined,\n fallbacks: ResponsiveValue<V>,\n): DeviceOverride<V> | undefined {\n return value || fallbacks[0]\n}\n\nexport function shallowMergeFallbacks<V extends Record<string, unknown>>(\n value: DeviceOverride<V> | undefined,\n fallbacks: ResponsiveValue<V>,\n): DeviceOverride<V> | undefined {\n return [value, ...fallbacks]\n .filter((override): override is DeviceOverride<V> => Boolean(override))\n .reduce((a, b) => ({\n deviceId: a.deviceId || b.deviceId,\n value: shallowMerge(a.value, b.value),\n }))\n}\n\nexport function findDeviceOverride<S>(\n values: ResponsiveValue<S> = [],\n deviceId: string,\n strategy: FallbackStrategy<S> = defaultStrategy,\n): DeviceOverride<S> | undefined {\n const value = values.find(({ deviceId: d }) => d === deviceId)\n const fallbacks = DEVICES.slice(0, DEVICES.findIndex(d => d.id === deviceId) + 1)\n .reverse()\n .map(d => values.find(v => v.deviceId === d.id))\n .filter((override): override is DeviceOverride<S> => Boolean(override))\n\n return value != null || fallbacks.length > 0 ? strategy(value, fallbacks) : undefined\n}\n\nexport type ExtractResponsiveValue<T> = T extends ResponsiveValue<infer V> ? V : never\n\nexport function join<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>, R>(\n responsiveValues: A,\n joinFn: (values: { [I in keyof A]: ExtractResponsiveValue<A[I]> | undefined }) => R,\n strategy?: FallbackStrategy<V>,\n): ResponsiveValue<R> {\n return DEVICES.map(({ id }) => id)\n .map(deviceId => {\n const value = joinFn(\n responsiveValues.map(responsiveValue => {\n const deviceValue =\n responsiveValue && findDeviceOverride(responsiveValue, deviceId, strategy)\n\n return deviceValue == null ? undefined : deviceValue.value\n }) as unknown as { [I in keyof A]: ExtractResponsiveValue<A[I] | undefined> },\n )\n\n if (value == null) return null\n\n return { deviceId, value }\n })\n .filter((override): override is DeviceOverride<R> => Boolean(override))\n}\n\nexport const getDeviceMediaQuery = (device: Device): string => {\n const parts = ['@media only screen']\n\n if (device.minWidth != null) {\n parts.push(`(min-width: ${device.minWidth}px)`)\n }\n\n if (device.maxWidth != null) {\n parts.push(`(max-width: ${device.maxWidth}px)`)\n }\n\n return parts.join(' and ')\n}\n","/* eslint-env browser */\n\nimport { useState, useLayoutEffect } from 'react'\n\nimport { DeviceOverride } from '../../prop-controllers'\nimport { DEVICES, findDeviceOverride, getDeviceMediaQuery } from '../utils/devices'\n\nexport function useMediaQuery<S>(responsiveValue?: Array<DeviceOverride<S>>): S | void {\n const [deviceId, setDeviceId] = useState(DEVICES[0].id)\n const { value } = findDeviceOverride(responsiveValue, deviceId) || {}\n\n useLayoutEffect(() => {\n if (responsiveValue == null || window == null) return () => {}\n\n const cleanUpFns = DEVICES.map(device => {\n const mediaQueryList = window.matchMedia(getDeviceMediaQuery(device).replace('@media', ''))\n\n const listener = () => {\n if (mediaQueryList.matches) setDeviceId(device.id)\n }\n\n listener()\n mediaQueryList.addListener(listener)\n\n return () => mediaQueryList.removeListener(listener)\n })\n\n return () => cleanUpFns.forEach(fn => fn())\n })\n\n return value\n}\n","import { useQuery } from '../../api/react'\nimport { PAGE_PATHNAMES_BY_ID } from '../utils/queries'\n\ntype Page = {\n id: string\n pathname: string\n}\n\nexport function usePage(pageId: string | null | undefined): Page | null | undefined {\n const { error, data = {} } = useQuery(PAGE_PATHNAMES_BY_ID, {\n skip: pageId == null,\n variables: { ids: [pageId] },\n })\n\n if (pageId == null || error != null) return null\n\n const { pagePathnamesById: [page] = [] } = data\n\n return page\n}\n","import { useQuery } from '../../api/react'\nimport { TABLE_BY_ID } from '../utils/queries'\n\nexport type SingleLineTextTableColumn = {\n id: string\n name: string\n __typename: 'SingleLineTextTableColumn'\n}\n\nexport type LongTextTableColumn = {\n id: string\n name: string\n __typename: 'LongTextTableColumn'\n}\n\nexport type CheckboxTableColumn = {\n id: string\n name: string\n __typename: 'CheckboxTableColumn'\n}\n\nexport type MultipleSelectTableColumnOption = {\n id: string\n name: string\n}\n\nexport type MultipleSelectTableColumn = {\n id: string\n name: string\n options: Array<MultipleSelectTableColumnOption>\n __typename: 'MultipleSelectTableColumn'\n}\n\nexport type SingleSelectTableColumnOption = {\n id: string\n name: string\n}\n\nexport type SingleSelectTableColumn = {\n id: string\n name: string\n options: Array<SingleSelectTableColumnOption>\n __typename: 'SingleSelectTableColumn'\n}\n\nexport type PhoneNumberTableColumn = {\n id: string\n name: string\n __typename: 'PhoneNumberTableColumn'\n}\n\nexport type EmailTableColumn = {\n id: string\n name: string\n __typename: 'EmailTableColumn'\n}\n\nexport type URLTableColumn = {\n id: string\n name: string\n __typename: 'URLTableColumn'\n}\n\nexport type NumberTableColumn = {\n id: string\n name: string\n __typename: 'NumberTableColumn'\n}\n\nexport type TableColumn =\n | SingleLineTextTableColumn\n | LongTextTableColumn\n | CheckboxTableColumn\n | MultipleSelectTableColumn\n | SingleSelectTableColumn\n | PhoneNumberTableColumn\n | EmailTableColumn\n | URLTableColumn\n | NumberTableColumn\n\ntype Table = {\n id: string\n name: string\n columns: Array<TableColumn>\n}\n\nexport function useTable(tableId: string | null | undefined) {\n return useQuery<{ table: Table | null }>(TABLE_BY_ID, {\n skip: tableId == null,\n variables: { id: tableId },\n })\n}\n","import {\n TargetAndTransition,\n Transition,\n useAnimation,\n useReducedMotion,\n Variants,\n MotionProps,\n} from 'framer-motion'\nimport { TransitionMap } from 'framer-motion/types/types'\nimport { useCallback, useEffect, useState } from 'react'\n\nimport { ResponsiveValue } from '../../../prop-controllers'\nimport { useMediaQuery } from '../../hooks'\nimport { Element } from '../../../state/react-page'\n\nexport type BoxAnimateIn =\n | 'none'\n | 'fadeIn'\n | 'fadeUp'\n | 'fadeDown'\n | 'fadeLeft'\n | 'fadeRight'\n | 'blurIn'\n | 'scaleUp'\n | 'scaleDown'\n\nconst defaultExitedProps = {\n opacity: 0,\n x: 0,\n y: 0,\n scale: 1,\n}\n\ntype BoxAnimationVariants = {\n entered: TargetAndTransition\n exited: TargetAndTransition\n}\n\nexport const boxAnimations: {\n [key in BoxAnimateIn]: {\n transition: TransitionMap\n } & BoxAnimationVariants\n} = {\n none: {\n entered: {\n opacity: 1,\n },\n exited: {\n ...defaultExitedProps,\n opacity: 1,\n },\n transition: {},\n },\n fadeIn: {\n exited: defaultExitedProps,\n entered: {\n opacity: 1,\n },\n transition: {},\n },\n fadeLeft: {\n exited: {\n ...defaultExitedProps,\n x: 60,\n },\n entered: {\n opacity: 1,\n x: 0,\n },\n transition: {\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeRight: {\n exited: {\n ...defaultExitedProps,\n x: -60,\n },\n entered: {\n opacity: 1,\n x: 0,\n },\n transition: {\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeUp: {\n exited: {\n ...defaultExitedProps,\n y: 80,\n },\n entered: {\n opacity: 1,\n y: 0,\n },\n transition: {\n y: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeDown: {\n exited: {\n ...defaultExitedProps,\n y: -80,\n },\n entered: {\n opacity: 1,\n y: 0,\n },\n transition: {\n y: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n blurIn: {\n exited: {\n ...defaultExitedProps,\n filter: 'blur(20px)',\n },\n entered: {\n opacity: 1,\n filter: 'blur(0px)',\n },\n transition: {},\n },\n scaleDown: {\n exited: {\n ...defaultExitedProps,\n scale: 1.2,\n },\n entered: {\n opacity: 1,\n scale: 1,\n },\n transition: {\n scale: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n scaleUp: {\n exited: {\n ...defaultExitedProps,\n scale: 0.75,\n },\n entered: {\n opacity: 1,\n scale: 1,\n },\n transition: {\n scale: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n}\n\nconst mergeCustomTransitionWithDefault = (\n transitions: TransitionMap,\n props: Transition,\n): TransitionMap | Transition =>\n transitions\n ? Object.keys(transitions).reduce(\n (a, c) => ({\n ...a,\n [c]: {\n ...transitions[c as string],\n ...props,\n },\n }),\n props,\n )\n : props\n\nexport type BoxAnimationType = {\n containerAnimationProps: {\n transition: Transition\n variants: Variants\n }\n parentAnimationProps: {\n transition: Transition\n }\n childAnimationProps: {\n transition: Transition\n variants: Variants\n }\n}\n\nconst useElementOnScreen = (element: HTMLElement | null, options: IntersectionObserverInit) => {\n const [isVisible, setIsVisible] = useState(false)\n\n useEffect(() => {\n const observer = new IntersectionObserver(intersectionCallback, options)\n\n if (element) observer.observe(element)\n\n return () => {\n if (element) observer.unobserve(element)\n }\n\n function intersectionCallback([entry]: IntersectionObserverEntry[]) {\n if (entry?.isIntersecting) {\n setIsVisible(true)\n }\n }\n }, [element, options])\n\n return isVisible\n}\n\nexport const DEFAULT_BOX_ANIMATE_TYPE = 'none'\nexport const DEFAULT_BOX_ANIMATE_DELAY = 0.0\nexport const DEFAULT_BOX_ANIMATE_DURATION = 0.75\nexport const DEFAULT_ITEM_ANIMATE_TYPE = 'none'\nexport const DEFAULT_ITEM_ANIMATE_DELAY = 0.0\nexport const DEFAULT_ITEM_ANIMATE_DURATION = 0.75\nexport const DEFAULT_ITEM_STAGGER_DURATION = 0.0\n\ntype UseBoxAnimationsPayload = {\n initial?: { container: MotionProps['initial']; parent: MotionProps['initial'] }\n animate?: { container: MotionProps['animate']; parent: MotionProps['animate'] }\n variants?: { container: MotionProps['variants']; child: MotionProps['variants'] }\n transition?: {\n container: MotionProps['transition']\n parent: MotionProps['transition']\n child: MotionProps['transition']\n }\n key?: { container: string }\n}\n\nexport const useBoxAnimations = ({\n boxElement,\n elements,\n ...props\n}: {\n boxAnimateType: ResponsiveValue<BoxAnimateIn> | undefined\n boxAnimateDuration: ResponsiveValue<number> | undefined\n boxAnimateDelay: ResponsiveValue<number> | undefined\n itemAnimateType: ResponsiveValue<BoxAnimateIn> | undefined\n itemAnimateDuration: ResponsiveValue<number> | undefined\n itemAnimateDelay: ResponsiveValue<number> | undefined\n itemStaggerDuration: ResponsiveValue<number> | undefined\n boxElement: HTMLElement | null\n elements: Element[] | undefined\n}): UseBoxAnimationsPayload => {\n const reducedMotion = useReducedMotion()\n const boxAnimateType = useMediaQuery(props.boxAnimateType) || DEFAULT_BOX_ANIMATE_TYPE\n const boxAnimateDuration = useMediaQuery(props.boxAnimateDuration) || DEFAULT_BOX_ANIMATE_DURATION\n const boxAnimateDelay = useMediaQuery(props.boxAnimateDelay) || DEFAULT_BOX_ANIMATE_DELAY\n const itemAnimateType = useMediaQuery(props.itemAnimateType) || DEFAULT_ITEM_ANIMATE_TYPE\n const itemAnimateDuration =\n useMediaQuery(props.itemAnimateDuration) || DEFAULT_ITEM_ANIMATE_DURATION\n const itemAnimateDelay = useMediaQuery(props.itemAnimateDelay) || DEFAULT_ITEM_ANIMATE_DELAY\n const itemStaggerDuration =\n useMediaQuery(props.itemStaggerDuration) || DEFAULT_ITEM_STAGGER_DURATION\n\n const isBoxVisible = useElementOnScreen(boxElement, {\n root: null,\n rootMargin: `0px 0px -10% 0px`,\n threshold: 0.2,\n })\n\n const itemControls = useAnimation()\n const boxControls = useAnimation()\n\n const setSequence = useCallback(\n (variant: keyof BoxAnimationVariants) => {\n boxControls.stop()\n itemControls.stop()\n boxControls.set(variant)\n itemControls.set(variant)\n },\n [boxControls, itemControls],\n )\n\n const playSequence = useCallback(() => {\n boxControls.stop()\n itemControls.stop()\n boxControls.set('exited')\n itemControls.set('exited')\n boxControls.start('entered')\n itemControls.start('entered')\n }, [boxControls, itemControls])\n\n useEffect(() => {\n if (isBoxVisible) {\n setSequence('entered')\n }\n }, [\n elements\n ?.map(e => e.key)\n .sort()\n .join(),\n setSequence,\n ])\n\n useEffect(() => {\n if (isBoxVisible) {\n playSequence()\n }\n }, [\n isBoxVisible,\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemAnimateDelay,\n itemStaggerDuration,\n reducedMotion,\n playSequence,\n ])\n\n const boxVariant = boxAnimations[boxAnimateType]\n const itemVariant = boxAnimations[itemAnimateType]\n\n return {\n initial: {\n container: reducedMotion ? 'entered' : 'exited',\n parent: reducedMotion ? 'entered' : 'exited',\n },\n animate: {\n container: reducedMotion ? undefined : boxControls,\n parent: reducedMotion ? undefined : itemControls,\n },\n variants: {\n container: {\n exited: boxVariant.exited,\n entered: boxVariant.entered,\n },\n child: {\n exited: itemVariant.exited,\n entered: itemVariant.entered,\n },\n },\n transition: {\n container: mergeCustomTransitionWithDefault(boxVariant.transition, {\n delay: boxAnimateDelay,\n duration: boxAnimateDuration,\n }),\n parent: {\n delayChildren: itemAnimateDelay,\n staggerChildren: itemStaggerDuration,\n duration: itemAnimateDuration,\n },\n child: mergeCustomTransitionWithDefault(itemVariant.transition, {\n duration: itemAnimateDuration,\n }),\n },\n key: {\n container:\n boxAnimateType +\n boxAnimateDuration +\n boxAnimateDelay +\n itemAnimateType +\n itemAnimateDuration +\n itemAnimateDelay +\n itemStaggerDuration +\n reducedMotion,\n },\n }\n}\n","export const getIndexes = (spans: Array<Array<number>>, index: number): [number, number] => {\n const flattened = spans.reduce((a, s) => a.concat(s), [])\n\n if (index < 0 || index > flattened.length) throw new RangeError()\n\n let remainder = index\n let rowIndex = 0\n\n while (rowIndex < spans.length - 1 && remainder >= spans[rowIndex].length) {\n remainder -= spans[rowIndex].length\n rowIndex += 1\n }\n\n return [rowIndex, remainder]\n}\n","import type { ColorValue as Color } from './types'\n\nexport function colorToString(color?: Color): string {\n return color && color.swatch\n ? `hsla(${color.swatch.hue},${color.swatch.saturation}%,${color.swatch.lightness}%,${color.alpha})`\n : ''\n}\n","import { css, CSSObject } from 'styled-components'\nimport {\n WidthProperty,\n MarginProperty,\n MarginTopProperty,\n MarginRightProperty,\n MarginBottomProperty,\n MarginLeftProperty,\n PaddingProperty,\n PaddingTopProperty,\n PaddingRightProperty,\n PaddingBottomProperty,\n PaddingLeftProperty,\n BorderRadiusProperty,\n BorderTopLeftRadiusProperty,\n BorderTopRightRadiusProperty,\n BorderBottomLeftRadiusProperty,\n BorderBottomRightRadiusProperty,\n} from 'csstype'\n\nimport {\n ResponsiveValue,\n ResponsiveValueType as ExtractResponsiveValue,\n Length as LengthValue,\n} from '../../prop-controllers'\nimport {\n FallbackStrategy,\n getDevice,\n getDeviceMediaQuery,\n join as joinResponsiveValues,\n} from './devices'\nimport { getIndexes } from './columns'\nimport {\n BorderRadiusValue,\n MarginValue,\n PaddingValue,\n TextStyleValue,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport { colorToString } from './colorToString'\nimport {\n BorderSide,\n BorderPropControllerData,\n BoxShadowData,\n BoxShadowPropControllerData,\n} from '../hooks'\n\ntype CSSRules = ReturnType<typeof css>\n\nexport function cssMediaRules<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>, P>(\n responsiveValues: A | ((props: P) => A),\n join: (values: { [K in keyof A]: ExtractResponsiveValue<A[K]> | undefined }) =>\n | CSSRules\n | CSSObject,\n strategy?: FallbackStrategy<V>,\n): (props: P) => CSSRules {\n return props =>\n joinResponsiveValues(\n typeof responsiveValues === 'function' ? responsiveValues(props) : responsiveValues,\n join,\n strategy,\n ).reduce((acc, { deviceId, value }) => {\n const device = getDevice(deviceId)\n const mediaQuery = getDeviceMediaQuery(device)\n\n return css`\n ${acc}${mediaQuery} {\n ${value}\n }\n `\n }, css`` as CSSRules)\n}\n\nexport function cssWidth(\n defaultValue: LengthValue | WidthProperty<string | number> = '100%',\n): (props: { width?: WidthValue }) => CSSRules {\n return props => css`\n max-width: 100%;\n ${cssMediaRules(\n [props.width] as const,\n ([width = defaultValue]) => css`\n width: ${typeof width === 'object' ? `${width.value}${width.unit}` : width};\n `,\n )}\n `\n}\n\nfunction getMarginSide(marginSide: LengthValue | MarginProperty<string | number>) {\n return typeof marginSide === 'object' ? `${marginSide.value}${marginSide.unit}` : marginSide\n}\n\nexport function cssMargin(\n defaultValue: {\n marginTop?: LengthValue | MarginTopProperty<string | number>\n marginRight?: LengthValue | MarginRightProperty<string | number>\n marginBottom?: LengthValue | MarginBottomProperty<string | number>\n marginLeft?: LengthValue | MarginLeftProperty<string | number>\n } = {},\n): (props: { margin?: MarginValue }) => CSSRules {\n const defaultMarginTop = defaultValue.marginTop === undefined ? 0 : defaultValue.marginTop\n const defaultMarginRight =\n defaultValue.marginRight === undefined ? 'auto' : defaultValue.marginRight\n const defaultMarginBottom =\n defaultValue.marginBottom === undefined ? 0 : defaultValue.marginBottom\n const defaultMarginLeft = defaultValue.marginLeft === undefined ? 'auto' : defaultValue.marginLeft\n\n return props => css`\n ${cssMediaRules(\n [props.margin] as const,\n ([\n {\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n } = {} as ExtractResponsiveValue<MarginValue>,\n ]) => css`\n margin-top: ${getMarginSide(marginTop || defaultMarginTop)};\n margin-right: ${getMarginSide(marginRight || defaultMarginRight)};\n margin-bottom: ${getMarginSide(marginBottom || defaultMarginBottom)};\n margin-left: ${getMarginSide(marginLeft || defaultMarginLeft)};\n `,\n )}\n `\n}\n\nfunction getPaddingSide(paddingSide: LengthValue | PaddingProperty<string | number>) {\n return typeof paddingSide === 'object' ? `${paddingSide.value}${paddingSide.unit}` : paddingSide\n}\n\nexport function cssPadding(\n defaultValue: {\n paddingTop?: LengthValue | PaddingTopProperty<string | number>\n paddingRight?: LengthValue | PaddingRightProperty<string | number>\n paddingBottom?: LengthValue | PaddingBottomProperty<string | number>\n paddingLeft?: LengthValue | PaddingLeftProperty<string | number>\n } = {},\n): (props: { padding?: PaddingValue }) => CSSRules {\n const defaultPaddingTop = defaultValue.paddingTop === undefined ? 0 : defaultValue.paddingTop\n const defaultPaddingRight =\n defaultValue.paddingRight === undefined ? 0 : defaultValue.paddingRight\n const defaultPaddingBottom =\n defaultValue.paddingBottom === undefined ? 0 : defaultValue.paddingBottom\n const defaultPaddingLeft = defaultValue.paddingLeft === undefined ? 0 : defaultValue.paddingLeft\n\n return props => css`\n ${cssMediaRules(\n [props.padding] as const,\n ([\n {\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n } = {} as ExtractResponsiveValue<PaddingValue>,\n ]) => css`\n padding-top: ${getPaddingSide(paddingTop || defaultPaddingTop)};\n padding-right: ${getPaddingSide(paddingRight || defaultPaddingRight)};\n padding-bottom: ${getPaddingSide(paddingBottom || defaultPaddingBottom)};\n padding-left: ${getPaddingSide(paddingLeft || defaultPaddingLeft)};\n `,\n )}\n `\n}\n\nconst defaultBorderSide = { width: 0, style: 'solid', color: null }\n\nconst getBorderSide = ({ width, style, color }: BorderSide) =>\n `${width != null ? width : 0}px ${style} ${color != null ? colorToString(color) : 'black'}`\n\nexport function cssBorder(\n defaultValue: {\n borderTop?: BorderSide\n borderRight?: BorderSide\n borderBottom?: BorderSide\n borderLeft?: BorderSide\n } = {},\n): (props: { border?: BorderPropControllerData | null | undefined }) => CSSRules {\n const defaultBorderTop =\n defaultValue.borderTop === undefined ? defaultBorderSide : defaultValue.borderTop\n const defaultBorderRight =\n defaultValue.borderRight === undefined ? defaultBorderSide : defaultValue.borderRight\n const defaultBorderBottom =\n defaultValue.borderBottom === undefined ? defaultBorderSide : defaultValue.borderBottom\n const defaultBorderLeft =\n defaultValue.borderLeft === undefined ? defaultBorderSide : defaultValue.borderLeft\n\n return props => css`\n ${cssMediaRules(\n [props.border] as const,\n ([\n {\n borderTop,\n borderRight,\n borderBottom,\n borderLeft,\n } = {} as ExtractResponsiveValue<BorderPropControllerData>,\n ]) => css`\n border-top: ${getBorderSide(borderTop || defaultBorderTop)};\n border-right: ${getBorderSide(borderRight || defaultBorderRight)};\n border-bottom: ${getBorderSide(borderBottom || defaultBorderBottom)};\n border-left: ${getBorderSide(borderLeft || defaultBorderLeft)};\n `,\n )}\n `\n}\n\nfunction getBorderRadiusCorner(\n borderRadiusCorner: LengthValue | BorderRadiusProperty<string | number>,\n) {\n return typeof borderRadiusCorner === 'object'\n ? `${borderRadiusCorner.value}${borderRadiusCorner.unit}`\n : borderRadiusCorner\n}\n\nexport function cssBorderRadius(\n defaultValue: {\n borderTopLeftRadius?: LengthValue | BorderTopLeftRadiusProperty<string | number>\n borderTopRightRadius?: LengthValue | BorderTopRightRadiusProperty<string | number>\n borderBottomLeftRadius?: LengthValue | BorderBottomLeftRadiusProperty<string | number>\n borderBottomRightRadius?: LengthValue | BorderBottomRightRadiusProperty<string | number>\n } = {},\n): (props: { borderRadius?: BorderRadiusValue }) => CSSRules {\n const defaultBorderTopLeftRadius =\n defaultValue.borderTopLeftRadius === undefined ? 0 : defaultValue.borderTopLeftRadius\n const defaultBorderTopRightRadius =\n defaultValue.borderTopRightRadius === undefined ? 0 : defaultValue.borderTopRightRadius\n const defaultPaddingBottom =\n defaultValue.borderBottomLeftRadius === undefined ? 0 : defaultValue.borderBottomLeftRadius\n const defaultPaddingLeft =\n defaultValue.borderBottomRightRadius === undefined ? 0 : defaultValue.borderBottomRightRadius\n\n return props => css`\n ${cssMediaRules(\n [props.borderRadius] as const,\n ([\n {\n borderTopLeftRadius,\n borderTopRightRadius,\n borderBottomLeftRadius,\n borderBottomRightRadius,\n } = {} as ExtractResponsiveValue<BorderRadiusValue>,\n ]) => css`\n border-top-left-radius: ${getBorderRadiusCorner(\n borderTopLeftRadius || defaultBorderTopLeftRadius,\n )};\n border-top-right-radius: ${getBorderRadiusCorner(\n borderTopRightRadius || defaultBorderTopRightRadius,\n )};\n border-bottom-left-radius: ${getBorderRadiusCorner(\n borderBottomLeftRadius || defaultPaddingBottom,\n )};\n border-bottom-right-radius: ${getBorderRadiusCorner(\n borderBottomRightRadius || defaultPaddingLeft,\n )};\n `,\n )}\n `\n}\n\nconst getBoxShadow = (shadows: BoxShadowData) =>\n shadows\n .map(\n ({ payload: { inset, offsetX, offsetY, blurRadius, spreadRadius, color } }) =>\n `${inset ? 'inset ' : ''}${offsetX.toFixed(1)}px ${offsetY.toFixed(\n 1,\n )}px ${blurRadius}px ${spreadRadius}px ${\n color != null ? colorToString(color) : 'rgba(0,0,0,0.2)'\n }`,\n )\n .filter(Boolean)\n .join()\n\nexport function cssBoxShadow(\n defaultValue: BoxShadowData = [],\n): (props: { boxShadow?: BoxShadowPropControllerData | null | undefined }) => CSSRules {\n return props => css`\n ${cssMediaRules(\n [props.boxShadow] as const,\n ([boxShadow = defaultValue]) => css`\n box-shadow: ${getBoxShadow(boxShadow)};\n `,\n )}\n `\n}\n\nconst floor =\n (d: number) =>\n (v: number): number =>\n Math.floor(10 ** d * v) / 10 ** d\n\nexport function cssGridItem(): (props: {\n grid: ResponsiveValue<{ spans: Array<Array<number>>; count: number }>\n index: number\n columnGap?: ResponsiveValue<LengthValue>\n rowGap?: ResponsiveValue<LengthValue>\n}) => CSSRules {\n return props => css`\n display: flex;\n\n /* TODO: A default span of 12 won't work once the column count is modifiable. */\n ${cssMediaRules(\n [props.grid, props.columnGap, props.rowGap] as const,\n ([\n { spans, count } = { spans: [[12]], count: 12 },\n columnGap = { value: 0, unit: 'px' },\n rowGap = { value: 0, unit: 'px' },\n ]) => {\n const [rowIndex, columnIndex] = getIndexes(spans, props.index)\n const firstCol = columnIndex === 0\n const lastCol = columnIndex === spans[rowIndex].length - 1\n const span = spans[rowIndex][columnIndex]\n const fraction = floor(5)(span / count)\n const width = `${fraction} * (100% + ${columnGap.value}${columnGap.unit})`\n const excessWidth = `${Number(firstCol) + Number(lastCol)} * ${columnGap.value}${\n columnGap.unit\n } / 2`\n const iePrecisionError = '0.01px'\n const flexBasis = `calc(${width} - ${excessWidth} - ${iePrecisionError})`\n const firstRow = rowIndex === 0\n const lastRow = rowIndex === spans.length - 1\n\n return span === 0\n ? { display: 'none' }\n : {\n flexBasis,\n minWidth: flexBasis,\n // NOTE: IE11 width breaks without max width\n // https://github.com/philipwalton/flexbugs/issues/3\n maxWidth: flexBasis,\n paddingLeft: firstCol ? 0 : `${columnGap.value / 2}${columnGap.unit}`,\n paddingRight: lastCol ? 0 : `${columnGap.value / 2}${columnGap.unit}`,\n paddingTop: firstRow ? 0 : `${rowGap.value / 2}${rowGap.unit}`,\n paddingBottom: lastRow ? 0 : `${rowGap.value / 2}${rowGap.unit}`,\n }\n },\n )}\n `\n}\n\nexport function cssTextStyle(\n defaultValue: {\n fontFamily?: string | null | undefined\n letterSpacing: number | null | undefined\n fontSize: LengthValue | null | undefined\n fontWeight: number | null | undefined\n textTransform: Array<'uppercase'>\n fontStyle: Array<'italic'>\n } = {\n fontFamily: null,\n letterSpacing: null,\n fontSize: null,\n fontWeight: null,\n textTransform: [],\n fontStyle: [],\n },\n): (arg0: { textStyle?: TextStyleValue | null | undefined }) => CSSRules {\n return props => css`\n ${cssMediaRules([props.textStyle], ([textStyle = defaultValue]) => {\n const {\n fontSize,\n fontWeight,\n fontStyle = [],\n textTransform = [],\n letterSpacing,\n fontFamily,\n } = textStyle\n\n return css`\n ${fontFamily != null\n ? css`\n font-family: '${fontFamily}';\n `\n : ''};\n ${fontWeight != null\n ? css`\n font-weight: ${fontWeight};\n `\n : ''};\n ${letterSpacing != null\n ? css`\n letter-spacing: ${letterSpacing}px;\n `\n : ''};\n ${fontSize != null\n ? css`\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n `\n : ''};\n ${textTransform.includes('uppercase')\n ? css`\n text-transform: uppercase;\n `\n : ''};\n ${fontStyle.includes('italic')\n ? css`\n font-style: italic;\n `\n : ''};\n `\n })}\n `\n}\n","const clamp = (min: number, val: number, max: number): number => Math.min(Math.max(min, val), max)\n\nexport default clamp\n","import { useState, useRef, useLayoutEffect, useCallback, ReactNode, CSSProperties } from 'react'\nimport clamp from '../../../../../utils/clamp'\n\nfunction isScrollable(element: HTMLElement) {\n const { overflow, overflowY, overflowX } =\n element.ownerDocument.defaultView!.getComputedStyle(element)\n\n return /(auto|scroll)/.test(overflow + overflowX + overflowY)\n}\n\nfunction getScrollParent(element: HTMLElement): HTMLElement {\n const { parentElement } = element\n\n if (!element || !parentElement) return element\n\n if (isScrollable(element)) return element\n\n return getScrollParent(parentElement)\n}\n\ntype Props = {\n strength: number | null | undefined\n children: (\n getParallaxProps: <P extends { style?: CSSProperties; [key: string]: unknown }>(props: P) => P,\n ) => ReactNode\n}\n\nexport default function Parallax({ strength, children, ...rest }: Props): JSX.Element {\n const container = useRef<HTMLDivElement>(null)\n const [containerScrollTop, setContainerScrollTop] = useState(strength == null ? 0 : strength)\n const lastScrollParentScrollTop = useRef(0)\n\n useLayoutEffect(() => {\n if (!container.current || strength == null || strength === 0) return undefined\n\n const containerDocument = container.current.ownerDocument\n const scrollParent = getScrollParent(container.current)\n const eventTarget =\n containerDocument.documentElement === scrollParent\n ? containerDocument.defaultView!\n : scrollParent\n\n lastScrollParentScrollTop.current = scrollParent.scrollTop\n setContainerScrollTop(strength)\n\n function handleScroll() {\n containerDocument.defaultView!.requestAnimationFrame(() => {\n if (!container.current) return\n\n const { top: containerTop, bottom: containerBottom } =\n container.current.getBoundingClientRect()\n const { top: scrollParentTop, bottom: scrollParentBottom } =\n scrollParent === containerDocument.documentElement\n ? { top: 0, bottom: containerDocument.defaultView!.innerHeight }\n : scrollParent.getBoundingClientRect()\n const { scrollTop: scrollParentScrollTop } =\n scrollParent === containerDocument.documentElement\n ? { scrollTop: containerDocument.defaultView!.pageYOffset }\n : scrollParent\n const scrollParentHeight = scrollParentBottom - scrollParentTop\n const scrollParentScrollDelta = scrollParentScrollTop - lastScrollParentScrollTop.current\n\n lastScrollParentScrollTop.current = scrollParentScrollTop\n\n setContainerScrollTop(scrollTop => {\n const isContainerVisible =\n containerTop < scrollParentTop + scrollParentHeight && containerBottom > scrollParentTop\n const containerScrollRemaining =\n scrollParentScrollDelta > 0 ? 2 * strength! - scrollTop : scrollTop\n const scrollParentScrollRemaining =\n scrollParentScrollDelta > 0\n ? scrollParentTop + containerBottom\n : scrollParentHeight - containerTop\n const parallaxRatio = containerScrollRemaining / scrollParentScrollRemaining\n const containerScrollDelta = isContainerVisible\n ? parallaxRatio * scrollParentScrollDelta\n : 0\n\n return clamp(0, scrollTop + containerScrollDelta, strength! * 2)\n })\n })\n }\n\n eventTarget.addEventListener('scroll', handleScroll)\n\n return () => eventTarget.removeEventListener('scroll', handleScroll)\n }, [strength])\n\n const getProps = useCallback(\n ({ style, ...restOfChildrenProps }) => ({\n ...restOfChildrenProps,\n style: {\n ...style,\n position: 'absolute',\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n ...(strength == null || strength === 0\n ? {}\n : {\n top: -strength,\n bottom: -strength,\n transform: `translate3d(0, ${containerScrollTop - strength}px, 0)`,\n }),\n },\n }),\n [strength, containerScrollTop],\n )\n\n return (\n <div\n {...rest}\n ref={container}\n style={{ position: 'absolute', top: 0, left: 0, right: 0, bottom: 0 }}\n >\n {children(getProps)}\n </div>\n )\n}\n","import { useState, useLayoutEffect, useRef } from 'react'\nimport ReactPlayer from 'react-player'\nimport styled from 'styled-components'\n\nconst Container = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n pointer-events: none;\n overflow: hidden;\n`\n\nconst Mask = styled.div<{ backgroundColor: string | undefined; visible: boolean }>`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: ${props => props.backgroundColor};\n opacity: ${props => (props.visible ? 1 : 0)};\n transition: opacity 1s;\n`\n\nconst getScale = (element: HTMLElement, aspectRatio: number, zoom: number) => {\n const { offsetWidth: width, offsetHeight: height } = element\n const computedAspectRatio = width / height\n\n return Math.max(aspectRatio / computedAspectRatio, computedAspectRatio / aspectRatio) * zoom\n}\n\ntype Props = {\n url?: string\n aspectRatio?: number\n zoom?: number\n opacity?: number\n maskColor?: string\n}\n\nexport default function BackgroundVideo({\n url = '',\n aspectRatio = 16 / 9,\n zoom = 1,\n maskColor,\n opacity,\n}: Props): JSX.Element {\n const [ready, setReady] = useState(false)\n const [scale, setScale] = useState(1)\n const container = useRef<HTMLDivElement>(null)\n\n useLayoutEffect(() => {\n const { current: containerEl } = container\n\n if (!containerEl) return undefined\n\n const { defaultView } = containerEl.ownerDocument\n const handleResize = () => setScale(getScale(containerEl, aspectRatio, zoom))\n\n handleResize()\n\n defaultView!.addEventListener('resize', handleResize)\n\n return () => defaultView!.removeEventListener('resize', handleResize)\n }, [aspectRatio, zoom])\n\n if (!ReactPlayer.canPlay(url)) return <></>\n\n return (\n <Container ref={container}>\n {container.current && (\n <ReactPlayer\n url={url}\n config={{\n vimeo: { playerOptions: { background: true } },\n youtube: {\n playerVars: {\n origin: container.current.ownerDocument.defaultView?.location.origin,\n },\n },\n wistia: {\n options: {\n endVideoBehavior: 'loop',\n playbackRateControl: false,\n playbar: false,\n playButton: false,\n volumeControl: false,\n fullscreenButton: false,\n muted: true,\n },\n },\n }}\n playing\n loop\n muted\n controls={false}\n onReady={() => setReady(true)}\n style={{\n transform: `scale3d(${scale}, ${scale}, 1)`,\n opacity,\n }}\n width=\"100%\"\n height=\"100%\"\n />\n )}\n <Mask backgroundColor={maskColor} visible={!ready} />\n </Container>\n )\n}\n","import styled, { css } from 'styled-components'\nimport NextImage from 'next/image'\n\nimport { cssMediaRules } from '../../../../utils/cssMediaRules'\nimport { BackgroundsPropControllerData } from '../../../../hooks'\nimport { ResponsiveValue } from '../../../../../prop-controllers'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport Parallax from '../Parallax'\nimport BackgroundVideo from '../BackgroundVideo'\nimport { useIsPrefetching } from '../../../../../api/react'\n\nfunction getColor(color: Color | null | undefined) {\n if (color == null) return 'black'\n\n if (color.swatch == null) {\n return colorToString({ ...color, swatch: { hue: 0, saturation: 0, lightness: 0 } })\n }\n\n return colorToString(color)\n}\n\ntype GradientStop = { color: Color | null | undefined; location: number }\n\nconst getStopsStyle = (stops: GradientStop[]) =>\n stops.map(({ color, location }) => `${getColor(color)} ${location}%`).join(',')\n\ntype AspectRatio = 'wide' | 'standard'\n\nconst getAspectRatio = (aspectRatio: AspectRatio) => {\n switch (aspectRatio) {\n case 'wide':\n return 16 / 9\n case 'standard':\n return 4 / 3\n default:\n return 16 / 9\n }\n}\n\nconst AbsoluteFill = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n`\n\nconst Container = styled(AbsoluteFill)`\n border-radius: inherit;\n`\n\nconst BackgroundsContainer = styled(Container)<{ visibility: ResponsiveValue<boolean> }>`\n overflow: hidden;\n ${p =>\n cssMediaRules(\n [p.visibility],\n ([visibility]) => css`\n display: ${visibility === true ? 'block' : 'none'};\n `,\n )}\n`\n\ntype Props = { backgrounds: BackgroundsPropControllerData | null | undefined }\n\nexport default function Backgrounds({ backgrounds }: Props): JSX.Element {\n const isPrefetching = useIsPrefetching()\n\n if (isPrefetching) return <></>\n\n if (backgrounds == null) return <></>\n\n return (\n <>\n {backgrounds.map(({ value, deviceId }) => {\n const visibility = backgrounds.map(v => ({\n deviceId: v.deviceId,\n value: v.deviceId === deviceId,\n }))\n\n return (\n <BackgroundsContainer key={deviceId} visibility={visibility}>\n {[...value].reverse().map(bg => {\n if (bg.type === 'color') {\n return (\n <Container\n key={bg.id}\n style={{\n backgroundColor: getColor(bg.payload),\n }}\n />\n )\n }\n\n if (bg.type === 'image' && bg.payload) {\n const {\n publicUrl,\n position,\n repeat = 'no-repeat',\n size = 'cover',\n opacity,\n parallax,\n } = bg.payload\n const backgroundPosition = `${position.x}% ${position.y}%`\n\n if (repeat === 'no-repeat' && size !== 'auto' && publicUrl != null) {\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <div {...getParallaxProps({ style: { opacity, overflow: 'hidden' } })}>\n <NextImage\n src={publicUrl}\n layout=\"fill\"\n objectPosition={backgroundPosition}\n objectFit={size}\n />\n </div>\n )}\n </Parallax>\n )\n }\n\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <Container\n {...getParallaxProps({\n style: {\n backgroundImage: publicUrl != null ? `url('${publicUrl}')` : undefined,\n backgroundPosition,\n backgroundRepeat: repeat,\n backgroundSize: size,\n opacity,\n },\n })}\n />\n )}\n </Parallax>\n )\n }\n\n if (bg.type === 'gradient' && bg.payload) {\n const { angle, stops, isRadial } = bg.payload\n const gradient = `${getStopsStyle(stops)}`\n\n return (\n <Container\n key={bg.id}\n style={{\n background: isRadial\n ? `radial-gradient(${gradient})`\n : `linear-gradient(${angle}rad, ${gradient})`,\n }}\n />\n )\n }\n\n if (bg.type === 'video' && bg.payload) {\n const { url, aspectRatio, maskColor, zoom, opacity, parallax } = bg.payload\n\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <Container {...getParallaxProps({})}>\n <BackgroundVideo\n url={url}\n zoom={zoom}\n opacity={opacity}\n aspectRatio={getAspectRatio(aspectRatio)}\n maskColor={getColor(maskColor)}\n />\n </Container>\n )}\n </Parallax>\n )\n }\n\n return null\n })}\n </BackgroundsContainer>\n )\n })}\n </>\n )\n}\n","import {\n ReactElement,\n ElementType,\n forwardRef,\n Children,\n ComponentPropsWithoutRef,\n useImperativeHandle,\n useState,\n} from 'react'\nimport styled from 'styled-components'\nimport { motion } from 'framer-motion'\n\nimport Backgrounds from './components/Backgrounds'\nimport { BackgroundsValue as BackgroundsPropControllerValue } from '../../../prop-controllers/descriptors'\nimport { useBackgrounds } from '../../hooks'\nimport { Ref } from 'react'\n\nconst OuterContainer = styled(motion.div)`\n position: relative;\n width: 100%;\n margin: 0 auto;\n\n > * {\n border-radius: inherit;\n height: inherit;\n }\n\n > :last-child {\n position: relative;\n }\n`\n\ntype BaseProps = {\n backgrounds: BackgroundsPropControllerValue | null | undefined\n children: ReactElement<ElementType>\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof OuterContainer>, keyof BaseProps>\n\nexport default forwardRef<HTMLDivElement | null, Props>(function BackgroundsContainer(\n { backgrounds, children, ...restOfProps }: Props,\n ref: Ref<HTMLDivElement | null>,\n) {\n const [handle, setHandle] = useState<HTMLDivElement | null>(null)\n\n useImperativeHandle(ref, () => handle, [handle])\n\n return (\n <OuterContainer {...restOfProps} ref={setHandle}>\n <Backgrounds backgrounds={useBackgrounds(backgrounds)} />\n {Children.only(children)}\n </OuterContainer>\n )\n})\n","import { forwardRef, Ref, useImperativeHandle, useRef, useState } from 'react'\nimport styled from 'styled-components'\nimport { motion } from 'framer-motion'\nimport { cx } from '@emotion/css'\n\nimport { Element, ReactRuntime } from '../../../react'\nimport Placeholder from './components/Placeholder'\nimport {\n BoxAnimateIn,\n DEFAULT_BOX_ANIMATE_DELAY,\n DEFAULT_BOX_ANIMATE_DURATION,\n DEFAULT_ITEM_ANIMATE_DELAY,\n DEFAULT_ITEM_STAGGER_DURATION,\n useBoxAnimations,\n} from './animations'\nimport {\n BorderRadiusValue,\n ElementIDValue,\n MarginValue,\n PaddingValue,\n ResponsiveIconRadioGroupValue,\n GridValue,\n GapYValue,\n GapXValue,\n CheckboxValue,\n ResponsiveSelectValue,\n ResponsiveNumberValue,\n BackgroundsValue,\n BorderValue,\n ShadowsValue,\n ResponsiveValue,\n} from '../../../prop-controllers/descriptors'\nimport {\n cssMargin,\n cssPadding,\n cssBorderRadius,\n cssGridItem,\n cssMediaRules,\n cssBorder,\n cssBoxShadow,\n} from '../../utils/cssMediaRules'\nimport { BoxModelHandle, parse, createBox } from '../../../box-model'\nimport BackgroundsContainer from '../../shared/BackgroundsContainer'\nimport {\n BorderPropControllerData,\n BoxShadowPropControllerData,\n useBorder,\n useBoxShadow,\n} from '../../hooks'\nimport { Props } from '../../../prop-controllers'\nimport { findDeviceOverride } from '../../utils/devices'\n\ntype Props = {\n id?: ElementIDValue\n backgrounds?: BackgroundsValue\n width?: string\n height?: ResponsiveIconRadioGroupValue<'auto' | 'stretch'>\n verticalAlign?: ResponsiveIconRadioGroupValue<\n 'flex-start' | 'center' | 'flex-end' | 'space-between'\n >\n margin?: MarginValue\n padding?: PaddingValue\n border?: BorderValue\n borderRadius?: BorderRadiusValue\n boxShadow?: ShadowsValue\n rowGap?: GapYValue\n columnGap?: GapXValue\n boxAnimateType?: ResponsiveSelectValue<BoxAnimateIn>\n boxAnimateDuration?: ResponsiveNumberValue\n boxAnimateDelay?: ResponsiveNumberValue\n itemAnimateType?: ResponsiveSelectValue<BoxAnimateIn>\n itemAnimateDuration?: ResponsiveNumberValue\n itemAnimateDelay?: ResponsiveNumberValue\n itemStaggerDuration?: ResponsiveNumberValue\n hidePlaceholder?: CheckboxValue\n children?: GridValue\n}\n\nconst StyledBackgroundsContainer = styled(BackgroundsContainer)<{\n margin: Props['margin']\n borderRadius: Props['borderRadius']\n alignSelf: Props['height']\n}>`\n display: flex;\n ${cssMargin()}\n ${cssBorderRadius()}\n ${props => cssMediaRules([props.alignSelf] as const, ([alignSelf = 'auto']) => ({ alignSelf }))}\n`\n\nconst Grid = styled(motion.div)<{\n padding: Props['padding']\n border: BorderPropControllerData | null | undefined\n boxShadow: BoxShadowPropControllerData | null | undefined\n alignContent: Props['verticalAlign']\n}>`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n ${cssPadding()}\n ${cssBorder()}\n ${cssBoxShadow()}\n ${props =>\n cssMediaRules([props.alignContent] as const, ([alignContent = 'flex-start']) => ({\n alignContent,\n }))}\n`\nconst GridItem = styled(motion.div)<{\n grid: NonNullable<Props['children']>['columns']\n alignItems: Props['verticalAlign']\n index: number\n columnGap: Props['columnGap']\n rowGap: Props['rowGap']\n}>`\n display: flex;\n\n /* IE11 doesn't recognize space-between and treats it as stretch, so we fall back to flex-start */\n align-items: flex-start;\n ${cssGridItem()}\n ${props =>\n cssMediaRules([props.alignItems] as const, ([alignItems = 'flex-start']) => ({ alignItems }))}\n`\n\nconst Box = forwardRef(function Box(\n {\n id,\n backgrounds,\n width,\n height,\n margin,\n padding,\n border,\n children,\n borderRadius,\n boxShadow,\n rowGap,\n columnGap,\n hidePlaceholder,\n verticalAlign,\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemStaggerDuration,\n }: Props,\n ref: Ref<BoxModelHandle>,\n) {\n const innerRef = useRef<HTMLDivElement | null>(null)\n const [boxElement, setBoxElement] = useState<HTMLElement | null>(null)\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n const paddingBoxElement = innerRef.current\n const borderBoxElement = innerRef.current\n const marginBoxElement = boxElement\n const borderBox = innerRef.current?.getBoundingClientRect()\n const paddingBoxComputedStyle =\n paddingBoxElement?.ownerDocument.defaultView?.getComputedStyle(paddingBoxElement)\n const borderBoxComputedStyle =\n borderBoxElement?.ownerDocument.defaultView?.getComputedStyle(borderBoxElement)\n const marginBoxComputedStyle =\n marginBoxElement?.ownerDocument.defaultView?.getComputedStyle(marginBoxElement)\n const padding = paddingBoxComputedStyle && {\n top: parse(paddingBoxComputedStyle.paddingTop),\n right: parse(paddingBoxComputedStyle.paddingRight),\n bottom: parse(paddingBoxComputedStyle.paddingBottom),\n left: parse(paddingBoxComputedStyle.paddingLeft),\n }\n const border = borderBoxComputedStyle && {\n top: parse(borderBoxComputedStyle.borderTopWidth),\n right: parse(borderBoxComputedStyle.borderRightWidth),\n bottom: parse(borderBoxComputedStyle.borderBottomWidth),\n left: parse(borderBoxComputedStyle.borderLeftWidth),\n }\n const margin = marginBoxComputedStyle && {\n top: parse(marginBoxComputedStyle.marginTop),\n right: parse(marginBoxComputedStyle.marginRight),\n bottom: parse(marginBoxComputedStyle.marginBottom),\n left: parse(marginBoxComputedStyle.marginLeft),\n }\n\n return borderBox ? createBox({ borderBox, padding, border, margin }) : null\n },\n }),\n [boxElement],\n )\n\n const borderData = useBorder(border)\n const boxShadowData = useBoxShadow(boxShadow)\n\n const { initial, animate, variants, transition, key } = useBoxAnimations({\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemStaggerDuration,\n boxElement,\n elements: children?.elements,\n })\n\n return (\n <StyledBackgroundsContainer\n ref={setBoxElement}\n id={id}\n className={cx(width)}\n backgrounds={backgrounds}\n margin={margin}\n borderRadius={borderRadius}\n alignSelf={height}\n animate={animate?.container}\n initial={initial?.container}\n variants={variants?.container}\n transition={transition?.container}\n key={key?.container}\n >\n <Grid\n ref={innerRef}\n padding={padding}\n border={borderData}\n boxShadow={boxShadowData}\n alignContent={verticalAlign}\n animate={animate?.parent}\n initial={initial?.parent}\n transition={transition?.parent}\n >\n {children && children.elements.length > 0 ? (\n children.elements.map((child, index) => (\n <GridItem\n key={child.key}\n grid={children.columns}\n index={index}\n columnGap={columnGap}\n rowGap={rowGap}\n alignItems={verticalAlign}\n variants={variants?.child}\n transition={transition?.child}\n >\n <Element element={child} />\n </GridItem>\n ))\n ) : (\n <Placeholder hide={hidePlaceholder} />\n )}\n </Grid>\n </StyledBackgroundsContainer>\n )\n})\n\nexport default Box\n\nexport function registerComponent(runtime: ReactRuntime) {\n function isHiddenBasedOnAnimationType(\n props: Record<string, unknown>,\n deviceId: string,\n property: 'boxAnimateType' | 'itemAnimateType',\n ): boolean {\n const animateIn = props[property] as ResponsiveValue<BoxAnimateIn>\n return (findDeviceOverride<BoxAnimateIn>(animateIn, deviceId)?.value ?? 'none') === 'none'\n }\n const isHiddenBasedOnBoxAnimation = (props: Record<string, unknown>, deviceId: string) =>\n isHiddenBasedOnAnimationType(props, deviceId, 'boxAnimateType')\n const isHiddenBasedOnItemAnimation = (props: Record<string, unknown>, deviceId: string) =>\n isHiddenBasedOnAnimationType(props, deviceId, 'itemAnimateType')\n\n return runtime.registerComponent(Box, {\n type: './components/Box/index.js',\n label: 'Box',\n props: {\n id: Props.ElementID(),\n backgrounds: Props.Backgrounds(),\n width: Props.Width({ format: Props.Width.Formats.ClassName }),\n height: Props.ResponsiveIconRadioGroup({\n label: 'Height',\n options: [\n { value: 'auto', label: 'Auto', icon: 'HeightAuto16' },\n { value: 'stretch', label: 'Stretch', icon: 'HeightMatch16' },\n ],\n defaultValue: 'auto',\n }),\n verticalAlign: Props.ResponsiveIconRadioGroup({\n label: 'Align items',\n options: [\n { value: 'flex-start', label: 'Top', icon: 'VerticalAlignStart16' },\n { value: 'center', label: 'Middle', icon: 'VerticalAlignMiddle16' },\n { value: 'flex-end', label: 'Bottom', icon: 'VerticalAlignEnd16' },\n {\n value: 'space-between',\n label: 'Space between',\n icon: 'VerticalAlignSpaceBetween16',\n },\n ],\n defaultValue: 'flex-start',\n }),\n margin: Props.Margin(),\n padding: Props.Padding({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n paddingTop: { value: 10, unit: 'px' },\n paddingRight: { value: 10, unit: 'px' },\n paddingBottom: { value: 10, unit: 'px' },\n paddingLeft: { value: 10, unit: 'px' },\n },\n },\n ],\n }),\n border: Props.Border(),\n borderRadius: Props.BorderRadius(),\n boxShadow: Props.Shadows(),\n rowGap: Props.GapY(props => ({\n hidden: props.children == null,\n })),\n columnGap: Props.GapX(props => ({\n hidden: props.children == null,\n })),\n boxAnimateType: Props.ResponsiveSelect({\n label: 'Animate box in',\n labelOrientation: 'vertical',\n options: [\n { value: 'none', label: 'None' },\n { value: 'fadeIn', label: 'Fade in' },\n { value: 'fadeRight', label: 'Fade right' },\n { value: 'fadeDown', label: 'Fade down' },\n { value: 'fadeLeft', label: 'Fade left' },\n { value: 'fadeUp', label: 'Fade up' },\n { value: 'blurIn', label: 'Blur in' },\n { value: 'scaleUp', label: 'Scale up' },\n { value: 'scaleDown', label: 'Scale down' },\n ],\n defaultValue: 'none',\n }),\n boxAnimateDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Box duration',\n defaultValue: DEFAULT_BOX_ANIMATE_DURATION,\n min: 0.1,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnBoxAnimation(props, device),\n })),\n boxAnimateDelay: Props.ResponsiveNumber((props, device) => ({\n label: 'Box delay',\n defaultValue: DEFAULT_BOX_ANIMATE_DELAY,\n min: 0,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnBoxAnimation(props, device),\n })),\n itemAnimateType: Props.ResponsiveSelect({\n label: 'Animate items in',\n labelOrientation: 'vertical',\n options: [\n { value: 'none', label: 'None' },\n { value: 'fadeIn', label: 'Fade in' },\n { value: 'fadeRight', label: 'Fade right' },\n { value: 'fadeDown', label: 'Fade down' },\n { value: 'fadeLeft', label: 'Fade left' },\n { value: 'fadeUp', label: 'Fade up' },\n { value: 'blurIn', label: 'Blur in' },\n { value: 'scaleUp', label: 'Scale up' },\n { value: 'scaleDown', label: 'Scale down' },\n ],\n defaultValue: 'none',\n }),\n itemAnimateDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Items duration',\n defaultValue: DEFAULT_BOX_ANIMATE_DURATION,\n min: 0.1,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n itemAnimateDelay: Props.ResponsiveNumber((props, device) => ({\n label: 'Items delay',\n defaultValue: DEFAULT_ITEM_ANIMATE_DELAY,\n min: 0,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n itemStaggerDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Stagger',\n min: 0,\n step: 0.05,\n suffix: 's',\n defaultValue: DEFAULT_ITEM_STAGGER_DURATION,\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n hidePlaceholder: Props.Checkbox(props => ({\n label: 'Hide placeholder',\n hidden: props.children != null,\n })),\n children: Props.Grid(),\n },\n })\n}\n","import { ComponentPropsWithoutRef, forwardRef, MouseEvent } from 'react'\nimport scrollIntoView from 'scroll-into-view-if-needed'\nimport NextLink from 'next/link'\n\nimport { LinkValue as LinkPropControllerValue } from '../../../prop-controllers/descriptors'\nimport { usePage } from '../../hooks'\nimport { useElementId } from '../../../runtimes/react'\n\ntype BaseProps = {\n link?: LinkPropControllerValue\n onClick?: (event: MouseEvent<HTMLAnchorElement>) => unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<'a'>, keyof BaseProps>\n\nexport const Link = forwardRef<HTMLAnchorElement, Props>(function Link(\n { link, onClick = () => {}, ...restOfProps }: Props,\n ref,\n) {\n const page = usePage(link && link.type === 'OPEN_PAGE' ? link.payload.pageId : null)\n const elementKey =\n link?.type === 'SCROLL_TO_ELEMENT' ? link.payload.elementIdConfig?.elementKey : null\n const elementId = useElementId(elementKey)\n\n let href = ''\n let target: '_blank' | '_self' | undefined\n let block: 'start' | 'center' | 'end' | undefined\n\n if (link) {\n switch (link.type) {\n case 'OPEN_PAGE': {\n if (page) href = `/${page.pathname}`\n\n target = link.payload.openInNewTab ? '_blank' : '_self'\n\n break\n }\n\n case 'OPEN_URL': {\n href = link.payload.url\n\n target = link.payload.openInNewTab ? '_blank' : '_self'\n\n break\n }\n\n case 'SEND_EMAIL': {\n const { to, subject = '', body = '' } = link.payload\n\n if (to != null) href = `mailto:${to}?subject=${subject}&body=${body}`\n\n break\n }\n\n case 'CALL_PHONE': {\n href = `tel:${link.payload.phoneNumber}`\n\n break\n }\n\n case 'SCROLL_TO_ELEMENT': {\n href = `#${elementId ?? ''}`\n block = link.payload.block\n\n break\n }\n\n default:\n throw new RangeError(`Invalid link type \"${(link as any).type}.\"`)\n }\n }\n\n function handleClick(event: MouseEvent<HTMLAnchorElement>) {\n onClick(event)\n\n if (event.defaultPrevented) return\n\n /**\n * When we introduced `next/link` instead of just `a` element slate no longer prevented link from navigating within\n * content mode. This is a hack to compensate for what would be expected as slate's default behavior.\n * On upgrade of slate this can be reevaluated.\n */\n if (event.currentTarget.isContentEditable) return event.preventDefault()\n\n if (link && link.type === 'SCROLL_TO_ELEMENT') {\n let hash: string | undefined\n\n try {\n hash = new URL(`http://www.example.com/${href}`).hash\n } catch (error) {\n console.error(`Link received invalid href: ${href}`, error)\n }\n\n if (href != null && href === hash) {\n event.preventDefault()\n const view = event.view as unknown as Window\n\n scrollIntoView(view.document.querySelector(hash)!, {\n behavior: 'smooth',\n block,\n })\n\n if (view.location.hash !== hash) view.history.pushState({}, '', hash)\n }\n }\n }\n\n return (\n <NextLink href={href}>\n {/* eslint-disable-next-line */}\n <a {...restOfProps} ref={ref} target={target} onClick={handleClick} />\n </NextLink>\n )\n})\n","import { WidthProperty } from 'csstype'\nimport { CSSObject } from '@emotion/css'\n\nimport {\n ResponsiveValue,\n ResponsiveValueType as ExtractResponsiveValue,\n Length as LengthValue,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport {\n FallbackStrategy,\n getDevice,\n getDeviceMediaQuery,\n join as joinResponsiveValues,\n} from './devices'\n\nexport function responsiveStyle<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>>(\n responsiveValues: A,\n join: (values: { [K in keyof A]: ExtractResponsiveValue<A[K]> | undefined }) => CSSObject,\n strategy?: FallbackStrategy<V>,\n): CSSObject {\n return joinResponsiveValues(responsiveValues, join, strategy).reduce(\n (acc, { deviceId, value }) => {\n const device = getDevice(deviceId)\n const mediaQuery = getDeviceMediaQuery(device)\n\n return {\n ...acc,\n [mediaQuery]: {\n ...(acc[mediaQuery] as CSSObject),\n ...value,\n },\n }\n },\n {} as CSSObject,\n )\n}\n\nexport function responsiveWidth(\n widthData: WidthValue | undefined,\n defaultValue: LengthValue | WidthProperty<string | number> = '100%',\n): CSSObject {\n return {\n maxWidth: '100%',\n ...responsiveStyle([widthData], ([width = defaultValue]) => ({\n width: typeof width === 'object' ? `${width.value}${width.unit}` : width,\n })),\n }\n}\n","import { ReactElement, ComponentPropsWithoutRef, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport ColorHelper from 'color'\nimport { cx, css as toClass } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin, cssTextStyle } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n MarginValue,\n TextInputValue,\n ResponsiveSelectValue,\n ResponsiveIconRadioGroupValue,\n TextStyleValue,\n LinkValue,\n WidthValue,\n} from '../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../utils/types'\nimport { colorToString } from '../../utils/colorToString'\nimport { Link } from '../../shared/Link'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { responsiveWidth } from '../../utils/responsive-style'\nimport { findDeviceOverride } from '../../utils/devices'\n\ntype ButtonVariant = 'flat' | 'outline' | 'shadow' | 'clear' | 'blocky' | 'bubbly' | 'skewed'\n\ntype ControllerProps = {\n id?: ElementIDValue\n children?: TextInputValue\n link?: LinkValue\n variant?: ResponsiveSelectValue<ButtonVariant>\n shape?: ResponsiveIconRadioGroupValue<'pill' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n color?: ResponsiveColor\n textColor?: ResponsiveColor\n textStyle?: TextStyleValue\n width?: WidthValue\n margin?: MarginValue\n}\n\nconst StyledButton = styled(Link)<{\n margin: ControllerProps['margin']\n variant: ControllerProps['variant']\n shape: ControllerProps['shape']\n size: ControllerProps['size']\n textColor: ResponsiveValue<Color> | null | undefined\n color: ResponsiveValue<Color> | null | undefined\n textStyle: ControllerProps['textStyle']\n}>`\n display: table;\n border: 0;\n outline: 0;\n user-select: none;\n cursor: pointer;\n font-family: inherit;\n text-decoration: none;\n text-align: center;\n ${cssMargin()}\n ${p =>\n cssMediaRules(\n [p.variant, p.shape, p.size, p.textColor, p.color] as const,\n ([\n variant = 'flat',\n shape = 'rounded',\n size = 'medium',\n textColor = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 },\n color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => {\n const fontSize = {\n value: { small: 12, medium: 14, large: 18 }[size],\n unit: 'px',\n }\n\n return css`\n color: ${colorToString(textColor)};\n border-radius: ${{ square: 0, rounded: 4, pill: 500 }[shape]}px;\n padding: ${{ small: '8px 12px', medium: '12px 16px', large: '16px 20px' }[size]};\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n\n ${{\n flat: css`\n background: ${colorToString(color)};\n border: none;\n transition: ${['color', 'background', 'border', 'box-shadow']\n .map(property => `${property} 0.15s ease-in-out`)\n .join(', ')};\n\n :hover {\n background: ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n }\n\n :active {\n background: ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n }\n `,\n outline: css`\n background: transparent;\n box-shadow: inset 0 0 0 2px ${colorToString(color)};\n transition: ${['color', 'background', 'box-shadow']\n .map(property => `${property} 0.15s ease-in-out`)\n .join(', ')};\n\n :hover {\n box-shadow: inset 0 0 0 2px ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n color: ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n }\n\n :active {\n box-shadow: inset 0 0 0 2px ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n color: ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n }\n `,\n shadow: css`\n background: ${colorToString(color)};\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.2);\n transition: ${['transform', 'box-shadow']\n .map(property => `${property} 0.18s`)\n .join(', ')};\n\n :hover {\n box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n transform: translateY(-1px);\n }\n\n :active {\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 4px 6px -3px rgba(0, 0, 0, 0.3);\n transform: translateY(0px);\n }\n `,\n clear: css`\n background: transparent;\n border: none;\n\n :hover {\n color: ${ColorHelper(colorToString(textColor)).alpha(0.5).toString()};\n }\n\n :active {\n color: ${ColorHelper(colorToString(textColor)).alpha(0.6).toString()};\n }\n `,\n blocky: css`\n background: ${colorToString(color)};\n border-width: 1px;\n border-style: solid;\n border-color: ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n box-shadow: 0 4px ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n transition: ${['transform', 'box-shadow']\n .map(property => `${property} 0.1s`)\n .join(', ')};\n\n :hover {\n transform: translateY(2px);\n box-shadow: 0 2px ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n }\n\n :active {\n transform: translateY(4px);\n box-shadow: 0 0 ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n }\n `,\n bubbly: css`\n background: linear-gradient(\n 180deg,\n ${ColorHelper(colorToString(color)).lighten(0.05).hex()},\n ${ColorHelper(colorToString(color)).darken(0.3).saturate(0.05).hex()}\n );\n position: relative;\n z-index: 0;\n\n :before {\n position: absolute;\n content: '';\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n border-radius: inherit;\n background: linear-gradient(\n 180deg,\n ${ColorHelper(colorToString(color)).lighten(0.2).hex()},\n ${ColorHelper(colorToString(color)).darken(0.2).saturate(0.05).hex()}\n );\n opacity: 0;\n transition: opacity 0.15s;\n }\n\n :hover {\n :before {\n opacity: 1;\n }\n }\n\n :active {\n :before {\n opacity: 0.25;\n }\n }\n `,\n skewed: css`\n position: relative;\n z-index: 0;\n\n :before {\n position: absolute;\n content: '';\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n background: ${colorToString(color)};\n transform: skewX(-12deg);\n border-radius: inherit;\n transition: transform 0.2s cubic-bezier(0.25, 0, 0.25, 1.75);\n }\n\n :hover:before {\n transform: skew(0deg);\n }\n\n :active:before {\n transform: skew(-8deg);\n }\n `,\n }[variant]}\n `\n },\n )}\n ${cssTextStyle()}\n`\n\ntype BaseProps = {\n id?: ControllerProps['id']\n children?: ReactElement | string\n link?: ControllerProps['link']\n variant?: ControllerProps['variant']\n shape?: ControllerProps['shape']\n size?: ControllerProps['size']\n textColor?: ControllerProps['textColor']\n color?: ControllerProps['color']\n textStyle?: ControllerProps['textStyle']\n width?: WidthValue\n margin?: ControllerProps['margin']\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof StyledButton>, keyof BaseProps>\n\nconst Button = forwardRef<HTMLAnchorElement, Props>(function Button(\n {\n id,\n children,\n link,\n variant,\n shape,\n size,\n textColor,\n color,\n textStyle,\n width,\n margin,\n className,\n ...restOfProps\n },\n ref,\n) {\n return (\n <StyledButton\n {...restOfProps}\n ref={ref}\n id={id}\n className={cx(toClass(responsiveWidth(width, 'auto')), className)}\n // @ts-expect-error: HTMLAnchorElement `color` attribute conflicts with prop\n color={color}\n link={link}\n margin={margin}\n shape={shape}\n size={size}\n textColor={textColor}\n textStyle={textStyle}\n variant={variant}\n >\n {children == null ? 'Button Text' : children}\n </StyledButton>\n )\n})\n\nexport default Button\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Button, {\n type: './components/Button/index.js',\n label: 'Button',\n props: {\n id: Props.ElementID(),\n children: Props.TextInput({ placeholder: 'Button text' }),\n link: Props.Link({\n defaultValue: {\n type: 'OPEN_PAGE',\n payload: {\n pageId: null,\n openInNewTab: false,\n },\n },\n }),\n variant: Props.ResponsiveSelect({\n label: 'Style',\n labelOrientation: 'horizontal',\n options: [\n { value: 'flat', label: 'Flat' },\n { value: 'outline', label: 'Outline' },\n { value: 'shadow', label: 'Floating' },\n { value: 'clear', label: 'Clear' },\n { value: 'blocky', label: 'Blocky' },\n { value: 'bubbly', label: 'Bubbly' },\n { value: 'skewed', label: 'Skewed' },\n ],\n defaultValue: 'flat',\n }),\n shape: Props.ResponsiveIconRadioGroup({\n label: 'Shape',\n options: [\n { label: 'Pill', value: 'pill', icon: 'ButtonPill16' },\n { label: 'Rounded', value: 'rounded', icon: 'ButtonRounded16' },\n { label: 'Square', value: 'square', icon: 'ButtonSquare16' },\n ],\n defaultValue: 'rounded',\n }),\n size: Props.ResponsiveIconRadioGroup({\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n }),\n color: Props.ResponsiveColor((props, device) => {\n const variant = props.variant as ResponsiveValue<ButtonVariant>\n const hidden = findDeviceOverride<ButtonVariant>(variant, device)?.value === 'clear'\n\n return { placeholder: 'black', hidden }\n }),\n textColor: Props.ResponsiveColor({\n label: 'Text color',\n placeholder: 'white',\n }),\n textStyle: Props.TextStyle(),\n width: Props.Width(),\n margin: Props.Margin(),\n },\n })\n}\n","export const placeholders = {\n image: {\n src: \"data:image/svg+xml,%3Csvg width='360' height='240' viewBox='0 0 360 240' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0)'%3E%3Cpath d='M0 0H360V240H0V0Z' fill='%23A1A8C2' fill-opacity='0.18'/%3E%3Cpath d='M260 59C260 78.33 244.33 94 225 94C205.67 94 190 78.33 190 59C190 39.67 205.67 24 225 24C244.33 24 260 39.67 260 59Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M319 250H417L291.485 124.485C286.799 119.799 279.201 119.799 274.515 124.485L234 165L319 250Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3Cpath d='M311 250L-89 250L102.515 58.4853C107.201 53.799 114.799 53.799 119.485 58.4853L311 250Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0'%3E%3Cpath d='M0 0H360V240H0V0Z' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A\",\n dimensions: { width: 360, height: 240 },\n },\n video: {\n src: \"data:image/svg+xml,%3Csvg width='712' height='400' viewBox='0 0 712 400' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M712 0H0V400H712V0ZM356 240C378.091 240 396 222.091 396 200C396 177.909 378.091 160 356 160C333.909 160 316 177.909 316 200C316 222.091 333.909 240 356 240Z' fill='%23A1A8C2' fill-opacity='0.18'/%3E%3Cpath d='M344 216.503V183.497C344 181.95 345.681 180.989 347.014 181.773L375.069 198.276C376.384 199.049 376.384 200.951 375.069 201.724L347.014 218.227C345.681 219.011 344 218.05 344 216.503Z' fill='%23A1A8C2' fill-opacity='0.4'/%3E%3C/svg%3E%0A\",\n dimensions: { width: 712, height: 400 },\n },\n}\n","import styled, { css } from 'styled-components'\nimport { useState, useEffect, Ref, forwardRef } from 'react'\nimport NextImage from 'next/image'\nimport { css as toClass, cx } from '@emotion/css'\n\nimport {\n BorderRadiusValue,\n BorderValue,\n ElementIDValue,\n ImageValue,\n LinkValue,\n MarginValue,\n PaddingValue,\n ResponsiveOpacityValue,\n ShadowsValue,\n TextInputValue,\n WidthValue,\n} from '../../../prop-controllers/descriptors'\nimport {\n cssBorder,\n cssBorderRadius,\n cssBoxShadow,\n cssMargin,\n cssMediaRules,\n cssPadding,\n} from '../../utils/cssMediaRules'\nimport { DEVICES, findDeviceOverride } from '../../utils/devices'\nimport {\n BorderPropControllerData,\n BoxShadowPropControllerData,\n useBorder,\n useBoxShadow,\n useFile,\n} from '../../hooks'\nimport { placeholders } from '../../utils/placeholders'\nimport { ReactRuntime, useIsInBuilder } from '../../../react'\nimport { Link } from '../../shared/Link'\nimport { Props } from '../../../prop-controllers'\nimport { useIsPrefetching } from '../../../api/react'\nimport { responsiveWidth } from '../../utils/responsive-style'\n\ntype Props = {\n id?: ElementIDValue\n file?: ImageValue\n altText?: TextInputValue\n link?: LinkValue\n width?: WidthValue\n margin?: MarginValue\n padding?: PaddingValue\n border?: BorderValue\n borderRadius?: BorderRadiusValue\n boxShadow?: ShadowsValue\n opacity?: ResponsiveOpacityValue\n placeholder?: { src: string; dimensions: { width: number; height: number } }\n className?: string\n}\n\nfunction loadImage(src: string): Promise<HTMLImageElement> {\n return new Promise<HTMLImageElement>((resolve, reject) => {\n const image = new Image()\n\n image.onload = () => resolve(image)\n image.onerror = reject\n image.src = src\n })\n}\n\nfunction imageSizes(width?: Props['width']): string {\n const baseDevice = DEVICES.find(device => device.maxWidth == null)\n const baseWidth = baseDevice && width && findDeviceOverride(width, baseDevice.id)\n const baseWidthSize =\n baseWidth == null || baseWidth.value.unit !== 'px' ? '100vw' : `${baseWidth.value.value}px`\n\n return DEVICES.map(device => {\n const override = findDeviceOverride(width, device.id)\n\n if (override == null || device.maxWidth == null || override.value.unit !== 'px') return null\n\n return `(max-width: ${device.maxWidth}px) ${Math.min(device.maxWidth, override.value.value)}px`\n })\n .filter((size): size is NonNullable<typeof size> => size != null)\n .reduce((sourceSizes, sourceSize) => `${sourceSize}, ${sourceSizes}`, baseWidthSize)\n}\n\nconst ImageContainer = styled.div<{\n margin?: Props['margin']\n padding?: Props['padding']\n border?: BorderPropControllerData | null | undefined\n borderRadius: Props['borderRadius']\n boxShadow?: BoxShadowPropControllerData | null | undefined\n opacity: Props['opacity']\n link?: Props['link']\n}>`\n line-height: 0;\n overflow: hidden;\n ${cssMargin()}\n ${cssPadding()}\n ${cssBorder()}\n ${cssBorderRadius()}\n ${cssBoxShadow()}\n ${p =>\n cssMediaRules(\n [p.opacity],\n ([opacity = 1]) => css`\n opacity: ${opacity};\n `,\n )}\n`\n\nconst UnoptimizedImage = styled.img`\n width: 100%;\n`\n\ntype Dimensions = {\n width: number\n height: number\n}\n\nconst ImageComponent = forwardRef(function Image(\n {\n id,\n width,\n margin,\n padding,\n file,\n border,\n borderRadius,\n altText,\n link,\n opacity,\n boxShadow,\n placeholder = placeholders.image,\n className,\n }: Props,\n ref: Ref<HTMLImageElement>,\n) {\n const fileData = useFile(file)\n const borderData = useBorder(border)\n const boxShadowData = useBoxShadow(boxShadow)\n const imageSrc = fileData?.publicUrl ? fileData.publicUrl : placeholder.src\n const dataDimensions = fileData?.publicUrl ? fileData?.dimensions : placeholder.dimensions\n const [measuredDimensions, setMeasuredDimensions] = useState<Dimensions | null>(null)\n const isInBuilder = useIsInBuilder()\n const isPrefetching = useIsPrefetching()\n\n useEffect(() => {\n if (dataDimensions) return\n\n let cleanedUp = false\n\n loadImage(imageSrc)\n .then(image => {\n if (!cleanedUp) {\n setMeasuredDimensions({ width: image.naturalWidth, height: image.naturalHeight })\n }\n })\n .catch(console.error)\n\n return () => {\n cleanedUp = true\n }\n }, [dataDimensions, imageSrc])\n\n const dimensions = dataDimensions ?? measuredDimensions\n\n if (!dimensions) return null\n\n const widthClass = toClass(responsiveWidth(width, `${dimensions.width}px`))\n\n if (isPrefetching) return null\n\n return (\n <ImageContainer\n as={link ? Link : 'div'}\n link={link}\n ref={ref}\n id={id}\n className={cx(className, widthClass)}\n margin={margin}\n opacity={opacity}\n padding={padding}\n border={borderData}\n borderRadius={borderRadius}\n boxShadow={boxShadowData}\n >\n {isInBuilder ? (\n <UnoptimizedImage src={imageSrc} alt={altText} />\n ) : (\n <NextImage\n layout=\"responsive\"\n src={imageSrc}\n sizes={imageSizes(width)}\n alt={altText}\n width={dimensions.width}\n height={dimensions.height}\n />\n )}\n </ImageContainer>\n )\n})\n\nexport default ImageComponent\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(ImageComponent, {\n type: './components/Image/index.js',\n label: 'Image',\n props: {\n id: Props.ElementID(),\n file: Props.Image(),\n altText: Props.TextInput({ label: 'Alt text' }),\n link: Props.Link({ label: 'On click' }),\n width: Props.Width(),\n margin: Props.Margin(),\n padding: Props.Padding(),\n border: Props.Border(),\n borderRadius: Props.BorderRadius(),\n boxShadow: Props.Shadows(),\n opacity: Props.ResponsiveOpacity(),\n },\n })\n}\n","import { useState, useRef, useEffect, useCallback, forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { motion, useAnimation } from 'framer-motion'\nimport { useGesture } from 'react-use-gesture'\nimport { wrap } from '@popmotion/popcorn'\nimport uuid from 'uuid/v4'\nimport { cx } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { useMediaQuery } from '../../hooks'\n\nimport Image from '../Image'\nimport {\n ResponsiveValue,\n ElementIDValue,\n ImagesValue,\n MarginValue,\n ResponsiveNumberValue,\n ResponsiveIconRadioGroupValue,\n GapXValue,\n CheckboxValue,\n NumberValue,\n BorderValue,\n BorderRadiusValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\n\nconst LeftChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M7,13,1,7,7,1\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\nconst RightChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M3,1,9,7,3,13\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\n// NOTE: We set height to 100% here to fix an issue on IE11 where the child height of a flex column extends too far\nconst Container = styled.div`\n position: relative;\n height: 100%;\n`\n\ntype Props = {\n id?: ElementIDValue\n images?: ImagesValue\n width?: string\n margin?: MarginValue\n pageSize?: ResponsiveNumberValue\n step?: ResponsiveNumberValue\n slideAlignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gap?: GapXValue\n autoplay?: CheckboxValue\n delay?: NumberValue\n showArrows?: CheckboxValue\n arrowPosition?: ResponsiveIconRadioGroupValue<'inside' | 'center' | 'outside'>\n arrowColor?: ResponsiveColor | null\n arrowBackground?: ResponsiveColor | null\n showDots?: CheckboxValue\n dotColor?: ResponsiveColor | null\n slideBorder?: BorderValue\n slideBorderRadius?: BorderRadiusValue\n}\n\nconst Wrapper = styled.div<{ margin: Props['margin'] }>`\n position: relative;\n display: flex;\n flex-direction: column;\n ${cssMargin()}\n\n &:focus {\n outline: 0;\n }\n`\n\nconst Arrow = styled.div<{ background?: ResponsiveValue<Color> | null }>`\n padding: 10px;\n border-radius: 50%;\n outline: 0;\n border: 0;\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n user-select: none;\n ${p =>\n cssMediaRules(\n [p.background] as const,\n ([background = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 }]) => css`\n background: ${colorToString(background)};\n `,\n )}\n\n svg {\n transition: transform 0.15s;\n stroke: currentColor;\n }\n`\n\nconst Slop = styled.div<{\n color?: ResponsiveValue<Color> | null\n}>`\n position: absolute;\n top: 0;\n bottom: 0;\n display: ${props => (props.hidden ? 'none' : 'flex')};\n align-items: center;\n cursor: pointer;\n z-index: 2;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Slide = styled(motion.div)<{\n pageSize: Props['pageSize']\n alignItems: Props['slideAlignment']\n}>`\n display: flex;\n ${p =>\n cssMediaRules(\n [p.pageSize],\n ([pageSize = 1]) => css`\n flex-basis: ${100 / pageSize}%;\n max-width: ${100 / pageSize}%;\n min-width: ${100 / pageSize}%;\n `,\n )}\n\n ${p => cssMediaRules([p.alignItems], ([alignItems = 'center']) => ({ alignItems }))}\n`\n\nconst Reel = styled(motion.div)<{ gap: Props['gap'] }>`\n display: flex;\n position: relative;\n flex-wrap: nowrap;\n ${p =>\n cssMediaRules(\n [p.gap] as const,\n ([gap = { value: 0, unit: 'px' }]) => css`\n margin: 0 ${`${-gap.value / 2}${gap.unit}`};\n\n & > ${Slide} {\n padding: 0 ${`${gap.value / 2}${gap.unit}`};\n }\n `,\n )}\n`\n\nconst Page = styled(motion.div)`\n position: relative;\n width: 100%;\n`\n\nconst LeftSlop = styled(Slop)<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(-100% - 8px));\n `\n default:\n return css`\n transform: translateX(calc(-50%));\n `\n }\n })}\n left: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(-2px);\n }\n }\n`\n\nconst RightSlop = styled(Slop)<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(-8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(100% + 8px));\n `\n default:\n return css`\n transform: translateX(calc(50%));\n `\n }\n })}\n right: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(2px);\n }\n }\n`\n\nconst ClipMask = styled.div`\n overflow: hidden;\n`\n\nconst Dots = styled.div<{ color?: ResponsiveValue<Color> | null }>`\n display: ${props => (props.hidden ? 'none' : 'flex')};\n justify-content: center;\n margin-top: 20px;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Dot = styled.div<{ active: boolean }>`\n position: relative;\n margin: 0 6px;\n border-radius: 50%;\n cursor: pointer;\n width: 16px;\n height: 16px;\n\n &::before,\n &::after {\n content: '';\n position: absolute;\n top: 50%;\n left: 50%;\n display: block;\n border-radius: 50%;\n transition: all 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);\n }\n\n &::before {\n box-shadow: 0 0 0 2px currentColor;\n transform: translate3d(-50%, -50%, 0);\n width: ${props => (props.active ? 16 : 10)}px;\n height: ${props => (props.active ? 16 : 10)}px;\n }\n\n &::after {\n background: currentColor;\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0)});\n width: 10px;\n height: 10px;\n }\n\n &:hover::after {\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0.5)});\n }\n`\n\nconst SWIPE_THRESHOLD = 20\nconst swipePower = (dx: number, velocity: number) => dx * (1 + velocity)\n\nconst Carousel = forwardRef(function Carousel(\n {\n images = [],\n width,\n margin,\n pageSize: responsivePageSize,\n step: responsiveStep,\n gap,\n slideAlignment,\n showDots,\n showArrows,\n arrowPosition,\n arrowColor,\n arrowBackground,\n dotColor,\n autoplay = false,\n delay = 5,\n slideBorder,\n slideBorderRadius,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const [index, setIndex] = useState(0)\n const swipe = useRef(0)\n const startIndex = wrap(0, images.length, index)\n const pageSize = useMediaQuery(responsivePageSize) || 1\n const step = useMediaQuery(responsiveStep) || 1\n const endIndex = startIndex + pageSize\n const pageCount = Math.ceil((images.length - pageSize) / step + 1)\n const pageIndex = Math.ceil(startIndex / step)\n const isFirstPage = pageIndex === 0\n const isLastPage = pageIndex === pageCount - 1\n const paginate = useCallback(\n pageDistance => {\n if (pageDistance === 0) return\n\n const direction = pageDistance / Math.abs(pageDistance)\n const remaining = direction > 0 ? images.slice(endIndex) : images.slice(0, startIndex)\n const distance = direction * Math.min(remaining.length, step * Math.abs(pageDistance))\n\n setIndex(index + distance)\n },\n [images, index, startIndex, endIndex, step],\n )\n // @ts-expect-error: `useAnimation` types expect no arguments.\n const animation = useAnimation({ x: 0, transition: { type: 'spring', stiffness: 100 } })\n const bindPage = useGesture(\n {\n onDrag: ({ movement: [mx], delta: [dx], velocity }) => {\n animation.start({ x: mx })\n swipe.current = swipePower(dx, velocity)\n },\n onDragEnd: () => {\n animation.start({ x: 0 })\n\n if (swipe.current > SWIPE_THRESHOLD) paginate(1)\n else if (swipe.current < -SWIPE_THRESHOLD) paginate(-1)\n },\n },\n {\n drag: {\n axis: 'x',\n bounds: { left: 0, right: 0 },\n rubberband: true,\n },\n },\n )\n\n useEffect(() => {\n if (!autoplay || pageSize !== 0) setIndex(0)\n }, [autoplay, pageSize])\n\n useEffect(() => {\n if (!autoplay) return () => {}\n\n const intervalId = setInterval(() => (isLastPage ? setIndex(0) : paginate(1)), delay * 1000)\n\n return () => clearInterval(intervalId)\n }, [autoplay, delay, paginate, isLastPage])\n\n return (\n <Wrapper\n ref={ref}\n className={cx(width)}\n margin={margin}\n tabIndex={-1}\n onKeyDown={e => {\n switch (e.key) {\n case 'ArrowRight':\n paginate(1)\n break\n case 'ArrowLeft':\n paginate(-1)\n break\n default:\n }\n }}\n >\n <Container>\n <ClipMask>\n <Page {...bindPage()} animate={animation}>\n <Reel\n gap={gap}\n animate={{ x: `${-(100 / pageSize) * startIndex}%` }}\n transition={{\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n duration: 0.5,\n },\n }}\n >\n {images.map(({ props: imageProps, key }) => (\n <Slide\n id={key}\n key={key}\n pageSize={responsivePageSize}\n alignItems={slideAlignment}\n onMouseDown={e => e.preventDefault()}\n onClick={e => {\n if (swipe.current !== 0) e.preventDefault()\n }}\n >\n <Image\n width={[{ deviceId: 'desktop', value: { value: 100, unit: '%' } }]}\n file={imageProps.file}\n altText={imageProps.altText}\n link={imageProps.link}\n border={slideBorder}\n borderRadius={slideBorderRadius}\n />\n </Slide>\n ))}\n </Reel>\n </Page>\n </ClipMask>\n <LeftSlop\n onClick={() => paginate(-1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isFirstPage}\n >\n <Arrow background={arrowBackground}>\n <LeftChevron />\n </Arrow>\n </LeftSlop>\n <RightSlop\n onClick={() => paginate(1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isLastPage}\n >\n <Arrow background={arrowBackground}>\n <RightChevron />\n </Arrow>\n </RightSlop>\n </Container>\n {/* @ts-expect-error: HTMLDivElement attributes conflicts with `color` prop */}\n <Dots color={dotColor} hidden={!showDots}>\n {Array.from({ length: pageCount }).map((_, i) => (\n <Dot key={i} active={i === pageIndex} onClick={() => paginate(i - pageIndex)} />\n ))}\n </Dots>\n </Wrapper>\n )\n})\n\nexport default Carousel\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Carousel, {\n type: './components/Carousel/index.js',\n label: 'Carousel',\n icon: 'Carousel40',\n props: {\n id: Props.ElementID(),\n images: Props.Images({\n preset: [\n { key: uuid(), props: {} },\n { key: uuid(), props: {} },\n { key: uuid(), props: {} },\n ],\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 400, unit: 'px' },\n }),\n margin: Props.Margin(),\n pageSize: Props.ResponsiveNumber(props => {\n const images = props.images as unknown[]\n const imagesLength = images?.length ?? 0\n\n return {\n label: 'Images shown',\n defaultValue: 1,\n min: 1,\n max: imagesLength,\n step: 1,\n }\n }),\n step: Props.ResponsiveNumber((props, device) => {\n const pageSize = props.pageSize as ResponsiveValue<number>\n const pageSizeValue = findDeviceOverride(pageSize, device)?.value ?? 1\n\n return {\n label: 'Step',\n defaultValue: 1,\n min: 1,\n max: pageSizeValue,\n step: 1,\n }\n }),\n slideAlignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'Top', value: 'flex-start', icon: 'VerticalAlignStart16' },\n { label: 'Middle', value: 'center', icon: 'VerticalAlignMiddle16' },\n { label: 'Bottom', value: 'flex-end', icon: 'VerticalAlignEnd16' },\n ],\n defaultValue: 'center',\n }),\n gap: Props.GapX({\n label: 'Gap',\n step: 5,\n defaultValue: { value: 0, unit: 'px' },\n }),\n autoplay: Props.Checkbox({ label: 'Autoplay' }),\n delay: Props.Number(props => ({\n label: 'Delay',\n preset: 5,\n min: 1,\n step: 0.1,\n suffix: 'seconds',\n hidden: !props.autoplay,\n })),\n showArrows: Props.Checkbox({ preset: true, label: 'Show arrows' }),\n arrowPosition: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Arrow position',\n options: [\n { label: 'Inside', value: 'inside', icon: 'ArrowInside16' },\n { label: 'Center', value: 'center', icon: 'ArrowCenter16' },\n { label: 'Outside', value: 'outside', icon: 'ArrowOutside16' },\n ],\n defaultValue: 'inside',\n hidden: props.showArrows === false,\n })),\n arrowColor: Props.ResponsiveColor(props => ({\n label: 'Arrow color',\n placeholder: 'black',\n hidden: props.showArrows === false,\n })),\n arrowBackground: Props.ResponsiveColor(props => ({\n label: 'Arrow background',\n placeholder: 'white',\n hidden: props.showArrows === false,\n })),\n showDots: Props.Checkbox({ preset: true, label: 'Show dots' }),\n dotColor: Props.ResponsiveColor(props => ({\n label: 'Dot color',\n placeholder: 'black',\n hidden: props.showDots === false,\n })),\n slideBorder: Props.Border(),\n slideBorderRadius: Props.BorderRadius(),\n },\n })\n}\n","import { useState, useEffect, Ref, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n DateValue,\n ElementIDValue,\n FontValue,\n GapXValue,\n MarginValue,\n ResponsiveIconRadioGroupValue,\n TextInputValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype Props = {\n id?: ElementIDValue\n date?: DateValue\n variant?: ResponsiveIconRadioGroupValue<\n 'filled' | 'filled-split' | 'outline' | 'outline-split' | 'clear'\n >\n shape?: ResponsiveIconRadioGroupValue<'pill' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n gap?: GapXValue\n numberFont?: FontValue\n numberColor?: ResponsiveColor | null\n blockColor?: ResponsiveColor | null\n labelFont?: FontValue\n labelColor?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n daysLabel?: TextInputValue\n hoursLabel?: TextInputValue\n minutesLabel?: TextInputValue\n secondsLabel?: TextInputValue\n}\n\nconst Block = styled.div`\n display: block;\n padding: 0.5em;\n font-size: 1em;\n`\n\nconst Label = styled.div`\n margin-top: 0.25em;\n`\n\nconst Segment = styled.div`\n flex: 1;\n text-align: center;\n`\n\nconst Container = styled.div<{\n margin: Props['margin']\n variant: Props['variant']\n size: Props['size']\n shape: Props['shape']\n gap: Props['gap']\n labelColor?: ResponsiveValue<Color> | null\n numberFont?: ResponsiveValue<string>\n numberColor?: ResponsiveValue<Color> | null\n blockColor?: ResponsiveValue<Color> | null\n labelFont?: ResponsiveValue<string>\n}>`\n display: flex;\n ${cssMargin()}\n ${p =>\n cssMediaRules([p.size] as const, ([size = 'medium']) => {\n switch (size) {\n case 'small':\n return css`\n font-size: 18px;\n\n ${Label} {\n font-size: 14px;\n }\n `\n case 'large':\n return css`\n font-size: 32px;\n\n ${Label} {\n font-size: 18px;\n }\n `\n default:\n return css`\n font-size: 24px;\n\n ${Label} {\n font-size: 16px;\n }\n `\n }\n })}\n\n ${Segment} {\n ${p =>\n cssMediaRules(\n [p.gap] as const,\n ([gap]) => css`\n margin: 0 ${gap == null ? 0 : `${gap.value / 2}${gap.unit}`};\n\n &:first-child {\n margin-left: 0;\n }\n\n &:last-child {\n margin-right: 0;\n }\n `,\n )}\n }\n\n ${Block} {\n ${p =>\n cssMediaRules([p.shape] as const, ([shape = 'rounded']) => {\n switch (shape) {\n case 'pill':\n return css`\n border-radius: 500px;\n `\n case 'rounded':\n return css`\n border-radius: 6px;\n `\n default:\n return css`\n border-radius: 0;\n `\n }\n })}\n ${p =>\n cssMediaRules(\n [p.variant, p.blockColor, p.numberColor, p.numberFont] as const,\n ([\n variant = 'filled',\n blockColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n numberColor = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 },\n numberFont = 'sans-serif',\n ]) => {\n switch (variant) {\n case 'filled':\n return css`\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n background: ${colorToString(blockColor)};\n `\n case 'filled-split':\n return css`\n position: relative;\n color: ${colorToString(numberColor)};\n font-family: '${numberFont}';\n\n > span {\n position: relative;\n z-index: 1;\n }\n\n :before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: calc(50% + 1px);\n border-top-left-radius: inherit;\n border-top-right-radius: inherit;\n background: ${colorToString(blockColor)};\n }\n\n :after {\n content: '';\n position: absolute;\n left: 0;\n right: 0;\n top: calc(50% + 1px);\n bottom: 0;\n border-bottom-left-radius: inherit;\n border-bottom-right-radius: inherit;\n background: ${colorToString(blockColor)};\n }\n `\n case 'outline':\n return css`\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n background: transparent;\n border: 2px solid ${colorToString(blockColor)};\n `\n case 'outline-split':\n return css`\n position: relative;\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n border: 2px solid ${colorToString(blockColor)};\n\n > span {\n position: relative;\n z-index: 1;\n }\n\n :before {\n content: '';\n position: absolute;\n top: 50%;\n left: 0;\n right: 0;\n height: 2px;\n margin-top: -1px;\n background: ${colorToString(blockColor)};\n }\n `\n default:\n return css`\n font-family: '${numberFont}';\n background: transparent;\n color: ${colorToString(numberColor)};\n padding-top: 0;\n padding-bottom: 0;\n `\n }\n },\n )}\n }\n\n ${Label} {\n ${p =>\n cssMediaRules(\n [p.labelColor, p.labelFont] as const,\n ([\n labelColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n labelFont = 'sans-serif',\n ]) => css`\n font-family: '${labelFont}';\n color: ${colorToString(labelColor)};\n `,\n )}\n }\n`\n\nconst getRemaining = (date: Props['date'] | undefined) => {\n if (date == null) return { days: 0, hours: 0, minutes: 0, seconds: 0 }\n\n const timeDiff = new Date(date).getTime() - Date.now()\n\n if (timeDiff <= 0) return { days: 0, hours: 0, minutes: 0, seconds: 0 }\n\n let delta = Math.abs(timeDiff) / 1000\n\n const days = Math.floor(delta / 86400)\n delta -= days * 86400\n\n const hours = Math.floor(delta / 3600) % 24\n delta -= hours * 3600\n\n const minutes = Math.floor(delta / 60) % 60\n delta -= minutes * 60\n\n const seconds = parseInt(String(delta % 60), 10)\n\n return { days, hours, minutes, seconds }\n}\n\nconst Countdown = forwardRef(function Countdown(\n {\n id,\n margin,\n width,\n date,\n variant,\n size,\n shape,\n gap,\n labelColor,\n labelFont,\n numberColor,\n numberFont,\n blockColor,\n daysLabel,\n hoursLabel,\n minutesLabel,\n secondsLabel,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const [{ days, hours, minutes, seconds }, setRemaining] = useState(getRemaining(date))\n\n useEffect(() => {\n setRemaining(getRemaining(date))\n\n const intervalId = setInterval(() => {\n setRemaining(getRemaining(date))\n }, 1000)\n\n return () => clearInterval(intervalId)\n }, [date])\n\n return (\n <Container\n ref={ref}\n id={id}\n className={cx(width)}\n margin={margin}\n variant={variant}\n size={size}\n shape={shape}\n labelColor={labelColor}\n labelFont={labelFont}\n numberColor={numberColor}\n numberFont={numberFont}\n blockColor={blockColor}\n gap={gap}\n >\n <Segment>\n <Block>\n <span>{days}</span>\n </Block>\n <Label>{daysLabel == null ? 'Days' : daysLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{hours}</span>\n </Block>\n <Label>{hoursLabel == null ? 'Hours' : hoursLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{minutes}</span>\n </Block>\n <Label>{minutesLabel == null ? 'Minutes' : minutesLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{seconds}</span>\n </Block>\n <Label>{secondsLabel == null ? 'Seconds' : secondsLabel}</Label>\n </Segment>\n </Container>\n )\n})\n\nexport default Countdown\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Countdown, {\n type: './components/Countdown/index.js',\n label: 'Countdown',\n icon: 'Countdown40',\n props: {\n id: Props.ElementID(),\n date: Props.Date(() => ({\n preset: new Date(Date.now() + 1000 * 60 * 60 * 24 * 2).toISOString(),\n })),\n variant: Props.ResponsiveIconRadioGroup({\n label: 'Style',\n options: [\n { label: 'Filled', value: 'filled', icon: 'CountdownSolid16' },\n {\n label: 'Filled split',\n value: 'filled-split',\n icon: 'CountdownSolidSplit16',\n },\n { label: 'Outline', value: 'outline', icon: 'CountdownOutline16' },\n {\n label: 'Outline split',\n value: 'outline-split',\n icon: 'CountdownOutlineSplit16',\n },\n { label: 'Clear', value: 'clear', icon: 'CountdownNaked16' },\n ],\n defaultValue: 'filled',\n }),\n shape: Props.ResponsiveIconRadioGroup({\n label: 'Shape',\n options: [\n { label: 'Pill', value: 'pill', icon: 'ButtonPill16' },\n { label: 'Rounded', value: 'rounded', icon: 'ButtonRounded16' },\n { label: 'Square', value: 'square', icon: 'ButtonSquare16' },\n ],\n defaultValue: 'rounded',\n }),\n size: Props.ResponsiveIconRadioGroup({\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n }),\n gap: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Gap',\n step: 1,\n min: 0,\n max: 100,\n defaultValue: { value: 0, unit: 'px' },\n }),\n numberFont: Props.Font({ label: 'Number font' }),\n numberColor: Props.ResponsiveColor({\n label: 'Number color',\n placeholder: 'white',\n }),\n blockColor: Props.ResponsiveColor({\n label: 'Block color',\n placeholder: 'black',\n }),\n labelFont: Props.Font({ label: 'Label font' }),\n labelColor: Props.ResponsiveColor({\n label: 'Label color',\n placeholder: 'black',\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 560, unit: 'px' },\n }),\n margin: Props.Margin(),\n daysLabel: Props.TextInput({ label: 'Days label', placeholder: 'Days' }),\n hoursLabel: Props.TextInput({ label: 'Hours label', placeholder: 'Hours' }),\n minutesLabel: Props.TextInput({\n label: 'Minutes label',\n placeholder: 'Minutes',\n }),\n secondsLabel: Props.TextInput({\n label: 'Seconds label',\n placeholder: 'Seconds',\n }),\n },\n })\n}\n","import { forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n MarginValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n} from '../../../prop-controllers/descriptors'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype DividerVariant = 'solid' | 'dashed' | 'dotted' | 'blended'\n\ntype Props = {\n id?: ElementIDValue\n variant?: ResponsiveSelectValue<DividerVariant>\n thickness?: ResponsiveLengthValue\n color?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n}\n\n// IE11 has a bug with Flexbox vertical centering with min height if height is not set.\n// Wrapping it in another flex container fixes it for some reason, read more here:\n// https://stackoverflow.com/questions/19371626/flexbox-not-centering-vertically-in-ie\nconst IE11MinHeightContainer = styled.div<{ margin: Props['margin'] }>`\n display: flex;\n width: 100%;\n ${cssMargin()}\n`\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n justify-content: center;\n min-height: 40px;\n width: 100%;\n`\n\nconst Line = styled.div<{\n variant: Props['variant']\n color?: ResponsiveValue<Color> | null\n thickness: Props['thickness']\n}>`\n ${p =>\n cssMediaRules(\n [p.variant, p.thickness, p.color] as const,\n ([\n variant = 'solid',\n thickness = { value: 1, unit: 'px' },\n color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => {\n switch (variant) {\n case 'solid':\n case 'dashed':\n case 'dotted':\n return css`\n border-bottom-width: ${thickness == null\n ? '1px'\n : `${thickness.value}${thickness.unit}`};\n border-bottom-style: ${variant};\n border-bottom-color: ${colorToString(color)};\n `\n\n case 'blended':\n return css`\n height: ${`${thickness.value}${thickness.unit}`};\n background: linear-gradient(\n ${[\n '90deg',\n colorToString({ swatch: color.swatch, alpha: 0 }),\n colorToString(color),\n colorToString({ swatch: color.swatch, alpha: 0 }),\n ].join(', ')}\n );\n `\n\n default:\n variant as never\n throw new Error(`Invalid variant ${variant}.`)\n }\n },\n )}\n`\n\nconst Divider = forwardRef(function Divider(\n { id, variant, thickness, color, width, margin }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <IE11MinHeightContainer ref={ref} id={id} className={cx(width)} margin={margin}>\n <Container>\n {/* @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop */}\n <Line variant={variant} thickness={thickness} color={color} />\n </Container>\n </IE11MinHeightContainer>\n )\n})\n\nexport default Divider\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Divider, {\n type: './components/Divider/index.js',\n label: 'Divider',\n icon: 'Divider40',\n props: {\n id: Props.ElementID(),\n variant: Props.ResponsiveSelect({\n label: 'Style',\n labelOrientation: 'horizontal',\n options: [\n { value: 'solid', label: 'Solid' },\n { value: 'dashed', label: 'Dashed' },\n { value: 'dotted', label: 'Dotted' },\n { value: 'blended', label: 'Blended' },\n ],\n defaultValue: 'solid',\n }),\n thickness: Props.ResponsiveLength({\n label: 'Height',\n defaultValue: { value: 1, unit: 'px' },\n options: [{ value: 'px', label: 'Pixels', icon: 'Px16' }],\n }),\n color: Props.ResponsiveColor({ placeholder: 'black' }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","/* eslint-env browser */\n\nimport { useState, useEffect, useLayoutEffect, forwardRef, Ref, useImperativeHandle } from 'react'\nimport styled from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { cssMargin } from '../../utils/cssMediaRules'\nimport { ElementIDValue, MarginValue, TextAreaValue } from '../../../prop-controllers/descriptors'\nimport { Props } from '../../../prop-controllers'\nimport { ReactRuntime } from '../../../react'\n\ntype Props = {\n id?: ElementIDValue\n html?: TextAreaValue\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.div<{ margin: Props['margin'] }>`\n min-height: 15px;\n ${cssMargin()}\n`\n\nconst defaultHtml = `<div style=\"padding: 24px; background-color: rgba(161, 168, 194, 0.18); overflow: hidden;\">\n<svg width=\"316\" height=\"168\" viewBox=\"0 0 316 168\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<rect width=\"70\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"78\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"116\" width=\"78\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect y=\"20\" width=\"120\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"128\" y=\"20\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"166\" y=\"20\" width=\"78\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect y=\"60\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"20\" y=\"80\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"40\" y=\"100\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"88\" y=\"100\" width=\"110\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"206\" y=\"100\" width=\"24\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"238\" y=\"100\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"40\" y=\"120\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"88\" y=\"120\" width=\"50\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"146\" y=\"120\" width=\"24\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"178\" y=\"120\" width=\"90\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"276\" y=\"120\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"20\" y=\"140\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect y=\"160\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n</svg>\n</div>`\nconst SCRIPT_TAG = 'script'\n\nconst Embed = forwardRef(function Embed(\n { id, width, margin, html = defaultHtml }: Props,\n ref: Ref<HTMLDivElement | null>,\n) {\n const [container, setContainer] = useState<HTMLDivElement | null>(null)\n const [shouldRender, setShouldRender] = useState(false)\n\n useLayoutEffect(() => {\n setShouldRender(true)\n }, [])\n\n useImperativeHandle(ref, () => container, [container])\n\n useEffect(() => {\n // TODO: When we SSR the editor, we can remove the editor check\n // and not run this effect on the first render.\n if (!container) return\n\n const walker = container.ownerDocument.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {\n acceptNode(node: Element) {\n return node.tagName.toLowerCase() === SCRIPT_TAG\n ? NodeFilter.FILTER_ACCEPT\n : NodeFilter.FILTER_REJECT\n },\n })\n\n const nodes: Element[] = []\n\n while (walker.nextNode()) nodes.push(walker.currentNode as Element)\n\n // By default scripts appended dynamically will execute asyncrhonously. Here we ensure that\n // scripts are loaded synchronously since that's what a user usually expects with scripts in\n // embedded in HTML which usually comes from the server.\n //\n // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script#notes\n async function executeScriptsInOrder() {\n for (let i = 0; i < nodes.length; i++) {\n await new Promise<void>(resolve => {\n const node = nodes[i]\n const script = node.ownerDocument.createElement(SCRIPT_TAG)\n\n script.textContent = node.textContent\n Array.from(node.attributes).forEach(({ name, value }) => {\n script.setAttribute(name, value)\n })\n\n script.onload = () => resolve()\n script.onerror = () => resolve()\n\n node.parentNode?.insertBefore(script, node)\n node.parentNode?.removeChild(node)\n\n if (!script.hasAttribute('src')) resolve()\n })\n }\n }\n\n executeScriptsInOrder().catch(error => {\n // Ignore errors from user-provided code\n console.error(error)\n })\n }, [container, html])\n\n if (shouldRender === false) return null\n\n return (\n <Container\n ref={setContainer}\n id={id}\n className={cx(width)}\n margin={margin}\n dangerouslySetInnerHTML={{ __html: html }}\n />\n )\n})\n\nexport default Embed\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Embed, {\n type: './components/Embed/index.js',\n label: 'Embed',\n icon: 'Code40',\n props: {\n id: Props.ElementID(),\n html: Props.TextArea({ label: 'Code', rows: 20 }),\n width: Props.Width({ format: Props.Width.Formats.ClassName }),\n margin: Props.Margin(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHZpZXdCb3g9IjAgMCAxMiAxMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMS43MDcxIDEuNzkyODlDMTIuMDk3NiAyLjE4MzQyIDEyLjA5NzYgMi44MTY1OCAxMS43MDcxIDMuMjA3MTFMNC43MDcxMSAxMC4yMDcxQzQuMzE2NTggMTAuNTk3NiAzLjY4MzQyIDEwLjU5NzYgMy4yOTI4OSAxMC4yMDcxTDAuMjkyODkzIDcuMjA3MTFDLTAuMDk3NjMxMSA2LjgxNjU4IC0wLjA5NzYzMTEgNi4xODM0MiAwLjI5Mjg5MyA1Ljc5Mjg5QzAuNjgzNDE3IDUuNDAyMzcgMS4zMTY1OCA1LjQwMjM3IDEuNzA3MTEgNS43OTI4OUw0IDguMDg1NzlMMTAuMjkyOSAxLjc5Mjg5QzEwLjY4MzQgMS40MDIzNyAxMS4zMTY2IDEuNDAyMzcgMTEuNzA3MSAxLjc5Mjg5WiIvPgo8L3N2Zz4K\"","import { createContext, useContext } from 'react'\n\nimport { ResponsiveValue, TextStyleValue } from '../../../../prop-controllers/descriptors'\nimport { ResponsiveColor } from '../../../../runtimes/react/controls'\nimport { ColorValue } from '../../../utils/types'\n\nexport const Shapes = Object.freeze({\n SQUARE: 'square',\n ROUNDED: 'rounded',\n PILL: 'pill',\n} as const)\n\nexport type Shape = typeof Shapes[keyof typeof Shapes]\n\nexport const Sizes = Object.freeze({\n SMALL: 'small',\n MEDIUM: 'medium',\n LARGE: 'large',\n} as const)\n\nexport type Size = typeof Sizes[keyof typeof Sizes]\n\nexport const Contrasts = Object.freeze({\n LIGHT: 'light',\n DARK: 'dark',\n} as const)\n\nexport type Contrast = typeof Contrasts[keyof typeof Contrasts]\n\nexport type Value = {\n shape: ResponsiveValue<Shape> | null | undefined\n size: ResponsiveValue<Size> | null | undefined\n contrast: ResponsiveValue<Contrast> | null | undefined\n brandColor: ResponsiveValue<ColorValue> | null | undefined\n labelTextStyle?: TextStyleValue\n labelTextColor?: ResponsiveColor | null\n}\n\nconst Context = createContext<Value>({} as Value)\n\nexport function useFormContext(): Value {\n return useContext(Context)\n}\n\nconst { Provider } = Context\n\nexport { Provider }\n","import { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../utils/colorToString'\n\nimport {\n Size,\n Shape,\n Contrast,\n Shapes,\n Sizes,\n Contrasts,\n Value,\n} from '../../../context/FormContext'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 30\n\n case Sizes.MEDIUM:\n return 38\n\n case Sizes.LARGE:\n return 48\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport function getSizeHorizontalPadding(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 8\n\n case Sizes.MEDIUM:\n return 12\n\n case Sizes.LARGE:\n return 16\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nfunction getSizeVerticalPadding(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 3\n\n case Sizes.MEDIUM:\n return 7\n\n case Sizes.LARGE:\n return 11\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport function getShapeBorderRadius(shape: Shape): number {\n switch (shape) {\n case Shapes.SQUARE:\n return 0\n\n case Shapes.ROUNDED:\n return 4\n\n case Shapes.PILL:\n return 500\n\n default:\n throw new Error(`Invalid form shape \"${shape}\"`)\n }\n}\n\nexport function getContrastBorderColor(contrast: Contrast, error?: boolean): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return error ? 'rgba(255, 0, 0, 0.7)' : 'rgba(0, 0, 0, 0.25)'\n\n case Contrasts.DARK:\n return error ? 'rgba(255, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.6)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport function getContrastBackgroundColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'white'\n\n case Contrasts.DARK:\n return 'rgba(0, 0, 0, 0.7)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport function getContrastColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.95)'\n\n case Contrasts.DARK:\n return 'white'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nfunction getContrastPlaceholderColor(contrast: Contrast) {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.3)'\n\n case Contrasts.DARK:\n return 'rgba(255,255,255,0.3)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport default function cssField() {\n return css<Pick<Value, 'shape' | 'size' | 'contrast' | 'brandColor'> & { error?: boolean }>`\n display: block;\n width: 100%;\n outline: none;\n border-width: 1px;\n border-style: solid;\n transition: border-color 200ms;\n ${props =>\n cssMediaRules(\n [props.shape, props.size, props.contrast, props.brandColor] as const,\n ([\n shape = Shapes.ROUNDED,\n size = Sizes.MEDIUM,\n contrast = Contrasts.LIGHT,\n brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => css`\n padding: ${getSizeVerticalPadding(size)}px ${getSizeHorizontalPadding(size)}px;\n border-radius: ${getShapeBorderRadius(shape)}px;\n border-color: ${getContrastBorderColor(contrast, props.error)};\n color: ${getContrastColor(contrast)};\n background-color: ${getContrastBackgroundColor(contrast)};\n\n :focus,\n :focus-within {\n border-color: ${colorToString(brandColor)};\n }\n\n ::placeholder {\n color: ${getContrastPlaceholderColor(contrast)};\n }\n `,\n )}\n `\n}\n","import { ComponentPropsWithoutRef, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { Size, useFormContext, Sizes, Value } from '../../../../context/FormContext'\nimport cssField from '../../services/cssField'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 36\n\n case Sizes.MEDIUM:\n return 42\n\n case Sizes.LARGE:\n return 48\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nconst Base = styled.input<\n Pick<Value, 'shape' | 'size' | 'contrast' | 'brandColor'> & { error?: boolean }\n>`\n ${cssField()}\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n min-height: ${getSizeHeight(size)}px;\n max-height: ${getSizeHeight(size)}px;\n `,\n )}\n`\n\ntype BaseProps = { error?: boolean; form?: unknown }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Base>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function Input(\n { error = false, form, ...restOfProps }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <Base\n {...restOfProps}\n ref={ref}\n error={error}\n shape={shape}\n // @ts-expect-error: HTMLInputEleent `size` attribute conflicts with prop\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n )\n})\n","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\n\nimport { MarginValue, WidthValue } from '../../../../../prop-controllers/descriptors'\nimport { cssMargin } from '../../../../utils/cssMediaRules'\n\nconst Container = styled.div<{\n width?: WidthValue\n margin?: MarginValue\n}>`\n display: flex;\n flex-direction: column;\n ${cssMargin()};\n`\n\nconst Label = styled.div`\n max-width: 120px;\n min-width: 60px;\n height: 8px;\n border-radius: 2px;\n background-color: #a1a8c2;\n opacity: 0.4;\n margin-bottom: 8px;\n`\n\nconst Input = styled.div`\n min-width: 80px;\n height: 32px;\n border-radius: 4px;\n border-width: 2px;\n border-style: solid;\n border-color: #a1a8c2;\n opacity: 0.4;\n`\n\nconst Button = styled.div`\n min-width: 140px;\n height: 32px;\n border-radius: 4px;\n background-color: #a1a8c2;\n opacity: 0.4;\n`\n\ntype Props = {\n className?: string\n margin?: MarginValue\n}\n\nexport default forwardRef(function Placeholder(\n { className, margin }: Props,\n ref: Ref<HTMLDivElement>,\n): JSX.Element {\n return (\n <Container ref={ref} className={className} margin={margin}>\n <div style={{ display: 'flex', flexDirection: 'column', marginBottom: 16 }}>\n <Label />\n <Input />\n </div>\n <div style={{ display: 'flex', flexDirection: 'column', marginBottom: 16 }}>\n <Label />\n <Input />\n </div>\n <div style={{ display: 'flex', flexDirection: 'column', justifyContent: 'flex-end' }}>\n <Button />\n </div>\n </Container>\n )\n})\n","import { ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport { ResponsiveValue } from '../../../../../../../prop-controllers'\nimport { TextStyleValue } from '../../../../../../../prop-controllers/descriptors'\nimport { cssMediaRules, cssTextStyle } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\n\nimport { useFormContext, Size, Sizes, Contrast, Contrasts } from '../../../../context/FormContext'\nimport { ColorValue } from '../../../../../../utils/types'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 14\n\n case Sizes.MEDIUM:\n return 18\n\n case Sizes.LARGE:\n return 22\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nfunction getContrastColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.8)'\n\n case Contrasts.DARK:\n return 'rgba(255, 255, 255, 0.95)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nconst Base = styled.label<{\n contrast?: ResponsiveValue<Contrast> | null | undefined\n size?: ResponsiveValue<Size> | null | undefined\n textStyle?: TextStyleValue | null | undefined\n textColor?: ResponsiveValue<ColorValue> | null | undefined\n}>`\n display: block;\n margin: 0 0 0.25em 0;\n ${cssTextStyle()}\n ${props =>\n cssMediaRules(\n [props.size, props.contrast, props.textColor] as const,\n ([size = Sizes.MEDIUM, contrast = Contrasts.LIGHT, textColor]) => css`\n min-height: ${getSizeHeight(size)}px;\n color: ${textColor == null ? getContrastColor(contrast) : colorToString(textColor)};\n `,\n )}\n`\n\ntype Props = ComponentPropsWithoutRef<typeof Base>\n\nexport default function Label(props: Props): JSX.Element {\n const { contrast, size, labelTextStyle, labelTextColor } = useFormContext()\n\n return (\n <Base\n {...props}\n contrast={contrast}\n size={size}\n textStyle={labelTextStyle}\n textColor={labelTextColor}\n />\n )\n}\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function SingleLineTextTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"text\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef, ComponentPropsWithoutRef } from 'react'\nimport styled from 'styled-components'\n\nimport cssField from '../../services/cssField'\nimport { Value, useFormContext } from '../../../../context/FormContext'\n\nconst Base = styled.textarea<Value & { error?: boolean }>`\n resize: vertical;\n ${cssField()}\n`\n\ntype BaseProps = { error?: boolean; form?: unknown }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Base>, keyof BaseProps>\n\nexport default forwardRef<HTMLTextAreaElement, Props>(function TextArea(\n { error = false, form, ...restOfProps }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <Base\n {...restOfProps}\n ref={ref}\n rows={4}\n error={error}\n shape={shape}\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport TextArea from '../TextArea'\n\ntype Props = {\n id: string\n label?: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLTextAreaElement, Props>(function LongTextTableField(\n { id, label = '', error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <TextArea {...restOfProps} aria-label={label} ref={ref} id={id} error={error != null} />\n </>\n )\n})\n","import { forwardRef, CSSProperties, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport Color from 'color'\n\nimport { getSizeHeight as getSize } from '../Label'\nimport {\n useFormContext,\n Value as FormContextValue,\n Sizes,\n Contrasts,\n} from '../../../../context/FormContext'\nimport { getContrastBorderColor, getContrastBackgroundColor } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { SwatchValue } from '../../../../../../utils/types'\n\nfunction getCheckmarkColor({\n swatch: { hue: h, saturation: s, lightness: l },\n alpha: a,\n}: {\n swatch: SwatchValue\n alpha: number\n}) {\n return Color({ h, s, l }).alpha(a).isLight() ? 'rgba(0, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.95)'\n}\n\nconst Container = styled.div<Pick<FormContextValue, 'size'>>`\n position: relative;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n height: ${getSize(size)}px;\n width: ${getSize(size)}px;\n `,\n )}\n`\n\nconst FakeCheckbox = styled.div<Pick<FormContextValue, 'contrast'> & { error?: boolean }>`\n position: absolute;\n width: 100%;\n height: 100%;\n border-style: solid;\n border-radius: 4px;\n pointer-events: none;\n border-width: 1px;\n ${props =>\n cssMediaRules(\n [props.contrast] as const,\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n background-color: ${getContrastBackgroundColor(contrast)};\n `,\n )}\n`\n\nconst HiddenCheckbox = styled.input<\n Pick<FormContextValue, 'size' | 'brandColor' | 'contrast'> & {\n error?: boolean\n }\n>`\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n\n &:disabled {\n cursor: no-drop;\n\n & ~ ${FakeCheckbox} {\n opacity: 0.5;\n }\n }\n\n &:checked ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([{ swatch = { hue: 0, saturation: 0, lightness: 0 }, alpha = 1 } = {}]) => css`\n background-color: ${colorToString({ swatch, alpha })};\n `,\n )}\n border-color: transparent;\n\n &::after {\n content: '';\n position: absolute;\n box-sizing: content-box;\n width: 25%;\n height: 50%;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n border-width: ${getSize(size) * 0.1}px;\n border-left: 0;\n border-top: 0;\n `,\n )}\n border-style: solid;\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([{ swatch = { hue: 0, saturation: 0, lightness: 0 }, alpha = 1 } = {}]) => css`\n border-color: ${getCheckmarkColor({ swatch, alpha })};\n `,\n )}\n transform: rotate(45deg) translate3d(91%, -23%, 0);\n }\n }\n\n &:not(:disabled) {\n &:focus ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.brandColor],\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n border-color: ${colorToString(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled):checked {\n &:focus ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.contrast],\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n `,\n )}\n }\n }\n`\n\ntype BaseProps = {\n error?: boolean\n className?: string\n style?: CSSProperties\n form?: unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof HiddenCheckbox>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function Checkbox(\n { error, className, style, form, ...restOfProps }: Props,\n ref,\n) {\n const { size, contrast, brandColor } = useFormContext()\n\n return (\n <Container size={size}>\n <HiddenCheckbox\n {...restOfProps}\n type=\"checkbox\"\n ref={ref}\n error={error}\n // @ts-expect-error: HTMLInputElement `size` attribute conflicts with prop\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n <FakeCheckbox className={className} error={error} contrast={contrast} style={style} />\n </Container>\n )\n})\n","import { forwardRef, SyntheticEvent } from 'react'\nimport styled, { css } from 'styled-components'\nimport { FormikProps } from 'formik'\n\nimport { useFormContext, Sizes, Value } from '../../../../context/FormContext'\nimport Label from '../Label'\nimport { getSizeHeight as getInputSizeHeight } from '../Input'\nimport Checkbox from '../Checkbox'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\n\nconst StyledLabel = styled(Label)<Pick<Value, 'size'>>`\n display: flex;\n align-items: center;\n margin: 0;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n `,\n )}\n`\n\nconst CheckboxContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n form: FormikProps<{\n [key: string]: boolean\n }>\n id: string\n label?: string\n name: string\n value?: boolean\n error?: string\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function CheckboxTableField(\n { form, id, name, label = '', value = false, error, ...restOfProps }: Props,\n ref,\n) {\n const { size } = useFormContext()\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n form.setFieldValue(name, event.currentTarget.checked)\n }\n\n return (\n <StyledLabel htmlFor={id} size={size}>\n <CheckboxContainer>\n <Checkbox\n {...restOfProps}\n aria-label={label}\n checked={value}\n onChange={handleChange}\n ref={ref}\n id={id}\n error={error != null}\n />\n </CheckboxContainer>\n {label}\n </StyledLabel>\n )\n})\n","import { forwardRef, useRef, useImperativeHandle, SyntheticEvent } from 'react'\nimport styled from 'styled-components'\n\nimport Label from '../Label'\nimport Checkbox from '../Checkbox'\n\nconst MainLabel = styled(Label)`\n margin: 0 0 4px 0;\n`\n\nconst StyledLabel = styled(Label)`\n display: flex;\n align-items: center;\n margin: 8px 0;\n\n &:last-of-type {\n margin-bottom: 0;\n }\n`\n\nconst CheckboxContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n value?: Array<string>\n label?: string\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n hideLabel?: boolean\n}\n\nexport default forwardRef<\n {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n },\n Props\n>(function MultipleSelectTableField(\n {\n tableColumn,\n label = '',\n required,\n value = [],\n onChange,\n hideLabel = false,\n ...restOfProps\n }: Props,\n ref,\n) {\n const handle = useRef({\n validity: { valueMissing: required === true && value.length === 0, typeMismatch: false },\n })\n\n useImperativeHandle(ref, () => handle.current, [])\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n handle.current.validity.valueMissing =\n required === true &&\n !event.currentTarget.checked &&\n value.filter(v => v !== event.currentTarget.value).length === 0\n\n onChange(event)\n }\n\n return (\n <div>\n {!hideLabel && <MainLabel>{label}</MainLabel>}\n {tableColumn.options.map(option => (\n <StyledLabel key={option.id} htmlFor={option.id}>\n <CheckboxContainer>\n <Checkbox\n {...restOfProps}\n aria-label={label}\n onChange={handleChange}\n checked={value.includes(option.name)}\n id={option.id}\n value={option.name}\n />\n </CheckboxContainer>\n {option.name}\n </StyledLabel>\n ))}\n </div>\n )\n})\n","import { forwardRef, CSSProperties, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport Color from 'color'\n\nimport { getSizeHeight as getSize } from '../Label'\nimport { useFormContext, Sizes, Contrasts, Value } from '../../../../context/FormContext'\nimport { getContrastBorderColor, getContrastBackgroundColor } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { ColorValue } from '../../../../../../utils/types'\n\nfunction getCheckmarkColor({\n swatch: { hue: h, saturation: s, lightness: l } = { hue: 0, saturation: 0, lightness: 0 },\n alpha: a,\n}: ColorValue) {\n return Color({ h, s, l }).alpha(a).isLight() ? 'rgba(0, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.95)'\n}\n\nconst Container = styled.div<Pick<Value, 'size'>>`\n position: relative;\n ${props =>\n cssMediaRules(\n [props.size],\n ([size = Sizes.MEDIUM]) => css`\n height: ${getSize(size)}px;\n width: ${getSize(size)}px;\n `,\n )}\n`\n\nconst FakeRadioButton = styled.div<Pick<Value, 'contrast'> & { error?: boolean }>`\n position: absolute;\n width: 100%;\n height: 100%;\n border-style: solid;\n border-radius: 50%;\n pointer-events: none;\n border-width: 1px;\n ${props =>\n cssMediaRules(\n [props.contrast],\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n background-color: ${getContrastBackgroundColor(contrast)};\n `,\n )}\n`\n\nconst HiddenRadioButton = styled.input.attrs({ type: 'radio' })<\n Pick<Value, 'brandColor' | 'contrast'> & { error?: boolean }\n>`\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n\n &:disabled {\n cursor: no-drop;\n\n & ~ ${FakeRadioButton} {\n opacity: 0.5;\n }\n }\n\n &:checked ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n background-color: ${colorToString(brandColor)};\n `,\n )}\n border-color: transparent;\n\n &::after {\n content: '';\n position: absolute;\n box-sizing: content-box;\n top: 50%;\n left: 50%;\n width: 50%;\n height: 50%;\n border-radius: 50%;\n transform: translate(-50%, -50%);\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n background-color: ${getCheckmarkColor(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled) {\n &:focus ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n border-color: ${colorToString(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled):checked {\n &:focus ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.contrast] as const,\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n `,\n )}\n }\n }\n`\n\ntype BaseProps = {\n error?: boolean\n className?: string\n style?: CSSProperties\n form?: unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof HiddenRadioButton>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function RadioButton(\n { error, className, style, form, ...restOfProps }: Props,\n ref,\n) {\n const { size, contrast, brandColor } = useFormContext()\n\n return (\n <Container size={size}>\n <HiddenRadioButton\n {...restOfProps}\n ref={ref}\n error={error}\n contrast={contrast}\n brandColor={brandColor}\n />\n <FakeRadioButton className={className} error={error} contrast={contrast} style={style} />\n </Container>\n )\n})\n","import { forwardRef, useRef, useImperativeHandle, SyntheticEvent } from 'react'\nimport styled from 'styled-components'\n\nimport Label from '../../../Label'\nimport RadioButton from '../../../RadioButton'\n\nconst StyledLabel = styled(Label)`\n display: flex;\n align-items: center;\n margin: 8px 0;\n\n &:last-of-type {\n margin-bottom: 0;\n }\n`\n\nconst RadioButtonContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n label?: string\n value?: string\n hideLabel?: boolean\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n}\n\nexport default forwardRef<\n {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n },\n Props\n>(function TableColumnRadioButtonGroup(\n {\n tableColumn,\n label = '',\n value = '',\n required = false,\n hideLabel = false,\n onChange,\n ...restOfProps\n }: Props,\n ref,\n) {\n const handle = useRef({\n validity: { valueMissing: required === true && value === '', typeMismatch: false },\n })\n\n useImperativeHandle(ref, () => handle.current, [])\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n handle.current.validity.valueMissing = required === true && !event.currentTarget.checked\n\n onChange(event)\n }\n\n return (\n <div>\n {!hideLabel && <Label as=\"p\">{label}</Label>}\n {tableColumn.options.map(option => (\n <StyledLabel key={option.id} htmlFor={option.id} aria-label={label}>\n <RadioButtonContainer>\n <RadioButton\n {...restOfProps}\n onChange={handleChange}\n checked={value === option.name}\n id={option.id}\n value={option.name}\n />\n </RadioButtonContainer>\n {option.name}\n </StyledLabel>\n ))}\n </div>\n )\n})\n","import { forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../../../utils/cssMediaRules'\nimport { useFormContext, Sizes, Contrasts, Value } from '../../../../../../context/FormContext'\nimport cssField, {\n getSizeHeight,\n getSizeHorizontalPadding,\n getContrastColor,\n} from '../../../../services/cssField'\nimport Label from '../../../Label'\n\nconst Container = styled.div<Value & { error?: boolean }>`\n ${cssField()}\n display: flex;\n align-items: center;\n position: relative;\n user-select: none;\n border-color: #f19eb9;\n\n &:focus,\n &:focus-within {\n border-color: #e54e7f;\n }\n\n ${props =>\n cssMediaRules(\n [props.size, props.contrast] as const,\n ([size = Sizes.MEDIUM, contrast = Contrasts.LIGHT]) => css`\n min-height: ${getSizeHeight(size)}px;\n max-height: ${getSizeHeight(size)}px;\n\n &::after {\n content: '';\n position: absolute;\n right: ${getSizeHorizontalPadding(size)}px;\n top: 50%;\n transform: translate3d(0, -25%, 0);\n border: solid 0.35em transparent;\n border-top-color: ${getContrastColor(contrast)};\n }\n `,\n )}\n`\n\nconst Select = styled.select`\n appearance: none;\n position: absolute;\n top: 0;\n left: 0;\n opacity: 0;\n width: 100%;\n height: 100%;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n value?: string\n label?: string\n required?: boolean\n error?: boolean\n hideLabel?: boolean\n form?: unknown\n}\n\nexport default forwardRef<HTMLSelectElement, Props>(function TableColumnSingleSelect(\n {\n id,\n tableColumn,\n value = '',\n label = '',\n error = false,\n hideLabel = false,\n form,\n ...restOfProps\n }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Container\n error={error}\n shape={shape}\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n >\n <span>{value === '' ? '-' : value}</span>\n <Select {...restOfProps} aria-label={label} ref={ref} id={id} value={value}>\n <option value=\"\">-</option>\n {tableColumn.options.map(option => (\n <option key={option.id} value={option.name}>\n {option.name}\n </option>\n ))}\n </Select>\n </Container>\n </>\n )\n})\n","import { forwardRef, SyntheticEvent } from 'react'\n\nimport TableColumnRadioButtonGroup from './components/TableColumnRadioButtonGroup'\nimport TableColumnSingleSelect from './components/TableColumnSingleSelect'\n\ntype Props = {\n id: string\n name: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n label?: string\n value?: string\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n type: 'select' | 'radio'\n}\n\nexport default forwardRef<\n {\n readonly validity: {\n readonly valueMissing: boolean\n readonly typeMismatch: boolean\n }\n },\n Props\n>(function SingleSelectTableField({ type, ...restOfProps }: Props, ref) {\n return type === 'select' ? (\n // @ts-expect-error: custom ref doesn't match select element\n <TableColumnSingleSelect {...restOfProps} ref={ref} />\n ) : (\n <TableColumnRadioButtonGroup {...restOfProps} ref={ref} />\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function PhoneNumberTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"tel\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function EmailTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"email\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function URLTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"url\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function NumberTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"number\"\n error={error != null}\n />\n </>\n )\n})\n","import styled, { css } from 'styled-components'\n\nimport { useFormContext, Sizes, Shapes, Value } from '../../../../context/FormContext'\nimport { getSizeHeight as getLabelSizeHeight } from '../Label'\nimport { getSizeHeight as getInputSizeHeight } from '../Input'\nimport { getShapeBorderRadius } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\n\nconst Label = styled.div<Pick<Value, 'size'>>`\n display: block;\n max-width: 120px;\n min-width: 60px;\n border-radius: 2px;\n background-color: #5f49f4;\n opacity: 0.4;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n margin: calc(0.25 * ${getLabelSizeHeight(size)}px + 2px) 0;\n min-height: ${0.5 * getLabelSizeHeight(size)}px;\n max-height: ${0.5 * getLabelSizeHeight(size)}px;\n `,\n )}\n`\n\nconst Input = styled.div<Pick<Value, 'shape' | 'size'>>`\n display: block;\n width: 100%;\n border-width: 2px;\n border-style: solid;\n border-color: #5f49f4;\n opacity: 0.4;\n ${props =>\n cssMediaRules(\n [props.shape, props.size] as const,\n ([shape = Shapes.ROUNDED, size = Sizes.MEDIUM]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n border-radius: ${getShapeBorderRadius(shape)}px;\n `,\n )}\n`\n\nexport default function PlaceholderTableField(): JSX.Element {\n const { size, shape } = useFormContext()\n\n return (\n <>\n <Label size={size} />\n <Input shape={shape} size={size} />\n </>\n )\n}\n","import { useRef } from 'react'\nimport { Field as FormikField, getIn } from 'formik'\n\nimport SingleLineTextTableField from './components/SingleLineTextTableField'\nimport LongTextTableField from './components/LongTextTableField'\nimport CheckboxTableField from './components/CheckboxTableField'\nimport MultipleSelectTableField from './components/MultipleSelectTableField'\nimport SingleSelectTableField from './components/SingleSelectTableField'\nimport PhoneNumberTableField from './components/PhoneNumberTableField'\nimport EmailTableField from './components/EmailTableField'\nimport URLTableField from './components/URLTableField'\nimport NumberTableField from './components/NumberTableField'\nimport PlaceholderTableField from './components/PlaceholderTableField'\nimport { TableColumn } from '../../../../hooks'\n\nfunction getTypeMismatchErrorMessage(tableColumn: TableColumn | null | undefined, label: string) {\n switch ((tableColumn || {}).__typename) {\n case 'PhoneNumberTableColumn':\n return `${label} field must be a valid phone number.`\n\n case 'EmailTableColumn':\n return `${label} field must be a valid email.`\n\n case 'URLTableColumn':\n return `${label} field must be a valid URL.`\n\n case 'NumberTableColumn':\n return `${label} field must be a valid number.`\n\n case 'SingleLineTextTableColumn':\n case 'LongTextTableColumn':\n case 'CheckboxTableColumn':\n default:\n return `${label} field is invalid.`\n }\n}\n\nfunction getTableColumnField(tableColumn: TableColumn | null | undefined) {\n switch ((tableColumn || {}).__typename) {\n case 'SingleLineTextTableColumn':\n return SingleLineTextTableField\n\n case 'LongTextTableColumn':\n return LongTextTableField\n\n case 'CheckboxTableColumn':\n return CheckboxTableField\n\n case 'MultipleSelectTableColumn':\n return MultipleSelectTableField\n\n case 'SingleSelectTableColumn':\n return SingleSelectTableField\n\n case 'PhoneNumberTableColumn':\n return PhoneNumberTableField\n\n case 'EmailTableColumn':\n return EmailTableField\n\n case 'URLTableColumn':\n return URLTableField\n\n case 'NumberTableColumn':\n return NumberTableField\n\n default:\n return SingleLineTextTableField\n }\n}\n\ntype TableFormField = {\n id: string\n tableColumnId: string\n label?: string\n placeholder?: string\n required?: boolean\n hidden?: boolean\n type?: 'select' | 'radio'\n hideLabel?: boolean\n}\n\ntype Props = {\n tableColumn: TableColumn | null | undefined\n tableFormField: TableFormField\n}\n\nexport default function Field({\n tableColumn,\n tableFormField: {\n id,\n label = '',\n placeholder,\n required = false,\n hidden = false,\n type = 'radio',\n hideLabel = false,\n },\n}: Props): JSX.Element {\n const TableColumnField = getTableColumnField(tableColumn)\n const input = useRef<\n | {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n }\n | null\n | undefined\n >(null)\n\n if (!tableColumn) return <PlaceholderTableField />\n\n function validate() {\n let errorMessage\n\n if (input.current) {\n const { validity = {} as ValidityState } = input.current\n\n if (validity.valueMissing) errorMessage = `${label} is required.`\n\n if (validity.typeMismatch) errorMessage = getTypeMismatchErrorMessage(tableColumn, label)\n }\n\n return errorMessage\n }\n\n return (\n <FormikField name={tableColumn.name} validate={validate}>\n {({ field, form }: any) =>\n hidden ? (\n <input {...field} ref={input} type=\"hidden\" />\n ) : (\n <TableColumnField\n {...field}\n type={type}\n form={form}\n tableColumn={tableColumn}\n ref={input}\n id={id}\n error={getIn(form.touched, field.name) && getIn(form.errors, field.name)}\n label={label}\n placeholder={placeholder}\n required={required}\n hideLabel={hideLabel}\n />\n )\n }\n </FormikField>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+CiAgPGcgZmlsbD0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIyIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxIDEpIj4KICAgIDxjaXJjbGUgc3Ryb2tlPSJjdXJyZW50Q29sb3IiIGN4PSI5IiBjeT0iOSIgcj0iOSIgc3Ryb2tlLW9wYWNpdHk9Ii40Ii8+CiAgICA8cGF0aCBzdHJva2UtbGluZWNhcD0icm91bmQiIGQ9Ik05IDE4QTkgOSAwIDAgMCA5IDAiLz4KICA8L2c+Cjwvc3ZnPgo=\"","import styled, { keyframes } from 'styled-components'\n\nimport { ReactComponent as Spinner20 } from '../../../../icons/spinner-20.svg'\n\nconst spin = keyframes`\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n`\n\nconst Icon = styled(Spinner20)`\n display: inline-flex;\n animation: ${spin} 1s linear infinite;\n stroke: currentColor;\n`\n\nexport default function Spinner(): JSX.Element {\n return <Icon />\n}\n","import { useState, useEffect, useMemo } from 'react'\nimport { getBox } from '../../box-model'\nimport { TableFormFieldsPropController } from '../../prop-controllers/instances'\nimport { useIsInBuilder } from '../../react'\n\nexport function useTableFormFieldRefs(\n propController: TableFormFieldsPropController | null | undefined,\n { fieldsCount }: { fieldsCount: number },\n): {\n container: (arg0: HTMLElement | null | undefined) => void\n items: Array<(arg0: HTMLElement | null | undefined) => void>\n} {\n const [container, setContainer] = useState<HTMLElement | null | undefined>(null)\n const [items, setItems] = useState<Array<HTMLElement | null | undefined>>(\n Array(fieldsCount + 1).fill(null),\n )\n\n const isInBuilder = useIsInBuilder()\n\n useEffect(() => {\n if (!isInBuilder) return\n\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n if (propController == null) return\n\n if (container != null) propController.tableFormLayoutChange({ layout: getBox(container) })\n\n items.map((item, index) => {\n if (item == null) return\n\n propController.tableFormFieldLayoutChange({ index, layout: getBox(item) })\n })\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }, [propController, container, items, isInBuilder])\n\n const itemRefs = useMemo(\n () =>\n Array.from({ length: fieldsCount + 1 }).map(\n (_, index) => (item: HTMLElement | null | undefined) => {\n setItems(is => [...is.slice(0, index), item, ...is.slice(index + 1)])\n },\n ),\n [fieldsCount, setItems],\n )\n\n return { container: setContainer, items: itemRefs }\n}\n","import {\n useState,\n useEffect,\n useRef,\n useMemo,\n forwardRef,\n ComponentPropsWithoutRef,\n Ref,\n useImperativeHandle,\n} from 'react'\nimport styled, { css } from 'styled-components'\nimport { Formik, getIn } from 'formik'\nimport { cx } from '@emotion/css'\n\nimport { ReactComponent as Check12 } from '../../icons/check-12.svg'\n\nimport { getSizeHeight as getInputSizeHeight } from './components/Field/components/Input'\n\nimport {\n Size,\n Sizes,\n Provider as FormContextProvider,\n Shape,\n Contrast,\n Shapes,\n Contrasts,\n} from './context/FormContext'\nimport Placeholder from './components/Placeholder'\nimport Field from './components/Field'\nimport Spinner from './components/Spinner'\nimport Button from '../Button'\nimport { TableColumn, useTable } from '../../hooks'\nimport { cssGridItem, cssMargin, cssMediaRules } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n GapYValue,\n LinkValue,\n MarginValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n TableFormFieldsDescriptor,\n TableFormFieldsValue,\n TableValue,\n TextInputValue,\n TextStyleValue,\n} from '../../../prop-controllers/descriptors'\nimport { Link } from '../../shared/Link'\nimport { BoxModelHandle, getBox } from '../../../box-model'\nimport { PropControllersHandle } from '../../../state/modules/prop-controller-handles'\nimport { DescriptorsPropControllers } from '../../../prop-controllers/instances'\nimport { useTableFormFieldRefs } from '../../hooks/useTableFormFieldRefs'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { useMutation, gql } from '../../../api/react'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\n\nconst LOCAL_STORAGE_NAMESPACE = '@@makeswift/components/form'\n\nfunction getSizeFontSize(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 12\n\n case Sizes.MEDIUM:\n return 14\n\n case Sizes.LARGE:\n return 18\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport const Alignments = {\n LEFT: 'left',\n CENTER: 'center',\n RIGHT: 'right',\n} as const\n\nexport type Alignment = typeof Alignments[keyof typeof Alignments]\n\ntype Props = {\n id?: ElementIDValue\n tableId?: TableValue\n fields?: TableFormFieldsValue\n submitLink?: LinkValue\n gap?: GapYValue\n shape?: ResponsiveIconRadioGroupValue<Shape>\n size?: ResponsiveIconRadioGroupValue<Size>\n contrast?: ResponsiveIconRadioGroupValue<Contrast>\n labelTextStyle?: TextStyleValue\n labelTextColor?: ResponsiveColor | null\n submitTextStyle?: TextStyleValue\n brandColor?: ResponsiveColor | null\n submitTextColor?: ResponsiveColor | null\n submitLabel?: TextInputValue\n submitVariant?: ResponsiveSelectValue<\n 'flat' | 'outline' | 'shadow' | 'clear' | 'blocky' | 'bubbly' | 'skewed'\n >\n submitWidth?: ResponsiveLengthValue\n submitAlignment?: ResponsiveIconRadioGroupValue<Alignment>\n width?: string\n margin?: MarginValue\n}\n\nconst GridForm = styled.form<{\n size: Props['size']\n margin: Props['margin']\n}>`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n ${props =>\n cssMediaRules(\n [props.size],\n ([size = Sizes.MEDIUM]) => css`\n font-size: ${getSizeFontSize(size)}px;\n `,\n )}\n ${cssMargin()}\n`\n\nconst GridItem = styled.div`\n align-self: flex-end;\n flex-direction: column;\n ${cssGridItem()}\n`\n\nfunction getAlignmentMargin(alignment: Alignment): string {\n switch (alignment) {\n case Alignments.LEFT:\n return '0 auto 0 0'\n case Alignments.RIGHT:\n return '0 0 0 auto'\n default:\n return '0 auto'\n }\n}\n\nconst StyledButton = styled((props: ComponentPropsWithoutRef<typeof Button>) => (\n <Button {...props} as=\"button\" />\n))<{\n size: Props['size']\n alignment: Props['submitAlignment']\n}>`\n display: flex;\n align-items: center;\n justify-content: center;\n ${props =>\n cssMediaRules(\n [props.size, props.alignment] as const,\n ([size = Sizes.MEDIUM, alignment = Alignments.CENTER]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n margin: ${getAlignmentMargin(alignment)};\n padding-top: 0;\n padding-bottom: 0;\n `,\n )}\n`\n\nconst ErrorContainer = styled.div`\n padding: 8px 16px;\n background-color: #f19eb9;\n border-radius: 4px;\n margin-top: 16px;\n`\n\nconst IconContainer = styled.div`\n fill: currentColor;\n`\n\nconst ErrorMessage = styled.p`\n font-size: 12px;\n margin: 8px 0;\n color: rgba(127, 0, 0, 0.95);\n`\n\nfunction getTableColumnDefaultValue(tableColumn: TableColumn) {\n switch (tableColumn.__typename) {\n case 'CheckboxTableColumn':\n return false\n\n case 'MultipleSelectTableColumn':\n return []\n\n case 'SingleLineTextTableColumn':\n case 'LongTextTableColumn':\n case 'SingleSelectTableColumn':\n case 'PhoneNumberTableColumn':\n case 'EmailTableColumn':\n case 'URLTableColumn':\n case 'NumberTableColumn':\n default:\n return ''\n }\n}\n\nconst CREATE_TABLE_RECORD = gql`\n mutation CreateTableRecord($input: CreateTableRecordInput!) {\n createTableRecord(input: $input) {\n tableRecord {\n id\n }\n }\n }\n`\n\ntype Column = { columnId: string; data: Record<string, any> }\ntype Fields = Record<string, string | string[] | boolean>\n\ntype Descriptors = { fields?: TableFormFieldsDescriptor }\n\nconst Form = forwardRef(function Form(\n {\n id,\n tableId,\n fields: fieldsProp,\n submitLabel = 'Submit',\n submitLink,\n shape,\n size,\n contrast,\n brandColor,\n gap,\n width,\n margin,\n submitTextStyle,\n submitVariant,\n submitTextColor,\n submitWidth,\n submitAlignment,\n labelTextStyle,\n labelTextColor,\n }: Props,\n ref: Ref<BoxModelHandle & PropControllersHandle<Descriptors>>,\n) {\n const fields = useMemo(() => fieldsProp?.fields ?? [], [fieldsProp])\n const grid = useMemo(() => fieldsProp?.grid ?? [], [fieldsProp])\n const { data: { table } = {} } = useTable(tableId)\n const [createTableRecord] = useMutation(CREATE_TABLE_RECORD)\n const [refEl, setRefEl] = useState<HTMLElement | null>(null)\n const [propControllers, setPropControllers] =\n useState<DescriptorsPropControllers<Descriptors> | null>(null)\n const [initialValues, setInitialValues] = useState<Fields>(() =>\n fields.reduce((acc, formField) => {\n const tableColumn = table && table.columns.find(field => field.id === formField.tableColumnId)\n const defaultValue = formField ? formField.defaultValue : null\n\n if (tableColumn) {\n acc[tableColumn.name] =\n defaultValue == null ? getTableColumnDefaultValue(tableColumn) : defaultValue\n }\n\n return acc\n }, {} as Fields),\n )\n const controller = propControllers?.fields\n const { container, items } = useTableFormFieldRefs(controller, { fieldsCount: fields.length })\n const [isDone, setIsDone] = useState(false)\n const linkRef = useRef<HTMLAnchorElement>(null)\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n return refEl instanceof Element ? getBox(refEl) : null\n },\n setPropControllers,\n }),\n [refEl, setPropControllers],\n )\n\n useEffect(() => {\n container(refEl)\n }, [container, refEl])\n\n useEffect(() => {\n if (!isDone) return\n\n let timeoutId = setTimeout(() => setIsDone(false), 2500)\n\n return () => clearTimeout(timeoutId)\n }, [isDone])\n\n function getTableColumn({ tableColumnId }: any) {\n return table && table.columns.find(field => tableColumnId === field.id)\n }\n\n async function handleSubmit(values: any, { setSubmitting, resetForm, setStatus }: any) {\n if (table) {\n const columns: Column[] = []\n\n fields.forEach(field => {\n const tableColumn = getTableColumn(field)\n\n if (tableColumn) {\n const data = values[tableColumn.name]\n\n if (data) {\n columns.push({ columnId: field.tableColumnId, data })\n\n if (field.autofill) {\n localStorage.setItem(\n `${LOCAL_STORAGE_NAMESPACE}/${tableColumn.name}`,\n JSON.stringify(data),\n )\n }\n }\n }\n })\n\n try {\n await createTableRecord({\n variables: { input: { data: { tableId: table.id, columns } } },\n })\n setIsDone(true)\n setInitialValues(prev =>\n fields.reduce(\n (acc, field) => {\n const tableColumn = getTableColumn(field)\n\n if (tableColumn) {\n const data = values[tableColumn.name]\n\n if (data && field.autofill) return { ...acc, [tableColumn.name]: data }\n }\n\n return acc\n },\n { ...prev },\n ),\n )\n resetForm()\n\n if (linkRef.current != null) linkRef.current.click()\n } catch (error) {\n setStatus({ error: 'An unexpected error has occurred, please try again later' })\n } finally {\n setSubmitting(false)\n }\n }\n }\n\n useEffect(() => {\n setInitialValues(prev =>\n fields.reduce(\n (acc, formField) => {\n const tableColumn =\n table && table.columns.find(field => field.id === formField.tableColumnId)\n\n if (tableColumn && formField.autofill) {\n const storedValue = localStorage.getItem(\n `${LOCAL_STORAGE_NAMESPACE}/${tableColumn.name}`,\n )\n\n if (storedValue) {\n try {\n acc[tableColumn.name] = JSON.parse(storedValue)\n } catch (e) {\n // Ignore\n }\n }\n }\n\n return acc\n },\n { ...prev },\n ),\n )\n }, [fields, table])\n\n return (\n <FormContextProvider\n value={{ shape, size, contrast, brandColor, labelTextStyle, labelTextColor }}\n >\n {tableId == null ? (\n <Placeholder ref={setRefEl} className={cx(width)} margin={margin} />\n ) : (\n <>\n <Formik\n onSubmit={handleSubmit}\n initialValues={initialValues}\n initialStatus={{ error: null }}\n enableReinitialize\n >\n {formik => {\n const error = formik.status && formik.status.error\n const errors = fields\n .map(field => {\n const tableColumn = getTableColumn(field)\n\n return (\n tableColumn &&\n getIn(formik.touched, tableColumn.name) &&\n getIn(formik.errors, tableColumn.name)\n )\n })\n .filter(message => typeof message === 'string')\n\n return (\n <>\n <GridForm\n ref={setRefEl}\n id={id}\n className={cx(width)}\n margin={margin}\n size={size}\n onSubmit={formik.handleSubmit}\n onReset={formik.handleReset}\n noValidate\n >\n {fields.map((field, index) => {\n const tableColumn = getTableColumn(field)\n\n return (\n <GridItem\n key={field.id}\n ref={items[index]}\n grid={grid}\n index={index}\n rowGap={gap}\n columnGap={gap}\n >\n <Field tableColumn={tableColumn} tableFormField={field} />\n </GridItem>\n )\n })}\n <GridItem\n ref={items[fields.length]}\n grid={grid}\n index={fields.length}\n rowGap={gap}\n columnGap={gap}\n >\n <StyledButton\n type=\"submit\"\n disabled={formik.isSubmitting || isDone}\n shape={shape}\n size={size}\n color={brandColor}\n variant={submitVariant}\n textColor={submitTextColor}\n width={submitWidth}\n alignment={submitAlignment}\n textStyle={submitTextStyle}\n >\n {formik.isSubmitting ? (\n <Spinner />\n ) : isDone ? (\n <IconContainer>\n <Check12 />\n </IconContainer>\n ) : (\n submitLabel\n )}\n </StyledButton>\n {(errors.length > 0 || error) && (\n <ErrorContainer>\n {errors.map(message => (\n <ErrorMessage key={message}>{message}</ErrorMessage>\n ))}\n {error != null && <ErrorMessage>{error}</ErrorMessage>}\n </ErrorContainer>\n )}\n </GridItem>\n </GridForm>\n {submitLink != null && <Link ref={linkRef} hidden link={submitLink} />}\n </>\n )\n }}\n </Formik>\n </>\n )}\n </FormContextProvider>\n )\n})\n\nexport default Form\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Form, {\n type: './components/Form/index.js',\n label: 'Form',\n icon: 'Form40',\n props: {\n id: Props.ElementID(),\n tableId: Props.Table(),\n fields: Props.TableFormFields(),\n submitLink: Props.Link(props => ({\n label: 'Redirect to',\n // TODO: This option is hardcoded. We should import it from LinkPanelOptions\n options: [\n { value: 'OPEN_PAGE', label: 'Open page' },\n { value: 'OPEN_URL', label: 'Open URL' },\n ],\n hidden: props.tableId == null,\n })),\n gap: Props.GapY(props => ({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Gap',\n defaultValue: { value: 0, unit: 'px' },\n hidden: props.tableId == null,\n })),\n shape: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Shape',\n options: [\n { label: 'Pill', value: Shapes.PILL, icon: 'ButtonPill16' },\n { label: 'Rounded', value: Shapes.ROUNDED, icon: 'ButtonRounded16' },\n { label: 'Square', value: Shapes.SQUARE, icon: 'ButtonSquare16' },\n ],\n defaultValue: Shapes.ROUNDED,\n hidden: props.tableId == null,\n })),\n size: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Size',\n options: [\n { label: 'Small', value: Sizes.SMALL, icon: 'SizeSmall16' },\n { label: 'Medium', value: Sizes.MEDIUM, icon: 'SizeMedium16' },\n { label: 'Large', value: Sizes.LARGE, icon: 'SizeLarge16' },\n ],\n defaultValue: Sizes.MEDIUM,\n hidden: props?.tableId == null,\n })),\n contrast: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Color',\n options: [\n { label: 'Light mode', value: Contrasts.LIGHT, icon: 'Sun16' },\n { label: 'Dark mode', value: Contrasts.DARK, icon: 'Moon16' },\n ],\n defaultValue: Contrasts.LIGHT,\n hidden: props.tableId == null,\n })),\n labelTextStyle: Props.TextStyle({ label: 'Label text style' }),\n labelTextColor: Props.ResponsiveColor((props, device) => {\n const hidden = props.tableId == null\n const responsiveContrast = props.contrast as ResponsiveValue<Contrast>\n const contrast = findDeviceOverride<Contrast>(responsiveContrast, device)\n\n return {\n hidden,\n label: 'Label text color',\n placeholder:\n contrast?.value === Contrasts.DARK ? 'rgba(255,255,255,0.95)' : 'rgba(0,0,0,0.8)',\n }\n }),\n submitTextStyle: Props.TextStyle({ label: 'Button text style' }),\n brandColor: Props.ResponsiveColor(props => ({\n label: 'Button color',\n placeholder: 'black',\n hidden: props.tableId == null,\n // TODO: Add hideAlphaSlider\n })),\n submitTextColor: Props.ResponsiveColor(props => ({\n label: 'Button text color',\n placeholder: 'white',\n hidden: props.tableId == null,\n })),\n submitLabel: Props.TextInput(props => ({\n label: 'Button label',\n placeholder: 'Submit',\n hidden: props.tableId == null,\n })),\n submitVariant: Props.ResponsiveSelect(props => ({\n label: 'Button style',\n options: [\n { value: 'flat', label: 'Flat' },\n { value: 'outline', label: 'Outline' },\n { value: 'shadow', label: 'Floating' },\n { value: 'clear', label: 'Clear' },\n { value: 'blocky', label: 'Blocky' },\n { value: 'bubbly', label: 'Bubbly' },\n { value: 'skewed', label: 'Skewed' },\n ],\n defaultValue: 'flat',\n hidden: props.tableId == null,\n })),\n submitWidth: Props.ResponsiveLength(props => ({\n label: 'Button width',\n hidden: props.tableId == null,\n // TODO: Add placeholder: { value: 'auto' }\n })),\n submitAlignment: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Button alignment',\n options: [\n { label: 'Left', value: Alignments.LEFT, icon: 'AlignLeft16' },\n { label: 'Center', value: Alignments.CENTER, icon: 'AlignCenter16' },\n { label: 'Right', value: Alignments.RIGHT, icon: 'AlignRight16' },\n ],\n defaultValue: Alignments.CENTER,\n hidden: props.tableId == null,\n })),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n preset: [{ deviceId: 'desktop', value: { value: 550, unit: 'px' } }],\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyOCIgaGVpZ2h0PSIyOCI+CiAgPHBhdGggZD0iTTI3IDE1SDFhMSAxIDAgMCAxLTEtMSAxIDEgMCAwIDEgMS0xaDI2YTEgMSAwIDAgMSAxIDEgMSAxIDAgMCAxLTEgMXptMC0xMEgxYTEgMSAwIDAgMC0xIDEgMSAxIDAgMCAwIDEgMWgyNmExIDEgMCAwIDAgMS0xIDEgMSAwIDAgMC0xLTF6bTAgMTZIMWExIDEgMCAwIDAtMSAxIDEgMSAwIDAgMCAxIDFoMjZhMSAxIDAgMCAwIDEtMSAxIDEgMCAwIDAtMS0xeiIvPgo8L3N2Zz4=\"","import styled, { css } from 'styled-components'\n\nimport { ResponsiveValue, Length } from '../../../prop-controllers/descriptors'\nimport { cssMediaRules } from '../../utils/cssMediaRules'\n\nconst GutterContainer = styled.div<{\n gutter?: ResponsiveValue<Length>\n first: boolean\n last: boolean\n}>`\n ${p =>\n cssMediaRules(\n [p.gutter],\n ([gutter = { value: 0, unit: 'px' }]) => css`\n padding-left: ${p.first ? '0px' : `${gutter.value / 2}${gutter.unit}`};\n padding-right: ${p.last ? '0px' : `${gutter.value / 2}${gutter.unit}`};\n `,\n )}\n`\n\nexport default GutterContainer\n","import styled from 'styled-components'\n\nimport { ResponsiveLengthValue } from '../../../../../prop-controllers/descriptors'\nimport GutterContainer from '../../../../shared/GutterContainer'\n\nconst PlaceholderLink = styled.div<{ width: number; button?: boolean }>`\n width: ${props => props.width}px;\n height: ${props => (props.button === true ? 32 : 8)}px;\n background-color: #a1a8c2;\n border-radius: ${props => (props.button === true ? 6 : 2)}px;\n opacity: 0.4;\n`\n\ntype Props = { gutter?: ResponsiveLengthValue }\n\nconst links = [{ width: 50 }, { width: 70 }, { width: 60 }, { width: 80, button: true }]\n\nexport default function LinksPlaceholder({ gutter }: Props): JSX.Element {\n return (\n <>\n {links.map((link, i) => (\n <GutterContainer key={i} gutter={gutter} first={i === 0} last={i === links.length - 1}>\n <PlaceholderLink {...link} />\n </GutterContainer>\n ))}\n </>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik0xIDJhMSAxIDAgMCAwLS43MDcgMS43MDdsMyAzYTEgMSAwIDAgMCAxLjQxNCAwbDMtM0ExIDEgMCAwIDAgNyAySDF6Ii8+PC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik00IDBhMSAxIDAgMCAwLTEgMXYySDFhMSAxIDAgMSAwIDAgMmgydjJhMSAxIDAgMCAwIDIgMFY1aDJhMSAxIDAgMCAwIDAtMkg1VjFhMSAxIDAgMCAwLTEtMXoiLz48L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik01IDFhMSAxIDAgMCAwLTIgMHYzLjU4NmwtLjI5My0uMjkzYTEgMSAwIDAgMC0xLjQxNCAxLjQxNGwyIDJhMSAxIDAgMCAwIDEuNDE0IDBsMi0yYTEgMSAwIDAgMC0xLjQxNC0xLjQxNEw1IDQuNTg2VjF6Ii8+PC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNLjI5MyAyLjI5M2ExIDEgMCAwIDEgMS40MTQgMEw0IDQuNTg2bDIuMjkzLTIuMjkzYTEgMSAwIDAgMSAxLjQxNCAxLjQxNGwtMyAzYTEgMSAwIDAgMS0xLjQxNCAwbC0zLTNhMSAxIDAgMCAxIDAtMS40MTR6Ii8+PC9zdmc+\"","import { ComponentPropsWithoutRef, useRef, useState, useLayoutEffect } from 'react'\nimport styled, { css, keyframes } from 'styled-components'\n\nimport { ReactComponent as CaretDown8 } from '../../../../icons/caret-down-8.svg'\nimport { ReactComponent as Plus8 } from '../../../../icons/plus-8.svg'\nimport { ReactComponent as ArrowDown8 } from '../../../../icons/arrow-down-8.svg'\nimport { ReactComponent as ChevronDown8 } from '../../../../icons/chevron-down-8.svg'\nimport { cssMediaRules, cssTextStyle } from '../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ResponsiveColorValue,\n TextStyleValue,\n LinkValue,\n} from '../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport { useResponsiveColor } from '../../../../hooks'\n\nimport { Link } from '../../../../shared/Link'\nimport Button from '../../../Button'\n\nconst DROP_DOWN_MENU_WIDTH = 200\n\ntype Position = 'left' | 'right'\n\nconst DropDownMenu = styled.div<{ position: Position }>`\n position: absolute;\n top: 100%;\n left: ${props => (props.position === 'left' ? 0 : 'auto')};\n right: ${props => (props.position === 'right' ? 0 : 'auto')};\n background: #fff;\n margin: 0;\n padding: 8px 0;\n border-radius: 4px;\n box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);\n width: ${DROP_DOWN_MENU_WIDTH}px;\n z-index: 99;\n list-style: none;\n overflow: hidden;\n transform-origin: 50% 0;\n will-change: transform, opacity;\n transform-style: preserve-3d;\n display: none;\n`\n\nconst dropIn = keyframes`\n 0% {\n opacity: 0;\n transform: rotateX(-20deg);\n }\n 100% {\n opacity: 1;\n transform: none;\n }\n`\n\nconst DropDownContainer = styled.div`\n position: relative;\n\n &:hover > ${DropDownMenu} {\n display: block;\n animation: ${dropIn} 0.25s;\n }\n`\n\nconst StyledDropDownItem = styled(Link)<{\n color?: ResponsiveValue<Color> | null\n textStyle?: TextStyleValue\n}>`\n display: block;\n text-decoration: none;\n line-height: 1.4;\n padding: 8px 16px;\n color: black;\n background-color: transparent;\n transition: background-color 0.2s;\n ${cssTextStyle()}\n ${p =>\n cssMediaRules([p.color, p.textStyle] as const, ([color, textStyle = {}]) => {\n const fontSize = textStyle.fontSize || { value: 14, unit: 'px' }\n const fontWeight = textStyle.fontWeight == null ? 'normal' : textStyle.fontWeight\n const fontStyle = textStyle.fontStyle || []\n const letterSpacing = textStyle.letterSpacing == null ? null : textStyle.letterSpacing\n const textTransform = textStyle.textTransform || []\n\n return css`\n color: ${color == null ? 'black' : colorToString(color)};\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n font-weight: ${fontWeight};\n font-style: ${fontStyle.includes('italic') ? 'italic' : 'normal'};\n letter-spacing: ${letterSpacing == null ? 'normal' : `${letterSpacing}px`};\n text-transform: ${textTransform.includes('uppercase') ? 'uppercase' : 'none'};\n `\n })}\n\n &:hover {\n background-color: rgba(0, 0, 0, 0.04);\n }\n`\n\ntype BaseDropDownItemProps = {\n color?: ResponsiveColorValue\n textStyle?: TextStyleValue\n}\n\ntype DropDownItemProps = BaseDropDownItemProps &\n Omit<ComponentPropsWithoutRef<typeof StyledDropDownItem>, keyof BaseDropDownItemProps>\n\nfunction DropDownItem({ color, ...restOfProps }: DropDownItemProps) {\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop.\n return <StyledDropDownItem {...restOfProps} color={useResponsiveColor(color)} />\n}\n\ntype Props = ComponentPropsWithoutRef<typeof Button> & {\n label: string\n caret?: 'caret' | 'plus' | 'arrow-down' | 'chevron-down'\n links?: Array<{\n id: string\n payload: ComponentPropsWithoutRef<typeof DropDownItem> & {\n link?: LinkValue\n label: string\n }\n }>\n}\n\nexport default function DropDownButton({\n label,\n caret = 'caret',\n links = [],\n textColor,\n color,\n ...restOfProps\n}: Props): JSX.Element {\n const container = useRef<HTMLDivElement>(null)\n const [position, setPosition] = useState<Position>('left')\n\n useLayoutEffect(() => {\n if (\n container.current &&\n container.current.ownerDocument.defaultView!.innerWidth <\n container.current.offsetLeft + DROP_DOWN_MENU_WIDTH\n ) {\n setPosition('right')\n } else {\n setPosition('left')\n }\n }, [setPosition])\n\n return (\n <DropDownContainer ref={container}>\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n >\n <div style={{ display: 'flex', alignItems: 'center' }}>\n <span style={{ marginRight: 6 }}>{label}</span>\n <span style={{ display: 'inline-flex', fill: 'currentColor' }}>\n {caret === 'caret' && <CaretDown8 />}\n {caret === 'plus' && <Plus8 />}\n {caret === 'arrow-down' && <ArrowDown8 />}\n {caret === 'chevron-down' && <ChevronDown8 />}\n </span>\n </div>\n </Button>\n <DropDownMenu position={position}>\n {links.map(({ id, payload }) => (\n <DropDownItem {...payload} key={id}>\n {payload.label}\n </DropDownItem>\n ))}\n </DropDownMenu>\n </DropDownContainer>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CiAgPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMy43MDcgMy43MDdhMSAxIDAgMCAwLTEuNDE0LTEuNDE0TDggNi41ODYgMy43MDcgMi4yOTNhMSAxIDAgMCAwLTEuNDE0IDEuNDE0TDYuNTg2IDhsLTQuMjkzIDQuMjkzYTEgMSAwIDEgMCAxLjQxNCAxLjQxNEw4IDkuNDE0bDQuMjkzIDQuMjkzYTEgMSAwIDAgMCAxLjQxNC0xLjQxNEw5LjQxNCA4bDQuMjkzLTQuMjkzWiIvPgo8L3N2Zz4=\"","import { ComponentPropsWithoutRef, useState } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules, cssTextStyle } from '../../../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ResponsiveColorValue,\n TextStyleValue,\n LinkValue,\n} from '../../../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../../../utils/types'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { useResponsiveColor } from '../../../../../../hooks'\n\nimport { ReactComponent as CaretDown8 } from '../../../../../../icons/caret-down-8.svg'\nimport { ReactComponent as Plus8 } from '../../../../../../icons/plus-8.svg'\nimport { ReactComponent as ArrowDown8 } from '../../../../../../icons/arrow-down-8.svg'\nimport { ReactComponent as ChevronDown8 } from '../../../../../../icons/chevron-down-8.svg'\n\nimport { Link } from '../../../../../../shared/Link'\nimport Button from '../../../../../Button'\n\nconst DropDownMenu = styled.div<{ open: boolean }>`\n display: ${props => (props.open ? 'flex' : 'none')};\n flex-direction: column;\n padding: 8px;\n`\n\nconst ButtonLink = styled(Button)`\n margin: 8px 0;\n`\n\nconst StyledLink = styled(Link)<{\n textStyle?: TextStyleValue\n color?: ResponsiveValue<Color> | null\n}>`\n text-decoration: none;\n line-height: 1.4;\n padding: 8px 16px;\n color: black;\n ${cssTextStyle()}\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color]) => css`\n color: ${color == null ? 'black' : colorToString(color)};\n `,\n )}\n`\n\ntype BaseDropDownItemProps = {\n color?: ResponsiveColorValue\n textStyle?: TextStyleValue\n}\n\ntype DropDownItemProps = BaseDropDownItemProps &\n Omit<ComponentPropsWithoutRef<typeof StyledLink>, keyof BaseDropDownItemProps>\n\nfunction DropDownItem({ color, ...restOfProps }: DropDownItemProps) {\n // @ts-expect-error: HTMLAnchorElement `color` attribute conflict with props\n return <StyledLink {...restOfProps} color={useResponsiveColor(color)} />\n}\n\ntype Props = ComponentPropsWithoutRef<typeof Button> & {\n label: string\n links?: Array<{\n id: string\n payload: ComponentPropsWithoutRef<typeof DropDownItem> & {\n link?: LinkValue\n label: string\n }\n }>\n onClose?: () => unknown\n caret?: string\n}\n\nexport default function MobileDropDownButton({\n label,\n caret,\n links = [],\n onClose = () => {},\n color,\n textColor,\n ...restOfProps\n}: Props): JSX.Element {\n const [isOpen, setIsOpen] = useState(false)\n return (\n <>\n <ButtonLink\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n onPointerDown={() => setIsOpen(prev => !prev)}\n >\n <div style={{ display: 'flex', alignItems: 'center' }}>\n <span style={{ marginRight: 6 }}>{label}</span>\n <span style={{ display: 'inline-flex', fill: 'currentColor' }}>\n <>\n {caret === 'caret' && <CaretDown8 />}\n {caret === 'plus' && <Plus8 />}\n {caret === 'arrow-down' && <ArrowDown8 />}\n {caret === 'chevron-down' && <ChevronDown8 />}\n </>\n </span>\n </div>\n </ButtonLink>\n <DropDownMenu open={isOpen}>\n {links.map(({ id, payload }) => (\n <DropDownItem {...payload} key={id} onClick={onClose}>\n {payload.label}\n </DropDownItem>\n ))}\n </DropDownMenu>\n </>\n )\n}\n","import { ComponentPropsWithoutRef, Fragment } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n NavigationLinksValue,\n NavigationButton as NavigationButtonValue,\n} from '../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport { ReactComponent as Times16 } from '../../../../icons/times-16.svg'\n\nimport Button from '../../../Button'\nimport DropDownButton from './components/MobileDropDownButton'\nimport { ResponsiveColor } from '../../../../../runtimes/react/controls'\nimport { useResponsiveColor } from '../../../../hooks'\n\ntype NavigationButtonProps = NavigationButtonValue['payload'] &\n Omit<ComponentPropsWithoutRef<typeof Button>, 'color' | 'textColor'>\n\nfunction NavigationButton(props: NavigationButtonProps): JSX.Element {\n const { textColor, color, ...restOfProps } = props\n\n return (\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n />\n )\n}\n\nconst ButtonLink = styled(NavigationButton)`\n margin: 8px 0;\n`\n\nconst Container = styled.div<{\n animation?: ResponsiveValue<'coverRight' | 'coverLeft'>\n backgroundColor?: ResponsiveValue<Color> | null\n open: boolean\n}>`\n position: fixed;\n flex-direction: column;\n width: 100%;\n padding: 40px 15px;\n transition: transform 300ms ease-in-out;\n overflow-y: auto;\n z-index: 9999;\n max-width: 575px;\n ${p =>\n cssMediaRules([p.animation, p.backgroundColor] as const, ([animation, backgroundColor]) =>\n animation == null\n ? css`\n display: none;\n `\n : css`\n display: flex;\n background-color: ${backgroundColor == null ? 'black' : colorToString(backgroundColor)};\n transform: ${p.open\n ? `translate3d(0,0,0)`\n : `translate3d(${{ coverRight: '', coverLeft: '-' }[animation]}100%, 0, 0)`};\n ${{\n coverRight: { top: 0, bottom: 0, right: 0 },\n coverLeft: { top: 0, bottom: 0, left: 0 },\n }[animation]}\n `,\n )}\n`\n\nconst CloseIconContainer = styled.button<{ color?: ResponsiveValue<Color> | null }>`\n position: absolute;\n top: 15px;\n right: 15px;\n padding: 0;\n border: 0;\n outline: 0;\n background: none;\n fill: currentColor;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color]) => css`\n color: ${color == null ? 'rgba(161, 168, 194, 0.5)' : colorToString(color)};\n `,\n )}\n`\n\ntype Props = {\n animation?: ResponsiveValue<'coverRight' | 'coverLeft'>\n backgroundColor?: ResponsiveColor | null\n closeIconColor?: ResponsiveColor | null\n links?: NavigationLinksValue\n onClose?: () => unknown\n open?: boolean\n}\n\nexport default function MobileMenu({\n animation,\n backgroundColor,\n open = false,\n closeIconColor,\n links = [],\n onClose = () => {},\n}: Props): JSX.Element {\n return (\n <Container animation={animation} backgroundColor={backgroundColor} open={open}>\n {/* @ts-expect-error: HTMLButtonElement `color` attribute conflicts with prop */}\n <CloseIconContainer color={closeIconColor} onClick={onClose}>\n <Times16 />\n </CloseIconContainer>\n <div\n style={{ display: 'flex', flexDirection: 'column', alignItems: 'center', flexShrink: 0 }}\n >\n {links.map(link => (\n <Fragment key={link.id}>\n {link.type === 'button' && (\n <ButtonLink {...link.payload} onClick={onClose}>\n {link.payload.label}\n </ButtonLink>\n )}\n {link.type === 'dropdown' && <DropDownButton {...link.payload} onClose={onClose} />}\n </Fragment>\n ))}\n </div>\n </Container>\n )\n}\n","import { ComponentPropsWithoutRef, forwardRef, useState } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { ReactComponent as MobileMenu28 } from '../../icons/mobile-menu-28.svg'\n\nimport GutterContainer from '../../shared/GutterContainer'\nimport Image from '../Image'\nimport Button from '../Button'\nimport LinksPlaceholder from './components/LinksPlaceholder'\nimport DropDownButton from './components/DropDownButton'\nimport MobileMenu from './components/MobileMenu'\nimport {\n ResponsiveValue,\n CheckboxValue,\n ElementIDValue,\n GapXValue,\n ImageValue,\n LinkValue,\n MarginValue,\n NavigationLinksValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n TextInputValue,\n TextStyleValue,\n NavigationButton as NavigationButtonValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssMargin, cssMediaRules, cssTextStyle } from '../../utils/cssMediaRules'\nimport { ColorValue as Color } from '../../utils/types'\nimport { colorToString } from '../../utils/colorToString'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\nimport { useResponsiveColor } from '../../hooks'\n\ntype Props = {\n id?: ElementIDValue\n links?: NavigationLinksValue\n linkTextStyle?: TextStyleValue\n showLogo?: CheckboxValue\n logoFile?: ImageValue\n logoWidth?: ResponsiveLengthValue\n logoAltText?: TextInputValue\n logoLink?: LinkValue\n alignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gutter?: GapXValue\n mobileMenuAnimation?: ResponsiveSelectValue<'coverRight' | 'coverLeft'>\n mobileMenuOpenIconColor?: ResponsiveColor | null\n mobileMenuCloseIconColor?: ResponsiveColor | null\n mobileMenuBackgroundColor?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.nav<{\n margin: Props['margin']\n textStyle: Props['linkTextStyle']\n gutter: Props['gutter']\n}>`\n display: flex;\n align-items: center;\n ${cssMargin()}\n ${cssTextStyle()}\n ${p =>\n cssMediaRules(\n [p.gutter] as const,\n ([gutter = { value: 0, unit: 'px' }]) => css`\n gap: ${gutter.value}${gutter.unit};\n `,\n )}\n`\n\nconst LinksContainer = styled.div<{\n alignment: Props['alignment']\n mobileMenuAnimation: Props['mobileMenuAnimation']\n}>`\n display: flex;\n align-items: center;\n flex-grow: 1;\n ${p =>\n cssMediaRules(\n [p.alignment, p.mobileMenuAnimation] as const,\n ([alignment = 'flex-end', mobileMenuAnimation]) => css`\n display: ${mobileMenuAnimation == null ? 'flex' : 'none'};\n justify-content: ${alignment};\n `,\n )}\n`\n\nconst OpenIconContainer = styled.button<{\n mobileMenuAnimation: Props['mobileMenuAnimation']\n alignment: Props['alignment']\n color: ResponsiveValue<Color> | null | undefined\n}>`\n display: none;\n flex-grow: 1;\n align-items: center;\n background: none;\n outline: 0;\n border: 0;\n padding: 0;\n fill: currentColor;\n ${p =>\n cssMediaRules(\n [p.mobileMenuAnimation, p.alignment, p.color] as const,\n ([mobileMenuAnimation, alignment = 'flex-end', color]) => css`\n display: ${mobileMenuAnimation == null ? 'none' : 'flex'};\n justify-content: ${alignment};\n color: ${color == null ? 'rgba(161, 168, 194, 0.5)' : colorToString(color)};\n `,\n )}\n`\n\ntype NavigationButtonProps = NavigationButtonValue['payload'] &\n Omit<ComponentPropsWithoutRef<typeof Button>, 'color' | 'textColor'>\n\nfunction NavigationButton(props: NavigationButtonProps): JSX.Element {\n const { textColor, color, ...restOfProps } = props\n\n return (\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n />\n )\n}\n\nconst placeholder = {\n src: \"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='93.12' height='36' viewBox='0 0 93.12 36'%3E%3Cg id='Layer_2' data-name='Layer 2'%3E%3Cg id='Layer_1-2' data-name='Layer 1'%3E%3Cpath d='M18,0A18,18,0,1,1,0,18,18,18,0,0,1,18,0ZM49.36,21.94h6.36V24H46.8V10h2.56Zm9.06.72a4.88,4.88,0,0,1-1.64-3.72,5,5,0,0,1,1.64-3.74,5.57,5.57,0,0,1,7.7,0,5.09,5.09,0,0,1,.26,7.18l-.26.26a5.56,5.56,0,0,1-7.7,0Zm1.68-6a3.39,3.39,0,0,0,0,4.52,3,3,0,0,0,4.24.08l.08-.08a3.39,3.39,0,0,0,0-4.52,3,3,0,0,0-4.24-.08Zm10,10.68,1-1.92a5.28,5.28,0,0,0,3.3,1.22,3.6,3.6,0,0,0,2.32-.72,2.73,2.73,0,0,0,.9-2.26V22.5a3.61,3.61,0,0,1-1.45,1.26,4.35,4.35,0,0,1-2,.46,4.57,4.57,0,0,1-3.58-1.54A5.48,5.48,0,0,1,69.2,18.9a5.42,5.42,0,0,1,1.36-3.74,4.64,4.64,0,0,1,3.62-1.5,4,4,0,0,1,3.44,1.72v-1.5h2.46v9a6.13,6.13,0,0,1-1.43,4.46,5.27,5.27,0,0,1-4,1.44,7.09,7.09,0,0,1-4.53-1.42Zm1.54-8.44a3.4,3.4,0,0,0,.82,2.3,2.72,2.72,0,0,0,2.17.94,3.13,3.13,0,0,0,1.21-.22,2.89,2.89,0,0,0,1-.62,3.08,3.08,0,0,0,.63-1,3.62,3.62,0,0,0,.21-1.3,4,4,0,0,0-.23-1.33,3.3,3.3,0,0,0-.63-1.05,2.74,2.74,0,0,0-1-.68,3.35,3.35,0,0,0-1.25-.24,2.92,2.92,0,0,0-1.2.24,2.58,2.58,0,0,0-.93.67,3,3,0,0,0-.59,1,3.89,3.89,0,0,0-.19,1.31ZM83.8,22.66a4.88,4.88,0,0,1-1.64-3.72A5,5,0,0,1,83.8,15.2a5.57,5.57,0,0,1,7.7,0,5.09,5.09,0,0,1,.26,7.18,3.19,3.19,0,0,1-.26.26,5.56,5.56,0,0,1-7.7,0Zm1.68-6a3.39,3.39,0,0,0,0,4.52,3,3,0,0,0,4.24.08l.08-.08a3.39,3.39,0,0,0,0-4.52,3,3,0,0,0-4.24-.08Z' fill='%23a1a8c2' opacity='0.4' style='isolation: isolate'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E%0A\",\n dimensions: { width: 93, height: 36 },\n}\n\nconst Navigation = forwardRef<HTMLDivElement, Props>(function Navigation(\n {\n id,\n links = [],\n linkTextStyle,\n showLogo,\n logoFile,\n logoWidth,\n logoAltText,\n logoLink,\n alignment,\n gutter,\n mobileMenuAnimation,\n mobileMenuOpenIconColor,\n mobileMenuCloseIconColor,\n mobileMenuBackgroundColor,\n width,\n margin,\n },\n ref,\n) {\n const [isOpen, setIsOpen] = useState(false)\n\n return (\n <Container\n ref={ref}\n id={id}\n className={cx(width)}\n margin={margin}\n textStyle={linkTextStyle}\n gutter={gutter}\n >\n {showLogo === true && (\n <Image\n altText={logoAltText}\n file={logoFile}\n link={logoLink}\n placeholder={placeholder}\n width={logoWidth}\n />\n )}\n <div style={{ display: 'flex', flexGrow: 1, justifyContent: 'flex-end' }}>\n <LinksContainer alignment={alignment} mobileMenuAnimation={mobileMenuAnimation}>\n {links.length > 0 ? (\n links.map((link, i) => (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n {link.type === 'button' && (\n <NavigationButton {...link.payload}>{link.payload.label}</NavigationButton>\n )}\n {link.type === 'dropdown' && <DropDownButton {...link.payload} />}\n </GutterContainer>\n ))\n ) : (\n <LinksPlaceholder gutter={gutter} />\n )}\n </LinksContainer>\n <OpenIconContainer\n alignment={alignment}\n // @ts-expect-error: HTMLButtonElement `color` attribute conflicts with prop\n color={mobileMenuOpenIconColor}\n mobileMenuAnimation={mobileMenuAnimation}\n onClick={() => setIsOpen(true)}\n >\n <MobileMenu28 />\n </OpenIconContainer>\n <MobileMenu\n animation={mobileMenuAnimation}\n backgroundColor={mobileMenuBackgroundColor}\n closeIconColor={mobileMenuCloseIconColor}\n links={links}\n onClose={() => setIsOpen(false)}\n open={isOpen}\n />\n </div>\n </Container>\n )\n})\n\nexport default Navigation\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Navigation, {\n type: './components/Navigation/index.js',\n label: 'Navigation',\n icon: 'Navigation40',\n props: {\n id: Props.ElementID(),\n links: Props.NavigationLinks(),\n linkTextStyle: Props.TextStyle(props => {\n const links = props.links as NavigationLinksValue\n\n return {\n label: 'Link text style',\n hidden: links == null || links.length === 0,\n }\n }),\n showLogo: Props.Checkbox({ preset: true, label: 'Show logo' }),\n logoFile: Props.Image(props => ({\n label: 'Logo',\n hidden: props.showLogo === false,\n })),\n logoWidth: Props.ResponsiveLength(props => ({\n preset: [{ deviceId: 'desktop', value: { value: 100, unit: 'px' } }],\n label: 'Logo width',\n min: 0,\n max: 1000,\n // TODO: This is hardcoded value, import it from LengthInputOptions\n options: [{ value: 'px', label: 'Pixels', icon: 'Px16' }],\n hidden: props.showLogo === false,\n })),\n logoAltText: Props.TextInput(props => ({\n label: 'Logo alt text',\n hidden: props.showLogo === false,\n })),\n logoLink: Props.Link(props => ({\n label: 'Logo on click',\n hidden: props.showLogo === false,\n })),\n alignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'Left', value: 'flex-start', icon: 'AlignLeft16' },\n { label: 'Center', value: 'center', icon: 'AlignCenter16' },\n { label: 'End', value: 'flex-end', icon: 'AlignRight16' },\n ],\n defaultValue: 'flex-end',\n }),\n gutter: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Link gap',\n min: 0,\n max: 100,\n step: 1,\n defaultValue: { value: 0, unit: 'px' },\n }),\n mobileMenuAnimation: Props.ResponsiveSelect({\n label: 'Mobile menu',\n options: [\n { value: 'coverRight', label: 'Cover from right' },\n { value: 'coverLeft', label: 'Cover from left' },\n ],\n }),\n mobileMenuOpenIconColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Open icon color',\n placeholder: 'rgba(161, 168, 194, 0.5)',\n hidden,\n }\n }),\n mobileMenuCloseIconColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Close icon color',\n placeholder: 'rgba(161, 168, 194, 0.5)',\n hidden,\n }\n }),\n mobileMenuBackgroundColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Menu BG color',\n placeholder: 'black',\n hidden,\n }\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","import { forwardRef } from 'react'\nimport styled from 'styled-components'\n\nconst PlaceholderBase = styled.div`\n width: 100%;\n background: rgba(161, 168, 194, 0.18);\n height: 80px;\n padding: 8px;\n`\n\ntype Props = Record<string, never>\n\nexport default forwardRef<HTMLDivElement, Props>(function Placeholder(props: Props, ref) {\n return (\n <PlaceholderBase {...props} ref={ref}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"100%\"\n height=\"100%\"\n style={{ overflow: 'visible' }}\n >\n <rect\n x={0}\n y={0}\n width=\"100%\"\n height=\"100%\"\n strokeWidth={2}\n strokeDasharray=\"4 2\"\n fill=\"none\"\n stroke=\"rgba(161, 168, 194, 0.40)\"\n rx=\"4\"\n ry=\"4\"\n />\n </svg>\n </PlaceholderBase>\n )\n})\n","import styled, { createGlobalStyle } from 'styled-components'\nimport { normalize } from 'polished'\nimport { forwardRef, Ref } from 'react'\n\nimport Placeholder from './components/Placeholder'\nimport {\n GridValue,\n BackgroundsValue,\n GapXValue,\n GapYValue,\n} from '../../../prop-controllers/descriptors'\nimport { Element, ReactRuntime } from '../../../react'\nimport { cssGridItem } from '../../utils/cssMediaRules'\nimport BackgroundsContainer from '../../shared/BackgroundsContainer'\nimport { Props } from '../../../prop-controllers'\n\nconst Normalize = createGlobalStyle`\n html {\n box-sizing: border-box;\n }\n\n *, *::before, *::after {\n box-sizing: inherit;\n }\n\n ${normalize()}\n`\n\nconst Grid = styled.div`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n`\n\nconst GridItem = styled.div`\n display: flex;\n align-items: flex-start;\n ${cssGridItem()}\n`\n\ntype Props = {\n children?: GridValue\n backgrounds?: BackgroundsValue\n rowGap?: GapYValue\n columnGap?: GapXValue\n}\n\nconst Root = forwardRef(function Page(\n { children, backgrounds, rowGap, columnGap }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <>\n <Normalize />\n <BackgroundsContainer ref={ref} style={{ background: 'white' }} backgrounds={backgrounds}>\n <Grid>\n {children && children.elements.length > 0 ? (\n children.elements.map((child, index) => (\n <GridItem\n key={child.key}\n grid={children.columns}\n index={index}\n columnGap={columnGap}\n rowGap={rowGap}\n >\n <Element element={child} />\n </GridItem>\n ))\n ) : (\n <Placeholder />\n )}\n </Grid>\n </BackgroundsContainer>\n </>\n )\n})\n\nexport default Root\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Root, {\n type: './components/Root/index.js',\n label: 'Page',\n hidden: true,\n props: {\n children: Props.Grid(),\n backgrounds: Props.Backgrounds(),\n rowGap: Props.GapY(),\n columnGap: Props.GapX(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTMuNzQxMiw4LjI5NjcgQzE0LjM1ODIsNi42Mjk3IDE0LjgzOTIsNS4yNTQ3IDE1LjE4NDIsNC4xNjg3IEMxNS41MjkyLDMuMDgzNyAxNS43MDIyLDIuNDE3NyAxNS43MDIyLDIuMTcwNyBDMTUuNzAyMiwxLjkwNDcgMTUuNjQ0MiwxLjY5ODcgMTUuNTI5MiwxLjU1MTcgQzE1LjQxNDIsMS40MDU3IDE1LjI1NjIsMS4zMzI3IDE1LjA1MzIsMS4zMzI3IEMxNC43OTYyLDEuMzMyNyAxNC41MzMyLDEuNTQ1NyAxNC4yNjYyLDEuOTcwNyBDMTMuOTk5MiwyLjM5NjcgMTMuNzA1MiwzLjA4MTcgMTMuMzgzMiw0LjAyNDcgTDEyLjAwMjIsNy45OTQ3IEwxMy43NDEyLDguMjk2NyBaIE0xMS45MDUyLDExLjk5MTcgQzExLjUxMDIsMTEuOTczNyAxMS4xMzQyLDExLjkzMjcgMTAuNzgwMiwxMS44Njc3IEMxMC40MjYyLDExLjgwNDcgMTAuMDg3MiwxMS43MTI3IDkuNzY1MiwxMS41OTM3IEM5LjkxMjIsMTEuODg2NyAxMC4wNDMyLDEyLjE3OTcgMTAuMTU4MiwxMi40NzI3IEMxMC4yNzQyLDEyLjc2NTcgMTAuMzY4MiwxMy4wNTQ3IDEwLjQ0MjIsMTMuMzM4NyBDMTAuNjYyMiwxMy4wNjM3IDEwLjg5NTIsMTIuODEzNyAxMS4xMzgyLDEyLjU4ODcgQzExLjM4MzIsMTIuMzY0NyAxMS42MzgyLDEyLjE2NTcgMTEuOTA1MiwxMS45OTE3IEwxMS45MDUyLDExLjk5MTcgWiBNMTAuMzQ1Miw3LjgyOTcgTDguODU0MiwzLjU0MzcgQzguNDY3MiwyLjQ1NDcgOC4xNjgyLDEuNzQyNyA3Ljk1NjIsMS40MDc3IEM3Ljc0NDIsMS4wNzM3IDcuNTE0MiwwLjkwNjcgNy4yNjYyLDAuOTA2NyBDNy4wNzMyLDAuOTA2NyA2LjkxNjIsMC45Nzk3IDYuNzk3MiwxLjEyNjcgQzYuNjc3MiwxLjI3MjcgNi42MTcyLDEuNDY5NyA2LjYxNzIsMS43MTY3IEM2LjYxNzIsMi4xMzg3IDYuNzc4MiwyLjg3MDcgNy4xMDAyLDMuOTE0NyBDNy40MjMyLDQuOTU4NyA3LjkwNjIsNi4zMjc3IDguNTUwMiw4LjAyMTcgQzguNjA1Miw3LjkyMTcgOC42ODMyLDcuODUwNyA4Ljc4NTIsNy44MDg3IEM4Ljg4NjIsNy43Njc3IDkuMDI0Miw3Ljc0NzcgOS4xOTkyLDcuNzQ3NyBDOS4yNTQyLDcuNzQ3NyA5LjM2NTIsNy43NTI3IDkuNTMxMiw3Ljc2MDcgQzkuNjk2Miw3Ljc3MDcgOS45NjgyLDcuNzkzNyAxMC4zNDUyLDcuODI5NyBMMTAuMzQ1Miw3LjgyOTcgWiBNOC45OTIyLDE0LjQ2MzcgQzkuMTQ4MiwxNC40NjM3IDkuMjkxMiwxNC4zOTM3IDkuNDIwMiwxNC4yNTE3IEM5LjU0OTIsMTQuMTA5NyA5LjYxMzIsMTMuOTU2NyA5LjYxMzIsMTMuNzkxNyBDOS42MTMyLDEzLjYxNzcgOS40ODcyLDEzLjIxMjcgOS4yMzQyLDEyLjU3NTcgQzguOTgwMiwxMS45Mzk3IDguNjY1MiwxMS4zMTQ3IDguMjg4MiwxMC43MDA3IEM4LjAxMjIsMTAuMjQyNyA3Ljc0MDIsOS44OTc3IDcuNDczMiw5LjY2MzcgQzcuMjA2Miw5LjQyOTcgNi45NTMyLDkuMzEzNyA2LjcxNDIsOS4zMTM3IEM2LjUyMDIsOS4zMTM3IDYuMzA2Miw5LjQzNDcgNi4wNzIyLDkuNjc2NyBDNS44MzcyLDkuOTE5NyA1LjcyMDIsMTAuMTQ2NyA1LjcyMDIsMTAuMzU3NyBDNS43MjAyLDEwLjU3NjcgNS44MzUyLDEwLjkwNjcgNi4wNjUyLDExLjM0NTcgQzYuMjk1MiwxMS43ODU3IDYuNjAzMiwxMi4yNTI3IDYuOTkwMiwxMi43NDc3IEM3LjM5NTIsMTMuMjg3NyA3Ljc3NzIsMTMuNzA4NyA4LjEzNjIsMTQuMDEwNyBDOC40OTUyLDE0LjMxMzcgOC43ODAyLDE0LjQ2MzcgOC45OTIyLDE0LjQ2MzcgTDguOTkyMiwxNC40NjM3IFogTTQuODUwMiwxNC4xMzQ3IEM0Ljk3OTIsMTQuMjkwNyA1LjE1ODIsMTQuNTE5NyA1LjM4ODIsMTQuODIxNyBDNS45OTYyLDE1LjY1NDcgNi41NTcyLDE2LjA3MTcgNy4wNzMyLDE2LjA3MTcgQzcuMjQ3MiwxNi4wNzE3IDcuNDA0MiwxNi4wMTY3IDcuNTQyMiwxNS45MDY3IEM3LjY4MDIsMTUuNzk2NyA3Ljc0OTIsMTUuNjgyNyA3Ljc0OTIsMTUuNTYzNyBDNy43NDkyLDE1LjQyNTcgNy42NTcyLDE1LjE5NjcgNy40NzMyLDE0Ljg3NjcgQzcuMjg5MiwxNC41NTU3IDcuMDM2MiwxNC4xOTQ3IDYuNzE0MiwxMy43OTE3IEM2LjM0NTIsMTMuMzI0NyA2LjAzOTIsMTIuOTgzNyA1Ljc5NjIsMTIuNzY3NyBDNS41NTIyLDEyLjU1MjcgNS4zNTYyLDEyLjQ0NDcgNS4yMDkyLDEyLjQ0NDcgQzQuODg3MiwxMi40NDQ3IDQuNTkwMiwxMi42MTY3IDQuMzE4MiwxMi45NjA3IEM0LjA0NzIsMTMuMzAzNyAzLjkxMTIsMTMuNzA4NyAzLjkxMTIsMTQuMTc1NyBDMy45MTEyLDE0LjU1MTcgNC4wMDUyLDE0Ljk3MDcgNC4xOTQyLDE1LjQzMjcgQzQuMzgzMiwxNS44OTU3IDQuNjU3MiwxNi4zNTk3IDUuMDE1MiwxNi44MjY3IEM1LjU1ODIsMTcuNTUwNyA2LjIzMzIsMTguMTA2NyA3LjAzODIsMTguNDk1NyBDNy44NDQyLDE4Ljg4NTcgOC43MzQyLDE5LjA3OTcgOS43MTAyLDE5LjA3OTcgQzExLjUwNTIsMTkuMDc5NyAxMy4wMDgyLDE4LjQxMzcgMTQuMjE4MiwxNy4wODE3IEMxNS40MjgyLDE1Ljc0ODcgMTYuMDMzMiwxNC4wNzk3IDE2LjAzMzIsMTIuMDczNyBDMTYuMDMzMiwxMS40NjA3IDE1Ljk4NzIsMTAuOTczNyAxNS44OTUyLDEwLjYxMDcgQzE1LjgwNDIsMTAuMjQ5NyAxNS42NTEyLDkuOTg1NyAxNS40MzkyLDkuODIxNyBDMTUuMDYyMiw5LjUwOTcgMTQuMzI4Miw5LjIzMDcgMTMuMjM3Miw4Ljk4MzcgQzEyLjE0NjIsOC43MzU3IDExLjAwODIsOC42MTI3IDkuODIwMiw4LjYxMjcgQzkuNDg5Miw4LjYxMjcgOS4yNTQyLDguNjY3NyA5LjExNjIsOC43Nzc3IEM4Ljk3ODIsOC44ODc3IDguOTA5Miw5LjA3NDcgOC45MDkyLDkuMzQwNyBDOC45MDkyLDkuOTYzNyA5LjI1OTIsMTAuNDE0NyA5Ljk1ODIsMTAuNjkzNyBDMTAuNjU4MiwxMC45NzM3IDExLjc5MDIsMTEuMTEyNyAxMy4zNTUyLDExLjExMjcgTDEzLjkyMTIsMTEuMTEyNyBDMTQuMDUwMiwxMS4xMTI3IDE0LjE1MzIsMTEuMTYwNyAxNC4yMzEyLDExLjI1NjcgQzE0LjMwOTIsMTEuMzUyNyAxNC4zNjMyLDExLjQ5NzcgMTQuMzkwMiwxMS42ODk3IEMxNC4yMzMyLDExLjgzNjcgMTMuOTEyMiwxMi4wMDM3IDEzLjQyNDIsMTIuMTkxNyBDMTIuOTM2MiwxMi4zNzg3IDEyLjU2MzIsMTIuNTY0NyAxMi4zMDUyLDEyLjc0NzcgQzExLjc1NDIsMTMuMTUwNyAxMS4zMDkyLDEzLjYyODcgMTAuOTczMiwxNC4xODI3IEMxMC42MzcyLDE0LjczNjcgMTAuNDY5MiwxNS4yNjA3IDEwLjQ2OTIsMTUuNzU1NyBDMTAuNDY5MiwxNi4wNTc3IDEwLjU0MDIsMTYuNDIxNyAxMC42ODMyLDE2Ljg0NzcgQzEwLjgyNjIsMTcuMjczNyAxMC44OTcyLDE3LjUzNjcgMTAuODk3MiwxNy42Mzc3IEwxMC44OTcyLDE3LjczMzcgTDEwLjg2OTIsMTcuODU3NyBDMTAuNDY1MiwxNy44Mjk3IDEwLjE0NTIsMTcuNTkzNyA5LjkxMDIsMTcuMTQ5NyBDOS42NzUyLDE2LjcwNTcgOS41NTgyLDE2LjExMjcgOS41NTgyLDE1LjM3MDcgTDkuNTU4MiwxNS4yNDc3IEM5LjQ4NDIsMTUuMzExNyA5LjQxMzIsMTUuMzU3NyA5LjM0NDIsMTUuMzg0NyBDOS4yNzUyLDE1LjQxMjcgOS4xOTkyLDE1LjQyNTcgOS4xMTYyLDE1LjQyNTcgQzkuMDMzMiwxNS40MjU3IDguOTU1MiwxNS40MTk3IDguODgyMiwxNS40MDQ3IEM4LjgwNzIsMTUuMzkxNyA4LjcyNTIsMTUuMzcwNyA4LjYzMzIsMTUuMzQzNyBDOC42NjAyLDE1LjQ0NDcgOC42ODEyLDE1LjU0MjcgOC42OTUyLDE1LjYzODcgQzguNzA5MiwxNS43MzQ3IDguNzE2MiwxNS44MTA3IDguNzE2MiwxNS44NjU3IEM4LjcxNjIsMTYuMjA0NyA4LjU4MjIsMTYuNDk1NyA4LjMxNTIsMTYuNzM3NyBDOC4wNDgyLDE2Ljk4MDcgNy43MzEyLDE3LjEwMTcgNy4zNjMyLDE3LjEwMTcgQzYuNzgzMiwxNy4xMDE3IDYuMTk0MiwxNi44MTk3IDUuNTk1MiwxNi4yNTY3IEM0Ljk5NzIsMTUuNjkzNyA0LjY5ODIsMTUuMTQyNyA0LjY5ODIsMTQuNjAxNyBDNC42OTgyLDE0LjUwMDcgNC43MTAyLDE0LjQxMTcgNC43MzMyLDE0LjMzMzcgQzQuNzU1MiwxNC4yNTU3IDQuNzk1MiwxNC4xODk3IDQuODUwMiwxNC4xMzQ3IEw0Ljg1MDIsMTQuMTM0NyBaIE0xNC43MzUyLDguNTI5NyBDMTUuNTY0Miw4LjY4NjcgMTYuMTQ4Miw5LjAzMzcgMTYuNDg5Miw5LjU3MzcgQzE2LjgyOTIsMTAuMTE0NyAxNy4wMDAyLDEwLjk2NjcgMTcuMDAwMiwxMi4xMjk3IEMxNy4wMDAyLDE0LjQzNjcgMTYuMzAzMiwxNi4zMjU3IDE0LjkwODIsMTcuNzk1NyBDMTMuNTEzMiwxOS4yNjQ3IDExLjczMDIsMTkuOTk5NyA5LjU1ODIsMTkuOTk5NyBDOC43MDIyLDE5Ljk5OTcgNy44NzEyLDE5Ljg0NjcgNy4wNjYyLDE5LjUzOTcgQzYuMjYwMiwxOS4yMzM3IDUuNTY4MiwxOC44MDQ3IDQuOTg4MiwxOC4yNTU3IEM0LjMyNTIsMTcuNjUwNyAzLjgyODIsMTcuMDEyNyAzLjQ5NzIsMTYuMzM5NyBDMy4xNjUyLDE1LjY2NjcgMy4wMDAyLDE0Ljk3NzcgMy4wMDAyLDE0LjI3MjcgQzMuMDAwMiwxMy40ODQ3IDMuMTcwMiwxMi44NzU3IDMuNTExMiwxMi40NDQ3IEMzLjg1MTIsMTIuMDE0NyA0LjM4OTIsMTEuNzIxNyA1LjEyNjIsMTEuNTY2NyBDNC45ODgyLDExLjI0NTcgNC44ODcyLDEwLjk3NTcgNC44MjIyLDEwLjc1NTcgQzQuNzU4MiwxMC41MzU3IDQuNzI1MiwxMC4zNjY3IDQuNzI1MiwxMC4yNDc3IEM0LjcyNTIsOS44MzU3IDQuOTQ0Miw5LjQxNDcgNS4zODIyLDguOTgzNyBDNS44MTkyLDguNTUyNyA2LjIzMTIsOC4zMzc3IDYuNjE3Miw4LjMzNzcgQzYuNzgzMiw4LjMzNzcgNi45NTcyLDguMzY3NyA3LjE0MjIsOC40MjY3IEM3LjMyNjIsOC40ODY3IDcuNTM3Miw4LjU4NTcgNy43NzcyLDguNzIyNyBDNy4wNjgyLDYuNzI2NyA2LjU1MzIsNS4xODU3IDYuMjMxMiw0LjEwMDcgQzUuOTA4MiwzLjAxNDcgNS43NDcyLDIuMjY2NyA1Ljc0NzIsMS44NTQ3IEM1Ljc0NzIsMS4yODY3IDUuODk0MiwwLjgzNTcgNi4xODkyLDAuNTAxNyBDNi40ODQyLDAuMTY3NyA2Ljg4NDIsLTAuMDAwMyA3LjM5MDIsLTAuMDAwMyBDOC4yNTUyLC0wLjAwMDMgOS4zNTEyLDEuOTIyNyAxMC42NzYyLDUuNzY5NyBDMTAuOTA2Miw2LjQyODcgMTEuMDgxMiw2LjkzNjcgMTEuMjAxMiw3LjI5NDcgQzExLjMwMzIsNy4wMDk3IDExLjQ0NTIsNi42MDc3IDExLjYyOTIsNi4wODU3IEMxMi45NTUyLDIuMjc1NyAxNC4wOTUyLDAuMzcwNyAxNS4wNTMyLDAuMzcwNyBDMTUuNTIyMiwwLjM3MDcgMTUuODk3MiwwLjUyODcgMTYuMTc5MiwwLjg0NDcgQzE2LjQ1OTIsMS4xNjA3IDE2LjU5OTIsMS41ODQ3IDE2LjU5OTIsMi4xMTU3IEMxNi41OTkyLDIuNTE4NyAxNi40NDUyLDMuMjU1NyAxNi4xMzcyLDQuMzI2NyBDMTUuODI4Miw1LjM5ODcgMTUuMzYxMiw2Ljc5OTcgMTQuNzM1Miw4LjUyOTcgTDE0LjczNTIsOC41Mjk3IFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguMjgxLDExLjQzODMgTDE2LjEzMiwxMC4wMDAzIEwxOC4yODEsOC41NjIzIEwxOC4yODEsMTEuNDM4MyBaIE0xMC44NTksMTcuNTM0MyBMMTAuODU5LDEzLjUyNjMgTDE0LjU4NiwxMS4wMzQzIEwxNy41OTQsMTMuMDQ1MyBMMTAuODU5LDE3LjUzNDMgWiBNMTAsMTIuMDMzMyBMNi45NjEsMTAuMDAwMyBMMTAsNy45NjYzIEwxMy4wNCwxMC4wMDAzIEwxMCwxMi4wMzMzIFogTTkuMTQxLDE3LjUzNDMgTDIuNDA3LDEzLjA0NTMgTDUuNDE1LDExLjAzNDMgTDkuMTQxLDEzLjUyNjMgTDkuMTQxLDE3LjUzNDMgWiBNMS43MTksOC41NjIzIEwzLjg2OSwxMC4wMDAzIEwxLjcxOSwxMS40MzgzIEwxLjcxOSw4LjU2MjMgWiBNOS4xNDEsMi40NjUzIEw5LjE0MSw2LjQ3NDMgTDUuNDE1LDguOTY2MyBMMi40MDcsNi45NTQzIEw5LjE0MSwyLjQ2NTMgWiBNMTAuODU5LDIuNDY1MyBMMTcuNTk0LDYuOTU0MyBMMTQuNTg2LDguOTY2MyBMMTAuODU5LDYuNDc0MyBMMTAuODU5LDIuNDY1MyBaIE0xOS45ODUsNi44MDMzIEMxOS45NDQsNi41ODAzIDE5LjgxMiw2LjM2MDMgMTkuNjE3LDYuMjM4MyBMMTAuNDc3LDAuMTQ0MyBDMTAuMTg4LC0wLjA0NzcgOS44MTIsLTAuMDQ3NyA5LjUyMywwLjE0NDMgTDAuMzgzLDYuMjM4MyBDMC4xNDgsNi4zOTQzIDAsNi42NzEzIDAsNi45NTMzIEwwLDEzLjA0NjMgQzAsMTMuMzI4MyAwLjE0OCwxMy42MDYzIDAuMzgzLDEzLjc2MTMgTDkuNTIzLDE5Ljg1NTMgQzkuNjY4LDE5Ljk1MjMgOS44MzQsMjAuMDAwMyAxMCwyMC4wMDAzIEMxMC4xNjcsMjAuMDAwMyAxMC4zMzMsMTkuOTUyMyAxMC40NzcsMTkuODU1MyBMMTkuNjE3LDEzLjc2MTMgQzE5Ljg1NCwxMy42MTMzIDIwLDEzLjMyMzMgMjAsMTMuMDQ2MyBMMjAsNi45NTMzIEMyMC4wMDEsNi45MDIzIDE5Ljk5Niw2Ljg1MzMgMTkuOTg1LDYuODAzMyBMMTkuOTg1LDYuODAzMyBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTkuNzk3LDcuOTg4MyBDMTkuNjY0LDcuMzQ0MyAxOS40NjgsNi43MTQzIDE5LjIxMiw2LjEwODMgQzE4Ljk2MSw1LjUxMzMgMTguNjUyLDQuOTQ1MyAxOC4yOSw0LjQxMDMgQzE1LjIwMywtMC4xNjg3IDguOTg4LC0xLjM3NzcgNC40MDksMS43MDkzIEMzLjM0NCwyLjQyNzMgMi40MjcsMy4zNDQzIDEuNzA5LDQuNDEwMyBDMC45NzcsNS40OTIzIDAuNDY1LDYuNzA4MyAwLjIwMiw3Ljk4ODMgQy0wLjA2Nyw5LjMxNzMgLTAuMDY3LDEwLjY4NjMgMC4yMDIsMTIuMDE1MyBDMC40NjYsMTMuMjk1MyAwLjk3OCwxNC41MTAzIDEuNzA5LDE1LjU5MzMgQzIuNDI3LDE2LjY1NzMgMy4zNDMsMTcuNTc0MyA0LjQwNywxOC4yOTIzIEM0Ljk0MywxOC42NTMzIDUuNTEyLDE4Ljk2MjMgNi4xMDcsMTkuMjE0MyBDOC41OTYsMjAuMjYxMyAxMS40MDIsMjAuMjYxMyAxMy44OTMsMTkuMjE0MyBDMTQuNDg2LDE4Ljk2MjMgMTUuMDU2LDE4LjY1MzMgMTUuNTkxLDE4LjI5MjMgQzE2LjY1NSwxNy41NzQzIDE3LjU3MiwxNi42NTgzIDE4LjI5LDE1LjU5MzMgQzE5LjAyMiwxNC41MTAzIDE5LjUzMywxMy4yOTUzIDE5Ljc5NywxMi4wMTUzIEMyMC4wNjcsMTAuNjg2MyAyMC4wNjcsOS4zMTczIDE5Ljc5Nyw3Ljk4ODMgTDE5Ljc5Nyw3Ljk4ODMgWiBNMTguNTM3LDkuOTE1MyBDMTYuNTgsOS41MjIzIDE0LjU3NSw5LjQyNzMgMTIuNTksOS42MzUzIEMxMi41MjgsOS40OTAzIDEyLjQ2OSw5LjM0MjMgMTIuNDA4LDkuMTk2MyBDMTIuMjI2LDguNzc3MyAxMi4wMzksOC4zNjMzIDExLjg0LDcuOTU2MyBDMTMuNzAxLDcuMjgwMyAxNS4zNDYsNi4xMTIzIDE2LjU5OCw0LjU3NzMgQzE3LjgzOCw2LjA4MTMgMTguNTI0LDcuOTY2MyAxOC41NCw5LjkxNTMgTDE4LjUzNyw5LjkxNTMgWiBNMTUuNjQxLDMuNTkzMyBDMTQuNDkzLDUuMDQ0MyAxMi45NDEsNi4xMjAzIDExLjE3OSw2LjY4MzMgQzEwLjIzLDQuOTUyMyA5LjE2MywzLjI4ODMgNy45ODcsMS43MDIzIEMxMC42OTMsMS4wNDMzIDEzLjU1MiwxLjc0OTMgMTUuNjQxLDMuNTkyMyBMMTUuNjQxLDMuNTkzMyBaIE02LjM1NywyLjI3OTMgQzcuNTA2LDMuODU2MyA4LjU2Niw1LjQ5OTMgOS41MjgsNy4xOTgzIEM2Ljk1NCw3Ljg3NzMgNC4zMDUsOC4yMjczIDEuNjQzLDguMjQxMyBDMi4xOTUsNS42MjYzIDMuOTM5LDMuNDE5MyA2LjM1NywyLjI3OTMgTDYuMzU3LDIuMjc5MyBaIE0xLjQ2MSwxMC4wMDAzIEMxLjQ2MSw5LjkwOTMgMS40NjUsOS44MTgzIDEuNDY4LDkuNzI3MyBDNC40MzMsOS43MzkzIDcuMzg1LDkuMzI5MyAxMC4yMzUsOC41MTAzIEMxMC40OCw4Ljk4OTMgMTAuNzE0LDkuNDc3MyAxMC45MjgsOS45NjQzIEMxMC44MTYsOS45OTQzIDEwLjcwMywxMC4wMjkzIDEwLjU5MiwxMC4wNjYzIEM3LjcwNCwxMS4xMDEzIDUuMjU0LDEzLjA5MDMgMy42NDYsMTUuNzAyMyBDMi4yMzgsMTQuMTM2MyAxLjQ2MiwxMi4xMDUzIDEuNDY1LDEwLjAwMDMgTDEuNDYxLDEwLjAwMDMgWiBNMTAuMDA1LDE4LjU0NTMgQzguMDE5LDE4LjU0ODMgNi4wOTQsMTcuODU0MyA0LjU2NSwxNi41ODczIEM0LjY3NywxNi42NzczIDQuNzU2LDE2LjczNzMgNC43NTYsMTYuNzM3MyBDNC43NTYsMTYuNzM3MyA2LjM5MywxMy4xNjczIDExLjQ1OCwxMS40MDEzIEMxMS40NzcsMTEuMzk0MyAxMS40OTcsMTEuMzg5MyAxMS41MTYsMTEuMzg0MyBDMTIuMzI3LDEzLjQ4MzMgMTIuOTM4LDE1LjY1MzMgMTMuMzM5LDE3Ljg2ODMgQzEyLjI4NCwxOC4zMTUzIDExLjE1MSwxOC41NDYzIDEwLjAwNSwxOC41NDUzIEwxMC4wMDUsMTguNTQ1MyBaIE0xNC43NzcsMTcuMDgyMyBDMTQuNCwxNS4wMDYzIDEzLjg0MywxMi45NjUzIDEzLjExNSwxMC45ODMzIEMxNC44OTYsMTAuNzE5MyAxNi43MTIsMTAuODQ2MyAxOC40MzgsMTEuMzU2MyBDMTguMDYyLDEzLjY4OTMgMTYuNzM3LDE1Ljc2MjMgMTQuNzc3LDE3LjA4MzMgTDE0Ljc3NywxNy4wODIzIFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguODk2IDBIMS4xMDRDLjQ5NCAwIDAgLjQ5NCAwIDEuMTA0djE3Ljc5MkMwIDE5LjUwNi40OTQgMjAgMS4xMDQgMjBoOS41OHYtNy43MzRIOC4wODZWOS4yMzhoMi41OThWNy4wMWMwLTIuNTgzIDEuNTc3LTMuOTg5IDMuODgxLTMuOTg5IDEuMTA0IDAgMi4wNTMuMDgyIDIuMzMuMTE5djIuNjk5bC0xLjU5LjAwMWMtMS4yNTQgMC0xLjQ5Ni41OTYtMS40OTYgMS40N3YxLjkyOGgyLjk5N2wtLjM5IDMuMDI4aC0yLjYwN1YyMGg1LjA4N2MuNjEgMCAxLjEwNC0uNDk0IDEuMTA0LTEuMTA0VjEuMTA0QzIwIC40OTQgMTkuNTA2IDAgMTguODk2IDAiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOS45OTU4LDAuMDAyOSBDNC42MDU4LC0wLjEyNTEgMC4xMzE4LDQuMTM4OSAwLjAwMjgsOS41Mjg5IEMtMC4xMDEyLDEzLjg3NzkgMi42ODU4LDE3Ljc3MDkgNi44MzU4LDE5LjA3NDkgQzcuMDkzOCwxOS4xNzU5IDcuMzgzOCwxOS4wNDg5IDcuNDg0OCwxOC43OTE5IEM3LjUwNzgsMTguNzMxOSA3LjUxOTgsMTguNjY4OSA3LjUxODgsMTguNjA0OSBDNy41MTg4LDE4LjM3MDkgNy41MDk4LDE3Ljc1NTkgNy41MDU4LDE2LjkzOTkgQzQuNzIzOCwxNy41Mjk5IDQuMTM2OCwxNS42MjY5IDQuMTM2OCwxNS42MjY5IEMzLjk0OTgsMTUuMDMyOSAzLjU1NTgsMTQuNTI0OSAzLjAyNjgsMTQuMTk1OSBDMi4xMTc4LDEzLjU4ODkgMy4wOTU4LDEzLjYwMTkgMy4wOTU4LDEzLjYwMTkgQzMuNzMzOCwxMy42ODQ5IDQuMjk3OCwxNC4wNTY5IDQuNjI2OCwxNC42MDg5IEM1LjIxMTgsMTUuNjI3OSA2LjUwNTgsMTUuOTg5OSA3LjUzNTgsMTUuNDIyOSBDNy41ODI4LDE0LjkyMzkgNy44MDg4LDE0LjQ1ODkgOC4xNzE4LDE0LjExMzkgQzUuOTUwOCwxMy44NjY5IDMuNjE3OCwxMy4wMjM5IDMuNjE3OCw5LjI3NjkgQzMuNjAzOCw4LjMwMTkgMy45NzM4LDcuMzU4OSA0LjY0NTgsNi42NTE5IEM0LjM0MDgsNS44MDg5IDQuMzc1OCw0Ljg3OTkgNC43NDM4LDQuMDYyOSBDNC43NDM4LDQuMDYyOSA1LjU4MzgsMy43OTg5IDcuNDkzOCw1LjA2MTkgQzkuMTMzOCw0LjYyMzkgMTAuODU5OCw0LjYyMzkgMTIuNTAwOCw1LjA2MTkgQzE0LjQwOTgsMy43OTU5IDE1LjI0NzgsNC4wNjI5IDE1LjI0NzgsNC4wNjI5IEMxNS42MTY4LDQuODc4OSAxNS42NTE4LDUuODA4OSAxNS4zNDY4LDYuNjUxOSBDMTYuMDE5OCw3LjM1ODkgMTYuMzg5OCw4LjMwMTkgMTYuMzc0OCw5LjI3NjkgQzE2LjM3NDgsMTMuMDM2OSAxNC4wMzY4LDEzLjg2NDkgMTEuODA4OCwxNC4xMDY5IEMxMi4yOTA4LDE0LjU4MTkgMTIuNTM4OCwxNS4yNDQ5IDEyLjQ4ODgsMTUuOTE4OSBDMTIuNDg4OCwxNy4yMjg5IDEyLjQ3NTgsMTguMjgxOSAxMi40NzU4LDE4LjYwNDkgQzEyLjQ3MTgsMTguODc4OSAxMi42ODk4LDE5LjEwNjkgMTIuOTY0OCwxOS4xMTA5IEMxMy4wMzI4LDE5LjExMTkgMTMuMDk5OCwxOS4wOTk5IDEzLjE2MzgsMTkuMDczOSBDMTguMzA3OCwxNy40NTY5IDIxLjE2NTgsMTEuOTc2OSAxOS41NDc4LDYuODMyOSBDMTguMjQxOCwyLjY4MjkgMTQuMzQ2OCwtMC4xMDMxIDkuOTk1OCwwLjAwMjkiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUuMzM4IDMuNDYyYTEuMiAxLjIgMCAxIDAgMCAyLjQgMS4yIDEuMiAwIDAgMCAwLTIuNE0xMCAxMy4zMzJhMy4zMzMgMy4zMzMgMCAxIDEgMC02LjY2NCAzLjMzMyAzLjMzMyAwIDAgMSAwIDYuNjY1bTAtOC40NjhhNS4xMzUgNS4xMzUgMCAxIDAgMCAxMC4yNyA1LjEzNSA1LjEzNSAwIDAgMCAwLTEwLjI3TTEwIDBDNy4yODQgMCA2Ljk0My4wMTIgNS44NzcuMDYgNC44MTMuMTA5IDQuMDg2LjI3OCAzLjQ1LjUyNWE0LjkxOSA0LjkxOSAwIDAgMC0xLjc3MiAxLjE1M0E0LjkwNSA0LjkwNSAwIDAgMCAuNTI1IDMuNDVDLjI3OCA0LjA4Ni4xMDkgNC44MTMuMDYgNS44NzcuMDExIDYuOTQ0IDAgNy4yODQgMCAxMHMuMDExIDMuMDU3LjA2IDQuMTIzYy4wNDkgMS4wNjUuMjE4IDEuNzkuNDY1IDIuNDI4YTQuODk4IDQuODk4IDAgMCAwIDEuMTUzIDEuNzcgNC44ODIgNC44ODIgMCAwIDAgMS43NzIgMS4xNTRjLjYzNi4yNDggMS4zNjMuNDE3IDIuNDI3LjQ2NSAxLjA2Ni4wNDggMS40MDcuMDYgNC4xMjMuMDZzMy4wNTYtLjAxMiA0LjEyMy0uMDZjMS4wNjUtLjA0OCAxLjc5MS0uMjE3IDIuNDI3LS40NjVhNC44NyA0Ljg3IDAgMCAwIDEuNzcxLTEuMTU0IDQuODg4IDQuODg4IDAgMCAwIDEuMTU0LTEuNzdjLjI0Ny0uNjM3LjQxNi0xLjM2My40NjUtMi40MjguMDQ4LTEuMDY2LjA2LTEuNDA3LjA2LTQuMTIzcy0uMDEyLTMuMDU2LS4wNi00LjEyM2MtLjA0OS0xLjA2NC0uMjE4LTEuNzkxLS40NjUtMi40MjdhNC44OTUgNC44OTUgMCAwIDAtMS4xNTQtMS43NzJBNC45MDcgNC45MDcgMCAwIDAgMTYuNTUuNTI1QzE1LjkxNC4yNzggMTUuMTg4LjEwOSAxNC4xMjMuMDYgMTMuMDU2LjAxMiAxMi43MTYgMCAxMCAwbTAgMS44MDJjMi42NyAwIDIuOTg2LjAxIDQuMDQxLjA1OC45NzUuMDQ1IDEuNTA1LjIwNyAxLjg1Ny4zNDUuNDY2LjE4Ljc5OS4zOTggMS4xNDkuNzQ4LjM1MS4zNDkuNTY3LjY4My43NDkgMS4xNDkuMTM3LjM1My4yOTkuODgyLjM0NCAxLjg1Ny4wNDggMS4wNTUuMDU4IDEuMzcuMDU4IDQuMDRzLS4wMSAyLjk4Ny0uMDU4IDQuMDQyYy0uMDQ1Ljk3NS0uMjA3IDEuNTA0LS4zNDQgMS44NTdhMy4xMSAzLjExIDAgMCAxLS43NDkgMS4xNWMtLjM1LjM1LS42ODMuNTY2LTEuMTQ5Ljc0OC0uMzUyLjEzNy0uODgyLjMtMS44NTcuMzQ0LTEuMDU1LjA0OS0xLjM3LjA1OC00LjA0MS4wNTgtMi42NyAwLTIuOTg3LS4wMS00LjA0MS0uMDU4LS45NzUtLjA0NC0xLjUwNC0uMjA3LTEuODU3LS4zNDRhMy4xMDQgMy4xMDQgMCAwIDEtMS4xNS0uNzQ4IDMuMTMzIDMuMTMzIDAgMCAxLS43NDgtMS4xNWMtLjEzNy0uMzUzLS4zLS44ODItLjM0NC0xLjg1Ny0uMDQ4LTEuMDU1LS4wNTgtMS4zNzEtLjA1OC00LjA0MSAwLTIuNjcuMDEtMi45ODYuMDU4LTQuMDQxLjA0NC0uOTc1LjIwNy0xLjUwNC4zNDQtMS44NTcuMTgyLS40NjYuMzk5LS44Ljc0OC0xLjE1LjM1LS4zNS42ODMtLjU2NiAxLjE1LS43NDcuMzUzLS4xMzguODgyLS4zIDEuODU3LS4zNDVDNy4wMTQgMS44MTIgNy4zMyAxLjgwMiAxMCAxLjgwMiIvPgo8L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMC41MTYsMTkuNjM4OSBMNC40MTIsMTkuNjM4OSBMNC40MTIsNy4yOTU5IEwwLjUxNiw3LjI5NTkgTDAuNTE2LDE5LjYzODkgWiBNMi4zNjUsNS43NTE5IEwyLjMzNyw1Ljc1MTkgQzEuMTUyLDUuODQ2OSAwLjExNCw0Ljk2MjkgMC4wMTksMy43NzY5IEMwLjAxNCwzLjcyMTkgMC4wMTIsMy42NjY5IDAuMDEyLDMuNjExOSBDLTAuMTE4LDIuMzA2OSAwLjgzNCwxLjE0MjkgMi4xNCwxLjAxMTkgQzMuNDQ2LDAuODgwOSA0LjYxLDEuODMzOSA0Ljc0LDMuMTM5OSBDNC44Nyw0LjQ0NTkgMy45MTgsNS42MDk5IDIuNjEyLDUuNzM5OSBDMi41Myw1Ljc0ODkgMi40NDcsNS43NTE5IDIuMzY1LDUuNzUxOSBMMi4zNjUsNS43NTE5IFogTTIwLDE5LjYzOTkgTDE1LjU4MywxOS42Mzk5IEwxNS41ODMsMTMuMjUxOSBDMTUuNTgzLDExLjU3OTkgMTQuODkxLDEwLjQzNTkgMTMuMzcyLDEwLjQzNTkgQzEyLjQxOCwxMC40MzU5IDExLjU2OSwxMS4wNDM5IDExLjI2MiwxMS45NDc5IEMxMS4xNzIsMTIuMjc1OSAxMS4xNCwxMi42MTc5IDExLjE3MiwxMi45NTY5IEwxMS4xNzIsMTkuNjM5OSBMNi43OTEsMTkuNjM5OSBDNi43OTEsMTkuNjM5OSA2Ljg0Nyw4LjMyNDkgNi43OTEsNy4yOTU5IEwxMS4xNjcsNy4yOTU5IEwxMS4xNjcsOS4yMzI5IEMxMS40MjYsOC4zODY5IDEyLjgyNCw3LjE3NjkgMTUuMDU1LDcuMTc2OSBDMTcuODI0LDcuMTc2OSAyMCw4Ljk1MjkgMjAsMTIuNzc1OSBMMjAsMTkuNjM5OSBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMi4zNzE2LDUuMjY0MiBDMi4zOTY2LDUuMDE2MiAyLjMwMjYsNC43NzIyIDIuMTE5Niw0LjYwNTIgTDAuMjUxNiwyLjMzOTIgTDAuMjUxNiwyLjAwMDIgTDYuMDUwNiwyLjAwMDIgTDEwLjUzMjYsMTEuOTA1MiBMMTQuNDcyNiwyLjAwMDIgTDE5Ljk5OTYsMi4wMDAyIEwxOS45OTk2LDIuMzM5MiBMMTguNDAzNiwzLjg4MTIgQzE4LjI2NTYsMy45ODcyIDE4LjE5NzYsNC4xNjAyIDE4LjIyNTYsNC4zMzIyIEwxOC4yMjU2LDE1LjY2NzIgQzE4LjE5NzYsMTUuODM5MiAxOC4yNjU2LDE2LjAxMzIgMTguNDAzNiwxNi4xMTkyIEwxOS45NjI2LDE3LjY2MTIgTDE5Ljk2MjYsMTguMDAwMiBMMTIuMTE5NiwxOC4wMDAyIEwxMi4xMTk2LDE3LjY2MTIgTDEzLjczNDYsMTYuMDgxMiBDMTMuODkzNiwxNS45MjEyIDEzLjg5MzYsMTUuODc0MiAxMy44OTM2LDE1LjYzMDIgTDEzLjg5MzYsNi40NjgyIEw5LjQwMjYsMTcuOTYyMiBMOC43OTU2LDE3Ljk2MjIgTDMuNTY2Niw2LjQ2ODIgTDMuNTY2NiwxNC4xNzIyIEMzLjUyMjYsMTQuNDk1MiAzLjYyOTYsMTQuODIxMiAzLjg1NjYsMTUuMDU2MiBMNS45NTY2LDE3LjYyNDIgTDUuOTU2NiwxNy45NjIyIEwtMC4wMDA0LDE3Ljk2MjIgTC0wLjAwMDQsMTcuNjI0MiBMMi4xMDA2LDE1LjA1NjIgQzIuMzI1NiwxNC44MjEyIDIuNDI1NiwxNC40OTMyIDIuMzcxNiwxNC4xNzIyIEwyLjM3MTYsNS4yNjQyIFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOS45OTQ5LC0wLjAwMDEgQzQuNDc0OSwtMC4wMDAxIC0wLjAwMDEsNC40NzU5IC0wLjAwMDEsOS45OTU5IEMtMC4wMDAxLDEzLjk2NDkgMi4zNDg5LDE3LjU1NzkgNS45ODM5LDE5LjE1MDkgQzUuOTQwOSwxOC4zODA5IDUuOTk4OSwxNy42MDk5IDYuMTU1OSwxNi44NTQ5IEM2LjM0ODksMTYuMDQzOSA3LjQ0MTksMTEuNDA5OSA3LjQ0MTksMTEuNDA5OSBDNy4yMjQ5LDEwLjkxMDkgNy4xMTY5LDEwLjM3MDkgNy4xMjI5LDkuODI2OSBDNy4xMjI5LDguMzQ1OSA3Ljk4MjksNy4yMzk5IDkuMDQ5OSw3LjIzOTkgQzkuNzg5OSw3LjIyODkgMTAuMzk3OSw3LjgxOTkgMTAuNDA4OSw4LjU1OTkgQzEwLjQwODksOC42MjA5IDEwLjQwNTksOC42ODA5IDEwLjM5ODksOC43NDA5IEMxMC4yMDU5LDkuOTQ0OSA5LjkxMDksMTEuMTI5OSA5LjUxNTksMTIuMjg0OSBDOS4zMDQ5LDEzLjExMDkgOS44MDM5LDEzLjk1MjkgMTAuNjMwOSwxNC4xNjQ5IEMxMC43ODE5LDE0LjIwMjkgMTAuOTM3OSwxNC4yMTc5IDExLjA5MzksMTQuMjA5OSBDMTIuOTg3OSwxNC4yMDk5IDE0LjI2MzksMTEuNzc3OSAxNC4yNjM5LDguODk1OSBDMTQuMjYzOSw2LjcwNTkgMTIuNzg4OSw1LjA2NTkgMTAuMTAzOSw1LjA2NTkgQzcuNDkyOSw0Ljk2MTkgNS4yOTA5LDYuOTk0OSA1LjE4NjksOS42MDU5IEM1LjE4MzksOS42ODc5IDUuMTgyOSw5Ljc2OTkgNS4xODM5LDkuODUwOSBDNS4xNTI5LDEwLjU2MzkgNS4zODc5LDExLjI2MjkgNS44NDI5LDExLjgxMjkgQzYuMDA3OSwxMS45NDc5IDYuMDY1OSwxMi4xNzI5IDUuOTg1OSwxMi4zNzA5IEM1LjkzODksMTIuNTUyOSA1LjgyODksMTIuOTk4OSA1Ljc4MjksMTMuMTcyOSBDNS43NTI5LDEzLjM2MDkgNS41NzY5LDEzLjQ4ODkgNS4zODk5LDEzLjQ1NzkgQzUuMzUxOSwxMy40NTI5IDUuMzE1OSwxMy40NDA5IDUuMjgyOSwxMy40MjI5IEMzLjg4NTksMTIuODUzOSAzLjIzNTksMTEuMzI0OSAzLjIzNTksOS42MDY5IEMzLjIzNTksNi43Njc5IDUuNjI5OSwzLjM2MDkgMTAuMzc4OSwzLjM2MDkgQzE0LjE5NDksMy4zNjA5IDE2LjcwNzksNi4xMjQ5IDE2LjcwNzksOS4wODU5IEMxNi43MDc5LDEzLjAwNjkgMTQuNTI2OSwxNS45MzY5IDExLjMxMzksMTUuOTM2OSBDMTAuMzQxOSwxNS45NjE5IDkuNDIyOSwxNS40OTM5IDguODcxOSwxNC42OTE5IEM4Ljg3MTksMTQuNjkxOSA4LjI5MTksMTYuOTk0OSA4LjE2ODksMTcuNDM4OSBDNy45MzY5LDE4LjE5NjkgNy41OTg5LDE4LjkxNjkgNy4xNjI5LDE5LjU3OTkgQzEyLjQ1NTksMjEuMTQ3OSAxOC4wMTc5LDE4LjEyNjkgMTkuNTg1OSwxMi44MzM5IEMyMS4xNTI5LDcuNTQxOSAxOC4xMzM5LDEuOTc4OSAxMi44NDA5LDAuNDExOSBDMTEuOTE2OSwwLjEzNzkgMTAuOTU4OSwtMC4wMDAxIDkuOTk0OSwtMC4wMDAxIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTMuNDM4NCwxMy4wODI1IEMxMi42MDk0LDEzLjA4MjUgMTEuOTM3NCwxMi40MTA1IDExLjkzNzQsMTEuNTgwNSBDMTEuOTM3NCwxMC43NTE1IDEyLjYwOTQsMTAuMDc5NSAxMy40Mzg0LDEwLjA3OTUgQzE0LjI2NzQsMTAuMDc5NSAxNC45NDA0LDEwLjc1MTUgMTQuOTQwNCwxMS41ODA1IEMxNC45NzM0LDEyLjQwOTUgMTQuMzI4NCwxMy4xMDc1IDEzLjUwMDQsMTMuMTQxNSBDMTMuNDc0NCwxMy4xNDI1IDEzLjQ0OTQsMTMuMTQzNSAxMy40MjM0LDEzLjE0MjUgTDEzLjQzODQsMTMuMDgyNSBaIE0xMy43MDk0LDE1LjY0OTUgQzEyLjY0MzQsMTYuNDUyNSAxMS4zMzM0LDE2Ljg2MDUgMTAuMDAwNCwxNi44MDY1IEM4LjY2NzQsMTYuODYwNSA3LjM1NjQsMTYuNDUyNSA2LjI5MjQsMTUuNjQ5NSBDNi4xNDk0LDE1LjQ3NzUgNi4xNzQ0LDE1LjIyMTUgNi4zNDg0LDE1LjA3OTUgQzYuNDk3NCwxNC45NTY1IDYuNzEyNCwxNC45NTY1IDYuODYyNCwxNS4wNzk1IEM3Ljc2NTQsMTUuNzQxNSA4Ljg2NjQsMTYuMDc1NSA5Ljk4NTQsMTYuMDI0NSBDMTEuMTA1NCwxNi4wODY1IDEyLjIxMTQsMTUuNzYzNSAxMy4xMjM0LDE1LjEwOTUgQzEzLjI4OTQsMTQuOTQ3NSAxMy41NTQ0LDE0Ljk1MDUgMTMuNzE2NCwxNS4xMTY1IEMxMy44Nzc0LDE1LjI4MjUgMTMuODc1NCwxNS41NDg1IDEzLjcwOTQsMTUuNzA5NSBMMTMuNzA5NCwxNS42NDk1IFogTTQuOTg1NCwxMS41MjA1IEM0Ljk4NTQsMTAuNjkxNSA1LjY1NzQsMTAuMDE5NSA2LjQ4NjQsMTAuMDE5NSBDNy4zMTY0LDEwLjAxOTUgNy45ODg0LDEwLjY5MTUgNy45ODg0LDExLjUyMDUgQzcuOTg4NCwxMi4zNTA1IDcuMzE2NCwxMy4wMjE1IDYuNDg2NCwxMy4wMjE1IEM1LjY1NzQsMTMuMDIxNSA0Ljk4NTQsMTIuMzUwNSA0Ljk4NTQsMTEuNTIwNSBMNC45ODU0LDExLjUyMDUgWiBNMjAuMDAwNCwxMC4wMTk1IEMxOS45NTY0LDguODA5NSAxOC45Mzg0LDcuODY0NSAxNy43Mjk0LDcuOTA5NSBDMTcuMTkxNCw3LjkyODUgMTYuNjc5NCw4LjE0NTUgMTYuMjkxNCw4LjUxODUgQzE0LjU4MzQsNy4zNTY1IDEyLjU3NTQsNi43MTU1IDEwLjUxMDQsNi42NzE1IEwxMS40ODY0LDEuOTg2NSBMMTQuNzAwNCwyLjY2MjUgQzE0Ljc4ODQsMy40ODY1IDE1LjUyODQsNC4wODM1IDE2LjM1MzQsMy45OTQ1IEMxNy4xNzc0LDMuOTA2NSAxNy43NzQ0LDMuMTY1NSAxNy42ODU0LDIuMzQxNSBDMTcuNTk2NCwxLjUxNzUgMTYuODU2NCwwLjkyMDUgMTYuMDMyNCwxLjAwOTUgQzE1LjU1NzQsMS4wNjA1IDE1LjEzNDQsMS4zMzM1IDE0Ljg5NDQsMS43NDY1IEwxMS4yMTY0LDEuMDEwNSBDMTAuOTY1NCwwLjk1NjUgMTAuNzE2NCwxLjExNDUgMTAuNjYyNCwxLjM2NTUgQzEwLjY2MjQsMS4zNjc1IDEwLjY2MTQsMS4zNjk1IDEwLjY2MTQsMS4zNzE1IEw5LjU0OTQsNi41ODE1IEM3LjQ1OTQsNi42MTI1IDUuNDI0NCw3LjI1NDUgMy42OTQ0LDguNDI4NSBDMi44MTI0LDcuNTk4NSAxLjQyNTQsNy42NDA1IDAuNTk1NCw4LjUyMjUgQy0wLjIzMzYsOS40MDQ1IC0wLjE5MTYsMTAuNzkxNSAwLjY4OTQsMTEuNjIwNSBDMC44NjI0LDExLjc4MzUgMS4wNjE0LDExLjkxNzUgMS4yNzY0LDEyLjAxNjUgQzEuMjYwNCwxMi4yMzU1IDEuMjYwNCwxMi40NTc1IDEuMjc2NCwxMi42Nzc1IEMxLjI3NjQsMTYuMDQwNSA1LjE5NTQsMTguNzcyNSAxMC4wMzA0LDE4Ljc3MjUgQzE0Ljg2NTQsMTguNzcyNSAxOC43ODM0LDE2LjA0MDUgMTguNzgzNCwxMi42Nzc1IEMxOC44MDA0LDEyLjQ1NzUgMTguODAwNCwxMi4yMzU1IDE4Ljc4MzQsMTIuMDE2NSBDMTkuNTQwNCwxMS42NDA1IDIwLjAxMjQsMTAuODYzNSAyMC4wMDA0LDEwLjAxOTUgTDIwLjAwMDQsMTAuMDE5NSBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUsMTkgQzE1LDExLjI4IDguNzIsNSAxLDUgQzAuNDQ3LDUgMCw1LjQ0OCAwLDYgQzAsNi41NTIgMC40NDcsNyAxLDcgQzcuNjE3LDcgMTMsMTIuMzgzIDEzLDE5IEMxMywxOS41NTMgMTMuNDQ3LDIwIDE0LDIwIEMxNC41NTMsMjAgMTUsMTkuNTUzIDE1LDE5IE0yMCwxOSBDMjAsOC41MjMgMTEuNDc3LDAgMSwwIEMwLjQ0NywwIDAsMC40NDggMCwxIEMwLDEuNTUyIDAuNDQ3LDIgMSwyIEMxMC4zNzQsMiAxOCw5LjYyNiAxOCwxOSBDMTgsMTkuNTUzIDE4LjQ0NywyMCAxOSwyMCBDMTkuNTUzLDIwIDIwLDE5LjU1MyAyMCwxOSBNMTAsMTkgQzEwLDE0LjAzNyA1Ljk2MywxMCAxLDEwIEMwLjQ0NywxMCAwLDEwLjQ0OCAwLDExIEMwLDExLjU1MiAwLjQ0NywxMiAxLDEyIEM0Ljg1OSwxMiA4LDE1LjE0MSA4LDE5IEM4LDE5LjU1MyA4LjQ0NywyMCA5LDIwIEM5LjU1MywyMCAxMCwxOS41NTMgMTAsMTkgTTUsMTcuNSBDNSwxOC44ODEgMy44ODEsMjAgMi41LDIwIEMxLjExOSwyMCAwLDE4Ljg4MSAwLDE3LjUgQzAsMTYuMTE5IDEuMTE5LDE1IDIuNSwxNSBDMy44ODEsMTUgNSwxNi4xMTkgNSwxNy41Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTAuMTI2MDQzOSwxOSBDMTAuMDc1MDQ1MywxOSAxMC4wMjQwNDY4LDE4Ljk5ODA4MjMgOS45NzMwNDgyLDE4Ljk5NjE2NDUgQzkuOTQxMDQ5MSwxOC45OTgwODIzIDkuOTA3MDUwMDUsMTkgOS44NzQwNTA5OCwxOSBDOC42ODkwODQyMSwxOSA3LjkyODEwNTU1LDE4LjQ4NDEyNTMgNy4xOTMxMjYxNywxNy45ODU1MTAzIEM2LjY4NTE0MDQxLDE3LjY0MTI3NDIgNi4yMDYxNTM4NSwxNy4zMTcxNzQ1IDUuNjQxMTY5NjksMTcuMjI2MDgxNCBDNS4zNjYxNzc0LDE3LjE4MjkzMiA1LjA5MTE4NTExLDE3LjE2MDg3NzkgNC44MjcxOTI1MiwxNy4xNjA4Nzc5IEM0LjM0OTIwNTkyLDE3LjE2MDg3NzkgMy45NzIyMTY1LDE3LjIzMDg3NTggMy42OTcyMjQyMSwxNy4yODI2NTUgQzMuNTMwMjI4ODksMTcuMzE0Mjk3OSAzLjM4NjIzMjkzLDE3LjM0MjEwNTMgMy4yNzcyMzU5OSwxNy4zNDIxMDUzIEMzLjE2MjIzOTIxLDE3LjM0MjEwNTMgMy4wMzgyNDI2OSwxNy4zMTcxNzQ1IDIuOTg0MjQ0MiwxNy4xNDE3MDA0IEMyLjkzODI0NTQ5LDE2Ljk4NzMyMTUgMi45MDQyNDY0NSwxNi44Mzk2NTQ4IDIuODcxMjQ3MzcsMTYuNjk2NzgyNCBDMi43ODcyNDk3MywxNi4zMjc2MTU2IDIuNzI4MjUxMzgsMTYuMTAxMzIxMSAyLjU2NjI1NTkzLDE2LjA3NjM5MDQgQzAuNjg3MzA4NjIyLDE1Ljc5ODMxNjYgMC4xNDkzMjM3MDksMTUuNDE5NTYxIDAuMDI5MzI3MDc0NywxNS4xNDkxNTgzIEMwLjAxMjMyNzU1MTQsMTUuMTEwODAzMyAwLjAwMjMyNzgzMTg4LDE1LjA3MjQ0ODMgMC4wMDAzMjc4ODc5NjksMTUuMDM0MDkzMyBDLTAuMDA1NjcxOTQzNzcsMTQuOTMxNDkzNyAwLjA3MTMyNTg5NjgsMTQuODM5NDQxNyAwLjE3NzMyMjkyNCwxNC44MjMxNDA4IEMzLjA2NjI0MTksMTQuMzY2NzE2NCA0LjM2MTIwNTU5LDExLjUzNjExNzYgNC40MTUyMDQwNywxMS40MTYyNTgzIEM0LjQxNzIwNDAyLDExLjQxMjQyMjggNC40MTgyMDM5OSwxMS40MDk1NDYxIDQuNDIwMjAzOTMsMTEuNDA1NzEwNiBDNC41OTcxOTg5NywxMS4wNjI0MzM0IDQuNjMxMTk4MDIsMTAuNzY0MjIzMyA0LjUyMzIwMTA0LDEwLjUxOTcxMDIgQzQuMzI1MjA2NiwxMC4wNzA5NTY3IDMuNjc4MjI0NzQsOS44NzQzODczOSAzLjI1MTIzNjcyLDkuNzQ0OTM5MjcgQzMuMTQ2MjM5NjYsOS43MTIzMzc1MiAzLjA0NjI0MjQ3LDkuNjgyNjEyNCAyLjk2ODI0NDY1LDkuNjUyODg3MjggQzIuMTE0MjY4Niw5LjMyODc4NzU2IDIuMDQzMjcwNTksOC45OTcwMTY4MyAyLjA3NzI2OTY0LDguODI4MjU0ODUgQzIuMTM0MjY4MDQsOC41Mzk2MzM1IDIuNTM2MjU2NzcsOC4zMzgyNjk3NiAyLjg2MTI0NzY1LDguMzM4MjY5NzYgQzIuOTUwMjQ1MTYsOC4zMzgyNjk3NiAzLjAyOTI0Mjk0LDguMzUyNjUyODkgMy4wOTUyNDEwOSw4LjM4MjM3ODAxIEMzLjQ3OTIzMDMyLDguNTU0OTc1NSAzLjgyNTIyMDYyLDguNjQyMjMzMTEgNC4xMjQyMTIyMyw4LjY0MjIzMzExIEM0LjUzNzIwMDY1LDguNjQyMjMzMTEgNC43MTcxOTU2LDguNDc2MzQ3NzUgNC43MzkxOTQ5OSw4LjQ1NDI5MzYzIEM0LjcyOTE5NTI3LDguMjY3MzEzMDIgNC43MTYxOTU2Myw4LjA3MTcwMjU0IDQuNzAyMTk2MDIsNy44NjkzNzk5MyBDNC42MTYxOTg0NCw2LjU1OTU1Njc5IDQuNTEwMjAxNDEsNC45MzIzNDYwNSA0Ljk0MjE4OTI5LDQuMDAzMTk2MjUgQzYuMjM3MTUyOTgsMS4yMTk1ODIzNiA4Ljk4MzA3NTk3LDEuMDAyODc2NjIgOS43OTQwNTMyMiwxLjAwMjg3NjYyIEM5LjgxNDA1MjY2LDEuMDAyODc2NjIgMTAuMTQ5MDQzMywxIDEwLjE0OTA0MzMsMSBMMTAuMTk3MDQxOSwxIEMxMS4wMTAwMTkxLDEgMTMuNzYxOTQxOSwxLjIxNTc0Njg2IDE1LjA1NzkwNTYsNC4wMDEyNzg1IEMxNS40ODk4OTM1LDQuOTMxMzg3MTcgMTUuMzgyODk2NSw2LjU1OTU1Njc5IDE1LjI5Njg5ODksNy44Njg0MjEwNSBMMTUuMjkyODk5LDcuOTI0OTk0NjcgQzE1LjI4MTg5OTMsOC4xMDgxMzk3OCAxNS4yNjk4OTk3LDguMjg0NTcyNzcgMTUuMjU5ODk5OSw4LjQ1NDI5MzYzIEMxNS4yODA4OTkzLDguNDczNDcxMTMgMTUuNDQ2ODk0Nyw4LjYyNzg0OTk5IDE1LjgyMDg4NDIsOC42NDEyNzQyNCBMMTUuODIwODg0Miw4LjY0MTI3NDI0IEMxNi4xMDU4NzYyLDguNjMwNzI2NjEgMTYuNDMyODY3LDguNTQ0NDI3ODcgMTYuNzkxODU3LDguMzgyMzc4MDEgQzE2Ljg5Njg1NCw4LjMzNTM5MzE0IDE3LjAxMjg1MDgsOC4zMjU4MDQzOSAxNy4wOTI4NDg1LDguMzI1ODA0MzkgQzE3LjIxMzg0NTEsOC4zMjU4MDQzOSAxNy4zMzY4NDE3LDguMzQ4ODE3MzkgMTcuNDM4ODM4OCw4LjM4OTA5MDEzIEwxNy40NDU4Mzg2LDguMzkxOTY2NzYgQzE3LjczNTgzMDUsOC40ODk3NzIgMTcuOTI1ODI1Miw4LjY4NDQyMzYxIDE3LjkyOTgyNTEsOC44ODg2NjM5NyBDMTcuOTMzODI0OSw5LjA4MDQzODk1IDE3Ljc4MDgyOTIsOS4zNjkwNjAzIDE3LjAzMTg1MDIsOS42NTI4ODcyOCBDMTYuOTUzODUyNCw5LjY4MTY1MzUzIDE2Ljg1NDg1NTIsOS43MTIzMzc1MiAxNi43NDk4NTgxLDkuNzQ0OTM5MjcgQzE2LjMyMDg3MDIsOS44NzQzODczOSAxNS42NzQ4ODgzLDEwLjA3MDk1NjcgMTUuNDc2ODkzOCwxMC41MTg3NTEzIEMxNS4zNjc4OTY5LDEwLjc2MzI2NDQgMTUuNDAyODk1OSwxMS4wNjI0MzM0IDE1LjU3OTg5MSwxMS40MDU3MTA2IEMxNS41ODA4OTA5LDExLjQwODU4NzMgMTUuNTgyODkwOSwxMS40MTI0MjI4IDE1LjU4Mzg5MDgsMTEuNDE2MjU4MyBDMTUuNjM3ODg5MywxMS41MzYxMTc2IDE2LjkzMjg1MywxNC4zNjU3NTc1IDE5LjgyMjc3MiwxNC44MjMxNDA4IEMxOS45Mjg3NjksMTQuODM5NDQxNyAyMC4wMDQ3NjY5LDE0LjkzMDUzNDggMTkuOTk5NzY3LDE1LjAzNDA5MzMgQzE5Ljk5Njc2NzEsMTUuMDcyNDQ4MyAxOS45ODY3Njc0LDE1LjExMTc2MjIgMTkuOTY5NzY3OCwxNS4xNTAxMTcyIEMxOS44NTA3NzEyLDE1LjQxNzY0MzMgMTkuMzEzNzg2MiwxNS43OTYzOTg5IDE3LjQzMzgzOSwxNi4wNzU0MzE1IEMxNy4yNzk4NDMzLDE2LjA5ODQ0NDUgMTcuMjE5ODQ1LDE2LjI5MDIxOTUgMTcuMTI4ODQ3NSwxNi42OTE5ODgxIEMxNy4wOTU4NDg0LDE2LjgzODY5NTkgMTcuMDYxODQ5NCwxNi45ODI1MjcyIDE3LjAxNDg1MDcsMTcuMTM0MDI5NCBDMTYuOTc0ODUxOCwxNy4yNjQ0MzY0IDE2Ljg4OTg1NDIsMTcuMzI2NzYzMyAxNi43NDY4NTgyLDE3LjMyNjc2MzMgTDE2LjcyMjg1ODksMTcuMzI2NzYzMyBDMTYuNjIzODYxNywxNy4zMjY3NjMzIDE2LjQ4MTg2NTcsMTcuMzA4NTQ0NiAxNi4zMDE4NzA3LDE3LjI3NDk4NCBDMTUuOTgzODc5NiwxNy4yMTY0OTI2IDE1LjYyNjg4OTYsMTcuMTYwODc3OSAxNS4xNzI5MDI0LDE3LjE2MDg3NzkgQzE0LjkwNzkwOTgsMTcuMTYwODc3OSAxNC42MzM5MTc1LDE3LjE4MjkzMiAxNC4zNTc5MjUyLDE3LjIyNjA4MTQgQzEzLjc5Mzk0MSwxNy4zMTcxNzQ1IDEzLjMxNDk1NDUsMTcuNjQxMjc0MiAxMi44MDg5Njg3LDE3Ljk4NDU1MTUgQzEyLjA3MTk4OTMsMTguNDg0MTI1MyAxMS4zMTIwMTA3LDE5IDEwLjEyNjA0MzksMTkiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMCwxMy4yMyBDMCwxMy40ODIgMC4wOSwxMy42NzIgMC4yNywxMy44MDEgQzAuNDUsMTMuOTMgMC42NDIsMTMuOTc2IDAuODQ3LDEzLjkzOCBDMS4wMzksMTMuOSAxLjE3NCwxMy44MzEgMS4yNTIsMTMuNzMgQzEuMzI5LDEzLjYyOSAxLjM2OCwxMy40NjMgMS4zNjgsMTMuMjMgTDEuMzY4LDEwLjQ5NCBDMS4zNjgsMTAuMjk4IDEuMzAxLDEwLjEzMyAxLjE2OCw5Ljk5OCBDMS4wMzUsOS44NjMgMC44NzIsOS43OTQgMC42NzksOS43OTQgQzAuNDkzLDkuNzk0IDAuMzMzLDkuODYzIDAuMiw5Ljk5OCBDMC4wNjcsMTAuMTMzIDAsMTAuMjk4IDAsMTAuNDk0IEwwLDEzLjIzIFogTTIuMTQxLDE0LjQwMSBDMi4xNDEsMTQuNTg0IDIuMjA0LDE0LjcyIDIuMzMxLDE0LjgxMSBDMi40NTgsMTQuOTAzIDIuNjIxLDE0Ljk0OCAyLjgyLDE0Ljk0OCBDMy4wMjQsMTQuOTQ4IDMuMTksMTQuOTAzIDMuMzE4LDE0LjgxMSBDMy40NDUsMTQuNzIgMy41MDksMTQuNTg0IDMuNTA5LDE0LjQwMSBMMy41MDksOC4wMjEgQzMuNTA5LDcuODMyIDMuNDQyLDcuNjY5IDMuMzA5LDcuNTM0IEMzLjE3NSw3LjM5OSAzLjAxMiw3LjMzMiAyLjgyLDcuMzMyIEMyLjYzNCw3LjMzMiAyLjQ3NCw3LjM5OSAyLjM0MSw3LjUzNCBDMi4yMDcsNy42NjkgMi4xNDEsNy44MzIgMi4xNDEsOC4wMjEgTDIuMTQxLDE0LjQwMSBaIE00LjI3MSwxNC43MDMgQzQuMjcxLDE0Ljg4NSA0LjMzNywxNS4wMjIgNC40NjcsMTUuMTEzIEM0LjU5OCwxNS4yMDUgNC43NjUsMTUuMjUgNC45NywxNS4yNSBDNS4xNjgsMTUuMjUgNS4zMzEsMTUuMjA1IDUuNDU4LDE1LjExMyBDNS41ODUsMTUuMDIyIDUuNjQ5LDE0Ljg4NSA1LjY0OSwxNC43MDMgTDUuNjQ5LDguODc5IEM1LjY0OSw4LjY4NCA1LjU4Myw4LjUxOCA1LjQ0OSw4LjM3OSBDNS4zMTUsOC4yNDEgNS4xNTYsOC4xNzEgNC45Nyw4LjE3MSBDNC43NzcsOC4xNzEgNC42MTMsOC4yNDEgNC40NzcsOC4zNzkgQzQuMzQsOC41MTggNC4yNzEsOC42ODQgNC4yNzEsOC44NzkgTDQuMjcxLDE0LjcwMyBaIE02LjQxMiwxNC43MzEgQzYuNDEyLDE1LjA3NyA2LjY0MiwxNS4yNSA3LjEwMSwxNS4yNSBDNy41NiwxNS4yNSA3Ljc5LDE1LjA3NyA3Ljc5LDE0LjczMSBMNy43OSw1LjI5MyBDNy43OSw0Ljc2NCA3LjYyLDQuNDA0IDcuMzExLDQuMzY1IEM3LjEwMiw0LjMzNyA2LjkwOSw0LjMzOCA2LjcxLDQuNTA4IEM2LjUxMiw0LjY3OCA2LjQxMiw0Ljk4NSA2LjQxMiw1LjI5MyBMNi40MTIsMTQuNzMxIFogTTguNTksMTUuMDA0IEw4LjU5LDQuNzM2IEM4LjU5LDQuNDA5IDguNjg2LDQuMjE0IDguODc4LDQuMTUxIEM5LjI5NCw0LjA1IDkuNzA3LDQgMTAuMTE3LDQgQzExLjA2Niw0IDExLjk1LDQuMjI3IDEyLjc2OSw0LjY4IEMxMy41ODcsNS4xMzIgMTQuMjUsNS43NTEgMTQuNzU1LDYuNTM0IEMxNS4yNjEsNy4zMTcgMTUuNTU0LDguMTgxIDE1LjYzNSw5LjEyNSBDMTYuMDEzLDguOTYxIDE2LjQxNyw4Ljg3OSAxNi44NDUsOC44NzkgQzE3LjcxMyw4Ljg3OSAxOC40NTcsOS4xOTEgMTkuMDc0LDkuODE0IEMxOS42OTEsMTAuNDM3IDIwLDExLjE4NSAyMCwxMi4wNiBDMjAsMTIuOTQxIDE5LjY5MSwxMy42OTMgMTkuMDc0LDE0LjMxNiBDMTguNDU3LDE0LjkzOSAxNy43MTYsMTUuMjUxIDE2Ljg1NCwxNS4yNTEgTDguNzU4LDE1LjI0MSBDOC43MDIsMTUuMjIyIDguNjYsMTUuMTg3IDguNjMyLDE1LjEzNyBDOC42MDQsMTUuMDg2IDguNTksMTUuMDQyIDguNTksMTUuMDA0IEw4LjU5LDE1LjAwNCBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTAsMCBDNC40NzcsMCAwLDQuNDc3IDAsMTAgQzAsMTUuNTIyIDQuNDc3LDIwIDEwLDIwIEMxNS41MjIsMjAgMjAsMTUuNTIyIDIwLDEwIEMxOS45ODQsNC40ODQgMTUuNTE3LDAuMDE2IDEwLDAgTTE0LjYsMTQuNDU0IEMxNC40MzgsMTQuNzQgMTQuMDc1LDE0Ljg0MSAxMy43OSwxNC42NzkgQzEzLjc3NiwxNC42NzIgMTMuNzYzLDE0LjY2MyAxMy43NSwxNC42NTQgQzExLjQsMTMuMiA4LjQ1LDEyLjkwNCA0Ljk1LDEzLjcwNCBDNC42MTksMTMuNzg3IDQuMjgzLDEzLjU4NiA0LjIsMTMuMjU1IEM0LjExNywxMi45MjMgNC4zMTksMTIuNTg3IDQuNjUsMTIuNTA1IEM4LjQ1LDExLjY1NCAxMS43NSwxMi4wMDUgMTQuMzUsMTMuNjA0IEMxNC42NDcsMTMuNzQ5IDE0Ljc3MSwxNC4xMDcgMTQuNjI3LDE0LjQwNSBDMTQuNjE5LDE0LjQyMiAxNC42MDksMTQuNDM4IDE0LjYsMTQuNDU0IE0xNS44MDUsMTEuNyBDMTUuNTkxLDEyLjA1OCAxNS4xMjgsMTIuMTc0IDE0Ljc3MSwxMS45NiBDMTQuNzY2LDExLjk1NyAxNC43NiwxMS45NTMgMTQuNzU1LDExLjk1IEMxMS43MjUsMTAuMjQ3IDguMTM4LDkuODMzIDQuOCwxMC44IEM0LjM5OSwxMC45MjYgMy45NzMsMTAuNzAzIDMuODQ4LDEwLjMwMyBDMy43MjIsOS45MDIgMy45NDUsOS40NzYgNC4zNDUsOS4zNSBDOC4xMjYsOC4yNjkgMTIuMTgzLDguNzU1IDE1LjYsMTAuNyBDMTUuOTI5LDEwLjkwOSAxNi4wMjYsMTEuMzQ2IDE1LjgxNiwxMS42NzUgQzE1LjgxMiwxMS42ODQgMTUuODA2LDExLjY5MSAxNS44LDExLjcgTTE1LjksOC45IEMxMi43LDcgNy4zNSw2LjggNC4zLDcuNzUgQzMuODIzLDcuOTIgMy4yOTgsNy42NzEgMy4xMjgsNy4xOTQgQzIuOTU4LDYuNzE3IDMuMjA2LDYuMTkyIDMuNjgzLDYuMDIyIEMzLjcwNyw2LjAxNCAzLjczLDYuMDA2IDMuNzU0LDYgQzcuMzA1LDQuOTUgMTMuMTU0LDUuMTUgMTYuODU0LDcuMzUgQzE3LjMwNCw3LjYxNyAxNy40NTksOC4xOTMgMTcuMjA0LDguNjUgQzE2Ljg4Niw5LjAzMSAxNi4zNDIsOS4xMzYgMTUuOTA0LDguOSIvPgo8L3N2Zz4K\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguNTQgMS4yTC43NzggOC40NThzLS44NC4zLS43NzQuODUyYy4wNjYuNTUzLjc1Mi44MDcuNzUyLjgwN2w0LjQ2OCAxLjU2NiAxMC43MjgtNy4wOTZzLjYyLS4zOTIuNTk3IDBjMCAwIC4xMTEuMDctLjIyLjM5MS0uMzMzLjMyNC04LjQyOSA3LjkwNC04LjQyOSA3LjkwNGwtLjU4MyA1LjE4MmMuMjQ3LjExMi40NzMtLjA2Ni40NzMtLjA2NmwyLjg4Ny0yLjc0MiA0LjUwMSAzLjU5M2MxLjIxNi41NTQgMS42Ni0uNTk4IDEuNjYtLjU5OEwyMCAxLjYzOGMwLTEuMTA2LTEuNDYtLjQzOC0xLjQ2LS40MzgiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUuMDgzLDE1Ljk2NSBDMTQuNTk1LDE2LjE3MyAxNC4wNzEsMTYuMjkgMTMuNTQsMTYuMzEgQzEyLjU4NSwxNi4zOCAxMS43NTQsMTUuNjY5IDExLjY4NCwxNC43MjQgQzExLjY3NCwxNC41OTYgMTEuNjc5LDE0LjQ2NyAxMS42OTgsMTQuMzQgTDExLjY5OCw4LjExNSBMMTUuNTQyLDguMTE1IEwxNS41NDIsNS4wODcgTDExLjcwNyw1LjA4NyBMMTEuNzA3LDAgTDguOTA0LDAgQzguODI3LDAuMDA4IDguNzY4LDAuMDcyIDguNzY2LDAuMTUgQzguNjY3LDIuNTE1IDcuMjAxLDQuNjEyIDUsNS41MzMgTDUsOC4xMTUgTDYuOTM3LDguMTE1IEw2LjkzNywxNC42NDggQzYuOTAzLDE3LjU2OSA5LjI2NiwxOS45NjYgMTIuMjE1LDE5Ljk5OSBDMTIuMzcyLDIwLjAwMSAxMi41MjksMTkuOTk2IDEyLjY4NywxOS45ODUgQzE0LjA5NCwxOS45NiAxNS42NTUsMTkuMzQ5IDE2LDE4LjgxNCBMMTUuMDgzLDE1Ljk2MyIvPgo8L3N2Zz4K\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMS40MDYgMEwwIDMuNDMzdjE0LjAzaDUuMDAxVjIwaDIuODEybDIuNjU2LTIuNTM3aDQuMDYzTDIwIDEyLjIzOFYwSDEuNDA2em0xLjcxOSAxLjc5MWgxNXY5LjU1MkwxNSAxNC4zMjhoLTVsLTIuNjU2IDIuNTM3di0yLjUzN0gzLjEyNVYxLjc5MXptMTAgOC42NTFoMS44NzZWNS4yMjRoLTEuODc2djUuMjE4em0tNSAwSDEwVjUuMjI0SDguMTI1djUuMjE4eiIvPgo8L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNNi4yOSAxOC4yNTRjNy41NDcgMCAxMS42NzUtNi4yNTMgMTEuNjc1LTExLjY3NSAwLS4xNzgtLjAwNC0uMzU0LS4wMTItLjUzQTguMzM5IDguMzM5IDAgMCAwIDIwIDMuOTI0YTguMTY1IDguMTY1IDAgMCAxLTIuMzU2LjY0NiA0LjEyIDQuMTIgMCAwIDAgMS44MDQtMi4yNyA4LjE5OCA4LjE5OCAwIDAgMS0yLjYwNi45OTZBNC4xMDQgNC4xMDQgMCAwIDAgOS44NSA3LjAzOWExMS42NTIgMTEuNjUyIDAgMCAxLTguNDU4LTQuMjg3IDQuMTAxIDQuMTAxIDAgMCAwIDEuMjcgNS40NzcgNC4wNTggNC4wNTggMCAwIDEtMS44NTgtLjUxM2wtLjAwMS4wNTJhNC4xMDQgNC4xMDQgMCAwIDAgMy4yOTIgNC4wMjMgNC4xMDcgNC4xMDcgMCAwIDEtMS44NTMuMDcgNC4xMDcgNC4xMDcgMCAwIDAgMy44MzMgMi44NSA4LjIzMyA4LjIzMyAwIDAgMS01LjA5NiAxLjc1N0E4LjMzIDguMzMgMCAwIDEgMCAxNi40MTFhMTEuNjE0IDExLjYxNCAwIDAgMCA2LjI5IDEuODQzIi8+Cjwvc3ZnPg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTQuNzg1IDExLjk1N2MtLjI0Ni0uMTM1LTEuNDU1LS43ODMtMS42ODMtLjg3My0uMjI2LS4wOTEtLjM5LS4xNC0uNTY4LjEwNC0uMTc3LjI0Mi0uNjc5Ljc4NC0uODMuOTQ0LS4xNTIuMTYyLS4zLjE3Ny0uNTQ2LjA0My0uMjQ2LS4xMzUtMS4wNDMtLjQyOC0xLjk2OS0xLjMxLS43MTktLjY4Ny0xLjE5Mi0xLjUyLTEuMzI5LTEuNzc0LS4xMzctLjI1NSAwLS4zODQuMTMtLjUwMy4xMTYtLjEwNy4yNjEtLjI4MS4zOTItLjQyMS4xMy0uMTQyLjE3Ni0uMjQ0LjI2Ni0uNDA2LjA5LS4xNjMuMDU0LS4zMS0uMDA1LS40MzctLjA1OC0uMTI1LS41MTItMS4zNjktLjcwMy0xLjg3NS0uMTktLjUwNS0uNC0uNDMtLjU0OC0uNDM2LS4xNDYtLjAwNS0uMzEyLS4wMzItLjQ3OS0uMDM3YS45MjUuOTI1IDAgMCAwLS42OC4yODVjLS4yNC4yNC0uOTA5LjgxOS0uOTU2IDIuMDQyLS4wNDYgMS4yMjQuODA3IDIuNDQuOTI2IDIuNjEuMTIuMTcgMS42MyAyLjgyMiA0LjE0IDMuOTEzIDIuNTEgMS4wOTEgMi41MjMuNzU4IDIuOTg0LjczNC40NjEtLjAyNCAxLjUwNS0uNTQ2IDEuNzM2LTEuMTIuMjMxLS41NzIuMjUtMS4wNy4xOTEtMS4xNzUtLjA1OS0uMTA3LS4yMjMtLjE3Ni0uNDY5LS4zMDltLTQuNjA0IDUuODk2YTguMTggOC4xOCAwIDAgMS00LjQ5Ny0xLjM0bC0zLjE0Ljk5NyAxLjAyLTMuMDExYTguMDI1IDguMDI1IDAgMCAxLTEuNTU2LTQuNzU1YzAtNC40NzQgMy42NjctOC4xMTIgOC4xNzMtOC4xMTIgNC41MDcgMCA4LjE3MyAzLjYzOCA4LjE3MyA4LjExMSAwIDQuNDcyLTMuNjY2IDguMTEtOC4xNzMgOC4xMW0wLTE3Ljg1MkM0Ljc2IDAgLjM2MyA0LjM2Mi4zNjMgOS43NDJjMCAxLjg0MS41MTUgMy41NjMgMS40MSA1LjAzTDAgMjBsNS40MzUtMS43MjdhOS44MzggOS44MzggMCAwIDAgNC43NDYgMS4yMTJjNS40MjMgMCA5LjgyLTQuMzYyIDkuODItOS43NDIgMC01LjM4MS00LjM5Ny05Ljc0NC05LjgyLTkuNzQ0Ii8+Cjwvc3ZnPg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTkuOTkyNSw1LjE1NjggQzE5LjkwNTUsNy4xODU4IDE4LjU0NjUsOS45NjA4IDE1LjkxNjUsMTMuNDc5OCBDMTMuMTk3NSwxNy4xNTk4IDEwLjg5NDUsMTguOTk5OCA5LjAxMDUsMTguOTk5OCBDNy44NDU1LDE4Ljk5OTggNi44NTk1LDE3Ljg3ODggNi4wNTM1LDE1LjYzNTggQzUuNTEzNSwxMy41NzU4IDQuOTc0NSwxMS41MTY4IDQuNDM4NSw5LjQ2MTggQzMuODM4NSw3LjIxNTggMy4xOTU1LDYuMDkxOCAyLjUwOTUsNi4wOTI4IEMxLjkzODUsNi4zMzk4IDEuNDA5NSw2LjY3MTggMC45NDA1LDcuMDc2OCBMLTAuMDAwNSw1LjgxNTggQzAuOTg1NSw0LjkxNTggMS45NTc1LDQuMDExOCAyLjkxNTUsMy4xMDY4IEM0LjIyODUsMS45MjE4IDUuMjE0NSwxLjI5NzggNS44NzM1LDEuMjM0OCBDNy40MjY1LDEuMDc2OCA4LjM4MzUsMi4xODI4IDguNzQ0NSw0LjU1MzggQzkuMTI5NSw3LjExMTggOS4zOTc1LDguNzAxOCA5LjU0ODUsOS4zMjU4IEM5Ljk5ODUsMTEuNDQ1OCAxMC40OTE1LDEyLjUwNTggMTEuMDI3NSwxMi41MDM4IEMxMS40NDU1LDEyLjUwMzggMTIuMDczNSwxMS44MTg4IDEyLjkxMTUsMTAuNDQ4OCBDMTMuNTcyNSw5LjUwNzggMTQuMDMwNSw4LjQzOTggMTQuMjU1NSw3LjMxNDggQzE0LjM3NTUsNi4xMjg4IDEzLjkyNzUsNS41Mzk4IDEyLjkxMTUsNS41Mzk4IEMxMi40MDA1LDUuNTQ0OCAxMS44OTY1LDUuNjU2OCAxMS40MzE1LDUuODY1OCBDMTIuNDE5NSwyLjUyOTggMTQuMzAzNSwwLjkwODggMTcuMDgyNSwxLjAwMzggQzE5LjE0MTUsMS4wNjM4IDIwLjExMDUsMi40NDk4IDE5Ljk4OTUsNS4xNjI4Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNNi44NjEzLDAuMzg5NiBDNi4wNTYzLDAuNTkwNiA1LjI4OTMsMC44NTY2IDQuNTYzMywxLjE3ODYgQzQuMDU5MywxLjQwMTYgMy44NzAzLDEuOTc5NiA0LjE0ODMsMi40Mjk2IEw4LjUxNzMsOS40NzU2IEM5LjAwNzMsMTAuMjY2NiAxMC4zMDUzLDkuOTQyNiAxMC4zMDUzLDkuMDI5NiBMMTAuMzA1MywwLjg5MzYgQzEwLjMwNTMsMC4zNzM2IDkuODMwMywtMC4wMzg0IDkuMjc0MywwLjAwMjYgQzguNDcyMywwLjA2MTYgNy42NjYzLDAuMTg5NiA2Ljg2MTMsMC4zODk2IE0xNy45MjAzLDkuMjc0NiBDMTcuNDI2Myw4LjIxMzYgMTYuNjk2Myw3LjI5NzYgMTUuODA1Myw2LjU2NTYgQzE1LjM3MjMsNi4yMDk2IDE0LjcwMTMsNi4yOTE2IDE0LjM3ODMsNi43Mzc2IEwxMS43NzczLDEwLjMyNzYgQzExLjI3NzMsMTEuMDE3NiAxMS45NzYzLDExLjkxMjYgMTIuODM2MywxMS42ODM2IEwxNy4zMDUzLDEwLjQ5MDYgQzE3Ljg2MzMsMTAuMzQxNiAxOC4xNTAzLDkuNzY5NiAxNy45MjAzLDkuMjc0NiBNMTEuNzAwMywxNC40Mzg2IEwxNC4xNjUzLDE4LjExMTYgQzE0LjQ3MjMsMTguNTY5NiAxNS4xNDIzLDE4LjY2OTYgMTUuNTkwMywxOC4zMjY2IEMxNi41MjkzLDE3LjYwNDYgMTcuMjgyMywxNi43MDA2IDE3LjgwMDMsMTUuNjg4NiBDMTguMDQ5MywxNS4yMDI2IDE3Ljc4MTMsMTQuNjIxNiAxNy4yMzEzLDE0LjQ1NDYgTDEyLjgwOTMsMTMuMTE3NiBDMTEuOTU4MywxMi44NTk2IDExLjIyNjMsMTMuNzMyNiAxMS43MDAzLDE0LjQzODYgTTUuNjAxMywxOC43MzI2IEM2LjU5NDMsMTkuMzY3NiA3LjczMTMsMTkuNzk5NiA4LjkzMzMsMTkuOTg3NiBDOS41MDUzLDIwLjA3NjYgMTAuMDMxMywxOS42Nzc2IDEwLjA1MTMsMTkuMTM3NiBMMTAuMjE0MywxNC44MDk2IEMxMC4yNDUzLDEzLjk3NjYgOS4xNDIzLDEzLjU2MjYgOC41NDQzLDE0LjE4MTYgTDUuNDMyMywxNy4zOTk2IEM1LjA0NjMsMTcuNzk5NiA1LjEyNTMsMTguNDI2NiA1LjYwMTMsMTguNzMyNiBNMy43NTkzLDkuMzg2NiBMNy45MzkzLDExLjI4NTYgQzguNzQzMywxMS42NTA2IDguNjE5MywxMi43NTA2IDcuNzUxMywxMi45NTI2IEwzLjIzOTMsMTMuOTk5NiBDMi42NzYzLDE0LjEzMDYgMi4xMjEzLDEzLjc2OTYgMi4wNTQzLDEzLjIzMjYgQzEuOTEyMywxMi4wODQ2IDIuMDUyMywxMC45NTE2IDIuNDMxMyw5LjkwMjYgQzIuNjE1Myw5LjM5MjYgMy4yNDAzLDkuMTUxNiAzLjc1OTMsOS4zODY2Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOCwxMyBMOCw3IEwxMywxMCBMOCwxMyBaIE0xOS41ODIsNS4xODYgQzE5LjM1Myw0LjMyNiAxOC42NzUsMy42NDggMTcuODEzLDMuNDE4IEMxNi4yNTQsMyAxMCwzIDEwLDMgQzEwLDMgMy43NDYsMyAyLjE4NiwzLjQxOCBDMS4zMjYsMy42NDggMC42NDgsNC4zMjYgMC40MTgsNS4xODYgQzAsNi43NDYgMCwxMCAwLDEwIEMwLDEwIDAsMTMuMjU0IDAuNDE4LDE0LjgxMyBDMC42NDgsMTUuNjc1IDEuMzI2LDE2LjM1MyAyLjE4NiwxNi41ODIgQzMuNzQ2LDE3IDEwLDE3IDEwLDE3IEMxMCwxNyAxNi4yNTQsMTcgMTcuODEzLDE2LjU4MiBDMTguNjc1LDE2LjM1MyAxOS4zNTMsMTUuNjc1IDE5LjU4MiwxNC44MTMgQzIwLDEzLjI1NCAyMCwxMCAyMCwxMCBDMjAsMTAgMjAsNi43NDYgMTkuNTgyLDUuMTg2IEwxOS41ODIsNS4xODYgWiIvPgo8L3N2Zz4K\"","import { ReactComponent as LogoAngellist20 } from '../../icons/logo-angellist-20.svg'\nimport { ReactComponent as LogoCodepen20 } from '../../icons/logo-codepen-20.svg'\nimport { ReactComponent as LogoDribbble20 } from '../../icons/logo-dribbble-20.svg'\nimport { ReactComponent as LogoFacebook20 } from '../../icons/logo-facebook-20.svg'\nimport { ReactComponent as LogoGithub20 } from '../../icons/logo-github-20.svg'\nimport { ReactComponent as LogoInstagram20 } from '../../icons/logo-instagram-20.svg'\nimport { ReactComponent as LogoLinkedin20 } from '../../icons/logo-linkedin-20.svg'\nimport { ReactComponent as LogoMedium20 } from '../../icons/logo-medium-20.svg'\nimport { ReactComponent as LogoPinterest20 } from '../../icons/logo-pinterest-20.svg'\nimport { ReactComponent as LogoReddit20 } from '../../icons/logo-reddit-20.svg'\nimport { ReactComponent as LogoRss20 } from '../../icons/logo-rss-20.svg'\nimport { ReactComponent as LogoSnapchat20 } from '../../icons/logo-snapchat-20.svg'\nimport { ReactComponent as LogoSoundcloud20 } from '../../icons/logo-soundcloud-20.svg'\nimport { ReactComponent as LogoSpotify20 } from '../../icons/logo-spotify-20.svg'\nimport { ReactComponent as LogoTelegram20 } from '../../icons/logo-telegram-20.svg'\nimport { ReactComponent as LogoTumblr20 } from '../../icons/logo-tumblr-20.svg'\nimport { ReactComponent as LogoTwitch20 } from '../../icons/logo-twitch-20.svg'\nimport { ReactComponent as LogoTwitter20 } from '../../icons/logo-twitter-20.svg'\nimport { ReactComponent as LogoWhatsapp20 } from '../../icons/logo-whatsapp-20.svg'\nimport { ReactComponent as LogoVimeo20 } from '../../icons/logo-vimeo-20.svg'\nimport { ReactComponent as LogoYelp20 } from '../../icons/logo-yelp-20.svg'\nimport { ReactComponent as LogoYoutube20 } from '../../icons/logo-youtube-20.svg'\n\nexport const SocialLinksOptions = [\n { type: 'angellist', label: 'AngelList', icon: <LogoAngellist20 />, brandColor: 'black' },\n { type: 'codepen', label: 'CodePen', icon: <LogoCodepen20 />, brandColor: 'black' },\n { type: 'dribbble', label: 'Dribbble', icon: <LogoDribbble20 />, brandColor: '#ea4c89' },\n { type: 'facebook', label: 'Facebook', icon: <LogoFacebook20 />, brandColor: '#3b5998' },\n { type: 'github', label: 'GitHub', icon: <LogoGithub20 />, brandColor: 'black' },\n { type: 'instagram', label: 'Instagram', icon: <LogoInstagram20 />, brandColor: 'black' },\n { type: 'linkedin', label: 'LinkedIn', icon: <LogoLinkedin20 />, brandColor: '#0077b5' },\n { type: 'medium', label: 'Medium', icon: <LogoMedium20 />, brandColor: 'black' },\n { type: 'pinterest', label: 'Pinterest', icon: <LogoPinterest20 />, brandColor: '#bd081c' },\n { type: 'reddit', label: 'Reddit', icon: <LogoReddit20 />, brandColor: '#ff4500' },\n { type: 'rss', label: 'RSS', icon: <LogoRss20 />, brandColor: 'black' },\n { type: 'snapchat', label: 'Snapchat', icon: <LogoSnapchat20 />, brandColor: '#fffc00' },\n { type: 'soundcloud', label: 'SoundCloud', icon: <LogoSoundcloud20 />, brandColor: '#ff3300' },\n { type: 'spotify', label: 'Spotify', icon: <LogoSpotify20 />, brandColor: '#1db954' },\n { type: 'telegram', label: 'Telegram', icon: <LogoTelegram20 />, brandColor: '#0088cc' },\n { type: 'tumblr', label: 'Tumblr', icon: <LogoTumblr20 />, brandColor: '#35465c' },\n { type: 'twitch', label: 'Twitch', icon: <LogoTwitch20 />, brandColor: '#6441A4' },\n { type: 'twitter', label: 'Twitter', icon: <LogoTwitter20 />, brandColor: '#1da1f2' },\n { type: 'whatsapp', label: 'WhatsApp', icon: <LogoWhatsapp20 />, brandColor: '#25d366' },\n { type: 'vimeo', label: 'Vimeo', icon: <LogoVimeo20 />, brandColor: '#1ab7ea' },\n { type: 'yelp', label: 'Yelp', icon: <LogoYelp20 />, brandColor: '#af0606' },\n { type: 'youtube', label: 'YouTube', icon: <LogoYoutube20 />, brandColor: '#ff0000' },\n] as const\n","import styled from 'styled-components'\n\nimport { ResponsiveValue, Length } from '../../../../../prop-controllers/descriptors'\n\nimport GutterContainer from '../../../../shared/GutterContainer'\n\nconst PlaceholderLink = styled.div`\n width: 44px;\n height: 44px;\n border-radius: 50%;\n background-color: rgba(161, 168, 194, 0.4);\n`\n\nconst links = [{ id: '1' }, { id: '2' }, { id: '3' }]\n\ntype Props = { gutter?: ResponsiveValue<Length> }\n\nexport default function SocialLinksPlaceholder({ gutter }: Props): JSX.Element {\n return (\n <>\n {links.map((link, i) => (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n <PlaceholderLink />\n </GutterContainer>\n ))}\n </>\n )\n}\n","import { forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { Link } from '../../shared/Link'\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { SocialLinksOptions } from './options'\nimport GutterContainer from '../../shared/GutterContainer'\nimport SocialLinksPlaceholder from './components/SocialLinksPlaceholder'\nimport {\n ResponsiveValue,\n ElementIDValue,\n SocialLinksValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveSelectValue,\n GapXValue,\n MarginValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype Props = {\n id?: ElementIDValue\n links?: SocialLinksValue\n shape?: ResponsiveIconRadioGroupValue<'naked' | 'circle' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n hoverStyle?: ResponsiveSelectValue<'none' | 'grow' | 'shrink' | 'fade'>\n fill?: ResponsiveColor | null\n backgroundColor?: ResponsiveColor | null\n alignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gutter?: GapXValue\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.div<{\n margin: Props['margin']\n alignment: Props['alignment']\n}>`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n ${cssMargin()}\n ${p =>\n cssMediaRules(\n [p.alignment] as const,\n ([alignment = 'center']) => css`\n justify-content: ${alignment};\n `,\n )}\n`\n\nconst StyledLink = styled(Link)<{\n brandColor: string\n shape: Props['shape']\n size: Props['size']\n hoverStyle: Props['hoverStyle']\n fill: ResponsiveValue<Color> | null | undefined\n backgroundColor: ResponsiveValue<Color> | null | undefined\n}>`\n display: block;\n color: ${props => props.brandColor};\n transition: transform, opacity 0.18s;\n\n svg {\n display: block;\n }\n\n ${p =>\n cssMediaRules(\n [p.shape, p.size, p.hoverStyle, p.fill, p.backgroundColor] as const,\n ([shape = 'naked', size = 'medium', hoverStyle = 'none', fill, backgroundColor]) => css`\n padding: ${shape === 'naked' ? 0 : { small: 10, medium: 12, large: 14 }[size]}px;\n border-radius: ${{ circle: '50%', rounded: '8px', naked: 0, square: 0 }[shape]};\n background: ${shape === 'naked'\n ? 'transparent'\n : backgroundColor == null\n ? 'currentColor'\n : colorToString(backgroundColor)};\n\n :hover {\n ${{\n none: '',\n grow: css`\n transform: scale(1.1);\n `,\n shrink: css`\n transform: scale(0.9);\n `,\n fade: css`\n opacity: 0.65;\n `,\n }[hoverStyle]}\n }\n\n svg {\n fill: ${fill == null\n ? shape === 'naked' || backgroundColor != null\n ? 'currentColor'\n : 'white'\n : colorToString(fill)};\n width: ${{ small: 16, medium: 20, large: 24 }[size]}px;\n height: ${{ small: 16, medium: 20, large: 24 }[size]}px;\n }\n `,\n )}\n`\n\nconst SocialLinks = forwardRef(function SocialLinks(\n {\n id,\n links: { links, openInNewTab } = { links: [], openInNewTab: false },\n shape,\n size,\n hoverStyle,\n fill,\n backgroundColor,\n alignment,\n gutter,\n width,\n margin,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <Container ref={ref} id={id} className={cx(width)} alignment={alignment} margin={margin}>\n {links.length > 0 ? (\n links.map((link, i) => {\n const option = SocialLinksOptions.find(o => o.type === link.payload.type)\n\n if (!option) throw new Error(`Invalid link payload type ${link.payload.type}`)\n\n return (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n <StyledLink\n backgroundColor={backgroundColor}\n brandColor={option.brandColor}\n fill={fill}\n hoverStyle={hoverStyle}\n link={{ type: 'OPEN_URL', payload: { url: link.payload.url, openInNewTab } }}\n shape={shape}\n size={size}\n >\n {option == null ? null : option.icon}\n </StyledLink>\n </GutterContainer>\n )\n })\n ) : (\n <SocialLinksPlaceholder gutter={gutter} />\n )}\n </Container>\n )\n})\n\nexport default SocialLinks\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(SocialLinks, {\n type: './components/SocialLinks/index.js',\n label: 'Social Links',\n icon: 'SocialLinks40',\n props: {\n id: Props.ElementID(),\n links: Props.SocialLinks({\n preset: {\n links: [\n {\n id: 'facebook',\n payload: { type: 'facebook', url: 'https://www.facebook.com' },\n },\n {\n id: 'instagram',\n payload: { type: 'instagram', url: 'https://www.instagram.com' },\n },\n {\n id: 'twitter',\n payload: { type: 'twitter', url: 'https://www.twitter.com' },\n },\n ],\n openInNewTab: false,\n },\n }),\n shape: Props.ResponsiveIconRadioGroup(props => {\n const links = props.links as SocialLinksValue\n\n return {\n label: 'Shape',\n options: [\n { label: 'Naked', value: 'naked', icon: 'Star16' },\n { label: 'Circle', value: 'circle', icon: 'StarCircle16' },\n { label: 'Rounded', value: 'rounded', icon: 'StarRoundedSquare16' },\n { label: 'Square', value: 'square', icon: 'StarSquare16' },\n ],\n defaultValue: 'naked',\n hidden: links == null || links.links.length === 0,\n }\n }),\n size: Props.ResponsiveIconRadioGroup(props => {\n const links = props.links as SocialLinksValue\n\n return {\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n hidden: links == null || links.links.length === 0,\n }\n }),\n hoverStyle: Props.ResponsiveSelect(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'On hover',\n options: [\n { value: 'none', label: 'None' },\n { value: 'grow', label: 'Grow' },\n { value: 'shrink', label: 'Shrink' },\n { value: 'fade', label: 'Fade' },\n ],\n defaultValue: 'none',\n labelOrientation: 'horizontal',\n hidden,\n }\n }),\n fill: Props.ResponsiveColor(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'Icon color',\n hidden,\n }\n }),\n backgroundColor: Props.ResponsiveColor(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'Shape color',\n hidden,\n }\n }),\n alignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'flex-start', value: 'flex-start', icon: 'AlignLeft16' },\n { label: 'center', value: 'center', icon: 'AlignCenter16' },\n { label: 'flex-end', value: 'flex-end', icon: 'AlignRight16' },\n ],\n defaultValue: 'center',\n }),\n gutter: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Link gap',\n min: 0,\n max: 100,\n step: 1,\n defaultValue: { value: 0, unit: 'px' },\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n marginTop: { value: 10, unit: 'px' },\n marginRight: 'auto',\n marginBottom: { value: 10, unit: 'px' },\n marginLeft: 'auto',\n },\n },\n ],\n }),\n },\n })\n}\n","import type { ColorValue } from '../utils/types'\nimport type { Length as LengthValue } from '../../prop-controllers'\nimport { DeviceOverride } from '../../prop-controllers'\nimport { TYPOGRAPHIES_BY_ID } from '../utils/queries'\nimport { useQuery } from '../../api/react'\n\nexport type TypographyStyleValue = {\n fontFamily?: string\n fontWeight?: number\n fontSize?: LengthValue\n color?: ColorValue\n textAlign?: string\n lineHeight?: number\n letterSpacing?: number\n uppercase?: boolean\n underline?: boolean\n strikethrough?: boolean\n italic?: boolean\n}\n\nexport type TypographyStyle = Array<DeviceOverride<TypographyStyleValue>>\n\nexport type Typography = {\n id: string\n name: string\n style: TypographyStyle\n}\n\nexport function useTypography(\n typographyId: string | null | undefined,\n): Typography | null | undefined {\n const { error, data } = useQuery(TYPOGRAPHIES_BY_ID, {\n skip: typographyId == null,\n variables: { ids: typographyId != null ? [typographyId] : [] },\n })\n\n if (typographyId == null || error != null) return null\n\n return data?.typographies[0] as Typography | null\n}\n","import { Length as LengthValue } from '../../../../../../../../prop-controllers'\nimport { ColorValue as Color } from '../../../../../../../utils/types'\nimport { findDeviceOverride } from '../../../../../../../utils/devices'\nimport type { DeviceOverride } from '../../../../../../../../prop-controllers'\nimport { SWATCHES_BY_ID } from '../../../../../../../utils/queries'\nimport { useTypography, TypographyStyle } from '../../../../../../../hooks/useTypography'\nimport { useQuery } from '../../../../../../../../api/react'\n\nexport type TypographyMarkDataValue = {\n fontWeight?: number\n fontSize?: LengthValue\n fontFamily?: string\n color?: Color\n textAlign?: string\n lineHeight?: number\n letterSpacing?: number\n uppercase?: boolean\n italic?: boolean\n underline?: boolean\n strikethrough?: boolean\n}\n\nexport type TypographyMarkValue = {\n id: string | null | undefined\n style: TypographyStyle\n}\n\nexport type TypographyMarkData = Array<DeviceOverride<TypographyMarkDataValue>>\n\nconst concat = <A extends unknown[], B extends unknown[]>(a: A, b: B) => a.concat(b)\nconst getSwatchId = ({ value: { color } }: any) => color && color.swatchId\nconst getDeviceId = ({ deviceId }: any) => deviceId\n\nconst withColor =\n (swatches: any) =>\n ({ value: { color, ...restOfValue }, ...rest }: any) => ({\n ...rest,\n value: {\n ...restOfValue,\n ...(color\n ? {\n color: {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n },\n }\n : {}),\n },\n })\n\nexport const overrideTypographyStyle = <A>(\n source: Array<DeviceOverride<A>>,\n override: Array<DeviceOverride<A>>,\n): Array<DeviceOverride<A>> => {\n const devices = [...new Set(source.map(getDeviceId).concat(override.map(getDeviceId)))]\n\n return devices.map((deviceId: any) => ({\n deviceId,\n value: {\n ...(findDeviceOverride(source, deviceId) || { value: {} }).value,\n ...(findDeviceOverride(override, deviceId, v => v) || { value: {} }).value,\n },\n })) as DeviceOverride<A>[]\n}\n\nexport default function useTypographyMark(\n value: TypographyMarkValue | null | undefined,\n): TypographyMarkData | null | undefined {\n const typography = useTypography(value && value.id)\n\n const swatchIds = [\n (typography && typography.style.map(getSwatchId)) || [],\n (value && value.style.map(getSwatchId)) || [],\n ]\n .reduce(concat)\n .filter(Boolean)\n\n const { error: colorError, data: colorData = {} } = useQuery(SWATCHES_BY_ID, {\n skip: swatchIds == null || swatchIds.length === 0,\n variables: { ids: swatchIds },\n })\n\n const { swatches = [] } = colorData\n\n if (colorError != null) return null\n\n return overrideTypographyStyle(\n (typography && typography.style.map(withColor(swatches))) || [],\n (value && value.style.map(withColor(swatches))) || [],\n )\n}\n","import { ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport useTypographyMark, {\n TypographyMarkValue,\n TypographyMarkData,\n overrideTypographyStyle,\n TypographyMarkDataValue,\n} from './hooks/useTypographyMark'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { shallowMergeFallbacks } from '../../../../../../utils/devices'\n\nexport type { TypographyMarkValue }\nexport { overrideTypographyStyle }\n\nconst Span = styled.span<{ typographyStyle: TypographyMarkData | null | undefined }>`\n ${p =>\n cssMediaRules(\n [p.typographyStyle] as const,\n ([\n {\n color,\n fontFamily,\n fontSize,\n fontWeight,\n lineHeight,\n letterSpacing,\n uppercase,\n underline,\n strikethrough,\n italic,\n } = {} as TypographyMarkDataValue,\n ]) => css`\n ${color == null\n ? ''\n : css`\n color: ${colorToString(color)};\n `}\n\n ${fontFamily == null\n ? ''\n : css`\n font-family: '${fontFamily}';\n `}\n\n ${fontSize == null || fontSize.value == null || fontSize.unit == null\n ? ''\n : css`\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n `}\n\n ${fontWeight == null\n ? ''\n : css`\n font-weight: ${fontWeight};\n `}\n\n ${lineHeight == null\n ? ''\n : css`\n line-height: ${lineHeight};\n `}\n\n ${letterSpacing == null\n ? ''\n : css`\n letter-spacing: ${letterSpacing / 10}em;\n `}\n\n ${underline == null && strikethrough == null\n ? ''\n : css`\n text-decoration: ${[\n Boolean(underline) && 'underline',\n Boolean(strikethrough) && 'line-through',\n ]\n .filter(Boolean)\n .join(' ')};\n `}\n\n ${uppercase == null\n ? ''\n : css`\n text-transform: ${uppercase === true ? 'uppercase' : 'initial'};\n `}\n\n ${italic == null\n ? ''\n : css`\n font-style: ${italic === true ? 'italic' : 'initial'};\n `}\n `,\n shallowMergeFallbacks,\n )}\n`\n\ntype BaseProps = { value: TypographyMarkValue }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Span>, keyof BaseProps>\n\nexport default function Mark({ value, ...restOfProps }: Props): JSX.Element {\n const typographyStyle = useTypographyMark(value)\n\n return <Span {...restOfProps} typographyStyle={typographyStyle} />\n}\n","import type { Plugin } from 'slate-react'\n\nimport Mark from '../components/Mark'\n\nconst TYPOGRAPHY_TYPE = 'typography'\n\nexport default function DeviceOverridesMarksPlugin(): Plugin {\n return {\n renderMark({ mark, children }, _editor, next) {\n if (mark.type === TYPOGRAPHY_TYPE) {\n return <Mark value={mark.data.get('value')}>{children}</Mark>\n }\n\n return next()\n },\n }\n}\n","import { forwardRef, ElementType, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport type { ResponsiveValue } from '../../../../../../../prop-controllers'\n\ntype StyledBlockProps = {\n textAlign?: ResponsiveValue<'left' | 'center' | 'right' | 'justify'>\n as?: ElementType\n}\n\nconst StyledBlock = styled.div<StyledBlockProps>`\n margin: 0;\n ${p =>\n cssMediaRules([p.textAlign] as const, ([textAlign]) =>\n textAlign == null\n ? css``\n : css`\n text-align: ${textAlign};\n `,\n )}\n\n ${p =>\n p.as === 'blockquote'\n ? css`\n padding: 0.5em 10px;\n font-size: 1.25em;\n font-weight: 300;\n border-left: 5px solid rgba(0, 0, 0, 0.1);\n `\n : ''}\n`\n\ntype Props = ComponentPropsWithoutRef<typeof StyledBlock>\n\nexport default forwardRef<HTMLDivElement, Props>(function Block(\n { textAlign, ...restOfProps }: Props,\n ref,\n) {\n return <StyledBlock {...restOfProps} ref={ref} textAlign={textAlign} />\n})\n","import { Plugin } from 'slate-react'\n\nimport Block from '../components/Block'\n\nexport default function DeviceOverridesBlockPlugin(): Plugin {\n return {\n renderBlock(props, _editor, next): JSX.Element {\n const { node, attributes, children } = props\n const blockProps = { textAlign: node.data.get('textAlign') }\n\n switch (node.type) {\n case 'paragraph':\n return (\n <Block {...attributes} {...blockProps} as=\"p\">\n {children}\n </Block>\n )\n\n case 'heading-one':\n return (\n <Block {...attributes} {...blockProps} as=\"h1\">\n {children}\n </Block>\n )\n\n case 'heading-two':\n return (\n <Block {...attributes} {...blockProps} as=\"h2\">\n {children}\n </Block>\n )\n\n case 'heading-three':\n return (\n <Block {...attributes} {...blockProps} as=\"h3\">\n {children}\n </Block>\n )\n\n case 'heading-four':\n return (\n <Block {...attributes} {...blockProps} as=\"h4\">\n {children}\n </Block>\n )\n\n case 'heading-five':\n return (\n <Block {...attributes} {...blockProps} as=\"h5\">\n {children}\n </Block>\n )\n\n case 'heading-six':\n return (\n <Block {...attributes} {...blockProps} as=\"h6\">\n {children}\n </Block>\n )\n\n case 'blockquote':\n return (\n <Block {...attributes} {...blockProps} as=\"blockquote\">\n {children}\n </Block>\n )\n\n default:\n return next()\n }\n },\n }\n}\n","import { Plugin } from 'slate-react'\nimport styled from 'styled-components'\n\nimport { Link } from '../../../../../shared/Link'\n\nconst StyledLink = styled(Link)`\n text-decoration: none;\n`\n\nexport default function LinkPlugin(): Plugin {\n return {\n renderInline(props, _editor, next) {\n const { attributes, children, node } = props\n\n switch (node.type) {\n case 'link': {\n const { data } = node\n\n return (\n <StyledLink {...attributes} link={data.toJS()}>\n {children}\n </StyledLink>\n )\n }\n\n default: {\n return next()\n }\n }\n },\n }\n}\n","import { Plugin } from 'slate-react'\n\nexport default function Inlines(): Plugin {\n return {\n renderInline(props, _editor, next) {\n const { attributes, children, node } = props\n\n switch (node.type) {\n case 'code': {\n return <code {...attributes}>{children}</code>\n }\n\n case 'superscript': {\n return <sup {...attributes}>{children}</sup>\n }\n\n case 'subscript': {\n return <sub {...attributes}>{children}</sub>\n }\n\n default: {\n return next()\n }\n }\n },\n }\n}\n","import { ComponentPropsWithoutRef, forwardRef, useMemo } from 'react'\n\nimport { Editor as SlateEditor } from 'slate-react'\n\n// @ts-expect-error: no types for '@convertkit/slate-lists'\nimport Lists from '@convertkit/slate-lists'\nimport styled from 'styled-components'\n\nimport DeviceOverridesMarks from './plugins/DeviceOverridesMarks'\nimport DeviceOverridesBlocks from './plugins/DeviceOverridesBlocks'\nimport Link from './plugins/Link'\nimport Inlines from './plugins/Inlines'\n\nexport { overrideTypographyStyle } from './components/Mark'\n\ntype Props = ComponentPropsWithoutRef<typeof SlateEditor>\n\nexport const RichTextEditor = styled(\n forwardRef<SlateEditor, Props>(function RichTextEditor(\n { placeholder = 'Write some text...', ...restOfProps }: Props,\n ref,\n ) {\n const plugins = useMemo(\n () => [Lists(), Link(), Inlines(), DeviceOverridesBlocks(), DeviceOverridesMarks()],\n [],\n )\n\n return (\n <SlateEditor\n {...restOfProps}\n ref={ref}\n autoFocus={false}\n plugins={plugins}\n placeholder={placeholder}\n />\n )\n }),\n)`\n ul,\n ol {\n margin: 0;\n }\n`\n","import {\n useState,\n Ref,\n useImperativeHandle,\n forwardRef,\n useEffect,\n useCallback,\n useRef,\n KeyboardEvent as ReactKeyboardEvent,\n} from 'react'\nimport styled from 'styled-components'\nimport { Editor, OnChangeParam } from 'slate-react'\nimport { Value, ValueJSON } from 'slate'\n// @ts-expect-error: no types for 'slate-hotkeys'\nimport Hotkeys from 'slate-hotkeys'\n// @ts-expect-error: there are no types for 'corporate-ipsum'\nimport ipsum from 'corporate-ipsum'\nimport { cx } from '@emotion/css'\nimport { isHotkey } from 'is-hotkey'\n\nimport {\n ElementIDValue,\n MarginValue,\n RichTextDescriptor,\n RichTextValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssMargin } from '../../utils/cssMediaRules'\nimport { BoxModelHandle, getBox } from '../../../box-model'\nimport { PropControllersHandle } from '../../../state/modules/prop-controller-handles'\nimport { RichTextEditor } from './components/RichTextEditor'\nimport { ReactRuntime, useIsInBuilder } from '../../../react'\nimport { DescriptorsPropControllers } from '../../../prop-controllers/instances'\nimport { Props } from '../../../prop-controllers'\n\ntype Props = {\n id?: ElementIDValue\n text?: RichTextValue\n width?: string\n margin?: MarginValue\n}\n\nconst StyledRichTextEditor = styled(RichTextEditor)<{ margin: Props['margin'] }>`\n ${cssMargin()}\n`\n\nconst defaultText: ValueJSON = {\n document: { nodes: [{ object: 'block' as const, type: 'paragraph' as const, nodes: [] }] },\n data: {},\n}\n\nconst COMMIT_DEBOUNCE_DELAY = 500\n\ntype Descriptors = { text?: RichTextDescriptor }\n\nconst Text = forwardRef(function Text(\n { id, text, width, margin }: Props,\n ref: Ref<BoxModelHandle & PropControllersHandle<Descriptors>>,\n) {\n const [editor, setEditor] = useState<Editor | null>(null)\n const [propControllers, setPropControllers] =\n useState<DescriptorsPropControllers<Descriptors> | null>(null)\n const controller = propControllers?.text\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n const el = editor?.findDOMNode([])\n\n return el instanceof Element ? getBox(el) : null\n },\n setPropControllers,\n }),\n [editor, setPropControllers],\n )\n\n useEffect(() => {\n if (editor) controller?.setSlateEditor(editor)\n }, [controller, editor])\n\n /**\n * We must keep local state so that we can reflect the user's typed changes immediately. At the\n * same time, though, the source of truth for the data is the prop data. This presents a\n * challenge: how do we keep local state in sync with the prop data without mangling user input as\n * data comes in?\n *\n * Consider, for example, that the user types \"Hello\". If at a later time, when the user is trying\n * to type \", world\" the component re-renders with prop data \"H\", \"He\", \"Hel\", \"Hell\", \"Hello\", it\n * will disrupt the user's typing. This could also happen as a result of the prop data changing\n * for other reasons, like collaborators changing the prop data concurrently. We want to avoid to\n * disrupt the user's typing, while at the same time display the \"true\" value as quickly as\n * possible.\n *\n * The approach we take here is to commit the prop data at an opportune time: as the user is\n * typing we avoid to commit prop data. But once they've stopped typing, we commit it as soon as\n * possible. This is known as a debounce.\n */\n const [value, setValue] = useState(() => {\n const { selection, ...textWithoutSelection } = text ?? defaultText\n\n return Value.fromJSON(textWithoutSelection)\n })\n const [shouldCommit, setShouldCommit] = useState(true)\n\n useEffect(() => {\n if (shouldCommit) {\n const nextValue = Value.fromJSON(text ?? defaultText)\n\n setValue(currentValue =>\n currentValue.selection.isBlurred\n ? Value.fromJSON(nextValue.toJSON({ preserveSelection: false }))\n : nextValue,\n )\n }\n }, [shouldCommit, text])\n\n useEffect(() => {\n if (shouldCommit) return\n\n const timeoutId = window.setTimeout(() => {\n setShouldCommit(true)\n }, COMMIT_DEBOUNCE_DELAY)\n\n return () => {\n window.clearTimeout(timeoutId)\n }\n }, [shouldCommit])\n\n function handleChange(change: OnChangeParam) {\n setValue(change.value as Value)\n\n if (change.value !== value) {\n setShouldCommit(false)\n\n controller?.onChange(change)\n }\n }\n\n // HACK: Slate holds on to the very first DOM event handlers passed in and doesn't update them\n // even if they change. Since `controller` is first `undefined` then we must use a ref.\n const lastController = useRef(controller)\n if (lastController.current !== controller) lastController.current = controller\n const handleFocus = useCallback(() => {\n lastController.current?.focus()\n }, [])\n const handleKeyDown = useCallback(\n (event: ReactKeyboardEvent, _editor: Editor, next: () => any) => {\n if (Hotkeys.isUndo(event)) {\n lastController.current?.undo()\n\n return true\n }\n\n if (Hotkeys.isRedo(event)) {\n lastController.current?.redo()\n\n return true\n }\n\n if (isHotkey('escape')(event)) {\n lastController.current?.blur()\n\n return true\n }\n\n return next()\n },\n [],\n )\n\n const isInBuilder = useIsInBuilder()\n\n return (\n <StyledRichTextEditor\n // @ts-expect-error: types don't allow for 'id' prop even though it's used.\n id={id}\n ref={setEditor}\n className={cx(width)}\n readOnly={!isInBuilder}\n margin={margin}\n value={value}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n // Workaround for: clicking on any of the text panel will remove the text selection.\n onBlur={e => e.preventDefault()}\n />\n )\n})\n\nexport default Text\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Text, {\n type: './components/Text/index.js',\n label: 'Text',\n props: {\n id: Props.ElementID(),\n text: Props.RichText(() => ({\n preset: {\n document: {\n nodes: [\n {\n object: 'block',\n type: 'paragraph',\n nodes: [\n {\n object: 'text',\n text: ipsum(3),\n marks: [\n {\n object: 'mark',\n type: 'typography',\n data: {\n value: {\n id: null,\n style: [\n {\n deviceId: 'mobile',\n value: { fontSize: { value: 16, unit: 'px' } },\n },\n {\n deviceId: 'desktop',\n value: {\n fontWeight: 400,\n fontSize: { value: 18, unit: 'px' },\n lineHeight: 1.5,\n },\n },\n ],\n },\n },\n },\n ],\n },\n ],\n },\n ],\n },\n },\n })),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n preset: [{ deviceId: 'desktop', value: { value: 700, unit: 'px' } }],\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n marginTop: null,\n marginRight: 'auto',\n marginBottom: { value: 20, unit: 'px' },\n marginLeft: 'auto',\n },\n },\n ],\n }),\n },\n })\n}\n","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\nimport ReactPlayer from 'react-player'\nimport { cx } from '@emotion/css'\n\nimport {\n BorderRadiusValue,\n ElementIDValue,\n MarginValue,\n VideoValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssBorderRadius, cssMargin } from '../../utils/cssMediaRules'\nimport { placeholders } from '../../utils/placeholders'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\n\ntype Props = {\n id?: ElementIDValue\n video?: VideoValue\n width?: string\n margin?: MarginValue\n borderRadius?: BorderRadiusValue\n}\n\nconst Container = styled.div<{ margin: Props['margin']; borderRadius: Props['borderRadius'] }>`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n ${cssMargin()}\n ${cssBorderRadius()}\n`\n\nconst ASPECT_RATIO = 16 / 9\n\nconst Video = forwardRef(function Video(\n { id, video, width, margin, borderRadius }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const canPlayUrl = video && video.url != null && ReactPlayer.canPlay(video.url)\n\n return (\n <Container ref={ref} id={id} className={cx(width)} margin={margin} borderRadius={borderRadius}>\n <div style={{ position: 'relative', paddingTop: `${100 / ASPECT_RATIO}%` }}>\n <div style={{ position: 'absolute', top: 0, left: 0, right: 0, bottom: 0 }}>\n {canPlayUrl === true ? (\n <ReactPlayer\n {...video}\n width=\"100%\"\n height=\"100%\"\n config={{\n vimeo: { playerOptions: { background: video != null && !video.controls } },\n wistia: {\n options: {\n endVideoBehavior: video != null && video.loop === true ? 'loop' : 'default',\n },\n },\n }}\n />\n ) : (\n <img width=\"100%\" src={placeholders.video.src} alt=\"Video Placeholder\" />\n )}\n </div>\n </div>\n </Container>\n )\n})\n\nexport default Video\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Video, {\n type: './components/Video/index.js',\n label: 'Video',\n icon: 'Video40',\n props: {\n id: Props.ElementID(),\n video: Props.Video({ preset: { controls: true } }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 560, unit: 'px' },\n }),\n margin: Props.Margin(),\n borderRadius: Props.BorderRadius(),\n },\n })\n}\n","export * from './Box'\nexport { default as Box } from './Box'\nexport { default as Button } from './Button'\nexport { default as Carousel } from './Carousel'\nexport { default as Countdown } from './Countdown'\nexport { default as Divider } from './Divider'\nexport { default as Embed } from './Embed'\nexport { default as Form } from './Form'\nexport { default as Image } from './Image'\nexport { default as Navigation } from './Navigation'\nexport { default as Root } from './Root'\nexport { default as SocialLinks } from './SocialLinks'\nexport { default as Text } from './Text'\n\nimport { ReactRuntime } from '../../react'\nimport { registerComponent as registerBoxComponent } from './Box'\nimport { registerComponent as registerButtonComponent } from './Button'\nimport { registerComponent as registerCarouselComponent } from './Carousel'\nimport { registerComponent as registerCountdownComponent } from './Countdown'\nimport { registerComponent as registerDividerComponent } from './Divider'\nimport { registerComponent as registerEmbedComponent } from './Embed'\nimport { registerComponent as registerFormComponent } from './Form'\nimport { registerComponent as registerImageComponent } from './Image'\nimport { registerComponent as registerNavigationComponent } from './Navigation'\nimport { registerComponent as registerRootComponent } from './Root'\nimport { registerComponent as registerSocialLinksComponent } from './SocialLinks'\nimport { registerComponent as registerTextComponent } from './Text'\nimport { registerComponent as registerVideoComponent } from './Video'\n\nexport function registerBuiltinComponents(runtime: ReactRuntime) {\n const unregisterBoxComponent = registerBoxComponent(runtime)\n const unregisterButtonComponent = registerButtonComponent(runtime)\n const unregisterCarouselComponent = registerCarouselComponent(runtime)\n const unregisterCountdownComponent = registerCountdownComponent(runtime)\n const unregisterDividerComponent = registerDividerComponent(runtime)\n const unregisterEmbedComponent = registerEmbedComponent(runtime)\n const unregisterFormComponent = registerFormComponent(runtime)\n const unregisterImageComponent = registerImageComponent(runtime)\n const unregisterNavigationComponent = registerNavigationComponent(runtime)\n const unregisterRootComponent = registerRootComponent(runtime)\n const unregisterSocialLinksComponent = registerSocialLinksComponent(runtime)\n const unregisterTextComponent = registerTextComponent(runtime)\n const unregisterVideoComponent = registerVideoComponent(runtime)\n\n return () => {\n unregisterBoxComponent()\n unregisterButtonComponent()\n unregisterCarouselComponent()\n unregisterCountdownComponent()\n unregisterDividerComponent()\n unregisterEmbedComponent()\n unregisterFormComponent()\n unregisterImageComponent()\n unregisterNavigationComponent()\n unregisterRootComponent()\n unregisterSocialLinksComponent()\n unregisterTextComponent()\n unregisterTextComponent()\n unregisterVideoComponent()\n }\n}\n","import { useEffect } from 'react'\n\nconst SCRIPT_TAG = 'script'\n\ntype Props = {\n code: string\n cleanup: string | null | undefined\n}\n\nexport function BodySnippet({ code, cleanup }: Props): null {\n useEffect(() => {\n const container = document.createElement('div')\n\n container.innerHTML = code\n\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT)\n const scripts: HTMLScriptElement[] = []\n\n while (walker.nextNode()) {\n if (walker.currentNode instanceof HTMLScriptElement) scripts.push(walker.currentNode)\n }\n\n scripts.forEach(inlineScript => {\n const executableScript = document.createElement(SCRIPT_TAG)\n\n executableScript.textContent = inlineScript.textContent\n Array.from(inlineScript.attributes).forEach(({ name, value }) => {\n executableScript.setAttribute(name, value)\n })\n\n inlineScript.parentNode?.replaceChild(executableScript, inlineScript)\n })\n\n const nodes = Array.from(container.childNodes)\n\n document.body.append(...nodes)\n\n return () => {\n nodes.forEach(node => {\n node.parentNode?.removeChild(node)\n })\n\n if (cleanup == null) return\n\n const cleanUp = new Function(cleanup)\n\n try {\n cleanUp()\n } catch {\n // Ignore errors from user input.\n }\n }\n }, [code, cleanup])\n\n return null\n}\n","export default function is(x: unknown, y: unknown): boolean {\n if (x === y) return x !== 0 || y !== 0 || 1 / x === 1 / y\n\n return x !== x && y !== y\n}\n","import is from './is'\n\nconst { hasOwnProperty } = Object.prototype\n\nconst shallowEqual = (a: unknown, b: unknown): boolean => {\n if (is(a, b)) return true\n\n if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) return false\n\n const keysA = Object.keys(a)\n const keysB = Object.keys(b)\n\n if (keysA.length !== keysB.length) return false\n\n for (let i = 0; i < keysA.length; i += 1) {\n // @ts-expect-error: {}[string] is OK.\n if (!hasOwnProperty.call(b, keysA[i]) || !is(a[keysA[i]], b[keysA[i]])) return false\n }\n\n return true\n}\n\nexport default shallowEqual\n","import shallowEqual from './shallowEqual'\n\nconst { hasOwnProperty } = Object.prototype\n\nconst deepEqual = (a: unknown, b: unknown): boolean => {\n if (shallowEqual(a, b)) return true\n\n if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) return false\n\n const keysA = Object.keys(a)\n const keysB = Object.keys(b)\n\n if (keysA.length !== keysB.length) return false\n\n for (let i = 0; i < keysA.length; i += 1) {\n if (\n !hasOwnProperty.call(b, keysA[i]) ||\n // @ts-expect-error: {}[string] is OK.\n !deepEqual(a[keysA[i]], b[keysA[i]])\n )\n return false\n }\n\n return true\n}\n\nexport default deepEqual\n","import { ReactElement, Children, createElement, useMemo, useEffect, useRef, useState } from 'react'\nimport parse from 'html-react-parser'\nimport Head from 'next/head'\n\nimport { BodySnippet } from './BodySnippet'\nimport { DocumentReference } from '../../runtimes/react'\nimport { createDocumentReference } from '../../state/react-page'\nimport { useQuery, gql } from '../../api/react'\nimport { useIsInBuilder } from '../../react'\nimport deepEqual from '../../utils/deepEqual'\n\nenum SnippetLocation {\n Body = 'BODY',\n Head = 'HEAD',\n}\n\ntype Snippet = {\n builderEnabled: boolean\n cleanup?: string | null\n code: string\n id: string\n liveEnabled: boolean\n location: SnippetLocation\n}\n\nexport type PageData = {\n id: string\n meta: {\n title?: string | null | undefined\n description?: string | null | undefined\n keywords?: string | null | undefined\n socialImage?: { id: string; publicUrl: any; mimetype: any } | null | undefined\n favicon?: { id: string; publicUrl: any; mimetype: any } | null | undefined\n }\n snippets: Snippet[]\n fonts: Array<{\n family: string\n variants: string[]\n }>\n seo: {\n canonicalUrl?: string | null | undefined\n isIndexingBlocked?: boolean | null | undefined\n }\n site: {\n id: string\n }\n}\n\nconst defaultFavicon = {\n mimetype: 'image/png',\n publicUrl:\n 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACIAAAAiCAYAAAA6RwvCAAAACXBIWXMAABcRAAAXEQHKJvM/AAABjElEQVRYhc2XzU3EMBCFB8TddAAXn6EE6GCpgNABZ1/IXnymBOgAOmA7YM8+ABVsXEHQQFaKQryeN3Yk3ilKJtEnv/nLUd/3pFG0riGi88yrnQn+UfJ5FUi0riWiB2H4nQn+KRd0DFP8agXEfkqCYJBoHdtxIQxfm+DfFgEhoith3NYE30o/qgGR2BJB+xY7kdYEL8oNFUi0jiFMJuxVWrJqEMFxsyUNCsE6AeNztvBp7aJ143vXksoRnwhYtmNdSoIQa6RlO9YXEWW7KgoCleOgxgTf1QZBT+RZ2lXFING6UxCCq+ceeUE8fYdknY599v9sJvzGBP+yCEgC7GPmETc0OJ+0awAlkhe2pAbIXAeFZ8xe2g2Nk3c3ub0xwWt6zY9qbmiqGVMbZK21ZC/YmhlbeBMTzZNDQqcvDb1kM1x32iqZSt1HaqukfKvq34BAOTLsrH+ETNmUkKHHA+428RgeclPVWozeSyAI2EdWB34jtqXNTAySOY3i/KgFIlqOa4GkFmBegorzg4joG07he/M7zl6jAAAAAElFTkSuQmCC',\n}\n\n// Taken from https://github.com/facebook/react/blob/14bac6193a334eda42e727336e8967419f08f5df/packages/react-dom/src/server/ReactPartialRenderer.js#L208\nconst VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_.\\-\\d]*$/\n\nconst VALID_HEAD_ELEMENT_TYPES = [\n 'title',\n 'base',\n 'link',\n 'style',\n 'meta',\n 'script',\n 'noscript',\n 'template',\n]\n\nfunction snippetToElement(snippet: Pick<Snippet, 'id' | 'code'>): (string | ReactElement)[] {\n return Children.map(parse(snippet.code), element => {\n if (typeof element === 'string') return element\n\n if (!VALID_TAG_REGEX.test(element.type)) return null\n\n const key = element.key ? `${snippet.id}:${element.key}` : snippet.id\n\n return createElement(element.type, { ...element.props, key })\n })\n}\n\nconst filterUsedSnippetProperties = ({\n code,\n builderEnabled,\n liveEnabled,\n location,\n cleanup,\n}: Snippet) => ({\n code,\n builderEnabled,\n liveEnabled,\n location,\n cleanup,\n})\n\ntype Props = {\n page: PageData\n preview?: boolean\n}\n\nexport const PAGE_SNIPPETS_QUERY = gql`\n query PageById($id: ID!) {\n page(id: $id) {\n __typename\n id\n snippets {\n __typename\n id\n name\n code\n cleanup\n location\n shouldAddToNewPages\n liveEnabled\n builderEnabled\n }\n }\n }\n`\n\nexport type SiteFontsSiteQuery = {\n site?: {\n id: string\n googleFonts: {\n edges: Array<{\n activeVariants: Array<{ specifier: string }>\n node: {\n family: string\n variants: Array<{ specifier: string }>\n }\n } | null>\n }\n } | null\n}\n\nexport const SITE_FONTS_QUERY = gql`\n query SiteById($id: ID!) {\n site(id: $id) {\n id\n googleFonts {\n edges {\n activeVariants {\n specifier\n }\n node {\n family\n variants {\n specifier\n }\n }\n }\n }\n }\n }\n`\n\nexport function Page({ page, preview = false }: Props): JSX.Element {\n const isInBuilder = useIsInBuilder()\n const [snippets, setSnippets] = useState(page.snippets)\n // We're using useQuery here for page snippets and site fonts so that anytime the user change\n // the snippets or fonts on the builder, the change would be reflected here.\n // See this PR for discussions and things we can do to improve it in the future:\n // https://github.com/makeswift/makeswift/pull/77\n useQuery<{ page: { snippets: Snippet[] } }>(PAGE_SNIPPETS_QUERY, {\n variables: { id: page.id },\n skip: isInBuilder === false,\n fetchPolicy: 'cache-only',\n onCompleted(data) {\n if (data == null) return\n\n const oldSnippets = snippets.map(filterUsedSnippetProperties)\n const newSnippets = data.page.snippets.map(filterUsedSnippetProperties)\n\n if (deepEqual(newSnippets, oldSnippets)) return\n\n setSnippets(data.page.snippets)\n },\n })\n const { data: siteData } = useQuery<SiteFontsSiteQuery>(SITE_FONTS_QUERY, {\n variables: { id: page.site.id },\n skip: isInBuilder === false,\n fetchPolicy: 'cache-only',\n })\n\n const favicon = page.meta.favicon ?? defaultFavicon\n const { title, description, keywords, socialImage } = page.meta\n const { canonicalUrl, isIndexingBlocked } = page.seo\n\n const fontFamilyParamValue = useMemo(() => {\n if (siteData?.site == null) {\n return page.fonts\n .map(({ family, variants }) => {\n return `${family.replace(/ /g, '+')}:${variants.join()}`\n })\n .join('|')\n }\n\n return siteData.site.googleFonts.edges\n .filter((edge): edge is NonNullable<typeof edge> => edge != null)\n .map(({ activeVariants, node: { family, variants } }) => {\n const activeVariantSpecifiers = variants\n .filter(variant =>\n activeVariants.some(activeVariant => activeVariant.specifier === variant.specifier),\n )\n .map(variant => variant.specifier)\n .join()\n\n return `${family.replace(/ /g, '+')}:${activeVariantSpecifiers}`\n })\n .join('|')\n }, [siteData, page])\n\n const filteredSnippets = useMemo(\n () => snippets.filter(snippet => (preview ? snippet.builderEnabled : snippet.liveEnabled)),\n [snippets],\n )\n const headSnippets = useMemo(\n () => filteredSnippets.filter(snippet => snippet.location === SnippetLocation.Head),\n [filteredSnippets],\n )\n\n const previousHeadSnippets = useRef<PageData['snippets'] | null>(null)\n useEffect(() => {\n const headSnippetsToCleanUp = (previousHeadSnippets.current ?? [])\n .filter(previousSnippet => previousSnippet.cleanup != null)\n .filter(previousSnippet => !headSnippets.some(snippet => previousSnippet.id === snippet.id))\n\n headSnippetsToCleanUp.forEach(snippetToCleanUp => {\n if (snippetToCleanUp.cleanup == null) return\n\n const cleanUp = new Function(snippetToCleanUp.cleanup)\n\n try {\n cleanUp()\n } catch {\n // Ignore errors from user input.\n }\n })\n\n previousHeadSnippets.current = headSnippets\n }, [headSnippets])\n\n return (\n <>\n <Head>\n <style>\n {`\n html {\n font-family: sans-serif;\n }\n div#__next {\n overflow: hidden;\n }\n `}\n </style>\n\n <link rel=\"icon\" type={favicon.mimetype} href={favicon.publicUrl} />\n\n {canonicalUrl && <link rel=\"canonical\" href={canonicalUrl} />}\n\n {isIndexingBlocked && <meta name=\"robots\" content=\"noindex\" />}\n\n {title && (\n <>\n <title>{title}</title>\n <meta property=\"og:title\" content={title} />\n <meta name=\"twitter:title\" content={title} />\n <meta itemProp=\"name\" content={title} />\n </>\n )}\n\n {description && (\n <>\n <meta name=\"description\" content={description} />\n <meta property=\"og:description\" content={description} />\n <meta name=\"twitter:description\" content={description} />\n <meta itemProp=\"description\" content={description} />\n </>\n )}\n\n {keywords && <meta name=\"keywords\" content={keywords} />}\n\n {socialImage && (\n <>\n <meta property=\"og:image\" content={socialImage.publicUrl} />\n <meta property=\"og:image:type\" content={socialImage.publicUrl} />\n <meta name=\"twitter:image\" content={socialImage.publicUrl} />\n <meta name=\"twitter:card\" content={socialImage.publicUrl} />\n <meta itemProp=\"image\" content={socialImage.publicUrl} />\n </>\n )}\n\n {fontFamilyParamValue !== '' && (\n <>\n <link\n rel=\"stylesheet\"\n href={`https://fonts.googleapis.com/css?family=${fontFamilyParamValue}&display=swap`}\n />\n </>\n )}\n\n {headSnippets.map(snippetToElement).map(children =>\n Children.map(children, child => {\n if (typeof child === 'string') return child\n\n if (VALID_HEAD_ELEMENT_TYPES.includes(child.type as string)) return child\n\n return null\n }),\n )}\n </Head>\n\n <DocumentReference documentReference={createDocumentReference(page.id)} />\n\n {filteredSnippets\n .filter(snippet => snippet.location === SnippetLocation.Body)\n .map(snippet => (\n <BodySnippet key={snippet.id} code={snippet.code} cleanup={snippet.cleanup} />\n ))}\n </>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0yLjg5ODY0IDE4SDE3LjEwMTRDMTguNDE4MyAxOCAxOS4yNjMzIDE2LjYwMDMgMTguNjUgMTUuNDM0OUwxMS41NDg2IDEuOTQyMzZDMTAuODkyNSAwLjY5NTc3IDkuMTA3NDkgMC42OTU3NjYgOC40NTEzOSAxLjk0MjM2TDEuMzUwMDMgMTUuNDM0OUMwLjczNjY5MiAxNi42MDAzIDEuNTgxNzQgMTggMi44OTg2NCAxOFpNOSA2QzkgNS40NDc3MiA5LjQ0NzcxIDUgMTAgNUMxMC41NTIzIDUgMTEgNS40NDc3MiAxMSA2VjExQzExIDExLjU1MjMgMTAuNTUyMyAxMiAxMCAxMkM5LjQ0NzcxIDEyIDkgMTEuNTUyMyA5IDExVjZaTTExLjI1IDE0Ljc1QzExLjI1IDE1LjQ0MDQgMTAuNjkwNCAxNiAxMCAxNkM5LjMwOTY0IDE2IDguNzUgMTUuNDQwNCA4Ljc1IDE0Ljc1QzguNzUgMTQuMDU5NiA5LjMwOTY0IDEzLjUgMTAgMTMuNUMxMC42OTA0IDEzLjUgMTEuMjUgMTQuMDU5NiAxMS4yNSAxNC43NVoiIC8+Cjwvc3ZnPgo=\"","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\nimport { ReactComponent as Warning20 } from '../../icons/warning-20.svg'\n\nconst ErrorDiv = styled('div')`\n width: 100%;\n height: 54px;\n background-color: #fcedf2;\n border-radius: 6px;\n padding: 16px;\n display: flex;\n align-items: center;\n gap: 8px;\n color: #c73e6d;\n fill: currentColor;\n font-family: Heebo, sans-serif;\n font-size: 16px;\n`\n\ntype Props = {\n text: string\n}\n\nexport const FallbackComponent = forwardRef(function FallbackComponent(\n { text }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <ErrorDiv ref={ref}>\n <Warning20 />\n <span>{text}</span>\n </ErrorDiv>\n )\n})\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport default murmur2;\n","var unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport default unitlessKeys;\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar ILLEGAL_ESCAPE_SEQUENCE_ERROR = \"You have illegal escape sequence in your template literal, most likely inside content's property value.\\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \\\"content: '\\\\00d7';\\\" should become \\\"content: '\\\\\\\\00d7';\\\".\\nYou can read more about this here:\\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences\";\nvar UNDEFINED_AS_OBJECT_KEY_ERROR = \"You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).\";\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nif (process.env.NODE_ENV !== 'production') {\n var contentValuePattern = /(var|attr|counters?|url|(((repeating-)?(linear|radial))|conic)-gradient)\\(|(no-)?(open|close)-quote/;\n var contentValues = ['normal', 'none', 'initial', 'inherit', 'unset'];\n var oldProcessStyleValue = processStyleValue;\n var msPattern = /^-ms-/;\n var hyphenPattern = /-(.)/g;\n var hyphenatedCache = {};\n\n processStyleValue = function processStyleValue(key, value) {\n if (key === 'content') {\n if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '\"' && value.charAt(0) !== \"'\")) {\n throw new Error(\"You seem to be using a value for 'content' without quotes, try replacing it with `content: '\\\"\" + value + \"\\\"'`\");\n }\n }\n\n var processed = oldProcessStyleValue(key, value);\n\n if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {\n hyphenatedCache[key] = true;\n console.error(\"Using kebab-case for css properties in objects is not supported. Did you mean \" + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {\n return _char.toUpperCase();\n }) + \"?\");\n }\n\n return processed;\n };\n}\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n if (interpolation.__emotion_styles !== undefined) {\n if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {\n throw new Error('Component selectors can only be used in conjunction with @emotion/babel-plugin.');\n }\n\n return interpolation;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n if (interpolation.anim === 1) {\n cursor = {\n name: interpolation.name,\n styles: interpolation.styles,\n next: cursor\n };\n return interpolation.name;\n }\n\n if (interpolation.styles !== undefined) {\n var next = interpolation.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = interpolation.styles + \";\";\n\n if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {\n styles += interpolation.map;\n }\n\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Functions that are interpolated in css calls will be stringified.\\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\\n' + 'It can be called directly with props or interpolated in a styled call like this\\n' + \"let SomeComponent = styled('div')`${dynamicStyle}`\");\n }\n\n break;\n }\n\n case 'string':\n if (process.env.NODE_ENV !== 'production') {\n var matched = [];\n var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {\n var fakeVarName = \"animation\" + matched.length;\n matched.push(\"const \" + fakeVarName + \" = keyframes`\" + p2.replace(/^@keyframes animation-\\w+/, '') + \"`\");\n return \"${\" + fakeVarName + \"}\";\n });\n\n if (matched.length) {\n console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\\n\\n' + 'Instead of doing this:\\n\\n' + [].concat(matched, [\"`\" + replaced + \"`\"]).join('\\n') + '\\n\\nYou should wrap it with `css` like this:\\n\\n' + (\"css`\" + replaced + \"`\"));\n }\n }\n\n break;\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n if (registered == null) {\n return interpolation;\n }\n\n var cached = registered[interpolation];\n return cached !== undefined ? cached : interpolation;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var _key in obj) {\n var value = obj[_key];\n\n if (typeof value !== 'object') {\n if (registered != null && registered[value] !== undefined) {\n string += _key + \"{\" + registered[value] + \"}\";\n } else if (isProcessableValue(value)) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value) + \";\";\n }\n } else {\n if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {\n throw new Error('Component selectors can only be used in conjunction with @emotion/babel-plugin.');\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (_key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(_key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {\n console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);\n }\n\n string += _key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;\\n{]+)\\s*(;|$)/g;\nvar sourceMapPattern;\n\nif (process.env.NODE_ENV !== 'production') {\n sourceMapPattern = /\\/\\*#\\ssourceMappingURL=data:application\\/json;\\S+\\s+\\*\\//g;\n} // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nvar serializeStyles = function serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[i];\n }\n }\n\n var sourceMap;\n\n if (process.env.NODE_ENV !== 'production') {\n styles = styles.replace(sourceMapPattern, function (match) {\n sourceMap = match;\n return '';\n });\n } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + // $FlowFixMe we know it's not null\n match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)\n return {\n name: name,\n styles: styles,\n map: sourceMap,\n next: cursor,\n toString: function toString() {\n return \"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).\";\n }\n };\n }\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n};\n\nexport { serializeStyles };\n","var isBrowser = \"object\" !== 'undefined';\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n var maybeStyles = cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","import * as React from 'react'\nimport { css, cache, CSSObject } from '@emotion/css'\nimport { serializeStyles } from '@emotion/serialize'\nimport { insertStyles } from '@emotion/utils'\n\nimport { useBorder, BorderSide } from '../../../components'\nimport { colorToString } from '../../../components/utils/colorToString'\nimport { responsiveStyle } from '../../../components/utils/responsive-style'\n\nimport {\n BorderRadiusLonghandPropertyData,\n MarginLonghandPropertyData,\n PaddingLonghandPropertyData,\n StyleControlData,\n StyleControlDefinition,\n StyleControlProperty,\n WidthPropertyData,\n} from '../../../controls'\n\nfunction useStyleControlCssObject(\n style: StyleControlData | undefined,\n controlDefinition: StyleControlDefinition,\n): CSSObject {\n const { properties } = controlDefinition.config\n\n return {\n ...(properties.includes(StyleControlProperty.Width) && {\n maxWidth: '100%',\n }),\n ...responsiveStyle(\n [\n style?.width,\n style?.margin,\n style?.padding,\n useBorder(style?.border),\n style?.borderRadius,\n ] as const,\n ([width, margin, padding, border, borderRadius]) => ({\n ...(properties.includes(StyleControlProperty.Width) && {\n width: widthToString(width) ?? '100%',\n }),\n ...(properties.includes(StyleControlProperty.Margin) && {\n marginTop: marginToString(margin?.marginTop) ?? 0,\n marginRight: marginToString(margin?.marginRight) ?? 'auto',\n marginBottom: marginToString(margin?.marginBottom) ?? 0,\n marginLeft: marginToString(margin?.marginLeft) ?? 'auto',\n }),\n ...(properties.includes(StyleControlProperty.Padding) && {\n paddingTop: paddingToString(padding?.paddingTop) ?? 0,\n paddingRight: paddingToString(padding?.paddingRight) ?? 0,\n paddingBottom: paddingToString(padding?.paddingBottom) ?? 0,\n paddingLeft: paddingToString(padding?.paddingLeft) ?? 0,\n }),\n ...(properties.includes(StyleControlProperty.Border) && {\n borderTop: borderSideToString(border?.borderTop) ?? '0 solid black',\n borderRight: borderSideToString(border?.borderRight) ?? '0 solid black',\n borderBottom: borderSideToString(border?.borderBottom) ?? '0 solid black',\n borderLeft: borderSideToString(border?.borderLeft) ?? '0 solid black',\n }),\n ...(properties.includes(StyleControlProperty.BorderRadius) && {\n borderTopLeftRadius: borderRadiusToString(borderRadius?.borderTopLeftRadius) ?? 0,\n borderTopRightRadius: borderRadiusToString(borderRadius?.borderTopRightRadius) ?? 0,\n borderBottomRightRadius: borderRadiusToString(borderRadius?.borderBottomRightRadius) ?? 0,\n borderBottomLeftRadius: borderRadiusToString(borderRadius?.borderBottomLeftRadius) ?? 0,\n }),\n }),\n ),\n }\n\n function widthToString(widthProperty: WidthPropertyData | undefined): string | null {\n if (widthProperty == null) return null\n\n return `${widthProperty.value}${widthProperty.unit}`\n }\n\n function marginToString(\n marginProperty: MarginLonghandPropertyData | null | undefined,\n ): string | null {\n if (marginProperty == null) return null\n\n if (marginProperty === 'auto') return marginProperty\n\n return `${marginProperty.value}${marginProperty.unit}`\n }\n\n function paddingToString(\n paddingProperty: PaddingLonghandPropertyData | null | undefined,\n ): string | null {\n if (paddingProperty == null) return null\n\n return `${paddingProperty.value}${paddingProperty.unit}`\n }\n\n function borderSideToString(borderSide: BorderSide | null | undefined): string | null {\n if (borderSide == null) return null\n\n const { width, color, style } = borderSide\n return `${width != null ? width : 0}px ${style} ${\n color != null ? colorToString(color) : 'black'\n }`\n }\n\n function borderRadiusToString(\n borderRadius: BorderRadiusLonghandPropertyData | null | undefined,\n ): string | null {\n if (borderRadius == null) return null\n\n return `${borderRadius.value}${borderRadius.unit}`\n }\n}\n\nconst useInsertionEffectSpecifier = 'useInsertionEffect'\n// @ts-expect-error: React types are outdated.\nconst useInsertionEffect = React[useInsertionEffectSpecifier] ?? React.useLayoutEffect\nconst isServer = typeof window === 'undefined'\n\nexport type StyleControlFormattedValue = string\n\nexport function useFormattedStyle(\n styleControlData: StyleControlData | undefined,\n controlDefinition: StyleControlDefinition,\n): StyleControlFormattedValue {\n const style = useStyleControlCssObject(styleControlData, controlDefinition)\n\n if (isServer) return css(style)\n\n const serialized = serializeStyles([style], cache.registered)\n\n useInsertionEffect(() => {\n insertStyles(cache, serialized, false)\n })\n\n return `${cache.key}-${serialized.name}`\n}\n","type Props<H extends (...args: any[]) => any> = {\n /**\n * `<RenderHook>` requires key that changes whenever the `hook` prop changes to ensure the rules of\n * hooks are followed.\n */\n key: string\n\n hook: H\n parameters: Parameters<H>\n children(result: ReturnType<H>): JSX.Element\n}\n\nexport function RenderHook<H extends (...args: any[]) => any>({\n hook: useHook,\n parameters,\n children,\n}: Props<H>) {\n return children(useHook(...parameters))\n}\n","import { CheckboxControlData, CheckboxControlDefinition } from '../../../controls'\n\nexport type CheckboxControlValue<T extends CheckboxControlDefinition> =\n undefined extends T['config']['defaultValue'] ? boolean | undefined : boolean\n\nexport function useCheckboxControlValue<T extends CheckboxControlDefinition>(\n data: CheckboxControlData | undefined,\n definition: T,\n): CheckboxControlValue<T> {\n return (data ?? definition.config.defaultValue) as CheckboxControlValue<T>\n}\n","import Color from 'color'\n\nimport { useQuery } from '../../../api/react'\nimport { SWATCHES_BY_ID } from '../../../components/utils/queries'\nimport { ColorControlData, ColorControlDefinition } from '../../../controls/color'\n\nexport type ColorControlValue<T extends ColorControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\ntype Swatch = {\n id: string\n hue: number\n saturation: number\n lightness: number\n}\n\ntype SwatchesById = { swatches: Swatch[] }\n\nexport function useColorValue<T extends ColorControlDefinition>(\n data: ColorControlData | undefined,\n definition: T,\n): ColorControlValue<T> {\n const result = useQuery<SwatchesById>(SWATCHES_BY_ID, {\n variables: { ids: [data?.swatchId] },\n skip: data?.swatchId == null,\n })\n\n if (data === undefined) {\n const { defaultValue } = definition.config\n\n if (defaultValue === undefined) return undefined as ColorControlValue<T>\n\n let defaultColor\n try {\n defaultColor = Color(definition.config.defaultValue)\n } catch {\n defaultColor = Color()\n }\n\n return defaultColor.rgb().string()\n }\n\n const [swatch] = result.data?.swatches ?? [null]\n\n return Color({ h: swatch?.hue, s: swatch?.saturation, l: swatch?.lightness })\n .alpha(data.alpha)\n .rgb()\n .string()\n}\n","import { useFile } from '../../../components'\nimport { ImageControlData } from '../../../controls'\n\nexport type ImageControlValue = string | undefined\n\nexport function useImageControlValue(data: ImageControlData | undefined): ImageControlValue {\n return useFile(data)?.publicUrl\n}\n","import { ListControlData, ListControlDefinition } from '../../../controls'\nimport { ControlDefinitionValue, ControlValue } from './control'\n\ntype ListControlItemValue<T extends ListControlDefinition> = ControlDefinitionValue<\n T['config']['type']\n>\n\nexport type ListControlValue<T extends ListControlDefinition> = ListControlItemValue<T>[]\n\ntype ListControlValueProps<T extends ListControlDefinition> = {\n definition: T\n data: ListControlData<T> | undefined\n children(value: ListControlValue<T>): JSX.Element\n}\n\nexport function ListControlValue<T extends ListControlDefinition>({\n definition,\n data,\n children,\n}: ListControlValueProps<T>): JSX.Element {\n return (data ?? []).reduce(\n (renderFn, item) => listControlValue =>\n (\n <ControlValue definition={definition.config.type} data={item.value}>\n {value => renderFn([value as ListControlItemValue<T>, ...listControlValue])}\n </ControlValue>\n ),\n children,\n )([])\n}\n","import { NumberControlData, NumberControlDefinition } from '../../../controls'\n\nexport type NumberControlValue<T extends NumberControlDefinition> =\n undefined extends T['config']['defaultValue'] ? NumberControlData | undefined : NumberControlData\n\nexport function useNumber<T extends NumberControlDefinition>(\n numberControlData: number | undefined,\n controlDefinition: T,\n): NumberControlValue<T> {\n return (numberControlData ?? controlDefinition.config.defaultValue) as NumberControlValue<T>\n}\n","import {\n SelectControlData,\n SelectControlDefinition,\n SelectControlDefinitionOption,\n} from '../../../controls'\n\nexport type SelectControlValue<T extends SelectControlDefinition> =\n undefined extends T['config']['defaultValue']\n ? SelectControlDefinitionOption<T> | undefined\n : SelectControlDefinitionOption<T>\n\nexport function useSelectControlValue<T extends SelectControlDefinition>(\n data: SelectControlData<T> | undefined,\n definition: T,\n): SelectControlValue<T> {\n return (data ?? definition?.config.defaultValue) as SelectControlValue<T>\n}\n","import { ShapeControlData, ShapeControlDefinition } from '../../../controls/shape'\nimport { ControlDefinitionValue, ControlValue } from './control'\n\nexport type ShapeControlValue<T extends ShapeControlDefinition> = {\n [K in keyof T['config']['type']]: ControlDefinitionValue<T['config']['type'][K]>\n}\n\ntype ShapeControlValueProps<T extends ShapeControlDefinition> = {\n definition: T\n data: ShapeControlData<T> | undefined\n children(value: ShapeControlValue<T>): JSX.Element\n}\n\nexport function ShapeControlValue<T extends ShapeControlDefinition>({\n definition,\n data,\n children,\n}: ShapeControlValueProps<T>) {\n return Object.entries(definition.config.type).reduceRight(\n (renderFn, [key, controlDefinition]) =>\n shapeControlValue =>\n (\n <ControlValue definition={controlDefinition} data={data?.[key]}>\n {value => renderFn({ ...shapeControlValue, [key]: value })}\n </ControlValue>\n ),\n children,\n )({} as ShapeControlValue<T>)\n}\n","import { TextAreaControlData, TextAreaControlDefinition } from '../../../controls'\n\nexport type TextAreaControlValue<T extends TextAreaControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\nexport function useTextAreaValue<T extends TextAreaControlDefinition>(\n data: TextAreaControlData | undefined,\n definition: T,\n): TextAreaControlValue<T> {\n return (data ?? definition.config.defaultValue) as TextAreaControlValue<T>\n}\n","import { TextInputControlData, TextInputControlDefinition } from '../../../controls'\n\nexport type TextInputControlValue<T extends TextInputControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\nexport function useTextInputValue<T extends TextInputControlDefinition>(\n data: TextInputControlData | undefined,\n definition: T,\n): TextInputControlValue<T> {\n return (data ?? definition.config.defaultValue) as TextInputControlValue<T>\n}\n","import {\n CheckboxControlData,\n CheckboxControlDefinition,\n CheckboxControlType,\n ColorControlData,\n ColorControlDefinition,\n ColorControlType,\n ControlDefinition,\n ControlDefinitionData,\n ImageControlData,\n ImageControlDefinition,\n ImageControlType,\n ListControlData,\n ListControlDefinition,\n ListControlType,\n NumberControlData,\n NumberControlDefinition,\n NumberControlType,\n SelectControlData,\n SelectControlDefinition,\n SelectControlType,\n ShapeControlData,\n ShapeControlDefinition,\n ShapeControlType,\n TextAreaControlData,\n TextAreaControlDefinition,\n TextAreaControlType,\n TextInputControlData,\n TextInputControlDefinition,\n TextInputControlType,\n} from '../../../controls'\nimport { RenderHook } from '../components'\nimport { CheckboxControlValue, useCheckboxControlValue } from './checkbox'\nimport { ColorControlValue, useColorValue } from './color'\nimport { ImageControlValue, useImageControlValue } from './image'\nimport { ListControlValue } from './list'\nimport { NumberControlValue, useNumber } from './number'\nimport { SelectControlValue, useSelectControlValue } from './select'\nimport { ShapeControlValue } from './shape'\nimport { TextAreaControlValue, useTextAreaValue } from './text-area'\nimport { TextInputControlValue, useTextInputValue } from './text-input'\n\nexport type ControlDefinitionValue<T extends ControlDefinition> =\n T extends CheckboxControlDefinition\n ? CheckboxControlValue<T>\n : T extends NumberControlDefinition\n ? NumberControlValue<T>\n : T extends TextInputControlDefinition\n ? TextInputControlValue<T>\n : T extends TextAreaControlDefinition\n ? TextAreaControlValue<T>\n : T extends SelectControlDefinition\n ? SelectControlValue<T>\n : T extends ColorControlDefinition\n ? ColorControlValue<T>\n : T extends ImageControlDefinition\n ? ImageControlValue\n : T extends ShapeControlDefinition\n ? ShapeControlValue<T>\n : T extends ListControlDefinition\n ? ListControlValue<T>\n : never\n\ntype ControlValueProps<T extends ControlDefinition> = {\n definition: T\n data: ControlDefinitionData<T> | undefined\n children(value: ControlDefinitionValue<T>): JSX.Element\n}\n\nexport function ControlValue<T extends ControlDefinition>({\n data,\n definition,\n children,\n}: ControlValueProps<T>): JSX.Element {\n switch (definition.type) {\n case CheckboxControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useCheckboxControlValue}\n parameters={[data as CheckboxControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case NumberControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useNumber}\n parameters={[data as NumberControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case TextInputControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useTextInputValue}\n parameters={[data as TextInputControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case TextAreaControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useTextAreaValue}\n parameters={[data as TextAreaControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case SelectControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useSelectControlValue}\n parameters={[data as SelectControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ColorControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useColorValue}\n parameters={[data as ColorControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ImageControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useImageControlValue}\n parameters={[data as ImageControlData]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ShapeControlType:\n return (\n <ShapeControlValue definition={definition} data={data as ShapeControlData}>\n {value => children(value as ControlDefinitionValue<T>)}\n </ShapeControlValue>\n )\n\n case ListControlType:\n return (\n <ListControlValue definition={definition} data={data as ListControlData}>\n {value => children(value as ControlDefinitionValue<T>)}\n </ListControlValue>\n )\n\n default:\n return children(data as ControlDefinitionValue<T>)\n }\n}\n","import { useMemo, useRef } from 'react'\n\nimport { useStore } from '.'\nimport * as ReactPage from '../../state/react-page'\nimport { Props } from '../../prop-controllers'\nimport {\n Descriptor,\n Device,\n ResolveOptions,\n ResponsiveValue,\n WidthControlValueFormats,\n WidthDescriptor,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport { css } from '@emotion/css'\nimport { useResponsiveColor } from '../../components'\nimport type { ColorValue } from '../../components/utils/types'\nimport { responsiveWidth } from '../../components/utils/responsive-style'\nimport {\n CheckboxControlType,\n ColorControlType,\n ImageControlType,\n ListControlType,\n NumberControlType,\n SelectControlType,\n ShapeControlType,\n StyleControlType,\n TextAreaControlType,\n TextInputControlType,\n} from '../../controls'\nimport { useFormattedStyle } from './controls/style'\nimport { ControlValue } from './controls/control'\nimport { RenderHook } from './components'\n\nexport type ResponsiveColor = ResponsiveValue<ColorValue>\n\nfunction useDeviceMode(): Device {\n return 'desktop'\n}\n\nfunction useWidth(\n value: WidthValue | undefined,\n descriptor: WidthDescriptor,\n props: Record<string, unknown>,\n): string | WidthValue | undefined {\n const deviceMode = useDeviceMode()\n const options = useMemo(\n () =>\n typeof descriptor.options === 'function'\n ? descriptor.options(props, deviceMode)\n : descriptor.options,\n [props, deviceMode],\n )\n\n return useMemo(\n () =>\n options.format === WidthControlValueFormats.ClassName\n ? css(responsiveWidth(value, options.defaultValue))\n : value,\n [value, options.defaultValue, options.format],\n )\n}\n\nexport type ResolveWidthControlValue<T extends Descriptor> = T extends WidthDescriptor\n ? undefined extends ResolveOptions<T['options']>['format']\n ? WidthValue | undefined\n : ResolveOptions<T['options']>['format'] extends typeof WidthControlValueFormats.ClassName\n ? string\n : ResolveOptions<T['options']>['format'] extends typeof WidthControlValueFormats.ResponsiveValue\n ? WidthValue | undefined\n : never\n : never\n\ntype PropsValueProps = {\n element: ReactPage.ElementData\n children(props: Record<string, unknown>): JSX.Element\n}\n\nexport function PropsValue({ element, children }: PropsValueProps): JSX.Element {\n const store = useStore()\n const propControllerDescriptorsRef = useRef(\n ReactPage.getComponentPropControllerDescriptors(store.getState(), element.type) ?? {},\n )\n const props = element.props as Record<string, any>\n\n return Object.entries(propControllerDescriptorsRef.current).reduceRight(\n (renderFn, [propName, descriptor]) =>\n propsValue => {\n switch (descriptor.type) {\n case CheckboxControlType:\n case NumberControlType:\n case TextInputControlType:\n case TextAreaControlType:\n case SelectControlType:\n case ColorControlType:\n case ImageControlType:\n case ShapeControlType:\n case ListControlType:\n return (\n <ControlValue definition={descriptor} data={props[propName]}>\n {value => renderFn({ ...propsValue, [propName]: value })}\n </ControlValue>\n )\n\n case StyleControlType:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useFormattedStyle}\n parameters={[props[propName], descriptor]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n case Props.Types.Width:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useWidth}\n parameters={[props[propName], descriptor, props]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n case Props.Types.ResponsiveColor:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useResponsiveColor}\n parameters={[props[propName]]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n default:\n return renderFn({ ...propsValue, [propName]: props[propName] })\n }\n },\n children,\n )({})\n}\n","import { ForwardedRef } from 'react'\nimport { ReactInstance } from 'react'\nimport { forwardRef } from 'react'\nimport { Component, ReactNode } from 'react'\nimport { findDOMNode } from 'react-dom'\n\ntype FindDomNodeClassComponentProps = {\n innerRef?: ForwardedRef<Element | Text | null>\n children?: ReactNode\n}\n\n/**\n * @see https://github.com/facebook/react/blob/a2505792ed17fd4d7ddc69561053c3ac90899491/packages/react-reconciler/src/ReactFiberReconciler.new.js#L179-L244\n */\nfunction suppressWarningAndFindDomNode(\n instance: ReactInstance | null | undefined,\n): Element | Text | null {\n const error = console.error\n\n console.error = (...args) => {\n if (typeof args[0] === 'string' && args[0].includes('%s is deprecated in StrictMode.')) return\n\n return error.apply(console, args)\n }\n\n const foundDomNode = findDOMNode(instance)\n\n console.error = error\n\n return foundDomNode\n}\n\nclass FindDomNodeClassComponent extends Component<FindDomNodeClassComponentProps> {\n componentDidMount() {\n this.setInnerRef(suppressWarningAndFindDomNode(this))\n }\n\n componentDidUpdate() {\n this.setInnerRef(suppressWarningAndFindDomNode(this))\n }\n\n setInnerRef(current: Element | Text | null) {\n const { innerRef } = this.props\n\n if (innerRef == null) return\n\n if (typeof innerRef === 'function') innerRef(current)\n else innerRef.current = current\n }\n\n render() {\n return <>{this.props.children}</>\n }\n}\n\ntype FindDomNodeProps = {\n children?: ReactNode\n}\n\nexport const FindDomNode = forwardRef<Element | Text | null, FindDomNodeProps>(function FindDomNode(\n props,\n ref,\n) {\n return <FindDomNodeClassComponent {...props} innerRef={ref} />\n})\n","import {\n ComponentPropsWithoutRef,\n createContext,\n forwardRef,\n memo,\n ReactNode,\n Ref,\n useContext,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from 'react'\nimport { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector'\nimport { gql } from '@apollo/client'\n\nimport * as ReactPage from '../../state/react-page'\nimport type * as ReactBuilderPreview from '../../state/react-builder-preview'\nimport {\n mountComponentEffect,\n registerComponentEffect,\n registerComponentHandleEffect,\n registerDocumentEffect,\n registerReactComponentEffect,\n} from '../../state/actions'\nimport type {\n PropControllerDescriptor,\n PropControllerDescriptorValueType,\n} from '../../prop-controllers'\nimport { ComponentIcon } from '../../state/modules/components-meta'\nimport { registerBuiltinComponents } from '../../components'\nimport { MakeswiftProvider, MakeswiftClient, useQuery } from '../../api/react'\nimport { FallbackComponent } from '../../components/shared/FallbackComponent'\nimport { PropsValue } from './controls'\nimport { FindDomNode } from './find-dom-node'\n\nconst contextDefaultValue = ReactPage.configureStore()\n\nexport interface ReactRuntime {\n registerComponent<\n P extends Record<string, PropControllerDescriptor>,\n C extends ReactPage.ComponentType<{ [K in keyof P]: PropControllerDescriptorValueType<P[K]> }>,\n >(\n component: C,\n meta: { type: string; label: string; icon?: ComponentIcon; hidden?: boolean; props?: P },\n ): () => void\n}\n\nexport function createReactRuntime(store: ReactPage.Store): ReactRuntime {\n return {\n registerComponent(component, { type, label, icon = 'Cube40', hidden = false, props }) {\n const unregisterComponent = store.dispatch(\n registerComponentEffect(type, { label, icon, hidden }, props ?? {}),\n )\n\n const unregisterReactComponent = store.dispatch(\n registerReactComponentEffect(type, component as unknown as ReactPage.ComponentType),\n )\n\n return () => {\n unregisterComponent()\n unregisterReactComponent()\n }\n },\n }\n}\n\nexport const ReactRuntime = createReactRuntime(contextDefaultValue)\n\nconst Context = createContext(contextDefaultValue)\n\ntype RuntimeProviderProps = {\n client: MakeswiftClient\n rootElements?: Map<string, ReactPage.Element>\n children?: ReactNode\n}\n\nexport function RuntimeProvider({\n client,\n children,\n rootElements,\n}: RuntimeProviderProps): JSX.Element {\n const [store, setStore] = useState(() => {\n const store = ReactPage.configureStore({\n preloadedState: contextDefaultValue.getState(),\n rootElements,\n })\n const runtime = createReactRuntime(store)\n\n registerBuiltinComponents(runtime)\n\n return store\n })\n\n useEffect(() => {\n return registerBuiltinComponents(createReactRuntime(store))\n }, [store])\n\n useEffect(() => {\n const unregisterDocuments = Array.from(rootElements?.entries() ?? []).map(\n ([documentKey, rootElement]) =>\n store.dispatch(registerDocumentEffect(ReactPage.createDocument(documentKey, rootElement))),\n )\n\n return () => {\n unregisterDocuments.forEach(unregisterDocument => {\n unregisterDocument()\n })\n }\n }, [store, rootElements])\n\n useEffect(() => {\n // TODO(miguel): perform a more robust validation.\n const isInBuilder = window.parent !== window\n\n if (isInBuilder) setReactBuilderPreviewStore()\n\n async function setReactBuilderPreviewStore(): Promise<void> {\n const ReactBuilderPreview = await import('../../state/react-builder-preview')\n\n setStore(store =>\n ReactBuilderPreview.configureStore({\n preloadedState: store.getState(),\n client: client.apolloClient,\n }),\n )\n }\n }, [client])\n\n return (\n <Context.Provider value={store}>\n <MakeswiftProvider client={client}>{children}</MakeswiftProvider>\n </Context.Provider>\n )\n}\n\nconst PageContext = createContext<string | null>(null)\n\nfunction usePageIdOrNull(): string | null {\n return useContext(PageContext)\n}\n\nexport function usePageId(): string {\n const pageIdOrNull = usePageIdOrNull()\n\n if (pageIdOrNull == null) throw new Error('`usePageId` must be used with `<PageProvider>`')\n\n return pageIdOrNull\n}\n\ntype PageProviderProps = {\n id: string\n children: ComponentPropsWithoutRef<typeof PageContext['Provider']>['children']\n}\n\nexport function PageProvider({ id, children }: PageProviderProps) {\n return <PageContext.Provider value={id}>{children}</PageContext.Provider>\n}\n\nconst DocumentContext = createContext<string | null>(null)\n\nfunction useDocumentKey(): string | null {\n return useContext(DocumentContext)\n}\n\ntype State = ReactPage.State | ReactBuilderPreview.State\n\nexport function useStore(): ReactPage.Store {\n return useContext(Context)\n}\n\nfunction useSelector<R>(selector: (state: State) => R): R {\n const store = useStore()\n\n return useSyncExternalStoreWithSelector(store.subscribe, store.getState, store.getState, selector)\n}\n\nfunction useComponent(type: string): ReactPage.ComponentType | null {\n return useSelector(state => ReactPage.getReactComponent(state, type))\n}\n\nexport function useElementId(elementKey: string | null | undefined): string | null {\n const documentKey = useDocumentKey()\n\n return useSelector(state =>\n documentKey == null || elementKey == null\n ? null\n : ReactPage.getElementId(state, documentKey, elementKey),\n )\n}\n\nfunction useDocument(documentKey: string): ReactPage.Document | null {\n return useSelector(state => ReactPage.getDocument(state, documentKey))\n}\n\nexport function useIsInBuilder(): boolean {\n return useSelector(state => ReactPage.getIsInBuilder(state))\n}\n\ntype Dispatch = ReactPage.Dispatch & ReactBuilderPreview.Dispatch\n\nfunction useDispatch(): Dispatch {\n const store = useContext(Context)\n\n return store.dispatch\n}\n\n/**\n * @see https://github.com/facebook/react/blob/a2505792ed17fd4d7ddc69561053c3ac90899491/packages/react-reconciler/src/ReactFiberBeginWork.new.js#L1814-L1890\n */\nfunction useSuppressRefWarning(ownerName: string) {\n const originalErrorRef = useRef(console.error)\n const patchedRef = useRef(false)\n\n if (patchedRef.current === false) {\n console.error = (...args) => {\n if (\n typeof args[0] === 'string' &&\n args[0].includes('Function components cannot be given refs.') &&\n args[0].includes(`Check the render method of \\`${ownerName}\\`.`)\n ) {\n return\n }\n\n return originalErrorRef.current(...args)\n }\n\n patchedRef.current = true\n }\n}\n\ntype ElementDataProps = {\n elementData: ReactPage.ElementData\n}\n\nconst ElementData = memo(\n forwardRef(function ElementData(\n { elementData }: ElementDataProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const Component = useComponent(elementData.type)\n const [handle, setHandle] = useState<unknown | null>(null)\n const [foundDomNode, setFoundDomNode] = useState<Element | Text | null>(null)\n\n useImperativeHandle(ref, () => handle ?? foundDomNode, [handle, foundDomNode])\n\n useSuppressRefWarning(`\\`ForwardRef(${ElementData.name})\\``)\n\n if (Component == null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Component not found\" />\n }\n\n return (\n <FindDomNode ref={setFoundDomNode}>\n <PropsValue element={elementData}>\n {props => <Component {...props} key={elementData.key} ref={setHandle} />}\n </PropsValue>\n </FindDomNode>\n )\n }),\n)\n\nconst DisableRegisterElement = createContext(false)\n\ntype ElementRefereceProps = {\n elementReference: ReactPage.ElementReference\n}\n\nconst ElementReference = memo(\n forwardRef(function ElementReference(\n { elementReference }: ElementRefereceProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const { error, data } = useQuery(\n gql`\n query ElementReferenceGlobalElement($id: ID!) {\n globalElement(id: $id) {\n id\n data\n }\n }\n `,\n { variables: { id: elementReference.value } },\n )\n const globalElementData = data?.globalElement?.data as ReactPage.ElementData | undefined\n const elementReferenceDocument = useDocument(elementReference.key)\n\n if (error != null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Something went wrong!\" />\n }\n\n if (globalElementData == null) {\n return (\n <FallbackComponent\n ref={ref as Ref<HTMLDivElement>}\n text=\"This global component doesn't exist\"\n />\n )\n }\n\n return elementReferenceDocument != null ? (\n <Document document={elementReferenceDocument} ref={ref} />\n ) : (\n <DisableRegisterElement.Provider value={true}>\n <ElementData elementData={globalElementData} ref={ref} />\n </DisableRegisterElement.Provider>\n )\n }),\n)\n\ntype ElementProps = {\n element: ReactPage.Element\n}\n\nexport const Element = memo(\n forwardRef(function Element({ element }: ElementProps, ref: Ref<unknown>): JSX.Element {\n const elementKey = element.key\n const dispatch = useDispatch()\n const documentKey = useDocumentKey()\n const [handle, setHandle] = useState<unknown>(null)\n const isRegisterElementDisabled = useContext(DisableRegisterElement)\n\n useImperativeHandle(ref, () => handle, [handle])\n\n useEffect(() => {\n if (documentKey == null || isRegisterElementDisabled) return\n\n return dispatch(registerComponentHandleEffect(documentKey, elementKey, handle))\n }, [dispatch, documentKey, elementKey, handle, isRegisterElementDisabled])\n\n useEffect(() => {\n if (documentKey == null || isRegisterElementDisabled) return\n\n return dispatch(mountComponentEffect(documentKey, elementKey))\n }, [dispatch, documentKey, elementKey, isRegisterElementDisabled])\n\n return ReactPage.isElementReference(element) ? (\n <ElementReference key={elementKey} ref={setHandle} elementReference={element} />\n ) : (\n <ElementData key={elementKey} ref={setHandle} elementData={element} />\n )\n }),\n)\n\ntype DocumentProps = {\n document: ReactPage.Document\n}\n\nconst Document = memo(\n forwardRef(function Document({ document }: DocumentProps, ref: Ref<unknown>): JSX.Element {\n return (\n <DocumentContext.Provider value={document.key}>\n <Element ref={ref} element={document.rootElement} />\n </DocumentContext.Provider>\n )\n }),\n)\n\ntype DocumentReferenceProps = {\n documentReference: ReactPage.DocumentReference\n}\n\nexport const DocumentReference = memo(\n forwardRef(function DocumentReference(\n { documentReference }: DocumentReferenceProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const document = useDocument(documentReference.key)\n\n if (document == null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Document not found\" />\n }\n\n return <Document ref={ref} document={document} />\n }),\n)\n"],"names":["PlaceholderBase","styled","div","hide","forwardRef","ref","restOfProps","overflow","typePolicies","Query","fields","swatches","existingData","args","toReference","ids","map","id","__typename","file","files","typographies","pagePathnamesById","globalElement","table","page","site","PrefetchContext","createContext","useContext","uri","cacheData","cache","InMemoryCache","restore","ApolloClient","MakeswiftClient","constructor","apolloClient","createApolloClient","prefetch","element","uuid","getDataFromTree","_jsx","Map","createDocumentReference","KeyUtils","resetGenerator","extract","updateCacheData","Context","undefined","query","options","client","useApolloQuery","mutation","useApolloMutation","children","defaultExitedProps","opacity","x","y","scale","boxAnimations","none","entered","exited","transition","fadeIn","fadeLeft","type","ease","fadeRight","fadeUp","fadeDown","blurIn","filter","scaleDown","scaleUp","mergeCustomTransitionWithDefault","transitions","props","Object","keys","reduce","a","c","useElementOnScreen","isVisible","setIsVisible","useState","useEffect","observer","IntersectionObserver","intersectionCallback","observe","unobserve","entry","isIntersecting","DEFAULT_BOX_ANIMATE_TYPE","DEFAULT_BOX_ANIMATE_DELAY","DEFAULT_BOX_ANIMATE_DURATION","DEFAULT_ITEM_ANIMATE_TYPE","DEFAULT_ITEM_ANIMATE_DELAY","DEFAULT_ITEM_ANIMATE_DURATION","DEFAULT_ITEM_STAGGER_DURATION","useBoxAnimations","boxElement","elements","reducedMotion","useReducedMotion","boxAnimateType","useMediaQuery","boxAnimateDuration","boxAnimateDelay","itemAnimateType","itemAnimateDuration","itemAnimateDelay","itemStaggerDuration","isBoxVisible","root","rootMargin","threshold","itemControls","useAnimation","boxControls","setSequence","useCallback","variant","stop","set","playSequence","start","e","key","sort","join","boxVariant","itemVariant","initial","container","parent","animate","variants","child","delay","duration","delayChildren","staggerChildren","joinResponsiveValues","overflowY","overflowX","ownerDocument","defaultView","getComputedStyle","test","parentElement","isScrollable","getScrollParent","strength","rest","useRef","containerScrollTop","setContainerScrollTop","lastScrollParentScrollTop","useLayoutEffect","current","containerDocument","scrollParent","eventTarget","documentElement","scrollTop","requestAnimationFrame","top","containerTop","bottom","containerBottom","getBoundingClientRect","scrollParentTop","scrollParentBottom","innerHeight","scrollParentScrollTop","pageYOffset","scrollParentHeight","scrollParentScrollDelta","isContainerVisible","containerScrollRemaining","scrollParentScrollRemaining","parallaxRatio","containerScrollDelta","clamp","addEventListener","handleScroll","removeEventListener","getProps","style","restOfChildrenProps","position","left","right","transform","Container","Mask","backgroundColor","visible","getScale","aspectRatio","zoom","offsetWidth","width","offsetHeight","height","computedAspectRatio","Math","max","url","maskColor","ready","setReady","setScale","containerEl","handleResize","ReactPlayer","canPlay","_Fragment","vimeo","playerOptions","background","youtube","playerVars","origin","location","wistia","endVideoBehavior","playbackRateControl","playbar","playButton","volumeControl","fullscreenButton","muted","color","swatch","colorToString","hue","saturation","lightness","getStopsStyle","stops","getColor","getAspectRatio","AbsoluteFill","BackgroundsContainer","p","cssMediaRules","visibility","css","backgrounds","isPrefetching","useIsPrefetching","value","deviceId","v","reverse","bg","payload","publicUrl","repeat","size","parallax","backgroundPosition","getParallaxProps","backgroundImage","backgroundRepeat","backgroundSize","angle","isRadial","gradient","OuterContainer","motion","handle","setHandle","useImperativeHandle","useBackgrounds","Children","only","StyledBackgroundsContainer","cssMargin","cssBorderRadius","alignSelf","Grid","cssPadding","cssBorder","cssBoxShadow","alignContent","GridItem","cssGridItem","alignItems","Box","margin","padding","border","borderRadius","boxShadow","rowGap","columnGap","hidePlaceholder","verticalAlign","innerRef","setBoxElement","getBoxModel","paddingBoxElement","borderBoxElement","marginBoxElement","borderBox","paddingBoxComputedStyle","borderBoxComputedStyle","marginBoxComputedStyle","parse","paddingTop","paddingRight","paddingBottom","paddingLeft","borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth","marginTop","marginRight","marginBottom","marginLeft","createBox","borderData","useBorder","boxShadowData","useBoxShadow","cx","length","index","columns","Element","Placeholder","runtime","property","animateIn","isHiddenBasedOnBoxAnimation","isHiddenBasedOnAnimationType","isHiddenBasedOnItemAnimation","registerComponent","label","Props","format","Formats","ClassName","icon","defaultValue","preset","unit","hidden","labelOrientation","device","min","step","suffix","Link","link","onClick","usePage","pageId","elementKey","elementIdConfig","elementId","useElementId","href","target","block","pathname","openInNewTab","to","subject","body","phoneNumber","RangeError","handleClick","event","defaultPrevented","currentTarget","isContentEditable","preventDefault","hash","URL","error","view","scrollIntoView","document","querySelector","behavior","history","pushState","StyledButton","shape","textColor","alpha","fontSize","small","medium","large","square","rounded","pill","flat","ColorHelper","darken","hex","outline","shadow","clear","toString","blocky","bubbly","lighten","saturate","skewed","cssTextStyle","Button","textStyle","className","toClass","responsiveWidth","placeholder","findDeviceOverride","src","Promise","resolve","reject","image","Image","onload","onerror","baseDevice","DEVICES","find","maxWidth","baseWidth","baseWidthSize","override","sourceSizes","sourceSize","ImageContainer","UnoptimizedImage","img","ImageComponent","altText","placeholders","fileData","useFile","imageSrc","dataDimensions","dimensions","measuredDimensions","setMeasuredDimensions","isInBuilder","useIsInBuilder","cleanedUp","then","naturalWidth","naturalHeight","catch","console","widthClass","imageSizes","LeftChevron","RightChevron","Wrapper","Arrow","Slop","Slide","pageSize","Reel","gap","Page","LeftSlop","RightSlop","ClipMask","Dots","Dot","active","SWIPE_THRESHOLD","swipePower","dx","velocity","Carousel","images","responsivePageSize","responsiveStep","slideAlignment","showDots","showArrows","arrowPosition","arrowColor","arrowBackground","dotColor","autoplay","slideBorder","slideBorderRadius","setIndex","swipe","startIndex","wrap","endIndex","pageCount","ceil","pageIndex","isFirstPage","isLastPage","paginate","pageDistance","direction","abs","remaining","slice","distance","animation","stiffness","bindPage","useGesture","onDrag","movement","mx","delta","onDragEnd","drag","axis","bounds","rubberband","intervalId","setInterval","clearInterval","_jsxs","imageProps","Array","from","_","i","imagesLength","pageSizeValue","Block","Label","Segment","blockColor","numberColor","numberFont","labelColor","labelFont","getRemaining","date","days","hours","minutes","seconds","timeDiff","Date","getTime","now","floor","parseInt","String","Countdown","daysLabel","hoursLabel","minutesLabel","secondsLabel","setRemaining","toISOString","IE11MinHeightContainer","Line","thickness","Error","Divider","defaultHtml","SCRIPT_TAG","Embed","html","setContainer","shouldRender","setShouldRender","walker","createTreeWalker","NodeFilter","SHOW_ELEMENT","acceptNode","node","tagName","toLowerCase","FILTER_ACCEPT","FILTER_REJECT","nodes","nextNode","push","currentNode","script","createElement","textContent","attributes","forEach","name","setAttribute","parentNode","insertBefore","removeChild","hasAttribute","__html","rows","_path","_extends","getContrastColor","Sizes","SMALL","MEDIUM","LARGE","Base","input","cssField","getSizeHeight","form","contrast","brandColor","useFormContext","Input","display","flexDirection","justifyContent","Contrasts","LIGHT","DARK","labelTextStyle","labelTextColor","hideLabel","textarea","h","s","l","Color","isLight","getSize","FakeCheckbox","getContrastBorderColor","getContrastBackgroundColor","HiddenCheckbox","getCheckmarkColor","StyledLabel","getInputSizeHeight","CheckboxContainer","span","handleChange","setFieldValue","checked","MainLabel","tableColumn","required","onChange","validity","valueMissing","typeMismatch","option","includes","FakeRadioButton","HiddenRadioButton","attrs","RadioButtonContainer","getSizeHorizontalPadding","Select","select","getLabelSizeHeight","Shapes","ROUNDED","getShapeBorderRadius","SingleLineTextTableField","LongTextTableField","CheckboxTableField","MultipleSelectTableField","SingleSelectTableField","PhoneNumberTableField","EmailTableField","URLTableField","NumberTableField","tableFormField","TableColumnField","getTableColumnField","errorMessage","getTypeMismatchErrorMessage","FormikField","field","getIn","touched","errors","spin","keyframes","Icon","Spinner20","LOCAL_STORAGE_NAMESPACE","Alignments","LEFT","CENTER","RIGHT","GridForm","getSizeFontSize","alignment","getAlignmentMargin","ErrorContainer","IconContainer","ErrorMessage","CREATE_TABLE_RECORD","gql","Form","tableId","fieldsProp","submitLabel","submitLink","submitTextStyle","submitVariant","submitTextColor","submitWidth","submitAlignment","useMemo","grid","data","useTable","createTableRecord","useMutation","refEl","setRefEl","propControllers","setPropControllers","initialValues","setInitialValues","acc","formField","tableColumnId","getTableColumnDefaultValue","controller","items","useTableFormFieldRefs","fieldsCount","isDone","setIsDone","linkRef","getBox","timeoutId","setTimeout","clearTimeout","values","setSubmitting","resetForm","setStatus","getTableColumn","columnId","autofill","setItem","JSON","stringify","variables","prev","click","storedValue","localStorage","getItem","FormContextProvider","handleSubmit","formik","status","message","handleReset","isSubmitting","Check12","PILL","SQUARE","responsiveContrast","GutterContainer","gutter","first","last","PlaceholderLink","button","links","DROP_DOWN_MENU_WIDTH","DropDownMenu","dropIn","DropDownContainer","StyledDropDownItem","fontWeight","fontStyle","letterSpacing","textTransform","useResponsiveColor","caret","setPosition","innerWidth","offsetLeft","fill","CaretDown8","Plus8","ArrowDown8","ChevronDown8","DropDownItem","open","ButtonLink","StyledLink","onClose","isOpen","setIsOpen","NavigationButton","coverRight","coverLeft","CloseIconContainer","closeIconColor","Times16","flexShrink","Fragment","DropDownButton","nav","LinksContainer","mobileMenuAnimation","OpenIconContainer","Navigation","linkTextStyle","showLogo","logoFile","logoWidth","logoAltText","logoLink","mobileMenuOpenIconColor","mobileMenuCloseIconColor","mobileMenuBackgroundColor","flexGrow","MobileMenu28","Normalize","createGlobalStyle","normalize","Root","SocialLinksOptions","LogoAngellist20","LogoCodepen20","LogoDribbble20","LogoFacebook20","LogoGithub20","LogoInstagram20","LogoLinkedin20","LogoMedium20","LogoPinterest20","LogoReddit20","LogoRss20","LogoSnapchat20","LogoSoundcloud20","LogoSpotify20","LogoTelegram20","LogoTumblr20","LogoTwitch20","LogoTwitter20","LogoWhatsapp20","LogoVimeo20","LogoYelp20","LogoYoutube20","hoverStyle","circle","naked","grow","shrink","fade","SocialLinks","o","Span","typographyStyle","fontFamily","lineHeight","uppercase","underline","strikethrough","italic","Boolean","shallowMergeFallbacks","useTypographyMark","TYPOGRAPHY_TYPE","renderMark","mark","_editor","next","get","StyledBlock","textAlign","as","renderBlock","blockProps","renderInline","toJS","RichTextEditor","plugins","Lists","Inlines","DeviceOverridesBlocks","DeviceOverridesMarks","SlateEditor","StyledRichTextEditor","defaultText","object","COMMIT_DEBOUNCE_DELAY","Text","text","editor","setEditor","el","findDOMNode","setSlateEditor","setValue","selection","textWithoutSelection","Value","fromJSON","shouldCommit","setShouldCommit","nextValue","currentValue","isBlurred","toJSON","preserveSelection","window","change","lastController","handleFocus","focus","handleKeyDown","Hotkeys","isUndo","undo","isRedo","redo","isHotkey","blur","ipsum","marks","ASPECT_RATIO","Video","video","canPlayUrl","controls","loop","registerBoxComponent","registerButtonComponent","registerCarouselComponent","registerCountdownComponent","registerDividerComponent","registerEmbedComponent","registerFormComponent","registerImageComponent","registerNavigationComponent","registerRootComponent","registerSocialLinksComponent","registerTextComponent","registerVideoComponent","code","cleanup","innerHTML","scripts","HTMLScriptElement","inlineScript","executableScript","replaceChild","childNodes","append","cleanUp","Function","hasOwnProperty","defaultFavicon","mimetype","VALID_TAG_REGEX","VALID_HEAD_ELEMENT_TYPES","snippet","filterUsedSnippetProperties","builderEnabled","liveEnabled","PAGE_SNIPPETS_QUERY","SITE_FONTS_QUERY","preview","snippets","setSnippets","useQuery","skip","fetchPolicy","onCompleted","oldSnippets","newSnippets","deepEqual","siteData","favicon","meta","title","description","keywords","socialImage","canonicalUrl","isIndexingBlocked","seo","fontFamilyParamValue","fonts","family","replace","googleFonts","edges","edge","activeVariants","activeVariantSpecifiers","some","activeVariant","specifier","filteredSnippets","headSnippets","SnippetLocation","previousHeadSnippets","headSnippetsToCleanUp","previousSnippet","snippetToCleanUp","snippetToElement","ErrorDiv","FallbackComponent","Warning20","unitless","hashString","definition","renderFn","item","listControlValue","config","entries","reduceRight","controlDefinition","shapeControlValue","CheckboxControlType","useCheckboxControlValue","NumberControlType","useNumber","TextInputControlType","useTextInputValue","TextAreaControlType","useTextAreaValue","SelectControlType","useSelectControlValue","ColorControlType","useColorValue","ImageControlType","useImageControlValue","ShapeControlType","ListControlType","descriptor","deviceMode","useDeviceMode","WidthControlValueFormats","store","useStore","propControllerDescriptorsRef","ReactPage","getState","propName","propsValue","StyleControlType","useFormattedStyle","Width","useWidth","ResponsiveColor","instance","apply","foundDomNode","FindDomNodeClassComponent","Component","componentDidMount","setInnerRef","suppressWarningAndFindDomNode","componentDidUpdate","render","FindDomNode","contextDefaultValue","component","unregisterComponent","dispatch","registerComponentEffect","unregisterReactComponent","registerReactComponentEffect","ReactRuntime","createReactRuntime","rootElements","setStore","preloadedState","registerBuiltinComponents","unregisterDocuments","documentKey","rootElement","registerDocumentEffect","unregisterDocument","ReactBuilderPreview","configureStore","PageContext","pageIdOrNull","usePageIdOrNull","DocumentContext","selector","useSyncExternalStoreWithSelector","subscribe","useSelector","state","useDocumentKey","ownerName","originalErrorRef","patchedRef","ElementData","memo","elementData","useComponent","setFoundDomNode","_createElement","DisableRegisterElement","ElementReference","elementReference","globalElementData","elementReferenceDocument","useDocument","useDispatch","isRegisterElementDisabled","registerComponentHandleEffect","mountComponentEffect","Document","DocumentReference","documentReference"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../src/components/builtin/Box/components/Placeholder/index.tsx","../src/components/utils/queries.ts","../src/components/utils/isNonNullable.ts","../src/api/introspection.ts","../src/api/react.tsx","../src/components/hooks/useBackgrounds.ts","../src/components/hooks/useBorder.ts","../src/components/hooks/useBoxShadow.ts","../src/components/hooks/useResponsiveColor.ts","../src/components/hooks/useFile.ts","../src/utils/keys.ts","../src/utils/coalesce.ts","../src/utils/shallowMerge.ts","../src/components/utils/devices.ts","../src/components/hooks/useIsomorphicLayoutEffect.ts","../src/components/hooks/useMediaQuery.ts","../src/components/hooks/usePage.ts","../src/components/hooks/useTable.ts","../src/components/builtin/Box/animations.tsx","../src/components/utils/columns.ts","../src/components/utils/colorToString.ts","../src/components/utils/cssMediaRules.ts","../src/utils/clamp.ts","../src/components/shared/BackgroundsContainer/components/Parallax/index.tsx","../src/components/shared/BackgroundsContainer/components/BackgroundVideo/index.tsx","../src/components/shared/BackgroundsContainer/components/Backgrounds/index.tsx","../src/components/shared/BackgroundsContainer/index.tsx","../src/components/builtin/Box/Box.tsx","../src/components/shared/Link/index.tsx","../src/components/utils/responsive-style.ts","../src/components/builtin/Button/Button.tsx","../src/components/utils/placeholders.ts","../src/components/builtin/Image/Image.tsx","../src/components/builtin/Carousel/Carousel.tsx","../src/components/builtin/Countdown/Countdown.tsx","../src/components/builtin/Divider/Divider.tsx","../src/components/builtin/Embed/Embed.tsx","../src/components/icons/check-12.svg","../src/components/builtin/Form/context/FormContext.ts","../src/components/builtin/Form/components/Field/services/cssField.ts","../src/components/builtin/Form/components/Field/components/Input/index.tsx","../src/components/builtin/Form/components/Placeholder/index.tsx","../src/components/builtin/Form/components/Field/components/Label/index.tsx","../src/components/builtin/Form/components/Field/components/SingleLineTextTableField/index.tsx","../src/components/builtin/Form/components/Field/components/TextArea/index.tsx","../src/components/builtin/Form/components/Field/components/LongTextTableField/index.tsx","../src/components/builtin/Form/components/Field/components/Checkbox/index.tsx","../src/components/builtin/Form/components/Field/components/CheckboxTableField/index.tsx","../src/components/builtin/Form/components/Field/components/MultipleSelectTableField/index.tsx","../src/components/builtin/Form/components/Field/components/RadioButton/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/components/TableColumnRadioButtonGroup/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/components/TableColumnSingleSelect/index.tsx","../src/components/builtin/Form/components/Field/components/SingleSelectTableField/index.tsx","../src/components/builtin/Form/components/Field/components/PhoneNumberTableField/index.tsx","../src/components/builtin/Form/components/Field/components/EmailTableField/index.tsx","../src/components/builtin/Form/components/Field/components/URLTableField/index.tsx","../src/components/builtin/Form/components/Field/components/NumberTableField/index.tsx","../src/components/builtin/Form/components/Field/components/PlaceholderTableField/index.tsx","../src/components/builtin/Form/components/Field/index.tsx","../src/components/icons/spinner-20.svg","../src/components/builtin/Form/components/Spinner/index.tsx","../src/components/hooks/useTableFormFieldRefs.ts","../src/components/builtin/Form/Form.tsx","../src/components/icons/mobile-menu-28.svg","../src/components/shared/GutterContainer/index.tsx","../src/components/builtin/Navigation/components/LinksPlaceholder/index.tsx","../src/components/icons/caret-down-8.svg","../src/components/icons/plus-8.svg","../src/components/icons/arrow-down-8.svg","../src/components/icons/chevron-down-8.svg","../src/components/builtin/Navigation/components/DropDownButton/index.tsx","../src/components/icons/times-16.svg","../src/components/builtin/Navigation/components/MobileMenu/components/MobileDropDownButton/index.tsx","../src/components/builtin/Navigation/components/MobileMenu/index.tsx","../src/components/builtin/Navigation/Navigation.tsx","../src/components/builtin/Root/components/Placeholder/index.tsx","../src/components/builtin/Root/Root.tsx","../src/components/icons/logo-angellist-20.svg","../src/components/icons/logo-codepen-20.svg","../src/components/icons/logo-dribbble-20.svg","../src/components/icons/logo-facebook-20.svg","../src/components/icons/logo-github-20.svg","../src/components/icons/logo-instagram-20.svg","../src/components/icons/logo-linkedin-20.svg","../src/components/icons/logo-medium-20.svg","../src/components/icons/logo-pinterest-20.svg","../src/components/icons/logo-reddit-20.svg","../src/components/icons/logo-rss-20.svg","../src/components/icons/logo-snapchat-20.svg","../src/components/icons/logo-soundcloud-20.svg","../src/components/icons/logo-spotify-20.svg","../src/components/icons/logo-telegram-20.svg","../src/components/icons/logo-tumblr-20.svg","../src/components/icons/logo-twitch-20.svg","../src/components/icons/logo-twitter-20.svg","../src/components/icons/logo-whatsapp-20.svg","../src/components/icons/logo-vimeo-20.svg","../src/components/icons/logo-yelp-20.svg","../src/components/icons/logo-youtube-20.svg","../src/components/builtin/SocialLinks/options.tsx","../src/components/builtin/SocialLinks/components/SocialLinksPlaceholder/index.tsx","../src/components/builtin/SocialLinks/SocialLinks.tsx","../src/components/hooks/useTypography.ts","../src/components/builtin/Text/components/RichTextEditor/components/Mark/hooks/useTypographyMark.ts","../src/components/builtin/Text/components/RichTextEditor/components/Mark/index.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/DeviceOverridesMarks.tsx","../src/components/builtin/Text/components/RichTextEditor/components/Block/index.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/DeviceOverridesBlocks.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/Link.tsx","../src/components/builtin/Text/components/RichTextEditor/plugins/Inlines.tsx","../src/components/builtin/Text/components/RichTextEditor/index.tsx","../src/components/builtin/Text/Text.tsx","../src/components/builtin/Video/Video.tsx","../src/components/builtin/index.ts","../src/components/page/BodySnippet.tsx","../src/utils/is.ts","../src/utils/shallowEqual.ts","../src/utils/deepEqual.ts","../src/components/page/Page.tsx","../src/components/icons/warning-20.svg","../src/components/shared/FallbackComponent/FallbackComponent.tsx","../../../node_modules/@emotion/hash/dist/hash.browser.esm.js","../../../node_modules/@emotion/unitless/dist/unitless.browser.esm.js","../../../node_modules/@emotion/memoize/dist/emotion-memoize.browser.esm.js","../../../node_modules/@emotion/serialize/dist/emotion-serialize.browser.esm.js","../../../node_modules/@emotion/utils/dist/emotion-utils.browser.esm.js","../src/runtimes/react/controls/style.ts","../src/runtimes/react/components/render-hook.ts","../src/runtimes/react/controls/checkbox.ts","../src/runtimes/react/controls/color.ts","../src/runtimes/react/controls/combobox.ts","../src/runtimes/react/controls/image.ts","../src/runtimes/react/controls/list.tsx","../src/runtimes/react/controls/number.ts","../src/runtimes/react/controls/select.ts","../src/runtimes/react/controls/shape.tsx","../src/runtimes/react/controls/text-area.ts","../src/runtimes/react/controls/text-input.ts","../src/runtimes/react/controls/control.tsx","../src/runtimes/react/controls.tsx","../src/runtimes/react/find-dom-node.tsx","../src/runtimes/react/index.tsx"],"sourcesContent":["import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\n\nconst PlaceholderBase = styled.div<{ hide: boolean }>`\n width: 100%;\n background: rgba(161, 168, 194, 0.18);\n height: 80px;\n padding: 8px;\n visibility: ${({ hide }) => (hide === true ? 'hidden' : 'initial')};\n`\n\ntype Props = { hide?: boolean }\n\nexport default forwardRef(function Placeholder(\n { hide = false, ...restOfProps }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <PlaceholderBase {...restOfProps} hide={hide} ref={ref}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"100%\"\n height=\"100%\"\n style={{ overflow: 'visible' }}\n >\n <rect\n x={0}\n y={0}\n width=\"100%\"\n height=\"100%\"\n strokeWidth={2}\n strokeDasharray=\"4 2\"\n fill=\"none\"\n stroke=\"rgba(161, 168, 194, 0.40)\"\n rx=\"4\"\n ry=\"4\"\n />\n </svg>\n </PlaceholderBase>\n )\n})\n","import { gql } from '@apollo/client'\n\nexport const SWATCHES_BY_ID = gql`\n query SwatchesById($ids: [ID!]!) {\n swatches(ids: $ids) {\n id\n hue\n saturation\n lightness\n }\n }\n`\n\nexport const FILE_BY_ID = gql`\n query FileById($id: ID!) {\n file(id: $id) {\n id\n name\n publicUrl\n extension\n dimensions {\n width\n height\n }\n }\n }\n`\n\nexport const FILES_BY_ID = gql`\n query FilesById($ids: [ID!]!) {\n files(ids: $ids) {\n id\n name\n publicUrl\n extension\n dimensions {\n width\n height\n }\n }\n }\n`\n\nexport const PAGE_PATHNAMES_BY_ID = gql`\n query PagePathnamesById($ids: [ID!]!) {\n pagePathnamesById(ids: $ids) {\n id\n pathname\n }\n }\n`\n\nexport const TYPOGRAPHY_FRAGMENT = gql`\n fragment Typography on Typography {\n id\n name\n style {\n deviceId\n value {\n fontFamily\n fontSize {\n value\n unit\n }\n color {\n swatchId\n alpha\n }\n lineHeight\n letterSpacing\n fontWeight\n textAlign\n uppercase\n underline\n strikethrough\n italic\n }\n }\n }\n`\n\nexport const TYPOGRAPHIES_BY_ID = gql`\n query TypographiesById($ids: [ID!]!) {\n typographies(ids: $ids) {\n ...Typography\n }\n }\n\n ${TYPOGRAPHY_FRAGMENT}\n`\n\nexport const TABLE_BY_ID = gql`\n query TableById($id: ID!) {\n table(id: $id) {\n id\n name\n columns {\n id\n name\n ... on MultipleSelectTableColumn {\n options {\n id\n name\n }\n }\n ... on SingleSelectTableColumn {\n options {\n id\n name\n }\n }\n }\n }\n }\n`\n\nexport const ELEMENT_REFERENCE_GLOBAL_ELEMENT = gql`\n query ElementReferenceGlobalElement($id: ID!) {\n globalElement(id: $id) {\n id\n data\n }\n }\n`\n\nexport const INTROSPECTION_QUERY = gql`\n query Introspection(\n $swatchIds: [ID!]!\n $fileIds: [ID!]!\n $pageIds: [ID!]!\n $typographyIds: [ID!]!\n $tableIds: [ID!]!\n ) {\n swatches(ids: $swatchIds) {\n id\n hue\n saturation\n lightness\n }\n\n files(ids: $fileIds) {\n id\n name\n publicUrl\n extension\n dimensions {\n width\n height\n }\n }\n\n pagePathnamesById(ids: $pageIds) {\n id\n pathname\n }\n\n typographies(ids: $typographyIds) {\n ...Typography\n }\n\n tables(ids: $tableIds) {\n id\n name\n columns {\n id\n name\n ... on MultipleSelectTableColumn {\n options {\n id\n name\n }\n }\n ... on SingleSelectTableColumn {\n options {\n id\n name\n }\n }\n }\n }\n }\n\n ${TYPOGRAPHY_FRAGMENT}\n`\n","export function isNonNullable<T>(value: T): value is NonNullable<T> {\n return value != null\n}\n","import { ApolloClient, NormalizedCacheObject } from '@apollo/client'\nimport {\n getElementChildren,\n getElementSwatchIds,\n getFileIds,\n getPageIds,\n getTableIds,\n getTypographyIds,\n} from '../prop-controllers/introspection'\nimport { ELEMENT_REFERENCE_GLOBAL_ELEMENT, TYPOGRAPHIES_BY_ID } from '../components/utils/queries'\nimport {\n Element,\n ElementData,\n getPropControllerDescriptors,\n isElementReference,\n Store,\n} from '../state/react-page'\nimport { TypographyFragment } from './generated/graphql'\nimport { PropControllerDescriptor } from '../prop-controllers'\nimport { ListControlData, ListControlType, ShapeControlData, ShapeControlType } from '../controls'\nimport { ListValue, ShapeValue, Types } from '../prop-controllers/descriptors'\n\nexport async function introspect(\n element: Element,\n client: ApolloClient<NormalizedCacheObject>,\n store: Store,\n) {\n const descriptors = getPropControllerDescriptors(store.getState())\n const swatchIds = new Set<string>()\n const fileIds = new Set<string>()\n const typographyIds = new Set<string>()\n const tableIds = new Set<string>()\n const pageIds = new Set<string>()\n\n const remaining = [element]\n let current: Element | undefined\n\n while ((current = remaining.pop())) {\n let element: ElementData\n\n if (isElementReference(current)) {\n const query = await client.query({\n query: ELEMENT_REFERENCE_GLOBAL_ELEMENT,\n variables: { id: current.value },\n })\n\n const elementData = query.data?.globalElement?.data\n\n if (elementData == null) continue\n\n element = elementData\n } else {\n element = current\n }\n\n const elementDescriptors = descriptors.get(element.type)\n\n if (elementDescriptors == null) continue\n\n getResourcesFromElementDescriptors(elementDescriptors, element.props)\n\n function getResourcesFromElementDescriptors(\n elementDescriptors: Record<string, PropControllerDescriptor>,\n props: ElementData['props'],\n ) {\n Object.entries(elementDescriptors).forEach(([propName, descriptor]) => {\n getElementSwatchIds(descriptor, props[propName]).forEach(swatchId => {\n swatchIds.add(swatchId)\n })\n\n getFileIds(descriptor, props[propName]).forEach(fileId => fileIds.add(fileId))\n\n getTypographyIds(descriptor, props[propName]).forEach(typographyId =>\n typographyIds.add(typographyId),\n )\n\n getTableIds(descriptor, props[propName]).forEach(tableId => tableIds.add(tableId))\n\n getPageIds(descriptor, props[propName]).forEach(pageId => pageIds.add(pageId))\n\n getElementChildren(descriptor, props[propName]).forEach(child => remaining.push(child))\n\n if (descriptor.type === ShapeControlType) {\n const prop = props[propName] as ShapeControlData\n\n if (prop == null) return\n\n getResourcesFromElementDescriptors(descriptor.config.type, prop)\n }\n\n if (descriptor.type === ListControlType) {\n const prop = props[propName] as ListControlData\n\n if (prop == null) return\n\n prop.forEach(item => {\n getResourcesFromElementDescriptors(\n { propName: descriptor.config.type },\n { propName: item.value },\n )\n })\n }\n\n if (descriptor.type === Types.Shape) {\n const prop = props[propName] as ShapeValue\n\n if (prop == null) return\n\n getResourcesFromElementDescriptors(descriptor.options.type, prop)\n }\n\n if (descriptor.type === Types.List) {\n const prop = props[propName] as ListValue\n\n if (prop == null) return\n\n prop.forEach(item => {\n getResourcesFromElementDescriptors(\n { propName: descriptor.options.type },\n { propName: item.value },\n )\n })\n }\n })\n }\n }\n\n const typographiesResult = await client.query({\n query: TYPOGRAPHIES_BY_ID,\n variables: { ids: [...typographyIds] },\n })\n\n typographiesResult?.data?.typographies.forEach((typography: TypographyFragment) => {\n typography.style.forEach(style => {\n const swatchId = style.value.color?.swatchId\n\n if (swatchId != null) swatchIds.add(swatchId)\n })\n })\n\n return {\n swatchIds: [...swatchIds],\n fileIds: [...fileIds],\n typographyIds: [...typographyIds],\n tableIds: [...tableIds],\n pageIds: [...pageIds],\n }\n}\n","import {\n ApolloClient,\n DocumentNode,\n NormalizedCacheObject,\n OperationVariables,\n QueryHookOptions,\n QueryResult,\n TypedDocumentNode,\n useQuery as useApolloQuery,\n useMutation as useApolloMutation,\n DefaultContext,\n ApolloCache,\n MutationHookOptions,\n MutationTuple,\n InMemoryCache,\n TypePolicies,\n} from '@apollo/client'\nimport { BatchHttpLink } from '@apollo/client/link/batch-http'\nexport { gql } from '@apollo/client'\nimport { createContext, ReactNode, useContext } from 'react'\nimport { KeyUtils } from 'slate'\n\nimport { INTROSPECTION_QUERY } from '../components/utils/queries'\n\nimport { Element } from '../state/react-page'\nimport { PagePathnameSliceFragment, PagePathnameSliceFragmentDoc } from './generated/graphql'\nimport { storeContextDefaultValue } from '../runtimes/react'\nimport { introspect } from './introspection'\n\nconst typePolicies: TypePolicies = {\n Query: {\n fields: {\n swatches(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'Swatch', id }, true))\n )\n },\n file(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'File', id: args?.id }, true)\n },\n files(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'File', id }, true))\n )\n },\n typographies(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'Typography', id }, true))\n )\n },\n pagePathnamesById(existingData, { args, toReference }) {\n return (\n existingData ??\n args?.ids.map((id: string) => toReference({ __typename: 'PagePathnameSlice', id }, true))\n )\n },\n globalElement(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'GlobalElement', id: args?.id }, true)\n },\n table(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Table', id: args?.id }, true)\n },\n page(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Page', id: args?.id }, true)\n },\n site(existingData, { args, toReference }) {\n return existingData ?? toReference({ __typename: 'Site', id: args?.id }, true)\n },\n },\n },\n}\n\ntype CreateApolloClientParams = {\n uri?: string\n cacheData?: NormalizedCacheObject\n}\n\nexport function createApolloClient({ uri, cacheData }: CreateApolloClientParams) {\n const cache = new InMemoryCache({ typePolicies })\n\n if (cacheData) cache.restore(cacheData)\n\n return new ApolloClient({ link: new BatchHttpLink({ uri, batchMax: 100 }), cache })\n}\n\nexport type MakeswiftClientOptions = {\n uri?: string\n cacheData?: NormalizedCacheObject\n}\n\nexport class MakeswiftClient {\n apolloClient: ApolloClient<NormalizedCacheObject>\n\n constructor({ uri, cacheData }: MakeswiftClientOptions) {\n this.apolloClient = createApolloClient({ uri, cacheData })\n }\n\n async prefetch(element: Element): Promise<NormalizedCacheObject> {\n const introspectionData = await introspect(element, this.apolloClient, storeContextDefaultValue)\n\n const res = await this.apolloClient.query({\n query: INTROSPECTION_QUERY,\n variables: introspectionData,\n })\n\n // We're doing this because the API return the id without turning it to nodeId:\n // '87237bda-e775-48d8-92cc-399c65577bb7' vs 'UGFnZTo4NzIzN2JkYS1lNzc1LTQ4ZDgtOTJjYy0zOTljNjU1NzdiYjc='\n res.data.pagePathnamesById.forEach((pagePathnameSlice: PagePathnameSliceFragment) => {\n const id = Buffer.from(`Page:${pagePathnameSlice.id}`).toString('base64')\n\n this.apolloClient.cache.writeFragment({\n fragment: PagePathnameSliceFragmentDoc,\n data: { ...pagePathnameSlice, id },\n })\n })\n\n KeyUtils.resetGenerator()\n\n return this.apolloClient.cache.extract()\n }\n\n updateCacheData(cacheData: NormalizedCacheObject): void {\n this.apolloClient.cache.restore(cacheData)\n }\n}\n\nconst Context = createContext<MakeswiftClient | undefined>(undefined)\n\nexport function useQuery<TData = any, TVariables = OperationVariables>(\n query: DocumentNode | TypedDocumentNode<TData, TVariables>,\n options?: QueryHookOptions<TData, TVariables>,\n): QueryResult<TData, TVariables> {\n const client = useContext(Context)\n\n return useApolloQuery(query, { client: client?.apolloClient, ...options })\n}\n\nexport function useMutation<\n TData = any,\n TVariables = OperationVariables,\n TContext = DefaultContext,\n TCache extends ApolloCache<any> = ApolloCache<any>,\n>(\n mutation: DocumentNode | TypedDocumentNode<TData, TVariables>,\n options?: MutationHookOptions<TData, TVariables, TContext>,\n): MutationTuple<TData, TVariables, TContext, TCache> {\n const client = useContext(Context)\n\n return useApolloMutation(mutation, { client: client?.apolloClient, ...options })\n}\n\ntype MakeswiftProviderProps = {\n client: MakeswiftClient\n children: ReactNode\n}\n\nexport function MakeswiftProvider({ client, children }: MakeswiftProviderProps) {\n return <Context.Provider value={client}>{children}</Context.Provider>\n}\n","import { useMemo } from 'react'\n\nimport { ColorValue as Color } from '../utils/types'\nimport { ResponsiveValue } from '../../prop-controllers'\nimport { FILES_BY_ID, SWATCHES_BY_ID } from '../utils/queries'\nimport { isNonNullable } from '../utils/isNonNullable'\nimport { BackgroundsValue as ResponsiveBackgroundsValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\ntype BackgroundColorData = Color\n\ntype BackgroundGradientStopData = {\n id: string\n location: number\n color: Color | null | undefined\n}\n\ntype BackgroundGradientData = {\n angle: number\n isRadial: boolean\n stops: Array<BackgroundGradientStopData>\n}\n\ntype BackgroundImageData = {\n publicUrl?: string\n dimensions: { width: number; height: number } | null\n position: {\n x: number\n y: number\n }\n size: 'cover' | 'contain' | 'auto'\n repeat: 'no-repeat' | 'repeat-x' | 'repeat-y' | 'repeat'\n opacity?: number\n parallax?: number\n}\n\ntype BackgroundVideoData = {\n url: string\n maskColor: Color | null | undefined\n aspectRatio: 'wide' | 'standard'\n opacity: number\n zoom: number\n parallax: number\n}\n\ntype BackgroundData =\n | { id: string; type: 'color'; payload: BackgroundColorData | null | undefined }\n | { id: string; type: 'image'; payload: BackgroundImageData | null | undefined }\n | { id: string; type: 'gradient'; payload: BackgroundGradientData | null | undefined }\n | { id: string; type: 'video'; payload: BackgroundVideoData | null | undefined }\n\ntype BackgroundsData = Array<BackgroundData>\n\nexport type BackgroundsPropControllerData = ResponsiveValue<BackgroundsData>\n\nexport function useBackgrounds(\n value: ResponsiveBackgroundsValue | null | undefined,\n): BackgroundsPropControllerData | null | undefined {\n const fileIds =\n value == null\n ? []\n : value\n .map(({ value: backgrounds }) =>\n backgrounds\n .map(background =>\n background.type === 'image' && background.payload != null\n ? background.payload.imageId\n : null,\n )\n .filter(isNonNullable)\n .reduce((a, b) => a.concat(b), [] as string[]),\n )\n .reduce((a, b) => a.concat(b), [])\n const swatchIds =\n value == null\n ? []\n : value\n .map(({ value: backgrounds }) =>\n backgrounds\n .map(background => {\n if (background.type === 'color' && background.payload != null) {\n return [background.payload.swatchId]\n }\n\n if (background.type === 'gradient' && background.payload != null) {\n return background.payload.stops\n .map(stop => stop.color && stop.color.swatchId)\n .filter(isNonNullable)\n }\n\n if (background.type === 'video' && background.payload != null) {\n return [background.payload.maskColor && background.payload.maskColor.swatchId]\n }\n\n return null\n })\n .filter(isNonNullable)\n .reduce((a, b) => a.concat(b), []),\n )\n .reduce((a, b) => a.concat(b), [])\n .filter(isNonNullable)\n const skip = value == null\n const filesResult = useQuery(FILES_BY_ID, {\n skip: skip || fileIds.length === 0,\n variables: { ids: fileIds },\n })\n const swatchesResult = useQuery(SWATCHES_BY_ID, {\n skip: skip || swatchIds.length === 0,\n variables: { ids: swatchIds },\n })\n\n return useMemo(() => {\n const { data: filesData = {} } = filesResult\n const { data: swatchesData = {} } = swatchesResult\n\n if (value == null || filesResult.error != null || swatchesResult.error != null) {\n return null\n }\n\n const { files = [] } = filesData\n const { swatches = [] } = swatchesData\n\n return value.map(({ value: backgrounds, ...restOfValue }) => ({\n ...restOfValue,\n value: backgrounds\n .map(bg => {\n if (bg.type === 'image' && bg.payload != null && bg.payload.imageId != null) {\n const { imageId, ...restOfPayload } = bg.payload\n const file = files.find((f: any) => f && f.id === imageId)\n\n return (\n file && {\n id: bg.id,\n type: 'image',\n payload: {\n ...restOfPayload,\n publicUrl: file.publicUrl,\n dimensions: file.dimensions,\n },\n }\n )\n }\n\n if (bg.type === 'color' && bg.payload != null) {\n const { swatchId, alpha } = bg.payload\n const swatch = swatches.find((s: any) => s && s.id === swatchId)\n\n return { id: bg.id, type: 'color', payload: { swatch, alpha } }\n }\n\n if (bg.type === 'gradient' && bg.payload != null && bg.payload.stops.length > 0) {\n return {\n id: bg.id,\n type: 'gradient',\n payload: {\n angle: bg.payload.angle,\n isRadial: bg.payload.isRadial,\n stops: bg.payload.stops.map(({ color, ...restOfStop }) => ({\n ...restOfStop,\n color: color && {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n },\n })),\n },\n }\n }\n\n if (bg.type === 'video' && bg.payload != null) {\n const { maskColor, ...restOfPayload } = bg.payload\n const swatch = maskColor && swatches.find((s: any) => s && s.id === maskColor.swatchId)\n\n return {\n id: bg.id,\n type: 'video',\n payload: {\n ...restOfPayload,\n maskColor: swatch && maskColor && { swatch, alpha: maskColor.alpha },\n },\n }\n }\n\n return null\n })\n .filter(Boolean),\n }))\n }, [filesResult, swatchesResult, value])\n}\n","import { BorderStyleProperty } from 'csstype'\n\nimport { isNonNullable } from '../utils/isNonNullable'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport type { ColorValue as Color } from '../utils/types'\nimport { ResponsiveValue } from '../../prop-controllers'\nimport { BorderValue as ResponsiveBorderValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\nfunction mapSideColor(swatches: any, { color, ...restOfSide }: any) {\n return {\n ...restOfSide,\n color: color && {\n alpha: color.alpha,\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n },\n }\n}\n\nexport type BorderSide = {\n width: number | null | undefined\n style: BorderStyleProperty\n color: Color | null | undefined\n}\n\ntype BorderData = {\n borderTop: BorderSide | null | undefined\n borderRight: BorderSide | null | undefined\n borderBottom: BorderSide | null | undefined\n borderLeft: BorderSide | null | undefined\n}\n\nexport type BorderPropControllerData = ResponsiveValue<BorderData>\n\nexport function useBorder(\n value: ResponsiveBorderValue | null | undefined,\n): BorderPropControllerData | null | undefined {\n const swatchIds =\n value == null\n ? []\n : [\n ...Array.from(\n new Set(\n value\n .map(({ value: { borderTop, borderLeft, borderBottom, borderRight } }) => [\n borderTop && borderTop.color && borderTop.color.swatchId,\n borderBottom && borderBottom.color && borderBottom.color.swatchId,\n borderLeft && borderLeft.color && borderLeft.color.swatchId,\n borderRight && borderRight.color && borderRight.color.swatchId,\n ])\n .reduce((a, b) => a.concat(b))\n .filter(isNonNullable),\n ),\n ),\n ]\n const skip = value == null || swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (value == null || error != null) return null\n\n const { swatches = [] } = data\n\n return value.map(({ value: { borderTop, borderBottom, borderLeft, borderRight }, ...rest }) => ({\n ...rest,\n value: {\n borderTop: borderTop && mapSideColor(swatches, borderTop),\n borderBottom: borderBottom && mapSideColor(swatches, borderBottom),\n borderLeft: borderLeft && mapSideColor(swatches, borderLeft),\n borderRight: borderRight && mapSideColor(swatches, borderRight),\n },\n }))\n}\n","import { isNonNullable } from '../utils/isNonNullable'\nimport type { ColorValue as Color } from '../utils/types'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport type { ResponsiveValue } from '../../prop-controllers'\nimport type { ShadowsValue as ResponsiveShadowsValue } from '../../prop-controllers/descriptors'\nimport { useQuery } from '../../api/react'\n\ntype ShadowData = {\n id: string\n payload: {\n inset: boolean\n offsetX: number\n offsetY: number\n blurRadius: number\n spreadRadius: number\n color: Color | null | undefined\n }\n}\n\nconst ShadowDefaultValue = {\n inset: false,\n offsetX: 0,\n offsetY: 2,\n blurRadius: 4,\n spreadRadius: 0,\n color: null,\n} as const\n\nexport type BoxShadowData = Array<ShadowData>\n\nexport type BoxShadowPropControllerData = ResponsiveValue<BoxShadowData>\n\nexport function useBoxShadow(\n value: ResponsiveShadowsValue | null | undefined,\n): BoxShadowPropControllerData | null | undefined {\n const swatchIds =\n value == null\n ? []\n : [\n ...Array.from(\n new Set(\n value\n .map(({ value: shadows }) =>\n shadows.map(({ payload: { color } }) => color && color.swatchId),\n )\n .reduce((a, b) => a.concat(b), [])\n .filter(isNonNullable),\n ),\n ),\n ]\n\n const skip = value == null || swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (value == null || error != null) return null\n\n const { swatches = [] } = data\n\n return value.map(({ value: shadows, ...restOfValue }) => ({\n ...restOfValue,\n value: shadows.map(\n ({\n payload: { color, inset, offsetX, offsetY, blurRadius, spreadRadius },\n ...restOfShadow\n }) => ({\n ...restOfShadow,\n payload: {\n color:\n color != null\n ? {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n }\n : null,\n inset: inset ?? ShadowDefaultValue.inset,\n offsetX: offsetX ?? ShadowDefaultValue.offsetX,\n offsetY: offsetY ?? ShadowDefaultValue.offsetY,\n blurRadius: blurRadius ?? ShadowDefaultValue.blurRadius,\n spreadRadius: spreadRadius ?? ShadowDefaultValue.spreadRadius,\n },\n }),\n ),\n }))\n}\n","import type { ResponsiveValue } from '../../prop-controllers'\nimport { SWATCHES_BY_ID } from '../utils/queries'\nimport { isNonNullable } from '../utils/isNonNullable'\nimport type { ColorValue as Color } from '../utils/types'\nimport { useQuery } from '../../api/react'\n\nexport function useResponsiveColor(\n color:\n | ResponsiveValue<{\n swatchId: string\n alpha: number\n }>\n | null\n | undefined,\n): ResponsiveValue<Color> | null | undefined {\n const swatchIds =\n color == null\n ? []\n : [...Array.from(new Set(color.map(({ value: v }) => v && v.swatchId).filter(isNonNullable)))]\n const skip = swatchIds.length === 0\n const { error, data = {} } = useQuery(SWATCHES_BY_ID, { skip, variables: { ids: swatchIds } })\n\n if (color == null || error != null) return null\n\n const { swatches = [] } = data\n\n return color\n .map(({ value: v, ...rest }) => {\n const { swatchId, alpha } = v\n const swatch = swatches.find((s: any) => s && s.id === swatchId)\n\n return swatch == null ? null : { ...rest, value: { swatch, alpha } }\n })\n .filter(isNonNullable)\n}\n","import { useQuery } from '../../api/react'\nimport { FILE_BY_ID } from '../utils/queries'\n\ntype File = {\n id: string\n name: string\n publicUrl: string\n extension: string\n dimensions: { width: number; height: number } | null\n}\n\nexport function useFile(fileId: string | null | undefined): File | null | undefined {\n const { error, data = {} } = useQuery(FILE_BY_ID, {\n skip: fileId == null,\n variables: { id: fileId },\n })\n\n if (fileId == null || error != null) return null\n\n return data.file\n}\n","const keys = <O extends { [key: string]: unknown }>(o: O): (keyof O)[] => Object.keys(o)\n\nexport default keys\n","const coalesce = <T>(...args: Array<T>): T => {\n let i: number\n\n for (i = 0; i < args.length - 1; i += 1) {\n if (args[i] != null) return args[i]\n }\n\n return args[i]\n}\n\nexport default coalesce\n","import keys from './keys'\nimport coalesce from './coalesce'\n\nexport default function shallowMerge<\n A extends Record<string, unknown>,\n B extends Record<string, unknown>,\n>(a: A, b: B): A & B {\n const bKeys = keys(b)\n const merged = { ...a } as A & B\n\n bKeys.forEach(key => {\n // @ts-expect-error: `coalesce` returns `null | undefined` regardless of input guarantees.\n merged[key] = coalesce(merged[key], b[key])\n })\n\n return merged\n}\n","import type { Device as DeviceID, DeviceOverride, ResponsiveValue } from '../../prop-controllers'\nimport shallowMerge from '../../utils/shallowMerge'\n\nexport type Device = {\n id: DeviceID\n minWidth?: number\n maxWidth?: number\n}\n\nexport const DEVICES: Array<Device> = [\n { id: 'desktop', minWidth: 769 },\n { id: 'tablet', minWidth: 576, maxWidth: 768 },\n { id: 'mobile', maxWidth: 575 },\n]\n\nexport const getDevice = (deviceId: DeviceID): Device => {\n const device = DEVICES.find(({ id }) => id === deviceId)\n\n if (device == null) throw new Error(`Unrecognized device ID: \"${deviceId}\".`)\n\n return device\n}\n\nexport type FallbackStrategy<V> = (\n arg0: DeviceOverride<V> | undefined,\n arg1: ResponsiveValue<V>,\n) => DeviceOverride<V> | undefined\n\nfunction defaultStrategy<V>(\n value: DeviceOverride<V> | undefined,\n fallbacks: ResponsiveValue<V>,\n): DeviceOverride<V> | undefined {\n return value || fallbacks[0]\n}\n\nexport function shallowMergeFallbacks<V extends Record<string, unknown>>(\n value: DeviceOverride<V> | undefined,\n fallbacks: ResponsiveValue<V>,\n): DeviceOverride<V> | undefined {\n return [value, ...fallbacks]\n .filter((override): override is DeviceOverride<V> => Boolean(override))\n .reduce((a, b) => ({\n deviceId: a.deviceId || b.deviceId,\n value: shallowMerge(a.value, b.value),\n }))\n}\n\nexport function findDeviceOverride<S>(\n values: ResponsiveValue<S> = [],\n deviceId: string,\n strategy: FallbackStrategy<S> = defaultStrategy,\n): DeviceOverride<S> | undefined {\n const value = values.find(({ deviceId: d }) => d === deviceId)\n const fallbacks = DEVICES.slice(0, DEVICES.findIndex(d => d.id === deviceId) + 1)\n .reverse()\n .map(d => values.find(v => v.deviceId === d.id))\n .filter((override): override is DeviceOverride<S> => Boolean(override))\n\n return value != null || fallbacks.length > 0 ? strategy(value, fallbacks) : undefined\n}\n\nexport type ExtractResponsiveValue<T> = T extends ResponsiveValue<infer V> ? V : never\n\nexport function join<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>, R>(\n responsiveValues: A,\n joinFn: (values: { [I in keyof A]: ExtractResponsiveValue<A[I]> | undefined }) => R,\n strategy?: FallbackStrategy<V>,\n): ResponsiveValue<R> {\n return DEVICES.map(({ id }) => id)\n .map(deviceId => {\n const value = joinFn(\n responsiveValues.map(responsiveValue => {\n const deviceValue =\n responsiveValue && findDeviceOverride(responsiveValue, deviceId, strategy)\n\n return deviceValue == null ? undefined : deviceValue.value\n }) as unknown as { [I in keyof A]: ExtractResponsiveValue<A[I] | undefined> },\n )\n\n if (value == null) return null\n\n return { deviceId, value }\n })\n .filter((override): override is DeviceOverride<R> => Boolean(override))\n}\n\nexport const getDeviceMediaQuery = (device: Device): string => {\n const parts = ['@media only screen']\n\n if (device.minWidth != null) {\n parts.push(`(min-width: ${device.minWidth}px)`)\n }\n\n if (device.maxWidth != null) {\n parts.push(`(max-width: ${device.maxWidth}px)`)\n }\n\n return parts.join(' and ')\n}\n","import { useEffect, useLayoutEffect } from 'react'\n\nconst isSSR =\n typeof window === 'undefined' ||\n /ServerSideRendering/.test(window.navigator && window.navigator.userAgent)\n\nexport const useIsomorphicLayoutEffect = isSSR ? useEffect : useLayoutEffect\n","/* eslint-env browser */\n\nimport { useState } from 'react'\n\nimport { DeviceOverride } from '../../prop-controllers'\nimport { DEVICES, findDeviceOverride, getDeviceMediaQuery } from '../utils/devices'\nimport { useIsomorphicLayoutEffect } from './useIsomorphicLayoutEffect'\n\nexport function useMediaQuery<S>(responsiveValue?: Array<DeviceOverride<S>>): S | void {\n const [deviceId, setDeviceId] = useState(DEVICES[0].id)\n const { value } = findDeviceOverride(responsiveValue, deviceId) || {}\n\n useIsomorphicLayoutEffect(() => {\n if (responsiveValue == null || window == null) return () => {}\n\n const cleanUpFns = DEVICES.map(device => {\n const mediaQueryList = window.matchMedia(getDeviceMediaQuery(device).replace('@media', ''))\n\n const listener = () => {\n if (mediaQueryList.matches) setDeviceId(device.id)\n }\n\n listener()\n mediaQueryList.addListener(listener)\n\n return () => mediaQueryList.removeListener(listener)\n })\n\n return () => cleanUpFns.forEach(fn => fn())\n })\n\n return value\n}\n","import { useQuery } from '../../api/react'\nimport { PAGE_PATHNAMES_BY_ID } from '../utils/queries'\n\ntype Page = {\n id: string\n pathname: string\n}\n\nexport function usePage(pageId: string | null | undefined): Page | null | undefined {\n const { error, data = {} } = useQuery(PAGE_PATHNAMES_BY_ID, {\n skip: pageId == null,\n variables: { ids: [pageId] },\n })\n\n if (pageId == null || error != null) return null\n\n const { pagePathnamesById: [page] = [] } = data\n\n return page\n}\n","import { useQuery } from '../../api/react'\nimport { TABLE_BY_ID } from '../utils/queries'\n\nexport type SingleLineTextTableColumn = {\n id: string\n name: string\n __typename: 'SingleLineTextTableColumn'\n}\n\nexport type LongTextTableColumn = {\n id: string\n name: string\n __typename: 'LongTextTableColumn'\n}\n\nexport type CheckboxTableColumn = {\n id: string\n name: string\n __typename: 'CheckboxTableColumn'\n}\n\nexport type MultipleSelectTableColumnOption = {\n id: string\n name: string\n}\n\nexport type MultipleSelectTableColumn = {\n id: string\n name: string\n options: Array<MultipleSelectTableColumnOption>\n __typename: 'MultipleSelectTableColumn'\n}\n\nexport type SingleSelectTableColumnOption = {\n id: string\n name: string\n}\n\nexport type SingleSelectTableColumn = {\n id: string\n name: string\n options: Array<SingleSelectTableColumnOption>\n __typename: 'SingleSelectTableColumn'\n}\n\nexport type PhoneNumberTableColumn = {\n id: string\n name: string\n __typename: 'PhoneNumberTableColumn'\n}\n\nexport type EmailTableColumn = {\n id: string\n name: string\n __typename: 'EmailTableColumn'\n}\n\nexport type URLTableColumn = {\n id: string\n name: string\n __typename: 'URLTableColumn'\n}\n\nexport type NumberTableColumn = {\n id: string\n name: string\n __typename: 'NumberTableColumn'\n}\n\nexport type TableColumn =\n | SingleLineTextTableColumn\n | LongTextTableColumn\n | CheckboxTableColumn\n | MultipleSelectTableColumn\n | SingleSelectTableColumn\n | PhoneNumberTableColumn\n | EmailTableColumn\n | URLTableColumn\n | NumberTableColumn\n\ntype Table = {\n id: string\n name: string\n columns: Array<TableColumn>\n}\n\nexport function useTable(tableId: string | null | undefined) {\n return useQuery<{ table: Table | null }>(TABLE_BY_ID, {\n skip: tableId == null,\n variables: { id: tableId },\n })\n}\n","import {\n TargetAndTransition,\n Transition,\n useAnimation,\n useReducedMotion,\n Variants,\n MotionProps,\n} from 'framer-motion'\nimport { TransitionMap } from 'framer-motion/types/types'\nimport { useCallback, useEffect, useState } from 'react'\n\nimport { ResponsiveValue } from '../../../prop-controllers'\nimport { useMediaQuery } from '../../hooks'\nimport { Element } from '../../../state/react-page'\n\nexport type BoxAnimateIn =\n | 'none'\n | 'fadeIn'\n | 'fadeUp'\n | 'fadeDown'\n | 'fadeLeft'\n | 'fadeRight'\n | 'blurIn'\n | 'scaleUp'\n | 'scaleDown'\n\nconst defaultExitedProps = {\n opacity: 0,\n x: 0,\n y: 0,\n scale: 1,\n}\n\ntype BoxAnimationVariants = {\n entered: TargetAndTransition\n exited: TargetAndTransition\n}\n\nexport const boxAnimations: {\n [key in BoxAnimateIn]: {\n transition: TransitionMap\n } & BoxAnimationVariants\n} = {\n none: {\n entered: {\n opacity: 1,\n },\n exited: {\n ...defaultExitedProps,\n opacity: 1,\n },\n transition: {},\n },\n fadeIn: {\n exited: defaultExitedProps,\n entered: {\n opacity: 1,\n },\n transition: {},\n },\n fadeLeft: {\n exited: {\n ...defaultExitedProps,\n x: 60,\n },\n entered: {\n opacity: 1,\n x: 0,\n },\n transition: {\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeRight: {\n exited: {\n ...defaultExitedProps,\n x: -60,\n },\n entered: {\n opacity: 1,\n x: 0,\n },\n transition: {\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeUp: {\n exited: {\n ...defaultExitedProps,\n y: 80,\n },\n entered: {\n opacity: 1,\n y: 0,\n },\n transition: {\n y: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n fadeDown: {\n exited: {\n ...defaultExitedProps,\n y: -80,\n },\n entered: {\n opacity: 1,\n y: 0,\n },\n transition: {\n y: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n blurIn: {\n exited: {\n ...defaultExitedProps,\n filter: 'blur(20px)',\n },\n entered: {\n opacity: 1,\n filter: 'blur(0px)',\n },\n transition: {},\n },\n scaleDown: {\n exited: {\n ...defaultExitedProps,\n scale: 1.2,\n },\n entered: {\n opacity: 1,\n scale: 1,\n },\n transition: {\n scale: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n scaleUp: {\n exited: {\n ...defaultExitedProps,\n scale: 0.75,\n },\n entered: {\n opacity: 1,\n scale: 1,\n },\n transition: {\n scale: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n },\n },\n },\n}\n\nconst mergeCustomTransitionWithDefault = (\n transitions: TransitionMap,\n props: Transition,\n): TransitionMap | Transition =>\n transitions\n ? Object.keys(transitions).reduce(\n (a, c) => ({\n ...a,\n [c]: {\n ...transitions[c as string],\n ...props,\n },\n }),\n props,\n )\n : props\n\nexport type BoxAnimationType = {\n containerAnimationProps: {\n transition: Transition\n variants: Variants\n }\n parentAnimationProps: {\n transition: Transition\n }\n childAnimationProps: {\n transition: Transition\n variants: Variants\n }\n}\n\nconst useElementOnScreen = (element: HTMLElement | null, options: IntersectionObserverInit) => {\n const [isVisible, setIsVisible] = useState(false)\n\n useEffect(() => {\n const observer = new IntersectionObserver(intersectionCallback, options)\n\n if (element) observer.observe(element)\n\n return () => {\n if (element) observer.unobserve(element)\n }\n\n function intersectionCallback([entry]: IntersectionObserverEntry[]) {\n if (entry?.isIntersecting) {\n setIsVisible(true)\n }\n }\n }, [element, options])\n\n return isVisible\n}\n\nexport const DEFAULT_BOX_ANIMATE_TYPE = 'none'\nexport const DEFAULT_BOX_ANIMATE_DELAY = 0.0\nexport const DEFAULT_BOX_ANIMATE_DURATION = 0.75\nexport const DEFAULT_ITEM_ANIMATE_TYPE = 'none'\nexport const DEFAULT_ITEM_ANIMATE_DELAY = 0.0\nexport const DEFAULT_ITEM_ANIMATE_DURATION = 0.75\nexport const DEFAULT_ITEM_STAGGER_DURATION = 0.0\n\ntype UseBoxAnimationsPayload = {\n initial?: { container: MotionProps['initial']; parent: MotionProps['initial'] }\n animate?: { container: MotionProps['animate']; parent: MotionProps['animate'] }\n variants?: { container: MotionProps['variants']; child: MotionProps['variants'] }\n transition?: {\n container: MotionProps['transition']\n parent: MotionProps['transition']\n child: MotionProps['transition']\n }\n key?: { container: string }\n}\n\nexport const useBoxAnimations = ({\n boxElement,\n elements,\n ...props\n}: {\n boxAnimateType: ResponsiveValue<BoxAnimateIn> | undefined\n boxAnimateDuration: ResponsiveValue<number> | undefined\n boxAnimateDelay: ResponsiveValue<number> | undefined\n itemAnimateType: ResponsiveValue<BoxAnimateIn> | undefined\n itemAnimateDuration: ResponsiveValue<number> | undefined\n itemAnimateDelay: ResponsiveValue<number> | undefined\n itemStaggerDuration: ResponsiveValue<number> | undefined\n boxElement: HTMLElement | null\n elements: Element[] | undefined\n}): UseBoxAnimationsPayload => {\n const reducedMotion = useReducedMotion()\n const boxAnimateType = useMediaQuery(props.boxAnimateType) || DEFAULT_BOX_ANIMATE_TYPE\n const boxAnimateDuration = useMediaQuery(props.boxAnimateDuration) || DEFAULT_BOX_ANIMATE_DURATION\n const boxAnimateDelay = useMediaQuery(props.boxAnimateDelay) || DEFAULT_BOX_ANIMATE_DELAY\n const itemAnimateType = useMediaQuery(props.itemAnimateType) || DEFAULT_ITEM_ANIMATE_TYPE\n const itemAnimateDuration =\n useMediaQuery(props.itemAnimateDuration) || DEFAULT_ITEM_ANIMATE_DURATION\n const itemAnimateDelay = useMediaQuery(props.itemAnimateDelay) || DEFAULT_ITEM_ANIMATE_DELAY\n const itemStaggerDuration =\n useMediaQuery(props.itemStaggerDuration) || DEFAULT_ITEM_STAGGER_DURATION\n\n const isBoxVisible = useElementOnScreen(boxElement, {\n root: null,\n rootMargin: `0px 0px -10% 0px`,\n threshold: 0.2,\n })\n\n const itemControls = useAnimation()\n const boxControls = useAnimation()\n\n const setSequence = useCallback(\n (variant: keyof BoxAnimationVariants) => {\n boxControls.stop()\n itemControls.stop()\n boxControls.set(variant)\n itemControls.set(variant)\n },\n [boxControls, itemControls],\n )\n\n const playSequence = useCallback(() => {\n boxControls.stop()\n itemControls.stop()\n boxControls.set('exited')\n itemControls.set('exited')\n boxControls.start('entered')\n itemControls.start('entered')\n }, [boxControls, itemControls])\n\n useEffect(() => {\n if (isBoxVisible) {\n setSequence('entered')\n }\n }, [\n elements\n ?.map(e => e.key)\n .sort()\n .join(),\n setSequence,\n ])\n\n useEffect(() => {\n if (isBoxVisible) {\n playSequence()\n }\n }, [\n isBoxVisible,\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemAnimateDelay,\n itemStaggerDuration,\n reducedMotion,\n playSequence,\n ])\n\n const boxVariant = boxAnimations[boxAnimateType]\n const itemVariant = boxAnimations[itemAnimateType]\n\n return {\n initial: {\n container: reducedMotion ? 'entered' : 'exited',\n parent: reducedMotion ? 'entered' : 'exited',\n },\n animate: {\n container: reducedMotion ? undefined : boxControls,\n parent: reducedMotion ? undefined : itemControls,\n },\n variants: {\n container: {\n exited: boxVariant.exited,\n entered: boxVariant.entered,\n },\n child: {\n exited: itemVariant.exited,\n entered: itemVariant.entered,\n },\n },\n transition: {\n container: mergeCustomTransitionWithDefault(boxVariant.transition, {\n delay: boxAnimateDelay,\n duration: boxAnimateDuration,\n }),\n parent: {\n delayChildren: itemAnimateDelay,\n staggerChildren: itemStaggerDuration,\n duration: itemAnimateDuration,\n },\n child: mergeCustomTransitionWithDefault(itemVariant.transition, {\n duration: itemAnimateDuration,\n }),\n },\n key: {\n container:\n boxAnimateType +\n boxAnimateDuration +\n boxAnimateDelay +\n itemAnimateType +\n itemAnimateDuration +\n itemAnimateDelay +\n itemStaggerDuration +\n reducedMotion,\n },\n }\n}\n","export const getIndexes = (spans: Array<Array<number>>, index: number): [number, number] => {\n const flattened = spans.reduce((a, s) => a.concat(s), [])\n\n if (index < 0 || index > flattened.length) throw new RangeError()\n\n let remainder = index\n let rowIndex = 0\n\n while (rowIndex < spans.length - 1 && remainder >= spans[rowIndex].length) {\n remainder -= spans[rowIndex].length\n rowIndex += 1\n }\n\n return [rowIndex, remainder]\n}\n","import type { ColorValue as Color } from './types'\n\nexport function colorToString(color?: Color): string {\n return color && color.swatch\n ? `hsla(${color.swatch.hue},${color.swatch.saturation}%,${color.swatch.lightness}%,${color.alpha})`\n : ''\n}\n","import { css, CSSObject } from 'styled-components'\nimport {\n WidthProperty,\n MarginProperty,\n MarginTopProperty,\n MarginRightProperty,\n MarginBottomProperty,\n MarginLeftProperty,\n PaddingProperty,\n PaddingTopProperty,\n PaddingRightProperty,\n PaddingBottomProperty,\n PaddingLeftProperty,\n BorderRadiusProperty,\n BorderTopLeftRadiusProperty,\n BorderTopRightRadiusProperty,\n BorderBottomLeftRadiusProperty,\n BorderBottomRightRadiusProperty,\n} from 'csstype'\n\nimport {\n ResponsiveValue,\n ResponsiveValueType as ExtractResponsiveValue,\n Length as LengthValue,\n} from '../../prop-controllers'\nimport {\n FallbackStrategy,\n getDevice,\n getDeviceMediaQuery,\n join as joinResponsiveValues,\n} from './devices'\nimport { getIndexes } from './columns'\nimport {\n BorderRadiusValue,\n MarginValue,\n PaddingValue,\n TextStyleValue,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport { colorToString } from './colorToString'\nimport {\n BorderSide,\n BorderPropControllerData,\n BoxShadowData,\n BoxShadowPropControllerData,\n} from '../hooks'\n\ntype CSSRules = ReturnType<typeof css>\n\nexport function cssMediaRules<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>, P>(\n responsiveValues: A | ((props: P) => A),\n join: (values: { [K in keyof A]: ExtractResponsiveValue<A[K]> | undefined }) =>\n | CSSRules\n | CSSObject,\n strategy?: FallbackStrategy<V>,\n): (props: P) => CSSRules {\n return props =>\n joinResponsiveValues(\n typeof responsiveValues === 'function' ? responsiveValues(props) : responsiveValues,\n join,\n strategy,\n ).reduce((acc, { deviceId, value }) => {\n const device = getDevice(deviceId)\n const mediaQuery = getDeviceMediaQuery(device)\n\n return css`\n ${acc}${mediaQuery} {\n ${value}\n }\n `\n }, css`` as CSSRules)\n}\n\nexport function cssWidth(\n defaultValue: LengthValue | WidthProperty<string | number> = '100%',\n): (props: { width?: WidthValue }) => CSSRules {\n return props => css`\n max-width: 100%;\n ${cssMediaRules(\n [props.width] as const,\n ([width = defaultValue]) => css`\n width: ${typeof width === 'object' ? `${width.value}${width.unit}` : width};\n `,\n )}\n `\n}\n\nfunction getMarginSide(marginSide: LengthValue | MarginProperty<string | number>) {\n return typeof marginSide === 'object' ? `${marginSide.value}${marginSide.unit}` : marginSide\n}\n\nexport function cssMargin(\n defaultValue: {\n marginTop?: LengthValue | MarginTopProperty<string | number>\n marginRight?: LengthValue | MarginRightProperty<string | number>\n marginBottom?: LengthValue | MarginBottomProperty<string | number>\n marginLeft?: LengthValue | MarginLeftProperty<string | number>\n } = {},\n): (props: { margin?: MarginValue }) => CSSRules {\n const defaultMarginTop = defaultValue.marginTop === undefined ? 0 : defaultValue.marginTop\n const defaultMarginRight =\n defaultValue.marginRight === undefined ? 'auto' : defaultValue.marginRight\n const defaultMarginBottom =\n defaultValue.marginBottom === undefined ? 0 : defaultValue.marginBottom\n const defaultMarginLeft = defaultValue.marginLeft === undefined ? 'auto' : defaultValue.marginLeft\n\n return props => css`\n ${cssMediaRules(\n [props.margin] as const,\n ([\n {\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n } = {} as ExtractResponsiveValue<MarginValue>,\n ]) => css`\n margin-top: ${getMarginSide(marginTop || defaultMarginTop)};\n margin-right: ${getMarginSide(marginRight || defaultMarginRight)};\n margin-bottom: ${getMarginSide(marginBottom || defaultMarginBottom)};\n margin-left: ${getMarginSide(marginLeft || defaultMarginLeft)};\n `,\n )}\n `\n}\n\nfunction getPaddingSide(paddingSide: LengthValue | PaddingProperty<string | number>) {\n return typeof paddingSide === 'object' ? `${paddingSide.value}${paddingSide.unit}` : paddingSide\n}\n\nexport function cssPadding(\n defaultValue: {\n paddingTop?: LengthValue | PaddingTopProperty<string | number>\n paddingRight?: LengthValue | PaddingRightProperty<string | number>\n paddingBottom?: LengthValue | PaddingBottomProperty<string | number>\n paddingLeft?: LengthValue | PaddingLeftProperty<string | number>\n } = {},\n): (props: { padding?: PaddingValue }) => CSSRules {\n const defaultPaddingTop = defaultValue.paddingTop === undefined ? 0 : defaultValue.paddingTop\n const defaultPaddingRight =\n defaultValue.paddingRight === undefined ? 0 : defaultValue.paddingRight\n const defaultPaddingBottom =\n defaultValue.paddingBottom === undefined ? 0 : defaultValue.paddingBottom\n const defaultPaddingLeft = defaultValue.paddingLeft === undefined ? 0 : defaultValue.paddingLeft\n\n return props => css`\n ${cssMediaRules(\n [props.padding] as const,\n ([\n {\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n } = {} as ExtractResponsiveValue<PaddingValue>,\n ]) => css`\n padding-top: ${getPaddingSide(paddingTop || defaultPaddingTop)};\n padding-right: ${getPaddingSide(paddingRight || defaultPaddingRight)};\n padding-bottom: ${getPaddingSide(paddingBottom || defaultPaddingBottom)};\n padding-left: ${getPaddingSide(paddingLeft || defaultPaddingLeft)};\n `,\n )}\n `\n}\n\nconst defaultBorderSide = { width: 0, style: 'solid', color: null }\n\nconst getBorderSide = ({ width, style, color }: BorderSide) =>\n `${width != null ? width : 0}px ${style} ${color != null ? colorToString(color) : 'black'}`\n\nexport function cssBorder(\n defaultValue: {\n borderTop?: BorderSide\n borderRight?: BorderSide\n borderBottom?: BorderSide\n borderLeft?: BorderSide\n } = {},\n): (props: { border?: BorderPropControllerData | null | undefined }) => CSSRules {\n const defaultBorderTop =\n defaultValue.borderTop === undefined ? defaultBorderSide : defaultValue.borderTop\n const defaultBorderRight =\n defaultValue.borderRight === undefined ? defaultBorderSide : defaultValue.borderRight\n const defaultBorderBottom =\n defaultValue.borderBottom === undefined ? defaultBorderSide : defaultValue.borderBottom\n const defaultBorderLeft =\n defaultValue.borderLeft === undefined ? defaultBorderSide : defaultValue.borderLeft\n\n return props => css`\n ${cssMediaRules(\n [props.border] as const,\n ([\n {\n borderTop,\n borderRight,\n borderBottom,\n borderLeft,\n } = {} as ExtractResponsiveValue<BorderPropControllerData>,\n ]) => css`\n border-top: ${getBorderSide(borderTop || defaultBorderTop)};\n border-right: ${getBorderSide(borderRight || defaultBorderRight)};\n border-bottom: ${getBorderSide(borderBottom || defaultBorderBottom)};\n border-left: ${getBorderSide(borderLeft || defaultBorderLeft)};\n `,\n )}\n `\n}\n\nfunction getBorderRadiusCorner(\n borderRadiusCorner: LengthValue | BorderRadiusProperty<string | number>,\n) {\n return typeof borderRadiusCorner === 'object'\n ? `${borderRadiusCorner.value}${borderRadiusCorner.unit}`\n : borderRadiusCorner\n}\n\nexport function cssBorderRadius(\n defaultValue: {\n borderTopLeftRadius?: LengthValue | BorderTopLeftRadiusProperty<string | number>\n borderTopRightRadius?: LengthValue | BorderTopRightRadiusProperty<string | number>\n borderBottomLeftRadius?: LengthValue | BorderBottomLeftRadiusProperty<string | number>\n borderBottomRightRadius?: LengthValue | BorderBottomRightRadiusProperty<string | number>\n } = {},\n): (props: { borderRadius?: BorderRadiusValue }) => CSSRules {\n const defaultBorderTopLeftRadius =\n defaultValue.borderTopLeftRadius === undefined ? 0 : defaultValue.borderTopLeftRadius\n const defaultBorderTopRightRadius =\n defaultValue.borderTopRightRadius === undefined ? 0 : defaultValue.borderTopRightRadius\n const defaultPaddingBottom =\n defaultValue.borderBottomLeftRadius === undefined ? 0 : defaultValue.borderBottomLeftRadius\n const defaultPaddingLeft =\n defaultValue.borderBottomRightRadius === undefined ? 0 : defaultValue.borderBottomRightRadius\n\n return props => css`\n ${cssMediaRules(\n [props.borderRadius] as const,\n ([\n {\n borderTopLeftRadius,\n borderTopRightRadius,\n borderBottomLeftRadius,\n borderBottomRightRadius,\n } = {} as ExtractResponsiveValue<BorderRadiusValue>,\n ]) => css`\n border-top-left-radius: ${getBorderRadiusCorner(\n borderTopLeftRadius || defaultBorderTopLeftRadius,\n )};\n border-top-right-radius: ${getBorderRadiusCorner(\n borderTopRightRadius || defaultBorderTopRightRadius,\n )};\n border-bottom-left-radius: ${getBorderRadiusCorner(\n borderBottomLeftRadius || defaultPaddingBottom,\n )};\n border-bottom-right-radius: ${getBorderRadiusCorner(\n borderBottomRightRadius || defaultPaddingLeft,\n )};\n `,\n )}\n `\n}\n\nconst getBoxShadow = (shadows: BoxShadowData) =>\n shadows\n .map(\n ({ payload: { inset, offsetX, offsetY, blurRadius, spreadRadius, color } }) =>\n `${inset ? 'inset ' : ''}${offsetX.toFixed(1)}px ${offsetY.toFixed(\n 1,\n )}px ${blurRadius}px ${spreadRadius}px ${\n color != null ? colorToString(color) : 'rgba(0,0,0,0.2)'\n }`,\n )\n .filter(Boolean)\n .join()\n\nexport function cssBoxShadow(\n defaultValue: BoxShadowData = [],\n): (props: { boxShadow?: BoxShadowPropControllerData | null | undefined }) => CSSRules {\n return props => css`\n ${cssMediaRules(\n [props.boxShadow] as const,\n ([boxShadow = defaultValue]) => css`\n box-shadow: ${getBoxShadow(boxShadow)};\n `,\n )}\n `\n}\n\nconst floor =\n (d: number) =>\n (v: number): number =>\n Math.floor(10 ** d * v) / 10 ** d\n\nexport function cssGridItem(): (props: {\n grid: ResponsiveValue<{ spans: Array<Array<number>>; count: number }>\n index: number\n columnGap?: ResponsiveValue<LengthValue>\n rowGap?: ResponsiveValue<LengthValue>\n}) => CSSRules {\n return props => css`\n display: flex;\n\n /* TODO: A default span of 12 won't work once the column count is modifiable. */\n ${cssMediaRules(\n [props.grid, props.columnGap, props.rowGap] as const,\n ([\n { spans, count } = { spans: [[12]], count: 12 },\n columnGap = { value: 0, unit: 'px' },\n rowGap = { value: 0, unit: 'px' },\n ]) => {\n const [rowIndex, columnIndex] = getIndexes(spans, props.index)\n const firstCol = columnIndex === 0\n const lastCol = columnIndex === spans[rowIndex].length - 1\n const span = spans[rowIndex][columnIndex]\n const fraction = floor(5)(span / count)\n const width = `${fraction} * (100% + ${columnGap.value}${columnGap.unit})`\n const excessWidth = `${Number(firstCol) + Number(lastCol)} * ${columnGap.value}${\n columnGap.unit\n } / 2`\n const iePrecisionError = '0.01px'\n const flexBasis = `calc(${width} - ${excessWidth} - ${iePrecisionError})`\n const firstRow = rowIndex === 0\n const lastRow = rowIndex === spans.length - 1\n\n return span === 0\n ? { display: 'none' }\n : {\n flexBasis,\n minWidth: flexBasis,\n // NOTE: IE11 width breaks without max width\n // https://github.com/philipwalton/flexbugs/issues/3\n maxWidth: flexBasis,\n paddingLeft: firstCol ? 0 : `${columnGap.value / 2}${columnGap.unit}`,\n paddingRight: lastCol ? 0 : `${columnGap.value / 2}${columnGap.unit}`,\n paddingTop: firstRow ? 0 : `${rowGap.value / 2}${rowGap.unit}`,\n paddingBottom: lastRow ? 0 : `${rowGap.value / 2}${rowGap.unit}`,\n }\n },\n )}\n `\n}\n\nexport function cssTextStyle(\n defaultValue: {\n fontFamily?: string | null | undefined\n letterSpacing: number | null | undefined\n fontSize: LengthValue | null | undefined\n fontWeight: number | null | undefined\n textTransform: Array<'uppercase'>\n fontStyle: Array<'italic'>\n } = {\n fontFamily: null,\n letterSpacing: null,\n fontSize: null,\n fontWeight: null,\n textTransform: [],\n fontStyle: [],\n },\n): (arg0: { textStyle?: TextStyleValue | null | undefined }) => CSSRules {\n return props => css`\n ${cssMediaRules([props.textStyle], ([textStyle = defaultValue]) => {\n const {\n fontSize,\n fontWeight,\n fontStyle = [],\n textTransform = [],\n letterSpacing,\n fontFamily,\n } = textStyle\n\n return css`\n ${fontFamily != null\n ? css`\n font-family: '${fontFamily}';\n `\n : ''};\n ${fontWeight != null\n ? css`\n font-weight: ${fontWeight};\n `\n : ''};\n ${letterSpacing != null\n ? css`\n letter-spacing: ${letterSpacing}px;\n `\n : ''};\n ${fontSize != null\n ? css`\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n `\n : ''};\n ${textTransform.includes('uppercase')\n ? css`\n text-transform: uppercase;\n `\n : ''};\n ${fontStyle.includes('italic')\n ? css`\n font-style: italic;\n `\n : ''};\n `\n })}\n `\n}\n","const clamp = (min: number, val: number, max: number): number => Math.min(Math.max(min, val), max)\n\nexport default clamp\n","import { useState, useRef, useCallback, ReactNode, CSSProperties } from 'react'\nimport clamp from '../../../../../utils/clamp'\nimport { useIsomorphicLayoutEffect } from '../../../../hooks/useIsomorphicLayoutEffect'\n\nfunction isScrollable(element: HTMLElement) {\n const { overflow, overflowY, overflowX } =\n element.ownerDocument.defaultView!.getComputedStyle(element)\n\n return /(auto|scroll)/.test(overflow + overflowX + overflowY)\n}\n\nfunction getScrollParent(element: HTMLElement): HTMLElement {\n const { parentElement } = element\n\n if (!element || !parentElement) return element\n\n if (isScrollable(element)) return element\n\n return getScrollParent(parentElement)\n}\n\ntype Props = {\n strength: number | null | undefined\n children: (\n getParallaxProps: <P extends { style?: CSSProperties; [key: string]: unknown }>(props: P) => P,\n ) => ReactNode\n}\n\nexport default function Parallax({ strength, children, ...rest }: Props): JSX.Element {\n const container = useRef<HTMLDivElement>(null)\n const [containerScrollTop, setContainerScrollTop] = useState(strength == null ? 0 : strength)\n const lastScrollParentScrollTop = useRef(0)\n\n useIsomorphicLayoutEffect(() => {\n if (!container.current || strength == null || strength === 0) return undefined\n\n const containerDocument = container.current.ownerDocument\n const scrollParent = getScrollParent(container.current)\n const eventTarget =\n containerDocument.documentElement === scrollParent\n ? containerDocument.defaultView!\n : scrollParent\n\n lastScrollParentScrollTop.current = scrollParent.scrollTop\n setContainerScrollTop(strength)\n\n function handleScroll() {\n containerDocument.defaultView!.requestAnimationFrame(() => {\n if (!container.current) return\n\n const { top: containerTop, bottom: containerBottom } =\n container.current.getBoundingClientRect()\n const { top: scrollParentTop, bottom: scrollParentBottom } =\n scrollParent === containerDocument.documentElement\n ? { top: 0, bottom: containerDocument.defaultView!.innerHeight }\n : scrollParent.getBoundingClientRect()\n const { scrollTop: scrollParentScrollTop } =\n scrollParent === containerDocument.documentElement\n ? { scrollTop: containerDocument.defaultView!.pageYOffset }\n : scrollParent\n const scrollParentHeight = scrollParentBottom - scrollParentTop\n const scrollParentScrollDelta = scrollParentScrollTop - lastScrollParentScrollTop.current\n\n lastScrollParentScrollTop.current = scrollParentScrollTop\n\n setContainerScrollTop(scrollTop => {\n const isContainerVisible =\n containerTop < scrollParentTop + scrollParentHeight && containerBottom > scrollParentTop\n const containerScrollRemaining =\n scrollParentScrollDelta > 0 ? 2 * strength! - scrollTop : scrollTop\n const scrollParentScrollRemaining =\n scrollParentScrollDelta > 0\n ? scrollParentTop + containerBottom\n : scrollParentHeight - containerTop\n const parallaxRatio = containerScrollRemaining / scrollParentScrollRemaining\n const containerScrollDelta = isContainerVisible\n ? parallaxRatio * scrollParentScrollDelta\n : 0\n\n return clamp(0, scrollTop + containerScrollDelta, strength! * 2)\n })\n })\n }\n\n eventTarget.addEventListener('scroll', handleScroll)\n\n return () => eventTarget.removeEventListener('scroll', handleScroll)\n }, [strength])\n\n const getProps = useCallback(\n ({ style, ...restOfChildrenProps }) => ({\n ...restOfChildrenProps,\n style: {\n ...style,\n position: 'absolute',\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n ...(strength == null || strength === 0\n ? {}\n : {\n top: -strength,\n bottom: -strength,\n transform: `translate3d(0, ${containerScrollTop - strength}px, 0)`,\n }),\n },\n }),\n [strength, containerScrollTop],\n )\n\n return (\n <div\n {...rest}\n ref={container}\n style={{ position: 'absolute', top: 0, left: 0, right: 0, bottom: 0 }}\n >\n {children(getProps)}\n </div>\n )\n}\n","import { useState, useRef } from 'react'\nimport ReactPlayer from 'react-player'\nimport styled from 'styled-components'\n\nimport { useIsomorphicLayoutEffect } from '../../../../hooks/useIsomorphicLayoutEffect'\n\nconst Container = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n pointer-events: none;\n overflow: hidden;\n`\n\nconst Mask = styled.div<{ backgroundColor: string | undefined; visible: boolean }>`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: ${props => props.backgroundColor};\n opacity: ${props => (props.visible ? 1 : 0)};\n transition: opacity 1s;\n`\n\nconst getScale = (element: HTMLElement, aspectRatio: number, zoom: number) => {\n const { offsetWidth: width, offsetHeight: height } = element\n const computedAspectRatio = width / height\n\n return Math.max(aspectRatio / computedAspectRatio, computedAspectRatio / aspectRatio) * zoom\n}\n\ntype Props = {\n url?: string\n aspectRatio?: number\n zoom?: number\n opacity?: number\n maskColor?: string\n}\n\nexport default function BackgroundVideo({\n url = '',\n aspectRatio = 16 / 9,\n zoom = 1,\n maskColor,\n opacity,\n}: Props): JSX.Element {\n const [ready, setReady] = useState(false)\n const [scale, setScale] = useState(1)\n const container = useRef<HTMLDivElement>(null)\n\n useIsomorphicLayoutEffect(() => {\n const { current: containerEl } = container\n\n if (!containerEl) return undefined\n\n const { defaultView } = containerEl.ownerDocument\n const handleResize = () => setScale(getScale(containerEl, aspectRatio, zoom))\n\n handleResize()\n\n defaultView!.addEventListener('resize', handleResize)\n\n return () => defaultView!.removeEventListener('resize', handleResize)\n }, [aspectRatio, zoom])\n\n if (!ReactPlayer.canPlay(url)) return <></>\n\n return (\n <Container ref={container}>\n {container.current && (\n <ReactPlayer\n url={url}\n config={{\n vimeo: { playerOptions: { background: true } },\n youtube: {\n playerVars: {\n origin: container.current.ownerDocument.defaultView?.location.origin,\n },\n },\n wistia: {\n options: {\n endVideoBehavior: 'loop',\n playbackRateControl: false,\n playbar: false,\n playButton: false,\n volumeControl: false,\n fullscreenButton: false,\n muted: true,\n },\n },\n }}\n playing\n loop\n muted\n controls={false}\n onReady={() => setReady(true)}\n style={{\n transform: `scale3d(${scale}, ${scale}, 1)`,\n opacity,\n }}\n width=\"100%\"\n height=\"100%\"\n />\n )}\n <Mask backgroundColor={maskColor} visible={!ready} />\n </Container>\n )\n}\n","import styled, { css } from 'styled-components'\nimport NextImage from 'next/image'\n\nimport { cssMediaRules } from '../../../../utils/cssMediaRules'\nimport { BackgroundsPropControllerData } from '../../../../hooks'\nimport { ResponsiveValue } from '../../../../../prop-controllers'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport Parallax from '../Parallax'\nimport BackgroundVideo from '../BackgroundVideo'\n\nfunction getColor(color: Color | null | undefined) {\n if (color == null) return 'black'\n\n if (color.swatch == null) {\n return colorToString({ ...color, swatch: { hue: 0, saturation: 0, lightness: 0 } })\n }\n\n return colorToString(color)\n}\n\ntype GradientStop = { color: Color | null | undefined; location: number }\n\nconst getStopsStyle = (stops: GradientStop[]) =>\n stops.map(({ color, location }) => `${getColor(color)} ${location}%`).join(',')\n\ntype AspectRatio = 'wide' | 'standard'\n\nconst getAspectRatio = (aspectRatio: AspectRatio) => {\n switch (aspectRatio) {\n case 'wide':\n return 16 / 9\n case 'standard':\n return 4 / 3\n default:\n return 16 / 9\n }\n}\n\nconst AbsoluteFill = styled.div`\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n`\n\nconst Container = styled(AbsoluteFill)`\n border-radius: inherit;\n`\n\nconst BackgroundsContainer = styled(Container)<{ visibility: ResponsiveValue<boolean> }>`\n overflow: hidden;\n ${p =>\n cssMediaRules(\n [p.visibility],\n ([visibility]) => css`\n display: ${visibility === true ? 'block' : 'none'};\n `,\n )}\n`\n\ntype Props = { backgrounds: BackgroundsPropControllerData | null | undefined }\n\nexport default function Backgrounds({ backgrounds }: Props): JSX.Element {\n if (backgrounds == null) return <></>\n\n return (\n <>\n {backgrounds.map(({ value, deviceId }) => {\n const visibility = backgrounds.map(v => ({\n deviceId: v.deviceId,\n value: v.deviceId === deviceId,\n }))\n\n return (\n <BackgroundsContainer key={deviceId} visibility={visibility}>\n {[...value].reverse().map(bg => {\n if (bg.type === 'color') {\n return (\n <Container\n key={bg.id}\n style={{\n backgroundColor: getColor(bg.payload),\n }}\n />\n )\n }\n\n if (bg.type === 'image' && bg.payload) {\n const {\n publicUrl,\n position,\n repeat = 'no-repeat',\n size = 'cover',\n opacity,\n parallax,\n } = bg.payload\n const backgroundPosition = `${position.x}% ${position.y}%`\n\n if (repeat === 'no-repeat' && size !== 'auto' && publicUrl != null) {\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <div {...getParallaxProps({ style: { opacity, overflow: 'hidden' } })}>\n <NextImage\n src={publicUrl}\n layout=\"fill\"\n objectPosition={backgroundPosition}\n objectFit={size}\n />\n </div>\n )}\n </Parallax>\n )\n }\n\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <Container\n {...getParallaxProps({\n style: {\n backgroundImage: publicUrl != null ? `url('${publicUrl}')` : undefined,\n backgroundPosition,\n backgroundRepeat: repeat,\n backgroundSize: size,\n opacity,\n },\n })}\n />\n )}\n </Parallax>\n )\n }\n\n if (bg.type === 'gradient' && bg.payload) {\n const { angle, stops, isRadial } = bg.payload\n const gradient = `${getStopsStyle(stops)}`\n\n return (\n <Container\n key={bg.id}\n style={{\n background: isRadial\n ? `radial-gradient(${gradient})`\n : `linear-gradient(${angle}rad, ${gradient})`,\n }}\n />\n )\n }\n\n if (bg.type === 'video' && bg.payload) {\n const { url, aspectRatio, maskColor, zoom, opacity, parallax } = bg.payload\n\n return (\n <Parallax key={bg.id} strength={parallax}>\n {getParallaxProps => (\n <Container {...getParallaxProps({})}>\n <BackgroundVideo\n url={url}\n zoom={zoom}\n opacity={opacity}\n aspectRatio={getAspectRatio(aspectRatio)}\n maskColor={getColor(maskColor)}\n />\n </Container>\n )}\n </Parallax>\n )\n }\n\n return null\n })}\n </BackgroundsContainer>\n )\n })}\n </>\n )\n}\n","import {\n ReactElement,\n ElementType,\n forwardRef,\n Children,\n ComponentPropsWithoutRef,\n useImperativeHandle,\n useState,\n} from 'react'\nimport styled from 'styled-components'\nimport { motion } from 'framer-motion'\n\nimport Backgrounds from './components/Backgrounds'\nimport { BackgroundsValue as BackgroundsPropControllerValue } from '../../../prop-controllers/descriptors'\nimport { useBackgrounds } from '../../hooks'\nimport { Ref } from 'react'\n\nconst OuterContainer = styled(motion.div)`\n position: relative;\n width: 100%;\n margin: 0 auto;\n\n > * {\n border-radius: inherit;\n height: inherit;\n }\n\n > :last-child {\n position: relative;\n }\n`\n\ntype BaseProps = {\n backgrounds: BackgroundsPropControllerValue | null | undefined\n children: ReactElement<ElementType>\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof OuterContainer>, keyof BaseProps>\n\nexport default forwardRef<HTMLDivElement | null, Props>(function BackgroundsContainer(\n { backgrounds, children, ...restOfProps }: Props,\n ref: Ref<HTMLDivElement | null>,\n) {\n const [handle, setHandle] = useState<HTMLDivElement | null>(null)\n\n useImperativeHandle(ref, () => handle, [handle])\n\n return (\n <OuterContainer {...restOfProps} ref={setHandle}>\n <Backgrounds backgrounds={useBackgrounds(backgrounds)} />\n {Children.only(children)}\n </OuterContainer>\n )\n})\n","import { forwardRef, Ref, useImperativeHandle, useRef, useState } from 'react'\nimport styled from 'styled-components'\nimport { motion } from 'framer-motion'\nimport { cx } from '@emotion/css'\n\nimport { Element, ReactRuntime } from '../../../react'\nimport Placeholder from './components/Placeholder'\nimport {\n BoxAnimateIn,\n DEFAULT_BOX_ANIMATE_DELAY,\n DEFAULT_BOX_ANIMATE_DURATION,\n DEFAULT_ITEM_ANIMATE_DELAY,\n DEFAULT_ITEM_STAGGER_DURATION,\n useBoxAnimations,\n} from './animations'\nimport {\n BorderRadiusValue,\n ElementIDValue,\n MarginValue,\n PaddingValue,\n ResponsiveIconRadioGroupValue,\n GridValue,\n GapYValue,\n GapXValue,\n CheckboxValue,\n ResponsiveSelectValue,\n ResponsiveNumberValue,\n BackgroundsValue,\n BorderValue,\n ShadowsValue,\n ResponsiveValue,\n} from '../../../prop-controllers/descriptors'\nimport {\n cssMargin,\n cssPadding,\n cssBorderRadius,\n cssGridItem,\n cssMediaRules,\n cssBorder,\n cssBoxShadow,\n} from '../../utils/cssMediaRules'\nimport { BoxModelHandle, parse, createBox } from '../../../box-model'\nimport BackgroundsContainer from '../../shared/BackgroundsContainer'\nimport {\n BorderPropControllerData,\n BoxShadowPropControllerData,\n useBorder,\n useBoxShadow,\n} from '../../hooks'\nimport { Props } from '../../../prop-controllers'\nimport { findDeviceOverride } from '../../utils/devices'\n\ntype Props = {\n id?: ElementIDValue\n backgrounds?: BackgroundsValue\n width?: string\n height?: ResponsiveIconRadioGroupValue<'auto' | 'stretch'>\n verticalAlign?: ResponsiveIconRadioGroupValue<\n 'flex-start' | 'center' | 'flex-end' | 'space-between'\n >\n margin?: MarginValue\n padding?: PaddingValue\n border?: BorderValue\n borderRadius?: BorderRadiusValue\n boxShadow?: ShadowsValue\n rowGap?: GapYValue\n columnGap?: GapXValue\n boxAnimateType?: ResponsiveSelectValue<BoxAnimateIn>\n boxAnimateDuration?: ResponsiveNumberValue\n boxAnimateDelay?: ResponsiveNumberValue\n itemAnimateType?: ResponsiveSelectValue<BoxAnimateIn>\n itemAnimateDuration?: ResponsiveNumberValue\n itemAnimateDelay?: ResponsiveNumberValue\n itemStaggerDuration?: ResponsiveNumberValue\n hidePlaceholder?: CheckboxValue\n children?: GridValue\n}\n\nconst StyledBackgroundsContainer = styled(BackgroundsContainer).withConfig({\n shouldForwardProp: prop => !['margin', 'borderRadius', 'alignSelf'].includes(prop.toString()),\n})<{\n margin: Props['margin']\n borderRadius: Props['borderRadius']\n alignSelf: Props['height']\n}>`\n display: flex;\n ${cssMargin()}\n ${cssBorderRadius()}\n ${props => cssMediaRules([props.alignSelf] as const, ([alignSelf = 'auto']) => ({ alignSelf }))}\n`\n\nconst Grid = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['padding', 'border', 'boxShadow', 'alignContent'].includes(prop),\n})<{\n padding: Props['padding']\n border: BorderPropControllerData | null | undefined\n boxShadow: BoxShadowPropControllerData | null | undefined\n alignContent: Props['verticalAlign']\n}>`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n ${cssPadding()}\n ${cssBorder()}\n ${cssBoxShadow()}\n ${props =>\n cssMediaRules([props.alignContent] as const, ([alignContent = 'flex-start']) => ({\n alignContent,\n }))}\n`\nconst GridItem = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['grid', 'alignItems', 'index', 'columnGap', 'rowGap'].includes(prop),\n})<{\n grid: NonNullable<Props['children']>['columns']\n alignItems: Props['verticalAlign']\n index: number\n columnGap: Props['columnGap']\n rowGap: Props['rowGap']\n}>`\n display: flex;\n\n /* IE11 doesn't recognize space-between and treats it as stretch, so we fall back to flex-start */\n align-items: flex-start;\n ${cssGridItem()}\n ${props =>\n cssMediaRules([props.alignItems] as const, ([alignItems = 'flex-start']) => ({ alignItems }))}\n`\n\nconst Box = forwardRef(function Box(\n {\n id,\n backgrounds,\n width,\n height,\n margin,\n padding,\n border,\n children,\n borderRadius,\n boxShadow,\n rowGap,\n columnGap,\n hidePlaceholder,\n verticalAlign,\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemStaggerDuration,\n }: Props,\n ref: Ref<BoxModelHandle>,\n) {\n const innerRef = useRef<HTMLDivElement | null>(null)\n const [boxElement, setBoxElement] = useState<HTMLElement | null>(null)\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n const paddingBoxElement = innerRef.current\n const borderBoxElement = innerRef.current\n const marginBoxElement = boxElement\n const borderBox = innerRef.current?.getBoundingClientRect()\n const paddingBoxComputedStyle =\n paddingBoxElement?.ownerDocument.defaultView?.getComputedStyle(paddingBoxElement)\n const borderBoxComputedStyle =\n borderBoxElement?.ownerDocument.defaultView?.getComputedStyle(borderBoxElement)\n const marginBoxComputedStyle =\n marginBoxElement?.ownerDocument.defaultView?.getComputedStyle(marginBoxElement)\n const padding = paddingBoxComputedStyle && {\n top: parse(paddingBoxComputedStyle.paddingTop),\n right: parse(paddingBoxComputedStyle.paddingRight),\n bottom: parse(paddingBoxComputedStyle.paddingBottom),\n left: parse(paddingBoxComputedStyle.paddingLeft),\n }\n const border = borderBoxComputedStyle && {\n top: parse(borderBoxComputedStyle.borderTopWidth),\n right: parse(borderBoxComputedStyle.borderRightWidth),\n bottom: parse(borderBoxComputedStyle.borderBottomWidth),\n left: parse(borderBoxComputedStyle.borderLeftWidth),\n }\n const margin = marginBoxComputedStyle && {\n top: parse(marginBoxComputedStyle.marginTop),\n right: parse(marginBoxComputedStyle.marginRight),\n bottom: parse(marginBoxComputedStyle.marginBottom),\n left: parse(marginBoxComputedStyle.marginLeft),\n }\n\n return borderBox ? createBox({ borderBox, padding, border, margin }) : null\n },\n }),\n [boxElement],\n )\n\n const borderData = useBorder(border)\n const boxShadowData = useBoxShadow(boxShadow)\n\n const { initial, animate, variants, transition, key } = useBoxAnimations({\n boxAnimateType,\n boxAnimateDuration,\n boxAnimateDelay,\n itemAnimateDelay,\n itemAnimateType,\n itemAnimateDuration,\n itemStaggerDuration,\n boxElement,\n elements: children?.elements,\n })\n\n return (\n <StyledBackgroundsContainer\n ref={setBoxElement}\n id={id}\n className={cx(width)}\n backgrounds={backgrounds}\n margin={margin}\n borderRadius={borderRadius}\n alignSelf={height}\n animate={animate?.container}\n initial={initial?.container}\n variants={variants?.container}\n transition={transition?.container}\n key={key?.container}\n >\n <Grid\n ref={innerRef}\n padding={padding}\n border={borderData}\n boxShadow={boxShadowData}\n alignContent={verticalAlign}\n animate={animate?.parent}\n initial={initial?.parent}\n transition={transition?.parent}\n >\n {children && children.elements.length > 0 ? (\n children.elements.map((child, index) => (\n <GridItem\n key={child.key}\n grid={children.columns}\n index={index}\n columnGap={columnGap}\n rowGap={rowGap}\n alignItems={verticalAlign}\n variants={variants?.child}\n transition={transition?.child}\n >\n <Element element={child} />\n </GridItem>\n ))\n ) : (\n <Placeholder hide={hidePlaceholder} />\n )}\n </Grid>\n </StyledBackgroundsContainer>\n )\n})\n\nexport default Box\n\nexport function registerComponent(runtime: ReactRuntime) {\n function isHiddenBasedOnAnimationType(\n props: Record<string, unknown>,\n deviceId: string,\n property: 'boxAnimateType' | 'itemAnimateType',\n ): boolean {\n const animateIn = props[property] as ResponsiveValue<BoxAnimateIn>\n return (findDeviceOverride<BoxAnimateIn>(animateIn, deviceId)?.value ?? 'none') === 'none'\n }\n const isHiddenBasedOnBoxAnimation = (props: Record<string, unknown>, deviceId: string) =>\n isHiddenBasedOnAnimationType(props, deviceId, 'boxAnimateType')\n const isHiddenBasedOnItemAnimation = (props: Record<string, unknown>, deviceId: string) =>\n isHiddenBasedOnAnimationType(props, deviceId, 'itemAnimateType')\n\n return runtime.registerComponent(Box, {\n type: './components/Box/index.js',\n label: 'Box',\n props: {\n id: Props.ElementID(),\n backgrounds: Props.Backgrounds(),\n width: Props.Width({ format: Props.Width.Formats.ClassName }),\n height: Props.ResponsiveIconRadioGroup({\n label: 'Height',\n options: [\n { value: 'auto', label: 'Auto', icon: 'HeightAuto16' },\n { value: 'stretch', label: 'Stretch', icon: 'HeightMatch16' },\n ],\n defaultValue: 'auto',\n }),\n verticalAlign: Props.ResponsiveIconRadioGroup({\n label: 'Align items',\n options: [\n { value: 'flex-start', label: 'Top', icon: 'VerticalAlignStart16' },\n { value: 'center', label: 'Middle', icon: 'VerticalAlignMiddle16' },\n { value: 'flex-end', label: 'Bottom', icon: 'VerticalAlignEnd16' },\n {\n value: 'space-between',\n label: 'Space between',\n icon: 'VerticalAlignSpaceBetween16',\n },\n ],\n defaultValue: 'flex-start',\n }),\n margin: Props.Margin(),\n padding: Props.Padding({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n paddingTop: { value: 10, unit: 'px' },\n paddingRight: { value: 10, unit: 'px' },\n paddingBottom: { value: 10, unit: 'px' },\n paddingLeft: { value: 10, unit: 'px' },\n },\n },\n ],\n }),\n border: Props.Border(),\n borderRadius: Props.BorderRadius(),\n boxShadow: Props.Shadows(),\n rowGap: Props.GapY(props => ({\n hidden: props.children == null,\n })),\n columnGap: Props.GapX(props => ({\n hidden: props.children == null,\n })),\n boxAnimateType: Props.ResponsiveSelect({\n label: 'Animate box in',\n labelOrientation: 'vertical',\n options: [\n { value: 'none', label: 'None' },\n { value: 'fadeIn', label: 'Fade in' },\n { value: 'fadeRight', label: 'Fade right' },\n { value: 'fadeDown', label: 'Fade down' },\n { value: 'fadeLeft', label: 'Fade left' },\n { value: 'fadeUp', label: 'Fade up' },\n { value: 'blurIn', label: 'Blur in' },\n { value: 'scaleUp', label: 'Scale up' },\n { value: 'scaleDown', label: 'Scale down' },\n ],\n defaultValue: 'none',\n }),\n boxAnimateDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Box duration',\n defaultValue: DEFAULT_BOX_ANIMATE_DURATION,\n min: 0.1,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnBoxAnimation(props, device),\n })),\n boxAnimateDelay: Props.ResponsiveNumber((props, device) => ({\n label: 'Box delay',\n defaultValue: DEFAULT_BOX_ANIMATE_DELAY,\n min: 0,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnBoxAnimation(props, device),\n })),\n itemAnimateType: Props.ResponsiveSelect({\n label: 'Animate items in',\n labelOrientation: 'vertical',\n options: [\n { value: 'none', label: 'None' },\n { value: 'fadeIn', label: 'Fade in' },\n { value: 'fadeRight', label: 'Fade right' },\n { value: 'fadeDown', label: 'Fade down' },\n { value: 'fadeLeft', label: 'Fade left' },\n { value: 'fadeUp', label: 'Fade up' },\n { value: 'blurIn', label: 'Blur in' },\n { value: 'scaleUp', label: 'Scale up' },\n { value: 'scaleDown', label: 'Scale down' },\n ],\n defaultValue: 'none',\n }),\n itemAnimateDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Items duration',\n defaultValue: DEFAULT_BOX_ANIMATE_DURATION,\n min: 0.1,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n itemAnimateDelay: Props.ResponsiveNumber((props, device) => ({\n label: 'Items delay',\n defaultValue: DEFAULT_ITEM_ANIMATE_DELAY,\n min: 0,\n step: 0.05,\n suffix: 's',\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n itemStaggerDuration: Props.ResponsiveNumber((props, device) => ({\n label: 'Stagger',\n min: 0,\n step: 0.05,\n suffix: 's',\n defaultValue: DEFAULT_ITEM_STAGGER_DURATION,\n hidden: isHiddenBasedOnItemAnimation(props, device),\n })),\n hidePlaceholder: Props.Checkbox(props => ({\n label: 'Hide placeholder',\n hidden: props.children != null,\n })),\n children: Props.Grid(),\n },\n })\n}\n","import { ComponentPropsWithoutRef, forwardRef, MouseEvent } from 'react'\nimport scrollIntoView from 'scroll-into-view-if-needed'\nimport NextLink from 'next/link'\n\nimport { LinkValue as LinkPropControllerValue } from '../../../prop-controllers/descriptors'\nimport { usePage } from '../../hooks'\nimport { useElementId } from '../../../runtimes/react'\n\ntype BaseProps = {\n link?: LinkPropControllerValue\n onClick?: (event: MouseEvent<HTMLAnchorElement>) => unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<'a'>, keyof BaseProps>\n\nexport const Link = forwardRef<HTMLAnchorElement, Props>(function Link(\n { link, onClick = () => {}, ...restOfProps }: Props,\n ref,\n) {\n const page = usePage(link && link.type === 'OPEN_PAGE' ? link.payload.pageId : null)\n const elementKey =\n link?.type === 'SCROLL_TO_ELEMENT' ? link.payload.elementIdConfig?.elementKey : null\n const elementId = useElementId(elementKey)\n\n let href = ''\n let target: '_blank' | '_self' | undefined\n let block: 'start' | 'center' | 'end' | undefined\n\n if (link) {\n switch (link.type) {\n case 'OPEN_PAGE': {\n if (page) href = `/${page.pathname}`\n\n target = link.payload.openInNewTab ? '_blank' : '_self'\n\n break\n }\n\n case 'OPEN_URL': {\n href = link.payload.url\n\n target = link.payload.openInNewTab ? '_blank' : '_self'\n\n break\n }\n\n case 'SEND_EMAIL': {\n const { to, subject = '', body = '' } = link.payload\n\n if (to != null) href = `mailto:${to}?subject=${subject}&body=${body}`\n\n break\n }\n\n case 'CALL_PHONE': {\n href = `tel:${link.payload.phoneNumber}`\n\n break\n }\n\n case 'SCROLL_TO_ELEMENT': {\n href = `#${elementId ?? ''}`\n block = link.payload.block\n\n break\n }\n\n default:\n throw new RangeError(`Invalid link type \"${(link as any).type}.\"`)\n }\n }\n\n function handleClick(event: MouseEvent<HTMLAnchorElement>) {\n onClick(event)\n\n if (event.defaultPrevented) return\n\n /**\n * When we introduced `next/link` instead of just `a` element slate no longer prevented link from navigating within\n * content mode. This is a hack to compensate for what would be expected as slate's default behavior.\n * On upgrade of slate this can be reevaluated.\n */\n if (event.currentTarget.isContentEditable) return event.preventDefault()\n\n if (link && link.type === 'SCROLL_TO_ELEMENT') {\n let hash: string | undefined\n\n try {\n hash = new URL(`http://www.example.com/${href}`).hash\n } catch (error) {\n console.error(`Link received invalid href: ${href}`, error)\n }\n\n if (href != null && href === hash) {\n event.preventDefault()\n const view = event.view as unknown as Window\n\n scrollIntoView(view.document.querySelector(hash)!, {\n behavior: 'smooth',\n block,\n })\n\n if (view.location.hash !== hash) view.history.pushState({}, '', hash)\n }\n }\n }\n\n return (\n <NextLink href={href}>\n {/* eslint-disable-next-line */}\n <a {...restOfProps} ref={ref} target={target} onClick={handleClick} />\n </NextLink>\n )\n})\n","import { WidthProperty } from 'csstype'\nimport { CSSObject } from '@emotion/css'\n\nimport {\n ResponsiveValue,\n ResponsiveValueType as ExtractResponsiveValue,\n Length as LengthValue,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport {\n FallbackStrategy,\n getDevice,\n getDeviceMediaQuery,\n join as joinResponsiveValues,\n} from './devices'\n\nexport function responsiveStyle<V, A extends ReadonlyArray<ResponsiveValue<V> | null | undefined>>(\n responsiveValues: A,\n join: (values: { [K in keyof A]: ExtractResponsiveValue<A[K]> | undefined }) => CSSObject,\n strategy?: FallbackStrategy<V>,\n): CSSObject {\n return joinResponsiveValues(responsiveValues, join, strategy).reduce(\n (acc, { deviceId, value }) => {\n const device = getDevice(deviceId)\n const mediaQuery = getDeviceMediaQuery(device)\n\n return {\n ...acc,\n [mediaQuery]: {\n ...(acc[mediaQuery] as CSSObject),\n ...value,\n },\n }\n },\n {} as CSSObject,\n )\n}\n\nexport function responsiveWidth(\n widthData: WidthValue | undefined,\n defaultValue: LengthValue | WidthProperty<string | number> = '100%',\n): CSSObject {\n return {\n maxWidth: '100%',\n ...responsiveStyle([widthData], ([width = defaultValue]) => ({\n width: typeof width === 'object' ? `${width.value}${width.unit}` : width,\n })),\n }\n}\n","import { ReactElement, ComponentPropsWithoutRef, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport ColorHelper from 'color'\nimport { cx, css as toClass } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin, cssTextStyle } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n MarginValue,\n TextInputValue,\n ResponsiveSelectValue,\n ResponsiveIconRadioGroupValue,\n TextStyleValue,\n LinkValue,\n WidthValue,\n} from '../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../utils/types'\nimport { colorToString } from '../../utils/colorToString'\nimport { Link } from '../../shared/Link'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { responsiveWidth } from '../../utils/responsive-style'\nimport { findDeviceOverride } from '../../utils/devices'\n\ntype ButtonVariant = 'flat' | 'outline' | 'shadow' | 'clear' | 'blocky' | 'bubbly' | 'skewed'\n\ntype ControllerProps = {\n id?: ElementIDValue\n children?: TextInputValue\n link?: LinkValue\n variant?: ResponsiveSelectValue<ButtonVariant>\n shape?: ResponsiveIconRadioGroupValue<'pill' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n color?: ResponsiveColor\n textColor?: ResponsiveColor\n textStyle?: TextStyleValue\n width?: WidthValue\n margin?: MarginValue\n}\n\nconst StyledButton = styled(Link).withConfig({\n shouldForwardProp: prop =>\n !['margin', 'variant', 'shape', 'size', 'textColor', 'color', 'textStyle'].includes(\n prop.toString(),\n ),\n})<{\n margin: ControllerProps['margin']\n variant: ControllerProps['variant']\n shape: ControllerProps['shape']\n size: ControllerProps['size']\n textColor: ResponsiveValue<Color> | null | undefined\n color: ResponsiveValue<Color> | null | undefined\n textStyle: ControllerProps['textStyle']\n}>`\n display: table;\n border: 0;\n outline: 0;\n user-select: none;\n cursor: pointer;\n font-family: inherit;\n text-decoration: none;\n text-align: center;\n ${cssMargin()}\n ${p =>\n cssMediaRules(\n [p.variant, p.shape, p.size, p.textColor, p.color] as const,\n ([\n variant = 'flat',\n shape = 'rounded',\n size = 'medium',\n textColor = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 },\n color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => {\n const fontSize = {\n value: { small: 12, medium: 14, large: 18 }[size],\n unit: 'px',\n }\n\n return css`\n color: ${colorToString(textColor)};\n border-radius: ${{ square: 0, rounded: 4, pill: 500 }[shape]}px;\n padding: ${{ small: '8px 12px', medium: '12px 16px', large: '16px 20px' }[size]};\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n ${{\n flat: css`\n background: ${colorToString(color)};\n border: none;\n transition: ${['color', 'background', 'border', 'box-shadow']\n .map(property => `${property} 0.15s ease-in-out`)\n .join(', ')};\n\n :hover {\n background: ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n }\n\n :active {\n background: ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n }\n `,\n outline: css`\n background: transparent;\n box-shadow: inset 0 0 0 2px ${colorToString(color)};\n transition: ${['color', 'background', 'box-shadow']\n .map(property => `${property} 0.15s ease-in-out`)\n .join(', ')};\n\n :hover {\n box-shadow: inset 0 0 0 2px ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n color: ${ColorHelper(colorToString(color)).darken(0.1).hex()};\n }\n\n :active {\n box-shadow: inset 0 0 0 2px ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n color: ${ColorHelper(colorToString(color)).darken(0.15).hex()};\n }\n `,\n shadow: css`\n background: ${colorToString(color)};\n box-shadow: 0 2px 4px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.2);\n transition: ${['transform', 'box-shadow']\n .map(property => `${property} 0.18s`)\n .join(', ')};\n\n :hover {\n box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15), 0 8px 10px -6px rgba(0, 0, 0, 0.3);\n transform: translateY(-1px);\n }\n\n :active {\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 4px 6px -3px rgba(0, 0, 0, 0.3);\n transform: translateY(0px);\n }\n `,\n clear: css`\n background: transparent;\n border: none;\n\n :hover {\n color: ${ColorHelper(colorToString(textColor)).alpha(0.5).toString()};\n }\n\n :active {\n color: ${ColorHelper(colorToString(textColor)).alpha(0.6).toString()};\n }\n `,\n blocky: css`\n background: ${colorToString(color)};\n border-width: 1px;\n border-style: solid;\n border-color: ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n box-shadow: 0 4px ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n transition: ${['transform', 'box-shadow']\n .map(property => `${property} 0.1s`)\n .join(', ')};\n\n :hover {\n transform: translateY(2px);\n box-shadow: 0 2px ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n }\n\n :active {\n transform: translateY(4px);\n box-shadow: 0 0 ${ColorHelper(colorToString(color)).darken(0.25).hex()};\n }\n `,\n bubbly: css`\n background: linear-gradient(\n 180deg,\n ${ColorHelper(colorToString(color)).lighten(0.05).hex()},\n ${ColorHelper(colorToString(color)).darken(0.3).saturate(0.05).hex()}\n );\n position: relative;\n z-index: 0;\n\n :before {\n position: absolute;\n content: '';\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n border-radius: inherit;\n background: linear-gradient(\n 180deg,\n ${ColorHelper(colorToString(color)).lighten(0.2).hex()},\n ${ColorHelper(colorToString(color)).darken(0.2).saturate(0.05).hex()}\n );\n opacity: 0;\n transition: opacity 0.15s;\n }\n\n :hover {\n :before {\n opacity: 1;\n }\n }\n\n :active {\n :before {\n opacity: 0.25;\n }\n }\n `,\n skewed: css`\n position: relative;\n z-index: 0;\n\n :before {\n position: absolute;\n content: '';\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n background: ${colorToString(color)};\n transform: skewX(-12deg);\n border-radius: inherit;\n transition: transform 0.2s cubic-bezier(0.25, 0, 0.25, 1.75);\n }\n\n :hover:before {\n transform: skew(0deg);\n }\n\n :active:before {\n transform: skew(-8deg);\n }\n `,\n }[variant]}\n `\n },\n )}\n ${cssTextStyle()}\n`\n\ntype BaseProps = {\n id?: ControllerProps['id']\n children?: ReactElement | string\n link?: ControllerProps['link']\n variant?: ControllerProps['variant']\n shape?: ControllerProps['shape']\n size?: ControllerProps['size']\n textColor?: ControllerProps['textColor']\n color?: ControllerProps['color']\n textStyle?: ControllerProps['textStyle']\n width?: WidthValue\n margin?: ControllerProps['margin']\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof StyledButton>, keyof BaseProps>\n\nconst Button = forwardRef<HTMLAnchorElement, Props>(function Button(\n {\n id,\n children,\n link,\n variant,\n shape,\n size,\n textColor,\n color,\n textStyle,\n width,\n margin,\n className,\n ...restOfProps\n },\n ref,\n) {\n return (\n <StyledButton\n {...restOfProps}\n ref={ref}\n id={id}\n className={cx(toClass(responsiveWidth(width, 'auto')), className)}\n // @ts-expect-error: HTMLAnchorElement `color` attribute conflicts with prop\n color={color}\n link={link}\n margin={margin}\n shape={shape}\n size={size}\n textColor={textColor}\n textStyle={textStyle}\n variant={variant}\n >\n {children == null ? 'Button Text' : children}\n </StyledButton>\n )\n})\n\nexport default Button\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Button, {\n type: './components/Button/index.js',\n label: 'Button',\n props: {\n id: Props.ElementID(),\n children: Props.TextInput({ placeholder: 'Button text' }),\n link: Props.Link({\n defaultValue: {\n type: 'OPEN_PAGE',\n payload: {\n pageId: null,\n openInNewTab: false,\n },\n },\n }),\n variant: Props.ResponsiveSelect({\n label: 'Style',\n labelOrientation: 'horizontal',\n options: [\n { value: 'flat', label: 'Flat' },\n { value: 'outline', label: 'Outline' },\n { value: 'shadow', label: 'Floating' },\n { value: 'clear', label: 'Clear' },\n { value: 'blocky', label: 'Blocky' },\n { value: 'bubbly', label: 'Bubbly' },\n { value: 'skewed', label: 'Skewed' },\n ],\n defaultValue: 'flat',\n }),\n shape: Props.ResponsiveIconRadioGroup({\n label: 'Shape',\n options: [\n { label: 'Pill', value: 'pill', icon: 'ButtonPill16' },\n { label: 'Rounded', value: 'rounded', icon: 'ButtonRounded16' },\n { label: 'Square', value: 'square', icon: 'ButtonSquare16' },\n ],\n defaultValue: 'rounded',\n }),\n size: Props.ResponsiveIconRadioGroup({\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n }),\n color: Props.ResponsiveColor((props, device) => {\n const variant = props.variant as ResponsiveValue<ButtonVariant>\n const hidden = findDeviceOverride<ButtonVariant>(variant, device)?.value === 'clear'\n\n return { placeholder: 'black', hidden }\n }),\n textColor: Props.ResponsiveColor({\n label: 'Text color',\n placeholder: 'white',\n }),\n textStyle: Props.TextStyle(),\n width: Props.Width(),\n margin: Props.Margin(),\n },\n })\n}\n","export const placeholders = {\n image: {\n src: \"data:image/svg+xml,%3Csvg width='360' height='240' viewBox='0 0 360 240' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cg clip-path='url(%23clip0)'%3E%3Cpath d='M0 0H360V240H0V0Z' fill='%23A1A8C2' fill-opacity='0.18'/%3E%3Cpath d='M260 59C260 78.33 244.33 94 225 94C205.67 94 190 78.33 190 59C190 39.67 205.67 24 225 24C244.33 24 260 39.67 260 59Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M319 250H417L291.485 124.485C286.799 119.799 279.201 119.799 274.515 124.485L234 165L319 250Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3Cpath d='M311 250L-89 250L102.515 58.4853C107.201 53.799 114.799 53.799 119.485 58.4853L311 250Z' fill='%23A1A8C2' fill-opacity='0.25'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id='clip0'%3E%3Cpath d='M0 0H360V240H0V0Z' fill='white'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A\",\n dimensions: { width: 360, height: 240 },\n },\n video: {\n src: \"data:image/svg+xml,%3Csvg width='712' height='400' viewBox='0 0 712 400' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M712 0H0V400H712V0ZM356 240C378.091 240 396 222.091 396 200C396 177.909 378.091 160 356 160C333.909 160 316 177.909 316 200C316 222.091 333.909 240 356 240Z' fill='%23A1A8C2' fill-opacity='0.18'/%3E%3Cpath d='M344 216.503V183.497C344 181.95 345.681 180.989 347.014 181.773L375.069 198.276C376.384 199.049 376.384 200.951 375.069 201.724L347.014 218.227C345.681 219.011 344 218.05 344 216.503Z' fill='%23A1A8C2' fill-opacity='0.4'/%3E%3C/svg%3E%0A\",\n dimensions: { width: 712, height: 400 },\n },\n}\n","import styled, { css } from 'styled-components'\nimport { useState, useEffect, Ref, forwardRef } from 'react'\nimport NextImage from 'next/image'\nimport { css as toClass, cx } from '@emotion/css'\n\nimport {\n BorderRadiusValue,\n BorderValue,\n ElementIDValue,\n ImageValue,\n LinkValue,\n MarginValue,\n PaddingValue,\n ResponsiveOpacityValue,\n ShadowsValue,\n TextInputValue,\n WidthValue,\n} from '../../../prop-controllers/descriptors'\nimport {\n cssBorder,\n cssBorderRadius,\n cssBoxShadow,\n cssMargin,\n cssMediaRules,\n cssPadding,\n} from '../../utils/cssMediaRules'\nimport { DEVICES, findDeviceOverride } from '../../utils/devices'\nimport {\n BorderPropControllerData,\n BoxShadowPropControllerData,\n useBorder,\n useBoxShadow,\n useFile,\n} from '../../hooks'\nimport { placeholders } from '../../utils/placeholders'\nimport { ReactRuntime, useIsInBuilder } from '../../../react'\nimport { Link } from '../../shared/Link'\nimport { Props } from '../../../prop-controllers'\nimport { responsiveWidth } from '../../utils/responsive-style'\n\ntype Props = {\n id?: ElementIDValue\n file?: ImageValue\n altText?: TextInputValue\n link?: LinkValue\n width?: WidthValue\n margin?: MarginValue\n padding?: PaddingValue\n border?: BorderValue\n borderRadius?: BorderRadiusValue\n boxShadow?: ShadowsValue\n opacity?: ResponsiveOpacityValue\n placeholder?: { src: string; dimensions: { width: number; height: number } }\n className?: string\n}\n\nfunction loadImage(src: string): Promise<HTMLImageElement> {\n return new Promise<HTMLImageElement>((resolve, reject) => {\n const image = new Image()\n\n image.onload = () => resolve(image)\n image.onerror = reject\n image.src = src\n })\n}\n\nfunction imageSizes(width?: Props['width']): string {\n const baseDevice = DEVICES.find(device => device.maxWidth == null)\n const baseWidth = baseDevice && width && findDeviceOverride(width, baseDevice.id)\n const baseWidthSize =\n baseWidth == null || baseWidth.value.unit !== 'px' ? '100vw' : `${baseWidth.value.value}px`\n\n return DEVICES.map(device => {\n const override = findDeviceOverride(width, device.id)\n\n if (override == null || device.maxWidth == null || override.value.unit !== 'px') return null\n\n return `(max-width: ${device.maxWidth}px) ${Math.min(device.maxWidth, override.value.value)}px`\n })\n .filter((size): size is NonNullable<typeof size> => size != null)\n .reduce((sourceSizes, sourceSize) => `${sourceSize}, ${sourceSizes}`, baseWidthSize)\n}\n\nconst ImageContainer = styled.div.withConfig({\n shouldForwardProp: prop =>\n !['margin', 'padding', 'border', 'borderRadius', 'boxShadow', 'opacity', 'dimensions'].includes(\n prop.toString(),\n ),\n})<{\n margin?: Props['margin']\n padding?: Props['padding']\n border?: BorderPropControllerData | null | undefined\n borderRadius: Props['borderRadius']\n boxShadow?: BoxShadowPropControllerData | null | undefined\n opacity: Props['opacity']\n link?: Props['link']\n}>`\n line-height: 0;\n overflow: hidden;\n ${cssMargin()}\n ${cssPadding()}\n ${cssBorder()}\n ${cssBorderRadius()}\n ${cssBoxShadow()}\n ${p =>\n cssMediaRules(\n [p.opacity],\n ([opacity = 1]) => css`\n opacity: ${opacity};\n `,\n )}\n`\n\nconst UnoptimizedImage = styled.img`\n width: 100%;\n`\n\ntype Dimensions = {\n width: number\n height: number\n}\n\nconst ImageComponent = forwardRef(function Image(\n {\n id,\n width,\n margin,\n padding,\n file,\n border,\n borderRadius,\n altText,\n link,\n opacity,\n boxShadow,\n placeholder = placeholders.image,\n className,\n }: Props,\n ref: Ref<HTMLImageElement>,\n) {\n const fileData = useFile(file)\n const borderData = useBorder(border)\n const boxShadowData = useBoxShadow(boxShadow)\n const imageSrc = fileData?.publicUrl ? fileData.publicUrl : placeholder.src\n const dataDimensions = fileData?.publicUrl ? fileData?.dimensions : placeholder.dimensions\n const [measuredDimensions, setMeasuredDimensions] = useState<Dimensions | null>(null)\n const isInBuilder = useIsInBuilder()\n\n useEffect(() => {\n if (dataDimensions) return\n\n let cleanedUp = false\n\n loadImage(imageSrc)\n .then(image => {\n if (!cleanedUp) {\n setMeasuredDimensions({ width: image.naturalWidth, height: image.naturalHeight })\n }\n })\n .catch(console.error)\n\n return () => {\n cleanedUp = true\n }\n }, [dataDimensions, imageSrc])\n\n const dimensions = dataDimensions ?? measuredDimensions\n\n if (!dimensions) return null\n\n const widthClass = toClass(responsiveWidth(width, `${dimensions.width}px`))\n\n return (\n <ImageContainer\n as={link ? Link : 'div'}\n link={link}\n ref={ref}\n id={id}\n className={cx(className, widthClass)}\n margin={margin}\n opacity={opacity}\n padding={padding}\n border={borderData}\n borderRadius={borderRadius}\n boxShadow={boxShadowData}\n >\n {isInBuilder ? (\n <UnoptimizedImage src={imageSrc} alt={altText} />\n ) : (\n <NextImage\n layout=\"responsive\"\n src={imageSrc}\n sizes={imageSizes(width)}\n alt={altText}\n width={dimensions.width}\n height={dimensions.height}\n />\n )}\n </ImageContainer>\n )\n})\n\nexport default ImageComponent\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(ImageComponent, {\n type: './components/Image/index.js',\n label: 'Image',\n props: {\n id: Props.ElementID(),\n file: Props.Image(),\n altText: Props.TextInput({ label: 'Alt text' }),\n link: Props.Link({ label: 'On click' }),\n width: Props.Width(),\n margin: Props.Margin(),\n padding: Props.Padding(),\n border: Props.Border(),\n borderRadius: Props.BorderRadius(),\n boxShadow: Props.Shadows(),\n opacity: Props.ResponsiveOpacity(),\n },\n })\n}\n","import { useState, useRef, useEffect, useCallback, forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { motion, useAnimation } from 'framer-motion'\nimport { useGesture } from 'react-use-gesture'\nimport { wrap } from '@popmotion/popcorn'\nimport uuid from 'uuid/v4'\nimport { cx } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { useMediaQuery } from '../../hooks'\n\nimport Image from '../Image'\nimport {\n ResponsiveValue,\n ElementIDValue,\n ImagesValue,\n MarginValue,\n ResponsiveNumberValue,\n ResponsiveIconRadioGroupValue,\n GapXValue,\n CheckboxValue,\n NumberValue,\n BorderValue,\n BorderRadiusValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\n\nconst LeftChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M7,13,1,7,7,1\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\nconst RightChevron = () => (\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"10\" height=\"14\" viewBox=\"0 0 10 14\">\n <path\n d=\"M3,1,9,7,3,13\"\n fill=\"none\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n strokeWidth=\"2\"\n />\n </svg>\n)\n\n// NOTE: We set height to 100% here to fix an issue on IE11 where the child height of a flex column extends too far\nconst Container = styled.div`\n position: relative;\n height: 100%;\n`\n\ntype Props = {\n id?: ElementIDValue\n images?: ImagesValue\n width?: string\n margin?: MarginValue\n pageSize?: ResponsiveNumberValue\n step?: ResponsiveNumberValue\n slideAlignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gap?: GapXValue\n autoplay?: CheckboxValue\n delay?: NumberValue\n showArrows?: CheckboxValue\n arrowPosition?: ResponsiveIconRadioGroupValue<'inside' | 'center' | 'outside'>\n arrowColor?: ResponsiveColor | null\n arrowBackground?: ResponsiveColor | null\n showDots?: CheckboxValue\n dotColor?: ResponsiveColor | null\n slideBorder?: BorderValue\n slideBorderRadius?: BorderRadiusValue\n}\n\nconst Wrapper = styled.div.withConfig({\n shouldForwardProp: prop => !['margin'].includes(prop),\n})<{ margin: Props['margin'] }>`\n position: relative;\n display: flex;\n flex-direction: column;\n ${cssMargin()}\n\n &:focus {\n outline: 0;\n }\n`\n\nconst Arrow = styled.div.withConfig({\n shouldForwardProp: prop => !['background'].includes(prop),\n})<{ background?: ResponsiveValue<Color> | null }>`\n padding: 10px;\n border-radius: 50%;\n outline: 0;\n border: 0;\n width: 40px;\n height: 40px;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n user-select: none;\n ${p =>\n cssMediaRules(\n [p.background] as const,\n ([background = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 }]) => css`\n background: ${colorToString(background)};\n `,\n )}\n\n svg {\n transition: transform 0.15s;\n stroke: currentColor;\n }\n`\n\nconst Slop = styled.div.withConfig({\n shouldForwardProp: prop => !['color'].includes(prop),\n})<{\n color?: ResponsiveValue<Color> | null\n}>`\n position: absolute;\n top: 0;\n bottom: 0;\n display: ${props => (props.hidden ? 'none' : 'flex')};\n align-items: center;\n cursor: pointer;\n z-index: 2;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Slide = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['pageSize', 'alignItems'].includes(prop),\n})<{\n pageSize: Props['pageSize']\n alignItems: Props['slideAlignment']\n}>`\n display: flex;\n ${p =>\n cssMediaRules(\n [p.pageSize],\n ([pageSize = 1]) => css`\n flex-basis: ${100 / pageSize}%;\n max-width: ${100 / pageSize}%;\n min-width: ${100 / pageSize}%;\n `,\n )}\n\n ${p => cssMediaRules([p.alignItems], ([alignItems = 'center']) => ({ alignItems }))}\n`\n\nconst Reel = styled(motion.div).withConfig({\n shouldForwardProp: prop => !['gap'].includes(prop),\n})<{ gap: Props['gap'] }>`\n display: flex;\n position: relative;\n flex-wrap: nowrap;\n ${p =>\n cssMediaRules(\n [p.gap] as const,\n ([gap = { value: 0, unit: 'px' }]) => css`\n margin: 0 ${`${-gap.value / 2}${gap.unit}`};\n\n & > ${Slide} {\n padding: 0 ${`${gap.value / 2}${gap.unit}`};\n }\n `,\n )}\n`\n\nconst Page = styled(motion.div)`\n position: relative;\n width: 100%;\n`\n\nconst LeftSlop = styled(Slop).withConfig({\n shouldForwardProp: prop => !['position'].includes(prop),\n})<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(-100% - 8px));\n `\n default:\n return css`\n transform: translateX(calc(-50%));\n `\n }\n })}\n left: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(-2px);\n }\n }\n`\n\nconst RightSlop = styled(Slop).withConfig({\n shouldForwardProp: prop => !['position'].includes(prop),\n})<{ position: Props['arrowPosition'] }>`\n ${p =>\n cssMediaRules([p.position] as const, ([position = 'inside']) => {\n switch (position) {\n case 'inside':\n return css`\n transform: translateX(-8px);\n `\n case 'outside':\n return css`\n transform: translateX(calc(100% + 8px));\n `\n default:\n return css`\n transform: translateX(calc(50%));\n `\n }\n })}\n right: 0;\n\n &:hover > ${Arrow} {\n & > svg {\n transform: translateX(2px);\n }\n }\n`\n\nconst ClipMask = styled.div`\n overflow: hidden;\n`\n\nconst Dots = styled.div.withConfig({\n shouldForwardProp: prop => !['color'].includes(prop),\n})<{ color?: ResponsiveValue<Color> | null }>`\n display: ${props => (props.hidden ? 'none' : 'flex')};\n justify-content: center;\n margin-top: 20px;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n color: ${colorToString(color)};\n `,\n )}\n`\n\nconst Dot = styled.div.withConfig({\n shouldForwardProp: prop => !['active'].includes(prop),\n})<{ active: boolean }>`\n position: relative;\n margin: 0 6px;\n border-radius: 50%;\n cursor: pointer;\n width: 16px;\n height: 16px;\n\n &::before,\n &::after {\n content: '';\n position: absolute;\n top: 50%;\n left: 50%;\n display: block;\n border-radius: 50%;\n transition: all 0.15s cubic-bezier(0.175, 0.885, 0.32, 1.275);\n }\n\n &::before {\n box-shadow: 0 0 0 2px currentColor;\n transform: translate3d(-50%, -50%, 0);\n width: ${props => (props.active ? 16 : 10)}px;\n height: ${props => (props.active ? 16 : 10)}px;\n }\n\n &::after {\n background: currentColor;\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0)});\n width: 10px;\n height: 10px;\n }\n\n &:hover::after {\n transform: translate3d(-50%, -50%, 0) scale(${props => (props.active ? 1 : 0.5)});\n }\n`\n\nconst SWIPE_THRESHOLD = 20\nconst swipePower = (dx: number, velocity: number) => dx * (1 + velocity)\n\nconst Carousel = forwardRef(function Carousel(\n {\n images = [],\n width,\n margin,\n pageSize: responsivePageSize,\n step: responsiveStep,\n gap,\n slideAlignment,\n showDots,\n showArrows,\n arrowPosition,\n arrowColor,\n arrowBackground,\n dotColor,\n autoplay = false,\n delay = 5,\n slideBorder,\n slideBorderRadius,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const [index, setIndex] = useState(0)\n const swipe = useRef(0)\n const startIndex = wrap(0, images.length, index)\n const pageSize = useMediaQuery(responsivePageSize) || 1\n const step = useMediaQuery(responsiveStep) || 1\n const endIndex = startIndex + pageSize\n const pageCount = Math.ceil((images.length - pageSize) / step + 1)\n const pageIndex = Math.ceil(startIndex / step)\n const isFirstPage = pageIndex === 0\n const isLastPage = pageIndex === pageCount - 1\n const paginate = useCallback(\n pageDistance => {\n if (pageDistance === 0) return\n\n const direction = pageDistance / Math.abs(pageDistance)\n const remaining = direction > 0 ? images.slice(endIndex) : images.slice(0, startIndex)\n const distance = direction * Math.min(remaining.length, step * Math.abs(pageDistance))\n\n setIndex(index + distance)\n },\n [images, index, startIndex, endIndex, step],\n )\n // @ts-expect-error: `useAnimation` types expect no arguments.\n const animation = useAnimation({ x: 0, transition: { type: 'spring', stiffness: 100 } })\n const bindPage = useGesture(\n {\n onDrag: ({ movement: [mx], delta: [dx], velocity }) => {\n animation.start({ x: mx })\n swipe.current = swipePower(dx, velocity)\n },\n onDragEnd: () => {\n animation.start({ x: 0 })\n\n if (swipe.current > SWIPE_THRESHOLD) paginate(1)\n else if (swipe.current < -SWIPE_THRESHOLD) paginate(-1)\n },\n },\n {\n drag: {\n axis: 'x',\n bounds: { left: 0, right: 0 },\n rubberband: true,\n },\n },\n )\n\n useEffect(() => {\n if (!autoplay || pageSize !== 0) setIndex(0)\n }, [autoplay, pageSize])\n\n useEffect(() => {\n if (!autoplay) return () => {}\n\n const intervalId = setInterval(() => (isLastPage ? setIndex(0) : paginate(1)), delay * 1000)\n\n return () => clearInterval(intervalId)\n }, [autoplay, delay, paginate, isLastPage])\n\n return (\n <Wrapper\n ref={ref}\n className={cx(width)}\n margin={margin}\n tabIndex={-1}\n onKeyDown={e => {\n switch (e.key) {\n case 'ArrowRight':\n paginate(1)\n break\n case 'ArrowLeft':\n paginate(-1)\n break\n default:\n }\n }}\n >\n <Container>\n <ClipMask>\n <Page {...bindPage()} animate={animation}>\n <Reel\n gap={gap}\n animate={{ x: `${-(100 / pageSize) * startIndex}%` }}\n transition={{\n x: {\n type: 'tween',\n ease: [0.165, 0.84, 0.44, 1],\n duration: 0.5,\n },\n }}\n >\n {images.map(({ props: imageProps, key }) => (\n <Slide\n id={key}\n key={key}\n pageSize={responsivePageSize}\n alignItems={slideAlignment}\n onMouseDown={e => e.preventDefault()}\n onClick={e => {\n if (swipe.current !== 0) e.preventDefault()\n }}\n >\n <Image\n width={[{ deviceId: 'desktop', value: { value: 100, unit: '%' } }]}\n file={imageProps.file}\n altText={imageProps.altText}\n link={imageProps.link}\n border={slideBorder}\n borderRadius={slideBorderRadius}\n />\n </Slide>\n ))}\n </Reel>\n </Page>\n </ClipMask>\n <LeftSlop\n onClick={() => paginate(-1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isFirstPage}\n >\n <Arrow background={arrowBackground}>\n <LeftChevron />\n </Arrow>\n </LeftSlop>\n <RightSlop\n onClick={() => paginate(1)}\n position={arrowPosition}\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop\n color={arrowColor}\n hidden={!showArrows || isLastPage}\n >\n <Arrow background={arrowBackground}>\n <RightChevron />\n </Arrow>\n </RightSlop>\n </Container>\n {/* @ts-expect-error: HTMLDivElement attributes conflicts with `color` prop */}\n <Dots color={dotColor} hidden={!showDots}>\n {Array.from({ length: pageCount }).map((_, i) => (\n <Dot key={i} active={i === pageIndex} onClick={() => paginate(i - pageIndex)} />\n ))}\n </Dots>\n </Wrapper>\n )\n})\n\nexport default Carousel\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Carousel, {\n type: './components/Carousel/index.js',\n label: 'Carousel',\n icon: 'Carousel40',\n props: {\n id: Props.ElementID(),\n images: Props.Images({\n preset: [\n { key: uuid(), props: {} },\n { key: uuid(), props: {} },\n { key: uuid(), props: {} },\n ],\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 400, unit: 'px' },\n }),\n margin: Props.Margin(),\n pageSize: Props.ResponsiveNumber(props => {\n const images = props.images as unknown[]\n const imagesLength = images?.length ?? 0\n\n return {\n label: 'Images shown',\n defaultValue: 1,\n min: 1,\n max: imagesLength,\n step: 1,\n }\n }),\n step: Props.ResponsiveNumber((props, device) => {\n const pageSize = props.pageSize as ResponsiveValue<number>\n const pageSizeValue = findDeviceOverride(pageSize, device)?.value ?? 1\n\n return {\n label: 'Step',\n defaultValue: 1,\n min: 1,\n max: pageSizeValue,\n step: 1,\n }\n }),\n slideAlignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'Top', value: 'flex-start', icon: 'VerticalAlignStart16' },\n { label: 'Middle', value: 'center', icon: 'VerticalAlignMiddle16' },\n { label: 'Bottom', value: 'flex-end', icon: 'VerticalAlignEnd16' },\n ],\n defaultValue: 'center',\n }),\n gap: Props.GapX({\n label: 'Gap',\n step: 5,\n defaultValue: { value: 0, unit: 'px' },\n }),\n autoplay: Props.Checkbox({ label: 'Autoplay' }),\n delay: Props.Number(props => ({\n label: 'Delay',\n preset: 5,\n min: 1,\n step: 0.1,\n suffix: 'seconds',\n hidden: !props.autoplay,\n })),\n showArrows: Props.Checkbox({ preset: true, label: 'Show arrows' }),\n arrowPosition: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Arrow position',\n options: [\n { label: 'Inside', value: 'inside', icon: 'ArrowInside16' },\n { label: 'Center', value: 'center', icon: 'ArrowCenter16' },\n { label: 'Outside', value: 'outside', icon: 'ArrowOutside16' },\n ],\n defaultValue: 'inside',\n hidden: props.showArrows === false,\n })),\n arrowColor: Props.ResponsiveColor(props => ({\n label: 'Arrow color',\n placeholder: 'black',\n hidden: props.showArrows === false,\n })),\n arrowBackground: Props.ResponsiveColor(props => ({\n label: 'Arrow background',\n placeholder: 'white',\n hidden: props.showArrows === false,\n })),\n showDots: Props.Checkbox({ preset: true, label: 'Show dots' }),\n dotColor: Props.ResponsiveColor(props => ({\n label: 'Dot color',\n placeholder: 'black',\n hidden: props.showDots === false,\n })),\n slideBorder: Props.Border(),\n slideBorderRadius: Props.BorderRadius(),\n },\n })\n}\n","import { useState, useEffect, Ref, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n DateValue,\n ElementIDValue,\n FontValue,\n GapXValue,\n MarginValue,\n ResponsiveIconRadioGroupValue,\n TextInputValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype Props = {\n id?: ElementIDValue\n date?: DateValue\n variant?: ResponsiveIconRadioGroupValue<\n 'filled' | 'filled-split' | 'outline' | 'outline-split' | 'clear'\n >\n shape?: ResponsiveIconRadioGroupValue<'pill' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n gap?: GapXValue\n numberFont?: FontValue\n numberColor?: ResponsiveColor | null\n blockColor?: ResponsiveColor | null\n labelFont?: FontValue\n labelColor?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n daysLabel?: TextInputValue\n hoursLabel?: TextInputValue\n minutesLabel?: TextInputValue\n secondsLabel?: TextInputValue\n}\n\nconst Block = styled.div`\n display: block;\n padding: 0.5em;\n font-size: 1em;\n`\n\nconst Label = styled.div`\n margin-top: 0.25em;\n`\n\nconst Segment = styled.div`\n flex: 1;\n text-align: center;\n`\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop =>\n ![\n 'margin',\n 'variant',\n 'size',\n 'shape',\n 'gap',\n 'labelColor',\n 'numberFont',\n 'numberColor',\n 'blockColor',\n 'labelFont',\n ].includes(prop),\n})<{\n margin: Props['margin']\n variant: Props['variant']\n size: Props['size']\n shape: Props['shape']\n gap: Props['gap']\n labelColor?: ResponsiveValue<Color> | null\n numberFont?: ResponsiveValue<string>\n numberColor?: ResponsiveValue<Color> | null\n blockColor?: ResponsiveValue<Color> | null\n labelFont?: ResponsiveValue<string>\n}>`\n display: flex;\n ${cssMargin()}\n ${p =>\n cssMediaRules([p.size] as const, ([size = 'medium']) => {\n switch (size) {\n case 'small':\n return css`\n font-size: 18px;\n\n ${Label} {\n font-size: 14px;\n }\n `\n case 'large':\n return css`\n font-size: 32px;\n\n ${Label} {\n font-size: 18px;\n }\n `\n default:\n return css`\n font-size: 24px;\n\n ${Label} {\n font-size: 16px;\n }\n `\n }\n })}\n\n ${Segment} {\n ${p =>\n cssMediaRules(\n [p.gap] as const,\n ([gap]) => css`\n margin: 0 ${gap == null ? 0 : `${gap.value / 2}${gap.unit}`};\n\n &:first-child {\n margin-left: 0;\n }\n\n &:last-child {\n margin-right: 0;\n }\n `,\n )}\n }\n\n ${Block} {\n ${p =>\n cssMediaRules([p.shape] as const, ([shape = 'rounded']) => {\n switch (shape) {\n case 'pill':\n return css`\n border-radius: 500px;\n `\n case 'rounded':\n return css`\n border-radius: 6px;\n `\n default:\n return css`\n border-radius: 0;\n `\n }\n })}\n ${p =>\n cssMediaRules(\n [p.variant, p.blockColor, p.numberColor, p.numberFont] as const,\n ([\n variant = 'filled',\n blockColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n numberColor = { swatch: { hue: 0, saturation: 0, lightness: 100 }, alpha: 1 },\n numberFont = 'sans-serif',\n ]) => {\n switch (variant) {\n case 'filled':\n return css`\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n background: ${colorToString(blockColor)};\n `\n case 'filled-split':\n return css`\n position: relative;\n color: ${colorToString(numberColor)};\n font-family: '${numberFont}';\n\n > span {\n position: relative;\n z-index: 1;\n }\n\n ::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: calc(50% + 1px);\n border-top-left-radius: inherit;\n border-top-right-radius: inherit;\n background: ${colorToString(blockColor)};\n }\n\n ::after {\n content: '';\n position: absolute;\n left: 0;\n right: 0;\n top: calc(50% + 1px);\n bottom: 0;\n border-bottom-left-radius: inherit;\n border-bottom-right-radius: inherit;\n background: ${colorToString(blockColor)};\n }\n `\n case 'outline':\n return css`\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n background: transparent;\n border: 2px solid ${colorToString(blockColor)};\n `\n case 'outline-split':\n return css`\n position: relative;\n font-family: '${numberFont}';\n color: ${colorToString(numberColor)};\n border: 2px solid ${colorToString(blockColor)};\n\n > span {\n position: relative;\n z-index: 1;\n }\n\n ::before {\n content: '';\n position: absolute;\n top: 50%;\n left: 0;\n right: 0;\n height: 2px;\n margin-top: -1px;\n background: ${colorToString(blockColor)};\n }\n `\n default:\n return css`\n font-family: '${numberFont}';\n background: transparent;\n color: ${colorToString(numberColor)};\n padding-top: 0;\n padding-bottom: 0;\n `\n }\n },\n )}\n }\n\n ${Label} {\n ${p =>\n cssMediaRules(\n [p.labelColor, p.labelFont] as const,\n ([\n labelColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n labelFont = 'sans-serif',\n ]) => css`\n font-family: '${labelFont}';\n color: ${colorToString(labelColor)};\n `,\n )}\n }\n`\n\nconst getRemaining = (date: Props['date'] | undefined) => {\n if (date == null) return { days: 0, hours: 0, minutes: 0, seconds: 0 }\n\n const timeDiff = new Date(date).getTime() - Date.now()\n\n if (timeDiff <= 0) return { days: 0, hours: 0, minutes: 0, seconds: 0 }\n\n let delta = Math.abs(timeDiff) / 1000\n\n const days = Math.floor(delta / 86400)\n delta -= days * 86400\n\n const hours = Math.floor(delta / 3600) % 24\n delta -= hours * 3600\n\n const minutes = Math.floor(delta / 60) % 60\n delta -= minutes * 60\n\n const seconds = parseInt(String(delta % 60), 10)\n\n return { days, hours, minutes, seconds }\n}\n\nconst Countdown = forwardRef(function Countdown(\n {\n id,\n margin,\n width,\n date,\n variant,\n size,\n shape,\n gap,\n labelColor,\n labelFont,\n numberColor,\n numberFont,\n blockColor,\n daysLabel,\n hoursLabel,\n minutesLabel,\n secondsLabel,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const [{ days, hours, minutes, seconds }, setRemaining] = useState(getRemaining(date))\n\n useEffect(() => {\n setRemaining(getRemaining(date))\n\n const intervalId = setInterval(() => {\n setRemaining(getRemaining(date))\n }, 1000)\n\n return () => clearInterval(intervalId)\n }, [date])\n\n return (\n <Container\n ref={ref}\n id={id}\n className={cx(width)}\n margin={margin}\n variant={variant}\n size={size}\n shape={shape}\n labelColor={labelColor}\n labelFont={labelFont}\n numberColor={numberColor}\n numberFont={numberFont}\n blockColor={blockColor}\n gap={gap}\n >\n <Segment>\n <Block>\n <span>{days}</span>\n </Block>\n <Label>{daysLabel == null ? 'Days' : daysLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{hours}</span>\n </Block>\n <Label>{hoursLabel == null ? 'Hours' : hoursLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{minutes}</span>\n </Block>\n <Label>{minutesLabel == null ? 'Minutes' : minutesLabel}</Label>\n </Segment>\n <Segment>\n <Block>\n <span>{seconds}</span>\n </Block>\n <Label>{secondsLabel == null ? 'Seconds' : secondsLabel}</Label>\n </Segment>\n </Container>\n )\n})\n\nexport default Countdown\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Countdown, {\n type: './components/Countdown/index.js',\n label: 'Countdown',\n icon: 'Countdown40',\n props: {\n id: Props.ElementID(),\n date: Props.Date(() => ({\n preset: new Date(Date.now() + 1000 * 60 * 60 * 24 * 2).toISOString(),\n })),\n variant: Props.ResponsiveIconRadioGroup({\n label: 'Style',\n options: [\n { label: 'Filled', value: 'filled', icon: 'CountdownSolid16' },\n {\n label: 'Filled split',\n value: 'filled-split',\n icon: 'CountdownSolidSplit16',\n },\n { label: 'Outline', value: 'outline', icon: 'CountdownOutline16' },\n {\n label: 'Outline split',\n value: 'outline-split',\n icon: 'CountdownOutlineSplit16',\n },\n { label: 'Clear', value: 'clear', icon: 'CountdownNaked16' },\n ],\n defaultValue: 'filled',\n }),\n shape: Props.ResponsiveIconRadioGroup({\n label: 'Shape',\n options: [\n { label: 'Pill', value: 'pill', icon: 'ButtonPill16' },\n { label: 'Rounded', value: 'rounded', icon: 'ButtonRounded16' },\n { label: 'Square', value: 'square', icon: 'ButtonSquare16' },\n ],\n defaultValue: 'rounded',\n }),\n size: Props.ResponsiveIconRadioGroup({\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n }),\n gap: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Gap',\n step: 1,\n min: 0,\n max: 100,\n defaultValue: { value: 0, unit: 'px' },\n }),\n numberFont: Props.Font({ label: 'Number font' }),\n numberColor: Props.ResponsiveColor({\n label: 'Number color',\n placeholder: 'white',\n }),\n blockColor: Props.ResponsiveColor({\n label: 'Block color',\n placeholder: 'black',\n }),\n labelFont: Props.Font({ label: 'Label font' }),\n labelColor: Props.ResponsiveColor({\n label: 'Label color',\n placeholder: 'black',\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 560, unit: 'px' },\n }),\n margin: Props.Margin(),\n daysLabel: Props.TextInput({ label: 'Days label', placeholder: 'Days' }),\n hoursLabel: Props.TextInput({ label: 'Hours label', placeholder: 'Hours' }),\n minutesLabel: Props.TextInput({\n label: 'Minutes label',\n placeholder: 'Minutes',\n }),\n secondsLabel: Props.TextInput({\n label: 'Seconds label',\n placeholder: 'Seconds',\n }),\n },\n })\n}\n","import { forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n MarginValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n} from '../../../prop-controllers/descriptors'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype DividerVariant = 'solid' | 'dashed' | 'dotted' | 'blended'\n\ntype Props = {\n id?: ElementIDValue\n variant?: ResponsiveSelectValue<DividerVariant>\n thickness?: ResponsiveLengthValue\n color?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n}\n\n// IE11 has a bug with Flexbox vertical centering with min height if height is not set.\n// Wrapping it in another flex container fixes it for some reason, read more here:\n// https://stackoverflow.com/questions/19371626/flexbox-not-centering-vertically-in-ie\nconst IE11MinHeightContainer = styled.div.withConfig({\n shouldForwardProp: prop => !['margin'].includes(prop),\n})<{ margin: Props['margin'] }>`\n display: flex;\n width: 100%;\n ${cssMargin()}\n`\n\nconst Container = styled.div`\n display: flex;\n flex-direction: column;\n justify-content: center;\n min-height: 40px;\n width: 100%;\n`\n\nconst Line = styled.div.withConfig({\n shouldForwardProp: prop => !['variant', 'color', 'thickness'].includes(prop),\n})<{\n variant: Props['variant']\n color?: ResponsiveValue<Color> | null\n thickness: Props['thickness']\n}>`\n ${p =>\n cssMediaRules(\n [p.variant, p.thickness, p.color] as const,\n ([\n variant = 'solid',\n thickness = { value: 1, unit: 'px' },\n color = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => {\n switch (variant) {\n case 'solid':\n case 'dashed':\n case 'dotted':\n return css`\n border-bottom-width: ${thickness == null\n ? '1px'\n : `${thickness.value}${thickness.unit}`};\n border-bottom-style: ${variant};\n border-bottom-color: ${colorToString(color)};\n `\n\n case 'blended':\n return css`\n height: ${`${thickness.value}${thickness.unit}`};\n background: linear-gradient(\n ${[\n '90deg',\n colorToString({ swatch: color.swatch, alpha: 0 }),\n colorToString(color),\n colorToString({ swatch: color.swatch, alpha: 0 }),\n ].join(', ')}\n );\n `\n\n default:\n variant as never\n throw new Error(`Invalid variant ${variant}.`)\n }\n },\n )}\n`\n\nconst Divider = forwardRef(function Divider(\n { id, variant, thickness, color, width, margin }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <IE11MinHeightContainer ref={ref} id={id} className={cx(width)} margin={margin}>\n <Container>\n {/* @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop */}\n <Line variant={variant} thickness={thickness} color={color} />\n </Container>\n </IE11MinHeightContainer>\n )\n})\n\nexport default Divider\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Divider, {\n type: './components/Divider/index.js',\n label: 'Divider',\n icon: 'Divider40',\n props: {\n id: Props.ElementID(),\n variant: Props.ResponsiveSelect({\n label: 'Style',\n labelOrientation: 'horizontal',\n options: [\n { value: 'solid', label: 'Solid' },\n { value: 'dashed', label: 'Dashed' },\n { value: 'dotted', label: 'Dotted' },\n { value: 'blended', label: 'Blended' },\n ],\n defaultValue: 'solid',\n }),\n thickness: Props.ResponsiveLength({\n label: 'Height',\n defaultValue: { value: 1, unit: 'px' },\n options: [{ value: 'px', label: 'Pixels', icon: 'Px16' }],\n }),\n color: Props.ResponsiveColor({ placeholder: 'black' }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","/* eslint-env browser */\n\nimport { useState, useEffect, forwardRef, Ref, useImperativeHandle } from 'react'\nimport styled from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { cssMargin } from '../../utils/cssMediaRules'\nimport { ElementIDValue, MarginValue, TextAreaValue } from '../../../prop-controllers/descriptors'\nimport { Props } from '../../../prop-controllers'\nimport { ReactRuntime } from '../../../react'\nimport { useIsomorphicLayoutEffect } from '../../hooks/useIsomorphicLayoutEffect'\n\ntype Props = {\n id?: ElementIDValue\n html?: TextAreaValue\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['margin'].includes(prop),\n})<{ margin: Props['margin'] }>`\n min-height: 15px;\n ${cssMargin()}\n`\n\nconst defaultHtml = `<div style=\"padding: 24px; background-color: rgba(161, 168, 194, 0.18); overflow: hidden;\">\n<svg width=\"316\" height=\"168\" viewBox=\"0 0 316 168\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<rect width=\"70\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"78\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"116\" width=\"78\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect y=\"20\" width=\"120\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"128\" y=\"20\" width=\"30\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"166\" y=\"20\" width=\"78\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect y=\"60\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"20\" y=\"80\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"40\" y=\"100\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"88\" y=\"100\" width=\"110\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"206\" y=\"100\" width=\"24\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"238\" y=\"100\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"40\" y=\"120\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"88\" y=\"120\" width=\"50\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"146\" y=\"120\" width=\"24\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"178\" y=\"120\" width=\"90\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.25\"/>\n<rect x=\"276\" y=\"120\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect x=\"20\" y=\"140\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n<rect y=\"160\" width=\"40\" height=\"8\" rx=\"2\" fill=\"#A1A8C2\" fill-opacity=\"0.5\"/>\n</svg>\n</div>`\nconst SCRIPT_TAG = 'script'\n\nconst Embed = forwardRef(function Embed(\n { id, width, margin, html = defaultHtml }: Props,\n ref: Ref<HTMLDivElement | null>,\n) {\n const [container, setContainer] = useState<HTMLDivElement | null>(null)\n const [shouldRender, setShouldRender] = useState(false)\n\n useIsomorphicLayoutEffect(() => {\n setShouldRender(true)\n }, [])\n\n useImperativeHandle(ref, () => container, [container])\n\n useEffect(() => {\n // TODO: When we SSR the editor, we can remove the editor check\n // and not run this effect on the first render.\n if (!container) return\n\n const walker = container.ownerDocument.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {\n acceptNode(node: Element) {\n return node.tagName.toLowerCase() === SCRIPT_TAG\n ? NodeFilter.FILTER_ACCEPT\n : NodeFilter.FILTER_REJECT\n },\n })\n\n const nodes: Element[] = []\n\n while (walker.nextNode()) nodes.push(walker.currentNode as Element)\n\n // By default scripts appended dynamically will execute asyncrhonously. Here we ensure that\n // scripts are loaded synchronously since that's what a user usually expects with scripts in\n // embedded in HTML which usually comes from the server.\n //\n // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/script#notes\n async function executeScriptsInOrder() {\n for (let i = 0; i < nodes.length; i++) {\n await new Promise<void>(resolve => {\n const node = nodes[i]\n const script = node.ownerDocument.createElement(SCRIPT_TAG)\n\n script.textContent = node.textContent\n Array.from(node.attributes).forEach(({ name, value }) => {\n script.setAttribute(name, value)\n })\n\n script.onload = () => resolve()\n script.onerror = () => resolve()\n\n node.parentNode?.insertBefore(script, node)\n node.parentNode?.removeChild(node)\n\n if (!script.hasAttribute('src')) resolve()\n })\n }\n }\n\n executeScriptsInOrder().catch(error => {\n // Ignore errors from user-provided code\n console.error(error)\n })\n }, [container, html])\n\n if (shouldRender === false) return null\n\n return (\n <Container\n ref={setContainer}\n id={id}\n className={cx(width)}\n margin={margin}\n dangerouslySetInnerHTML={{ __html: html }}\n />\n )\n})\n\nexport default Embed\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Embed, {\n type: './components/Embed/index.js',\n label: 'Embed',\n icon: 'Code40',\n props: {\n id: Props.ElementID(),\n html: Props.TextArea({ label: 'Code', rows: 20 }),\n width: Props.Width({ format: Props.Width.Formats.ClassName }),\n margin: Props.Margin(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHZpZXdCb3g9IjAgMCAxMiAxMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMS43MDcxIDEuNzkyODlDMTIuMDk3NiAyLjE4MzQyIDEyLjA5NzYgMi44MTY1OCAxMS43MDcxIDMuMjA3MTFMNC43MDcxMSAxMC4yMDcxQzQuMzE2NTggMTAuNTk3NiAzLjY4MzQyIDEwLjU5NzYgMy4yOTI4OSAxMC4yMDcxTDAuMjkyODkzIDcuMjA3MTFDLTAuMDk3NjMxMSA2LjgxNjU4IC0wLjA5NzYzMTEgNi4xODM0MiAwLjI5Mjg5MyA1Ljc5Mjg5QzAuNjgzNDE3IDUuNDAyMzcgMS4zMTY1OCA1LjQwMjM3IDEuNzA3MTEgNS43OTI4OUw0IDguMDg1NzlMMTAuMjkyOSAxLjc5Mjg5QzEwLjY4MzQgMS40MDIzNyAxMS4zMTY2IDEuNDAyMzcgMTEuNzA3MSAxLjc5Mjg5WiIvPgo8L3N2Zz4K\"","import { createContext, useContext } from 'react'\n\nimport { ResponsiveValue, TextStyleValue } from '../../../../prop-controllers/descriptors'\nimport { ResponsiveColor } from '../../../../runtimes/react/controls'\nimport { ColorValue } from '../../../utils/types'\n\nexport const Shapes = Object.freeze({\n SQUARE: 'square',\n ROUNDED: 'rounded',\n PILL: 'pill',\n} as const)\n\nexport type Shape = typeof Shapes[keyof typeof Shapes]\n\nexport const Sizes = Object.freeze({\n SMALL: 'small',\n MEDIUM: 'medium',\n LARGE: 'large',\n} as const)\n\nexport type Size = typeof Sizes[keyof typeof Sizes]\n\nexport const Contrasts = Object.freeze({\n LIGHT: 'light',\n DARK: 'dark',\n} as const)\n\nexport type Contrast = typeof Contrasts[keyof typeof Contrasts]\n\nexport type Value = {\n shape: ResponsiveValue<Shape> | null | undefined\n size: ResponsiveValue<Size> | null | undefined\n contrast: ResponsiveValue<Contrast> | null | undefined\n brandColor: ResponsiveValue<ColorValue> | null | undefined\n labelTextStyle?: TextStyleValue\n labelTextColor?: ResponsiveColor | null\n}\n\nconst Context = createContext<Value>({} as Value)\n\nexport function useFormContext(): Value {\n return useContext(Context)\n}\n\nconst { Provider } = Context\n\nexport { Provider }\n","import { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../utils/colorToString'\n\nimport {\n Size,\n Shape,\n Contrast,\n Shapes,\n Sizes,\n Contrasts,\n Value,\n} from '../../../context/FormContext'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 30\n\n case Sizes.MEDIUM:\n return 38\n\n case Sizes.LARGE:\n return 48\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport function getSizeHorizontalPadding(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 8\n\n case Sizes.MEDIUM:\n return 12\n\n case Sizes.LARGE:\n return 16\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nfunction getSizeVerticalPadding(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 3\n\n case Sizes.MEDIUM:\n return 7\n\n case Sizes.LARGE:\n return 11\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport function getShapeBorderRadius(shape: Shape): number {\n switch (shape) {\n case Shapes.SQUARE:\n return 0\n\n case Shapes.ROUNDED:\n return 4\n\n case Shapes.PILL:\n return 500\n\n default:\n throw new Error(`Invalid form shape \"${shape}\"`)\n }\n}\n\nexport function getContrastBorderColor(contrast: Contrast, error?: boolean): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return error ? 'rgba(255, 0, 0, 0.7)' : 'rgba(0, 0, 0, 0.25)'\n\n case Contrasts.DARK:\n return error ? 'rgba(255, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.6)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport function getContrastBackgroundColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'white'\n\n case Contrasts.DARK:\n return 'rgba(0, 0, 0, 0.7)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport function getContrastColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.95)'\n\n case Contrasts.DARK:\n return 'white'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nfunction getContrastPlaceholderColor(contrast: Contrast) {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.3)'\n\n case Contrasts.DARK:\n return 'rgba(255,255,255,0.3)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nexport default function cssField() {\n return css<Pick<Value, 'shape' | 'size' | 'contrast' | 'brandColor'> & { error?: boolean }>`\n display: block;\n width: 100%;\n outline: none;\n border-width: 1px;\n border-style: solid;\n transition: border-color 200ms;\n ${props =>\n cssMediaRules(\n [props.shape, props.size, props.contrast, props.brandColor] as const,\n ([\n shape = Shapes.ROUNDED,\n size = Sizes.MEDIUM,\n contrast = Contrasts.LIGHT,\n brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 },\n ]) => css`\n padding: ${getSizeVerticalPadding(size)}px ${getSizeHorizontalPadding(size)}px;\n border-radius: ${getShapeBorderRadius(shape)}px;\n border-color: ${getContrastBorderColor(contrast, props.error)};\n color: ${getContrastColor(contrast)};\n background-color: ${getContrastBackgroundColor(contrast)};\n\n :focus,\n :focus-within {\n border-color: ${colorToString(brandColor)};\n }\n\n ::placeholder {\n color: ${getContrastPlaceholderColor(contrast)};\n }\n `,\n )}\n `\n}\n","import { ComponentPropsWithoutRef, forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { Size, useFormContext, Sizes, Value } from '../../../../context/FormContext'\nimport cssField from '../../services/cssField'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 36\n\n case Sizes.MEDIUM:\n return 42\n\n case Sizes.LARGE:\n return 48\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nconst Base = styled.input.withConfig({\n shouldForwardProp: (prop, defaultValidator) =>\n !['shape', 'size', 'contrast', 'brandColor', 'error'].includes(prop.toString()) &&\n defaultValidator(prop),\n})<Pick<Value, 'shape' | 'size' | 'contrast' | 'brandColor'> & { error?: boolean }>`\n ${cssField()}\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n min-height: ${getSizeHeight(size)}px;\n max-height: ${getSizeHeight(size)}px;\n `,\n )}\n`\n\ntype BaseProps = { error?: boolean; form?: unknown }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Base>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function Input(\n { error = false, form, ...restOfProps }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <Base\n {...restOfProps}\n ref={ref}\n error={error}\n shape={shape}\n // @ts-expect-error: HTMLInputEleent `size` attribute conflicts with prop\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n )\n})\n","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\n\nimport { MarginValue, WidthValue } from '../../../../../prop-controllers/descriptors'\nimport { cssMargin } from '../../../../utils/cssMediaRules'\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['width', 'margin'].includes(prop.toString()),\n})<{\n width?: WidthValue\n margin?: MarginValue\n}>`\n display: flex;\n flex-direction: column;\n ${cssMargin()};\n`\n\nconst Label = styled.div`\n max-width: 120px;\n min-width: 60px;\n height: 8px;\n border-radius: 2px;\n background-color: #a1a8c2;\n opacity: 0.4;\n margin-bottom: 8px;\n`\n\nconst Input = styled.div`\n min-width: 80px;\n height: 32px;\n border-radius: 4px;\n border-width: 2px;\n border-style: solid;\n border-color: #a1a8c2;\n opacity: 0.4;\n`\n\nconst Button = styled.div`\n min-width: 140px;\n height: 32px;\n border-radius: 4px;\n background-color: #a1a8c2;\n opacity: 0.4;\n`\n\ntype Props = {\n className?: string\n margin?: MarginValue\n}\n\nexport default forwardRef(function Placeholder(\n { className, margin }: Props,\n ref: Ref<HTMLDivElement>,\n): JSX.Element {\n return (\n <Container ref={ref} className={className} margin={margin}>\n <div style={{ display: 'flex', flexDirection: 'column', marginBottom: 16 }}>\n <Label />\n <Input />\n </div>\n <div style={{ display: 'flex', flexDirection: 'column', marginBottom: 16 }}>\n <Label />\n <Input />\n </div>\n <div style={{ display: 'flex', flexDirection: 'column', justifyContent: 'flex-end' }}>\n <Button />\n </div>\n </Container>\n )\n})\n","import { ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport { ResponsiveValue } from '../../../../../../../prop-controllers'\nimport { TextStyleValue } from '../../../../../../../prop-controllers/descriptors'\nimport { cssMediaRules, cssTextStyle } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\n\nimport { useFormContext, Size, Sizes, Contrast, Contrasts } from '../../../../context/FormContext'\nimport { ColorValue } from '../../../../../../utils/types'\n\nexport function getSizeHeight(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 14\n\n case Sizes.MEDIUM:\n return 18\n\n case Sizes.LARGE:\n return 22\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nfunction getContrastColor(contrast: Contrast): string {\n switch (contrast) {\n case Contrasts.LIGHT:\n return 'rgba(0, 0, 0, 0.8)'\n\n case Contrasts.DARK:\n return 'rgba(255, 255, 255, 0.95)'\n\n default:\n throw new Error(`Invalid form contrast \"${contrast}\"`)\n }\n}\n\nconst Base = styled.label.withConfig({\n shouldForwardProp: (prop, defaultValidator) =>\n !['contrast', 'size', 'textStyle', 'textColor'].includes(prop.toString()) &&\n defaultValidator(prop),\n})<{\n contrast?: ResponsiveValue<Contrast> | null | undefined\n size?: ResponsiveValue<Size> | null | undefined\n textStyle?: TextStyleValue | null | undefined\n textColor?: ResponsiveValue<ColorValue> | null | undefined\n}>`\n display: block;\n margin: 0 0 0.25em 0;\n ${cssTextStyle()}\n ${props =>\n cssMediaRules(\n [props.size, props.contrast, props.textColor] as const,\n ([size = Sizes.MEDIUM, contrast = Contrasts.LIGHT, textColor]) => css`\n min-height: ${getSizeHeight(size)}px;\n color: ${textColor == null ? getContrastColor(contrast) : colorToString(textColor)};\n `,\n )}\n`\n\ntype Props = ComponentPropsWithoutRef<typeof Base>\n\nexport default function Label(props: Props): JSX.Element {\n const { contrast, size, labelTextStyle, labelTextColor } = useFormContext()\n\n return (\n <Base\n {...props}\n contrast={contrast}\n size={size}\n textStyle={labelTextStyle}\n textColor={labelTextColor}\n />\n )\n}\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function SingleLineTextTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"text\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef, ComponentPropsWithoutRef } from 'react'\nimport styled from 'styled-components'\n\nimport cssField from '../../services/cssField'\nimport { Value, useFormContext } from '../../../../context/FormContext'\n\nconst Base = styled.textarea.withConfig({\n shouldForwardProp: (prop, defaultValidator) =>\n !['error', 'shape', 'size', 'contrast', 'brandColor'].includes(prop.toString()) &&\n defaultValidator(prop),\n})<Value & { error?: boolean }>`\n resize: vertical;\n ${cssField()}\n`\n\ntype BaseProps = { error?: boolean; form?: unknown }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Base>, keyof BaseProps>\n\nexport default forwardRef<HTMLTextAreaElement, Props>(function TextArea(\n { error = false, form, ...restOfProps }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <Base\n {...restOfProps}\n ref={ref}\n rows={4}\n error={error}\n shape={shape}\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport TextArea from '../TextArea'\n\ntype Props = {\n id: string\n label?: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLTextAreaElement, Props>(function LongTextTableField(\n { id, label = '', error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <TextArea {...restOfProps} aria-label={label} ref={ref} id={id} error={error != null} />\n </>\n )\n})\n","import { forwardRef, CSSProperties, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport Color from 'color'\n\nimport { getSizeHeight as getSize } from '../Label'\nimport {\n useFormContext,\n Value as FormContextValue,\n Sizes,\n Contrasts,\n} from '../../../../context/FormContext'\nimport { getContrastBorderColor, getContrastBackgroundColor } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { SwatchValue } from '../../../../../../utils/types'\n\nfunction getCheckmarkColor({\n swatch: { hue: h, saturation: s, lightness: l },\n alpha: a,\n}: {\n swatch: SwatchValue\n alpha: number\n}) {\n return Color({ h, s, l }).alpha(a).isLight() ? 'rgba(0, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.95)'\n}\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['size'].includes(prop),\n})<Pick<FormContextValue, 'size'>>`\n position: relative;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n height: ${getSize(size)}px;\n width: ${getSize(size)}px;\n `,\n )}\n`\n\nconst FakeCheckbox = styled.div.withConfig({\n shouldForwardProp: prop => !['contrast', 'error'].includes(prop),\n})<Pick<FormContextValue, 'contrast'> & { error?: boolean }>`\n position: absolute;\n width: 100%;\n height: 100%;\n border-style: solid;\n border-radius: 4px;\n pointer-events: none;\n border-width: 1px;\n ${props =>\n cssMediaRules(\n [props.contrast] as const,\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n background-color: ${getContrastBackgroundColor(contrast)};\n `,\n )}\n`\n\nconst HiddenCheckbox = styled.input.withConfig({\n shouldForwardProp: (prop, defaultValidator) =>\n !['size', 'brandColor', 'contrast', 'error'].includes(prop) && defaultValidator(prop),\n})<\n Pick<FormContextValue, 'size' | 'brandColor' | 'contrast'> & {\n error?: boolean\n }\n>`\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n\n &:disabled {\n cursor: no-drop;\n\n & ~ ${FakeCheckbox} {\n opacity: 0.5;\n }\n }\n\n &:checked ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([{ swatch = { hue: 0, saturation: 0, lightness: 0 }, alpha = 1 } = {}]) => css`\n background-color: ${colorToString({ swatch, alpha })};\n `,\n )}\n border-color: transparent;\n\n &::after {\n content: '';\n position: absolute;\n box-sizing: content-box;\n width: 25%;\n height: 50%;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n border-width: ${getSize(size) * 0.1}px;\n border-left: 0;\n border-top: 0;\n `,\n )}\n border-style: solid;\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([{ swatch = { hue: 0, saturation: 0, lightness: 0 }, alpha = 1 } = {}]) => css`\n border-color: ${getCheckmarkColor({ swatch, alpha })};\n `,\n )}\n transform: rotate(45deg) translate3d(91%, -23%, 0);\n }\n }\n\n &:not(:disabled) {\n &:focus ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.brandColor],\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n border-color: ${colorToString(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled):checked {\n &:focus ~ ${FakeCheckbox} {\n ${props =>\n cssMediaRules(\n [props.contrast],\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n `,\n )}\n }\n }\n`\n\ntype BaseProps = {\n error?: boolean\n className?: string\n style?: CSSProperties\n form?: unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof HiddenCheckbox>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function Checkbox(\n { error, className, style, form, ...restOfProps }: Props,\n ref,\n) {\n const { size, contrast, brandColor } = useFormContext()\n\n return (\n <Container size={size}>\n <HiddenCheckbox\n {...restOfProps}\n type=\"checkbox\"\n ref={ref}\n error={error}\n // @ts-expect-error: HTMLInputElement `size` attribute conflicts with prop\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n />\n <FakeCheckbox className={className} error={error} contrast={contrast} style={style} />\n </Container>\n )\n})\n","import { forwardRef, SyntheticEvent } from 'react'\nimport styled, { css } from 'styled-components'\nimport { FormikProps } from 'formik'\n\nimport { useFormContext, Sizes, Value } from '../../../../context/FormContext'\nimport Label from '../Label'\nimport { getSizeHeight as getInputSizeHeight } from '../Input'\nimport Checkbox from '../Checkbox'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\n\nconst StyledLabel = styled(Label)<Pick<Value, 'size'>>`\n display: flex;\n align-items: center;\n margin: 0;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n `,\n )}\n`\n\nconst CheckboxContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n form: FormikProps<{\n [key: string]: boolean\n }>\n id: string\n label?: string\n name: string\n value?: boolean\n error?: string\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function CheckboxTableField(\n { form, id, name, label = '', value = false, error, ...restOfProps }: Props,\n ref,\n) {\n const { size } = useFormContext()\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n form.setFieldValue(name, event.currentTarget.checked)\n }\n\n return (\n <StyledLabel htmlFor={id} size={size}>\n <CheckboxContainer>\n <Checkbox\n {...restOfProps}\n aria-label={label}\n checked={value}\n onChange={handleChange}\n ref={ref}\n id={id}\n error={error != null}\n />\n </CheckboxContainer>\n {label}\n </StyledLabel>\n )\n})\n","import { forwardRef, useRef, useImperativeHandle, SyntheticEvent } from 'react'\nimport styled from 'styled-components'\n\nimport Label from '../Label'\nimport Checkbox from '../Checkbox'\n\nconst MainLabel = styled(Label)`\n margin: 0 0 4px 0;\n`\n\nconst StyledLabel = styled(Label)`\n display: flex;\n align-items: center;\n margin: 8px 0;\n\n &:last-of-type {\n margin-bottom: 0;\n }\n`\n\nconst CheckboxContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n value?: Array<string>\n label?: string\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n hideLabel?: boolean\n}\n\nexport default forwardRef<\n {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n },\n Props\n>(function MultipleSelectTableField(\n {\n tableColumn,\n label = '',\n required,\n value = [],\n onChange,\n hideLabel = false,\n ...restOfProps\n }: Props,\n ref,\n) {\n const handle = useRef({\n validity: { valueMissing: required === true && value.length === 0, typeMismatch: false },\n })\n\n useImperativeHandle(ref, () => handle.current, [])\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n handle.current.validity.valueMissing =\n required === true &&\n !event.currentTarget.checked &&\n value.filter(v => v !== event.currentTarget.value).length === 0\n\n onChange(event)\n }\n\n return (\n <div>\n {!hideLabel && <MainLabel>{label}</MainLabel>}\n {tableColumn.options.map(option => (\n <StyledLabel key={option.id} htmlFor={option.id}>\n <CheckboxContainer>\n <Checkbox\n {...restOfProps}\n aria-label={label}\n onChange={handleChange}\n checked={value.includes(option.name)}\n id={option.id}\n value={option.name}\n />\n </CheckboxContainer>\n {option.name}\n </StyledLabel>\n ))}\n </div>\n )\n})\n","import { forwardRef, CSSProperties, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\nimport Color from 'color'\n\nimport { getSizeHeight as getSize } from '../Label'\nimport { useFormContext, Sizes, Contrasts, Value } from '../../../../context/FormContext'\nimport { getContrastBorderColor, getContrastBackgroundColor } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { ColorValue } from '../../../../../../utils/types'\n\nfunction getCheckmarkColor({\n swatch: { hue: h, saturation: s, lightness: l } = { hue: 0, saturation: 0, lightness: 0 },\n alpha: a,\n}: ColorValue) {\n return Color({ h, s, l }).alpha(a).isLight() ? 'rgba(0, 0, 0, 0.7)' : 'rgba(255, 255, 255, 0.95)'\n}\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['size'].includes(prop.toString()),\n})<Pick<Value, 'size'>>`\n position: relative;\n ${props =>\n cssMediaRules(\n [props.size],\n ([size = Sizes.MEDIUM]) => css`\n height: ${getSize(size)}px;\n width: ${getSize(size)}px;\n `,\n )}\n`\n\nconst FakeRadioButton = styled.div.withConfig({\n shouldForwardProp: prop => !['contrast', 'error'].includes(prop.toString()),\n})<Pick<Value, 'contrast'> & { error?: boolean }>`\n position: absolute;\n width: 100%;\n height: 100%;\n border-style: solid;\n border-radius: 50%;\n pointer-events: none;\n border-width: 1px;\n ${props =>\n cssMediaRules(\n [props.contrast],\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n background-color: ${getContrastBackgroundColor(contrast)};\n `,\n )}\n`\n\nconst HiddenRadioButton = styled.input\n .withConfig({\n shouldForwardProp: prop => !['brandColor', 'contrast', 'error'].includes(prop.toString()),\n })\n .attrs({ type: 'radio' })<Pick<Value, 'brandColor' | 'contrast'> & { error?: boolean }>`\n position: absolute;\n opacity: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n\n &:disabled {\n cursor: no-drop;\n\n & ~ ${FakeRadioButton} {\n opacity: 0.5;\n }\n }\n\n &:checked ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n background-color: ${colorToString(brandColor)};\n `,\n )}\n border-color: transparent;\n\n &::after {\n content: '';\n position: absolute;\n box-sizing: content-box;\n top: 50%;\n left: 50%;\n width: 50%;\n height: 50%;\n border-radius: 50%;\n transform: translate(-50%, -50%);\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n background-color: ${getCheckmarkColor(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled) {\n &:focus ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.brandColor] as const,\n ([brandColor = { swatch: { hue: 0, saturation: 0, lightness: 0 }, alpha: 1 }]) => css`\n border-color: ${colorToString(brandColor)};\n `,\n )}\n }\n }\n\n &:not(:disabled):checked {\n &:focus ~ ${FakeRadioButton} {\n ${props =>\n cssMediaRules(\n [props.contrast] as const,\n ([contrast = Contrasts.LIGHT]) => css`\n border-color: ${getContrastBorderColor(contrast, props.error)};\n `,\n )}\n }\n }\n`\n\ntype BaseProps = {\n error?: boolean\n className?: string\n style?: CSSProperties\n form?: unknown\n}\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof HiddenRadioButton>, keyof BaseProps>\n\nexport default forwardRef<HTMLInputElement, Props>(function RadioButton(\n { error, className, style, form, ...restOfProps }: Props,\n ref,\n) {\n const { size, contrast, brandColor } = useFormContext()\n\n return (\n <Container size={size}>\n <HiddenRadioButton\n {...restOfProps}\n ref={ref}\n error={error}\n contrast={contrast}\n brandColor={brandColor}\n />\n <FakeRadioButton className={className} error={error} contrast={contrast} style={style} />\n </Container>\n )\n})\n","import { forwardRef, useRef, useImperativeHandle, SyntheticEvent } from 'react'\nimport styled from 'styled-components'\n\nimport Label from '../../../Label'\nimport RadioButton from '../../../RadioButton'\n\nconst StyledLabel = styled(Label)`\n display: flex;\n align-items: center;\n margin: 8px 0;\n\n &:last-of-type {\n margin-bottom: 0;\n }\n`\n\nconst RadioButtonContainer = styled.span`\n margin-right: 8px;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n label?: string\n value?: string\n hideLabel?: boolean\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n}\n\nexport default forwardRef<\n {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n },\n Props\n>(function TableColumnRadioButtonGroup(\n {\n tableColumn,\n label = '',\n value = '',\n required = false,\n hideLabel = false,\n onChange,\n ...restOfProps\n }: Props,\n ref,\n) {\n const handle = useRef({\n validity: { valueMissing: required === true && value === '', typeMismatch: false },\n })\n\n useImperativeHandle(ref, () => handle.current, [])\n\n function handleChange(event: SyntheticEvent<HTMLInputElement>) {\n handle.current.validity.valueMissing = required === true && !event.currentTarget.checked\n\n onChange(event)\n }\n\n return (\n <div>\n {!hideLabel && <Label as=\"p\">{label}</Label>}\n {tableColumn.options.map(option => (\n <StyledLabel key={option.id} htmlFor={option.id} aria-label={label}>\n <RadioButtonContainer>\n <RadioButton\n {...restOfProps}\n onChange={handleChange}\n checked={value === option.name}\n id={option.id}\n value={option.name}\n />\n </RadioButtonContainer>\n {option.name}\n </StyledLabel>\n ))}\n </div>\n )\n})\n","import { forwardRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../../../utils/cssMediaRules'\nimport { useFormContext, Sizes, Contrasts, Value } from '../../../../../../context/FormContext'\nimport cssField, {\n getSizeHeight,\n getSizeHorizontalPadding,\n getContrastColor,\n} from '../../../../services/cssField'\nimport Label from '../../../Label'\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop =>\n !['error', 'shape', 'size', 'contrast', 'brandColor'].includes(prop.toString()),\n})<Value & { error?: boolean }>`\n ${cssField()}\n display: flex;\n align-items: center;\n position: relative;\n user-select: none;\n border-color: #f19eb9;\n\n &:focus,\n &:focus-within {\n border-color: #e54e7f;\n }\n\n ${props =>\n cssMediaRules(\n [props.size, props.contrast] as const,\n ([size = Sizes.MEDIUM, contrast = Contrasts.LIGHT]) => css`\n min-height: ${getSizeHeight(size)}px;\n max-height: ${getSizeHeight(size)}px;\n\n &::after {\n content: '';\n position: absolute;\n right: ${getSizeHorizontalPadding(size)}px;\n top: 50%;\n transform: translate3d(0, -25%, 0);\n border: solid 0.35em transparent;\n border-top-color: ${getContrastColor(contrast)};\n }\n `,\n )}\n`\n\nconst Select = styled.select`\n appearance: none;\n position: absolute;\n top: 0;\n left: 0;\n opacity: 0;\n width: 100%;\n height: 100%;\n`\n\ntype Props = {\n id: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n value?: string\n label?: string\n required?: boolean\n error?: boolean\n hideLabel?: boolean\n form?: unknown\n}\n\nexport default forwardRef<HTMLSelectElement, Props>(function TableColumnSingleSelect(\n {\n id,\n tableColumn,\n value = '',\n label = '',\n error = false,\n hideLabel = false,\n form,\n ...restOfProps\n }: Props,\n ref,\n) {\n const { shape, size, contrast, brandColor } = useFormContext()\n\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Container\n error={error}\n shape={shape}\n size={size}\n contrast={contrast}\n brandColor={brandColor}\n >\n <span>{value === '' ? '-' : value}</span>\n <Select {...restOfProps} aria-label={label} ref={ref} id={id} value={value}>\n <option value=\"\">-</option>\n {tableColumn.options.map(option => (\n <option key={option.id} value={option.name}>\n {option.name}\n </option>\n ))}\n </Select>\n </Container>\n </>\n )\n})\n","import { forwardRef, SyntheticEvent } from 'react'\n\nimport TableColumnRadioButtonGroup from './components/TableColumnRadioButtonGroup'\nimport TableColumnSingleSelect from './components/TableColumnSingleSelect'\n\ntype Props = {\n id: string\n name: string\n tableColumn: {\n options: Array<{\n id: string\n name: string\n }>\n }\n label?: string\n value?: string\n onChange: (arg0: SyntheticEvent<HTMLInputElement>) => unknown\n required?: boolean\n type: 'select' | 'radio'\n}\n\nexport default forwardRef<\n {\n readonly validity: {\n readonly valueMissing: boolean\n readonly typeMismatch: boolean\n }\n },\n Props\n>(function SingleSelectTableField({ type, ...restOfProps }: Props, ref) {\n return type === 'select' ? (\n // @ts-expect-error: custom ref doesn't match select element\n <TableColumnSingleSelect {...restOfProps} ref={ref} />\n ) : (\n <TableColumnRadioButtonGroup {...restOfProps} ref={ref} />\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function PhoneNumberTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"tel\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function EmailTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"email\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function URLTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"url\"\n error={error != null}\n />\n </>\n )\n})\n","import { forwardRef } from 'react'\n\nimport Label from '../Label'\nimport Input from '../Input'\n\ntype Props = {\n id: string\n label?: string\n name: string\n error?: string\n hideLabel?: boolean\n}\n\nexport default forwardRef<HTMLInputElement, Props>(function NumberTableField(\n { id, label = '', name, error, hideLabel = false, ...restOfProps }: Props,\n ref,\n) {\n return (\n <>\n {!hideLabel && <Label htmlFor={id}>{label}</Label>}\n <Input\n {...restOfProps}\n aria-label={label}\n ref={ref}\n id={id}\n name={name}\n type=\"number\"\n error={error != null}\n />\n </>\n )\n})\n","import styled, { css } from 'styled-components'\n\nimport { useFormContext, Sizes, Shapes, Value } from '../../../../context/FormContext'\nimport { getSizeHeight as getLabelSizeHeight } from '../Label'\nimport { getSizeHeight as getInputSizeHeight } from '../Input'\nimport { getShapeBorderRadius } from '../../services/cssField'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\n\nconst Label = styled.div.withConfig({\n shouldForwardProp: prop => !['size'].includes(prop.toString()),\n})<Pick<Value, 'size'>>`\n display: block;\n max-width: 120px;\n min-width: 60px;\n border-radius: 2px;\n background-color: #5f49f4;\n opacity: 0.4;\n ${props =>\n cssMediaRules(\n [props.size] as const,\n ([size = Sizes.MEDIUM]) => css`\n margin: calc(0.25 * ${getLabelSizeHeight(size)}px + 2px) 0;\n min-height: ${0.5 * getLabelSizeHeight(size)}px;\n max-height: ${0.5 * getLabelSizeHeight(size)}px;\n `,\n )}\n`\n\nconst Input = styled.div.withConfig({\n shouldForwardProp: prop => !['shape', 'size'].includes(prop.toString()),\n})<Pick<Value, 'shape' | 'size'>>`\n display: block;\n width: 100%;\n border-width: 2px;\n border-style: solid;\n border-color: #5f49f4;\n opacity: 0.4;\n ${props =>\n cssMediaRules(\n [props.shape, props.size] as const,\n ([shape = Shapes.ROUNDED, size = Sizes.MEDIUM]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n border-radius: ${getShapeBorderRadius(shape)}px;\n `,\n )}\n`\n\nexport default function PlaceholderTableField(): JSX.Element {\n const { size, shape } = useFormContext()\n\n return (\n <>\n <Label size={size} />\n <Input shape={shape} size={size} />\n </>\n )\n}\n","import { useRef } from 'react'\nimport { Field as FormikField, getIn } from 'formik'\n\nimport SingleLineTextTableField from './components/SingleLineTextTableField'\nimport LongTextTableField from './components/LongTextTableField'\nimport CheckboxTableField from './components/CheckboxTableField'\nimport MultipleSelectTableField from './components/MultipleSelectTableField'\nimport SingleSelectTableField from './components/SingleSelectTableField'\nimport PhoneNumberTableField from './components/PhoneNumberTableField'\nimport EmailTableField from './components/EmailTableField'\nimport URLTableField from './components/URLTableField'\nimport NumberTableField from './components/NumberTableField'\nimport PlaceholderTableField from './components/PlaceholderTableField'\nimport { TableColumn } from '../../../../hooks'\n\nfunction getTypeMismatchErrorMessage(tableColumn: TableColumn | null | undefined, label: string) {\n switch ((tableColumn || {}).__typename) {\n case 'PhoneNumberTableColumn':\n return `${label} field must be a valid phone number.`\n\n case 'EmailTableColumn':\n return `${label} field must be a valid email.`\n\n case 'URLTableColumn':\n return `${label} field must be a valid URL.`\n\n case 'NumberTableColumn':\n return `${label} field must be a valid number.`\n\n case 'SingleLineTextTableColumn':\n case 'LongTextTableColumn':\n case 'CheckboxTableColumn':\n default:\n return `${label} field is invalid.`\n }\n}\n\nfunction getTableColumnField(tableColumn: TableColumn | null | undefined) {\n switch ((tableColumn || {}).__typename) {\n case 'SingleLineTextTableColumn':\n return SingleLineTextTableField\n\n case 'LongTextTableColumn':\n return LongTextTableField\n\n case 'CheckboxTableColumn':\n return CheckboxTableField\n\n case 'MultipleSelectTableColumn':\n return MultipleSelectTableField\n\n case 'SingleSelectTableColumn':\n return SingleSelectTableField\n\n case 'PhoneNumberTableColumn':\n return PhoneNumberTableField\n\n case 'EmailTableColumn':\n return EmailTableField\n\n case 'URLTableColumn':\n return URLTableField\n\n case 'NumberTableColumn':\n return NumberTableField\n\n default:\n return SingleLineTextTableField\n }\n}\n\ntype TableFormField = {\n id: string\n tableColumnId: string\n label?: string\n placeholder?: string\n required?: boolean\n hidden?: boolean\n type?: 'select' | 'radio'\n hideLabel?: boolean\n}\n\ntype Props = {\n tableColumn: TableColumn | null | undefined\n tableFormField: TableFormField\n}\n\nexport default function Field({\n tableColumn,\n tableFormField: {\n id,\n label = '',\n placeholder,\n required = false,\n hidden = false,\n type = 'radio',\n hideLabel = false,\n },\n}: Props): JSX.Element {\n const TableColumnField = getTableColumnField(tableColumn)\n const input = useRef<\n | {\n validity: {\n valueMissing: boolean\n typeMismatch: boolean\n }\n }\n | null\n | undefined\n >(null)\n\n if (!tableColumn) return <PlaceholderTableField />\n\n function validate() {\n let errorMessage\n\n if (input.current) {\n const { validity = {} as ValidityState } = input.current\n\n if (validity.valueMissing) errorMessage = `${label} is required.`\n\n if (validity.typeMismatch) errorMessage = getTypeMismatchErrorMessage(tableColumn, label)\n }\n\n return errorMessage\n }\n\n return (\n <FormikField name={tableColumn.name} validate={validate}>\n {({ field, form }: any) =>\n hidden ? (\n <input {...field} ref={input} type=\"hidden\" />\n ) : (\n <TableColumnField\n {...field}\n type={type}\n form={form}\n tableColumn={tableColumn}\n ref={input}\n id={id}\n error={getIn(form.touched, field.name) && getIn(form.errors, field.name)}\n label={label}\n placeholder={placeholder}\n required={required}\n hideLabel={hideLabel}\n />\n )\n }\n </FormikField>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCI+CiAgPGcgZmlsbD0ibm9uZSIgc3Ryb2tlLXdpZHRoPSIyIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgxIDEpIj4KICAgIDxjaXJjbGUgc3Ryb2tlPSJjdXJyZW50Q29sb3IiIGN4PSI5IiBjeT0iOSIgcj0iOSIgc3Ryb2tlLW9wYWNpdHk9Ii40Ii8+CiAgICA8cGF0aCBzdHJva2UtbGluZWNhcD0icm91bmQiIGQ9Ik05IDE4QTkgOSAwIDAgMCA5IDAiLz4KICA8L2c+Cjwvc3ZnPgo=\"","import styled, { keyframes } from 'styled-components'\n\nimport { ReactComponent as Spinner20 } from '../../../../icons/spinner-20.svg'\n\nconst spin = keyframes`\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n`\n\nconst Icon = styled(Spinner20)`\n display: inline-flex;\n animation: ${spin} 1s linear infinite;\n stroke: currentColor;\n`\n\nexport default function Spinner(): JSX.Element {\n return <Icon />\n}\n","import { useState, useEffect, useMemo } from 'react'\nimport { getBox } from '../../box-model'\nimport { TableFormFieldsPropController } from '../../prop-controllers/instances'\nimport { useIsInBuilder } from '../../react'\n\nexport function useTableFormFieldRefs(\n propController: TableFormFieldsPropController | null | undefined,\n { fieldsCount }: { fieldsCount: number },\n): {\n container: (arg0: HTMLElement | null | undefined) => void\n items: Array<(arg0: HTMLElement | null | undefined) => void>\n} {\n const [container, setContainer] = useState<HTMLElement | null | undefined>(null)\n const [items, setItems] = useState<Array<HTMLElement | null | undefined>>(\n Array(fieldsCount + 1).fill(null),\n )\n\n const isInBuilder = useIsInBuilder()\n\n useEffect(() => {\n if (!isInBuilder) return\n\n let animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n\n return () => {\n cancelAnimationFrame(animationFrameHandle)\n }\n\n function handleAnimationFrameRequest() {\n if (propController == null) return\n\n if (container != null) propController.tableFormLayoutChange({ layout: getBox(container) })\n\n items.map((item, index) => {\n if (item == null) return\n\n propController.tableFormFieldLayoutChange({ index, layout: getBox(item) })\n })\n\n animationFrameHandle = requestAnimationFrame(handleAnimationFrameRequest)\n }\n }, [propController, container, items, isInBuilder])\n\n const itemRefs = useMemo(\n () =>\n Array.from({ length: fieldsCount + 1 }).map(\n (_, index) => (item: HTMLElement | null | undefined) => {\n setItems(is => [...is.slice(0, index), item, ...is.slice(index + 1)])\n },\n ),\n [fieldsCount, setItems],\n )\n\n return { container: setContainer, items: itemRefs }\n}\n","import {\n useState,\n useEffect,\n useRef,\n useMemo,\n forwardRef,\n ComponentPropsWithoutRef,\n Ref,\n useImperativeHandle,\n} from 'react'\nimport styled, { css } from 'styled-components'\nimport { Formik, getIn } from 'formik'\nimport { cx } from '@emotion/css'\n\nimport { ReactComponent as Check12 } from '../../icons/check-12.svg'\n\nimport { getSizeHeight as getInputSizeHeight } from './components/Field/components/Input'\n\nimport {\n Size,\n Sizes,\n Provider as FormContextProvider,\n Shape,\n Contrast,\n Shapes,\n Contrasts,\n} from './context/FormContext'\nimport Placeholder from './components/Placeholder'\nimport Field from './components/Field'\nimport Spinner from './components/Spinner'\nimport Button from '../Button'\nimport { TableColumn, useTable } from '../../hooks'\nimport { cssGridItem, cssMargin, cssMediaRules } from '../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ElementIDValue,\n GapYValue,\n LinkValue,\n MarginValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n TableFormFieldsDescriptor,\n TableFormFieldsValue,\n TableValue,\n TextInputValue,\n TextStyleValue,\n} from '../../../prop-controllers/descriptors'\nimport { Link } from '../../shared/Link'\nimport { BoxModelHandle, getBox } from '../../../box-model'\nimport { PropControllersHandle } from '../../../state/modules/prop-controller-handles'\nimport { DescriptorsPropControllers } from '../../../prop-controllers/instances'\nimport { useTableFormFieldRefs } from '../../hooks/useTableFormFieldRefs'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { useMutation, gql } from '../../../api/react'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\n\nconst LOCAL_STORAGE_NAMESPACE = '@@makeswift/components/form'\n\nfunction getSizeFontSize(size: Size): number {\n switch (size) {\n case Sizes.SMALL:\n return 12\n\n case Sizes.MEDIUM:\n return 14\n\n case Sizes.LARGE:\n return 18\n\n default:\n throw new Error(`Invalid form size \"${size}\"`)\n }\n}\n\nexport const Alignments = {\n LEFT: 'left',\n CENTER: 'center',\n RIGHT: 'right',\n} as const\n\nexport type Alignment = typeof Alignments[keyof typeof Alignments]\n\ntype Props = {\n id?: ElementIDValue\n tableId?: TableValue\n fields?: TableFormFieldsValue\n submitLink?: LinkValue\n gap?: GapYValue\n shape?: ResponsiveIconRadioGroupValue<Shape>\n size?: ResponsiveIconRadioGroupValue<Size>\n contrast?: ResponsiveIconRadioGroupValue<Contrast>\n labelTextStyle?: TextStyleValue\n labelTextColor?: ResponsiveColor | null\n submitTextStyle?: TextStyleValue\n brandColor?: ResponsiveColor | null\n submitTextColor?: ResponsiveColor | null\n submitLabel?: TextInputValue\n submitVariant?: ResponsiveSelectValue<\n 'flat' | 'outline' | 'shadow' | 'clear' | 'blocky' | 'bubbly' | 'skewed'\n >\n submitWidth?: ResponsiveLengthValue\n submitAlignment?: ResponsiveIconRadioGroupValue<Alignment>\n width?: string\n margin?: MarginValue\n}\n\nconst GridForm = styled.form.withConfig({\n shouldForwardProp: prop => !['size', 'width', 'margin'].includes(prop),\n})<{\n size: Props['size']\n margin: Props['margin']\n}>`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n ${props =>\n cssMediaRules(\n [props.size],\n ([size = Sizes.MEDIUM]) => css`\n font-size: ${getSizeFontSize(size)}px;\n `,\n )}\n ${cssMargin()}\n`\n\nconst GridItem = styled.div.withConfig({\n shouldForwardProp: prop => !['grid', 'index', 'rowGap', 'columnGap'].includes(prop),\n})`\n align-self: flex-end;\n flex-direction: column;\n ${cssGridItem()}\n`\n\nfunction getAlignmentMargin(alignment: Alignment): string {\n switch (alignment) {\n case Alignments.LEFT:\n return '0 auto 0 0'\n case Alignments.RIGHT:\n return '0 0 0 auto'\n default:\n return '0 auto'\n }\n}\n\nconst StyledButton = styled((props: ComponentPropsWithoutRef<typeof Button>) => (\n <Button {...props} as=\"button\" />\n)).withConfig({\n shouldForwardProp: prop => !['alignment'].includes(prop.toString()),\n})<{\n size: Props['size']\n alignment: Props['submitAlignment']\n}>`\n display: flex;\n align-items: center;\n justify-content: center;\n ${props =>\n cssMediaRules(\n [props.size, props.alignment] as const,\n ([size = Sizes.MEDIUM, alignment = Alignments.CENTER]) => css`\n min-height: ${getInputSizeHeight(size)}px;\n max-height: ${getInputSizeHeight(size)}px;\n margin: ${getAlignmentMargin(alignment)};\n padding-top: 0;\n padding-bottom: 0;\n `,\n )}\n`\n\nconst ErrorContainer = styled.div`\n padding: 8px 16px;\n background-color: #f19eb9;\n border-radius: 4px;\n margin-top: 16px;\n`\n\nconst IconContainer = styled.div`\n fill: currentColor;\n`\n\nconst ErrorMessage = styled.p`\n font-size: 12px;\n margin: 8px 0;\n color: rgba(127, 0, 0, 0.95);\n`\n\nfunction getTableColumnDefaultValue(tableColumn: TableColumn) {\n switch (tableColumn.__typename) {\n case 'CheckboxTableColumn':\n return false\n\n case 'MultipleSelectTableColumn':\n return []\n\n case 'SingleLineTextTableColumn':\n case 'LongTextTableColumn':\n case 'SingleSelectTableColumn':\n case 'PhoneNumberTableColumn':\n case 'EmailTableColumn':\n case 'URLTableColumn':\n case 'NumberTableColumn':\n default:\n return ''\n }\n}\n\nconst CREATE_TABLE_RECORD = gql`\n mutation CreateTableRecord($input: CreateTableRecordInput!) {\n createTableRecord(input: $input) {\n tableRecord {\n id\n }\n }\n }\n`\n\ntype Column = { columnId: string; data: Record<string, any> }\ntype Fields = Record<string, string | string[] | boolean>\n\ntype Descriptors = { fields?: TableFormFieldsDescriptor }\n\nconst Form = forwardRef(function Form(\n {\n id,\n tableId,\n fields: fieldsProp,\n submitLabel = 'Submit',\n submitLink,\n shape,\n size,\n contrast,\n brandColor,\n gap,\n width,\n margin,\n submitTextStyle,\n submitVariant,\n submitTextColor,\n submitWidth,\n submitAlignment,\n labelTextStyle,\n labelTextColor,\n }: Props,\n ref: Ref<BoxModelHandle & PropControllersHandle<Descriptors>>,\n) {\n const fields = useMemo(() => fieldsProp?.fields ?? [], [fieldsProp])\n const grid = useMemo(() => fieldsProp?.grid ?? [], [fieldsProp])\n const { data: { table } = {} } = useTable(tableId)\n const [createTableRecord] = useMutation(CREATE_TABLE_RECORD)\n const [refEl, setRefEl] = useState<HTMLElement | null>(null)\n const [propControllers, setPropControllers] =\n useState<DescriptorsPropControllers<Descriptors> | null>(null)\n const [initialValues, setInitialValues] = useState<Fields>(() =>\n fields.reduce((acc, formField) => {\n const tableColumn = table && table.columns.find(field => field.id === formField.tableColumnId)\n const defaultValue = formField ? formField.defaultValue : null\n\n if (tableColumn) {\n acc[tableColumn.name] =\n defaultValue == null ? getTableColumnDefaultValue(tableColumn) : defaultValue\n }\n\n return acc\n }, {} as Fields),\n )\n const controller = propControllers?.fields\n const { container, items } = useTableFormFieldRefs(controller, { fieldsCount: fields.length })\n const [isDone, setIsDone] = useState(false)\n const linkRef = useRef<HTMLAnchorElement>(null)\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n return refEl instanceof Element ? getBox(refEl) : null\n },\n setPropControllers,\n }),\n [refEl, setPropControllers],\n )\n\n useEffect(() => {\n container(refEl)\n }, [container, refEl])\n\n useEffect(() => {\n if (!isDone) return\n\n let timeoutId = setTimeout(() => setIsDone(false), 2500)\n\n return () => clearTimeout(timeoutId)\n }, [isDone])\n\n function getTableColumn({ tableColumnId }: any) {\n return table && table.columns.find(field => tableColumnId === field.id)\n }\n\n async function handleSubmit(values: any, { setSubmitting, resetForm, setStatus }: any) {\n if (table) {\n const columns: Column[] = []\n\n fields.forEach(field => {\n const tableColumn = getTableColumn(field)\n\n if (tableColumn) {\n const data = values[tableColumn.name]\n\n if (data) {\n columns.push({ columnId: field.tableColumnId, data })\n\n if (field.autofill) {\n localStorage.setItem(\n `${LOCAL_STORAGE_NAMESPACE}/${tableColumn.name}`,\n JSON.stringify(data),\n )\n }\n }\n }\n })\n\n try {\n await createTableRecord({\n variables: { input: { data: { tableId: table.id, columns } } },\n })\n setIsDone(true)\n setInitialValues(prev =>\n fields.reduce(\n (acc, field) => {\n const tableColumn = getTableColumn(field)\n\n if (tableColumn) {\n const data = values[tableColumn.name]\n\n if (data && field.autofill) return { ...acc, [tableColumn.name]: data }\n }\n\n return acc\n },\n { ...prev },\n ),\n )\n resetForm()\n\n if (linkRef.current != null) linkRef.current.click()\n } catch (error) {\n setStatus({ error: 'An unexpected error has occurred, please try again later' })\n } finally {\n setSubmitting(false)\n }\n }\n }\n\n useEffect(() => {\n setInitialValues(prev =>\n fields.reduce(\n (acc, formField) => {\n const tableColumn =\n table && table.columns.find(field => field.id === formField.tableColumnId)\n\n if (tableColumn && formField.autofill) {\n const storedValue = localStorage.getItem(\n `${LOCAL_STORAGE_NAMESPACE}/${tableColumn.name}`,\n )\n\n if (storedValue) {\n try {\n acc[tableColumn.name] = JSON.parse(storedValue)\n } catch (e) {\n // Ignore\n }\n }\n }\n\n return acc\n },\n { ...prev },\n ),\n )\n }, [fields, table])\n\n return (\n <FormContextProvider\n value={{ shape, size, contrast, brandColor, labelTextStyle, labelTextColor }}\n >\n {tableId == null ? (\n <Placeholder ref={setRefEl} className={cx(width)} margin={margin} />\n ) : (\n <>\n <Formik\n onSubmit={handleSubmit}\n initialValues={initialValues}\n initialStatus={{ error: null }}\n enableReinitialize\n >\n {formik => {\n const error = formik.status && formik.status.error\n const errors = fields\n .map(field => {\n const tableColumn = getTableColumn(field)\n\n return (\n tableColumn &&\n getIn(formik.touched, tableColumn.name) &&\n getIn(formik.errors, tableColumn.name)\n )\n })\n .filter(message => typeof message === 'string')\n\n return (\n <>\n <GridForm\n ref={setRefEl}\n id={id}\n className={cx(width)}\n margin={margin}\n size={size}\n onSubmit={formik.handleSubmit}\n onReset={formik.handleReset}\n noValidate\n >\n {fields.map((field, index) => {\n const tableColumn = getTableColumn(field)\n\n return (\n <GridItem\n key={field.id}\n ref={items[index]}\n grid={grid}\n index={index}\n rowGap={gap}\n columnGap={gap}\n >\n <Field tableColumn={tableColumn} tableFormField={field} />\n </GridItem>\n )\n })}\n <GridItem\n ref={items[fields.length]}\n grid={grid}\n index={fields.length}\n rowGap={gap}\n columnGap={gap}\n >\n <StyledButton\n type=\"submit\"\n disabled={formik.isSubmitting || isDone}\n shape={shape}\n size={size}\n color={brandColor}\n variant={submitVariant}\n textColor={submitTextColor}\n width={submitWidth}\n alignment={submitAlignment}\n textStyle={submitTextStyle}\n >\n {formik.isSubmitting ? (\n <Spinner />\n ) : isDone ? (\n <IconContainer>\n <Check12 />\n </IconContainer>\n ) : (\n submitLabel\n )}\n </StyledButton>\n {(errors.length > 0 || error) && (\n <ErrorContainer>\n {errors.map(message => (\n <ErrorMessage key={message}>{message}</ErrorMessage>\n ))}\n {error != null && <ErrorMessage>{error}</ErrorMessage>}\n </ErrorContainer>\n )}\n </GridItem>\n </GridForm>\n {submitLink != null && <Link ref={linkRef} hidden link={submitLink} />}\n </>\n )\n }}\n </Formik>\n </>\n )}\n </FormContextProvider>\n )\n})\n\nexport default Form\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Form, {\n type: './components/Form/index.js',\n label: 'Form',\n icon: 'Form40',\n props: {\n id: Props.ElementID(),\n tableId: Props.Table(),\n fields: Props.TableFormFields(),\n submitLink: Props.Link(props => ({\n label: 'Redirect to',\n // TODO: This option is hardcoded. We should import it from LinkPanelOptions\n options: [\n { value: 'OPEN_PAGE', label: 'Open page' },\n { value: 'OPEN_URL', label: 'Open URL' },\n ],\n hidden: props.tableId == null,\n })),\n gap: Props.GapY(props => ({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Gap',\n defaultValue: { value: 0, unit: 'px' },\n hidden: props.tableId == null,\n })),\n shape: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Shape',\n options: [\n { label: 'Pill', value: Shapes.PILL, icon: 'ButtonPill16' },\n { label: 'Rounded', value: Shapes.ROUNDED, icon: 'ButtonRounded16' },\n { label: 'Square', value: Shapes.SQUARE, icon: 'ButtonSquare16' },\n ],\n defaultValue: Shapes.ROUNDED,\n hidden: props.tableId == null,\n })),\n size: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Size',\n options: [\n { label: 'Small', value: Sizes.SMALL, icon: 'SizeSmall16' },\n { label: 'Medium', value: Sizes.MEDIUM, icon: 'SizeMedium16' },\n { label: 'Large', value: Sizes.LARGE, icon: 'SizeLarge16' },\n ],\n defaultValue: Sizes.MEDIUM,\n hidden: props?.tableId == null,\n })),\n contrast: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Color',\n options: [\n { label: 'Light mode', value: Contrasts.LIGHT, icon: 'Sun16' },\n { label: 'Dark mode', value: Contrasts.DARK, icon: 'Moon16' },\n ],\n defaultValue: Contrasts.LIGHT,\n hidden: props.tableId == null,\n })),\n labelTextStyle: Props.TextStyle({ label: 'Label text style' }),\n labelTextColor: Props.ResponsiveColor((props, device) => {\n const hidden = props.tableId == null\n const responsiveContrast = props.contrast as ResponsiveValue<Contrast>\n const contrast = findDeviceOverride<Contrast>(responsiveContrast, device)\n\n return {\n hidden,\n label: 'Label text color',\n placeholder:\n contrast?.value === Contrasts.DARK ? 'rgba(255,255,255,0.95)' : 'rgba(0,0,0,0.8)',\n }\n }),\n submitTextStyle: Props.TextStyle({ label: 'Button text style' }),\n brandColor: Props.ResponsiveColor(props => ({\n label: 'Button color',\n placeholder: 'black',\n hidden: props.tableId == null,\n // TODO: Add hideAlphaSlider\n })),\n submitTextColor: Props.ResponsiveColor(props => ({\n label: 'Button text color',\n placeholder: 'white',\n hidden: props.tableId == null,\n })),\n submitLabel: Props.TextInput(props => ({\n label: 'Button label',\n placeholder: 'Submit',\n hidden: props.tableId == null,\n })),\n submitVariant: Props.ResponsiveSelect(props => ({\n label: 'Button style',\n options: [\n { value: 'flat', label: 'Flat' },\n { value: 'outline', label: 'Outline' },\n { value: 'shadow', label: 'Floating' },\n { value: 'clear', label: 'Clear' },\n { value: 'blocky', label: 'Blocky' },\n { value: 'bubbly', label: 'Bubbly' },\n { value: 'skewed', label: 'Skewed' },\n ],\n defaultValue: 'flat',\n hidden: props.tableId == null,\n })),\n submitWidth: Props.ResponsiveLength(props => ({\n label: 'Button width',\n hidden: props.tableId == null,\n // TODO: Add placeholder: { value: 'auto' }\n })),\n submitAlignment: Props.ResponsiveIconRadioGroup(props => ({\n label: 'Button alignment',\n options: [\n { label: 'Left', value: Alignments.LEFT, icon: 'AlignLeft16' },\n { label: 'Center', value: Alignments.CENTER, icon: 'AlignCenter16' },\n { label: 'Right', value: Alignments.RIGHT, icon: 'AlignRight16' },\n ],\n defaultValue: Alignments.CENTER,\n hidden: props.tableId == null,\n })),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n preset: [{ deviceId: 'desktop', value: { value: 550, unit: 'px' } }],\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyOCIgaGVpZ2h0PSIyOCI+CiAgPHBhdGggZD0iTTI3IDE1SDFhMSAxIDAgMCAxLTEtMSAxIDEgMCAwIDEgMS0xaDI2YTEgMSAwIDAgMSAxIDEgMSAxIDAgMCAxLTEgMXptMC0xMEgxYTEgMSAwIDAgMC0xIDEgMSAxIDAgMCAwIDEgMWgyNmExIDEgMCAwIDAgMS0xIDEgMSAwIDAgMC0xLTF6bTAgMTZIMWExIDEgMCAwIDAtMSAxIDEgMSAwIDAgMCAxIDFoMjZhMSAxIDAgMCAwIDEtMSAxIDEgMCAwIDAtMS0xeiIvPgo8L3N2Zz4=\"","import styled, { css } from 'styled-components'\n\nimport { ResponsiveValue, Length } from '../../../prop-controllers/descriptors'\nimport { cssMediaRules } from '../../utils/cssMediaRules'\n\nconst GutterContainer = styled.div<{\n gutter?: ResponsiveValue<Length>\n first: boolean\n last: boolean\n}>`\n ${p =>\n cssMediaRules(\n [p.gutter],\n ([gutter = { value: 0, unit: 'px' }]) => css`\n padding-left: ${p.first ? '0px' : `${gutter.value / 2}${gutter.unit}`};\n padding-right: ${p.last ? '0px' : `${gutter.value / 2}${gutter.unit}`};\n `,\n )}\n`\n\nexport default GutterContainer\n","import styled from 'styled-components'\n\nimport { ResponsiveLengthValue } from '../../../../../prop-controllers/descriptors'\nimport GutterContainer from '../../../../shared/GutterContainer'\n\nconst PlaceholderLink = styled.div.withConfig({\n shouldForwardProp: prop => !['width', 'button'].includes(prop.toString()),\n})<{ width: number; button?: boolean }>`\n width: ${props => props.width}px;\n height: ${props => (props.button === true ? 32 : 8)}px;\n background-color: #a1a8c2;\n border-radius: ${props => (props.button === true ? 6 : 2)}px;\n opacity: 0.4;\n`\n\ntype Props = { gutter?: ResponsiveLengthValue }\n\nconst links = [{ width: 50 }, { width: 70 }, { width: 60 }, { width: 80, button: true }]\n\nexport default function LinksPlaceholder({ gutter }: Props): JSX.Element {\n return (\n <>\n {links.map((link, i) => (\n <GutterContainer key={i} gutter={gutter} first={i === 0} last={i === links.length - 1}>\n <PlaceholderLink {...link} />\n </GutterContainer>\n ))}\n </>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik0xIDJhMSAxIDAgMCAwLS43MDcgMS43MDdsMyAzYTEgMSAwIDAgMCAxLjQxNCAwbDMtM0ExIDEgMCAwIDAgNyAySDF6Ii8+PC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik00IDBhMSAxIDAgMCAwLTEgMXYySDFhMSAxIDAgMSAwIDAgMmgydjJhMSAxIDAgMCAwIDIgMFY1aDJhMSAxIDAgMCAwIDAtMkg1VjFhMSAxIDAgMCAwLTEtMXoiLz48L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGQ9Ik01IDFhMSAxIDAgMCAwLTIgMHYzLjU4NmwtLjI5My0uMjkzYTEgMSAwIDAgMC0xLjQxNCAxLjQxNGwyIDJhMSAxIDAgMCAwIDEuNDE0IDBsMi0yYTEgMSAwIDAgMC0xLjQxNC0xLjQxNEw1IDQuNTg2VjF6Ii8+PC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iOCIgaGVpZ2h0PSI4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNLjI5MyAyLjI5M2ExIDEgMCAwIDEgMS40MTQgMEw0IDQuNTg2bDIuMjkzLTIuMjkzYTEgMSAwIDAgMSAxLjQxNCAxLjQxNGwtMyAzYTEgMSAwIDAgMS0xLjQxNCAwbC0zLTNhMSAxIDAgMCAxIDAtMS40MTR6Ii8+PC9zdmc+\"","import { ComponentPropsWithoutRef, useRef, useState } from 'react'\nimport styled, { css, keyframes } from 'styled-components'\n\nimport { ReactComponent as CaretDown8 } from '../../../../icons/caret-down-8.svg'\nimport { ReactComponent as Plus8 } from '../../../../icons/plus-8.svg'\nimport { ReactComponent as ArrowDown8 } from '../../../../icons/arrow-down-8.svg'\nimport { ReactComponent as ChevronDown8 } from '../../../../icons/chevron-down-8.svg'\nimport { cssMediaRules, cssTextStyle } from '../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ResponsiveColorValue,\n TextStyleValue,\n LinkValue,\n} from '../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport { useResponsiveColor } from '../../../../hooks'\n\nimport { Link } from '../../../../shared/Link'\nimport Button from '../../../Button'\nimport { useIsomorphicLayoutEffect } from '../../../../hooks/useIsomorphicLayoutEffect'\n\nconst DROP_DOWN_MENU_WIDTH = 200\n\ntype Position = 'left' | 'right'\n\nconst DropDownMenu = styled.div.withConfig({\n shouldForwardProp: prop => !['position'].includes(prop.toString()),\n})<{ position: Position }>`\n position: absolute;\n top: 100%;\n left: ${props => (props.position === 'left' ? 0 : 'auto')};\n right: ${props => (props.position === 'right' ? 0 : 'auto')};\n background: #fff;\n margin: 0;\n padding: 8px 0;\n border-radius: 4px;\n box-shadow: 0 3px 10px rgba(0, 0, 0, 0.15);\n width: ${DROP_DOWN_MENU_WIDTH}px;\n z-index: 99;\n list-style: none;\n overflow: hidden;\n transform-origin: 50% 0;\n will-change: transform, opacity;\n transform-style: preserve-3d;\n display: none;\n`\n\nconst dropIn = keyframes`\n 0% {\n opacity: 0;\n transform: rotateX(-20deg);\n }\n 100% {\n opacity: 1;\n transform: none;\n }\n`\n\nconst DropDownContainer = styled.div`\n position: relative;\n\n &:hover > ${DropDownMenu} {\n display: block;\n animation: ${dropIn} 0.25s;\n }\n`\n\nconst StyledDropDownItem = styled(Link).withConfig({\n shouldForwardProp: prop => !['color', 'textStyle'].includes(prop.toString()),\n})<{\n color?: ResponsiveValue<Color> | null\n textStyle?: TextStyleValue\n}>`\n display: block;\n text-decoration: none;\n line-height: 1.4;\n padding: 8px 16px;\n color: black;\n background-color: transparent;\n transition: background-color 0.2s;\n ${cssTextStyle()}\n ${p =>\n cssMediaRules([p.color, p.textStyle] as const, ([color, textStyle = {}]) => {\n const fontSize = textStyle.fontSize || { value: 14, unit: 'px' }\n const fontWeight = textStyle.fontWeight == null ? 'normal' : textStyle.fontWeight\n const fontStyle = textStyle.fontStyle || []\n const letterSpacing = textStyle.letterSpacing == null ? null : textStyle.letterSpacing\n const textTransform = textStyle.textTransform || []\n\n return css`\n color: ${color == null ? 'black' : colorToString(color)};\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n font-weight: ${fontWeight};\n font-style: ${fontStyle.includes('italic') ? 'italic' : 'normal'};\n letter-spacing: ${letterSpacing == null ? 'normal' : `${letterSpacing}px`};\n text-transform: ${textTransform.includes('uppercase') ? 'uppercase' : 'none'};\n `\n })}\n\n &:hover {\n background-color: rgba(0, 0, 0, 0.04);\n }\n`\n\ntype BaseDropDownItemProps = {\n color?: ResponsiveColorValue\n textStyle?: TextStyleValue\n}\n\ntype DropDownItemProps = BaseDropDownItemProps &\n Omit<ComponentPropsWithoutRef<typeof StyledDropDownItem>, keyof BaseDropDownItemProps>\n\nfunction DropDownItem({ color, ...restOfProps }: DropDownItemProps) {\n // @ts-expect-error: HTMLDivElement `color` attribute conflicts with prop.\n return <StyledDropDownItem {...restOfProps} color={useResponsiveColor(color)} />\n}\n\ntype Props = ComponentPropsWithoutRef<typeof Button> & {\n label: string\n caret?: 'caret' | 'plus' | 'arrow-down' | 'chevron-down'\n links?: Array<{\n id: string\n payload: ComponentPropsWithoutRef<typeof DropDownItem> & {\n link?: LinkValue\n label: string\n }\n }>\n}\n\nexport default function DropDownButton({\n label,\n caret = 'caret',\n links = [],\n textColor,\n color,\n ...restOfProps\n}: Props): JSX.Element {\n const container = useRef<HTMLDivElement>(null)\n const [position, setPosition] = useState<Position>('left')\n\n useIsomorphicLayoutEffect(() => {\n if (\n container.current &&\n container.current.ownerDocument.defaultView!.innerWidth <\n container.current.offsetLeft + DROP_DOWN_MENU_WIDTH\n ) {\n setPosition('right')\n } else {\n setPosition('left')\n }\n }, [setPosition])\n\n return (\n <DropDownContainer ref={container}>\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n >\n <div style={{ display: 'flex', alignItems: 'center' }}>\n <span style={{ marginRight: 6 }}>{label}</span>\n <span style={{ display: 'inline-flex', fill: 'currentColor' }}>\n {caret === 'caret' && <CaretDown8 />}\n {caret === 'plus' && <Plus8 />}\n {caret === 'arrow-down' && <ArrowDown8 />}\n {caret === 'chevron-down' && <ChevronDown8 />}\n </span>\n </div>\n </Button>\n <DropDownMenu position={position}>\n {links.map(({ id, payload }) => (\n <DropDownItem {...payload} key={id}>\n {payload.label}\n </DropDownItem>\n ))}\n </DropDownMenu>\n </DropDownContainer>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTYiIGhlaWdodD0iMTYiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CiAgPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0xMy43MDcgMy43MDdhMSAxIDAgMCAwLTEuNDE0LTEuNDE0TDggNi41ODYgMy43MDcgMi4yOTNhMSAxIDAgMCAwLTEuNDE0IDEuNDE0TDYuNTg2IDhsLTQuMjkzIDQuMjkzYTEgMSAwIDEgMCAxLjQxNCAxLjQxNEw4IDkuNDE0bDQuMjkzIDQuMjkzYTEgMSAwIDAgMCAxLjQxNC0xLjQxNEw5LjQxNCA4bDQuMjkzLTQuMjkzWiIvPgo8L3N2Zz4=\"","import { ComponentPropsWithoutRef, useState } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules, cssTextStyle } from '../../../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n ResponsiveColorValue,\n TextStyleValue,\n LinkValue,\n} from '../../../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../../../utils/types'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { useResponsiveColor } from '../../../../../../hooks'\n\nimport { ReactComponent as CaretDown8 } from '../../../../../../icons/caret-down-8.svg'\nimport { ReactComponent as Plus8 } from '../../../../../../icons/plus-8.svg'\nimport { ReactComponent as ArrowDown8 } from '../../../../../../icons/arrow-down-8.svg'\nimport { ReactComponent as ChevronDown8 } from '../../../../../../icons/chevron-down-8.svg'\n\nimport { Link } from '../../../../../../shared/Link'\nimport Button from '../../../../../Button'\n\nconst DropDownMenu = styled.div.withConfig({\n shouldForwardProp: prop => !['open'].includes(prop.toString()),\n})<{ open: boolean }>`\n display: ${props => (props.open ? 'flex' : 'none')};\n flex-direction: column;\n padding: 8px;\n`\n\nconst ButtonLink = styled(Button)`\n margin: 8px 0;\n`\n\nconst StyledLink = styled(Link).withConfig({\n shouldForwardProp: prop => !['textStyle', 'color'].includes(prop.toString()),\n})<{\n textStyle?: TextStyleValue\n color?: ResponsiveValue<Color> | null\n}>`\n text-decoration: none;\n line-height: 1.4;\n padding: 8px 16px;\n color: black;\n ${cssTextStyle()}\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color]) => css`\n color: ${color == null ? 'black' : colorToString(color)};\n `,\n )}\n`\n\ntype BaseDropDownItemProps = {\n color?: ResponsiveColorValue\n textStyle?: TextStyleValue\n}\n\ntype DropDownItemProps = BaseDropDownItemProps &\n Omit<ComponentPropsWithoutRef<typeof StyledLink>, keyof BaseDropDownItemProps>\n\nfunction DropDownItem({ color, ...restOfProps }: DropDownItemProps) {\n // @ts-expect-error: HTMLAnchorElement `color` attribute conflict with props\n return <StyledLink {...restOfProps} color={useResponsiveColor(color)} />\n}\n\ntype Props = ComponentPropsWithoutRef<typeof Button> & {\n label: string\n links?: Array<{\n id: string\n payload: ComponentPropsWithoutRef<typeof DropDownItem> & {\n link?: LinkValue\n label: string\n }\n }>\n onClose?: () => unknown\n caret?: string\n}\n\nexport default function MobileDropDownButton({\n label,\n caret,\n links = [],\n onClose = () => {},\n color,\n textColor,\n ...restOfProps\n}: Props): JSX.Element {\n const [isOpen, setIsOpen] = useState(false)\n return (\n <>\n <ButtonLink\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n onPointerDown={() => setIsOpen(prev => !prev)}\n >\n <div style={{ display: 'flex', alignItems: 'center' }}>\n <span style={{ marginRight: 6 }}>{label}</span>\n <span style={{ display: 'inline-flex', fill: 'currentColor' }}>\n <>\n {caret === 'caret' && <CaretDown8 />}\n {caret === 'plus' && <Plus8 />}\n {caret === 'arrow-down' && <ArrowDown8 />}\n {caret === 'chevron-down' && <ChevronDown8 />}\n </>\n </span>\n </div>\n </ButtonLink>\n <DropDownMenu open={isOpen}>\n {links.map(({ id, payload }) => (\n <DropDownItem {...payload} key={id} onClick={onClose}>\n {payload.label}\n </DropDownItem>\n ))}\n </DropDownMenu>\n </>\n )\n}\n","import { ComponentPropsWithoutRef, Fragment } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../utils/cssMediaRules'\nimport {\n ResponsiveValue,\n NavigationLinksValue,\n NavigationButton as NavigationButtonValue,\n} from '../../../../../prop-controllers/descriptors'\nimport { ColorValue as Color } from '../../../../utils/types'\nimport { colorToString } from '../../../../utils/colorToString'\nimport { ReactComponent as Times16 } from '../../../../icons/times-16.svg'\n\nimport Button from '../../../Button'\nimport DropDownButton from './components/MobileDropDownButton'\nimport { ResponsiveColor } from '../../../../../runtimes/react/controls'\nimport { useResponsiveColor } from '../../../../hooks'\n\ntype NavigationButtonProps = NavigationButtonValue['payload'] &\n Omit<ComponentPropsWithoutRef<typeof Button>, 'color' | 'textColor'>\n\nfunction NavigationButton(props: NavigationButtonProps): JSX.Element {\n const { textColor, color, ...restOfProps } = props\n\n return (\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n />\n )\n}\n\nconst ButtonLink = styled(NavigationButton)`\n margin: 8px 0;\n`\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['animation', 'backgroundColor', 'open'].includes(prop.toString()),\n})<{\n animation?: ResponsiveValue<'coverRight' | 'coverLeft'>\n backgroundColor?: ResponsiveValue<Color> | null\n open: boolean\n}>`\n position: fixed;\n flex-direction: column;\n width: 100%;\n padding: 40px 15px;\n transition: transform 300ms ease-in-out;\n overflow-y: auto;\n z-index: 9999;\n max-width: 575px;\n ${p =>\n cssMediaRules([p.animation, p.backgroundColor] as const, ([animation, backgroundColor]) =>\n animation == null\n ? css`\n display: none;\n `\n : css`\n display: flex;\n background-color: ${backgroundColor == null ? 'black' : colorToString(backgroundColor)};\n transform: ${p.open\n ? `translate3d(0,0,0)`\n : `translate3d(${{ coverRight: '', coverLeft: '-' }[animation]}100%, 0, 0)`};\n ${{\n coverRight: { top: 0, bottom: 0, right: 0 },\n coverLeft: { top: 0, bottom: 0, left: 0 },\n }[animation]}\n `,\n )}\n`\n\nconst CloseIconContainer = styled.button.withConfig({\n shouldForwardProp: prop => !['color'].includes(prop.toString()),\n})<{ color?: ResponsiveValue<Color> | null }>`\n position: absolute;\n top: 15px;\n right: 15px;\n padding: 0;\n border: 0;\n outline: 0;\n background: none;\n fill: currentColor;\n ${p =>\n cssMediaRules(\n [p.color] as const,\n ([color]) => css`\n color: ${color == null ? 'rgba(161, 168, 194, 0.5)' : colorToString(color)};\n `,\n )}\n`\n\ntype Props = {\n animation?: ResponsiveValue<'coverRight' | 'coverLeft'>\n backgroundColor?: ResponsiveColor | null\n closeIconColor?: ResponsiveColor | null\n links?: NavigationLinksValue\n onClose?: () => unknown\n open?: boolean\n}\n\nexport default function MobileMenu({\n animation,\n backgroundColor,\n open = false,\n closeIconColor,\n links = [],\n onClose = () => {},\n}: Props): JSX.Element {\n return (\n <Container animation={animation} backgroundColor={backgroundColor} open={open}>\n {/* @ts-expect-error: HTMLButtonElement `color` attribute conflicts with prop */}\n <CloseIconContainer color={closeIconColor} onClick={onClose}>\n <Times16 />\n </CloseIconContainer>\n <div\n style={{ display: 'flex', flexDirection: 'column', alignItems: 'center', flexShrink: 0 }}\n >\n {links.map(link => (\n <Fragment key={link.id}>\n {link.type === 'button' && (\n <ButtonLink {...link.payload} onClick={onClose}>\n {link.payload.label}\n </ButtonLink>\n )}\n {link.type === 'dropdown' && <DropDownButton {...link.payload} onClose={onClose} />}\n </Fragment>\n ))}\n </div>\n </Container>\n )\n}\n","import { ComponentPropsWithoutRef, forwardRef, useState } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { ReactComponent as MobileMenu28 } from '../../icons/mobile-menu-28.svg'\n\nimport GutterContainer from '../../shared/GutterContainer'\nimport Image from '../Image'\nimport Button from '../Button'\nimport LinksPlaceholder from './components/LinksPlaceholder'\nimport DropDownButton from './components/DropDownButton'\nimport MobileMenu from './components/MobileMenu'\nimport {\n ResponsiveValue,\n CheckboxValue,\n ElementIDValue,\n GapXValue,\n ImageValue,\n LinkValue,\n MarginValue,\n NavigationLinksValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveLengthValue,\n ResponsiveSelectValue,\n TextInputValue,\n TextStyleValue,\n NavigationButton as NavigationButtonValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssMargin, cssMediaRules, cssTextStyle } from '../../utils/cssMediaRules'\nimport { ColorValue as Color } from '../../utils/types'\nimport { colorToString } from '../../utils/colorToString'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\nimport { findDeviceOverride } from '../../utils/devices'\nimport { useResponsiveColor } from '../../hooks'\n\ntype Props = {\n id?: ElementIDValue\n links?: NavigationLinksValue\n linkTextStyle?: TextStyleValue\n showLogo?: CheckboxValue\n logoFile?: ImageValue\n logoWidth?: ResponsiveLengthValue\n logoAltText?: TextInputValue\n logoLink?: LinkValue\n alignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gutter?: GapXValue\n mobileMenuAnimation?: ResponsiveSelectValue<'coverRight' | 'coverLeft'>\n mobileMenuOpenIconColor?: ResponsiveColor | null\n mobileMenuCloseIconColor?: ResponsiveColor | null\n mobileMenuBackgroundColor?: ResponsiveColor | null\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.nav.withConfig({\n shouldForwardProp: prop => !['margin', 'textStyle', 'gutter'].includes(prop.toString()),\n})<{\n margin: Props['margin']\n textStyle: Props['linkTextStyle']\n gutter: Props['gutter']\n}>`\n display: flex;\n align-items: center;\n ${cssMargin()}\n ${cssTextStyle()}\n ${p =>\n cssMediaRules(\n [p.gutter] as const,\n ([gutter = { value: 0, unit: 'px' }]) => css`\n gap: ${gutter.value}${gutter.unit};\n `,\n )}\n`\n\nconst LinksContainer = styled.div.withConfig({\n shouldForwardProp: prop => !['alignment', 'mobileMenuAnimation'].includes(prop.toString()),\n})<{\n alignment: Props['alignment']\n mobileMenuAnimation: Props['mobileMenuAnimation']\n}>`\n display: flex;\n align-items: center;\n flex-grow: 1;\n ${p =>\n cssMediaRules(\n [p.alignment, p.mobileMenuAnimation] as const,\n ([alignment = 'flex-end', mobileMenuAnimation]) => css`\n display: ${mobileMenuAnimation == null ? 'flex' : 'none'};\n justify-content: ${alignment};\n `,\n )}\n`\n\nconst OpenIconContainer = styled.button.withConfig({\n shouldForwardProp: prop =>\n !['mobileMenuAnimation', 'alignment', 'color'].includes(prop.toString()),\n})<{\n mobileMenuAnimation: Props['mobileMenuAnimation']\n alignment: Props['alignment']\n color: ResponsiveValue<Color> | null | undefined\n}>`\n display: none;\n flex-grow: 1;\n align-items: center;\n background: none;\n outline: 0;\n border: 0;\n padding: 0;\n fill: currentColor;\n ${p =>\n cssMediaRules(\n [p.mobileMenuAnimation, p.alignment, p.color] as const,\n ([mobileMenuAnimation, alignment = 'flex-end', color]) => css`\n display: ${mobileMenuAnimation == null ? 'none' : 'flex'};\n justify-content: ${alignment};\n color: ${color == null ? 'rgba(161, 168, 194, 0.5)' : colorToString(color)};\n `,\n )}\n`\n\ntype NavigationButtonProps = NavigationButtonValue['payload'] &\n Omit<ComponentPropsWithoutRef<typeof Button>, 'color' | 'textColor'>\n\nfunction NavigationButton(props: NavigationButtonProps): JSX.Element {\n const { textColor, color, ...restOfProps } = props\n\n return (\n <Button\n {...restOfProps}\n textColor={useResponsiveColor(textColor)}\n color={useResponsiveColor(color)}\n />\n )\n}\n\nconst placeholder = {\n src: \"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='93.12' height='36' viewBox='0 0 93.12 36'%3E%3Cg id='Layer_2' data-name='Layer 2'%3E%3Cg id='Layer_1-2' data-name='Layer 1'%3E%3Cpath d='M18,0A18,18,0,1,1,0,18,18,18,0,0,1,18,0ZM49.36,21.94h6.36V24H46.8V10h2.56Zm9.06.72a4.88,4.88,0,0,1-1.64-3.72,5,5,0,0,1,1.64-3.74,5.57,5.57,0,0,1,7.7,0,5.09,5.09,0,0,1,.26,7.18l-.26.26a5.56,5.56,0,0,1-7.7,0Zm1.68-6a3.39,3.39,0,0,0,0,4.52,3,3,0,0,0,4.24.08l.08-.08a3.39,3.39,0,0,0,0-4.52,3,3,0,0,0-4.24-.08Zm10,10.68,1-1.92a5.28,5.28,0,0,0,3.3,1.22,3.6,3.6,0,0,0,2.32-.72,2.73,2.73,0,0,0,.9-2.26V22.5a3.61,3.61,0,0,1-1.45,1.26,4.35,4.35,0,0,1-2,.46,4.57,4.57,0,0,1-3.58-1.54A5.48,5.48,0,0,1,69.2,18.9a5.42,5.42,0,0,1,1.36-3.74,4.64,4.64,0,0,1,3.62-1.5,4,4,0,0,1,3.44,1.72v-1.5h2.46v9a6.13,6.13,0,0,1-1.43,4.46,5.27,5.27,0,0,1-4,1.44,7.09,7.09,0,0,1-4.53-1.42Zm1.54-8.44a3.4,3.4,0,0,0,.82,2.3,2.72,2.72,0,0,0,2.17.94,3.13,3.13,0,0,0,1.21-.22,2.89,2.89,0,0,0,1-.62,3.08,3.08,0,0,0,.63-1,3.62,3.62,0,0,0,.21-1.3,4,4,0,0,0-.23-1.33,3.3,3.3,0,0,0-.63-1.05,2.74,2.74,0,0,0-1-.68,3.35,3.35,0,0,0-1.25-.24,2.92,2.92,0,0,0-1.2.24,2.58,2.58,0,0,0-.93.67,3,3,0,0,0-.59,1,3.89,3.89,0,0,0-.19,1.31ZM83.8,22.66a4.88,4.88,0,0,1-1.64-3.72A5,5,0,0,1,83.8,15.2a5.57,5.57,0,0,1,7.7,0,5.09,5.09,0,0,1,.26,7.18,3.19,3.19,0,0,1-.26.26,5.56,5.56,0,0,1-7.7,0Zm1.68-6a3.39,3.39,0,0,0,0,4.52,3,3,0,0,0,4.24.08l.08-.08a3.39,3.39,0,0,0,0-4.52,3,3,0,0,0-4.24-.08Z' fill='%23a1a8c2' opacity='0.4' style='isolation: isolate'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E%0A\",\n dimensions: { width: 93, height: 36 },\n}\n\nconst Navigation = forwardRef<HTMLDivElement, Props>(function Navigation(\n {\n id,\n links = [],\n linkTextStyle,\n showLogo,\n logoFile,\n logoWidth,\n logoAltText,\n logoLink,\n alignment,\n gutter,\n mobileMenuAnimation,\n mobileMenuOpenIconColor,\n mobileMenuCloseIconColor,\n mobileMenuBackgroundColor,\n width,\n margin,\n },\n ref,\n) {\n const [isOpen, setIsOpen] = useState(false)\n\n return (\n <Container\n ref={ref}\n id={id}\n className={cx(width)}\n margin={margin}\n textStyle={linkTextStyle}\n gutter={gutter}\n >\n {showLogo === true && (\n <Image\n altText={logoAltText}\n file={logoFile}\n link={logoLink}\n placeholder={placeholder}\n width={logoWidth}\n />\n )}\n <div style={{ display: 'flex', flexGrow: 1, justifyContent: 'flex-end' }}>\n <LinksContainer alignment={alignment} mobileMenuAnimation={mobileMenuAnimation}>\n {links.length > 0 ? (\n links.map((link, i) => (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n {link.type === 'button' && (\n <NavigationButton {...link.payload}>{link.payload.label}</NavigationButton>\n )}\n {link.type === 'dropdown' && <DropDownButton {...link.payload} />}\n </GutterContainer>\n ))\n ) : (\n <LinksPlaceholder gutter={gutter} />\n )}\n </LinksContainer>\n <OpenIconContainer\n alignment={alignment}\n // @ts-expect-error: HTMLButtonElement `color` attribute conflicts with prop\n color={mobileMenuOpenIconColor}\n mobileMenuAnimation={mobileMenuAnimation}\n onClick={() => setIsOpen(true)}\n >\n <MobileMenu28 />\n </OpenIconContainer>\n <MobileMenu\n animation={mobileMenuAnimation}\n backgroundColor={mobileMenuBackgroundColor}\n closeIconColor={mobileMenuCloseIconColor}\n links={links}\n onClose={() => setIsOpen(false)}\n open={isOpen}\n />\n </div>\n </Container>\n )\n})\n\nexport default Navigation\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Navigation, {\n type: './components/Navigation/index.js',\n label: 'Navigation',\n icon: 'Navigation40',\n props: {\n id: Props.ElementID(),\n links: Props.NavigationLinks(),\n linkTextStyle: Props.TextStyle(props => {\n const links = props.links as NavigationLinksValue\n\n return {\n label: 'Link text style',\n hidden: links == null || links.length === 0,\n }\n }),\n showLogo: Props.Checkbox({ preset: true, label: 'Show logo' }),\n logoFile: Props.Image(props => ({\n label: 'Logo',\n hidden: props.showLogo === false,\n })),\n logoWidth: Props.ResponsiveLength(props => ({\n preset: [{ deviceId: 'desktop', value: { value: 100, unit: 'px' } }],\n label: 'Logo width',\n min: 0,\n max: 1000,\n // TODO: This is hardcoded value, import it from LengthInputOptions\n options: [{ value: 'px', label: 'Pixels', icon: 'Px16' }],\n hidden: props.showLogo === false,\n })),\n logoAltText: Props.TextInput(props => ({\n label: 'Logo alt text',\n hidden: props.showLogo === false,\n })),\n logoLink: Props.Link(props => ({\n label: 'Logo on click',\n hidden: props.showLogo === false,\n })),\n alignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'Left', value: 'flex-start', icon: 'AlignLeft16' },\n { label: 'Center', value: 'center', icon: 'AlignCenter16' },\n { label: 'End', value: 'flex-end', icon: 'AlignRight16' },\n ],\n defaultValue: 'flex-end',\n }),\n gutter: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Link gap',\n min: 0,\n max: 100,\n step: 1,\n defaultValue: { value: 0, unit: 'px' },\n }),\n mobileMenuAnimation: Props.ResponsiveSelect({\n label: 'Mobile menu',\n options: [\n { value: 'coverRight', label: 'Cover from right' },\n { value: 'coverLeft', label: 'Cover from left' },\n ],\n }),\n mobileMenuOpenIconColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Open icon color',\n placeholder: 'rgba(161, 168, 194, 0.5)',\n hidden,\n }\n }),\n mobileMenuCloseIconColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Close icon color',\n placeholder: 'rgba(161, 168, 194, 0.5)',\n hidden,\n }\n }),\n mobileMenuBackgroundColor: Props.ResponsiveColor((props, device) => {\n const mobileMenuAnimation = props.mobileMenuAnimation as ResponsiveValue<string>\n const hidden = !findDeviceOverride(mobileMenuAnimation, device)\n\n return {\n label: 'Menu BG color',\n placeholder: 'black',\n hidden,\n }\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin(),\n },\n })\n}\n","import { forwardRef } from 'react'\nimport styled from 'styled-components'\n\nconst PlaceholderBase = styled.div`\n width: 100%;\n background: rgba(161, 168, 194, 0.18);\n height: 80px;\n padding: 8px;\n`\n\ntype Props = Record<string, never>\n\nexport default forwardRef<HTMLDivElement, Props>(function Placeholder(props: Props, ref) {\n return (\n <PlaceholderBase {...props} ref={ref}>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"100%\"\n height=\"100%\"\n style={{ overflow: 'visible' }}\n >\n <rect\n x={0}\n y={0}\n width=\"100%\"\n height=\"100%\"\n strokeWidth={2}\n strokeDasharray=\"4 2\"\n fill=\"none\"\n stroke=\"rgba(161, 168, 194, 0.40)\"\n rx=\"4\"\n ry=\"4\"\n />\n </svg>\n </PlaceholderBase>\n )\n})\n","import styled, { createGlobalStyle } from 'styled-components'\nimport { normalize } from 'polished'\nimport { forwardRef, Ref } from 'react'\n\nimport Placeholder from './components/Placeholder'\nimport {\n GridValue,\n BackgroundsValue,\n GapXValue,\n GapYValue,\n} from '../../../prop-controllers/descriptors'\nimport { Element, ReactRuntime } from '../../../react'\nimport { cssGridItem } from '../../utils/cssMediaRules'\nimport BackgroundsContainer from '../../shared/BackgroundsContainer'\nimport { Props } from '../../../prop-controllers'\n\nconst Normalize = createGlobalStyle`\n html {\n box-sizing: border-box;\n }\n\n *, *::before, *::after {\n box-sizing: inherit;\n }\n\n ${normalize()}\n`\n\nconst Grid = styled.div`\n display: flex;\n flex-wrap: wrap;\n width: 100%;\n`\n\nconst GridItem = styled.div.withConfig({\n shouldForwardProp: prop => !['grid', 'index', 'rowGap', 'columnGap'].includes(prop.toString()),\n})`\n display: flex;\n align-items: flex-start;\n ${cssGridItem()}\n`\n\ntype Props = {\n children?: GridValue\n backgrounds?: BackgroundsValue\n rowGap?: GapYValue\n columnGap?: GapXValue\n}\n\nconst Root = forwardRef(function Page(\n { children, backgrounds, rowGap, columnGap }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <>\n <Normalize />\n <BackgroundsContainer ref={ref} style={{ background: 'white' }} backgrounds={backgrounds}>\n <Grid>\n {children && children.elements.length > 0 ? (\n children.elements.map((child, index) => (\n <GridItem\n key={child.key}\n grid={children.columns}\n index={index}\n columnGap={columnGap}\n rowGap={rowGap}\n >\n <Element element={child} />\n </GridItem>\n ))\n ) : (\n <Placeholder />\n )}\n </Grid>\n </BackgroundsContainer>\n </>\n )\n})\n\nexport default Root\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Root, {\n type: './components/Root/index.js',\n label: 'Page',\n hidden: true,\n props: {\n children: Props.Grid(),\n backgrounds: Props.Backgrounds(),\n rowGap: Props.GapY(),\n columnGap: Props.GapX(),\n },\n })\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTMuNzQxMiw4LjI5NjcgQzE0LjM1ODIsNi42Mjk3IDE0LjgzOTIsNS4yNTQ3IDE1LjE4NDIsNC4xNjg3IEMxNS41MjkyLDMuMDgzNyAxNS43MDIyLDIuNDE3NyAxNS43MDIyLDIuMTcwNyBDMTUuNzAyMiwxLjkwNDcgMTUuNjQ0MiwxLjY5ODcgMTUuNTI5MiwxLjU1MTcgQzE1LjQxNDIsMS40MDU3IDE1LjI1NjIsMS4zMzI3IDE1LjA1MzIsMS4zMzI3IEMxNC43OTYyLDEuMzMyNyAxNC41MzMyLDEuNTQ1NyAxNC4yNjYyLDEuOTcwNyBDMTMuOTk5MiwyLjM5NjcgMTMuNzA1MiwzLjA4MTcgMTMuMzgzMiw0LjAyNDcgTDEyLjAwMjIsNy45OTQ3IEwxMy43NDEyLDguMjk2NyBaIE0xMS45MDUyLDExLjk5MTcgQzExLjUxMDIsMTEuOTczNyAxMS4xMzQyLDExLjkzMjcgMTAuNzgwMiwxMS44Njc3IEMxMC40MjYyLDExLjgwNDcgMTAuMDg3MiwxMS43MTI3IDkuNzY1MiwxMS41OTM3IEM5LjkxMjIsMTEuODg2NyAxMC4wNDMyLDEyLjE3OTcgMTAuMTU4MiwxMi40NzI3IEMxMC4yNzQyLDEyLjc2NTcgMTAuMzY4MiwxMy4wNTQ3IDEwLjQ0MjIsMTMuMzM4NyBDMTAuNjYyMiwxMy4wNjM3IDEwLjg5NTIsMTIuODEzNyAxMS4xMzgyLDEyLjU4ODcgQzExLjM4MzIsMTIuMzY0NyAxMS42MzgyLDEyLjE2NTcgMTEuOTA1MiwxMS45OTE3IEwxMS45MDUyLDExLjk5MTcgWiBNMTAuMzQ1Miw3LjgyOTcgTDguODU0MiwzLjU0MzcgQzguNDY3MiwyLjQ1NDcgOC4xNjgyLDEuNzQyNyA3Ljk1NjIsMS40MDc3IEM3Ljc0NDIsMS4wNzM3IDcuNTE0MiwwLjkwNjcgNy4yNjYyLDAuOTA2NyBDNy4wNzMyLDAuOTA2NyA2LjkxNjIsMC45Nzk3IDYuNzk3MiwxLjEyNjcgQzYuNjc3MiwxLjI3MjcgNi42MTcyLDEuNDY5NyA2LjYxNzIsMS43MTY3IEM2LjYxNzIsMi4xMzg3IDYuNzc4MiwyLjg3MDcgNy4xMDAyLDMuOTE0NyBDNy40MjMyLDQuOTU4NyA3LjkwNjIsNi4zMjc3IDguNTUwMiw4LjAyMTcgQzguNjA1Miw3LjkyMTcgOC42ODMyLDcuODUwNyA4Ljc4NTIsNy44MDg3IEM4Ljg4NjIsNy43Njc3IDkuMDI0Miw3Ljc0NzcgOS4xOTkyLDcuNzQ3NyBDOS4yNTQyLDcuNzQ3NyA5LjM2NTIsNy43NTI3IDkuNTMxMiw3Ljc2MDcgQzkuNjk2Miw3Ljc3MDcgOS45NjgyLDcuNzkzNyAxMC4zNDUyLDcuODI5NyBMMTAuMzQ1Miw3LjgyOTcgWiBNOC45OTIyLDE0LjQ2MzcgQzkuMTQ4MiwxNC40NjM3IDkuMjkxMiwxNC4zOTM3IDkuNDIwMiwxNC4yNTE3IEM5LjU0OTIsMTQuMTA5NyA5LjYxMzIsMTMuOTU2NyA5LjYxMzIsMTMuNzkxNyBDOS42MTMyLDEzLjYxNzcgOS40ODcyLDEzLjIxMjcgOS4yMzQyLDEyLjU3NTcgQzguOTgwMiwxMS45Mzk3IDguNjY1MiwxMS4zMTQ3IDguMjg4MiwxMC43MDA3IEM4LjAxMjIsMTAuMjQyNyA3Ljc0MDIsOS44OTc3IDcuNDczMiw5LjY2MzcgQzcuMjA2Miw5LjQyOTcgNi45NTMyLDkuMzEzNyA2LjcxNDIsOS4zMTM3IEM2LjUyMDIsOS4zMTM3IDYuMzA2Miw5LjQzNDcgNi4wNzIyLDkuNjc2NyBDNS44MzcyLDkuOTE5NyA1LjcyMDIsMTAuMTQ2NyA1LjcyMDIsMTAuMzU3NyBDNS43MjAyLDEwLjU3NjcgNS44MzUyLDEwLjkwNjcgNi4wNjUyLDExLjM0NTcgQzYuMjk1MiwxMS43ODU3IDYuNjAzMiwxMi4yNTI3IDYuOTkwMiwxMi43NDc3IEM3LjM5NTIsMTMuMjg3NyA3Ljc3NzIsMTMuNzA4NyA4LjEzNjIsMTQuMDEwNyBDOC40OTUyLDE0LjMxMzcgOC43ODAyLDE0LjQ2MzcgOC45OTIyLDE0LjQ2MzcgTDguOTkyMiwxNC40NjM3IFogTTQuODUwMiwxNC4xMzQ3IEM0Ljk3OTIsMTQuMjkwNyA1LjE1ODIsMTQuNTE5NyA1LjM4ODIsMTQuODIxNyBDNS45OTYyLDE1LjY1NDcgNi41NTcyLDE2LjA3MTcgNy4wNzMyLDE2LjA3MTcgQzcuMjQ3MiwxNi4wNzE3IDcuNDA0MiwxNi4wMTY3IDcuNTQyMiwxNS45MDY3IEM3LjY4MDIsMTUuNzk2NyA3Ljc0OTIsMTUuNjgyNyA3Ljc0OTIsMTUuNTYzNyBDNy43NDkyLDE1LjQyNTcgNy42NTcyLDE1LjE5NjcgNy40NzMyLDE0Ljg3NjcgQzcuMjg5MiwxNC41NTU3IDcuMDM2MiwxNC4xOTQ3IDYuNzE0MiwxMy43OTE3IEM2LjM0NTIsMTMuMzI0NyA2LjAzOTIsMTIuOTgzNyA1Ljc5NjIsMTIuNzY3NyBDNS41NTIyLDEyLjU1MjcgNS4zNTYyLDEyLjQ0NDcgNS4yMDkyLDEyLjQ0NDcgQzQuODg3MiwxMi40NDQ3IDQuNTkwMiwxMi42MTY3IDQuMzE4MiwxMi45NjA3IEM0LjA0NzIsMTMuMzAzNyAzLjkxMTIsMTMuNzA4NyAzLjkxMTIsMTQuMTc1NyBDMy45MTEyLDE0LjU1MTcgNC4wMDUyLDE0Ljk3MDcgNC4xOTQyLDE1LjQzMjcgQzQuMzgzMiwxNS44OTU3IDQuNjU3MiwxNi4zNTk3IDUuMDE1MiwxNi44MjY3IEM1LjU1ODIsMTcuNTUwNyA2LjIzMzIsMTguMTA2NyA3LjAzODIsMTguNDk1NyBDNy44NDQyLDE4Ljg4NTcgOC43MzQyLDE5LjA3OTcgOS43MTAyLDE5LjA3OTcgQzExLjUwNTIsMTkuMDc5NyAxMy4wMDgyLDE4LjQxMzcgMTQuMjE4MiwxNy4wODE3IEMxNS40MjgyLDE1Ljc0ODcgMTYuMDMzMiwxNC4wNzk3IDE2LjAzMzIsMTIuMDczNyBDMTYuMDMzMiwxMS40NjA3IDE1Ljk4NzIsMTAuOTczNyAxNS44OTUyLDEwLjYxMDcgQzE1LjgwNDIsMTAuMjQ5NyAxNS42NTEyLDkuOTg1NyAxNS40MzkyLDkuODIxNyBDMTUuMDYyMiw5LjUwOTcgMTQuMzI4Miw5LjIzMDcgMTMuMjM3Miw4Ljk4MzcgQzEyLjE0NjIsOC43MzU3IDExLjAwODIsOC42MTI3IDkuODIwMiw4LjYxMjcgQzkuNDg5Miw4LjYxMjcgOS4yNTQyLDguNjY3NyA5LjExNjIsOC43Nzc3IEM4Ljk3ODIsOC44ODc3IDguOTA5Miw5LjA3NDcgOC45MDkyLDkuMzQwNyBDOC45MDkyLDkuOTYzNyA5LjI1OTIsMTAuNDE0NyA5Ljk1ODIsMTAuNjkzNyBDMTAuNjU4MiwxMC45NzM3IDExLjc5MDIsMTEuMTEyNyAxMy4zNTUyLDExLjExMjcgTDEzLjkyMTIsMTEuMTEyNyBDMTQuMDUwMiwxMS4xMTI3IDE0LjE1MzIsMTEuMTYwNyAxNC4yMzEyLDExLjI1NjcgQzE0LjMwOTIsMTEuMzUyNyAxNC4zNjMyLDExLjQ5NzcgMTQuMzkwMiwxMS42ODk3IEMxNC4yMzMyLDExLjgzNjcgMTMuOTEyMiwxMi4wMDM3IDEzLjQyNDIsMTIuMTkxNyBDMTIuOTM2MiwxMi4zNzg3IDEyLjU2MzIsMTIuNTY0NyAxMi4zMDUyLDEyLjc0NzcgQzExLjc1NDIsMTMuMTUwNyAxMS4zMDkyLDEzLjYyODcgMTAuOTczMiwxNC4xODI3IEMxMC42MzcyLDE0LjczNjcgMTAuNDY5MiwxNS4yNjA3IDEwLjQ2OTIsMTUuNzU1NyBDMTAuNDY5MiwxNi4wNTc3IDEwLjU0MDIsMTYuNDIxNyAxMC42ODMyLDE2Ljg0NzcgQzEwLjgyNjIsMTcuMjczNyAxMC44OTcyLDE3LjUzNjcgMTAuODk3MiwxNy42Mzc3IEwxMC44OTcyLDE3LjczMzcgTDEwLjg2OTIsMTcuODU3NyBDMTAuNDY1MiwxNy44Mjk3IDEwLjE0NTIsMTcuNTkzNyA5LjkxMDIsMTcuMTQ5NyBDOS42NzUyLDE2LjcwNTcgOS41NTgyLDE2LjExMjcgOS41NTgyLDE1LjM3MDcgTDkuNTU4MiwxNS4yNDc3IEM5LjQ4NDIsMTUuMzExNyA5LjQxMzIsMTUuMzU3NyA5LjM0NDIsMTUuMzg0NyBDOS4yNzUyLDE1LjQxMjcgOS4xOTkyLDE1LjQyNTcgOS4xMTYyLDE1LjQyNTcgQzkuMDMzMiwxNS40MjU3IDguOTU1MiwxNS40MTk3IDguODgyMiwxNS40MDQ3IEM4LjgwNzIsMTUuMzkxNyA4LjcyNTIsMTUuMzcwNyA4LjYzMzIsMTUuMzQzNyBDOC42NjAyLDE1LjQ0NDcgOC42ODEyLDE1LjU0MjcgOC42OTUyLDE1LjYzODcgQzguNzA5MiwxNS43MzQ3IDguNzE2MiwxNS44MTA3IDguNzE2MiwxNS44NjU3IEM4LjcxNjIsMTYuMjA0NyA4LjU4MjIsMTYuNDk1NyA4LjMxNTIsMTYuNzM3NyBDOC4wNDgyLDE2Ljk4MDcgNy43MzEyLDE3LjEwMTcgNy4zNjMyLDE3LjEwMTcgQzYuNzgzMiwxNy4xMDE3IDYuMTk0MiwxNi44MTk3IDUuNTk1MiwxNi4yNTY3IEM0Ljk5NzIsMTUuNjkzNyA0LjY5ODIsMTUuMTQyNyA0LjY5ODIsMTQuNjAxNyBDNC42OTgyLDE0LjUwMDcgNC43MTAyLDE0LjQxMTcgNC43MzMyLDE0LjMzMzcgQzQuNzU1MiwxNC4yNTU3IDQuNzk1MiwxNC4xODk3IDQuODUwMiwxNC4xMzQ3IEw0Ljg1MDIsMTQuMTM0NyBaIE0xNC43MzUyLDguNTI5NyBDMTUuNTY0Miw4LjY4NjcgMTYuMTQ4Miw5LjAzMzcgMTYuNDg5Miw5LjU3MzcgQzE2LjgyOTIsMTAuMTE0NyAxNy4wMDAyLDEwLjk2NjcgMTcuMDAwMiwxMi4xMjk3IEMxNy4wMDAyLDE0LjQzNjcgMTYuMzAzMiwxNi4zMjU3IDE0LjkwODIsMTcuNzk1NyBDMTMuNTEzMiwxOS4yNjQ3IDExLjczMDIsMTkuOTk5NyA5LjU1ODIsMTkuOTk5NyBDOC43MDIyLDE5Ljk5OTcgNy44NzEyLDE5Ljg0NjcgNy4wNjYyLDE5LjUzOTcgQzYuMjYwMiwxOS4yMzM3IDUuNTY4MiwxOC44MDQ3IDQuOTg4MiwxOC4yNTU3IEM0LjMyNTIsMTcuNjUwNyAzLjgyODIsMTcuMDEyNyAzLjQ5NzIsMTYuMzM5NyBDMy4xNjUyLDE1LjY2NjcgMy4wMDAyLDE0Ljk3NzcgMy4wMDAyLDE0LjI3MjcgQzMuMDAwMiwxMy40ODQ3IDMuMTcwMiwxMi44NzU3IDMuNTExMiwxMi40NDQ3IEMzLjg1MTIsMTIuMDE0NyA0LjM4OTIsMTEuNzIxNyA1LjEyNjIsMTEuNTY2NyBDNC45ODgyLDExLjI0NTcgNC44ODcyLDEwLjk3NTcgNC44MjIyLDEwLjc1NTcgQzQuNzU4MiwxMC41MzU3IDQuNzI1MiwxMC4zNjY3IDQuNzI1MiwxMC4yNDc3IEM0LjcyNTIsOS44MzU3IDQuOTQ0Miw5LjQxNDcgNS4zODIyLDguOTgzNyBDNS44MTkyLDguNTUyNyA2LjIzMTIsOC4zMzc3IDYuNjE3Miw4LjMzNzcgQzYuNzgzMiw4LjMzNzcgNi45NTcyLDguMzY3NyA3LjE0MjIsOC40MjY3IEM3LjMyNjIsOC40ODY3IDcuNTM3Miw4LjU4NTcgNy43NzcyLDguNzIyNyBDNy4wNjgyLDYuNzI2NyA2LjU1MzIsNS4xODU3IDYuMjMxMiw0LjEwMDcgQzUuOTA4MiwzLjAxNDcgNS43NDcyLDIuMjY2NyA1Ljc0NzIsMS44NTQ3IEM1Ljc0NzIsMS4yODY3IDUuODk0MiwwLjgzNTcgNi4xODkyLDAuNTAxNyBDNi40ODQyLDAuMTY3NyA2Ljg4NDIsLTAuMDAwMyA3LjM5MDIsLTAuMDAwMyBDOC4yNTUyLC0wLjAwMDMgOS4zNTEyLDEuOTIyNyAxMC42NzYyLDUuNzY5NyBDMTAuOTA2Miw2LjQyODcgMTEuMDgxMiw2LjkzNjcgMTEuMjAxMiw3LjI5NDcgQzExLjMwMzIsNy4wMDk3IDExLjQ0NTIsNi42MDc3IDExLjYyOTIsNi4wODU3IEMxMi45NTUyLDIuMjc1NyAxNC4wOTUyLDAuMzcwNyAxNS4wNTMyLDAuMzcwNyBDMTUuNTIyMiwwLjM3MDcgMTUuODk3MiwwLjUyODcgMTYuMTc5MiwwLjg0NDcgQzE2LjQ1OTIsMS4xNjA3IDE2LjU5OTIsMS41ODQ3IDE2LjU5OTIsMi4xMTU3IEMxNi41OTkyLDIuNTE4NyAxNi40NDUyLDMuMjU1NyAxNi4xMzcyLDQuMzI2NyBDMTUuODI4Miw1LjM5ODcgMTUuMzYxMiw2Ljc5OTcgMTQuNzM1Miw4LjUyOTcgTDE0LjczNTIsOC41Mjk3IFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguMjgxLDExLjQzODMgTDE2LjEzMiwxMC4wMDAzIEwxOC4yODEsOC41NjIzIEwxOC4yODEsMTEuNDM4MyBaIE0xMC44NTksMTcuNTM0MyBMMTAuODU5LDEzLjUyNjMgTDE0LjU4NiwxMS4wMzQzIEwxNy41OTQsMTMuMDQ1MyBMMTAuODU5LDE3LjUzNDMgWiBNMTAsMTIuMDMzMyBMNi45NjEsMTAuMDAwMyBMMTAsNy45NjYzIEwxMy4wNCwxMC4wMDAzIEwxMCwxMi4wMzMzIFogTTkuMTQxLDE3LjUzNDMgTDIuNDA3LDEzLjA0NTMgTDUuNDE1LDExLjAzNDMgTDkuMTQxLDEzLjUyNjMgTDkuMTQxLDE3LjUzNDMgWiBNMS43MTksOC41NjIzIEwzLjg2OSwxMC4wMDAzIEwxLjcxOSwxMS40MzgzIEwxLjcxOSw4LjU2MjMgWiBNOS4xNDEsMi40NjUzIEw5LjE0MSw2LjQ3NDMgTDUuNDE1LDguOTY2MyBMMi40MDcsNi45NTQzIEw5LjE0MSwyLjQ2NTMgWiBNMTAuODU5LDIuNDY1MyBMMTcuNTk0LDYuOTU0MyBMMTQuNTg2LDguOTY2MyBMMTAuODU5LDYuNDc0MyBMMTAuODU5LDIuNDY1MyBaIE0xOS45ODUsNi44MDMzIEMxOS45NDQsNi41ODAzIDE5LjgxMiw2LjM2MDMgMTkuNjE3LDYuMjM4MyBMMTAuNDc3LDAuMTQ0MyBDMTAuMTg4LC0wLjA0NzcgOS44MTIsLTAuMDQ3NyA5LjUyMywwLjE0NDMgTDAuMzgzLDYuMjM4MyBDMC4xNDgsNi4zOTQzIDAsNi42NzEzIDAsNi45NTMzIEwwLDEzLjA0NjMgQzAsMTMuMzI4MyAwLjE0OCwxMy42MDYzIDAuMzgzLDEzLjc2MTMgTDkuNTIzLDE5Ljg1NTMgQzkuNjY4LDE5Ljk1MjMgOS44MzQsMjAuMDAwMyAxMCwyMC4wMDAzIEMxMC4xNjcsMjAuMDAwMyAxMC4zMzMsMTkuOTUyMyAxMC40NzcsMTkuODU1MyBMMTkuNjE3LDEzLjc2MTMgQzE5Ljg1NCwxMy42MTMzIDIwLDEzLjMyMzMgMjAsMTMuMDQ2MyBMMjAsNi45NTMzIEMyMC4wMDEsNi45MDIzIDE5Ljk5Niw2Ljg1MzMgMTkuOTg1LDYuODAzMyBMMTkuOTg1LDYuODAzMyBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTkuNzk3LDcuOTg4MyBDMTkuNjY0LDcuMzQ0MyAxOS40NjgsNi43MTQzIDE5LjIxMiw2LjEwODMgQzE4Ljk2MSw1LjUxMzMgMTguNjUyLDQuOTQ1MyAxOC4yOSw0LjQxMDMgQzE1LjIwMywtMC4xNjg3IDguOTg4LC0xLjM3NzcgNC40MDksMS43MDkzIEMzLjM0NCwyLjQyNzMgMi40MjcsMy4zNDQzIDEuNzA5LDQuNDEwMyBDMC45NzcsNS40OTIzIDAuNDY1LDYuNzA4MyAwLjIwMiw3Ljk4ODMgQy0wLjA2Nyw5LjMxNzMgLTAuMDY3LDEwLjY4NjMgMC4yMDIsMTIuMDE1MyBDMC40NjYsMTMuMjk1MyAwLjk3OCwxNC41MTAzIDEuNzA5LDE1LjU5MzMgQzIuNDI3LDE2LjY1NzMgMy4zNDMsMTcuNTc0MyA0LjQwNywxOC4yOTIzIEM0Ljk0MywxOC42NTMzIDUuNTEyLDE4Ljk2MjMgNi4xMDcsMTkuMjE0MyBDOC41OTYsMjAuMjYxMyAxMS40MDIsMjAuMjYxMyAxMy44OTMsMTkuMjE0MyBDMTQuNDg2LDE4Ljk2MjMgMTUuMDU2LDE4LjY1MzMgMTUuNTkxLDE4LjI5MjMgQzE2LjY1NSwxNy41NzQzIDE3LjU3MiwxNi42NTgzIDE4LjI5LDE1LjU5MzMgQzE5LjAyMiwxNC41MTAzIDE5LjUzMywxMy4yOTUzIDE5Ljc5NywxMi4wMTUzIEMyMC4wNjcsMTAuNjg2MyAyMC4wNjcsOS4zMTczIDE5Ljc5Nyw3Ljk4ODMgTDE5Ljc5Nyw3Ljk4ODMgWiBNMTguNTM3LDkuOTE1MyBDMTYuNTgsOS41MjIzIDE0LjU3NSw5LjQyNzMgMTIuNTksOS42MzUzIEMxMi41MjgsOS40OTAzIDEyLjQ2OSw5LjM0MjMgMTIuNDA4LDkuMTk2MyBDMTIuMjI2LDguNzc3MyAxMi4wMzksOC4zNjMzIDExLjg0LDcuOTU2MyBDMTMuNzAxLDcuMjgwMyAxNS4zNDYsNi4xMTIzIDE2LjU5OCw0LjU3NzMgQzE3LjgzOCw2LjA4MTMgMTguNTI0LDcuOTY2MyAxOC41NCw5LjkxNTMgTDE4LjUzNyw5LjkxNTMgWiBNMTUuNjQxLDMuNTkzMyBDMTQuNDkzLDUuMDQ0MyAxMi45NDEsNi4xMjAzIDExLjE3OSw2LjY4MzMgQzEwLjIzLDQuOTUyMyA5LjE2MywzLjI4ODMgNy45ODcsMS43MDIzIEMxMC42OTMsMS4wNDMzIDEzLjU1MiwxLjc0OTMgMTUuNjQxLDMuNTkyMyBMMTUuNjQxLDMuNTkzMyBaIE02LjM1NywyLjI3OTMgQzcuNTA2LDMuODU2MyA4LjU2Niw1LjQ5OTMgOS41MjgsNy4xOTgzIEM2Ljk1NCw3Ljg3NzMgNC4zMDUsOC4yMjczIDEuNjQzLDguMjQxMyBDMi4xOTUsNS42MjYzIDMuOTM5LDMuNDE5MyA2LjM1NywyLjI3OTMgTDYuMzU3LDIuMjc5MyBaIE0xLjQ2MSwxMC4wMDAzIEMxLjQ2MSw5LjkwOTMgMS40NjUsOS44MTgzIDEuNDY4LDkuNzI3MyBDNC40MzMsOS43MzkzIDcuMzg1LDkuMzI5MyAxMC4yMzUsOC41MTAzIEMxMC40OCw4Ljk4OTMgMTAuNzE0LDkuNDc3MyAxMC45MjgsOS45NjQzIEMxMC44MTYsOS45OTQzIDEwLjcwMywxMC4wMjkzIDEwLjU5MiwxMC4wNjYzIEM3LjcwNCwxMS4xMDEzIDUuMjU0LDEzLjA5MDMgMy42NDYsMTUuNzAyMyBDMi4yMzgsMTQuMTM2MyAxLjQ2MiwxMi4xMDUzIDEuNDY1LDEwLjAwMDMgTDEuNDYxLDEwLjAwMDMgWiBNMTAuMDA1LDE4LjU0NTMgQzguMDE5LDE4LjU0ODMgNi4wOTQsMTcuODU0MyA0LjU2NSwxNi41ODczIEM0LjY3NywxNi42NzczIDQuNzU2LDE2LjczNzMgNC43NTYsMTYuNzM3MyBDNC43NTYsMTYuNzM3MyA2LjM5MywxMy4xNjczIDExLjQ1OCwxMS40MDEzIEMxMS40NzcsMTEuMzk0MyAxMS40OTcsMTEuMzg5MyAxMS41MTYsMTEuMzg0MyBDMTIuMzI3LDEzLjQ4MzMgMTIuOTM4LDE1LjY1MzMgMTMuMzM5LDE3Ljg2ODMgQzEyLjI4NCwxOC4zMTUzIDExLjE1MSwxOC41NDYzIDEwLjAwNSwxOC41NDUzIEwxMC4wMDUsMTguNTQ1MyBaIE0xNC43NzcsMTcuMDgyMyBDMTQuNCwxNS4wMDYzIDEzLjg0MywxMi45NjUzIDEzLjExNSwxMC45ODMzIEMxNC44OTYsMTAuNzE5MyAxNi43MTIsMTAuODQ2MyAxOC40MzgsMTEuMzU2MyBDMTguMDYyLDEzLjY4OTMgMTYuNzM3LDE1Ljc2MjMgMTQuNzc3LDE3LjA4MzMgTDE0Ljc3NywxNy4wODIzIFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguODk2IDBIMS4xMDRDLjQ5NCAwIDAgLjQ5NCAwIDEuMTA0djE3Ljc5MkMwIDE5LjUwNi40OTQgMjAgMS4xMDQgMjBoOS41OHYtNy43MzRIOC4wODZWOS4yMzhoMi41OThWNy4wMWMwLTIuNTgzIDEuNTc3LTMuOTg5IDMuODgxLTMuOTg5IDEuMTA0IDAgMi4wNTMuMDgyIDIuMzMuMTE5djIuNjk5bC0xLjU5LjAwMWMtMS4yNTQgMC0xLjQ5Ni41OTYtMS40OTYgMS40N3YxLjkyOGgyLjk5N2wtLjM5IDMuMDI4aC0yLjYwN1YyMGg1LjA4N2MuNjEgMCAxLjEwNC0uNDk0IDEuMTA0LTEuMTA0VjEuMTA0QzIwIC40OTQgMTkuNTA2IDAgMTguODk2IDAiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOS45OTU4LDAuMDAyOSBDNC42MDU4LC0wLjEyNTEgMC4xMzE4LDQuMTM4OSAwLjAwMjgsOS41Mjg5IEMtMC4xMDEyLDEzLjg3NzkgMi42ODU4LDE3Ljc3MDkgNi44MzU4LDE5LjA3NDkgQzcuMDkzOCwxOS4xNzU5IDcuMzgzOCwxOS4wNDg5IDcuNDg0OCwxOC43OTE5IEM3LjUwNzgsMTguNzMxOSA3LjUxOTgsMTguNjY4OSA3LjUxODgsMTguNjA0OSBDNy41MTg4LDE4LjM3MDkgNy41MDk4LDE3Ljc1NTkgNy41MDU4LDE2LjkzOTkgQzQuNzIzOCwxNy41Mjk5IDQuMTM2OCwxNS42MjY5IDQuMTM2OCwxNS42MjY5IEMzLjk0OTgsMTUuMDMyOSAzLjU1NTgsMTQuNTI0OSAzLjAyNjgsMTQuMTk1OSBDMi4xMTc4LDEzLjU4ODkgMy4wOTU4LDEzLjYwMTkgMy4wOTU4LDEzLjYwMTkgQzMuNzMzOCwxMy42ODQ5IDQuMjk3OCwxNC4wNTY5IDQuNjI2OCwxNC42MDg5IEM1LjIxMTgsMTUuNjI3OSA2LjUwNTgsMTUuOTg5OSA3LjUzNTgsMTUuNDIyOSBDNy41ODI4LDE0LjkyMzkgNy44MDg4LDE0LjQ1ODkgOC4xNzE4LDE0LjExMzkgQzUuOTUwOCwxMy44NjY5IDMuNjE3OCwxMy4wMjM5IDMuNjE3OCw5LjI3NjkgQzMuNjAzOCw4LjMwMTkgMy45NzM4LDcuMzU4OSA0LjY0NTgsNi42NTE5IEM0LjM0MDgsNS44MDg5IDQuMzc1OCw0Ljg3OTkgNC43NDM4LDQuMDYyOSBDNC43NDM4LDQuMDYyOSA1LjU4MzgsMy43OTg5IDcuNDkzOCw1LjA2MTkgQzkuMTMzOCw0LjYyMzkgMTAuODU5OCw0LjYyMzkgMTIuNTAwOCw1LjA2MTkgQzE0LjQwOTgsMy43OTU5IDE1LjI0NzgsNC4wNjI5IDE1LjI0NzgsNC4wNjI5IEMxNS42MTY4LDQuODc4OSAxNS42NTE4LDUuODA4OSAxNS4zNDY4LDYuNjUxOSBDMTYuMDE5OCw3LjM1ODkgMTYuMzg5OCw4LjMwMTkgMTYuMzc0OCw5LjI3NjkgQzE2LjM3NDgsMTMuMDM2OSAxNC4wMzY4LDEzLjg2NDkgMTEuODA4OCwxNC4xMDY5IEMxMi4yOTA4LDE0LjU4MTkgMTIuNTM4OCwxNS4yNDQ5IDEyLjQ4ODgsMTUuOTE4OSBDMTIuNDg4OCwxNy4yMjg5IDEyLjQ3NTgsMTguMjgxOSAxMi40NzU4LDE4LjYwNDkgQzEyLjQ3MTgsMTguODc4OSAxMi42ODk4LDE5LjEwNjkgMTIuOTY0OCwxOS4xMTA5IEMxMy4wMzI4LDE5LjExMTkgMTMuMDk5OCwxOS4wOTk5IDEzLjE2MzgsMTkuMDczOSBDMTguMzA3OCwxNy40NTY5IDIxLjE2NTgsMTEuOTc2OSAxOS41NDc4LDYuODMyOSBDMTguMjQxOCwyLjY4MjkgMTQuMzQ2OCwtMC4xMDMxIDkuOTk1OCwwLjAwMjkiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUuMzM4IDMuNDYyYTEuMiAxLjIgMCAxIDAgMCAyLjQgMS4yIDEuMiAwIDAgMCAwLTIuNE0xMCAxMy4zMzJhMy4zMzMgMy4zMzMgMCAxIDEgMC02LjY2NCAzLjMzMyAzLjMzMyAwIDAgMSAwIDYuNjY1bTAtOC40NjhhNS4xMzUgNS4xMzUgMCAxIDAgMCAxMC4yNyA1LjEzNSA1LjEzNSAwIDAgMCAwLTEwLjI3TTEwIDBDNy4yODQgMCA2Ljk0My4wMTIgNS44NzcuMDYgNC44MTMuMTA5IDQuMDg2LjI3OCAzLjQ1LjUyNWE0LjkxOSA0LjkxOSAwIDAgMC0xLjc3MiAxLjE1M0E0LjkwNSA0LjkwNSAwIDAgMCAuNTI1IDMuNDVDLjI3OCA0LjA4Ni4xMDkgNC44MTMuMDYgNS44NzcuMDExIDYuOTQ0IDAgNy4yODQgMCAxMHMuMDExIDMuMDU3LjA2IDQuMTIzYy4wNDkgMS4wNjUuMjE4IDEuNzkuNDY1IDIuNDI4YTQuODk4IDQuODk4IDAgMCAwIDEuMTUzIDEuNzcgNC44ODIgNC44ODIgMCAwIDAgMS43NzIgMS4xNTRjLjYzNi4yNDggMS4zNjMuNDE3IDIuNDI3LjQ2NSAxLjA2Ni4wNDggMS40MDcuMDYgNC4xMjMuMDZzMy4wNTYtLjAxMiA0LjEyMy0uMDZjMS4wNjUtLjA0OCAxLjc5MS0uMjE3IDIuNDI3LS40NjVhNC44NyA0Ljg3IDAgMCAwIDEuNzcxLTEuMTU0IDQuODg4IDQuODg4IDAgMCAwIDEuMTU0LTEuNzdjLjI0Ny0uNjM3LjQxNi0xLjM2My40NjUtMi40MjguMDQ4LTEuMDY2LjA2LTEuNDA3LjA2LTQuMTIzcy0uMDEyLTMuMDU2LS4wNi00LjEyM2MtLjA0OS0xLjA2NC0uMjE4LTEuNzkxLS40NjUtMi40MjdhNC44OTUgNC44OTUgMCAwIDAtMS4xNTQtMS43NzJBNC45MDcgNC45MDcgMCAwIDAgMTYuNTUuNTI1QzE1LjkxNC4yNzggMTUuMTg4LjEwOSAxNC4xMjMuMDYgMTMuMDU2LjAxMiAxMi43MTYgMCAxMCAwbTAgMS44MDJjMi42NyAwIDIuOTg2LjAxIDQuMDQxLjA1OC45NzUuMDQ1IDEuNTA1LjIwNyAxLjg1Ny4zNDUuNDY2LjE4Ljc5OS4zOTggMS4xNDkuNzQ4LjM1MS4zNDkuNTY3LjY4My43NDkgMS4xNDkuMTM3LjM1My4yOTkuODgyLjM0NCAxLjg1Ny4wNDggMS4wNTUuMDU4IDEuMzcuMDU4IDQuMDRzLS4wMSAyLjk4Ny0uMDU4IDQuMDQyYy0uMDQ1Ljk3NS0uMjA3IDEuNTA0LS4zNDQgMS44NTdhMy4xMSAzLjExIDAgMCAxLS43NDkgMS4xNWMtLjM1LjM1LS42ODMuNTY2LTEuMTQ5Ljc0OC0uMzUyLjEzNy0uODgyLjMtMS44NTcuMzQ0LTEuMDU1LjA0OS0xLjM3LjA1OC00LjA0MS4wNTgtMi42NyAwLTIuOTg3LS4wMS00LjA0MS0uMDU4LS45NzUtLjA0NC0xLjUwNC0uMjA3LTEuODU3LS4zNDRhMy4xMDQgMy4xMDQgMCAwIDEtMS4xNS0uNzQ4IDMuMTMzIDMuMTMzIDAgMCAxLS43NDgtMS4xNWMtLjEzNy0uMzUzLS4zLS44ODItLjM0NC0xLjg1Ny0uMDQ4LTEuMDU1LS4wNTgtMS4zNzEtLjA1OC00LjA0MSAwLTIuNjcuMDEtMi45ODYuMDU4LTQuMDQxLjA0NC0uOTc1LjIwNy0xLjUwNC4zNDQtMS44NTcuMTgyLS40NjYuMzk5LS44Ljc0OC0xLjE1LjM1LS4zNS42ODMtLjU2NiAxLjE1LS43NDcuMzUzLS4xMzguODgyLS4zIDEuODU3LS4zNDVDNy4wMTQgMS44MTIgNy4zMyAxLjgwMiAxMCAxLjgwMiIvPgo8L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMC41MTYsMTkuNjM4OSBMNC40MTIsMTkuNjM4OSBMNC40MTIsNy4yOTU5IEwwLjUxNiw3LjI5NTkgTDAuNTE2LDE5LjYzODkgWiBNMi4zNjUsNS43NTE5IEwyLjMzNyw1Ljc1MTkgQzEuMTUyLDUuODQ2OSAwLjExNCw0Ljk2MjkgMC4wMTksMy43NzY5IEMwLjAxNCwzLjcyMTkgMC4wMTIsMy42NjY5IDAuMDEyLDMuNjExOSBDLTAuMTE4LDIuMzA2OSAwLjgzNCwxLjE0MjkgMi4xNCwxLjAxMTkgQzMuNDQ2LDAuODgwOSA0LjYxLDEuODMzOSA0Ljc0LDMuMTM5OSBDNC44Nyw0LjQ0NTkgMy45MTgsNS42MDk5IDIuNjEyLDUuNzM5OSBDMi41Myw1Ljc0ODkgMi40NDcsNS43NTE5IDIuMzY1LDUuNzUxOSBMMi4zNjUsNS43NTE5IFogTTIwLDE5LjYzOTkgTDE1LjU4MywxOS42Mzk5IEwxNS41ODMsMTMuMjUxOSBDMTUuNTgzLDExLjU3OTkgMTQuODkxLDEwLjQzNTkgMTMuMzcyLDEwLjQzNTkgQzEyLjQxOCwxMC40MzU5IDExLjU2OSwxMS4wNDM5IDExLjI2MiwxMS45NDc5IEMxMS4xNzIsMTIuMjc1OSAxMS4xNCwxMi42MTc5IDExLjE3MiwxMi45NTY5IEwxMS4xNzIsMTkuNjM5OSBMNi43OTEsMTkuNjM5OSBDNi43OTEsMTkuNjM5OSA2Ljg0Nyw4LjMyNDkgNi43OTEsNy4yOTU5IEwxMS4xNjcsNy4yOTU5IEwxMS4xNjcsOS4yMzI5IEMxMS40MjYsOC4zODY5IDEyLjgyNCw3LjE3NjkgMTUuMDU1LDcuMTc2OSBDMTcuODI0LDcuMTc2OSAyMCw4Ljk1MjkgMjAsMTIuNzc1OSBMMjAsMTkuNjM5OSBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMi4zNzE2LDUuMjY0MiBDMi4zOTY2LDUuMDE2MiAyLjMwMjYsNC43NzIyIDIuMTE5Niw0LjYwNTIgTDAuMjUxNiwyLjMzOTIgTDAuMjUxNiwyLjAwMDIgTDYuMDUwNiwyLjAwMDIgTDEwLjUzMjYsMTEuOTA1MiBMMTQuNDcyNiwyLjAwMDIgTDE5Ljk5OTYsMi4wMDAyIEwxOS45OTk2LDIuMzM5MiBMMTguNDAzNiwzLjg4MTIgQzE4LjI2NTYsMy45ODcyIDE4LjE5NzYsNC4xNjAyIDE4LjIyNTYsNC4zMzIyIEwxOC4yMjU2LDE1LjY2NzIgQzE4LjE5NzYsMTUuODM5MiAxOC4yNjU2LDE2LjAxMzIgMTguNDAzNiwxNi4xMTkyIEwxOS45NjI2LDE3LjY2MTIgTDE5Ljk2MjYsMTguMDAwMiBMMTIuMTE5NiwxOC4wMDAyIEwxMi4xMTk2LDE3LjY2MTIgTDEzLjczNDYsMTYuMDgxMiBDMTMuODkzNiwxNS45MjEyIDEzLjg5MzYsMTUuODc0MiAxMy44OTM2LDE1LjYzMDIgTDEzLjg5MzYsNi40NjgyIEw5LjQwMjYsMTcuOTYyMiBMOC43OTU2LDE3Ljk2MjIgTDMuNTY2Niw2LjQ2ODIgTDMuNTY2NiwxNC4xNzIyIEMzLjUyMjYsMTQuNDk1MiAzLjYyOTYsMTQuODIxMiAzLjg1NjYsMTUuMDU2MiBMNS45NTY2LDE3LjYyNDIgTDUuOTU2NiwxNy45NjIyIEwtMC4wMDA0LDE3Ljk2MjIgTC0wLjAwMDQsMTcuNjI0MiBMMi4xMDA2LDE1LjA1NjIgQzIuMzI1NiwxNC44MjEyIDIuNDI1NiwxNC40OTMyIDIuMzcxNiwxNC4xNzIyIEwyLjM3MTYsNS4yNjQyIFoiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOS45OTQ5LC0wLjAwMDEgQzQuNDc0OSwtMC4wMDAxIC0wLjAwMDEsNC40NzU5IC0wLjAwMDEsOS45OTU5IEMtMC4wMDAxLDEzLjk2NDkgMi4zNDg5LDE3LjU1NzkgNS45ODM5LDE5LjE1MDkgQzUuOTQwOSwxOC4zODA5IDUuOTk4OSwxNy42MDk5IDYuMTU1OSwxNi44NTQ5IEM2LjM0ODksMTYuMDQzOSA3LjQ0MTksMTEuNDA5OSA3LjQ0MTksMTEuNDA5OSBDNy4yMjQ5LDEwLjkxMDkgNy4xMTY5LDEwLjM3MDkgNy4xMjI5LDkuODI2OSBDNy4xMjI5LDguMzQ1OSA3Ljk4MjksNy4yMzk5IDkuMDQ5OSw3LjIzOTkgQzkuNzg5OSw3LjIyODkgMTAuMzk3OSw3LjgxOTkgMTAuNDA4OSw4LjU1OTkgQzEwLjQwODksOC42MjA5IDEwLjQwNTksOC42ODA5IDEwLjM5ODksOC43NDA5IEMxMC4yMDU5LDkuOTQ0OSA5LjkxMDksMTEuMTI5OSA5LjUxNTksMTIuMjg0OSBDOS4zMDQ5LDEzLjExMDkgOS44MDM5LDEzLjk1MjkgMTAuNjMwOSwxNC4xNjQ5IEMxMC43ODE5LDE0LjIwMjkgMTAuOTM3OSwxNC4yMTc5IDExLjA5MzksMTQuMjA5OSBDMTIuOTg3OSwxNC4yMDk5IDE0LjI2MzksMTEuNzc3OSAxNC4yNjM5LDguODk1OSBDMTQuMjYzOSw2LjcwNTkgMTIuNzg4OSw1LjA2NTkgMTAuMTAzOSw1LjA2NTkgQzcuNDkyOSw0Ljk2MTkgNS4yOTA5LDYuOTk0OSA1LjE4NjksOS42MDU5IEM1LjE4MzksOS42ODc5IDUuMTgyOSw5Ljc2OTkgNS4xODM5LDkuODUwOSBDNS4xNTI5LDEwLjU2MzkgNS4zODc5LDExLjI2MjkgNS44NDI5LDExLjgxMjkgQzYuMDA3OSwxMS45NDc5IDYuMDY1OSwxMi4xNzI5IDUuOTg1OSwxMi4zNzA5IEM1LjkzODksMTIuNTUyOSA1LjgyODksMTIuOTk4OSA1Ljc4MjksMTMuMTcyOSBDNS43NTI5LDEzLjM2MDkgNS41NzY5LDEzLjQ4ODkgNS4zODk5LDEzLjQ1NzkgQzUuMzUxOSwxMy40NTI5IDUuMzE1OSwxMy40NDA5IDUuMjgyOSwxMy40MjI5IEMzLjg4NTksMTIuODUzOSAzLjIzNTksMTEuMzI0OSAzLjIzNTksOS42MDY5IEMzLjIzNTksNi43Njc5IDUuNjI5OSwzLjM2MDkgMTAuMzc4OSwzLjM2MDkgQzE0LjE5NDksMy4zNjA5IDE2LjcwNzksNi4xMjQ5IDE2LjcwNzksOS4wODU5IEMxNi43MDc5LDEzLjAwNjkgMTQuNTI2OSwxNS45MzY5IDExLjMxMzksMTUuOTM2OSBDMTAuMzQxOSwxNS45NjE5IDkuNDIyOSwxNS40OTM5IDguODcxOSwxNC42OTE5IEM4Ljg3MTksMTQuNjkxOSA4LjI5MTksMTYuOTk0OSA4LjE2ODksMTcuNDM4OSBDNy45MzY5LDE4LjE5NjkgNy41OTg5LDE4LjkxNjkgNy4xNjI5LDE5LjU3OTkgQzEyLjQ1NTksMjEuMTQ3OSAxOC4wMTc5LDE4LjEyNjkgMTkuNTg1OSwxMi44MzM5IEMyMS4xNTI5LDcuNTQxOSAxOC4xMzM5LDEuOTc4OSAxMi44NDA5LDAuNDExOSBDMTEuOTE2OSwwLjEzNzkgMTAuOTU4OSwtMC4wMDAxIDkuOTk0OSwtMC4wMDAxIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTMuNDM4NCwxMy4wODI1IEMxMi42MDk0LDEzLjA4MjUgMTEuOTM3NCwxMi40MTA1IDExLjkzNzQsMTEuNTgwNSBDMTEuOTM3NCwxMC43NTE1IDEyLjYwOTQsMTAuMDc5NSAxMy40Mzg0LDEwLjA3OTUgQzE0LjI2NzQsMTAuMDc5NSAxNC45NDA0LDEwLjc1MTUgMTQuOTQwNCwxMS41ODA1IEMxNC45NzM0LDEyLjQwOTUgMTQuMzI4NCwxMy4xMDc1IDEzLjUwMDQsMTMuMTQxNSBDMTMuNDc0NCwxMy4xNDI1IDEzLjQ0OTQsMTMuMTQzNSAxMy40MjM0LDEzLjE0MjUgTDEzLjQzODQsMTMuMDgyNSBaIE0xMy43MDk0LDE1LjY0OTUgQzEyLjY0MzQsMTYuNDUyNSAxMS4zMzM0LDE2Ljg2MDUgMTAuMDAwNCwxNi44MDY1IEM4LjY2NzQsMTYuODYwNSA3LjM1NjQsMTYuNDUyNSA2LjI5MjQsMTUuNjQ5NSBDNi4xNDk0LDE1LjQ3NzUgNi4xNzQ0LDE1LjIyMTUgNi4zNDg0LDE1LjA3OTUgQzYuNDk3NCwxNC45NTY1IDYuNzEyNCwxNC45NTY1IDYuODYyNCwxNS4wNzk1IEM3Ljc2NTQsMTUuNzQxNSA4Ljg2NjQsMTYuMDc1NSA5Ljk4NTQsMTYuMDI0NSBDMTEuMTA1NCwxNi4wODY1IDEyLjIxMTQsMTUuNzYzNSAxMy4xMjM0LDE1LjEwOTUgQzEzLjI4OTQsMTQuOTQ3NSAxMy41NTQ0LDE0Ljk1MDUgMTMuNzE2NCwxNS4xMTY1IEMxMy44Nzc0LDE1LjI4MjUgMTMuODc1NCwxNS41NDg1IDEzLjcwOTQsMTUuNzA5NSBMMTMuNzA5NCwxNS42NDk1IFogTTQuOTg1NCwxMS41MjA1IEM0Ljk4NTQsMTAuNjkxNSA1LjY1NzQsMTAuMDE5NSA2LjQ4NjQsMTAuMDE5NSBDNy4zMTY0LDEwLjAxOTUgNy45ODg0LDEwLjY5MTUgNy45ODg0LDExLjUyMDUgQzcuOTg4NCwxMi4zNTA1IDcuMzE2NCwxMy4wMjE1IDYuNDg2NCwxMy4wMjE1IEM1LjY1NzQsMTMuMDIxNSA0Ljk4NTQsMTIuMzUwNSA0Ljk4NTQsMTEuNTIwNSBMNC45ODU0LDExLjUyMDUgWiBNMjAuMDAwNCwxMC4wMTk1IEMxOS45NTY0LDguODA5NSAxOC45Mzg0LDcuODY0NSAxNy43Mjk0LDcuOTA5NSBDMTcuMTkxNCw3LjkyODUgMTYuNjc5NCw4LjE0NTUgMTYuMjkxNCw4LjUxODUgQzE0LjU4MzQsNy4zNTY1IDEyLjU3NTQsNi43MTU1IDEwLjUxMDQsNi42NzE1IEwxMS40ODY0LDEuOTg2NSBMMTQuNzAwNCwyLjY2MjUgQzE0Ljc4ODQsMy40ODY1IDE1LjUyODQsNC4wODM1IDE2LjM1MzQsMy45OTQ1IEMxNy4xNzc0LDMuOTA2NSAxNy43NzQ0LDMuMTY1NSAxNy42ODU0LDIuMzQxNSBDMTcuNTk2NCwxLjUxNzUgMTYuODU2NCwwLjkyMDUgMTYuMDMyNCwxLjAwOTUgQzE1LjU1NzQsMS4wNjA1IDE1LjEzNDQsMS4zMzM1IDE0Ljg5NDQsMS43NDY1IEwxMS4yMTY0LDEuMDEwNSBDMTAuOTY1NCwwLjk1NjUgMTAuNzE2NCwxLjExNDUgMTAuNjYyNCwxLjM2NTUgQzEwLjY2MjQsMS4zNjc1IDEwLjY2MTQsMS4zNjk1IDEwLjY2MTQsMS4zNzE1IEw5LjU0OTQsNi41ODE1IEM3LjQ1OTQsNi42MTI1IDUuNDI0NCw3LjI1NDUgMy42OTQ0LDguNDI4NSBDMi44MTI0LDcuNTk4NSAxLjQyNTQsNy42NDA1IDAuNTk1NCw4LjUyMjUgQy0wLjIzMzYsOS40MDQ1IC0wLjE5MTYsMTAuNzkxNSAwLjY4OTQsMTEuNjIwNSBDMC44NjI0LDExLjc4MzUgMS4wNjE0LDExLjkxNzUgMS4yNzY0LDEyLjAxNjUgQzEuMjYwNCwxMi4yMzU1IDEuMjYwNCwxMi40NTc1IDEuMjc2NCwxMi42Nzc1IEMxLjI3NjQsMTYuMDQwNSA1LjE5NTQsMTguNzcyNSAxMC4wMzA0LDE4Ljc3MjUgQzE0Ljg2NTQsMTguNzcyNSAxOC43ODM0LDE2LjA0MDUgMTguNzgzNCwxMi42Nzc1IEMxOC44MDA0LDEyLjQ1NzUgMTguODAwNCwxMi4yMzU1IDE4Ljc4MzQsMTIuMDE2NSBDMTkuNTQwNCwxMS42NDA1IDIwLjAxMjQsMTAuODYzNSAyMC4wMDA0LDEwLjAxOTUgTDIwLjAwMDQsMTAuMDE5NSBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUsMTkgQzE1LDExLjI4IDguNzIsNSAxLDUgQzAuNDQ3LDUgMCw1LjQ0OCAwLDYgQzAsNi41NTIgMC40NDcsNyAxLDcgQzcuNjE3LDcgMTMsMTIuMzgzIDEzLDE5IEMxMywxOS41NTMgMTMuNDQ3LDIwIDE0LDIwIEMxNC41NTMsMjAgMTUsMTkuNTUzIDE1LDE5IE0yMCwxOSBDMjAsOC41MjMgMTEuNDc3LDAgMSwwIEMwLjQ0NywwIDAsMC40NDggMCwxIEMwLDEuNTUyIDAuNDQ3LDIgMSwyIEMxMC4zNzQsMiAxOCw5LjYyNiAxOCwxOSBDMTgsMTkuNTUzIDE4LjQ0NywyMCAxOSwyMCBDMTkuNTUzLDIwIDIwLDE5LjU1MyAyMCwxOSBNMTAsMTkgQzEwLDE0LjAzNyA1Ljk2MywxMCAxLDEwIEMwLjQ0NywxMCAwLDEwLjQ0OCAwLDExIEMwLDExLjU1MiAwLjQ0NywxMiAxLDEyIEM0Ljg1OSwxMiA4LDE1LjE0MSA4LDE5IEM4LDE5LjU1MyA4LjQ0NywyMCA5LDIwIEM5LjU1MywyMCAxMCwxOS41NTMgMTAsMTkgTTUsMTcuNSBDNSwxOC44ODEgMy44ODEsMjAgMi41LDIwIEMxLjExOSwyMCAwLDE4Ljg4MSAwLDE3LjUgQzAsMTYuMTE5IDEuMTE5LDE1IDIuNSwxNSBDMy44ODEsMTUgNSwxNi4xMTkgNSwxNy41Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTAuMTI2MDQzOSwxOSBDMTAuMDc1MDQ1MywxOSAxMC4wMjQwNDY4LDE4Ljk5ODA4MjMgOS45NzMwNDgyLDE4Ljk5NjE2NDUgQzkuOTQxMDQ5MSwxOC45OTgwODIzIDkuOTA3MDUwMDUsMTkgOS44NzQwNTA5OCwxOSBDOC42ODkwODQyMSwxOSA3LjkyODEwNTU1LDE4LjQ4NDEyNTMgNy4xOTMxMjYxNywxNy45ODU1MTAzIEM2LjY4NTE0MDQxLDE3LjY0MTI3NDIgNi4yMDYxNTM4NSwxNy4zMTcxNzQ1IDUuNjQxMTY5NjksMTcuMjI2MDgxNCBDNS4zNjYxNzc0LDE3LjE4MjkzMiA1LjA5MTE4NTExLDE3LjE2MDg3NzkgNC44MjcxOTI1MiwxNy4xNjA4Nzc5IEM0LjM0OTIwNTkyLDE3LjE2MDg3NzkgMy45NzIyMTY1LDE3LjIzMDg3NTggMy42OTcyMjQyMSwxNy4yODI2NTUgQzMuNTMwMjI4ODksMTcuMzE0Mjk3OSAzLjM4NjIzMjkzLDE3LjM0MjEwNTMgMy4yNzcyMzU5OSwxNy4zNDIxMDUzIEMzLjE2MjIzOTIxLDE3LjM0MjEwNTMgMy4wMzgyNDI2OSwxNy4zMTcxNzQ1IDIuOTg0MjQ0MiwxNy4xNDE3MDA0IEMyLjkzODI0NTQ5LDE2Ljk4NzMyMTUgMi45MDQyNDY0NSwxNi44Mzk2NTQ4IDIuODcxMjQ3MzcsMTYuNjk2NzgyNCBDMi43ODcyNDk3MywxNi4zMjc2MTU2IDIuNzI4MjUxMzgsMTYuMTAxMzIxMSAyLjU2NjI1NTkzLDE2LjA3NjM5MDQgQzAuNjg3MzA4NjIyLDE1Ljc5ODMxNjYgMC4xNDkzMjM3MDksMTUuNDE5NTYxIDAuMDI5MzI3MDc0NywxNS4xNDkxNTgzIEMwLjAxMjMyNzU1MTQsMTUuMTEwODAzMyAwLjAwMjMyNzgzMTg4LDE1LjA3MjQ0ODMgMC4wMDAzMjc4ODc5NjksMTUuMDM0MDkzMyBDLTAuMDA1NjcxOTQzNzcsMTQuOTMxNDkzNyAwLjA3MTMyNTg5NjgsMTQuODM5NDQxNyAwLjE3NzMyMjkyNCwxNC44MjMxNDA4IEMzLjA2NjI0MTksMTQuMzY2NzE2NCA0LjM2MTIwNTU5LDExLjUzNjExNzYgNC40MTUyMDQwNywxMS40MTYyNTgzIEM0LjQxNzIwNDAyLDExLjQxMjQyMjggNC40MTgyMDM5OSwxMS40MDk1NDYxIDQuNDIwMjAzOTMsMTEuNDA1NzEwNiBDNC41OTcxOTg5NywxMS4wNjI0MzM0IDQuNjMxMTk4MDIsMTAuNzY0MjIzMyA0LjUyMzIwMTA0LDEwLjUxOTcxMDIgQzQuMzI1MjA2NiwxMC4wNzA5NTY3IDMuNjc4MjI0NzQsOS44NzQzODczOSAzLjI1MTIzNjcyLDkuNzQ0OTM5MjcgQzMuMTQ2MjM5NjYsOS43MTIzMzc1MiAzLjA0NjI0MjQ3LDkuNjgyNjEyNCAyLjk2ODI0NDY1LDkuNjUyODg3MjggQzIuMTE0MjY4Niw5LjMyODc4NzU2IDIuMDQzMjcwNTksOC45OTcwMTY4MyAyLjA3NzI2OTY0LDguODI4MjU0ODUgQzIuMTM0MjY4MDQsOC41Mzk2MzM1IDIuNTM2MjU2NzcsOC4zMzgyNjk3NiAyLjg2MTI0NzY1LDguMzM4MjY5NzYgQzIuOTUwMjQ1MTYsOC4zMzgyNjk3NiAzLjAyOTI0Mjk0LDguMzUyNjUyODkgMy4wOTUyNDEwOSw4LjM4MjM3ODAxIEMzLjQ3OTIzMDMyLDguNTU0OTc1NSAzLjgyNTIyMDYyLDguNjQyMjMzMTEgNC4xMjQyMTIyMyw4LjY0MjIzMzExIEM0LjUzNzIwMDY1LDguNjQyMjMzMTEgNC43MTcxOTU2LDguNDc2MzQ3NzUgNC43MzkxOTQ5OSw4LjQ1NDI5MzYzIEM0LjcyOTE5NTI3LDguMjY3MzEzMDIgNC43MTYxOTU2Myw4LjA3MTcwMjU0IDQuNzAyMTk2MDIsNy44NjkzNzk5MyBDNC42MTYxOTg0NCw2LjU1OTU1Njc5IDQuNTEwMjAxNDEsNC45MzIzNDYwNSA0Ljk0MjE4OTI5LDQuMDAzMTk2MjUgQzYuMjM3MTUyOTgsMS4yMTk1ODIzNiA4Ljk4MzA3NTk3LDEuMDAyODc2NjIgOS43OTQwNTMyMiwxLjAwMjg3NjYyIEM5LjgxNDA1MjY2LDEuMDAyODc2NjIgMTAuMTQ5MDQzMywxIDEwLjE0OTA0MzMsMSBMMTAuMTk3MDQxOSwxIEMxMS4wMTAwMTkxLDEgMTMuNzYxOTQxOSwxLjIxNTc0Njg2IDE1LjA1NzkwNTYsNC4wMDEyNzg1IEMxNS40ODk4OTM1LDQuOTMxMzg3MTcgMTUuMzgyODk2NSw2LjU1OTU1Njc5IDE1LjI5Njg5ODksNy44Njg0MjEwNSBMMTUuMjkyODk5LDcuOTI0OTk0NjcgQzE1LjI4MTg5OTMsOC4xMDgxMzk3OCAxNS4yNjk4OTk3LDguMjg0NTcyNzcgMTUuMjU5ODk5OSw4LjQ1NDI5MzYzIEMxNS4yODA4OTkzLDguNDczNDcxMTMgMTUuNDQ2ODk0Nyw4LjYyNzg0OTk5IDE1LjgyMDg4NDIsOC42NDEyNzQyNCBMMTUuODIwODg0Miw4LjY0MTI3NDI0IEMxNi4xMDU4NzYyLDguNjMwNzI2NjEgMTYuNDMyODY3LDguNTQ0NDI3ODcgMTYuNzkxODU3LDguMzgyMzc4MDEgQzE2Ljg5Njg1NCw4LjMzNTM5MzE0IDE3LjAxMjg1MDgsOC4zMjU4MDQzOSAxNy4wOTI4NDg1LDguMzI1ODA0MzkgQzE3LjIxMzg0NTEsOC4zMjU4MDQzOSAxNy4zMzY4NDE3LDguMzQ4ODE3MzkgMTcuNDM4ODM4OCw4LjM4OTA5MDEzIEwxNy40NDU4Mzg2LDguMzkxOTY2NzYgQzE3LjczNTgzMDUsOC40ODk3NzIgMTcuOTI1ODI1Miw4LjY4NDQyMzYxIDE3LjkyOTgyNTEsOC44ODg2NjM5NyBDMTcuOTMzODI0OSw5LjA4MDQzODk1IDE3Ljc4MDgyOTIsOS4zNjkwNjAzIDE3LjAzMTg1MDIsOS42NTI4ODcyOCBDMTYuOTUzODUyNCw5LjY4MTY1MzUzIDE2Ljg1NDg1NTIsOS43MTIzMzc1MiAxNi43NDk4NTgxLDkuNzQ0OTM5MjcgQzE2LjMyMDg3MDIsOS44NzQzODczOSAxNS42NzQ4ODgzLDEwLjA3MDk1NjcgMTUuNDc2ODkzOCwxMC41MTg3NTEzIEMxNS4zNjc4OTY5LDEwLjc2MzI2NDQgMTUuNDAyODk1OSwxMS4wNjI0MzM0IDE1LjU3OTg5MSwxMS40MDU3MTA2IEMxNS41ODA4OTA5LDExLjQwODU4NzMgMTUuNTgyODkwOSwxMS40MTI0MjI4IDE1LjU4Mzg5MDgsMTEuNDE2MjU4MyBDMTUuNjM3ODg5MywxMS41MzYxMTc2IDE2LjkzMjg1MywxNC4zNjU3NTc1IDE5LjgyMjc3MiwxNC44MjMxNDA4IEMxOS45Mjg3NjksMTQuODM5NDQxNyAyMC4wMDQ3NjY5LDE0LjkzMDUzNDggMTkuOTk5NzY3LDE1LjAzNDA5MzMgQzE5Ljk5Njc2NzEsMTUuMDcyNDQ4MyAxOS45ODY3Njc0LDE1LjExMTc2MjIgMTkuOTY5NzY3OCwxNS4xNTAxMTcyIEMxOS44NTA3NzEyLDE1LjQxNzY0MzMgMTkuMzEzNzg2MiwxNS43OTYzOTg5IDE3LjQzMzgzOSwxNi4wNzU0MzE1IEMxNy4yNzk4NDMzLDE2LjA5ODQ0NDUgMTcuMjE5ODQ1LDE2LjI5MDIxOTUgMTcuMTI4ODQ3NSwxNi42OTE5ODgxIEMxNy4wOTU4NDg0LDE2LjgzODY5NTkgMTcuMDYxODQ5NCwxNi45ODI1MjcyIDE3LjAxNDg1MDcsMTcuMTM0MDI5NCBDMTYuOTc0ODUxOCwxNy4yNjQ0MzY0IDE2Ljg4OTg1NDIsMTcuMzI2NzYzMyAxNi43NDY4NTgyLDE3LjMyNjc2MzMgTDE2LjcyMjg1ODksMTcuMzI2NzYzMyBDMTYuNjIzODYxNywxNy4zMjY3NjMzIDE2LjQ4MTg2NTcsMTcuMzA4NTQ0NiAxNi4zMDE4NzA3LDE3LjI3NDk4NCBDMTUuOTgzODc5NiwxNy4yMTY0OTI2IDE1LjYyNjg4OTYsMTcuMTYwODc3OSAxNS4xNzI5MDI0LDE3LjE2MDg3NzkgQzE0LjkwNzkwOTgsMTcuMTYwODc3OSAxNC42MzM5MTc1LDE3LjE4MjkzMiAxNC4zNTc5MjUyLDE3LjIyNjA4MTQgQzEzLjc5Mzk0MSwxNy4zMTcxNzQ1IDEzLjMxNDk1NDUsMTcuNjQxMjc0MiAxMi44MDg5Njg3LDE3Ljk4NDU1MTUgQzEyLjA3MTk4OTMsMTguNDg0MTI1MyAxMS4zMTIwMTA3LDE5IDEwLjEyNjA0MzksMTkiLz4KPC9zdmc+Cg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMCwxMy4yMyBDMCwxMy40ODIgMC4wOSwxMy42NzIgMC4yNywxMy44MDEgQzAuNDUsMTMuOTMgMC42NDIsMTMuOTc2IDAuODQ3LDEzLjkzOCBDMS4wMzksMTMuOSAxLjE3NCwxMy44MzEgMS4yNTIsMTMuNzMgQzEuMzI5LDEzLjYyOSAxLjM2OCwxMy40NjMgMS4zNjgsMTMuMjMgTDEuMzY4LDEwLjQ5NCBDMS4zNjgsMTAuMjk4IDEuMzAxLDEwLjEzMyAxLjE2OCw5Ljk5OCBDMS4wMzUsOS44NjMgMC44NzIsOS43OTQgMC42NzksOS43OTQgQzAuNDkzLDkuNzk0IDAuMzMzLDkuODYzIDAuMiw5Ljk5OCBDMC4wNjcsMTAuMTMzIDAsMTAuMjk4IDAsMTAuNDk0IEwwLDEzLjIzIFogTTIuMTQxLDE0LjQwMSBDMi4xNDEsMTQuNTg0IDIuMjA0LDE0LjcyIDIuMzMxLDE0LjgxMSBDMi40NTgsMTQuOTAzIDIuNjIxLDE0Ljk0OCAyLjgyLDE0Ljk0OCBDMy4wMjQsMTQuOTQ4IDMuMTksMTQuOTAzIDMuMzE4LDE0LjgxMSBDMy40NDUsMTQuNzIgMy41MDksMTQuNTg0IDMuNTA5LDE0LjQwMSBMMy41MDksOC4wMjEgQzMuNTA5LDcuODMyIDMuNDQyLDcuNjY5IDMuMzA5LDcuNTM0IEMzLjE3NSw3LjM5OSAzLjAxMiw3LjMzMiAyLjgyLDcuMzMyIEMyLjYzNCw3LjMzMiAyLjQ3NCw3LjM5OSAyLjM0MSw3LjUzNCBDMi4yMDcsNy42NjkgMi4xNDEsNy44MzIgMi4xNDEsOC4wMjEgTDIuMTQxLDE0LjQwMSBaIE00LjI3MSwxNC43MDMgQzQuMjcxLDE0Ljg4NSA0LjMzNywxNS4wMjIgNC40NjcsMTUuMTEzIEM0LjU5OCwxNS4yMDUgNC43NjUsMTUuMjUgNC45NywxNS4yNSBDNS4xNjgsMTUuMjUgNS4zMzEsMTUuMjA1IDUuNDU4LDE1LjExMyBDNS41ODUsMTUuMDIyIDUuNjQ5LDE0Ljg4NSA1LjY0OSwxNC43MDMgTDUuNjQ5LDguODc5IEM1LjY0OSw4LjY4NCA1LjU4Myw4LjUxOCA1LjQ0OSw4LjM3OSBDNS4zMTUsOC4yNDEgNS4xNTYsOC4xNzEgNC45Nyw4LjE3MSBDNC43NzcsOC4xNzEgNC42MTMsOC4yNDEgNC40NzcsOC4zNzkgQzQuMzQsOC41MTggNC4yNzEsOC42ODQgNC4yNzEsOC44NzkgTDQuMjcxLDE0LjcwMyBaIE02LjQxMiwxNC43MzEgQzYuNDEyLDE1LjA3NyA2LjY0MiwxNS4yNSA3LjEwMSwxNS4yNSBDNy41NiwxNS4yNSA3Ljc5LDE1LjA3NyA3Ljc5LDE0LjczMSBMNy43OSw1LjI5MyBDNy43OSw0Ljc2NCA3LjYyLDQuNDA0IDcuMzExLDQuMzY1IEM3LjEwMiw0LjMzNyA2LjkwOSw0LjMzOCA2LjcxLDQuNTA4IEM2LjUxMiw0LjY3OCA2LjQxMiw0Ljk4NSA2LjQxMiw1LjI5MyBMNi40MTIsMTQuNzMxIFogTTguNTksMTUuMDA0IEw4LjU5LDQuNzM2IEM4LjU5LDQuNDA5IDguNjg2LDQuMjE0IDguODc4LDQuMTUxIEM5LjI5NCw0LjA1IDkuNzA3LDQgMTAuMTE3LDQgQzExLjA2Niw0IDExLjk1LDQuMjI3IDEyLjc2OSw0LjY4IEMxMy41ODcsNS4xMzIgMTQuMjUsNS43NTEgMTQuNzU1LDYuNTM0IEMxNS4yNjEsNy4zMTcgMTUuNTU0LDguMTgxIDE1LjYzNSw5LjEyNSBDMTYuMDEzLDguOTYxIDE2LjQxNyw4Ljg3OSAxNi44NDUsOC44NzkgQzE3LjcxMyw4Ljg3OSAxOC40NTcsOS4xOTEgMTkuMDc0LDkuODE0IEMxOS42OTEsMTAuNDM3IDIwLDExLjE4NSAyMCwxMi4wNiBDMjAsMTIuOTQxIDE5LjY5MSwxMy42OTMgMTkuMDc0LDE0LjMxNiBDMTguNDU3LDE0LjkzOSAxNy43MTYsMTUuMjUxIDE2Ljg1NCwxNS4yNTEgTDguNzU4LDE1LjI0MSBDOC43MDIsMTUuMjIyIDguNjYsMTUuMTg3IDguNjMyLDE1LjEzNyBDOC42MDQsMTUuMDg2IDguNTksMTUuMDQyIDguNTksMTUuMDA0IEw4LjU5LDE1LjAwNCBaIi8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTAsMCBDNC40NzcsMCAwLDQuNDc3IDAsMTAgQzAsMTUuNTIyIDQuNDc3LDIwIDEwLDIwIEMxNS41MjIsMjAgMjAsMTUuNTIyIDIwLDEwIEMxOS45ODQsNC40ODQgMTUuNTE3LDAuMDE2IDEwLDAgTTE0LjYsMTQuNDU0IEMxNC40MzgsMTQuNzQgMTQuMDc1LDE0Ljg0MSAxMy43OSwxNC42NzkgQzEzLjc3NiwxNC42NzIgMTMuNzYzLDE0LjY2MyAxMy43NSwxNC42NTQgQzExLjQsMTMuMiA4LjQ1LDEyLjkwNCA0Ljk1LDEzLjcwNCBDNC42MTksMTMuNzg3IDQuMjgzLDEzLjU4NiA0LjIsMTMuMjU1IEM0LjExNywxMi45MjMgNC4zMTksMTIuNTg3IDQuNjUsMTIuNTA1IEM4LjQ1LDExLjY1NCAxMS43NSwxMi4wMDUgMTQuMzUsMTMuNjA0IEMxNC42NDcsMTMuNzQ5IDE0Ljc3MSwxNC4xMDcgMTQuNjI3LDE0LjQwNSBDMTQuNjE5LDE0LjQyMiAxNC42MDksMTQuNDM4IDE0LjYsMTQuNDU0IE0xNS44MDUsMTEuNyBDMTUuNTkxLDEyLjA1OCAxNS4xMjgsMTIuMTc0IDE0Ljc3MSwxMS45NiBDMTQuNzY2LDExLjk1NyAxNC43NiwxMS45NTMgMTQuNzU1LDExLjk1IEMxMS43MjUsMTAuMjQ3IDguMTM4LDkuODMzIDQuOCwxMC44IEM0LjM5OSwxMC45MjYgMy45NzMsMTAuNzAzIDMuODQ4LDEwLjMwMyBDMy43MjIsOS45MDIgMy45NDUsOS40NzYgNC4zNDUsOS4zNSBDOC4xMjYsOC4yNjkgMTIuMTgzLDguNzU1IDE1LjYsMTAuNyBDMTUuOTI5LDEwLjkwOSAxNi4wMjYsMTEuMzQ2IDE1LjgxNiwxMS42NzUgQzE1LjgxMiwxMS42ODQgMTUuODA2LDExLjY5MSAxNS44LDExLjcgTTE1LjksOC45IEMxMi43LDcgNy4zNSw2LjggNC4zLDcuNzUgQzMuODIzLDcuOTIgMy4yOTgsNy42NzEgMy4xMjgsNy4xOTQgQzIuOTU4LDYuNzE3IDMuMjA2LDYuMTkyIDMuNjgzLDYuMDIyIEMzLjcwNyw2LjAxNCAzLjczLDYuMDA2IDMuNzU0LDYgQzcuMzA1LDQuOTUgMTMuMTU0LDUuMTUgMTYuODU0LDcuMzUgQzE3LjMwNCw3LjYxNyAxNy40NTksOC4xOTMgMTcuMjA0LDguNjUgQzE2Ljg4Niw5LjAzMSAxNi4zNDIsOS4xMzYgMTUuOTA0LDguOSIvPgo8L3N2Zz4K\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTguNTQgMS4yTC43NzggOC40NThzLS44NC4zLS43NzQuODUyYy4wNjYuNTUzLjc1Mi44MDcuNzUyLjgwN2w0LjQ2OCAxLjU2NiAxMC43MjgtNy4wOTZzLjYyLS4zOTIuNTk3IDBjMCAwIC4xMTEuMDctLjIyLjM5MS0uMzMzLjMyNC04LjQyOSA3LjkwNC04LjQyOSA3LjkwNGwtLjU4MyA1LjE4MmMuMjQ3LjExMi40NzMtLjA2Ni40NzMtLjA2NmwyLjg4Ny0yLjc0MiA0LjUwMSAzLjU5M2MxLjIxNi41NTQgMS42Ni0uNTk4IDEuNjYtLjU5OEwyMCAxLjYzOGMwLTEuMTA2LTEuNDYtLjQzOC0xLjQ2LS40MzgiLz4KPC9zdmc+\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTUuMDgzLDE1Ljk2NSBDMTQuNTk1LDE2LjE3MyAxNC4wNzEsMTYuMjkgMTMuNTQsMTYuMzEgQzEyLjU4NSwxNi4zOCAxMS43NTQsMTUuNjY5IDExLjY4NCwxNC43MjQgQzExLjY3NCwxNC41OTYgMTEuNjc5LDE0LjQ2NyAxMS42OTgsMTQuMzQgTDExLjY5OCw4LjExNSBMMTUuNTQyLDguMTE1IEwxNS41NDIsNS4wODcgTDExLjcwNyw1LjA4NyBMMTEuNzA3LDAgTDguOTA0LDAgQzguODI3LDAuMDA4IDguNzY4LDAuMDcyIDguNzY2LDAuMTUgQzguNjY3LDIuNTE1IDcuMjAxLDQuNjEyIDUsNS41MzMgTDUsOC4xMTUgTDYuOTM3LDguMTE1IEw2LjkzNywxNC42NDggQzYuOTAzLDE3LjU2OSA5LjI2NiwxOS45NjYgMTIuMjE1LDE5Ljk5OSBDMTIuMzcyLDIwLjAwMSAxMi41MjksMTkuOTk2IDEyLjY4NywxOS45ODUgQzE0LjA5NCwxOS45NiAxNS42NTUsMTkuMzQ5IDE2LDE4LjgxNCBMMTUuMDgzLDE1Ljk2MyIvPgo8L3N2Zz4K\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMS40MDYgMEwwIDMuNDMzdjE0LjAzaDUuMDAxVjIwaDIuODEybDIuNjU2LTIuNTM3aDQuMDYzTDIwIDEyLjIzOFYwSDEuNDA2em0xLjcxOSAxLjc5MWgxNXY5LjU1MkwxNSAxNC4zMjhoLTVsLTIuNjU2IDIuNTM3di0yLjUzN0gzLjEyNVYxLjc5MXptMTAgOC42NTFoMS44NzZWNS4yMjRoLTEuODc2djUuMjE4em0tNSAwSDEwVjUuMjI0SDguMTI1djUuMjE4eiIvPgo8L3N2Zz4=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNNi4yOSAxOC4yNTRjNy41NDcgMCAxMS42NzUtNi4yNTMgMTEuNjc1LTExLjY3NSAwLS4xNzgtLjAwNC0uMzU0LS4wMTItLjUzQTguMzM5IDguMzM5IDAgMCAwIDIwIDMuOTI0YTguMTY1IDguMTY1IDAgMCAxLTIuMzU2LjY0NiA0LjEyIDQuMTIgMCAwIDAgMS44MDQtMi4yNyA4LjE5OCA4LjE5OCAwIDAgMS0yLjYwNi45OTZBNC4xMDQgNC4xMDQgMCAwIDAgOS44NSA3LjAzOWExMS42NTIgMTEuNjUyIDAgMCAxLTguNDU4LTQuMjg3IDQuMTAxIDQuMTAxIDAgMCAwIDEuMjcgNS40NzcgNC4wNTggNC4wNTggMCAwIDEtMS44NTgtLjUxM2wtLjAwMS4wNTJhNC4xMDQgNC4xMDQgMCAwIDAgMy4yOTIgNC4wMjMgNC4xMDcgNC4xMDcgMCAwIDEtMS44NTMuMDcgNC4xMDcgNC4xMDcgMCAwIDAgMy44MzMgMi44NSA4LjIzMyA4LjIzMyAwIDAgMS01LjA5NiAxLjc1N0E4LjMzIDguMzMgMCAwIDEgMCAxNi40MTFhMTEuNjE0IDExLjYxNCAwIDAgMCA2LjI5IDEuODQzIi8+Cjwvc3ZnPg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTQuNzg1IDExLjk1N2MtLjI0Ni0uMTM1LTEuNDU1LS43ODMtMS42ODMtLjg3My0uMjI2LS4wOTEtLjM5LS4xNC0uNTY4LjEwNC0uMTc3LjI0Mi0uNjc5Ljc4NC0uODMuOTQ0LS4xNTIuMTYyLS4zLjE3Ny0uNTQ2LjA0My0uMjQ2LS4xMzUtMS4wNDMtLjQyOC0xLjk2OS0xLjMxLS43MTktLjY4Ny0xLjE5Mi0xLjUyLTEuMzI5LTEuNzc0LS4xMzctLjI1NSAwLS4zODQuMTMtLjUwMy4xMTYtLjEwNy4yNjEtLjI4MS4zOTItLjQyMS4xMy0uMTQyLjE3Ni0uMjQ0LjI2Ni0uNDA2LjA5LS4xNjMuMDU0LS4zMS0uMDA1LS40MzctLjA1OC0uMTI1LS41MTItMS4zNjktLjcwMy0xLjg3NS0uMTktLjUwNS0uNC0uNDMtLjU0OC0uNDM2LS4xNDYtLjAwNS0uMzEyLS4wMzItLjQ3OS0uMDM3YS45MjUuOTI1IDAgMCAwLS42OC4yODVjLS4yNC4yNC0uOTA5LjgxOS0uOTU2IDIuMDQyLS4wNDYgMS4yMjQuODA3IDIuNDQuOTI2IDIuNjEuMTIuMTcgMS42MyAyLjgyMiA0LjE0IDMuOTEzIDIuNTEgMS4wOTEgMi41MjMuNzU4IDIuOTg0LjczNC40NjEtLjAyNCAxLjUwNS0uNTQ2IDEuNzM2LTEuMTIuMjMxLS41NzIuMjUtMS4wNy4xOTEtMS4xNzUtLjA1OS0uMTA3LS4yMjMtLjE3Ni0uNDY5LS4zMDltLTQuNjA0IDUuODk2YTguMTggOC4xOCAwIDAgMS00LjQ5Ny0xLjM0bC0zLjE0Ljk5NyAxLjAyLTMuMDExYTguMDI1IDguMDI1IDAgMCAxLTEuNTU2LTQuNzU1YzAtNC40NzQgMy42NjctOC4xMTIgOC4xNzMtOC4xMTIgNC41MDcgMCA4LjE3MyAzLjYzOCA4LjE3MyA4LjExMSAwIDQuNDcyLTMuNjY2IDguMTEtOC4xNzMgOC4xMW0wLTE3Ljg1MkM0Ljc2IDAgLjM2MyA0LjM2Mi4zNjMgOS43NDJjMCAxLjg0MS41MTUgMy41NjMgMS40MSA1LjAzTDAgMjBsNS40MzUtMS43MjdhOS44MzggOS44MzggMCAwIDAgNC43NDYgMS4yMTJjNS40MjMgMCA5LjgyLTQuMzYyIDkuODItOS43NDIgMC01LjM4MS00LjM5Ny05Ljc0NC05LjgyLTkuNzQ0Ii8+Cjwvc3ZnPg==\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNMTkuOTkyNSw1LjE1NjggQzE5LjkwNTUsNy4xODU4IDE4LjU0NjUsOS45NjA4IDE1LjkxNjUsMTMuNDc5OCBDMTMuMTk3NSwxNy4xNTk4IDEwLjg5NDUsMTguOTk5OCA5LjAxMDUsMTguOTk5OCBDNy44NDU1LDE4Ljk5OTggNi44NTk1LDE3Ljg3ODggNi4wNTM1LDE1LjYzNTggQzUuNTEzNSwxMy41NzU4IDQuOTc0NSwxMS41MTY4IDQuNDM4NSw5LjQ2MTggQzMuODM4NSw3LjIxNTggMy4xOTU1LDYuMDkxOCAyLjUwOTUsNi4wOTI4IEMxLjkzODUsNi4zMzk4IDEuNDA5NSw2LjY3MTggMC45NDA1LDcuMDc2OCBMLTAuMDAwNSw1LjgxNTggQzAuOTg1NSw0LjkxNTggMS45NTc1LDQuMDExOCAyLjkxNTUsMy4xMDY4IEM0LjIyODUsMS45MjE4IDUuMjE0NSwxLjI5NzggNS44NzM1LDEuMjM0OCBDNy40MjY1LDEuMDc2OCA4LjM4MzUsMi4xODI4IDguNzQ0NSw0LjU1MzggQzkuMTI5NSw3LjExMTggOS4zOTc1LDguNzAxOCA5LjU0ODUsOS4zMjU4IEM5Ljk5ODUsMTEuNDQ1OCAxMC40OTE1LDEyLjUwNTggMTEuMDI3NSwxMi41MDM4IEMxMS40NDU1LDEyLjUwMzggMTIuMDczNSwxMS44MTg4IDEyLjkxMTUsMTAuNDQ4OCBDMTMuNTcyNSw5LjUwNzggMTQuMDMwNSw4LjQzOTggMTQuMjU1NSw3LjMxNDggQzE0LjM3NTUsNi4xMjg4IDEzLjkyNzUsNS41Mzk4IDEyLjkxMTUsNS41Mzk4IEMxMi40MDA1LDUuNTQ0OCAxMS44OTY1LDUuNjU2OCAxMS40MzE1LDUuODY1OCBDMTIuNDE5NSwyLjUyOTggMTQuMzAzNSwwLjkwODggMTcuMDgyNSwxLjAwMzggQzE5LjE0MTUsMS4wNjM4IDIwLjExMDUsMi40NDk4IDE5Ljk4OTUsNS4xNjI4Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNNi44NjEzLDAuMzg5NiBDNi4wNTYzLDAuNTkwNiA1LjI4OTMsMC44NTY2IDQuNTYzMywxLjE3ODYgQzQuMDU5MywxLjQwMTYgMy44NzAzLDEuOTc5NiA0LjE0ODMsMi40Mjk2IEw4LjUxNzMsOS40NzU2IEM5LjAwNzMsMTAuMjY2NiAxMC4zMDUzLDkuOTQyNiAxMC4zMDUzLDkuMDI5NiBMMTAuMzA1MywwLjg5MzYgQzEwLjMwNTMsMC4zNzM2IDkuODMwMywtMC4wMzg0IDkuMjc0MywwLjAwMjYgQzguNDcyMywwLjA2MTYgNy42NjYzLDAuMTg5NiA2Ljg2MTMsMC4zODk2IE0xNy45MjAzLDkuMjc0NiBDMTcuNDI2Myw4LjIxMzYgMTYuNjk2Myw3LjI5NzYgMTUuODA1Myw2LjU2NTYgQzE1LjM3MjMsNi4yMDk2IDE0LjcwMTMsNi4yOTE2IDE0LjM3ODMsNi43Mzc2IEwxMS43NzczLDEwLjMyNzYgQzExLjI3NzMsMTEuMDE3NiAxMS45NzYzLDExLjkxMjYgMTIuODM2MywxMS42ODM2IEwxNy4zMDUzLDEwLjQ5MDYgQzE3Ljg2MzMsMTAuMzQxNiAxOC4xNTAzLDkuNzY5NiAxNy45MjAzLDkuMjc0NiBNMTEuNzAwMywxNC40Mzg2IEwxNC4xNjUzLDE4LjExMTYgQzE0LjQ3MjMsMTguNTY5NiAxNS4xNDIzLDE4LjY2OTYgMTUuNTkwMywxOC4zMjY2IEMxNi41MjkzLDE3LjYwNDYgMTcuMjgyMywxNi43MDA2IDE3LjgwMDMsMTUuNjg4NiBDMTguMDQ5MywxNS4yMDI2IDE3Ljc4MTMsMTQuNjIxNiAxNy4yMzEzLDE0LjQ1NDYgTDEyLjgwOTMsMTMuMTE3NiBDMTEuOTU4MywxMi44NTk2IDExLjIyNjMsMTMuNzMyNiAxMS43MDAzLDE0LjQzODYgTTUuNjAxMywxOC43MzI2IEM2LjU5NDMsMTkuMzY3NiA3LjczMTMsMTkuNzk5NiA4LjkzMzMsMTkuOTg3NiBDOS41MDUzLDIwLjA3NjYgMTAuMDMxMywxOS42Nzc2IDEwLjA1MTMsMTkuMTM3NiBMMTAuMjE0MywxNC44MDk2IEMxMC4yNDUzLDEzLjk3NjYgOS4xNDIzLDEzLjU2MjYgOC41NDQzLDE0LjE4MTYgTDUuNDMyMywxNy4zOTk2IEM1LjA0NjMsMTcuNzk5NiA1LjEyNTMsMTguNDI2NiA1LjYwMTMsMTguNzMyNiBNMy43NTkzLDkuMzg2NiBMNy45MzkzLDExLjI4NTYgQzguNzQzMywxMS42NTA2IDguNjE5MywxMi43NTA2IDcuNzUxMywxMi45NTI2IEwzLjIzOTMsMTMuOTk5NiBDMi42NzYzLDE0LjEzMDYgMi4xMjEzLDEzLjc2OTYgMi4wNTQzLDEzLjIzMjYgQzEuOTEyMywxMi4wODQ2IDIuMDUyMywxMC45NTE2IDIuNDMxMyw5LjkwMjYgQzIuNjE1Myw5LjM5MjYgMy4yNDAzLDkuMTUxNiAzLjc1OTMsOS4zODY2Ii8+Cjwvc3ZnPgo=\"","export default \"data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgdmlld0JveD0iMCAwIDIwIDIwIj4KICA8cGF0aCBkPSJNOCwxMyBMOCw3IEwxMywxMCBMOCwxMyBaIE0xOS41ODIsNS4xODYgQzE5LjM1Myw0LjMyNiAxOC42NzUsMy42NDggMTcuODEzLDMuNDE4IEMxNi4yNTQsMyAxMCwzIDEwLDMgQzEwLDMgMy43NDYsMyAyLjE4NiwzLjQxOCBDMS4zMjYsMy42NDggMC42NDgsNC4zMjYgMC40MTgsNS4xODYgQzAsNi43NDYgMCwxMCAwLDEwIEMwLDEwIDAsMTMuMjU0IDAuNDE4LDE0LjgxMyBDMC42NDgsMTUuNjc1IDEuMzI2LDE2LjM1MyAyLjE4NiwxNi41ODIgQzMuNzQ2LDE3IDEwLDE3IDEwLDE3IEMxMCwxNyAxNi4yNTQsMTcgMTcuODEzLDE2LjU4MiBDMTguNjc1LDE2LjM1MyAxOS4zNTMsMTUuNjc1IDE5LjU4MiwxNC44MTMgQzIwLDEzLjI1NCAyMCwxMCAyMCwxMCBDMjAsMTAgMjAsNi43NDYgMTkuNTgyLDUuMTg2IEwxOS41ODIsNS4xODYgWiIvPgo8L3N2Zz4K\"","import { ReactComponent as LogoAngellist20 } from '../../icons/logo-angellist-20.svg'\nimport { ReactComponent as LogoCodepen20 } from '../../icons/logo-codepen-20.svg'\nimport { ReactComponent as LogoDribbble20 } from '../../icons/logo-dribbble-20.svg'\nimport { ReactComponent as LogoFacebook20 } from '../../icons/logo-facebook-20.svg'\nimport { ReactComponent as LogoGithub20 } from '../../icons/logo-github-20.svg'\nimport { ReactComponent as LogoInstagram20 } from '../../icons/logo-instagram-20.svg'\nimport { ReactComponent as LogoLinkedin20 } from '../../icons/logo-linkedin-20.svg'\nimport { ReactComponent as LogoMedium20 } from '../../icons/logo-medium-20.svg'\nimport { ReactComponent as LogoPinterest20 } from '../../icons/logo-pinterest-20.svg'\nimport { ReactComponent as LogoReddit20 } from '../../icons/logo-reddit-20.svg'\nimport { ReactComponent as LogoRss20 } from '../../icons/logo-rss-20.svg'\nimport { ReactComponent as LogoSnapchat20 } from '../../icons/logo-snapchat-20.svg'\nimport { ReactComponent as LogoSoundcloud20 } from '../../icons/logo-soundcloud-20.svg'\nimport { ReactComponent as LogoSpotify20 } from '../../icons/logo-spotify-20.svg'\nimport { ReactComponent as LogoTelegram20 } from '../../icons/logo-telegram-20.svg'\nimport { ReactComponent as LogoTumblr20 } from '../../icons/logo-tumblr-20.svg'\nimport { ReactComponent as LogoTwitch20 } from '../../icons/logo-twitch-20.svg'\nimport { ReactComponent as LogoTwitter20 } from '../../icons/logo-twitter-20.svg'\nimport { ReactComponent as LogoWhatsapp20 } from '../../icons/logo-whatsapp-20.svg'\nimport { ReactComponent as LogoVimeo20 } from '../../icons/logo-vimeo-20.svg'\nimport { ReactComponent as LogoYelp20 } from '../../icons/logo-yelp-20.svg'\nimport { ReactComponent as LogoYoutube20 } from '../../icons/logo-youtube-20.svg'\n\nexport const SocialLinksOptions = [\n { type: 'angellist', label: 'AngelList', icon: <LogoAngellist20 />, brandColor: 'black' },\n { type: 'codepen', label: 'CodePen', icon: <LogoCodepen20 />, brandColor: 'black' },\n { type: 'dribbble', label: 'Dribbble', icon: <LogoDribbble20 />, brandColor: '#ea4c89' },\n { type: 'facebook', label: 'Facebook', icon: <LogoFacebook20 />, brandColor: '#3b5998' },\n { type: 'github', label: 'GitHub', icon: <LogoGithub20 />, brandColor: 'black' },\n { type: 'instagram', label: 'Instagram', icon: <LogoInstagram20 />, brandColor: 'black' },\n { type: 'linkedin', label: 'LinkedIn', icon: <LogoLinkedin20 />, brandColor: '#0077b5' },\n { type: 'medium', label: 'Medium', icon: <LogoMedium20 />, brandColor: 'black' },\n { type: 'pinterest', label: 'Pinterest', icon: <LogoPinterest20 />, brandColor: '#bd081c' },\n { type: 'reddit', label: 'Reddit', icon: <LogoReddit20 />, brandColor: '#ff4500' },\n { type: 'rss', label: 'RSS', icon: <LogoRss20 />, brandColor: 'black' },\n { type: 'snapchat', label: 'Snapchat', icon: <LogoSnapchat20 />, brandColor: '#fffc00' },\n { type: 'soundcloud', label: 'SoundCloud', icon: <LogoSoundcloud20 />, brandColor: '#ff3300' },\n { type: 'spotify', label: 'Spotify', icon: <LogoSpotify20 />, brandColor: '#1db954' },\n { type: 'telegram', label: 'Telegram', icon: <LogoTelegram20 />, brandColor: '#0088cc' },\n { type: 'tumblr', label: 'Tumblr', icon: <LogoTumblr20 />, brandColor: '#35465c' },\n { type: 'twitch', label: 'Twitch', icon: <LogoTwitch20 />, brandColor: '#6441A4' },\n { type: 'twitter', label: 'Twitter', icon: <LogoTwitter20 />, brandColor: '#1da1f2' },\n { type: 'whatsapp', label: 'WhatsApp', icon: <LogoWhatsapp20 />, brandColor: '#25d366' },\n { type: 'vimeo', label: 'Vimeo', icon: <LogoVimeo20 />, brandColor: '#1ab7ea' },\n { type: 'yelp', label: 'Yelp', icon: <LogoYelp20 />, brandColor: '#af0606' },\n { type: 'youtube', label: 'YouTube', icon: <LogoYoutube20 />, brandColor: '#ff0000' },\n] as const\n","import styled from 'styled-components'\n\nimport { ResponsiveValue, Length } from '../../../../../prop-controllers/descriptors'\n\nimport GutterContainer from '../../../../shared/GutterContainer'\n\nconst PlaceholderLink = styled.div`\n width: 44px;\n height: 44px;\n border-radius: 50%;\n background-color: rgba(161, 168, 194, 0.4);\n`\n\nconst links = [{ id: '1' }, { id: '2' }, { id: '3' }]\n\ntype Props = { gutter?: ResponsiveValue<Length> }\n\nexport default function SocialLinksPlaceholder({ gutter }: Props): JSX.Element {\n return (\n <>\n {links.map((link, i) => (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n <PlaceholderLink />\n </GutterContainer>\n ))}\n </>\n )\n}\n","import { forwardRef, Ref } from 'react'\nimport styled, { css } from 'styled-components'\nimport { cx } from '@emotion/css'\n\nimport { Link } from '../../shared/Link'\nimport { cssMediaRules, cssMargin } from '../../utils/cssMediaRules'\nimport { colorToString } from '../../utils/colorToString'\nimport { ColorValue as Color } from '../../utils/types'\nimport { SocialLinksOptions } from './options'\nimport GutterContainer from '../../shared/GutterContainer'\nimport SocialLinksPlaceholder from './components/SocialLinksPlaceholder'\nimport {\n ResponsiveValue,\n ElementIDValue,\n SocialLinksValue,\n ResponsiveIconRadioGroupValue,\n ResponsiveSelectValue,\n GapXValue,\n MarginValue,\n} from '../../../prop-controllers/descriptors'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\nimport { ResponsiveColor } from '../../../runtimes/react/controls'\n\ntype Props = {\n id?: ElementIDValue\n links?: SocialLinksValue\n shape?: ResponsiveIconRadioGroupValue<'naked' | 'circle' | 'rounded' | 'square'>\n size?: ResponsiveIconRadioGroupValue<'small' | 'medium' | 'large'>\n hoverStyle?: ResponsiveSelectValue<'none' | 'grow' | 'shrink' | 'fade'>\n fill?: ResponsiveColor | null\n backgroundColor?: ResponsiveColor | null\n alignment?: ResponsiveIconRadioGroupValue<'flex-start' | 'center' | 'flex-end'>\n gutter?: GapXValue\n width?: string\n margin?: MarginValue\n}\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['width', 'margin', 'alignment'].includes(prop.toString()),\n})<{\n margin: Props['margin']\n alignment: Props['alignment']\n}>`\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n ${cssMargin()}\n ${p =>\n cssMediaRules(\n [p.alignment] as const,\n ([alignment = 'center']) => css`\n justify-content: ${alignment};\n `,\n )}\n`\n\nconst StyledLink = styled(Link).withConfig({\n shouldForwardProp: prop =>\n !['brandColor', 'shape', 'size', 'hoverStyle', 'fill', 'backgroundColor'].includes(\n prop.toString(),\n ),\n})<{\n brandColor: string\n shape: Props['shape']\n size: Props['size']\n hoverStyle: Props['hoverStyle']\n fill: ResponsiveValue<Color> | null | undefined\n backgroundColor: ResponsiveValue<Color> | null | undefined\n}>`\n display: block;\n color: ${props => props.brandColor};\n transition: transform, opacity 0.18s;\n\n svg {\n display: block;\n }\n\n ${p =>\n cssMediaRules(\n [p.shape, p.size, p.hoverStyle, p.fill, p.backgroundColor] as const,\n ([shape = 'naked', size = 'medium', hoverStyle = 'none', fill, backgroundColor]) => css`\n padding: ${shape === 'naked' ? 0 : { small: 10, medium: 12, large: 14 }[size]}px;\n border-radius: ${{ circle: '50%', rounded: '8px', naked: 0, square: 0 }[shape]};\n background: ${shape === 'naked'\n ? 'transparent'\n : backgroundColor == null\n ? 'currentColor'\n : colorToString(backgroundColor)};\n\n :hover {\n ${{\n none: '',\n grow: css`\n transform: scale(1.1);\n `,\n shrink: css`\n transform: scale(0.9);\n `,\n fade: css`\n opacity: 0.65;\n `,\n }[hoverStyle]}\n }\n\n svg {\n fill: ${fill == null\n ? shape === 'naked' || backgroundColor != null\n ? 'currentColor'\n : 'white'\n : colorToString(fill)};\n width: ${{ small: 16, medium: 20, large: 24 }[size]}px;\n height: ${{ small: 16, medium: 20, large: 24 }[size]}px;\n }\n `,\n )}\n`\n\nconst SocialLinks = forwardRef(function SocialLinks(\n {\n id,\n links: { links, openInNewTab } = { links: [], openInNewTab: false },\n shape,\n size,\n hoverStyle,\n fill,\n backgroundColor,\n alignment,\n gutter,\n width,\n margin,\n }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <Container ref={ref} id={id} className={cx(width)} alignment={alignment} margin={margin}>\n {links.length > 0 ? (\n links.map((link, i) => {\n const option = SocialLinksOptions.find(o => o.type === link.payload.type)\n\n if (!option) throw new Error(`Invalid link payload type ${link.payload.type}`)\n\n return (\n <GutterContainer\n key={link.id}\n gutter={gutter}\n first={i === 0}\n last={i === links.length - 1}\n >\n <StyledLink\n backgroundColor={backgroundColor}\n brandColor={option.brandColor}\n fill={fill}\n hoverStyle={hoverStyle}\n link={{ type: 'OPEN_URL', payload: { url: link.payload.url, openInNewTab } }}\n shape={shape}\n size={size}\n >\n {option == null ? null : option.icon}\n </StyledLink>\n </GutterContainer>\n )\n })\n ) : (\n <SocialLinksPlaceholder gutter={gutter} />\n )}\n </Container>\n )\n})\n\nexport default SocialLinks\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(SocialLinks, {\n type: './components/SocialLinks/index.js',\n label: 'Social Links',\n icon: 'SocialLinks40',\n props: {\n id: Props.ElementID(),\n links: Props.SocialLinks({\n preset: {\n links: [\n {\n id: 'facebook',\n payload: { type: 'facebook', url: 'https://www.facebook.com' },\n },\n {\n id: 'instagram',\n payload: { type: 'instagram', url: 'https://www.instagram.com' },\n },\n {\n id: 'twitter',\n payload: { type: 'twitter', url: 'https://www.twitter.com' },\n },\n ],\n openInNewTab: false,\n },\n }),\n shape: Props.ResponsiveIconRadioGroup(props => {\n const links = props.links as SocialLinksValue\n\n return {\n label: 'Shape',\n options: [\n { label: 'Naked', value: 'naked', icon: 'Star16' },\n { label: 'Circle', value: 'circle', icon: 'StarCircle16' },\n { label: 'Rounded', value: 'rounded', icon: 'StarRoundedSquare16' },\n { label: 'Square', value: 'square', icon: 'StarSquare16' },\n ],\n defaultValue: 'naked',\n hidden: links == null || links.links.length === 0,\n }\n }),\n size: Props.ResponsiveIconRadioGroup(props => {\n const links = props.links as SocialLinksValue\n\n return {\n label: 'Size',\n options: [\n { label: 'Small', value: 'small', icon: 'SizeSmall16' },\n { label: 'Medium', value: 'medium', icon: 'SizeMedium16' },\n { label: 'Large', value: 'large', icon: 'SizeLarge16' },\n ],\n defaultValue: 'medium',\n hidden: links == null || links.links.length === 0,\n }\n }),\n hoverStyle: Props.ResponsiveSelect(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'On hover',\n options: [\n { value: 'none', label: 'None' },\n { value: 'grow', label: 'Grow' },\n { value: 'shrink', label: 'Shrink' },\n { value: 'fade', label: 'Fade' },\n ],\n defaultValue: 'none',\n labelOrientation: 'horizontal',\n hidden,\n }\n }),\n fill: Props.ResponsiveColor(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'Icon color',\n hidden,\n }\n }),\n backgroundColor: Props.ResponsiveColor(props => {\n const links = props.links as SocialLinksValue\n const hidden = links == null || links.links.length === 0\n\n return {\n label: 'Shape color',\n hidden,\n }\n }),\n alignment: Props.ResponsiveIconRadioGroup({\n label: 'Alignment',\n options: [\n { label: 'flex-start', value: 'flex-start', icon: 'AlignLeft16' },\n { label: 'center', value: 'center', icon: 'AlignCenter16' },\n { label: 'flex-end', value: 'flex-end', icon: 'AlignRight16' },\n ],\n defaultValue: 'center',\n }),\n gutter: Props.GapX({\n preset: [{ deviceId: 'desktop', value: { value: 10, unit: 'px' } }],\n label: 'Link gap',\n min: 0,\n max: 100,\n step: 1,\n defaultValue: { value: 0, unit: 'px' },\n }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n marginTop: { value: 10, unit: 'px' },\n marginRight: 'auto',\n marginBottom: { value: 10, unit: 'px' },\n marginLeft: 'auto',\n },\n },\n ],\n }),\n },\n })\n}\n","import type { ColorValue } from '../utils/types'\nimport type { Length as LengthValue } from '../../prop-controllers'\nimport { DeviceOverride } from '../../prop-controllers'\nimport { TYPOGRAPHIES_BY_ID } from '../utils/queries'\nimport { useQuery } from '../../api/react'\n\nexport type TypographyStyleValue = {\n fontFamily?: string\n fontWeight?: number\n fontSize?: LengthValue\n color?: ColorValue\n textAlign?: string\n lineHeight?: number\n letterSpacing?: number\n uppercase?: boolean\n underline?: boolean\n strikethrough?: boolean\n italic?: boolean\n}\n\nexport type TypographyStyle = Array<DeviceOverride<TypographyStyleValue>>\n\nexport type Typography = {\n id: string\n name: string\n style: TypographyStyle\n}\n\nexport function useTypography(\n typographyId: string | null | undefined,\n): Typography | null | undefined {\n const { error, data } = useQuery(TYPOGRAPHIES_BY_ID, {\n skip: typographyId == null,\n variables: { ids: typographyId != null ? [typographyId] : [] },\n })\n\n if (typographyId == null || error != null) return null\n\n return data?.typographies[0] as Typography | null\n}\n","import { Length as LengthValue } from '../../../../../../../../prop-controllers'\nimport { ColorValue as Color } from '../../../../../../../utils/types'\nimport { findDeviceOverride } from '../../../../../../../utils/devices'\nimport type { DeviceOverride } from '../../../../../../../../prop-controllers'\nimport { SWATCHES_BY_ID } from '../../../../../../../utils/queries'\nimport { useTypography, TypographyStyle } from '../../../../../../../hooks/useTypography'\nimport { useQuery } from '../../../../../../../../api/react'\n\nexport type TypographyMarkDataValue = {\n fontWeight?: number\n fontSize?: LengthValue\n fontFamily?: string\n color?: Color\n textAlign?: string\n lineHeight?: number\n letterSpacing?: number\n uppercase?: boolean\n italic?: boolean\n underline?: boolean\n strikethrough?: boolean\n}\n\nexport type TypographyMarkValue = {\n id: string | null | undefined\n style: TypographyStyle\n}\n\nexport type TypographyMarkData = Array<DeviceOverride<TypographyMarkDataValue>>\n\nconst concat = <A extends unknown[], B extends unknown[]>(a: A, b: B) => a.concat(b)\nconst getSwatchId = ({ value: { color } }: any) => color && color.swatchId\nconst getDeviceId = ({ deviceId }: any) => deviceId\n\nconst withColor =\n (swatches: any) =>\n ({ value: { color, ...restOfValue }, ...rest }: any) => ({\n ...rest,\n value: {\n ...restOfValue,\n ...(color\n ? {\n color: {\n swatch: swatches.find((s: any) => s && s.id === color.swatchId),\n alpha: color.alpha,\n },\n }\n : {}),\n },\n })\n\nexport const overrideTypographyStyle = <A>(\n source: Array<DeviceOverride<A>>,\n override: Array<DeviceOverride<A>>,\n): Array<DeviceOverride<A>> => {\n const devices = [...new Set(source.map(getDeviceId).concat(override.map(getDeviceId)))]\n\n return devices.map((deviceId: any) => ({\n deviceId,\n value: {\n ...(findDeviceOverride(source, deviceId) || { value: {} }).value,\n ...(findDeviceOverride(override, deviceId, v => v) || { value: {} }).value,\n },\n })) as DeviceOverride<A>[]\n}\n\nexport default function useTypographyMark(\n value: TypographyMarkValue | null | undefined,\n): TypographyMarkData | null | undefined {\n const typography = useTypography(value && value.id)\n\n const swatchIds = [\n (typography && typography.style.map(getSwatchId)) || [],\n (value && value.style.map(getSwatchId)) || [],\n ]\n .reduce(concat)\n .filter(Boolean)\n\n const { error: colorError, data: colorData = {} } = useQuery(SWATCHES_BY_ID, {\n skip: swatchIds == null || swatchIds.length === 0,\n variables: { ids: swatchIds },\n })\n\n const { swatches = [] } = colorData\n\n if (colorError != null) return null\n\n return overrideTypographyStyle(\n (typography && typography.style.map(withColor(swatches))) || [],\n (value && value.style.map(withColor(swatches))) || [],\n )\n}\n","import { ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport useTypographyMark, {\n TypographyMarkValue,\n TypographyMarkData,\n overrideTypographyStyle,\n TypographyMarkDataValue,\n} from './hooks/useTypographyMark'\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport { colorToString } from '../../../../../../utils/colorToString'\nimport { shallowMergeFallbacks } from '../../../../../../utils/devices'\n\nexport type { TypographyMarkValue }\nexport { overrideTypographyStyle }\n\nconst Span = styled.span<{ typographyStyle: TypographyMarkData | null | undefined }>`\n ${p =>\n cssMediaRules(\n [p.typographyStyle] as const,\n ([\n {\n color,\n fontFamily,\n fontSize,\n fontWeight,\n lineHeight,\n letterSpacing,\n uppercase,\n underline,\n strikethrough,\n italic,\n } = {} as TypographyMarkDataValue,\n ]) => css`\n ${color == null\n ? ''\n : css`\n color: ${colorToString(color)};\n `}\n\n ${fontFamily == null\n ? ''\n : css`\n font-family: '${fontFamily}';\n `}\n\n ${fontSize == null || fontSize.value == null || fontSize.unit == null\n ? ''\n : css`\n font-size: ${`${fontSize.value}${fontSize.unit}`};\n `}\n\n ${fontWeight == null\n ? ''\n : css`\n font-weight: ${fontWeight};\n `}\n\n ${lineHeight == null\n ? ''\n : css`\n line-height: ${lineHeight};\n `}\n\n ${letterSpacing == null\n ? ''\n : css`\n letter-spacing: ${letterSpacing / 10}em;\n `}\n\n ${underline == null && strikethrough == null\n ? ''\n : css`\n text-decoration: ${[\n Boolean(underline) && 'underline',\n Boolean(strikethrough) && 'line-through',\n ]\n .filter(Boolean)\n .join(' ')};\n `}\n\n ${uppercase == null\n ? ''\n : css`\n text-transform: ${uppercase === true ? 'uppercase' : 'initial'};\n `}\n\n ${italic == null\n ? ''\n : css`\n font-style: ${italic === true ? 'italic' : 'initial'};\n `}\n `,\n shallowMergeFallbacks,\n )}\n`\n\ntype BaseProps = { value: TypographyMarkValue }\n\ntype Props = BaseProps & Omit<ComponentPropsWithoutRef<typeof Span>, keyof BaseProps>\n\nexport default function Mark({ value, ...restOfProps }: Props): JSX.Element {\n const typographyStyle = useTypographyMark(value)\n\n return <Span {...restOfProps} typographyStyle={typographyStyle} />\n}\n","import type { Plugin } from 'slate-react'\n\nimport Mark from '../components/Mark'\n\nconst TYPOGRAPHY_TYPE = 'typography'\n\nexport default function DeviceOverridesMarksPlugin(): Plugin {\n return {\n renderMark({ mark, children }, _editor, next) {\n if (mark.type === TYPOGRAPHY_TYPE) {\n return <Mark value={mark.data.get('value')}>{children}</Mark>\n }\n\n return next()\n },\n }\n}\n","import { forwardRef, ElementType, ComponentPropsWithoutRef } from 'react'\nimport styled, { css } from 'styled-components'\n\nimport { cssMediaRules } from '../../../../../../utils/cssMediaRules'\nimport type { ResponsiveValue } from '../../../../../../../prop-controllers'\n\ntype StyledBlockProps = {\n textAlign?: ResponsiveValue<'left' | 'center' | 'right' | 'justify'>\n as?: ElementType\n}\n\nconst StyledBlock = styled.div<StyledBlockProps>`\n margin: 0;\n ${p =>\n cssMediaRules([p.textAlign] as const, ([textAlign]) =>\n textAlign == null\n ? css``\n : css`\n text-align: ${textAlign};\n `,\n )}\n\n ${p =>\n p.as === 'blockquote'\n ? css`\n padding: 0.5em 10px;\n font-size: 1.25em;\n font-weight: 300;\n border-left: 5px solid rgba(0, 0, 0, 0.1);\n `\n : ''}\n`\n\ntype Props = ComponentPropsWithoutRef<typeof StyledBlock>\n\nexport default forwardRef<HTMLDivElement, Props>(function Block(\n { textAlign, ...restOfProps }: Props,\n ref,\n) {\n return <StyledBlock {...restOfProps} ref={ref} textAlign={textAlign} />\n})\n","import { Plugin } from 'slate-react'\n\nimport Block from '../components/Block'\n\nexport default function DeviceOverridesBlockPlugin(): Plugin {\n return {\n renderBlock(props, _editor, next): JSX.Element {\n const { node, attributes, children } = props\n const blockProps = { textAlign: node.data.get('textAlign') }\n\n switch (node.type) {\n case 'paragraph':\n return (\n <Block {...attributes} {...blockProps} as=\"p\">\n {children}\n </Block>\n )\n\n case 'heading-one':\n return (\n <Block {...attributes} {...blockProps} as=\"h1\">\n {children}\n </Block>\n )\n\n case 'heading-two':\n return (\n <Block {...attributes} {...blockProps} as=\"h2\">\n {children}\n </Block>\n )\n\n case 'heading-three':\n return (\n <Block {...attributes} {...blockProps} as=\"h3\">\n {children}\n </Block>\n )\n\n case 'heading-four':\n return (\n <Block {...attributes} {...blockProps} as=\"h4\">\n {children}\n </Block>\n )\n\n case 'heading-five':\n return (\n <Block {...attributes} {...blockProps} as=\"h5\">\n {children}\n </Block>\n )\n\n case 'heading-six':\n return (\n <Block {...attributes} {...blockProps} as=\"h6\">\n {children}\n </Block>\n )\n\n case 'blockquote':\n return (\n <Block {...attributes} {...blockProps} as=\"blockquote\">\n {children}\n </Block>\n )\n\n default:\n return next()\n }\n },\n }\n}\n","import { Plugin } from 'slate-react'\nimport styled from 'styled-components'\n\nimport { Link } from '../../../../../shared/Link'\n\nconst StyledLink = styled(Link)`\n text-decoration: none;\n`\n\nexport default function LinkPlugin(): Plugin {\n return {\n renderInline(props, _editor, next) {\n const { attributes, children, node } = props\n\n switch (node.type) {\n case 'link': {\n const { data } = node\n\n return (\n <StyledLink {...attributes} link={data.toJS()}>\n {children}\n </StyledLink>\n )\n }\n\n default: {\n return next()\n }\n }\n },\n }\n}\n","import { Plugin } from 'slate-react'\n\nexport default function Inlines(): Plugin {\n return {\n renderInline(props, _editor, next) {\n const { attributes, children, node } = props\n\n switch (node.type) {\n case 'code': {\n return <code {...attributes}>{children}</code>\n }\n\n case 'superscript': {\n return <sup {...attributes}>{children}</sup>\n }\n\n case 'subscript': {\n return <sub {...attributes}>{children}</sub>\n }\n\n default: {\n return next()\n }\n }\n },\n }\n}\n","import { ComponentPropsWithoutRef, forwardRef, useMemo } from 'react'\n\nimport { Editor as SlateEditor } from 'slate-react'\n\n// @ts-expect-error: no types for '@convertkit/slate-lists'\nimport Lists from '@convertkit/slate-lists'\nimport styled from 'styled-components'\n\nimport DeviceOverridesMarks from './plugins/DeviceOverridesMarks'\nimport DeviceOverridesBlocks from './plugins/DeviceOverridesBlocks'\nimport Link from './plugins/Link'\nimport Inlines from './plugins/Inlines'\n\nexport { overrideTypographyStyle } from './components/Mark'\n\ntype Props = ComponentPropsWithoutRef<typeof SlateEditor>\n\nexport const RichTextEditor = styled(\n forwardRef<SlateEditor, Props>(function RichTextEditor(\n { placeholder = 'Write some text...', ...restOfProps }: Props,\n ref,\n ) {\n const plugins = useMemo(\n () => [Lists(), Link(), Inlines(), DeviceOverridesBlocks(), DeviceOverridesMarks()],\n [],\n )\n\n return (\n <SlateEditor\n {...restOfProps}\n ref={ref}\n autoFocus={false}\n plugins={plugins}\n placeholder={placeholder}\n />\n )\n }),\n)`\n ul,\n ol {\n margin: 0;\n }\n`\n","import {\n useState,\n Ref,\n useImperativeHandle,\n forwardRef,\n useEffect,\n useCallback,\n useRef,\n KeyboardEvent as ReactKeyboardEvent,\n} from 'react'\nimport styled from 'styled-components'\nimport { Editor, OnChangeParam } from 'slate-react'\nimport { Value, ValueJSON } from 'slate'\n// @ts-expect-error: no types for 'slate-hotkeys'\nimport Hotkeys from 'slate-hotkeys'\n// @ts-expect-error: there are no types for 'corporate-ipsum'\nimport ipsum from 'corporate-ipsum'\nimport { cx } from '@emotion/css'\nimport { isHotkey } from 'is-hotkey'\n\nimport {\n ElementIDValue,\n MarginValue,\n RichTextDescriptor,\n RichTextValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssMargin } from '../../utils/cssMediaRules'\nimport { BoxModelHandle, getBox } from '../../../box-model'\nimport { PropControllersHandle } from '../../../state/modules/prop-controller-handles'\nimport { RichTextEditor } from './components/RichTextEditor'\nimport { ReactRuntime, useIsInBuilder } from '../../../react'\nimport { DescriptorsPropControllers } from '../../../prop-controllers/instances'\nimport { Props } from '../../../prop-controllers'\n\ntype Props = {\n id?: ElementIDValue\n text?: RichTextValue\n width?: string\n margin?: MarginValue\n}\n\nconst StyledRichTextEditor = styled(RichTextEditor).withConfig({\n shouldForwardProp: prop => !['margin'].includes(prop.toString()),\n})<{ margin: Props['margin'] }>`\n ${cssMargin()}\n`\n\nconst defaultText: ValueJSON = {\n document: { nodes: [{ object: 'block' as const, type: 'paragraph' as const, nodes: [] }] },\n data: {},\n}\n\nconst COMMIT_DEBOUNCE_DELAY = 500\n\ntype Descriptors = { text?: RichTextDescriptor }\n\nconst Text = forwardRef(function Text(\n { id, text, width, margin }: Props,\n ref: Ref<BoxModelHandle & PropControllersHandle<Descriptors>>,\n) {\n const [editor, setEditor] = useState<Editor | null>(null)\n const [propControllers, setPropControllers] =\n useState<DescriptorsPropControllers<Descriptors> | null>(null)\n const controller = propControllers?.text\n\n useImperativeHandle(\n ref,\n () => ({\n getBoxModel() {\n const el = editor?.findDOMNode([])\n\n return el instanceof Element ? getBox(el) : null\n },\n setPropControllers,\n }),\n [editor, setPropControllers],\n )\n\n useEffect(() => {\n if (editor) controller?.setSlateEditor(editor)\n }, [controller, editor])\n\n /**\n * We must keep local state so that we can reflect the user's typed changes immediately. At the\n * same time, though, the source of truth for the data is the prop data. This presents a\n * challenge: how do we keep local state in sync with the prop data without mangling user input as\n * data comes in?\n *\n * Consider, for example, that the user types \"Hello\". If at a later time, when the user is trying\n * to type \", world\" the component re-renders with prop data \"H\", \"He\", \"Hel\", \"Hell\", \"Hello\", it\n * will disrupt the user's typing. This could also happen as a result of the prop data changing\n * for other reasons, like collaborators changing the prop data concurrently. We want to avoid to\n * disrupt the user's typing, while at the same time display the \"true\" value as quickly as\n * possible.\n *\n * The approach we take here is to commit the prop data at an opportune time: as the user is\n * typing we avoid to commit prop data. But once they've stopped typing, we commit it as soon as\n * possible. This is known as a debounce.\n */\n const [value, setValue] = useState(() => {\n const { selection, ...textWithoutSelection } = text ?? defaultText\n\n return Value.fromJSON(textWithoutSelection)\n })\n const [shouldCommit, setShouldCommit] = useState(true)\n\n useEffect(() => {\n if (shouldCommit) {\n const nextValue = Value.fromJSON(text ?? defaultText)\n\n setValue(currentValue =>\n currentValue.selection.isBlurred\n ? Value.fromJSON(nextValue.toJSON({ preserveSelection: false }))\n : nextValue,\n )\n }\n }, [shouldCommit, text])\n\n useEffect(() => {\n if (shouldCommit) return\n\n const timeoutId = window.setTimeout(() => {\n setShouldCommit(true)\n }, COMMIT_DEBOUNCE_DELAY)\n\n return () => {\n window.clearTimeout(timeoutId)\n }\n }, [shouldCommit])\n\n function handleChange(change: OnChangeParam) {\n setValue(change.value as Value)\n\n if (change.value !== value) {\n setShouldCommit(false)\n\n controller?.onChange(change)\n }\n }\n\n // HACK: Slate holds on to the very first DOM event handlers passed in and doesn't update them\n // even if they change. Since `controller` is first `undefined` then we must use a ref.\n const lastController = useRef(controller)\n if (lastController.current !== controller) lastController.current = controller\n const handleFocus = useCallback(() => {\n lastController.current?.focus()\n }, [])\n const handleKeyDown = useCallback(\n (event: ReactKeyboardEvent, _editor: Editor, next: () => any) => {\n if (Hotkeys.isUndo(event)) {\n lastController.current?.undo()\n\n return true\n }\n\n if (Hotkeys.isRedo(event)) {\n lastController.current?.redo()\n\n return true\n }\n\n if (isHotkey('escape')(event)) {\n lastController.current?.blur()\n\n return true\n }\n\n return next()\n },\n [],\n )\n\n const isInBuilder = useIsInBuilder()\n\n return (\n <StyledRichTextEditor\n // @ts-expect-error: types don't allow for 'id' prop even though it's used.\n id={id}\n ref={setEditor}\n className={cx(width)}\n readOnly={!isInBuilder}\n margin={margin}\n value={value}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleKeyDown}\n // Workaround for: clicking on any of the text panel will remove the text selection.\n onBlur={e => e.preventDefault()}\n />\n )\n})\n\nexport default Text\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Text, {\n type: './components/Text/index.js',\n label: 'Text',\n props: {\n id: Props.ElementID(),\n text: Props.RichText(() => ({\n preset: {\n document: {\n nodes: [\n {\n object: 'block',\n type: 'paragraph',\n nodes: [\n {\n object: 'text',\n text: ipsum(3),\n marks: [\n {\n object: 'mark',\n type: 'typography',\n data: {\n value: {\n id: null,\n style: [\n {\n deviceId: 'mobile',\n value: { fontSize: { value: 16, unit: 'px' } },\n },\n {\n deviceId: 'desktop',\n value: {\n fontWeight: 400,\n fontSize: { value: 18, unit: 'px' },\n lineHeight: 1.5,\n },\n },\n ],\n },\n },\n },\n ],\n },\n ],\n },\n ],\n },\n },\n })),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n preset: [{ deviceId: 'desktop', value: { value: 700, unit: 'px' } }],\n defaultValue: { value: 100, unit: '%' },\n }),\n margin: Props.Margin({\n preset: [\n {\n deviceId: 'desktop',\n value: {\n marginTop: null,\n marginRight: 'auto',\n marginBottom: { value: 20, unit: 'px' },\n marginLeft: 'auto',\n },\n },\n ],\n }),\n },\n })\n}\n","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\nimport ReactPlayer from 'react-player'\nimport { cx } from '@emotion/css'\n\nimport {\n BorderRadiusValue,\n ElementIDValue,\n MarginValue,\n VideoValue,\n} from '../../../prop-controllers/descriptors'\nimport { cssBorderRadius, cssMargin } from '../../utils/cssMediaRules'\nimport { placeholders } from '../../utils/placeholders'\nimport { ReactRuntime } from '../../../react'\nimport { Props } from '../../../prop-controllers'\n\ntype Props = {\n id?: ElementIDValue\n video?: VideoValue\n width?: string\n margin?: MarginValue\n borderRadius?: BorderRadiusValue\n}\n\nconst Container = styled.div.withConfig({\n shouldForwardProp: prop => !['margin', 'borderRadius'].includes(prop.toString()),\n})<{ margin: Props['margin']; borderRadius: Props['borderRadius'] }>`\n display: flex;\n flex-direction: column;\n overflow: hidden;\n ${cssMargin()}\n ${cssBorderRadius()}\n`\n\nconst ASPECT_RATIO = 16 / 9\n\nconst Video = forwardRef(function Video(\n { id, video, width, margin, borderRadius }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n const canPlayUrl = video && video.url != null && ReactPlayer.canPlay(video.url)\n\n return (\n <Container ref={ref} id={id} className={cx(width)} margin={margin} borderRadius={borderRadius}>\n <div style={{ position: 'relative', paddingTop: `${100 / ASPECT_RATIO}%` }}>\n <div style={{ position: 'absolute', top: 0, left: 0, right: 0, bottom: 0 }}>\n {canPlayUrl === true ? (\n <ReactPlayer\n {...video}\n width=\"100%\"\n height=\"100%\"\n config={{\n vimeo: { playerOptions: { background: video != null && !video.controls } },\n wistia: {\n options: {\n endVideoBehavior: video != null && video.loop === true ? 'loop' : 'default',\n },\n },\n }}\n />\n ) : (\n <img width=\"100%\" src={placeholders.video.src} alt=\"Video Placeholder\" />\n )}\n </div>\n </div>\n </Container>\n )\n})\n\nexport default Video\n\nexport function registerComponent(runtime: ReactRuntime) {\n return runtime.registerComponent(Video, {\n type: './components/Video/index.js',\n label: 'Video',\n icon: 'Video40',\n props: {\n id: Props.ElementID(),\n video: Props.Video({ preset: { controls: true } }),\n width: Props.Width({\n format: Props.Width.Formats.ClassName,\n defaultValue: { value: 560, unit: 'px' },\n }),\n margin: Props.Margin(),\n borderRadius: Props.BorderRadius(),\n },\n })\n}\n","export * from './Box'\nexport { default as Box } from './Box'\nexport { default as Button } from './Button'\nexport { default as Carousel } from './Carousel'\nexport { default as Countdown } from './Countdown'\nexport { default as Divider } from './Divider'\nexport { default as Embed } from './Embed'\nexport { default as Form } from './Form'\nexport { default as Image } from './Image'\nexport { default as Navigation } from './Navigation'\nexport { default as Root } from './Root'\nexport { default as SocialLinks } from './SocialLinks'\nexport { default as Text } from './Text'\n\nimport { ReactRuntime } from '../../react'\nimport { registerComponent as registerBoxComponent } from './Box'\nimport { registerComponent as registerButtonComponent } from './Button'\nimport { registerComponent as registerCarouselComponent } from './Carousel'\nimport { registerComponent as registerCountdownComponent } from './Countdown'\nimport { registerComponent as registerDividerComponent } from './Divider'\nimport { registerComponent as registerEmbedComponent } from './Embed'\nimport { registerComponent as registerFormComponent } from './Form'\nimport { registerComponent as registerImageComponent } from './Image'\nimport { registerComponent as registerNavigationComponent } from './Navigation'\nimport { registerComponent as registerRootComponent } from './Root'\nimport { registerComponent as registerSocialLinksComponent } from './SocialLinks'\nimport { registerComponent as registerTextComponent } from './Text'\nimport { registerComponent as registerVideoComponent } from './Video'\n\nexport function registerBuiltinComponents(runtime: ReactRuntime) {\n const unregisterBoxComponent = registerBoxComponent(runtime)\n const unregisterButtonComponent = registerButtonComponent(runtime)\n const unregisterCarouselComponent = registerCarouselComponent(runtime)\n const unregisterCountdownComponent = registerCountdownComponent(runtime)\n const unregisterDividerComponent = registerDividerComponent(runtime)\n const unregisterEmbedComponent = registerEmbedComponent(runtime)\n const unregisterFormComponent = registerFormComponent(runtime)\n const unregisterImageComponent = registerImageComponent(runtime)\n const unregisterNavigationComponent = registerNavigationComponent(runtime)\n const unregisterRootComponent = registerRootComponent(runtime)\n const unregisterSocialLinksComponent = registerSocialLinksComponent(runtime)\n const unregisterTextComponent = registerTextComponent(runtime)\n const unregisterVideoComponent = registerVideoComponent(runtime)\n\n return () => {\n unregisterBoxComponent()\n unregisterButtonComponent()\n unregisterCarouselComponent()\n unregisterCountdownComponent()\n unregisterDividerComponent()\n unregisterEmbedComponent()\n unregisterFormComponent()\n unregisterImageComponent()\n unregisterNavigationComponent()\n unregisterRootComponent()\n unregisterSocialLinksComponent()\n unregisterTextComponent()\n unregisterTextComponent()\n unregisterVideoComponent()\n }\n}\n","import { useEffect } from 'react'\n\nconst SCRIPT_TAG = 'script'\n\ntype Props = {\n code: string\n cleanup: string | null | undefined\n}\n\nexport function BodySnippet({ code, cleanup }: Props): null {\n useEffect(() => {\n const container = document.createElement('div')\n\n container.innerHTML = code\n\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT)\n const scripts: HTMLScriptElement[] = []\n\n while (walker.nextNode()) {\n if (walker.currentNode instanceof HTMLScriptElement) scripts.push(walker.currentNode)\n }\n\n scripts.forEach(inlineScript => {\n const executableScript = document.createElement(SCRIPT_TAG)\n\n executableScript.textContent = inlineScript.textContent\n Array.from(inlineScript.attributes).forEach(({ name, value }) => {\n executableScript.setAttribute(name, value)\n })\n\n inlineScript.parentNode?.replaceChild(executableScript, inlineScript)\n })\n\n const nodes = Array.from(container.childNodes)\n\n document.body.append(...nodes)\n\n return () => {\n nodes.forEach(node => {\n node.parentNode?.removeChild(node)\n })\n\n if (cleanup == null) return\n\n const cleanUp = new Function(cleanup)\n\n try {\n cleanUp()\n } catch {\n // Ignore errors from user input.\n }\n }\n }, [code, cleanup])\n\n return null\n}\n","export default function is(x: unknown, y: unknown): boolean {\n if (x === y) return x !== 0 || y !== 0 || 1 / x === 1 / y\n\n return x !== x && y !== y\n}\n","import is from './is'\n\nconst { hasOwnProperty } = Object.prototype\n\nconst shallowEqual = (a: unknown, b: unknown): boolean => {\n if (is(a, b)) return true\n\n if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) return false\n\n const keysA = Object.keys(a)\n const keysB = Object.keys(b)\n\n if (keysA.length !== keysB.length) return false\n\n for (let i = 0; i < keysA.length; i += 1) {\n // @ts-expect-error: {}[string] is OK.\n if (!hasOwnProperty.call(b, keysA[i]) || !is(a[keysA[i]], b[keysA[i]])) return false\n }\n\n return true\n}\n\nexport default shallowEqual\n","import shallowEqual from './shallowEqual'\n\nconst { hasOwnProperty } = Object.prototype\n\nconst deepEqual = (a: unknown, b: unknown): boolean => {\n if (shallowEqual(a, b)) return true\n\n if (typeof a !== 'object' || a === null || typeof b !== 'object' || b === null) return false\n\n const keysA = Object.keys(a)\n const keysB = Object.keys(b)\n\n if (keysA.length !== keysB.length) return false\n\n for (let i = 0; i < keysA.length; i += 1) {\n if (\n !hasOwnProperty.call(b, keysA[i]) ||\n // @ts-expect-error: {}[string] is OK.\n !deepEqual(a[keysA[i]], b[keysA[i]])\n )\n return false\n }\n\n return true\n}\n\nexport default deepEqual\n","import { ReactElement, Children, createElement, useMemo, useEffect, useRef, useState } from 'react'\nimport parse from 'html-react-parser'\nimport Head from 'next/head'\n\nimport { BodySnippet } from './BodySnippet'\nimport { DocumentReference } from '../../runtimes/react'\nimport { createDocumentReference } from '../../state/react-page'\nimport { useQuery, gql } from '../../api/react'\nimport { useIsInBuilder } from '../../react'\nimport deepEqual from '../../utils/deepEqual'\n\nenum SnippetLocation {\n Body = 'BODY',\n Head = 'HEAD',\n}\n\ntype Snippet = {\n builderEnabled: boolean\n cleanup?: string | null\n code: string\n id: string\n liveEnabled: boolean\n location: SnippetLocation\n}\n\nexport type PageData = {\n id: string\n meta: {\n title?: string | null | undefined\n description?: string | null | undefined\n keywords?: string | null | undefined\n socialImage?: { id: string; publicUrl: any; mimetype: any } | null | undefined\n favicon?: { id: string; publicUrl: any; mimetype: any } | null | undefined\n }\n snippets: Snippet[]\n fonts: Array<{\n family: string\n variants: string[]\n }>\n seo: {\n canonicalUrl?: string | null | undefined\n isIndexingBlocked?: boolean | null | undefined\n }\n site: {\n id: string\n }\n}\n\nconst defaultFavicon = {\n mimetype: 'image/png',\n publicUrl:\n 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACIAAAAiCAYAAAA6RwvCAAAACXBIWXMAABcRAAAXEQHKJvM/AAABjElEQVRYhc2XzU3EMBCFB8TddAAXn6EE6GCpgNABZ1/IXnymBOgAOmA7YM8+ABVsXEHQQFaKQryeN3Yk3ilKJtEnv/nLUd/3pFG0riGi88yrnQn+UfJ5FUi0riWiB2H4nQn+KRd0DFP8agXEfkqCYJBoHdtxIQxfm+DfFgEhoith3NYE30o/qgGR2BJB+xY7kdYEL8oNFUi0jiFMJuxVWrJqEMFxsyUNCsE6AeNztvBp7aJ143vXksoRnwhYtmNdSoIQa6RlO9YXEWW7KgoCleOgxgTf1QZBT+RZ2lXFING6UxCCq+ceeUE8fYdknY599v9sJvzGBP+yCEgC7GPmETc0OJ+0awAlkhe2pAbIXAeFZ8xe2g2Nk3c3ub0xwWt6zY9qbmiqGVMbZK21ZC/YmhlbeBMTzZNDQqcvDb1kM1x32iqZSt1HaqukfKvq34BAOTLsrH+ETNmUkKHHA+428RgeclPVWozeSyAI2EdWB34jtqXNTAySOY3i/KgFIlqOa4GkFmBegorzg4joG07he/M7zl6jAAAAAElFTkSuQmCC',\n}\n\n// Taken from https://github.com/facebook/react/blob/14bac6193a334eda42e727336e8967419f08f5df/packages/react-dom/src/server/ReactPartialRenderer.js#L208\nconst VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_.\\-\\d]*$/\n\nconst VALID_HEAD_ELEMENT_TYPES = [\n 'title',\n 'base',\n 'link',\n 'style',\n 'meta',\n 'script',\n 'noscript',\n 'template',\n]\n\nfunction snippetToElement(snippet: Pick<Snippet, 'id' | 'code'>): (string | ReactElement)[] {\n return Children.map(parse(snippet.code), element => {\n if (typeof element === 'string') return element\n\n if (!VALID_TAG_REGEX.test(element.type)) return null\n\n const key = element.key ? `${snippet.id}:${element.key}` : snippet.id\n\n return createElement(element.type, { ...element.props, key })\n })\n}\n\nconst filterUsedSnippetProperties = ({\n code,\n builderEnabled,\n liveEnabled,\n location,\n cleanup,\n}: Snippet) => ({\n code,\n builderEnabled,\n liveEnabled,\n location,\n cleanup,\n})\n\ntype Props = {\n page: PageData\n preview?: boolean\n}\n\nexport const PAGE_SNIPPETS_QUERY = gql`\n query PageById($id: ID!) {\n page(id: $id) {\n __typename\n id\n snippets {\n __typename\n id\n name\n code\n cleanup\n location\n shouldAddToNewPages\n liveEnabled\n builderEnabled\n }\n }\n }\n`\n\nexport type SiteFontsSiteQuery = {\n site?: {\n id: string\n googleFonts: {\n edges: Array<{\n activeVariants: Array<{ specifier: string }>\n node: {\n family: string\n variants: Array<{ specifier: string }>\n }\n } | null>\n }\n } | null\n}\n\nexport const SITE_FONTS_QUERY = gql`\n query SiteById($id: ID!) {\n site(id: $id) {\n id\n googleFonts {\n edges {\n activeVariants {\n specifier\n }\n node {\n family\n variants {\n specifier\n }\n }\n }\n }\n }\n }\n`\n\nexport function Page({ page, preview = false }: Props): JSX.Element {\n const isInBuilder = useIsInBuilder()\n const [snippets, setSnippets] = useState(page.snippets)\n // We're using useQuery here for page snippets and site fonts so that anytime the user change\n // the snippets or fonts on the builder, the change would be reflected here.\n // See this PR for discussions and things we can do to improve it in the future:\n // https://github.com/makeswift/makeswift/pull/77\n useQuery<{ page: { snippets: Snippet[] } }>(PAGE_SNIPPETS_QUERY, {\n variables: { id: page.id },\n skip: isInBuilder === false,\n fetchPolicy: 'cache-only',\n onCompleted(data) {\n if (data == null) return\n\n const oldSnippets = snippets.map(filterUsedSnippetProperties)\n const newSnippets = data.page.snippets.map(filterUsedSnippetProperties)\n\n if (deepEqual(newSnippets, oldSnippets)) return\n\n setSnippets(data.page.snippets)\n },\n })\n const { data: siteData } = useQuery<SiteFontsSiteQuery>(SITE_FONTS_QUERY, {\n variables: { id: page.site.id },\n skip: isInBuilder === false,\n fetchPolicy: 'cache-only',\n })\n\n const favicon = page.meta.favicon ?? defaultFavicon\n const { title, description, keywords, socialImage } = page.meta\n const { canonicalUrl, isIndexingBlocked } = page.seo\n\n const fontFamilyParamValue = useMemo(() => {\n if (siteData?.site == null) {\n return page.fonts\n .map(({ family, variants }) => {\n return `${family.replace(/ /g, '+')}:${variants.join()}`\n })\n .join('|')\n }\n\n return siteData.site.googleFonts.edges\n .filter((edge): edge is NonNullable<typeof edge> => edge != null)\n .map(({ activeVariants, node: { family, variants } }) => {\n const activeVariantSpecifiers = variants\n .filter(variant =>\n activeVariants.some(activeVariant => activeVariant.specifier === variant.specifier),\n )\n .map(variant => variant.specifier)\n .join()\n\n return `${family.replace(/ /g, '+')}:${activeVariantSpecifiers}`\n })\n .join('|')\n }, [siteData, page])\n\n const filteredSnippets = useMemo(\n () => snippets.filter(snippet => (preview ? snippet.builderEnabled : snippet.liveEnabled)),\n [snippets],\n )\n const headSnippets = useMemo(\n () => filteredSnippets.filter(snippet => snippet.location === SnippetLocation.Head),\n [filteredSnippets],\n )\n\n const previousHeadSnippets = useRef<PageData['snippets'] | null>(null)\n useEffect(() => {\n const headSnippetsToCleanUp = (previousHeadSnippets.current ?? [])\n .filter(previousSnippet => previousSnippet.cleanup != null)\n .filter(previousSnippet => !headSnippets.some(snippet => previousSnippet.id === snippet.id))\n\n headSnippetsToCleanUp.forEach(snippetToCleanUp => {\n if (snippetToCleanUp.cleanup == null) return\n\n const cleanUp = new Function(snippetToCleanUp.cleanup)\n\n try {\n cleanUp()\n } catch {\n // Ignore errors from user input.\n }\n })\n\n previousHeadSnippets.current = headSnippets\n }, [headSnippets])\n\n return (\n <>\n <Head>\n <style>\n {`\n html {\n font-family: sans-serif;\n }\n div#__next {\n overflow: hidden;\n }\n `}\n </style>\n\n <link rel=\"icon\" type={favicon.mimetype} href={favicon.publicUrl} />\n\n {canonicalUrl && <link rel=\"canonical\" href={canonicalUrl} />}\n\n {isIndexingBlocked && <meta name=\"robots\" content=\"noindex\" />}\n\n {title && (\n <>\n <title>{title}</title>\n <meta property=\"og:title\" content={title} />\n <meta name=\"twitter:title\" content={title} />\n <meta itemProp=\"name\" content={title} />\n </>\n )}\n\n {description && (\n <>\n <meta name=\"description\" content={description} />\n <meta property=\"og:description\" content={description} />\n <meta name=\"twitter:description\" content={description} />\n <meta itemProp=\"description\" content={description} />\n </>\n )}\n\n {keywords && <meta name=\"keywords\" content={keywords} />}\n\n {socialImage && (\n <>\n <meta property=\"og:image\" content={socialImage.publicUrl} />\n <meta property=\"og:image:type\" content={socialImage.publicUrl} />\n <meta name=\"twitter:image\" content={socialImage.publicUrl} />\n <meta name=\"twitter:card\" content={socialImage.publicUrl} />\n <meta itemProp=\"image\" content={socialImage.publicUrl} />\n </>\n )}\n\n {fontFamilyParamValue !== '' && (\n <>\n <link\n rel=\"stylesheet\"\n href={`https://fonts.googleapis.com/css?family=${fontFamilyParamValue}&display=swap`}\n />\n </>\n )}\n\n {headSnippets.map(snippetToElement).map(children =>\n Children.map(children, child => {\n if (typeof child === 'string') return child\n\n if (VALID_HEAD_ELEMENT_TYPES.includes(child.type as string)) return child\n\n return null\n }),\n )}\n </Head>\n\n <DocumentReference documentReference={createDocumentReference(page.id)} />\n\n {filteredSnippets\n .filter(snippet => snippet.location === SnippetLocation.Body)\n .map(snippet => (\n <BodySnippet key={snippet.id} code={snippet.code} cleanup={snippet.cleanup} />\n ))}\n </>\n )\n}\n","export default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZmlsbC1ydWxlPSJldmVub2RkIiBjbGlwLXJ1bGU9ImV2ZW5vZGQiIGQ9Ik0yLjg5ODY0IDE4SDE3LjEwMTRDMTguNDE4MyAxOCAxOS4yNjMzIDE2LjYwMDMgMTguNjUgMTUuNDM0OUwxMS41NDg2IDEuOTQyMzZDMTAuODkyNSAwLjY5NTc3IDkuMTA3NDkgMC42OTU3NjYgOC40NTEzOSAxLjk0MjM2TDEuMzUwMDMgMTUuNDM0OUMwLjczNjY5MiAxNi42MDAzIDEuNTgxNzQgMTggMi44OTg2NCAxOFpNOSA2QzkgNS40NDc3MiA5LjQ0NzcxIDUgMTAgNUMxMC41NTIzIDUgMTEgNS40NDc3MiAxMSA2VjExQzExIDExLjU1MjMgMTAuNTUyMyAxMiAxMCAxMkM5LjQ0NzcxIDEyIDkgMTEuNTUyMyA5IDExVjZaTTExLjI1IDE0Ljc1QzExLjI1IDE1LjQ0MDQgMTAuNjkwNCAxNiAxMCAxNkM5LjMwOTY0IDE2IDguNzUgMTUuNDQwNCA4Ljc1IDE0Ljc1QzguNzUgMTQuMDU5NiA5LjMwOTY0IDEzLjUgMTAgMTMuNUMxMC42OTA0IDEzLjUgMTEuMjUgMTQuMDU5NiAxMS4yNSAxNC43NVoiIC8+Cjwvc3ZnPgo=\"","import { forwardRef, Ref } from 'react'\nimport styled from 'styled-components'\nimport { ReactComponent as Warning20 } from '../../icons/warning-20.svg'\n\nconst ErrorDiv = styled('div')`\n width: 100%;\n height: 54px;\n background-color: #fcedf2;\n border-radius: 6px;\n padding: 16px;\n display: flex;\n align-items: center;\n gap: 8px;\n color: #c73e6d;\n fill: currentColor;\n font-family: Heebo, sans-serif;\n font-size: 16px;\n`\n\ntype Props = {\n text: string\n}\n\nexport const FallbackComponent = forwardRef(function FallbackComponent(\n { text }: Props,\n ref: Ref<HTMLDivElement>,\n) {\n return (\n <ErrorDiv ref={ref}>\n <Warning20 />\n <span>{text}</span>\n </ErrorDiv>\n )\n})\n","/* eslint-disable */\n// Inspired by https://github.com/garycourt/murmurhash-js\n// Ported from https://github.com/aappleby/smhasher/blob/61a0530f28277f2e850bfc39600ce61d02b518de/src/MurmurHash2.cpp#L37-L86\nfunction murmur2(str) {\n // 'm' and 'r' are mixing constants generated offline.\n // They're not really 'magic', they just happen to work well.\n // const m = 0x5bd1e995;\n // const r = 24;\n // Initialize the hash\n var h = 0; // Mix 4 bytes at a time into the hash\n\n var k,\n i = 0,\n len = str.length;\n\n for (; len >= 4; ++i, len -= 4) {\n k = str.charCodeAt(i) & 0xff | (str.charCodeAt(++i) & 0xff) << 8 | (str.charCodeAt(++i) & 0xff) << 16 | (str.charCodeAt(++i) & 0xff) << 24;\n k =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16);\n k ^=\n /* k >>> r: */\n k >>> 24;\n h =\n /* Math.imul(k, m): */\n (k & 0xffff) * 0x5bd1e995 + ((k >>> 16) * 0xe995 << 16) ^\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Handle the last few bytes of the input array\n\n\n switch (len) {\n case 3:\n h ^= (str.charCodeAt(i + 2) & 0xff) << 16;\n\n case 2:\n h ^= (str.charCodeAt(i + 1) & 0xff) << 8;\n\n case 1:\n h ^= str.charCodeAt(i) & 0xff;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n } // Do a few final mixes of the hash to ensure the last few\n // bytes are well-incorporated.\n\n\n h ^= h >>> 13;\n h =\n /* Math.imul(h, m): */\n (h & 0xffff) * 0x5bd1e995 + ((h >>> 16) * 0xe995 << 16);\n return ((h ^ h >>> 15) >>> 0).toString(36);\n}\n\nexport default murmur2;\n","var unitlessKeys = {\n animationIterationCount: 1,\n borderImageOutset: 1,\n borderImageSlice: 1,\n borderImageWidth: 1,\n boxFlex: 1,\n boxFlexGroup: 1,\n boxOrdinalGroup: 1,\n columnCount: 1,\n columns: 1,\n flex: 1,\n flexGrow: 1,\n flexPositive: 1,\n flexShrink: 1,\n flexNegative: 1,\n flexOrder: 1,\n gridRow: 1,\n gridRowEnd: 1,\n gridRowSpan: 1,\n gridRowStart: 1,\n gridColumn: 1,\n gridColumnEnd: 1,\n gridColumnSpan: 1,\n gridColumnStart: 1,\n msGridRow: 1,\n msGridRowSpan: 1,\n msGridColumn: 1,\n msGridColumnSpan: 1,\n fontWeight: 1,\n lineHeight: 1,\n opacity: 1,\n order: 1,\n orphans: 1,\n tabSize: 1,\n widows: 1,\n zIndex: 1,\n zoom: 1,\n WebkitLineClamp: 1,\n // SVG-related properties\n fillOpacity: 1,\n floodOpacity: 1,\n stopOpacity: 1,\n strokeDasharray: 1,\n strokeDashoffset: 1,\n strokeMiterlimit: 1,\n strokeOpacity: 1,\n strokeWidth: 1\n};\n\nexport default unitlessKeys;\n","function memoize(fn) {\n var cache = Object.create(null);\n return function (arg) {\n if (cache[arg] === undefined) cache[arg] = fn(arg);\n return cache[arg];\n };\n}\n\nexport default memoize;\n","import hashString from '@emotion/hash';\nimport unitless from '@emotion/unitless';\nimport memoize from '@emotion/memoize';\n\nvar ILLEGAL_ESCAPE_SEQUENCE_ERROR = \"You have illegal escape sequence in your template literal, most likely inside content's property value.\\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \\\"content: '\\\\00d7';\\\" should become \\\"content: '\\\\\\\\00d7';\\\".\\nYou can read more about this here:\\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences\";\nvar UNDEFINED_AS_OBJECT_KEY_ERROR = \"You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).\";\nvar hyphenateRegex = /[A-Z]|^ms/g;\nvar animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;\n\nvar isCustomProperty = function isCustomProperty(property) {\n return property.charCodeAt(1) === 45;\n};\n\nvar isProcessableValue = function isProcessableValue(value) {\n return value != null && typeof value !== 'boolean';\n};\n\nvar processStyleName = /* #__PURE__ */memoize(function (styleName) {\n return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, '-$&').toLowerCase();\n});\n\nvar processStyleValue = function processStyleValue(key, value) {\n switch (key) {\n case 'animation':\n case 'animationName':\n {\n if (typeof value === 'string') {\n return value.replace(animationRegex, function (match, p1, p2) {\n cursor = {\n name: p1,\n styles: p2,\n next: cursor\n };\n return p1;\n });\n }\n }\n }\n\n if (unitless[key] !== 1 && !isCustomProperty(key) && typeof value === 'number' && value !== 0) {\n return value + 'px';\n }\n\n return value;\n};\n\nif (process.env.NODE_ENV !== 'production') {\n var contentValuePattern = /(var|attr|counters?|url|(((repeating-)?(linear|radial))|conic)-gradient)\\(|(no-)?(open|close)-quote/;\n var contentValues = ['normal', 'none', 'initial', 'inherit', 'unset'];\n var oldProcessStyleValue = processStyleValue;\n var msPattern = /^-ms-/;\n var hyphenPattern = /-(.)/g;\n var hyphenatedCache = {};\n\n processStyleValue = function processStyleValue(key, value) {\n if (key === 'content') {\n if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '\"' && value.charAt(0) !== \"'\")) {\n throw new Error(\"You seem to be using a value for 'content' without quotes, try replacing it with `content: '\\\"\" + value + \"\\\"'`\");\n }\n }\n\n var processed = oldProcessStyleValue(key, value);\n\n if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {\n hyphenatedCache[key] = true;\n console.error(\"Using kebab-case for css properties in objects is not supported. Did you mean \" + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {\n return _char.toUpperCase();\n }) + \"?\");\n }\n\n return processed;\n };\n}\n\nfunction handleInterpolation(mergedProps, registered, interpolation) {\n if (interpolation == null) {\n return '';\n }\n\n if (interpolation.__emotion_styles !== undefined) {\n if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {\n throw new Error('Component selectors can only be used in conjunction with @emotion/babel-plugin.');\n }\n\n return interpolation;\n }\n\n switch (typeof interpolation) {\n case 'boolean':\n {\n return '';\n }\n\n case 'object':\n {\n if (interpolation.anim === 1) {\n cursor = {\n name: interpolation.name,\n styles: interpolation.styles,\n next: cursor\n };\n return interpolation.name;\n }\n\n if (interpolation.styles !== undefined) {\n var next = interpolation.next;\n\n if (next !== undefined) {\n // not the most efficient thing ever but this is a pretty rare case\n // and there will be very few iterations of this generally\n while (next !== undefined) {\n cursor = {\n name: next.name,\n styles: next.styles,\n next: cursor\n };\n next = next.next;\n }\n }\n\n var styles = interpolation.styles + \";\";\n\n if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {\n styles += interpolation.map;\n }\n\n return styles;\n }\n\n return createStringFromObject(mergedProps, registered, interpolation);\n }\n\n case 'function':\n {\n if (mergedProps !== undefined) {\n var previousCursor = cursor;\n var result = interpolation(mergedProps);\n cursor = previousCursor;\n return handleInterpolation(mergedProps, registered, result);\n } else if (process.env.NODE_ENV !== 'production') {\n console.error('Functions that are interpolated in css calls will be stringified.\\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\\n' + 'It can be called directly with props or interpolated in a styled call like this\\n' + \"let SomeComponent = styled('div')`${dynamicStyle}`\");\n }\n\n break;\n }\n\n case 'string':\n if (process.env.NODE_ENV !== 'production') {\n var matched = [];\n var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {\n var fakeVarName = \"animation\" + matched.length;\n matched.push(\"const \" + fakeVarName + \" = keyframes`\" + p2.replace(/^@keyframes animation-\\w+/, '') + \"`\");\n return \"${\" + fakeVarName + \"}\";\n });\n\n if (matched.length) {\n console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\\n\\n' + 'Instead of doing this:\\n\\n' + [].concat(matched, [\"`\" + replaced + \"`\"]).join('\\n') + '\\n\\nYou should wrap it with `css` like this:\\n\\n' + (\"css`\" + replaced + \"`\"));\n }\n }\n\n break;\n } // finalize string values (regular strings and functions interpolated into css calls)\n\n\n if (registered == null) {\n return interpolation;\n }\n\n var cached = registered[interpolation];\n return cached !== undefined ? cached : interpolation;\n}\n\nfunction createStringFromObject(mergedProps, registered, obj) {\n var string = '';\n\n if (Array.isArray(obj)) {\n for (var i = 0; i < obj.length; i++) {\n string += handleInterpolation(mergedProps, registered, obj[i]) + \";\";\n }\n } else {\n for (var _key in obj) {\n var value = obj[_key];\n\n if (typeof value !== 'object') {\n if (registered != null && registered[value] !== undefined) {\n string += _key + \"{\" + registered[value] + \"}\";\n } else if (isProcessableValue(value)) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value) + \";\";\n }\n } else {\n if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {\n throw new Error('Component selectors can only be used in conjunction with @emotion/babel-plugin.');\n }\n\n if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {\n for (var _i = 0; _i < value.length; _i++) {\n if (isProcessableValue(value[_i])) {\n string += processStyleName(_key) + \":\" + processStyleValue(_key, value[_i]) + \";\";\n }\n }\n } else {\n var interpolated = handleInterpolation(mergedProps, registered, value);\n\n switch (_key) {\n case 'animation':\n case 'animationName':\n {\n string += processStyleName(_key) + \":\" + interpolated + \";\";\n break;\n }\n\n default:\n {\n if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {\n console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);\n }\n\n string += _key + \"{\" + interpolated + \"}\";\n }\n }\n }\n }\n }\n }\n\n return string;\n}\n\nvar labelPattern = /label:\\s*([^\\s;\\n{]+)\\s*(;|$)/g;\nvar sourceMapPattern;\n\nif (process.env.NODE_ENV !== 'production') {\n sourceMapPattern = /\\/\\*#\\ssourceMappingURL=data:application\\/json;\\S+\\s+\\*\\//g;\n} // this is the cursor for keyframes\n// keyframes are stored on the SerializedStyles object as a linked list\n\n\nvar cursor;\nvar serializeStyles = function serializeStyles(args, registered, mergedProps) {\n if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {\n return args[0];\n }\n\n var stringMode = true;\n var styles = '';\n cursor = undefined;\n var strings = args[0];\n\n if (strings == null || strings.raw === undefined) {\n stringMode = false;\n styles += handleInterpolation(mergedProps, registered, strings);\n } else {\n if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[0];\n } // we start at 1 since we've already handled the first arg\n\n\n for (var i = 1; i < args.length; i++) {\n styles += handleInterpolation(mergedProps, registered, args[i]);\n\n if (stringMode) {\n if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {\n console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);\n }\n\n styles += strings[i];\n }\n }\n\n var sourceMap;\n\n if (process.env.NODE_ENV !== 'production') {\n styles = styles.replace(sourceMapPattern, function (match) {\n sourceMap = match;\n return '';\n });\n } // using a global regex with .exec is stateful so lastIndex has to be reset each time\n\n\n labelPattern.lastIndex = 0;\n var identifierName = '';\n var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5\n\n while ((match = labelPattern.exec(styles)) !== null) {\n identifierName += '-' + // $FlowFixMe we know it's not null\n match[1];\n }\n\n var name = hashString(styles) + identifierName;\n\n if (process.env.NODE_ENV !== 'production') {\n // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)\n return {\n name: name,\n styles: styles,\n map: sourceMap,\n next: cursor,\n toString: function toString() {\n return \"You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).\";\n }\n };\n }\n\n return {\n name: name,\n styles: styles,\n next: cursor\n };\n};\n\nexport { serializeStyles };\n","var isBrowser = \"object\" !== 'undefined';\nfunction getRegisteredStyles(registered, registeredStyles, classNames) {\n var rawClassName = '';\n classNames.split(' ').forEach(function (className) {\n if (registered[className] !== undefined) {\n registeredStyles.push(registered[className] + \";\");\n } else {\n rawClassName += className + \" \";\n }\n });\n return rawClassName;\n}\nvar registerStyles = function registerStyles(cache, serialized, isStringTag) {\n var className = cache.key + \"-\" + serialized.name;\n\n if ( // we only need to add the styles to the registered cache if the\n // class name could be used further down\n // the tree but if it's a string tag, we know it won't\n // so we don't have to add it to registered cache.\n // this improves memory usage since we can avoid storing the whole style string\n (isStringTag === false || // we need to always store it if we're in compat mode and\n // in node since emotion-server relies on whether a style is in\n // the registered cache to know whether a style is global or not\n // also, note that this check will be dead code eliminated in the browser\n isBrowser === false ) && cache.registered[className] === undefined) {\n cache.registered[className] = serialized.styles;\n }\n};\nvar insertStyles = function insertStyles(cache, serialized, isStringTag) {\n registerStyles(cache, serialized, isStringTag);\n var className = cache.key + \"-\" + serialized.name;\n\n if (cache.inserted[serialized.name] === undefined) {\n var current = serialized;\n\n do {\n var maybeStyles = cache.insert(serialized === current ? \".\" + className : '', current, cache.sheet, true);\n\n current = current.next;\n } while (current !== undefined);\n }\n};\n\nexport { getRegisteredStyles, insertStyles, registerStyles };\n","import * as React from 'react'\nimport { css, cache, CSSObject } from '@emotion/css'\nimport { serializeStyles } from '@emotion/serialize'\nimport { insertStyles } from '@emotion/utils'\n\nimport { useBorder, BorderSide } from '../../../components'\nimport { colorToString } from '../../../components/utils/colorToString'\nimport { responsiveStyle } from '../../../components/utils/responsive-style'\n\nimport {\n BorderRadiusLonghandPropertyData,\n MarginLonghandPropertyData,\n PaddingLonghandPropertyData,\n StyleControlData,\n StyleControlDefinition,\n StyleControlProperty,\n WidthPropertyData,\n} from '../../../controls'\n\nfunction useStyleControlCssObject(\n style: StyleControlData | undefined,\n controlDefinition: StyleControlDefinition,\n): CSSObject {\n const { properties } = controlDefinition.config\n\n return {\n ...(properties.includes(StyleControlProperty.Width) && {\n maxWidth: '100%',\n }),\n ...responsiveStyle(\n [\n style?.width,\n style?.margin,\n style?.padding,\n useBorder(style?.border),\n style?.borderRadius,\n ] as const,\n ([width, margin, padding, border, borderRadius]) => ({\n ...(properties.includes(StyleControlProperty.Width) && {\n width: widthToString(width) ?? '100%',\n }),\n ...(properties.includes(StyleControlProperty.Margin) && {\n marginTop: marginToString(margin?.marginTop) ?? 0,\n marginRight: marginToString(margin?.marginRight) ?? 'auto',\n marginBottom: marginToString(margin?.marginBottom) ?? 0,\n marginLeft: marginToString(margin?.marginLeft) ?? 'auto',\n }),\n ...(properties.includes(StyleControlProperty.Padding) && {\n paddingTop: paddingToString(padding?.paddingTop) ?? 0,\n paddingRight: paddingToString(padding?.paddingRight) ?? 0,\n paddingBottom: paddingToString(padding?.paddingBottom) ?? 0,\n paddingLeft: paddingToString(padding?.paddingLeft) ?? 0,\n }),\n ...(properties.includes(StyleControlProperty.Border) && {\n borderTop: borderSideToString(border?.borderTop) ?? '0 solid black',\n borderRight: borderSideToString(border?.borderRight) ?? '0 solid black',\n borderBottom: borderSideToString(border?.borderBottom) ?? '0 solid black',\n borderLeft: borderSideToString(border?.borderLeft) ?? '0 solid black',\n }),\n ...(properties.includes(StyleControlProperty.BorderRadius) && {\n borderTopLeftRadius: borderRadiusToString(borderRadius?.borderTopLeftRadius) ?? 0,\n borderTopRightRadius: borderRadiusToString(borderRadius?.borderTopRightRadius) ?? 0,\n borderBottomRightRadius: borderRadiusToString(borderRadius?.borderBottomRightRadius) ?? 0,\n borderBottomLeftRadius: borderRadiusToString(borderRadius?.borderBottomLeftRadius) ?? 0,\n }),\n }),\n ),\n }\n\n function widthToString(widthProperty: WidthPropertyData | undefined): string | null {\n if (widthProperty == null) return null\n\n return `${widthProperty.value}${widthProperty.unit}`\n }\n\n function marginToString(\n marginProperty: MarginLonghandPropertyData | null | undefined,\n ): string | null {\n if (marginProperty == null) return null\n\n if (marginProperty === 'auto') return marginProperty\n\n return `${marginProperty.value}${marginProperty.unit}`\n }\n\n function paddingToString(\n paddingProperty: PaddingLonghandPropertyData | null | undefined,\n ): string | null {\n if (paddingProperty == null) return null\n\n return `${paddingProperty.value}${paddingProperty.unit}`\n }\n\n function borderSideToString(borderSide: BorderSide | null | undefined): string | null {\n if (borderSide == null) return null\n\n const { width, color, style } = borderSide\n return `${width != null ? width : 0}px ${style} ${\n color != null ? colorToString(color) : 'black'\n }`\n }\n\n function borderRadiusToString(\n borderRadius: BorderRadiusLonghandPropertyData | null | undefined,\n ): string | null {\n if (borderRadius == null) return null\n\n return `${borderRadius.value}${borderRadius.unit}`\n }\n}\n\nconst useInsertionEffectSpecifier = 'useInsertionEffect'\n// @ts-expect-error: React types are outdated.\nconst useInsertionEffect = React[useInsertionEffectSpecifier] ?? React.useLayoutEffect\nconst isServer = typeof window === 'undefined'\n\nexport type StyleControlFormattedValue = string\n\nexport function useFormattedStyle(\n styleControlData: StyleControlData | undefined,\n controlDefinition: StyleControlDefinition,\n): StyleControlFormattedValue {\n const style = useStyleControlCssObject(styleControlData, controlDefinition)\n\n if (isServer) return css(style)\n\n const serialized = serializeStyles([style], cache.registered)\n\n useInsertionEffect(() => {\n insertStyles(cache, serialized, false)\n })\n\n return `${cache.key}-${serialized.name}`\n}\n","type Props<H extends (...args: any[]) => any> = {\n /**\n * `<RenderHook>` requires key that changes whenever the `hook` prop changes to ensure the rules of\n * hooks are followed.\n */\n key: string\n\n hook: H\n parameters: Parameters<H>\n children(result: ReturnType<H>): JSX.Element\n}\n\nexport function RenderHook<H extends (...args: any[]) => any>({\n hook: useHook,\n parameters,\n children,\n}: Props<H>) {\n return children(useHook(...parameters))\n}\n","import { CheckboxControlData, CheckboxControlDefinition } from '../../../controls'\n\nexport type CheckboxControlValue<T extends CheckboxControlDefinition> =\n undefined extends T['config']['defaultValue'] ? boolean | undefined : boolean\n\nexport function useCheckboxControlValue<T extends CheckboxControlDefinition>(\n data: CheckboxControlData | undefined,\n definition: T,\n): CheckboxControlValue<T> {\n return (data ?? definition.config.defaultValue) as CheckboxControlValue<T>\n}\n","import Color from 'color'\n\nimport { useQuery } from '../../../api/react'\nimport { SWATCHES_BY_ID } from '../../../components/utils/queries'\nimport { ColorControlData, ColorControlDefinition } from '../../../controls/color'\n\nexport type ColorControlValue<T extends ColorControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\ntype Swatch = {\n id: string\n hue: number\n saturation: number\n lightness: number\n}\n\ntype SwatchesById = { swatches: Swatch[] }\n\nexport function useColorValue<T extends ColorControlDefinition>(\n data: ColorControlData | undefined,\n definition: T,\n): ColorControlValue<T> {\n const result = useQuery<SwatchesById>(SWATCHES_BY_ID, {\n variables: { ids: [data?.swatchId] },\n skip: data?.swatchId == null,\n })\n\n if (data === undefined) {\n const { defaultValue } = definition.config\n\n if (defaultValue === undefined) return undefined as ColorControlValue<T>\n\n let defaultColor\n try {\n defaultColor = Color(definition.config.defaultValue)\n } catch {\n defaultColor = Color()\n }\n\n return defaultColor.rgb().string()\n }\n\n const [swatch] = result.data?.swatches ?? [null]\n\n return Color({ h: swatch?.hue, s: swatch?.saturation, l: swatch?.lightness })\n .alpha(data.alpha)\n .rgb()\n .string()\n}\n","import {\n ComboboxControlData,\n ComboboxControlDefinition,\n ComboboxControlDefinitionOption,\n} from '../../../controls'\n\nexport type ComboboxControlValue<T extends ComboboxControlDefinition> =\n | ComboboxControlDefinitionOption<T>\n | undefined\n\nexport function useComboboxControlValue<T extends ComboboxControlDefinition>(\n data: ComboboxControlData<T> | undefined,\n): ComboboxControlValue<T> {\n return data?.value\n}\n","import { useFile } from '../../../components'\nimport { ImageControlData } from '../../../controls'\n\nexport type ImageControlValue = string | undefined\n\nexport function useImageControlValue(data: ImageControlData | undefined): ImageControlValue {\n return useFile(data)?.publicUrl\n}\n","import { ListControlData, ListControlDefinition } from '../../../controls'\nimport { ControlDefinitionValue, ControlValue } from './control'\n\ntype ListControlItemValue<T extends ListControlDefinition> = ControlDefinitionValue<\n T['config']['type']\n>\n\nexport type ListControlValue<T extends ListControlDefinition> = ListControlItemValue<T>[]\n\ntype ListControlValueProps<T extends ListControlDefinition> = {\n definition: T\n data: ListControlData<T> | undefined\n children(value: ListControlValue<T>): JSX.Element\n}\n\nexport function ListControlValue<T extends ListControlDefinition>({\n definition,\n data,\n children,\n}: ListControlValueProps<T>): JSX.Element {\n return (data ?? []).reduce(\n (renderFn, item) => listControlValue =>\n (\n <ControlValue definition={definition.config.type} data={item.value}>\n {value => renderFn([value as ListControlItemValue<T>, ...listControlValue])}\n </ControlValue>\n ),\n children,\n )([])\n}\n","import { NumberControlData, NumberControlDefinition } from '../../../controls'\n\nexport type NumberControlValue<T extends NumberControlDefinition> =\n undefined extends T['config']['defaultValue'] ? NumberControlData | undefined : NumberControlData\n\nexport function useNumber<T extends NumberControlDefinition>(\n numberControlData: number | undefined,\n controlDefinition: T,\n): NumberControlValue<T> {\n return (numberControlData ?? controlDefinition.config.defaultValue) as NumberControlValue<T>\n}\n","import {\n SelectControlData,\n SelectControlDefinition,\n SelectControlDefinitionOption,\n} from '../../../controls'\n\nexport type SelectControlValue<T extends SelectControlDefinition> =\n undefined extends T['config']['defaultValue']\n ? SelectControlDefinitionOption<T> | undefined\n : SelectControlDefinitionOption<T>\n\nexport function useSelectControlValue<T extends SelectControlDefinition>(\n data: SelectControlData<T> | undefined,\n definition: T,\n): SelectControlValue<T> {\n return (data ?? definition?.config.defaultValue) as SelectControlValue<T>\n}\n","import { ShapeControlData, ShapeControlDefinition } from '../../../controls/shape'\nimport { ControlDefinitionValue, ControlValue } from './control'\n\nexport type ShapeControlValue<T extends ShapeControlDefinition> = {\n [K in keyof T['config']['type']]: ControlDefinitionValue<T['config']['type'][K]>\n}\n\ntype ShapeControlValueProps<T extends ShapeControlDefinition> = {\n definition: T\n data: ShapeControlData<T> | undefined\n children(value: ShapeControlValue<T>): JSX.Element\n}\n\nexport function ShapeControlValue<T extends ShapeControlDefinition>({\n definition,\n data,\n children,\n}: ShapeControlValueProps<T>) {\n return Object.entries(definition.config.type).reduceRight(\n (renderFn, [key, controlDefinition]) =>\n shapeControlValue =>\n (\n <ControlValue definition={controlDefinition} data={data?.[key]}>\n {value => renderFn({ ...shapeControlValue, [key]: value })}\n </ControlValue>\n ),\n children,\n )({} as ShapeControlValue<T>)\n}\n","import { TextAreaControlData, TextAreaControlDefinition } from '../../../controls'\n\nexport type TextAreaControlValue<T extends TextAreaControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\nexport function useTextAreaValue<T extends TextAreaControlDefinition>(\n data: TextAreaControlData | undefined,\n definition: T,\n): TextAreaControlValue<T> {\n return (data ?? definition.config.defaultValue) as TextAreaControlValue<T>\n}\n","import { TextInputControlData, TextInputControlDefinition } from '../../../controls'\n\nexport type TextInputControlValue<T extends TextInputControlDefinition> =\n undefined extends T['config']['defaultValue'] ? string | undefined : string\n\nexport function useTextInputValue<T extends TextInputControlDefinition>(\n data: TextInputControlData | undefined,\n definition: T,\n): TextInputControlValue<T> {\n return (data ?? definition.config.defaultValue) as TextInputControlValue<T>\n}\n","import {\n CheckboxControlData,\n CheckboxControlDefinition,\n CheckboxControlType,\n ColorControlData,\n ColorControlDefinition,\n ColorControlType,\n ComboboxControlData,\n ComboboxControlDefinition,\n ComboboxControlType,\n ControlDefinition,\n ControlDefinitionData,\n ImageControlData,\n ImageControlDefinition,\n ImageControlType,\n ListControlData,\n ListControlDefinition,\n ListControlType,\n NumberControlData,\n NumberControlDefinition,\n NumberControlType,\n SelectControlData,\n SelectControlDefinition,\n SelectControlType,\n ShapeControlData,\n ShapeControlDefinition,\n ShapeControlType,\n TextAreaControlData,\n TextAreaControlDefinition,\n TextAreaControlType,\n TextInputControlData,\n TextInputControlDefinition,\n TextInputControlType,\n} from '../../../controls'\nimport { RenderHook } from '../components'\nimport { CheckboxControlValue, useCheckboxControlValue } from './checkbox'\nimport { ColorControlValue, useColorValue } from './color'\nimport { ComboboxControlValue, useComboboxControlValue } from './combobox'\nimport { ImageControlValue, useImageControlValue } from './image'\nimport { ListControlValue } from './list'\nimport { NumberControlValue, useNumber } from './number'\nimport { SelectControlValue, useSelectControlValue } from './select'\nimport { ShapeControlValue } from './shape'\nimport { TextAreaControlValue, useTextAreaValue } from './text-area'\nimport { TextInputControlValue, useTextInputValue } from './text-input'\n\nexport type ControlDefinitionValue<T extends ControlDefinition> =\n T extends CheckboxControlDefinition\n ? CheckboxControlValue<T>\n : T extends NumberControlDefinition\n ? NumberControlValue<T>\n : T extends TextInputControlDefinition\n ? TextInputControlValue<T>\n : T extends TextAreaControlDefinition\n ? TextAreaControlValue<T>\n : T extends SelectControlDefinition\n ? SelectControlValue<T>\n : T extends ColorControlDefinition\n ? ColorControlValue<T>\n : T extends ImageControlDefinition\n ? ImageControlValue\n : T extends ComboboxControlDefinition\n ? ComboboxControlValue<T>\n : T extends ShapeControlDefinition\n ? ShapeControlValue<T>\n : T extends ListControlDefinition\n ? ListControlValue<T>\n : never\n\ntype ControlValueProps<T extends ControlDefinition> = {\n definition: T\n data: ControlDefinitionData<T> | undefined\n children(value: ControlDefinitionValue<T>): JSX.Element\n}\n\nexport function ControlValue<T extends ControlDefinition>({\n data,\n definition,\n children,\n}: ControlValueProps<T>): JSX.Element {\n switch (definition.type) {\n case CheckboxControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useCheckboxControlValue}\n parameters={[data as CheckboxControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case NumberControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useNumber}\n parameters={[data as NumberControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case TextInputControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useTextInputValue}\n parameters={[data as TextInputControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case TextAreaControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useTextAreaValue}\n parameters={[data as TextAreaControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case SelectControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useSelectControlValue}\n parameters={[data as SelectControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ColorControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useColorValue}\n parameters={[data as ColorControlData, definition]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ImageControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useImageControlValue}\n parameters={[data as ImageControlData]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ComboboxControlType:\n return (\n <RenderHook\n key={definition.type}\n hook={useComboboxControlValue}\n parameters={[data as ComboboxControlData]}\n >\n {value => children(value as ControlDefinitionValue<T>)}\n </RenderHook>\n )\n\n case ShapeControlType:\n return (\n <ShapeControlValue definition={definition} data={data as ShapeControlData}>\n {value => children(value as ControlDefinitionValue<T>)}\n </ShapeControlValue>\n )\n\n case ListControlType:\n return (\n <ListControlValue definition={definition} data={data as ListControlData}>\n {value => children(value as ControlDefinitionValue<T>)}\n </ListControlValue>\n )\n\n default:\n return children(data as ControlDefinitionValue<T>)\n }\n}\n","import { useMemo, useRef } from 'react'\n\nimport { useStore } from '.'\nimport * as ReactPage from '../../state/react-page'\nimport { Props } from '../../prop-controllers'\nimport {\n Descriptor,\n Device,\n ResolveOptions,\n ResponsiveValue,\n WidthControlValueFormats,\n WidthDescriptor,\n WidthValue,\n} from '../../prop-controllers/descriptors'\nimport { css } from '@emotion/css'\nimport { useResponsiveColor } from '../../components'\nimport type { ColorValue } from '../../components/utils/types'\nimport { responsiveWidth } from '../../components/utils/responsive-style'\nimport {\n CheckboxControlType,\n ColorControlType,\n ComboboxControlType,\n ImageControlType,\n ListControlType,\n NumberControlType,\n SelectControlType,\n ShapeControlType,\n StyleControlType,\n TextAreaControlType,\n TextInputControlType,\n} from '../../controls'\nimport { useFormattedStyle } from './controls/style'\nimport { ControlValue } from './controls/control'\nimport { RenderHook } from './components'\n\nexport type ResponsiveColor = ResponsiveValue<ColorValue>\n\nfunction useDeviceMode(): Device {\n return 'desktop'\n}\n\nfunction useWidth(\n value: WidthValue | undefined,\n descriptor: WidthDescriptor,\n props: Record<string, unknown>,\n): string | WidthValue | undefined {\n const deviceMode = useDeviceMode()\n const options = useMemo(\n () =>\n typeof descriptor.options === 'function'\n ? descriptor.options(props, deviceMode)\n : descriptor.options,\n [props, deviceMode],\n )\n\n return useMemo(\n () =>\n options.format === WidthControlValueFormats.ClassName\n ? css(responsiveWidth(value, options.defaultValue))\n : value,\n [value, options.defaultValue, options.format],\n )\n}\n\nexport type ResolveWidthControlValue<T extends Descriptor> = T extends WidthDescriptor\n ? undefined extends ResolveOptions<T['options']>['format']\n ? WidthValue | undefined\n : ResolveOptions<T['options']>['format'] extends typeof WidthControlValueFormats.ClassName\n ? string\n : ResolveOptions<T['options']>['format'] extends typeof WidthControlValueFormats.ResponsiveValue\n ? WidthValue | undefined\n : never\n : never\n\ntype PropsValueProps = {\n element: ReactPage.ElementData\n children(props: Record<string, unknown>): JSX.Element\n}\n\nexport function PropsValue({ element, children }: PropsValueProps): JSX.Element {\n const store = useStore()\n const propControllerDescriptorsRef = useRef(\n ReactPage.getComponentPropControllerDescriptors(store.getState(), element.type) ?? {},\n )\n const props = element.props as Record<string, any>\n\n return Object.entries(propControllerDescriptorsRef.current).reduceRight(\n (renderFn, [propName, descriptor]) =>\n propsValue => {\n switch (descriptor.type) {\n case CheckboxControlType:\n case NumberControlType:\n case TextInputControlType:\n case TextAreaControlType:\n case SelectControlType:\n case ColorControlType:\n case ImageControlType:\n case ComboboxControlType:\n case ShapeControlType:\n case ListControlType:\n return (\n <ControlValue definition={descriptor} data={props[propName]}>\n {value => renderFn({ ...propsValue, [propName]: value })}\n </ControlValue>\n )\n\n case StyleControlType:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useFormattedStyle}\n parameters={[props[propName], descriptor]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n case Props.Types.Width:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useWidth}\n parameters={[props[propName], descriptor, props]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n case Props.Types.ResponsiveColor:\n return (\n <RenderHook\n key={descriptor.type}\n hook={useResponsiveColor}\n parameters={[props[propName]]}\n >\n {value => renderFn({ ...propsValue, [propName]: value })}\n </RenderHook>\n )\n\n default:\n return renderFn({ ...propsValue, [propName]: props[propName] })\n }\n },\n children,\n )({})\n}\n","import { ForwardedRef } from 'react'\nimport { ReactInstance } from 'react'\nimport { forwardRef } from 'react'\nimport { Component, ReactNode } from 'react'\nimport { findDOMNode } from 'react-dom'\n\ntype FindDomNodeClassComponentProps = {\n innerRef?: ForwardedRef<Element | Text | null>\n children?: ReactNode\n}\n\n/**\n * @see https://github.com/facebook/react/blob/a2505792ed17fd4d7ddc69561053c3ac90899491/packages/react-reconciler/src/ReactFiberReconciler.new.js#L179-L244\n */\nfunction suppressWarningAndFindDomNode(\n instance: ReactInstance | null | undefined,\n): Element | Text | null {\n const error = console.error\n\n console.error = (...args) => {\n if (typeof args[0] === 'string' && args[0].includes('%s is deprecated in StrictMode.')) return\n\n return error.apply(console, args)\n }\n\n const foundDomNode = findDOMNode(instance)\n\n console.error = error\n\n return foundDomNode\n}\n\nclass FindDomNodeClassComponent extends Component<FindDomNodeClassComponentProps> {\n componentDidMount() {\n this.setInnerRef(suppressWarningAndFindDomNode(this))\n }\n\n componentDidUpdate() {\n this.setInnerRef(suppressWarningAndFindDomNode(this))\n }\n\n setInnerRef(current: Element | Text | null) {\n const { innerRef } = this.props\n\n if (innerRef == null) return\n\n if (typeof innerRef === 'function') innerRef(current)\n else innerRef.current = current\n }\n\n render() {\n return <>{this.props.children}</>\n }\n}\n\ntype FindDomNodeProps = {\n children?: ReactNode\n}\n\nexport const FindDomNode = forwardRef<Element | Text | null, FindDomNodeProps>(function FindDomNode(\n props,\n ref,\n) {\n return <FindDomNodeClassComponent {...props} innerRef={ref} />\n})\n","import {\n ComponentPropsWithoutRef,\n createContext,\n forwardRef,\n memo,\n ReactNode,\n Ref,\n useContext,\n useEffect,\n useImperativeHandle,\n useRef,\n useState,\n} from 'react'\nimport { useSyncExternalStoreWithSelector } from 'use-sync-external-store/shim/with-selector'\n\nimport * as ReactPage from '../../state/react-page'\nimport type * as ReactBuilderPreview from '../../state/react-builder-preview'\nimport {\n mountComponentEffect,\n registerComponentEffect,\n registerComponentHandleEffect,\n registerDocumentEffect,\n registerReactComponentEffect,\n} from '../../state/actions'\nimport type {\n PropControllerDescriptor,\n PropControllerDescriptorValueType,\n} from '../../prop-controllers'\nimport { ComponentIcon } from '../../state/modules/components-meta'\nimport { registerBuiltinComponents } from '../../components'\nimport { MakeswiftProvider, MakeswiftClient, useQuery } from '../../api/react'\nimport { FallbackComponent } from '../../components/shared/FallbackComponent'\nimport { PropsValue } from './controls'\nimport { FindDomNode } from './find-dom-node'\nimport { ELEMENT_REFERENCE_GLOBAL_ELEMENT } from '../../components/utils/queries'\n\nexport const storeContextDefaultValue = ReactPage.configureStore()\n\nexport interface ReactRuntime {\n registerComponent<\n P extends Record<string, PropControllerDescriptor>,\n C extends ReactPage.ComponentType<{ [K in keyof P]: PropControllerDescriptorValueType<P[K]> }>,\n >(\n component: C,\n meta: { type: string; label: string; icon?: ComponentIcon; hidden?: boolean; props?: P },\n ): () => void\n}\n\nfunction createReactRuntime(store: ReactPage.Store): ReactRuntime {\n return {\n registerComponent(component, { type, label, icon = 'Cube40', hidden = false, props }) {\n const unregisterComponent = store.dispatch(\n registerComponentEffect(type, { label, icon, hidden }, props ?? {}),\n )\n\n const unregisterReactComponent = store.dispatch(\n registerReactComponentEffect(type, component as unknown as ReactPage.ComponentType),\n )\n\n return () => {\n unregisterComponent()\n unregisterReactComponent()\n }\n },\n }\n}\n\nexport const ReactRuntime = createReactRuntime(storeContextDefaultValue)\n\nregisterBuiltinComponents(ReactRuntime)\n\nconst Context = createContext(storeContextDefaultValue)\n\ntype RuntimeProviderProps = {\n client: MakeswiftClient\n rootElements?: Map<string, ReactPage.Element>\n children?: ReactNode\n}\n\nexport function RuntimeProvider({\n client,\n children,\n rootElements,\n}: RuntimeProviderProps): JSX.Element {\n const [store, setStore] = useState(() => {\n const store = ReactPage.configureStore({\n preloadedState: storeContextDefaultValue.getState(),\n rootElements,\n })\n\n return store\n })\n\n useEffect(() => {\n const unregisterDocuments = Array.from(rootElements?.entries() ?? []).map(\n ([documentKey, rootElement]) =>\n store.dispatch(registerDocumentEffect(ReactPage.createDocument(documentKey, rootElement))),\n )\n\n return () => {\n unregisterDocuments.forEach(unregisterDocument => {\n unregisterDocument()\n })\n }\n }, [store, rootElements])\n\n useEffect(() => {\n // TODO(miguel): perform a more robust validation.\n const isInBuilder = window.parent !== window\n\n if (isInBuilder) setReactBuilderPreviewStore()\n\n async function setReactBuilderPreviewStore(): Promise<void> {\n const ReactBuilderPreview = await import('../../state/react-builder-preview')\n\n setStore(store =>\n ReactBuilderPreview.configureStore({\n preloadedState: store.getState(),\n client: client.apolloClient,\n }),\n )\n }\n }, [client])\n\n return (\n <Context.Provider value={store}>\n <MakeswiftProvider client={client}>{children}</MakeswiftProvider>\n </Context.Provider>\n )\n}\n\nconst PageContext = createContext<string | null>(null)\n\nfunction usePageIdOrNull(): string | null {\n return useContext(PageContext)\n}\n\nexport function usePageId(): string {\n const pageIdOrNull = usePageIdOrNull()\n\n if (pageIdOrNull == null) throw new Error('`usePageId` must be used with `<PageProvider>`')\n\n return pageIdOrNull\n}\n\ntype PageProviderProps = {\n id: string\n children: ComponentPropsWithoutRef<typeof PageContext['Provider']>['children']\n}\n\nexport function PageProvider({ id, children }: PageProviderProps) {\n return <PageContext.Provider value={id}>{children}</PageContext.Provider>\n}\n\nconst DocumentContext = createContext<string | null>(null)\n\nfunction useDocumentKey(): string | null {\n return useContext(DocumentContext)\n}\n\ntype State = ReactPage.State | ReactBuilderPreview.State\n\nexport function useStore(): ReactPage.Store {\n return useContext(Context)\n}\n\nfunction useSelector<R>(selector: (state: State) => R): R {\n const store = useStore()\n\n return useSyncExternalStoreWithSelector(store.subscribe, store.getState, store.getState, selector)\n}\n\nfunction useComponent(type: string): ReactPage.ComponentType | null {\n return useSelector(state => ReactPage.getReactComponent(state, type))\n}\n\nexport function useElementId(elementKey: string | null | undefined): string | null {\n const documentKey = useDocumentKey()\n\n return useSelector(state =>\n documentKey == null || elementKey == null\n ? null\n : ReactPage.getElementId(state, documentKey, elementKey),\n )\n}\n\nfunction useDocument(documentKey: string): ReactPage.Document | null {\n return useSelector(state => ReactPage.getDocument(state, documentKey))\n}\n\nexport function useIsInBuilder(): boolean {\n return useSelector(state => ReactPage.getIsInBuilder(state))\n}\n\ntype Dispatch = ReactPage.Dispatch & ReactBuilderPreview.Dispatch\n\nfunction useDispatch(): Dispatch {\n const store = useContext(Context)\n\n return store.dispatch\n}\n\n/**\n * @see https://github.com/facebook/react/blob/a2505792ed17fd4d7ddc69561053c3ac90899491/packages/react-reconciler/src/ReactFiberBeginWork.new.js#L1814-L1890\n */\nfunction useSuppressRefWarning(ownerName: string) {\n const originalErrorRef = useRef(console.error)\n const patchedRef = useRef(false)\n\n if (patchedRef.current === false) {\n console.error = (...args) => {\n if (\n typeof args[0] === 'string' &&\n args[0].includes('Function components cannot be given refs.') &&\n args[0].includes(`Check the render method of \\`${ownerName}\\`.`)\n ) {\n return\n }\n\n return originalErrorRef.current(...args)\n }\n\n patchedRef.current = true\n }\n}\n\ntype ElementDataProps = {\n elementData: ReactPage.ElementData\n}\n\nconst ElementData = memo(\n forwardRef(function ElementData(\n { elementData }: ElementDataProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const Component = useComponent(elementData.type)\n const [handle, setHandle] = useState<unknown | null>(null)\n const [foundDomNode, setFoundDomNode] = useState<Element | Text | null>(null)\n\n useImperativeHandle(ref, () => handle ?? foundDomNode, [handle, foundDomNode])\n\n useSuppressRefWarning(`\\`ForwardRef(${ElementData.name})\\``)\n\n if (Component == null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Component not found\" />\n }\n\n return (\n <FindDomNode ref={setFoundDomNode}>\n <PropsValue element={elementData}>\n {props => <Component {...props} key={elementData.key} ref={setHandle} />}\n </PropsValue>\n </FindDomNode>\n )\n }),\n)\n\nconst DisableRegisterElement = createContext(false)\n\ntype ElementRefereceProps = {\n elementReference: ReactPage.ElementReference\n}\n\nconst ElementReference = memo(\n forwardRef(function ElementReference(\n { elementReference }: ElementRefereceProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const { error, data } = useQuery(ELEMENT_REFERENCE_GLOBAL_ELEMENT, {\n variables: { id: elementReference.value },\n })\n const globalElementData = data?.globalElement?.data as ReactPage.ElementData | undefined\n const elementReferenceDocument = useDocument(elementReference.key)\n\n if (error != null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Something went wrong!\" />\n }\n\n if (globalElementData == null) {\n return (\n <FallbackComponent\n ref={ref as Ref<HTMLDivElement>}\n text=\"This global component doesn't exist\"\n />\n )\n }\n\n return elementReferenceDocument != null ? (\n <Document document={elementReferenceDocument} ref={ref} />\n ) : (\n <DisableRegisterElement.Provider value={true}>\n <ElementData elementData={globalElementData} ref={ref} />\n </DisableRegisterElement.Provider>\n )\n }),\n)\n\ntype ElementProps = {\n element: ReactPage.Element\n}\n\nexport const Element = memo(\n forwardRef(function Element({ element }: ElementProps, ref: Ref<unknown>): JSX.Element {\n const elementKey = element.key\n const dispatch = useDispatch()\n const documentKey = useDocumentKey()\n const [handle, setHandle] = useState<unknown>(null)\n const isRegisterElementDisabled = useContext(DisableRegisterElement)\n\n useImperativeHandle(ref, () => handle, [handle])\n\n useEffect(() => {\n if (documentKey == null || isRegisterElementDisabled) return\n\n return dispatch(registerComponentHandleEffect(documentKey, elementKey, handle))\n }, [dispatch, documentKey, elementKey, handle, isRegisterElementDisabled])\n\n useEffect(() => {\n if (documentKey == null || isRegisterElementDisabled) return\n\n return dispatch(mountComponentEffect(documentKey, elementKey))\n }, [dispatch, documentKey, elementKey, isRegisterElementDisabled])\n\n return ReactPage.isElementReference(element) ? (\n <ElementReference key={elementKey} ref={setHandle} elementReference={element} />\n ) : (\n <ElementData key={elementKey} ref={setHandle} elementData={element} />\n )\n }),\n)\n\ntype DocumentProps = {\n document: ReactPage.Document\n}\n\nconst Document = memo(\n forwardRef(function Document({ document }: DocumentProps, ref: Ref<unknown>): JSX.Element {\n return (\n <DocumentContext.Provider value={document.key}>\n <Element ref={ref} element={document.rootElement} />\n </DocumentContext.Provider>\n )\n }),\n)\n\ntype DocumentReferenceProps = {\n documentReference: ReactPage.DocumentReference\n}\n\nexport const DocumentReference = memo(\n forwardRef(function DocumentReference(\n { documentReference }: DocumentReferenceProps,\n ref: Ref<unknown>,\n ): JSX.Element {\n const document = useDocument(documentReference.key)\n\n if (document == null) {\n return <FallbackComponent ref={ref as Ref<HTMLDivElement>} text=\"Document not found\" />\n }\n\n return <Document ref={ref} document={document} />\n }),\n)\n"],"names":["PlaceholderBase","styled","div","hide","forwardRef","ref","restOfProps","overflow","typePolicies","Query","fields","swatches","existingData","args","toReference","ids","map","id","__typename","file","files","typographies","pagePathnamesById","globalElement","table","page","site","uri","cacheData","cache","InMemoryCache","restore","ApolloClient","link","BatchHttpLink","batchMax","MakeswiftClient","constructor","apolloClient","createApolloClient","prefetch","element","introspectionData","introspect","storeContextDefaultValue","res","query","INTROSPECTION_QUERY","variables","data","forEach","pagePathnameSlice","Buffer","from","toString","writeFragment","fragment","PagePathnameSliceFragmentDoc","KeyUtils","resetGenerator","extract","updateCacheData","Context","createContext","undefined","options","client","useContext","useApolloQuery","mutation","useApolloMutation","children","_jsx","defaultExitedProps","opacity","x","y","scale","boxAnimations","none","entered","exited","transition","fadeIn","fadeLeft","type","ease","fadeRight","fadeUp","fadeDown","blurIn","filter","scaleDown","scaleUp","mergeCustomTransitionWithDefault","transitions","props","Object","keys","reduce","a","c","useElementOnScreen","isVisible","setIsVisible","useState","useEffect","observer","IntersectionObserver","intersectionCallback","observe","unobserve","entry","isIntersecting","DEFAULT_BOX_ANIMATE_TYPE","DEFAULT_BOX_ANIMATE_DELAY","DEFAULT_BOX_ANIMATE_DURATION","DEFAULT_ITEM_ANIMATE_TYPE","DEFAULT_ITEM_ANIMATE_DELAY","DEFAULT_ITEM_ANIMATE_DURATION","DEFAULT_ITEM_STAGGER_DURATION","useBoxAnimations","boxElement","elements","reducedMotion","useReducedMotion","boxAnimateType","useMediaQuery","boxAnimateDuration","boxAnimateDelay","itemAnimateType","itemAnimateDuration","itemAnimateDelay","itemStaggerDuration","isBoxVisible","root","rootMargin","threshold","itemControls","useAnimation","boxControls","setSequence","useCallback","variant","stop","set","playSequence","start","e","key","sort","join","boxVariant","itemVariant","initial","container","parent","animate","variants","child","delay","duration","delayChildren","staggerChildren","joinResponsiveValues","overflowY","overflowX","ownerDocument","defaultView","getComputedStyle","test","parentElement","isScrollable","getScrollParent","strength","rest","useRef","containerScrollTop","setContainerScrollTop","lastScrollParentScrollTop","useIsomorphicLayoutEffect","current","containerDocument","scrollParent","eventTarget","documentElement","scrollTop","requestAnimationFrame","top","containerTop","bottom","containerBottom","getBoundingClientRect","scrollParentTop","scrollParentBottom","innerHeight","scrollParentScrollTop","pageYOffset","scrollParentHeight","scrollParentScrollDelta","isContainerVisible","containerScrollRemaining","scrollParentScrollRemaining","parallaxRatio","containerScrollDelta","clamp","addEventListener","handleScroll","removeEventListener","getProps","style","restOfChildrenProps","position","left","right","transform","Container","Mask","backgroundColor","visible","getScale","aspectRatio","zoom","offsetWidth","width","offsetHeight","height","computedAspectRatio","Math","max","url","maskColor","ready","setReady","setScale","containerEl","handleResize","ReactPlayer","canPlay","_Fragment","vimeo","playerOptions","background","youtube","playerVars","origin","location","wistia","endVideoBehavior","playbackRateControl","playbar","playButton","volumeControl","fullscreenButton","muted","color","swatch","colorToString","hue","saturation","lightness","getStopsStyle","stops","getColor","getAspectRatio","AbsoluteFill","BackgroundsContainer","p","cssMediaRules","visibility","css","backgrounds","value","deviceId","v","reverse","bg","payload","publicUrl","repeat","size","parallax","backgroundPosition","getParallaxProps","backgroundImage","backgroundRepeat","backgroundSize","angle","isRadial","gradient","OuterContainer","motion","handle","setHandle","useImperativeHandle","useBackgrounds","Children","only","StyledBackgroundsContainer","withConfig","shouldForwardProp","prop","includes","cssMargin","cssBorderRadius","alignSelf","Grid","cssPadding","cssBorder","cssBoxShadow","alignContent","GridItem","cssGridItem","alignItems","Box","margin","padding","border","borderRadius","boxShadow","rowGap","columnGap","hidePlaceholder","verticalAlign","innerRef","setBoxElement","getBoxModel","paddingBoxElement","borderBoxElement","marginBoxElement","borderBox","paddingBoxComputedStyle","borderBoxComputedStyle","marginBoxComputedStyle","parse","paddingTop","paddingRight","paddingBottom","paddingLeft","borderTopWidth","borderRightWidth","borderBottomWidth","borderLeftWidth","marginTop","marginRight","marginBottom","marginLeft","createBox","borderData","useBorder","boxShadowData","useBoxShadow","cx","length","index","columns","Element","Placeholder","runtime","property","animateIn","isHiddenBasedOnBoxAnimation","isHiddenBasedOnAnimationType","isHiddenBasedOnItemAnimation","registerComponent","label","Props","format","Formats","ClassName","icon","defaultValue","preset","unit","hidden","labelOrientation","device","min","step","suffix","Link","onClick","usePage","pageId","elementKey","elementIdConfig","elementId","useElementId","href","target","block","pathname","openInNewTab","to","subject","body","phoneNumber","RangeError","handleClick","event","defaultPrevented","currentTarget","isContentEditable","preventDefault","hash","URL","error","view","scrollIntoView","document","querySelector","behavior","history","pushState","StyledButton","shape","textColor","alpha","fontSize","small","medium","large","square","rounded","pill","flat","ColorHelper","darken","hex","outline","shadow","clear","blocky","bubbly","lighten","saturate","skewed","cssTextStyle","Button","textStyle","className","toClass","responsiveWidth","placeholder","findDeviceOverride","src","Promise","resolve","reject","image","Image","onload","onerror","baseDevice","DEVICES","find","maxWidth","baseWidth","baseWidthSize","override","sourceSizes","sourceSize","ImageContainer","UnoptimizedImage","img","ImageComponent","altText","placeholders","fileData","useFile","imageSrc","dataDimensions","dimensions","measuredDimensions","setMeasuredDimensions","isInBuilder","useIsInBuilder","cleanedUp","then","naturalWidth","naturalHeight","catch","console","widthClass","imageSizes","LeftChevron","RightChevron","Wrapper","Arrow","Slop","Slide","pageSize","Reel","gap","Page","LeftSlop","RightSlop","ClipMask","Dots","Dot","active","SWIPE_THRESHOLD","swipePower","dx","velocity","Carousel","images","responsivePageSize","responsiveStep","slideAlignment","showDots","showArrows","arrowPosition","arrowColor","arrowBackground","dotColor","autoplay","slideBorder","slideBorderRadius","setIndex","swipe","startIndex","wrap","endIndex","pageCount","ceil","pageIndex","isFirstPage","isLastPage","paginate","pageDistance","direction","abs","remaining","slice","distance","animation","stiffness","bindPage","useGesture","onDrag","movement","mx","delta","onDragEnd","drag","axis","bounds","rubberband","intervalId","setInterval","clearInterval","_jsxs","imageProps","Array","_","i","uuid","imagesLength","pageSizeValue","Block","Label","Segment","blockColor","numberColor","numberFont","labelColor","labelFont","getRemaining","date","days","hours","minutes","seconds","timeDiff","Date","getTime","now","floor","parseInt","String","Countdown","daysLabel","hoursLabel","minutesLabel","secondsLabel","setRemaining","toISOString","IE11MinHeightContainer","Line","thickness","Error","Divider","defaultHtml","SCRIPT_TAG","Embed","html","setContainer","shouldRender","setShouldRender","walker","createTreeWalker","NodeFilter","SHOW_ELEMENT","acceptNode","node","tagName","toLowerCase","FILTER_ACCEPT","FILTER_REJECT","nodes","nextNode","push","currentNode","script","createElement","textContent","attributes","name","setAttribute","parentNode","insertBefore","removeChild","hasAttribute","__html","rows","_path","_extends","getContrastColor","Sizes","SMALL","MEDIUM","LARGE","Base","input","defaultValidator","cssField","getSizeHeight","form","contrast","brandColor","useFormContext","Input","display","flexDirection","justifyContent","Contrasts","LIGHT","DARK","labelTextStyle","labelTextColor","hideLabel","textarea","h","s","l","Color","isLight","getSize","FakeCheckbox","getContrastBorderColor","getContrastBackgroundColor","HiddenCheckbox","getCheckmarkColor","StyledLabel","getInputSizeHeight","CheckboxContainer","span","handleChange","setFieldValue","checked","MainLabel","tableColumn","required","onChange","validity","valueMissing","typeMismatch","option","FakeRadioButton","HiddenRadioButton","attrs","RadioButtonContainer","getSizeHorizontalPadding","Select","select","getLabelSizeHeight","Shapes","ROUNDED","getShapeBorderRadius","SingleLineTextTableField","LongTextTableField","CheckboxTableField","MultipleSelectTableField","SingleSelectTableField","PhoneNumberTableField","EmailTableField","URLTableField","NumberTableField","tableFormField","TableColumnField","getTableColumnField","errorMessage","getTypeMismatchErrorMessage","FormikField","field","getIn","touched","errors","spin","keyframes","Icon","Spinner20","LOCAL_STORAGE_NAMESPACE","Alignments","LEFT","CENTER","RIGHT","GridForm","getSizeFontSize","alignment","getAlignmentMargin","ErrorContainer","IconContainer","ErrorMessage","CREATE_TABLE_RECORD","gql","Form","tableId","fieldsProp","submitLabel","submitLink","submitTextStyle","submitVariant","submitTextColor","submitWidth","submitAlignment","useMemo","grid","useTable","createTableRecord","useMutation","refEl","setRefEl","propControllers","setPropControllers","initialValues","setInitialValues","acc","formField","tableColumnId","getTableColumnDefaultValue","controller","items","useTableFormFieldRefs","fieldsCount","isDone","setIsDone","linkRef","getBox","timeoutId","setTimeout","clearTimeout","values","setSubmitting","resetForm","setStatus","getTableColumn","columnId","autofill","setItem","JSON","stringify","prev","click","storedValue","localStorage","getItem","FormContextProvider","handleSubmit","formik","status","message","handleReset","isSubmitting","Check12","PILL","SQUARE","responsiveContrast","GutterContainer","gutter","first","last","PlaceholderLink","button","links","DROP_DOWN_MENU_WIDTH","DropDownMenu","dropIn","DropDownContainer","StyledDropDownItem","fontWeight","fontStyle","letterSpacing","textTransform","useResponsiveColor","caret","setPosition","innerWidth","offsetLeft","fill","CaretDown8","Plus8","ArrowDown8","ChevronDown8","DropDownItem","open","ButtonLink","StyledLink","onClose","isOpen","setIsOpen","NavigationButton","coverRight","coverLeft","CloseIconContainer","closeIconColor","Times16","flexShrink","Fragment","DropDownButton","nav","LinksContainer","mobileMenuAnimation","OpenIconContainer","Navigation","linkTextStyle","showLogo","logoFile","logoWidth","logoAltText","logoLink","mobileMenuOpenIconColor","mobileMenuCloseIconColor","mobileMenuBackgroundColor","flexGrow","MobileMenu28","Normalize","createGlobalStyle","normalize","Root","SocialLinksOptions","LogoAngellist20","LogoCodepen20","LogoDribbble20","LogoFacebook20","LogoGithub20","LogoInstagram20","LogoLinkedin20","LogoMedium20","LogoPinterest20","LogoReddit20","LogoRss20","LogoSnapchat20","LogoSoundcloud20","LogoSpotify20","LogoTelegram20","LogoTumblr20","LogoTwitch20","LogoTwitter20","LogoWhatsapp20","LogoVimeo20","LogoYelp20","LogoYoutube20","hoverStyle","circle","naked","grow","shrink","fade","SocialLinks","o","Span","typographyStyle","fontFamily","lineHeight","uppercase","underline","strikethrough","italic","Boolean","shallowMergeFallbacks","useTypographyMark","TYPOGRAPHY_TYPE","renderMark","mark","_editor","next","get","StyledBlock","textAlign","as","renderBlock","blockProps","renderInline","toJS","RichTextEditor","plugins","Lists","Inlines","DeviceOverridesBlocks","DeviceOverridesMarks","SlateEditor","StyledRichTextEditor","defaultText","object","COMMIT_DEBOUNCE_DELAY","Text","text","editor","setEditor","el","findDOMNode","setSlateEditor","setValue","selection","textWithoutSelection","Value","fromJSON","shouldCommit","setShouldCommit","nextValue","currentValue","isBlurred","toJSON","preserveSelection","window","change","lastController","handleFocus","focus","handleKeyDown","Hotkeys","isUndo","undo","isRedo","redo","isHotkey","blur","ipsum","marks","ASPECT_RATIO","Video","video","canPlayUrl","controls","loop","registerBoxComponent","registerButtonComponent","registerCarouselComponent","registerCountdownComponent","registerDividerComponent","registerEmbedComponent","registerFormComponent","registerImageComponent","registerNavigationComponent","registerRootComponent","registerSocialLinksComponent","registerTextComponent","registerVideoComponent","code","cleanup","innerHTML","scripts","HTMLScriptElement","inlineScript","executableScript","replaceChild","childNodes","append","cleanUp","Function","hasOwnProperty","defaultFavicon","mimetype","VALID_TAG_REGEX","VALID_HEAD_ELEMENT_TYPES","snippet","filterUsedSnippetProperties","builderEnabled","liveEnabled","PAGE_SNIPPETS_QUERY","SITE_FONTS_QUERY","preview","snippets","setSnippets","useQuery","skip","fetchPolicy","onCompleted","oldSnippets","newSnippets","deepEqual","siteData","favicon","meta","title","description","keywords","socialImage","canonicalUrl","isIndexingBlocked","seo","fontFamilyParamValue","fonts","family","replace","googleFonts","edges","edge","activeVariants","activeVariantSpecifiers","some","activeVariant","specifier","filteredSnippets","headSnippets","SnippetLocation","previousHeadSnippets","headSnippetsToCleanUp","previousSnippet","snippetToCleanUp","snippetToElement","createDocumentReference","ErrorDiv","FallbackComponent","Warning20","unitless","hashString","definition","renderFn","item","listControlValue","config","entries","reduceRight","controlDefinition","shapeControlValue","CheckboxControlType","useCheckboxControlValue","NumberControlType","useNumber","TextInputControlType","useTextInputValue","TextAreaControlType","useTextAreaValue","SelectControlType","useSelectControlValue","ColorControlType","useColorValue","ImageControlType","useImageControlValue","ComboboxControlType","useComboboxControlValue","ShapeControlType","ListControlType","descriptor","deviceMode","useDeviceMode","WidthControlValueFormats","store","useStore","propControllerDescriptorsRef","ReactPage","getState","propName","propsValue","StyleControlType","useFormattedStyle","Width","useWidth","ResponsiveColor","instance","apply","foundDomNode","FindDomNodeClassComponent","Component","componentDidMount","setInnerRef","suppressWarningAndFindDomNode","componentDidUpdate","render","FindDomNode","component","unregisterComponent","dispatch","registerComponentEffect","unregisterReactComponent","registerReactComponentEffect","ReactRuntime","createReactRuntime","registerBuiltinComponents","rootElements","setStore","preloadedState","unregisterDocuments","documentKey","rootElement","registerDocumentEffect","unregisterDocument","ReactBuilderPreview","configureStore","PageContext","pageIdOrNull","usePageIdOrNull","DocumentContext","selector","useSyncExternalStoreWithSelector","subscribe","useSelector","state","useDocumentKey","ownerName","originalErrorRef","patchedRef","ElementData","memo","elementData","useComponent","setFoundDomNode","_createElement","DisableRegisterElement","ElementReference","elementReference","ELEMENT_REFERENCE_GLOBAL_ELEMENT","globalElementData","elementReferenceDocument","useDocument","useDispatch","isRegisterElementDisabled","registerComponentHandleEffect","mountComponentEffect","Document","DocumentReference","documentReference"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,MAAMA,oBAAkBC,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gBAKf,CAAC;AAAA,EAAEC;AAAAA,MAAYA,SAAS,OAAO,WAAW;AAAA;AAK1D,IAAA,gBAAeC,WAAW,qBACxB,IACAC,KACA;AAFA,eAAEF;AAAAA,WAAO;AAAA,MAAT,IAAmBG,wBAAnB,IAAmBA;AAAAA,IAAjBH;AAAAA;AAIA,6BAACH,mBAAD,iCAAqBM,cAArB;AAAA,IAAkC;AAAA,IAAY;AAAA,IAC5C,8BAAA,OAAA;AAAA,MACE,OAAM;AAAA,MACN,OAAM;AAAA,MACN,QAAO;AAAA,MACP,OAAO;AAAA,QAAEC,UAAU;AAAA,MAJrB;AAAA,MAME,8BAAA,QAAA;AAAA,QACE,GAAG;AAAA,QACH,GAAG;AAAA,QACH,OAAM;AAAA,QACN,QAAO;AAAA,QACP,aAAa;AAAA,QACb,iBAAgB;AAAA,QAChB,MAAK;AAAA,QACL,QAAO;AAAA,QACP,IAAG;AAAA,QACH,IAAG;AAAA,MAAA,CAVL;AAAA,IAAA,CANF;AAAA,EAAA,EAFJ;AAuBD,CA3BwB;ACXlB,MAAM,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAWvB,MAAM,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAenB,MAAM,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAepB,MAAM,uBAAuB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAS7B,MAAM,sBAAsB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA6B5B,MAAM,qBAAqB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAO9B;AAAA;AAGG,MAAM,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyBpB,MAAM,mCAAmC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASzC,MAAM,sBAAsB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAyD/B;AAAA;ACtLG,uBAA0B,OAAmC;AAClE,SAAO,SAAS;AAClB;ACqBE,0BAAA,SACA,QACA,OACA;;AACA,QAAM,cAAc,6BAA6B,MAAM,SAAU,CAAA;AAC3D,QAAA,gCAAgB;AAChB,QAAA,8BAAc;AACd,QAAA,oCAAoB;AACpB,QAAA,+BAAe;AACf,QAAA,8BAAc;AAEd,QAAA,YAAY,CAAC,OAAO;AACtB,MAAA;AAEI,SAAA,UAAU,UAAU,OAAQ;AAwBzB,QAAA,qCAAT,SACE,qBACA,OACA;AACA,aAAO,QAAQ,mBAAkB,EAAE,QAAQ,CAAC,CAAC,UAAU,gBAAgB;AACrE,4BAAoB,YAAY,MAAM,SAAS,EAAE,QAAQ,CAAY,aAAA;AACnE,oBAAU,IAAI,QAAQ;AAAA,QAAA,CACvB;AAEU,mBAAA,YAAY,MAAM,SAAS,EAAE,QAAQ,CAAU,WAAA,QAAQ,IAAI,MAAM,CAAC;AAE5D,yBAAA,YAAY,MAAM,SAAS,EAAE,QAAQ,CACpD,iBAAA,cAAc,IAAI,YAAY,CAChC;AAEY,oBAAA,YAAY,MAAM,SAAS,EAAE,QAAQ,CAAW,YAAA,SAAS,IAAI,OAAO,CAAC;AAEtE,mBAAA,YAAY,MAAM,SAAS,EAAE,QAAQ,CAAU,WAAA,QAAQ,IAAI,MAAM,CAAC;AAE1D,2BAAA,YAAY,MAAM,SAAS,EAAE,QAAQ,CAAS,UAAA,UAAU,KAAK,KAAK,CAAC;AAElF,YAAA,WAAW,SAAS,kBAAkB;AACxC,gBAAM,OAAO,MAAM;AAEnB,cAAI,QAAQ;AAAM;AAEiB,6CAAA,WAAW,OAAO,MAAM,IAAI;AAAA,QACjE;AAEI,YAAA,WAAW,SAAS,iBAAiB;AACvC,gBAAM,OAAO,MAAM;AAEnB,cAAI,QAAQ;AAAM;AAElB,eAAK,QAAQ,CAAQ,SAAA;AAEjB,+CAAA,EAAE,UAAU,WAAW,OAAO,QAC9B,EAAE,UAAU,KAAK,MAAA,CACnB;AAAA,UAAA,CACD;AAAA,QACH;AAEI,YAAA,WAAW,SAAS,MAAM,OAAO;AACnC,gBAAM,OAAO,MAAM;AAEnB,cAAI,QAAQ;AAAM;AAEiB,6CAAA,WAAW,QAAQ,MAAM,IAAI;AAAA,QAClE;AAEI,YAAA,WAAW,SAAS,MAAM,MAAM;AAClC,gBAAM,OAAO,MAAM;AAEnB,cAAI,QAAQ;AAAM;AAElB,eAAK,QAAQ,CAAQ,SAAA;AAEjB,+CAAA,EAAE,UAAU,WAAW,QAAQ,QAC/B,EAAE,UAAU,KAAK,MAAA,CACnB;AAAA,UAAA,CACD;AAAA,QACH;AAAA,MAAA,CACD;AAAA,IAAA;AArFC,QAAA;AAEA,QAAA,mBAAmB,OAAO,GAAG;AACzB,YAAA,QAAQ,MAAM,OAAO,MAAM;AAAA,QAC/B,OAAO;AAAA,QACP,WAAW,EAAE,IAAI,QAAQ,MAAM;AAAA,MAAA,CAChC;AAEK,YAAA,cAAc,kBAAM,SAAN,mBAAY,kBAAZ,mBAA2B;AAE/C,UAAI,eAAe;AAAM;AAEf,iBAAA;AAAA,IAAA,OACL;AACK,iBAAA;AAAA,IACZ;AAEA,UAAM,qBAAqB,YAAY,IAAI,SAAQ,IAAI;AAEvD,QAAI,sBAAsB;AAAM;AAEG,uCAAA,oBAAoB,SAAQ,KAAK;AAAA,EAkEtE;AAEM,QAAA,qBAAqB,MAAM,OAAO,MAAM;AAAA,IAC5C,OAAO;AAAA,IACP,WAAW,EAAE,KAAK,CAAC,GAAG,aAAa,EAAE;AAAA,EAAA,CACtC;AAED,iEAAoB,SAApB,mBAA0B,aAAa,QAAQ,CAAC,eAAmC;AACtE,eAAA,MAAM,QAAQ,CAAS,UAAA;;AAC1B,YAAA,WAAW,aAAM,MAAM,UAAZ,oBAAmB;AAEpC,UAAI,YAAY;AAAM,kBAAU,IAAI,QAAQ;AAAA,IAAA,CAC7C;AAAA,EAAA;AAGI,SAAA;AAAA,IACL,WAAW,CAAC,GAAG,SAAS;AAAA,IACxB,SAAS,CAAC,GAAG,OAAO;AAAA,IACpB,eAAe,CAAC,GAAG,aAAa;AAAA,IAChC,UAAU,CAAC,GAAG,QAAQ;AAAA,IACtB,SAAS,CAAC,GAAG,OAAO;AAAA,EAAA;AAExB;ACtHA,MAAMC,eAA6B;AAAA,EACjCC,OAAO;AAAA,IACLC,QAAQ;AAAA,MACNC,SAASC,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AAC5C,eACEF,sCACAC,6BAAME,IAAIC,IAAI,CAACC,OAAeH,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAUD;AAAAA,QAAAA,GAAM,IAA/B;AAAA,MAJvC;AAAA,MAONE,KAAKP,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AACjCF,eAAAA,sCAAgBE,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAQD,IAAIJ,6BAAMI;AAAAA,WAAM,IAAvC;AAAA,MAR9B;AAAA,MAUNG,MAAMR,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AACzC,eACEF,sCACAC,6BAAME,IAAIC,IAAI,CAACC,OAAeH,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAQD;AAAAA,QAAAA,GAAM,IAA7B;AAAA,MAbvC;AAAA,MAgBNI,aAAaT,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AAChD,eACEF,sCACAC,6BAAME,IAAIC,IAAI,CAACC,OAAeH,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAcD;AAAAA,QAAAA,GAAM,IAAnC;AAAA,MAnBvC;AAAA,MAsBNK,kBAAkBV,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AACrD,eACEF,sCACAC,6BAAME,IAAIC,IAAI,CAACC,OAAeH,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAqBD;AAAAA,QAAAA,GAAM,IAA1C;AAAA,MAzBvC;AAAA,MA4BNM,cAAcX,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AAC1CF,eAAAA,sCAAgBE,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAiBD,IAAIJ,6BAAMI;AAAAA,WAAM,IAAhD;AAAA,MA7B9B;AAAA,MA+BNO,MAAMZ,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AAClCF,eAAAA,sCAAgBE,YAAY;AAAA,UAAEI,YAAY;AAAA,UAASD,IAAIJ,6BAAMI;AAAAA,WAAM,IAAxC;AAAA,MAhC9B;AAAA,MAkCNQ,KAAKb,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AACjCF,eAAAA,sCAAgBE,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAQD,IAAIJ,6BAAMI;AAAAA,WAAM,IAAvC;AAAA,MAnC9B;AAAA,MAqCNS,KAAKd,cAAc;AAAA,QAAEC;AAAAA,QAAMC;AAAAA,SAAe;AACjCF,eAAAA,sCAAgBE,YAAY;AAAA,UAAEI,YAAY;AAAA,UAAQD,IAAIJ,6BAAMI;AAAAA,WAAM,IAAvC;AAAA,MACnC;AAAA,IAvCK;AAAA,EADH;AAD0B;AAmDA,4BAAA;AAAA,EAAEU;AAAAA,EAAKC;AAAAA,GAAuC;AACzEC,QAAAA,SAAQ,IAAIC,cAAc;AAAA,IAAEtB;AAAAA,EAAAA,CAApB;AAEVoB,MAAAA;AAAWC,WAAME,QAAQH,SAAd;AAER,SAAA,IAAII,aAAa;AAAA,IAAEC,MAAM,IAAIC,cAAc;AAAA,MAAEP;AAAAA,MAAKQ,UAAU;AAAA,IAAA,CAAnC;AAAA,IAA2CN;AAAAA,EAAAA,CAApE;AACR;AAOM,MAAMO,gBAAgB;AAAA,EAG3BC,YAAY;AAAA,IAAEV;AAAAA,IAAKC;AAAAA,KAAqC;AAFxDU;AAGOA,SAAAA,eAAeC,mBAAmB;AAAA,MAAEZ;AAAAA,MAAKC;AAAAA,IAAAA,CAAR;AAAA,EACvC;AAAA,QAEKY,SAASC,SAAkD;AACzDC,UAAAA,oBAAoB,MAAMC,WAAWF,SAAS,KAAKH,cAAcM,wBAA7B;AAE1C,UAAMC,MAAM,MAAM,KAAKP,aAAaQ,MAAM;AAAA,MACxCA,OAAOC;AAAAA,MACPC,WAAWN;AAAAA,IAAAA,CAFK;AAOlBG,QAAII,KAAK3B,kBAAkB4B,QAAQ,CAACC,sBAAiD;AAC7ElC,YAAAA,KAAKmC,OAAOC,KAAM,QAAOF,kBAAkBlC,IAAtC,EAA4CqC,SAAS,QAArD;AAENhB,WAAAA,aAAaT,MAAM0B,cAAc;AAAA,QACpCC,UAAUC;AAAAA,QACVR,MAAM,iCAAKE,oBAAL;AAAA,UAAwBlC;AAAAA,QAAxB;AAAA,MAAA,CAFR;AAAA,IAAA,CAHF;AASAyC,aAASC,eAAT;AAEO,WAAA,KAAKrB,aAAaT,MAAM+B,QAA/B;AAAA,EACD;AAAA,EAEDC,gBAAgBjC,WAAwC;AACjDU,SAAAA,aAAaT,MAAME,QAAQH,SAAhC;AAAA,EACD;AAjC0B;AAoC7B,MAAMkC,YAAUC,cAA2CC,MAA9B;AAEtB,kBACLlB,OACAmB,SACgC;AAC1BC,QAAAA,SAASC,WAAWL,SAAD;AAElBM,SAAAA,WAAetB,OAAO;AAAA,IAAEoB,QAAQA,iCAAQ5B;AAAAA,KAAiB2B,QAA3C;AACtB;AAEM,qBAMLI,UACAJ,SACoD;AAC9CC,QAAAA,SAASC,WAAWL,SAAD;AAElBQ,SAAAA,cAAkBD,UAAU;AAAA,IAAEH,QAAQA,iCAAQ5B;AAAAA,KAAiB2B,QAA9C;AACzB;AAOiC,2BAAA;AAAA,EAAEC;AAAAA,EAAQK;AAAAA,GAAoC;AACvE,SAAAC,oBAACV,UAAQ,UAAT;AAAA,IAAkB,OAAOI;AAAAA,IAASK;AAAAA,EAAAA,CAAzC;AACD;AC1GM,wBACL,OACkD;AAC5C,QAAA,UACJ,SAAS,OACL,KACA,MACG,IAAI,CAAC,EAAE,OAAO,kBACb,YACG,IAAI,CAAA,eACH,WAAW,SAAS,WAAW,WAAW,WAAW,OACjD,WAAW,QAAQ,UACnB,IACN,EACC,OAAO,aAAa,EACpB,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAA,CAAc,CACjD,EACC,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAA,CAAE;AACzC,QAAM,YACJ,SAAS,OACL,CACA,IAAA,MACG,IAAI,CAAC,EAAE,OAAO,kBACb,YACG,IAAI,CAAc,eAAA;AACjB,QAAI,WAAW,SAAS,WAAW,WAAW,WAAW,MAAM;AACtD,aAAA,CAAC,WAAW,QAAQ,QAAQ;AAAA,IACrC;AAEA,QAAI,WAAW,SAAS,cAAc,WAAW,WAAW,MAAM;AAChE,aAAO,WAAW,QAAQ,MACvB,IAAI,CAAQ,SAAA,KAAK,SAAS,KAAK,MAAM,QAAQ,EAC7C,OAAO,aAAa;AAAA,IACzB;AAEA,QAAI,WAAW,SAAS,WAAW,WAAW,WAAW,MAAM;AAC7D,aAAO,CAAC,WAAW,QAAQ,aAAa,WAAW,QAAQ,UAAU,QAAQ;AAAA,IAC/E;AAEO,WAAA;AAAA,EACR,CAAA,EACA,OAAO,aAAa,EACpB,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAE,CAAA,CACrC,EACC,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAE,CAAA,EAChC,OAAO,aAAa;AAC7B,QAAM,OAAO,SAAS;AAChB,QAAA,cAAc,SAAS,aAAa;AAAA,IACxC,MAAM,QAAQ,QAAQ,WAAW;AAAA,IACjC,WAAW,EAAE,KAAK,QAAQ;AAAA,EAAA,CAC3B;AACK,QAAA,iBAAiB,SAAS,gBAAgB;AAAA,IAC9C,MAAM,QAAQ,UAAU,WAAW;AAAA,IACnC,WAAW,EAAE,KAAK,UAAU;AAAA,EAAA,CAC7B;AAED,SAAO,QAAQ,MAAM;AACnB,UAAM,EAAE,MAAM,YAAY,CAAO,MAAA;AACjC,UAAM,EAAE,MAAM,eAAe,CAAO,MAAA;AAEpC,QAAI,SAAS,QAAQ,YAAY,SAAS,QAAQ,eAAe,SAAS,MAAM;AACvE,aAAA;AAAA,IACT;AAEM,UAAA,EAAE,QAAQ,OAAO;AACjB,UAAA,EAAE,WAAW,OAAO;AAE1B,WAAO,MAAM,IAAI,CAAC,OAA4C;AAA5C,mBAAE,SAAO,gBAAT,IAAyB,wBAAzB,IAAyB,CAAvB;AAA0C,8CACzD,cADyD;AAAA,QAE5D,OAAO,YACJ,IAAI,CAAM,OAAA;AACL,cAAA,GAAG,SAAS,WAAW,GAAG,WAAW,QAAQ,GAAG,QAAQ,WAAW,MAAM;AACrE,kBAAgC,SAAG,SAAjC,cAA8B,KAAlB,0BAAkB,KAAlB,CAAZ;AACF,kBAAA,OAAO,MAAM,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,OAAO;AAEzD,mBACE,QAAQ;AAAA,cACN,IAAI,GAAG;AAAA,cACP,MAAM;AAAA,cACN,SAAS,iCACJ,gBADI;AAAA,gBAEP,WAAW,KAAK;AAAA,gBAChB,YAAY,KAAK;AAAA,cACnB;AAAA,YAAA;AAAA,UAGN;AAEA,cAAI,GAAG,SAAS,WAAW,GAAG,WAAW,MAAM;AACvC,kBAAA,EAAE,UAAU,UAAU,GAAG;AACzB,kBAAA,SAAS,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,QAAQ;AAExD,mBAAA,EAAE,IAAI,GAAG,IAAI,MAAM,SAAS,SAAS,EAAE,QAAQ,MAAA;UACxD;AAEI,cAAA,GAAG,SAAS,cAAc,GAAG,WAAW,QAAQ,GAAG,QAAQ,MAAM,SAAS,GAAG;AACxE,mBAAA;AAAA,cACL,IAAI,GAAG;AAAA,cACP,MAAM;AAAA,cACN,SAAS;AAAA,gBACP,OAAO,GAAG,QAAQ;AAAA,gBAClB,UAAU,GAAG,QAAQ;AAAA,gBACrB,OAAO,GAAG,QAAQ,MAAM,IAAI,CAAC,QAA8B;AAA9B,gCAAE,YAAF,IAAY,uBAAZ,IAAY,CAAV;AAA4B,0DACtD,aADsD;AAAA,oBAEzD,OAAO,SAAS;AAAA,sBACd,QAAQ,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,MAAM,QAAQ;AAAA,sBAC9D,OAAO,MAAM;AAAA,oBACf;AAAA,kBAAA;AAAA,iBACA;AAAA,cACJ;AAAA,YAAA;AAAA,UAEJ;AAEA,cAAI,GAAG,SAAS,WAAW,GAAG,WAAW,MAAM;AACvC,kBAAkC,QAAG,SAAnC,gBAAgC,IAAlB,0BAAkB,IAAlB,CAAd;AACF,kBAAA,SAAS,aAAa,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,UAAU,QAAQ;AAE/E,mBAAA;AAAA,cACL,IAAI,GAAG;AAAA,cACP,MAAM;AAAA,cACN,SAAS,iCACJ,gBADI;AAAA,gBAEP,WAAW,UAAU,aAAa,EAAE,QAAQ,OAAO,UAAU,MAAM;AAAA,cACrE;AAAA,YAAA;AAAA,UAEJ;AAEO,iBAAA;AAAA,QAAA,CACR,EACA,OAAO,OAAO;AAAA,MACjB;AAAA,KAAA;AAAA,EACD,GAAA,CAAC,aAAa,gBAAgB,KAAK,CAAC;AACzC;AClLA,sBAAsB,UAAe,IAA+B;AAA/B,eAAE,YAAF,IAAY,uBAAZ,IAAY,CAAV;AAC9B,SAAA,iCACF,aADE;AAAA,IAEL,OAAO,SAAS;AAAA,MACd,OAAO,MAAM;AAAA,MACb,QAAQ,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,MAAM,QAAQ;AAAA,IAChE;AAAA,EAAA;AAEJ;AAiBO,mBACL,OAC6C;AAC7C,QAAM,YACJ,SAAS,OACL,KACA;AAAA,IACE,GAAG,MAAM,KACP,IAAI,IACF,MACG,IAAI,CAAC,EAAE,OAAO,EAAE,WAAW,YAAY,cAAc,oBAAoB;AAAA,MACxE,aAAa,UAAU,SAAS,UAAU,MAAM;AAAA,MAChD,gBAAgB,aAAa,SAAS,aAAa,MAAM;AAAA,MACzD,cAAc,WAAW,SAAS,WAAW,MAAM;AAAA,MACnD,eAAe,YAAY,SAAS,YAAY,MAAM;AAAA,IACvD,CAAA,EACA,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,CAAC,EAC5B,OAAO,aAAa,CACzB,CACF;AAAA,EAAA;AAER,QAAM,OAAO,SAAS,QAAQ,UAAU,WAAW;AACnD,QAAM,EAAE,OAAO,OAAO,OAAO,SAAS,gBAAgB,EAAE,MAAM,WAAW,EAAE,KAAK,UAAA,EAAa,CAAA;AAEzF,MAAA,SAAS,QAAQ,SAAS;AAAa,WAAA;AAErC,QAAA,EAAE,WAAW,OAAO;AAEnB,SAAA,MAAM,IAAI,CAAC,OAA8E;AAA9E,iBAAE,SAAO,EAAE,WAAW,cAAc,YAAY,kBAAhD,IAAkE,iBAAlE,IAAkE,CAAhE;AAA4E,4CAC3F,OAD2F;AAAA,MAE9F,OAAO;AAAA,QACL,WAAW,aAAa,aAAa,UAAU,SAAS;AAAA,QACxD,cAAc,gBAAgB,aAAa,UAAU,YAAY;AAAA,QACjE,YAAY,cAAc,aAAa,UAAU,UAAU;AAAA,QAC3D,aAAa,eAAe,aAAa,UAAU,WAAW;AAAA,MAChE;AAAA,IACA;AAAA,GAAA;AACJ;ACpDA,MAAM,qBAAqB;AAAA,EACzB,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,OAAO;AACT;AAMO,sBACL,OACgD;AAChD,QAAM,YACJ,SAAS,OACL,KACA;AAAA,IACE,GAAG,MAAM,KACP,IAAI,IACF,MACG,IAAI,CAAC,EAAE,OAAO,cACb,QAAQ,IAAI,CAAC,EAAE,SAAS,EAAE,cAAc,SAAS,MAAM,QAAQ,CACjE,EACC,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAA,CAAE,EAChC,OAAO,aAAa,CACzB,CACF;AAAA,EAAA;AAGR,QAAM,OAAO,SAAS,QAAQ,UAAU,WAAW;AACnD,QAAM,EAAE,OAAO,OAAO,OAAO,SAAS,gBAAgB,EAAE,MAAM,WAAW,EAAE,KAAK,UAAA,EAAa,CAAA;AAEzF,MAAA,SAAS,QAAQ,SAAS;AAAa,WAAA;AAErC,QAAA,EAAE,WAAW,OAAO;AAE1B,SAAO,MAAM,IAAI,CAAC,OAAwC;AAAxC,iBAAE,SAAO,YAAT,IAAqB,wBAArB,IAAqB,CAAnB;AAAsC,4CACrD,cADqD;AAAA,MAExD,OAAO,QAAQ,IACb,CAAC,QAGM;AAHN,uBACC;AAAA,mBAAS,EAAE,OAAO,OAAO,SAAS,SAAS,YAAY;AAAA,YADxD,KAEI,yBAFJ,KAEI;AAAA,UADH;AAAA;AAEK,gDACF,eADE;AAAA,UAEL,SAAS;AAAA,YACP,OACE,SAAS,OACL;AAAA,cACE,QAAQ,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,MAAM,QAAQ;AAAA,cAC9D,OAAO,MAAM;AAAA,YAAA,IAEf;AAAA,YACN,OAAO,wBAAS,mBAAmB;AAAA,YACnC,SAAS,4BAAW,mBAAmB;AAAA,YACvC,SAAS,4BAAW,mBAAmB;AAAA,YACvC,YAAY,kCAAc,mBAAmB;AAAA,YAC7C,cAAc,sCAAgB,mBAAmB;AAAA,UACnD;AAAA,QAAA;AAAA,OAEJ;AAAA,IACA;AAAA,GAAA;AACJ;AC7EO,4BACL,OAO2C;AACrC,QAAA,YACJ,SAAS,OACL,CAAC,IACD,CAAC,GAAG,MAAM,KAAK,IAAI,IAAI,MAAM,IAAI,CAAC,EAAE,OAAO,QAAQ,KAAK,EAAE,QAAQ,EAAE,OAAO,aAAa,CAAC,CAAC,CAAC;AAC3F,QAAA,OAAO,UAAU,WAAW;AAClC,QAAM,EAAE,OAAO,OAAO,OAAO,SAAS,gBAAgB,EAAE,MAAM,WAAW,EAAE,KAAK,UAAA,EAAa,CAAA;AAEzF,MAAA,SAAS,QAAQ,SAAS;AAAa,WAAA;AAErC,QAAA,EAAE,WAAW,OAAO;AAE1B,SAAO,MACJ,IAAI,CAAC,OAA0B;AAA1B,iBAAE,SAAO,MAAT,IAAe,iBAAf,IAAe,CAAb;AACA,UAAA,EAAE,UAAU,UAAU;AACtB,UAAA,SAAS,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,QAAQ;AAExD,WAAA,UAAU,OAAO,OAAO,iCAAK,OAAL,EAAW,OAAO,EAAE,QAAQ,MAAA;EAAQ,CACpE,EACA,OAAO,aAAa;AACzB;ACvBO,iBAAiB,QAA4D;AAClF,QAAM,EAAE,OAAO,OAAO,CAAC,MAAM,SAAS,YAAY;AAAA,IAChD,MAAM,UAAU;AAAA,IAChB,WAAW,EAAE,IAAI,OAAO;AAAA,EAAA,CACzB;AAEG,MAAA,UAAU,QAAQ,SAAS;AAAa,WAAA;AAE5C,SAAO,KAAK;AACd;ACpBA,MAAM,OAAO,CAAuC,MAAsB,OAAO,KAAK,CAAC;ACAvF,MAAM,WAAW,IAAO,SAAsB;AACxC,MAAA;AAEJ,OAAK,IAAI,GAAG,IAAI,KAAK,SAAS,GAAG,KAAK,GAAG;AACvC,QAAI,KAAK,MAAM;AAAM,aAAO,KAAK;AAAA,EACnC;AAEA,SAAO,KAAK;AACd;ACLA,sBAGE,GAAM,GAAa;AACb,QAAA,QAAQ,KAAK,CAAC;AACd,QAAA,SAAS,mBAAK;AAEpB,QAAM,QAAQ,CAAO,QAAA;AAEnB,WAAO,OAAO,SAAS,OAAO,MAAM,EAAE,IAAI;AAAA,EAAA,CAC3C;AAEM,SAAA;AACT;ACPO,MAAM,UAAyB;AAAA,EACpC,EAAE,IAAI,WAAW,UAAU,IAAI;AAAA,EAC/B,EAAE,IAAI,UAAU,UAAU,KAAK,UAAU,IAAI;AAAA,EAC7C,EAAE,IAAI,UAAU,UAAU,IAAI;AAChC;AAEa,MAAA,YAAY,CAAC,aAA+B;AACvD,QAAM,SAAS,QAAQ,KAAK,CAAC,EAAE,SAAS,OAAO,QAAQ;AAEvD,MAAI,UAAU;AAAY,UAAA,IAAI,MAAM,4BAA4B,YAAY;AAErE,SAAA;AACT;AAOA,yBACE,OACA,WAC+B;AAC/B,SAAO,SAAS,UAAU;AAC5B;AAEO,+BACL,OACA,WAC+B;AAC/B,SAAO,CAAC,OAAO,GAAG,SAAS,EACxB,OAAO,CAAC,aAA4C,QAAQ,QAAQ,CAAC,EACrE,OAAO,CAAC,GAAG,MAAO;AAAA,IACjB,UAAU,EAAE,YAAY,EAAE;AAAA,IAC1B,OAAO,aAAa,EAAE,OAAO,EAAE,KAAK;AAAA,EACpC,EAAA;AACN;AAEO,4BACL,SAA6B,CAAA,GAC7B,UACA,WAAgC,iBACD;AACzB,QAAA,QAAQ,OAAO,KAAK,CAAC,EAAE,UAAU,QAAQ,MAAM,QAAQ;AAC7D,QAAM,YAAY,QAAQ,MAAM,GAAG,QAAQ,UAAU,CAAK,MAAA,EAAE,OAAO,QAAQ,IAAI,CAAC,EAC7E,QAAQ,EACR,IAAI,CAAA,MAAK,OAAO,KAAK,CAAK,MAAA,EAAE,aAAa,EAAE,EAAE,CAAC,EAC9C,OAAO,CAAC,aAA4C,QAAQ,QAAQ,CAAC;AAEjE,SAAA,SAAS,QAAQ,UAAU,SAAS,IAAI,SAAS,OAAO,SAAS,IAAI;AAC9E;AAKE,cAAA,kBACA,QACA,UACoB;AACb,SAAA,QAAQ,IAAI,CAAC,EAAE,SAAS,EAAE,EAC9B,IAAI,CAAY,aAAA;AACf,UAAM,QAAQ,OACZ,iBAAiB,IAAI,CAAmB,oBAAA;AACtC,YAAM,cACJ,mBAAmB,mBAAmB,iBAAiB,UAAU,QAAQ;AAEpE,aAAA,eAAe,OAAO,SAAY,YAAY;AAAA,IACtD,CAAA,CACH;AAEA,QAAI,SAAS;AAAa,aAAA;AAEnB,WAAA,EAAE,UAAU;EAAM,CAC1B,EACA,OAAO,CAAC,aAA4C,QAAQ,QAAQ,CAAC;AAC1E;AAEa,MAAA,sBAAsB,CAAC,WAA2B;AACvD,QAAA,QAAQ,CAAC,oBAAoB;AAE/B,MAAA,OAAO,YAAY,MAAM;AACrB,UAAA,KAAK,eAAe,OAAO,aAAa;AAAA,EAChD;AAEI,MAAA,OAAO,YAAY,MAAM;AACrB,UAAA,KAAK,eAAe,OAAO,aAAa;AAAA,EAChD;AAEO,SAAA,MAAM,KAAK,OAAO;AAC3B;AChGA,MAAM,QACJ,OAAO,WAAW,eAClB,sBAAsB,KAAK,OAAO,aAAa,OAAO,UAAU,SAAS;AAE9D,MAAA,4BAA4B,QAAQ,YAAY;ACEtD,uBAA0B,iBAAsD;AACrF,QAAM,CAAC,UAAU,eAAe,SAAS,QAAQ,GAAG,EAAE;AACtD,QAAM,EAAE,UAAU,mBAAmB,iBAAiB,QAAQ,KAAK;AAEnE,4BAA0B,MAAM;AAC1B,QAAA,mBAAmB,QAAQ,UAAU;AAAM,aAAO,MAAM;AAAA,MAAA;AAEtD,UAAA,aAAa,QAAQ,IAAI,CAAU,WAAA;AACjC,YAAA,iBAAiB,OAAO,WAAW,oBAAoB,MAAM,EAAE,QAAQ,UAAU,EAAE,CAAC;AAE1F,YAAM,WAAW,MAAM;AACrB,YAAI,eAAe;AAAS,sBAAY,OAAO,EAAE;AAAA,MAAA;AAG1C;AACT,qBAAe,YAAY,QAAQ;AAE5B,aAAA,MAAM,eAAe,eAAe,QAAQ;AAAA,IAAA,CACpD;AAED,WAAO,MAAM,WAAW,QAAQ,CAAA,OAAM,GAAI,CAAA;AAAA,EAAA,CAC3C;AAEM,SAAA;AACT;ACxBO,iBAAiB,QAA4D;AAClF,QAAM,EAAE,OAAO,OAAO,CAAC,MAAM,SAAS,sBAAsB;AAAA,IAC1D,MAAM,UAAU;AAAA,IAChB,WAAW,EAAE,KAAK,CAAC,MAAM,EAAE;AAAA,EAAA,CAC5B;AAEG,MAAA,UAAU,QAAQ,SAAS;AAAa,WAAA;AAE5C,QAAM,EAAE,mBAAmB,CAAC,QAAQ,CAAO,MAAA;AAEpC,SAAA;AACT;ACmEO,kBAAkB,SAAoC;AAC3D,SAAO,SAAkC,aAAa;AAAA,IACpD,MAAM,WAAW;AAAA,IACjB,WAAW,EAAE,IAAI,QAAQ;AAAA,EAAA,CAC1B;AACH;ACjEA,MAAME,qBAAqB;AAAA,EACzBC,SAAS;AAAA,EACTC,GAAG;AAAA,EACHC,GAAG;AAAA,EACHC,OAAO;AAJkB;AAYpB,MAAMC,gBAIT;AAAA,EACFC,MAAM;AAAA,IACJC,SAAS;AAAA,MACPN,SAAS;AAAA,IAFP;AAAA,IAIJO,QAAQ,iCACHR,qBADG;AAAA,MAENC,SAAS;AAAA,IANP;AAAA,IAQJQ,YAAY,CAAA;AAAA,EATZ;AAAA,EAWFC,QAAQ;AAAA,IACNF,QAAQR;AAAAA,IACRO,SAAS;AAAA,MACPN,SAAS;AAAA,IAHL;AAAA,IAKNQ,YAAY,CAAA;AAAA,EAhBZ;AAAA,EAkBFE,UAAU;AAAA,IACRH,QAAQ,iCACHR,qBADG;AAAA,MAENE,GAAG;AAAA,IAHG;AAAA,IAKRK,SAAS;AAAA,MACPN,SAAS;AAAA,MACTC,GAAG;AAAA,IAPG;AAAA,IASRO,YAAY;AAAA,MACVP,GAAG;AAAA,QACDU,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFL;AAAA,IADO;AAAA,EA3BZ;AAAA,EAkCFC,WAAW;AAAA,IACTN,QAAQ,iCACHR,qBADG;AAAA,MAENE,GAAG;AAAA,IAHI;AAAA,IAKTK,SAAS;AAAA,MACPN,SAAS;AAAA,MACTC,GAAG;AAAA,IAPI;AAAA,IASTO,YAAY;AAAA,MACVP,GAAG;AAAA,QACDU,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFL;AAAA,IADO;AAAA,EA3CZ;AAAA,EAkDFE,QAAQ;AAAA,IACNP,QAAQ,iCACHR,qBADG;AAAA,MAENG,GAAG;AAAA,IAHC;AAAA,IAKNI,SAAS;AAAA,MACPN,SAAS;AAAA,MACTE,GAAG;AAAA,IAPC;AAAA,IASNM,YAAY;AAAA,MACVN,GAAG;AAAA,QACDS,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFL;AAAA,IADO;AAAA,EA3DZ;AAAA,EAkEFG,UAAU;AAAA,IACRR,QAAQ,iCACHR,qBADG;AAAA,MAENG,GAAG;AAAA,IAHG;AAAA,IAKRI,SAAS;AAAA,MACPN,SAAS;AAAA,MACTE,GAAG;AAAA,IAPG;AAAA,IASRM,YAAY;AAAA,MACVN,GAAG;AAAA,QACDS,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFL;AAAA,IADO;AAAA,EA3EZ;AAAA,EAkFFI,QAAQ;AAAA,IACNT,QAAQ,iCACHR,qBADG;AAAA,MAENkB,QAAQ;AAAA,IAHJ;AAAA,IAKNX,SAAS;AAAA,MACPN,SAAS;AAAA,MACTiB,QAAQ;AAAA,IAPJ;AAAA,IASNT,YAAY,CAAA;AAAA,EA3FZ;AAAA,EA6FFU,WAAW;AAAA,IACTX,QAAQ,iCACHR,qBADG;AAAA,MAENI,OAAO;AAAA,IAHA;AAAA,IAKTG,SAAS;AAAA,MACPN,SAAS;AAAA,MACTG,OAAO;AAAA,IAPA;AAAA,IASTK,YAAY;AAAA,MACVL,OAAO;AAAA,QACLQ,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFD;AAAA,IADG;AAAA,EAtGZ;AAAA,EA6GFO,SAAS;AAAA,IACPZ,QAAQ,iCACHR,qBADG;AAAA,MAENI,OAAO;AAAA,IAHF;AAAA,IAKPG,SAAS;AAAA,MACPN,SAAS;AAAA,MACTG,OAAO;AAAA,IAPF;AAAA,IASPK,YAAY;AAAA,MACVL,OAAO;AAAA,QACLQ,MAAM;AAAA,QACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,MAFD;AAAA,IADG;AAAA,EATL;AA7GP;AA+HJ,MAAMQ,mCAAmC,CACvCC,aACAC,UAEAD,cACIE,OAAOC,KAAKH,WAAZ,EAAyBI,OACvB,CAACC,GAAGC,MAAO,iCACND,IADM;AAAA,GAERC,IAAI,kCACAN,YAAYM,KACZL;AAJI,IAOXA,KARF,IAUAA;AAgBN,MAAMM,qBAAqB,CAAC7D,SAA6BwB,YAAsC;AACvF,QAAA,CAACsC,WAAWC,gBAAgBC,SAAS,KAAD;AAE1CC,YAAU,MAAM;AACRC,UAAAA,WAAW,IAAIC,qBAAqBC,sBAAsB5C,OAA/C;AAEbxB,QAAAA;AAASkE,eAASG,QAAQrE,OAAjB;AAEb,WAAO,MAAM;AACPA,UAAAA;AAASkE,iBAASI,UAAUtE,OAAnB;AAAA,IAAA;AAGNoE,kCAAqB,CAACG,QAAqC;AAC9DA,UAAAA,+BAAOC,gBAAgB;AACzBT,qBAAa,IAAD;AAAA,MACb;AAAA,IACF;AAAA,EAAA,GACA,CAAC/D,SAASwB,OAAV,CAdM;AAgBFsC,SAAAA;AACR;AAEM,MAAMW,2BAA2B;AACjC,MAAMC,4BAA4B;AAClC,MAAMC,+BAA+B;AACrC,MAAMC,4BAA4B;AAClC,MAAMC,6BAA6B;AACnC,MAAMC,gCAAgC;AACtC,MAAMC,gCAAgC;AActC,MAAMC,mBAAmB,CAAC,OAcF;AAdE,eAC/BC;AAAAA;AAAAA,IACAC;AAAAA,MAF+B,IAG5B3B,kBAH4B,IAG5BA;AAAAA,IAFH0B;AAAAA,IACAC;AAAAA;AAaMC,QAAAA,gBAAgBC;AAChBC,QAAAA,iBAAiBC,cAAc/B,MAAM8B,cAAP,KAA0BZ;AACxDc,QAAAA,qBAAqBD,cAAc/B,MAAMgC,kBAAP,KAA8BZ;AAChEa,QAAAA,kBAAkBF,cAAc/B,MAAMiC,eAAP,KAA2Bd;AAC1De,QAAAA,kBAAkBH,cAAc/B,MAAMkC,eAAP,KAA2Bb;AAC1Dc,QAAAA,sBACJJ,cAAc/B,MAAMmC,mBAAP,KAA+BZ;AACxCa,QAAAA,mBAAmBL,cAAc/B,MAAMoC,gBAAP,KAA4Bd;AAC5De,QAAAA,sBACJN,cAAc/B,MAAMqC,mBAAP,KAA+Bb;AAExCc,QAAAA,eAAehC,mBAAmBoB,YAAY;AAAA,IAClDa,MAAM;AAAA,IACNC,YAAa;AAAA,IACbC,WAAW;AAAA,EAAA,CAH0B;AAMjCC,QAAAA,eAAeC;AACfC,QAAAA,cAAcD;AAEdE,QAAAA,cAAcC,YAClB,CAACC,YAAwC;AACvCH,gBAAYI,KAAZ;AACAN,iBAAaM,KAAb;AACAJ,gBAAYK,IAAIF,OAAhB;AACAL,iBAAaO,IAAIF,OAAjB;AAAA,EAAA,GAEF,CAACH,aAAaF,YAAd,CAP6B;AAUzBQ,QAAAA,eAAeJ,YAAY,MAAM;AACrCF,gBAAYI,KAAZ;AACAN,iBAAaM,KAAb;AACAJ,gBAAYK,IAAI,QAAhB;AACAP,iBAAaO,IAAI,QAAjB;AACAL,gBAAYO,MAAM,SAAlB;AACAT,iBAAaS,MAAM,SAAnB;AAAA,EAAA,GACC,CAACP,aAAaF,YAAd,CAP6B;AAShChC,YAAU,MAAM;AACd,QAAI4B,cAAc;AAChBO,kBAAY,SAAD;AAAA,IACZ;AAAA,EACA,GAAA,CACDlB,qCACI3G,IAAIoI,CAAKA,MAAAA,EAAEC,KACZC,OACAC,QACHV,WALC,CAJM;AAYTnC,YAAU,MAAM;AACd,QAAI4B,cAAc;AACJ;IACb;AAAA,EACA,GAAA,CACDA,cACAR,gBACAE,oBACAC,iBACAC,iBACAC,qBACAC,kBACAC,qBACAT,eACAsB,YAVC,CAJM;AAiBT,QAAMM,aAAa1E,cAAcgD;AACjC,QAAM2B,cAAc3E,cAAcoD;AAE3B,SAAA;AAAA,IACLwB,SAAS;AAAA,MACPC,WAAW/B,gBAAgB,YAAY;AAAA,MACvCgC,QAAQhC,gBAAgB,YAAY;AAAA,IAHjC;AAAA,IAKLiC,SAAS;AAAA,MACPF,WAAW/B,gBAAgB5D,SAAY4E;AAAAA,MACvCgB,QAAQhC,gBAAgB5D,SAAY0E;AAAAA,IAPjC;AAAA,IASLoB,UAAU;AAAA,MACRH,WAAW;AAAA,QACT1E,QAAQuE,WAAWvE;AAAAA,QACnBD,SAASwE,WAAWxE;AAAAA,MAHd;AAAA,MAKR+E,OAAO;AAAA,QACL9E,QAAQwE,YAAYxE;AAAAA,QACpBD,SAASyE,YAAYzE;AAAAA,MAFhB;AAAA,IAdJ;AAAA,IAmBLE,YAAY;AAAA,MACVyE,WAAW7D,iCAAiC0D,WAAWtE,YAAY;AAAA,QACjE8E,OAAO/B;AAAAA,QACPgC,UAAUjC;AAAAA,MAAAA,CAF+B;AAAA,MAI3C4B,QAAQ;AAAA,QACNM,eAAe9B;AAAAA,QACf+B,iBAAiB9B;AAAAA,QACjB4B,UAAU9B;AAAAA,MARF;AAAA,MAUV4B,OAAOjE,iCAAiC2D,YAAYvE,YAAY;AAAA,QAC9D+E,UAAU9B;AAAAA,MAAAA,CAD2B;AAAA,IA7BpC;AAAA,IAiCLkB,KAAK;AAAA,MACHM,WACE7B,iBACAE,qBACAC,kBACAC,kBACAC,sBACAC,mBACAC,sBACAT;AAAAA,IATC;AAAA,EAAA;AAYR;ACrXY,MAAA,aAAa,CAAC,OAA6B,UAAoC;AACpF,QAAA,YAAY,MAAM,OAAO,CAAC,GAAG,MAAM,EAAE,OAAO,CAAC,GAAG,CAAE,CAAA;AAEpD,MAAA,QAAQ,KAAK,QAAQ,UAAU;AAAQ,UAAM,IAAI,WAAW;AAEhE,MAAI,YAAY;AAChB,MAAI,WAAW;AAEf,SAAO,WAAW,MAAM,SAAS,KAAK,aAAa,MAAM,UAAU,QAAQ;AACzE,iBAAa,MAAM,UAAU;AACjB,gBAAA;AAAA,EACd;AAEO,SAAA,CAAC,UAAU,SAAS;AAC7B;ACZO,uBAAuB,OAAuB;AACnD,SAAO,SAAS,MAAM,SAClB,QAAQ,MAAM,OAAO,OAAO,MAAM,OAAO,eAAe,MAAM,OAAO,cAAc,MAAM,WACzF;AACN;AC4CE,uBAAA,kBACA2B,QAGA,UACwB;AACxB,SAAO,WACLa,KACE,OAAO,qBAAqB,aAAa,iBAAiB,KAAK,IAAI,kBACnEb,QACA,QACF,EAAE,OAAO,CAAC,KAAK,EAAE,UAAU,YAAY;AAC/B,UAAA,SAAS,UAAU,QAAQ;AAC3B,UAAA,aAAa,oBAAoB,MAAM;AAEtC,WAAA;AAAA,UACH,MAAM;AAAA,YACJ;AAAA;AAAA;AAAA,EAAA,GAGL,KAAiB;AACxB;AAEO,kBACL,eAA6D,QAChB;AAC7C,SAAO,CAAS,UAAA;AAAA;AAAA,MAEZ,cACA,CAAC,MAAM,KAAK,GACZ,CAAC,CAAC,QAAQ,kBAAkB;AAAA,iBACjB,OAAO,UAAU,WAAW,GAAG,MAAM,QAAQ,MAAM,SAAS;AAAA,OAEzE;AAAA;AAEJ;AAEA,uBAAuB,YAA2D;AAChF,SAAO,OAAO,eAAe,WAAW,GAAG,WAAW,QAAQ,WAAW,SAAS;AACpF;AAGE,mBAAA,eAKI,IAC2C;AAC/C,QAAM,mBAAmB,aAAa,cAAc,SAAY,IAAI,aAAa;AACjF,QAAM,qBACJ,aAAa,gBAAgB,SAAY,SAAS,aAAa;AACjE,QAAM,sBACJ,aAAa,iBAAiB,SAAY,IAAI,aAAa;AAC7D,QAAM,oBAAoB,aAAa,eAAe,SAAY,SAAS,aAAa;AAExF,SAAO,CAAS,UAAA;AAAA,MACZ,cACA,CAAC,MAAM,MAAM,GACb,CAAC;AAAA,IACC;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,QACE,CAAC;AAAA,QACD;AAAA,sBACU,cAAc,aAAa,gBAAgB;AAAA,wBACzC,cAAc,eAAe,kBAAkB;AAAA,yBAC9C,cAAc,gBAAgB,mBAAmB;AAAA,uBACnD,cAAc,cAAc,iBAAiB;AAAA,OAEhE;AAAA;AAEJ;AAEA,wBAAwB,aAA6D;AACnF,SAAO,OAAO,gBAAgB,WAAW,GAAG,YAAY,QAAQ,YAAY,SAAS;AACvF;AAGE,oBAAA,eAKI,IAC6C;AACjD,QAAM,oBAAoB,aAAa,eAAe,SAAY,IAAI,aAAa;AACnF,QAAM,sBACJ,aAAa,iBAAiB,SAAY,IAAI,aAAa;AAC7D,QAAM,uBACJ,aAAa,kBAAkB,SAAY,IAAI,aAAa;AAC9D,QAAM,qBAAqB,aAAa,gBAAgB,SAAY,IAAI,aAAa;AAErF,SAAO,CAAS,UAAA;AAAA,MACZ,cACA,CAAC,MAAM,OAAO,GACd,CAAC;AAAA,IACC;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,QACE,CAAC;AAAA,QACD;AAAA,uBACW,eAAe,cAAc,iBAAiB;AAAA,yBAC5C,eAAe,gBAAgB,mBAAmB;AAAA,0BACjD,eAAe,iBAAiB,oBAAoB;AAAA,wBACtD,eAAe,eAAe,kBAAkB;AAAA,OAEpE;AAAA;AAEJ;AAEA,MAAM,oBAAoB,EAAE,OAAO,GAAG,OAAO,SAAS,OAAO;AAE7D,MAAM,gBAAgB,CAAC,EAAE,OAAO,OAAO,YACrC,GAAG,SAAS,OAAO,QAAQ,OAAO,SAAS,SAAS,OAAO,cAAc,KAAK,IAAI;AAGlF,mBAAA,eAKI,IAC2E;AAC/E,QAAM,mBACJ,aAAa,cAAc,SAAY,oBAAoB,aAAa;AAC1E,QAAM,qBACJ,aAAa,gBAAgB,SAAY,oBAAoB,aAAa;AAC5E,QAAM,sBACJ,aAAa,iBAAiB,SAAY,oBAAoB,aAAa;AAC7E,QAAM,oBACJ,aAAa,eAAe,SAAY,oBAAoB,aAAa;AAE3E,SAAO,CAAS,UAAA;AAAA,MACZ,cACA,CAAC,MAAM,MAAM,GACb,CAAC;AAAA,IACC;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,QACE,CAAC;AAAA,QACD;AAAA,sBACU,cAAc,aAAa,gBAAgB;AAAA,wBACzC,cAAc,eAAe,kBAAkB;AAAA,yBAC9C,cAAc,gBAAgB,mBAAmB;AAAA,uBACnD,cAAc,cAAc,iBAAiB;AAAA,OAEhE;AAAA;AAEJ;AAEA,+BACE,oBACA;AACA,SAAO,OAAO,uBAAuB,WACjC,GAAG,mBAAmB,QAAQ,mBAAmB,SACjD;AACN;AAGE,yBAAA,eAKI,IACuD;AAC3D,QAAM,6BACJ,aAAa,wBAAwB,SAAY,IAAI,aAAa;AACpE,QAAM,8BACJ,aAAa,yBAAyB,SAAY,IAAI,aAAa;AACrE,QAAM,uBACJ,aAAa,2BAA2B,SAAY,IAAI,aAAa;AACvE,QAAM,qBACJ,aAAa,4BAA4B,SAAY,IAAI,aAAa;AAExE,SAAO,CAAS,UAAA;AAAA,MACZ,cACA,CAAC,MAAM,YAAY,GACnB,CAAC;AAAA,IACC;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,QACE,CAAC;AAAA,QACD;AAAA,kCACsB,sBACxB,uBAAuB,0BACzB;AAAA,mCAC2B,sBACzB,wBAAwB,2BAC1B;AAAA,qCAC6B,sBAC3B,0BAA0B,oBAC5B;AAAA,sCAC8B,sBAC5B,2BAA2B,kBAC7B;AAAA,OAEJ;AAAA;AAEJ;AAEA,MAAM,eAAe,CAAC,YACpB,QACG,IACC,CAAC,EAAE,SAAS,EAAE,OAAO,SAAS,SAAS,YAAY,cAAc,cAC/D,GAAG,QAAQ,WAAW,KAAK,QAAQ,QAAQ,CAAC,OAAO,QAAQ,QACzD,CACF,OAAO,gBAAgB,kBACrB,SAAS,OAAO,cAAc,KAAK,IAAI,mBAE7C,EACC,OAAO,OAAO,EACd;AAGH,sBAAA,eAA8B,IACuD;AACrF,SAAO,CAAS,UAAA;AAAA,MACZ,cACA,CAAC,MAAM,SAAS,GAChB,CAAC,CAAC,YAAY,kBAAkB;AAAA,sBAChB,aAAa,SAAS;AAAA,OAExC;AAAA;AAEJ;AAEA,MAAM,QACJ,CAAC,MACD,CAAC,MACC,KAAK,MAAM,MAAM,IAAI,CAAC,IAAI,MAAM;AAOrB,uBAAA;AACb,SAAO,CAAS,UAAA;AAAA;AAAA;AAAA;AAAA,MAIZ,cACA,CAAC,MAAM,MAAM,MAAM,WAAW,MAAM,MAAM,GAC1C,CAAC;AAAA,IACC,EAAE,OAAO,UAAU,EAAE,OAAO,CAAC,CAAC,EAAE,CAAC,GAAG,OAAO,GAAG;AAAA,IAC9C,YAAY,EAAE,OAAO,GAAG,MAAM,KAAK;AAAA,IACnC,SAAS,EAAE,OAAO,GAAG,MAAM,KAAK;AAAA,QAC5B;AACJ,UAAM,CAAC,UAAU,eAAe,WAAW,OAAO,MAAM,KAAK;AAC7D,UAAM,WAAW,gBAAgB;AACjC,UAAM,UAAU,gBAAgB,MAAM,UAAU,SAAS;AACnD,UAAA,OAAO,MAAM,UAAU;AAC7B,UAAM,WAAW,MAAM,CAAC,EAAE,OAAO,KAAK;AACtC,UAAM,QAAQ,GAAG,sBAAsB,UAAU,QAAQ,UAAU;AAC7D,UAAA,cAAc,GAAG,OAAO,QAAQ,IAAI,OAAO,OAAO,OAAO,UAAU,QACvE,UAAU;AAEZ,UAAM,mBAAmB;AACnB,UAAA,YAAY,QAAQ,WAAW,iBAAiB;AACtD,UAAM,WAAW,aAAa;AACxB,UAAA,UAAU,aAAa,MAAM,SAAS;AAE5C,WAAO,SAAS,IACZ,EAAE,SAAS,WACX;AAAA,MACE;AAAA,MACA,UAAU;AAAA,MAGV,UAAU;AAAA,MACV,aAAa,WAAW,IAAI,GAAG,UAAU,QAAQ,IAAI,UAAU;AAAA,MAC/D,cAAc,UAAU,IAAI,GAAG,UAAU,QAAQ,IAAI,UAAU;AAAA,MAC/D,YAAY,WAAW,IAAI,GAAG,OAAO,QAAQ,IAAI,OAAO;AAAA,MACxD,eAAe,UAAU,IAAI,GAAG,OAAO,QAAQ,IAAI,OAAO;AAAA,IAAA;AAAA,EAC5D,CAER;AAAA;AAEJ;AAEO,sBACL,eAOI;AAAA,EACF,YAAY;AAAA,EACZ,eAAe;AAAA,EACf,UAAU;AAAA,EACV,YAAY;AAAA,EACZ,eAAe,CAAC;AAAA,EAChB,WAAW,CAAC;AACd,GACuE;AACvE,SAAO,CAAS,UAAA;AAAA,MACZ,cAAc,CAAC,MAAM,SAAS,GAAG,CAAC,CAAC,YAAY,kBAAkB;AAC3D,UAAA;AAAA,MACJ;AAAA,MACA;AAAA,MACA,YAAY,CAAC;AAAA,MACb,gBAAgB,CAAC;AAAA,MACjB;AAAA,MACA;AAAA,QACE;AAEG,WAAA;AAAA,UACH,cAAc,OACZ;AAAA,8BACkB;AAAA,gBAElB;AAAA,UACF,cAAc,OACZ;AAAA,6BACiB;AAAA,gBAEjB;AAAA,UACF,iBAAiB,OACf;AAAA,gCACoB;AAAA,gBAEpB;AAAA,UACF,YAAY,OACV;AAAA,2BACe,GAAG,SAAS,QAAQ,SAAS;AAAA,gBAE5C;AAAA,UACF,cAAc,SAAS,WAAW,IAChC;AAAA;AAAA,gBAGA;AAAA,UACF,UAAU,SAAS,QAAQ,IACzB;AAAA;AAAA,gBAGA;AAAA;AAAA,EAAA,CAEP;AAAA;AAEL;AClZA,MAAM,QAAQ,CAAC,KAAa,KAAa,QAAwB,KAAK,IAAI,KAAK,IAAI,KAAK,GAAG,GAAG,GAAG;ACIjG,sBAAsB9G,SAAsB;AACpC,QAAA;AAAA,IAAElC;AAAAA,IAAU8J;AAAAA,IAAWC;AAAAA,MAC3B7H,QAAQ8H,cAAcC,YAAaC,iBAAiBhI,OAApD;AAEK,SAAA,gBAAgBiI,KAAKnK,WAAW+J,YAAYD,SAA5C;AACR;AAED,yBAAyB5H,SAAmC;AACpD,QAAA;AAAA,IAAEkI;AAAAA,MAAkBlI;AAEtB,MAAA,CAACA,WAAW,CAACkI;AAAsBlI,WAAAA;AAEvC,MAAImI,aAAanI,OAAD;AAAkBA,WAAAA;AAE3BoI,SAAAA,gBAAgBF,aAAD;AACvB;AASgC,kBAAA,KAAqD;AAArD,gBAAEG;AAAAA;AAAAA,IAAUvG;AAAAA,MAAZ,IAAyBwG,iBAAzB,IAAyBA;AAAAA,IAAvBD;AAAAA,IAAUvG;AAAAA;AACrCoF,QAAAA,YAAYqB,OAAuB,IAAjB;AACxB,QAAM,CAACC,oBAAoBC,yBAAyBzE,SAASqE,YAAY,OAAO,IAAIA,QAAxB;AACtDK,QAAAA,4BAA4BH,OAAO,CAAD;AAExCI,4BAA0B,MAAM;AAC9B,QAAI,CAACzB,UAAU0B,WAAWP,YAAY,QAAQA,aAAa;AAAU9G,aAAAA;AAE/DsH,UAAAA,oBAAoB3B,UAAU0B,QAAQd;AACtCgB,UAAAA,eAAeV,gBAAgBlB,UAAU0B,OAAX;AACpC,UAAMG,cACJF,kBAAkBG,oBAAoBF,eAClCD,kBAAkBd,cAClBe;AAENJ,8BAA0BE,UAAUE,aAAaG;AACjDR,0BAAsBJ,QAAD;AAEG,4BAAA;AACJN,wBAAAA,YAAamB,sBAAsB,MAAM;AACzD,YAAI,CAAChC,UAAU0B;AAAS;AAElB,cAAA;AAAA,UAAEO,KAAKC;AAAAA,UAAcC,QAAQC;AAAAA,YACjCpC,UAAU0B,QAAQW;AACd,cAAA;AAAA,UAAEJ,KAAKK;AAAAA,UAAiBH,QAAQI;AAAAA,YACpCX,iBAAiBD,kBAAkBG,kBAC/B;AAAA,UAAEG,KAAK;AAAA,UAAGE,QAAQR,kBAAkBd,YAAa2B;AAAAA,QAAAA,IACjDZ,aAAaS;AACb,cAAA;AAAA,UAAEN,WAAWU;AAAAA,YACjBb,iBAAiBD,kBAAkBG,kBAC/B;AAAA,UAAEC,WAAWJ,kBAAkBd,YAAa6B;AAAAA,QAC5Cd,IAAAA;AACN,cAAMe,qBAAqBJ,qBAAqBD;AAC1CM,cAAAA,0BAA0BH,wBAAwBjB,0BAA0BE;AAElFF,kCAA0BE,UAAUe;AAEpClB,8BAAsBQ,CAAa,cAAA;AAC3Bc,gBAAAA,qBACJX,eAAeI,kBAAkBK,sBAAsBP,kBAAkBE;AAC3E,gBAAMQ,2BACJF,0BAA0B,IAAI,IAAIzB,WAAYY,YAAYA;AAC5D,gBAAMgB,8BACJH,0BAA0B,IACtBN,kBAAkBF,kBAClBO,qBAAqBT;AAC3B,gBAAMc,gBAAgBF,2BAA2BC;AAC3CE,gBAAAA,uBAAuBJ,qBACzBG,gBAAgBJ,0BAChB;AAEGM,iBAAAA,MAAM,GAAGnB,YAAYkB,sBAAsB9B,WAAY,CAAlD;AAAA,QAAA,CAdO;AAAA,MAAA,CAlBvB;AAAA,IAmCD;AAEWgC,gBAAAA,iBAAiB,UAAUC,YAAvC;AAEO,WAAA,MAAMvB,YAAYwB,oBAAoB,UAAUD,YAA1C;AAAA,EAAA,GACZ,CAACjC,QAAD,CAtDsB;AAwDnBmC,QAAAA,WAAWnE,YACf,CAAC,OAAuC;AAAvC,iBAAEoE;AAAAA;AAAAA,QAAF,IAAYC,gCAAZ,IAAYA;AAAAA,MAAVD;AAAAA;AAAqC,4CACnCC,sBADmC;AAAA,MAEtCD,OAAO,gDACFA,QADE;AAAA,QAELE,UAAU;AAAA,QACVC,MAAM;AAAA,QACNC,OAAO;AAAA,QACP1B,KAAK;AAAA,QACLE,QAAQ;AAAA,UACJhB,YAAY,QAAQA,aAAa,IACjC,CAAA,IACA;AAAA,QACEc,KAAK,CAACd;AAAAA,QACNgB,QAAQ,CAAChB;AAAAA,QACTyC,WAAY,kBAAiBtC,qBAAqBH;AAAAA,MALxD;AAAA,IASJ;AAAA,KAAA,CAACA,UAAUG,kBAAX,CAnB0B;AAsB5B,qEAEQF;IACJ,KAAKpB;AAAAA,IACL,OAAO;AAAA,MAAEyD,UAAU;AAAA,MAAYxB,KAAK;AAAA,MAAGyB,MAAM;AAAA,MAAGC,OAAO;AAAA,MAAGxB,QAAQ;AAAA,IAHpE;AAAA,IAKGvH,UAAAA,SAAS0I,QAAD;AAAA,EAAA,EANb;AASD;AClHD,MAAMO,cAAYvN,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAUzB,MAAMuN,OAAOxN,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gBAMJ8F,WAASA,MAAM0H;AAAAA,aAClB1H,CAAAA,UAAUA,MAAM2H,UAAU,IAAI;AAAA;AAAA;AAI3C,MAAMC,WAAW,CAACnL,SAAsBoL,aAAqBC,SAAiB;AACtE,QAAA;AAAA,IAAEC,aAAaC;AAAAA,IAAOC,cAAcC;AAAAA,MAAWzL;AACrD,QAAM0L,sBAAsBH,QAAQE;AAEpC,SAAOE,KAAKC,IAAIR,cAAcM,qBAAqBA,sBAAsBN,WAAlE,IAAiFC;AACzF;AAUuC,yBAAA;AAAA,EACtCQ,MAAM;AAAA,EACNT,cAAc,KAAK;AAAA,EACnBC,OAAO;AAAA,EACPS;AAAAA,EACA7J;AAAAA,GACqB;;AACf,QAAA,CAAC8J,OAAOC,YAAYhI,SAAS,KAAD;AAC5B,QAAA,CAAC5B,OAAO6J,YAAYjI,SAAS,CAAD;AAC5BkD,QAAAA,YAAYqB,OAAuB,IAAjB;AAExBI,4BAA0B,MAAM;AACxB,UAAA;AAAA,MAAEC,SAASsD;AAAAA,QAAgBhF;AAEjC,QAAI,CAACgF;AAAoB3K,aAAAA;AAEnB,UAAA;AAAA,MAAEwG;AAAAA,QAAgBmE,YAAYpE;AACpC,UAAMqE,eAAe,MAAMF,SAASd,SAASe,aAAad,aAAaC,IAA3B,CAAT;AAEvB;AAEChB,gBAAAA,iBAAiB,UAAU8B,YAAxC;AAEO,WAAA,MAAMpE,YAAawC,oBAAoB,UAAU4B,YAA3C;AAAA,EAAA,GACZ,CAACf,aAAaC,IAAd,CAbsB;AAerB,MAAA,CAACe,YAAYC,QAAQR,GAApB;AAAiC,WAAA9J,oBAAPuK,UAAA,CAAA,CAAA;AAE/B,8BACGvB,aAAD;AAAA,IAAW,KAAK7D;AAAAA,IAAhB,UAAA,CACGA,UAAU0B,+BACR,aAAD;AAAA,MACE;AAAA,MACA,QAAQ;AAAA,QACN2D,OAAO;AAAA,UAAEC,eAAe;AAAA,YAAEC,YAAY;AAAA,UAAd;AAAA,QADlB;AAAA,QAENC,SAAS;AAAA,UACPC,YAAY;AAAA,YACVC,QAAQ1F,gBAAU0B,QAAQd,cAAcC,gBAAhCb,mBAA6C2F,SAASD;AAAAA,UADpD;AAAA,QAHR;AAAA,QAONE,QAAQ;AAAA,UACNtL,SAAS;AAAA,YACPuL,kBAAkB;AAAA,YAClBC,qBAAqB;AAAA,YACrBC,SAAS;AAAA,YACTC,YAAY;AAAA,YACZC,eAAe;AAAA,YACfC,kBAAkB;AAAA,YAClBC,OAAO;AAAA,UAPA;AAAA,QADH;AAAA,MATZ;AAAA,MAqBE,SArBF;AAAA,MAsBE,MAtBF;AAAA,MAuBE,OAvBF;AAAA,MAwBE,UAAU;AAAA,MACV,SAAS,MAAMrB,SAAS,IAAD;AAAA,MACvB,OAAO;AAAA,QACLlB,WAAY,WAAU1I,UAAUA;AAAAA,QAChCH;AAAAA,MA5BJ;AAAA,MA8BE,OAAM;AAAA,MACN,QAAO;AAAA,IAAA,CAjCb,GAoCEF,oBAAC,MAAD;AAAA,MAAM,iBAAiB+J;AAAAA,MAAW,SAAS,CAACC;AAAAA,IAAAA,CApC9C,CAAA;AAAA,EAAA,CADF;AAwCD;ACnGD,kBAAkBuB,OAAiC;AACjD,MAAIA,SAAS;AAAa,WAAA;AAEtBA,MAAAA,MAAMC,UAAU,MAAM;AACxB,WAAOC,cAAc,iCAAKF,QAAL;AAAA,MAAYC,QAAQ;AAAA,QAAEE,KAAK;AAAA,QAAGC,YAAY;AAAA,QAAGC,WAAW;AAAA,MAApC;AAAA,IAAA,EAArB;AAAA,EACrB;AAEMH,SAAAA,cAAcF,KAAD;AACrB;AAID,MAAMM,gBAAgB,CAACC,UACrBA,MAAMtP,IAAI,CAAC;AAAA,EAAE+O;AAAAA,EAAOT;AAAAA,MAAgB,GAAEiB,SAASR,KAAD,KAAWT,WAAzD,EAAsE/F,KAAK,GAA3E;AAIF,MAAMiH,iBAAiB,CAAC3C,gBAA6B;AAC3CA,UAAAA;AAAAA,SACD;AACH,aAAO,KAAK;AAAA,SACT;AACH,aAAO,IAAI;AAAA;AAEX,aAAO,KAAK;AAAA;AAEjB;AAED,MAAM4C,eAAexQ,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAQ5B,MAAMsN,cAAYvN,OAAOwQ,YAAD;AAAA;AAAA;AAIxB,MAAMC,yBAAuBzQ,OAAOuN,WAAD;AAAA;AAAA,IAE/BmD,CAAAA,MACAC,cACE,CAACD,EAAEE,UAAH,GACA,CAAC,CAACA,gBAAgBC;AAAAA,mBACLD,eAAe,OAAO,UAAU;AAAA,OAHlC;AAAA;AAUmB,qBAAA;AAAA,EAAEE;AAAAA,GAAmC;AACvE,MAAIA,eAAe;AAAa,WAAAvM,oBAAPuK,UAAA,CAAA,CAAA;AAGvB,6BAAAA,UAAA;AAAA,IAAA,UACGgC,YAAY/P,IAAI,CAAC;AAAA,MAAEgQ;AAAAA,MAAOC;AAAAA,UAAe;AAClCJ,YAAAA,aAAaE,YAAY/P,IAAIkQ,CAAM,MAAA;AAAA,QACvCD,UAAUC,EAAED;AAAAA,QACZD,OAAOE,EAAED,aAAaA;AAAAA,MAFL,EAAA;AAKnB,iCACGP,wBAAD;AAAA,QAAqC;AAAA,QAClC,UAAA,CAAC,GAAGM,KAAJ,EAAWG,QAAUnQ,EAAAA,IAAIoQ,CAAM,OAAA;AAC1BA,cAAAA,GAAG/L,SAAS,SAAS;AACvB,uCACGmI,aAAD;AAAA,cAEE,OAAO;AAAA,gBACLE,iBAAiB6C,SAASa,GAAGC,OAAJ;AAAA,cADpB;AAAA,YAAA,GADFD,GAAGnQ,EADV;AAAA,UAOH;AAEGmQ,cAAAA,GAAG/L,SAAS,WAAW+L,GAAGC,SAAS;AAC/B,kBAAA;AAAA,cACJC;AAAAA,cACAlE;AAAAA,cACAmE,SAAS;AAAA,cACTC,OAAO;AAAA,cACP9M;AAAAA,cACA+M;AAAAA,gBACEL,GAAGC;AACDK,kBAAAA,qBAAsB,GAAEtE,SAASzI,MAAMyI,SAASxI;AAElD2M,gBAAAA,WAAW,eAAeC,SAAS,UAAUF,aAAa,MAAM;AAClE,yCACG,UAAD;AAAA,gBAAsB,UAAUG;AAAAA,gBAAhC,UACGE,CACC,qBAAAnN,oBAASmN,OAAAA,iCAAAA,iBAAiB;AAAA,kBAAEzE,OAAO;AAAA,oBAAExI;AAAAA,oBAASnE,UAAU;AAAA,kBAArB;AAAA,gBAAA,CAAV,IAAhBoR;AAAAA,kBAAT,8BACG,WAAD;AAAA,oBACE,KAAKL;AAAAA,oBACL,QAAO;AAAA,oBACP,gBAAgBI;AAAAA,oBAChB,WAAWF;AAAAA,kBAAAA,CAJb;AAAA,gBAAA,EADF;AAAA,cAAA,GAFWJ,GAAGnQ,EAAlB;AAAA,YAaH;AAED,uCACG,UAAD;AAAA,cAAsB,UAAUwQ;AAAAA,cAAhC,UACGE,CACC,qBAAAnN,oBAACgJ,aAAD,mBACMmE,iBAAiB;AAAA,gBACnBzE,OAAO;AAAA,kBACL0E,iBAAiBN,aAAa,OAAQ,QAAOA,gBAAgBtN;AAAAA,kBAC7D0N;AAAAA,kBACAG,kBAAkBN;AAAAA,kBAClBO,gBAAgBN;AAAAA,kBAChB9M;AAAAA,gBALK;AAAA,cAAA,CADW,EADtB;AAAA,YAAA,GAFW0M,GAAGnQ,EAAlB;AAAA,UAgBH;AAEGmQ,cAAAA,GAAG/L,SAAS,cAAc+L,GAAGC,SAAS;AAClC,kBAAA;AAAA,cAAEU;AAAAA,cAAOzB;AAAAA,cAAO0B;AAAAA,gBAAaZ,GAAGC;AAChCY,kBAAAA,WAAY,GAAE5B,cAAcC,KAAD;AAEjC,uCACG9C,aAAD;AAAA,cAEE,OAAO;AAAA,gBACL0B,YAAY8C,WACP,mBAAkBC,cAClB,mBAAkBF,aAAaE;AAAAA,cAH/B;AAAA,YAAA,GADFb,GAAGnQ,EADV;AAAA,UASH;AAEGmQ,cAAAA,GAAG/L,SAAS,WAAW+L,GAAGC,SAAS;AAC/B,kBAAA;AAAA,cAAE/C;AAAAA,cAAKT;AAAAA,cAAaU;AAAAA,cAAWT;AAAAA,cAAMpJ;AAAAA,cAAS+M;AAAAA,gBAAaL,GAAGC;AAEpE,uCACG,UAAD;AAAA,cAAsB,UAAUI;AAAAA,cAC7BE,UAAAA,CACC,qBAAAnN,oBAACgJ,8CAAcmE,iBAAiB,CAAA,CAAD;gBAA/B,8BACG,iBAAD;AAAA,kBACE;AAAA,kBACA;AAAA,kBACA;AAAA,kBACA,aAAanB,eAAe3C,WAAD;AAAA,kBAC3B,WAAW0C,SAAShC,SAAD;AAAA,gBAAA,CALrB;AAAA,cAAA,EADF;AAAA,YAAA,GAFW6C,GAAGnQ,EAAlB;AAAA,UAcH;AAEM,iBAAA;AAAA,QAAA,CA/FR;AAAA,SADwBgQ,QAA3B;AAAA,IAAA,CAPH;AAAA,EAAA,CAFL;AAgHD;AClKD,MAAMiB,iBAAiBjS,OAAOkS,OAAOjS,GAAR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAsB7B,IAAA,uBAAeE,WAAyC,+BACtD,IACAC,KACA;AAFA,eAAE0Q;AAAAA;AAAAA,IAAaxM;AAAAA,MAAf,IAA4BjE,wBAA5B,IAA4BA;AAAAA,IAA1ByQ;AAAAA,IAAaxM;AAAAA;AAGf,QAAM,CAAC6N,QAAQC,aAAa5L,SAAgC,IAAxB;AAEpC6L,sBAAoBjS,KAAK,MAAM+R,QAAQ,CAACA,MAAD,CAApB;AAGjB,8BAAC,gBAAD,iCAAoB9R,cAApB;AAAA,IAAiC,KAAK+R;AAAAA,IAAtC,UAAA,CACE7N,oBAAC,aAAD;AAAA,MAAa,aAAa+N,eAAexB,WAAD;AAAA,IAAxC,CAAA,GACCyB,SAASC,KAAKlO,QAAd,CAFH;AAAA,EAAA,EADF;AAMD,CAdwB;ACuCzB,MAAMmO,6BAA6BzS,OAAOyQ,oBAAD,EAAuBiC,WAAW;AAAA,EACzEC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,UAAU,gBAAgB,WAA3B,EAAwCC,SAASD,KAAKvP,UAAtD;AAD6C,CAAxC;AAAA;AAAA,IAQ/ByP,UAAY;AAAA,IACZC,gBAAkB;AAAA,IAClBhN,CAAAA,UAAS4K,cAAc,CAAC5K,MAAMiN,SAAP,GAA4B,CAAC,CAACA,YAAY,YAAa;AAAA,EAAEA;AAAF,EAAxD;AAAA;AAG1B,MAAMC,SAAOjT,OAAOkS,OAAOjS,GAAR,EAAayS,WAAW;AAAA,EACzCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,WAAW,UAAU,aAAa,cAAnC,EAAmDC,SAASD,IAA5D;AADa,CAA9B;AAAA;AAAA;AAAA;AAAA,IAWTM,WAAa;AAAA,IACbC,UAAY;AAAA,IACZC,aAAe;AAAA,IACfrN,CAAAA,UACA4K,cAAc,CAAC5K,MAAMsN,YAAP,GAA+B,CAAC,CAACA,eAAe,kBAAmB;AAAA,EAC/EA;AAD+E,EAApE;AAAA;AAIjB,MAAMC,aAAWtT,OAAOkS,OAAOjS,GAAR,EAAayS,WAAW;AAAA,EAC7CC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAQ,cAAc,SAAS,aAAa,QAA7C,EAAuDC,SAASD,IAAhE;AADiB,CAA9B;AAAA;AAAA;AAAA;AAAA;AAAA,IAabW,YAAc;AAAA,IACdxN,CAAAA,UACA4K,cAAc,CAAC5K,MAAMyN,UAAP,GAA6B,CAAC,CAACA,aAAa,kBAAmB;AAAA,EAAEA;AAAF,EAAhE;AAAA;AAGXC,MAAAA,MAAMtT,WAAW,cACrB;AAAA,EACEa;AAAAA,EACA8P;AAAAA,EACA/C;AAAAA,EACAE;AAAAA,EACAyF;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAtP;AAAAA,EACAuP;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACArM;AAAAA,EACAE;AAAAA,EACAC;AAAAA,EACAG;AAAAA,EACAF;AAAAA,EACAC;AAAAA,EACAE;AAAAA,GAEFhI,KACA;AACM+T,QAAAA,WAAWpJ,OAA8B,IAAxB;AACvB,QAAM,CAACtD,YAAY2M,iBAAiB5N,SAA6B,IAArB;AAE5C6L,sBACEjS,KACA,MAAO;AAAA,IACLiU,cAAc;;AACZ,YAAMC,oBAAoBH,SAAS/I;AACnC,YAAMmJ,mBAAmBJ,SAAS/I;AAC5BoJ,YAAAA,mBAAmB/M;AACnBgN,YAAAA,YAAYN,eAAS/I,YAAT+I,mBAAkBpI;AAC9B2I,YAAAA,0BACJJ,6DAAmBhK,cAAcC,gBAAjC+J,mBAA8C9J,iBAAiB8J;AAC3DK,YAAAA,yBACJJ,2DAAkBjK,cAAcC,gBAAhCgK,mBAA6C/J,iBAAiB+J;AAC1DK,YAAAA,yBACJJ,2DAAkBlK,cAAcC,gBAAhCiK,mBAA6ChK,iBAAiBgK;AAC1Db,YAAAA,WAAUe,2BAA2B;AAAA,QACzC/I,KAAKkJ,MAAMH,wBAAwBI,UAAzB;AAAA,QACVzH,OAAOwH,MAAMH,wBAAwBK,YAAzB;AAAA,QACZlJ,QAAQgJ,MAAMH,wBAAwBM,aAAzB;AAAA,QACb5H,MAAMyH,MAAMH,wBAAwBO,WAAzB;AAAA,MAAA;AAEPrB,YAAAA,UAASe,0BAA0B;AAAA,QACvChJ,KAAKkJ,MAAMF,uBAAuBO,cAAxB;AAAA,QACV7H,OAAOwH,MAAMF,uBAAuBQ,gBAAxB;AAAA,QACZtJ,QAAQgJ,MAAMF,uBAAuBS,iBAAxB;AAAA,QACbhI,MAAMyH,MAAMF,uBAAuBU,eAAxB;AAAA,MAAA;AAEP3B,YAAAA,UAASkB,0BAA0B;AAAA,QACvCjJ,KAAKkJ,MAAMD,uBAAuBU,SAAxB;AAAA,QACVjI,OAAOwH,MAAMD,uBAAuBW,WAAxB;AAAA,QACZ1J,QAAQgJ,MAAMD,uBAAuBY,YAAxB;AAAA,QACbpI,MAAMyH,MAAMD,uBAAuBa,UAAxB;AAAA,MAAA;AAGNhB,aAAAA,YAAYiB,UAAU;AAAA,QAAEjB;AAAAA,QAAWd,SAAAA;AAAAA,QAASC,QAAAA;AAAAA,QAAQF,QAAAA;AAAAA,MAA/B,CAAA,IAA2C;AAAA,IACxE;AAAA,EAAA,IAEH,CAACjM,UAAD,CApCiB;AAuCbkO,QAAAA,aAAaC,UAAUhC,MAAD;AACtBiC,QAAAA,gBAAgBC,aAAahC,SAAD;AAE5B,QAAA;AAAA,IAAErK;AAAAA,IAASG;AAAAA,IAASC;AAAAA,IAAU5E;AAAAA,IAAYmE;AAAAA,MAAQ5B,iBAAiB;AAAA,IACvEK;AAAAA,IACAE;AAAAA,IACAC;AAAAA,IACAG;AAAAA,IACAF;AAAAA,IACAC;AAAAA,IACAE;AAAAA,IACAX;AAAAA,IACAC,UAAUpD,qCAAUoD;AAAAA,EAAAA,CATkD;AAYxE,6BACG,4BAAD;AAAA,IACE,KAAK0M;AAAAA,IACL;AAAA,IACA,WAAW2B,GAAGhI,KAAD;AAAA,IACb;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAWE;AAAAA,IACX,SAASrE,mCAASF;AAAAA,IAClB,SAASD,mCAASC;AAAAA,IAClB,UAAUG,qCAAUH;AAAAA,IACpB,YAAYzE,yCAAYyE;AAAAA,IAX1B,8BAcGuJ,QAAD;AAAA,MACE,KAAKkB;AAAAA,MACL;AAAA,MACA,QAAQwB;AAAAA,MACR,WAAWE;AAAAA,MACX,cAAc3B;AAAAA,MACd,SAAStK,mCAASD;AAAAA,MAClB,SAASF,mCAASE;AAAAA,MAClB,YAAY1E,yCAAY0E;AAAAA,MAEvBrF,UAAAA,YAAYA,SAASoD,SAASsO,SAAS,IACtC1R,SAASoD,SAAS3G,IAAI,CAAC+I,OAAOmM,8BAC3B3C,YAAD;AAAA,QAEE,MAAMhP,SAAS4R;AAAAA,QACf;AAAA,QACA;AAAA,QACA;AAAA,QACA,YAAYhC;AAAAA,QACZ,UAAUrK,qCAAUC;AAAAA,QACpB,YAAY7E,yCAAY6E;AAAAA,QAR1B,8BAUGqM,WAAD;AAAA,UAAS,SAASrM;AAAAA,QAAAA,CAAlB;AAAA,SATKA,MAAMV,GADb,CADF,wBAeCgN,eAAD;AAAA,QAAa,MAAMnC;AAAAA,MAAAA,CAAnB;AAAA,IAAA,CA1BJ;AAAA,EAAA,GAFK7K,2BAAKM,SAZZ;AA6CH,CAjIqB;AAqIf,6BAA2B2M,SAAuB;AAErDtQ,wCAAAA,OACAiL,UACAsF,UACS;;AACHC,UAAAA,YAAYxQ,MAAMuQ;AACxB,WAAyCC,gCAAAA,WAAWvF,QAA1B,MAAeuF,mBAAsBxF,UAAtBwF,YAA+B,YAAY;AAAA,EACrF;AACKC,QAAAA,8BAA8B,CAACzQ,OAAgCiL,aACnEyF,6BAA6B1Q,OAAOiL,UAAU,gBAAlB;AACxB0F,QAAAA,+BAA+B,CAAC3Q,OAAgCiL,aACpEyF,6BAA6B1Q,OAAOiL,UAAU,iBAAlB;AAEvBqF,SAAAA,QAAQM,kBAAkBlD,KAAK;AAAA,IACpCrO,MAAM;AAAA,IACNwR,OAAO;AAAA,IACP7Q,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL/F,aAAa+F,cAFR;AAAA,MAGL9I,OAAO8I,MAAY;AAAA,QAAEC,QAAQD,MAAYE,QAAQC;AAAAA,MAAAA,CAA1C;AAAA,MACP/I,QAAQ4I,yBAA+B;AAAA,QACrCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAQ6F,OAAO;AAAA,UAAQK,MAAM;AAAA,QAAA,GACtC;AAAA,UAAElG,OAAO;AAAA,UAAW6F,OAAO;AAAA,UAAWK,MAAM;AAAA,QAAA,CAFrC;AAAA,QAITC,cAAc;AAAA,MAAA,CANR;AAAA,MAQRhD,eAAe2C,yBAA+B;AAAA,QAC5CD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAc6F,OAAO;AAAA,UAAOK,MAAM;AAAA,QAAA,GAC3C;AAAA,UAAElG,OAAO;AAAA,UAAU6F,OAAO;AAAA,UAAUK,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAElG,OAAO;AAAA,UAAY6F,OAAO;AAAA,UAAUK,MAAM;AAAA,QAAA,GAC5C;AAAA,UACElG,OAAO;AAAA,UACP6F,OAAO;AAAA,UACPK,MAAM;AAAA,QAAA,CAPD;AAAA,QAUTC,cAAc;AAAA,MAAA,CAZD;AAAA,MAcfxD,QAAQmD,OA1BH;AAAA,MA2BLlD,SAASkD,QAAc;AAAA,QACrBM,QAAQ,CACN;AAAA,UACEnG,UAAU;AAAA,UACVD,OAAO;AAAA,YACL+D,YAAY;AAAA,cAAE/D,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAD1B;AAAA,YAELrC,cAAc;AAAA,cAAEhE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAF5B;AAAA,YAGLpC,eAAe;AAAA,cAAEjE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAH7B;AAAA,YAILnC,aAAa;AAAA,cAAElE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAAnB;AAAA,UAJR;AAAA,QAAA,CAHH;AAAA,MAAA,CADD;AAAA,MAaTxD,QAAQiD,OAxCH;AAAA,MAyCLhD,cAAcgD,aAzCT;AAAA,MA0CL/C,WAAW+C,QA1CN;AAAA,MA2CL9C,QAAQ8C,KAAW9Q,CAAU,UAAA;AAAA,QAC3BsR,QAAQtR,MAAMzB,YAAY;AAAA,MAAA,EADpB;AAAA,MAGR0P,WAAW6C,KAAW9Q,CAAU,UAAA;AAAA,QAC9BsR,QAAQtR,MAAMzB,YAAY;AAAA,MAAA,EADjB;AAAA,MAGXuD,gBAAgBgP,iBAAuB;AAAA,QACrCD,OAAO;AAAA,QACPU,kBAAkB;AAAA,QAClBtT,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAQ6F,OAAO;AAAA,QAAA,GACxB;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,GAC7B;AAAA,UAAE7F,OAAO;AAAA,UAAY6F,OAAO;AAAA,QAAA,GAC5B;AAAA,UAAE7F,OAAO;AAAA,UAAY6F,OAAO;AAAA,QAAA,GAC5B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAW6F,OAAO;AAAA,QAAA,GAC3B;AAAA,UAAE7F,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,CATtB;AAAA,QAWTM,cAAc;AAAA,MAAA,CAdA;AAAA,MAgBhBnP,oBAAoB8O,iBAAuB,CAAC9Q,OAAOwR,WAAY;AAAA,QAC7DX,OAAO;AAAA,QACPM,cAAc/P;AAAAA,QACdqQ,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRL,QAAQb,4BAA4BzQ,OAAOwR,MAAR;AAAA,MAAA,EANjB;AAAA,MAQpBvP,iBAAiB6O,iBAAuB,CAAC9Q,OAAOwR,WAAY;AAAA,QAC1DX,OAAO;AAAA,QACPM,cAAchQ;AAAAA,QACdsQ,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRL,QAAQb,4BAA4BzQ,OAAOwR,MAAR;AAAA,MAAA,EANpB;AAAA,MAQjBtP,iBAAiB4O,iBAAuB;AAAA,QACtCD,OAAO;AAAA,QACPU,kBAAkB;AAAA,QAClBtT,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAQ6F,OAAO;AAAA,QAAA,GACxB;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,GAC7B;AAAA,UAAE7F,OAAO;AAAA,UAAY6F,OAAO;AAAA,QAAA,GAC5B;AAAA,UAAE7F,OAAO;AAAA,UAAY6F,OAAO;AAAA,QAAA,GAC5B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAW6F,OAAO;AAAA,QAAA,GAC3B;AAAA,UAAE7F,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,CATtB;AAAA,QAWTM,cAAc;AAAA,MAAA,CAdC;AAAA,MAgBjBhP,qBAAqB2O,iBAAuB,CAAC9Q,OAAOwR,WAAY;AAAA,QAC9DX,OAAO;AAAA,QACPM,cAAc/P;AAAAA,QACdqQ,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRL,QAAQX,6BAA6B3Q,OAAOwR,MAAR;AAAA,MAAA,EANjB;AAAA,MAQrBpP,kBAAkB0O,iBAAuB,CAAC9Q,OAAOwR,WAAY;AAAA,QAC3DX,OAAO;AAAA,QACPM,cAAc7P;AAAAA,QACdmQ,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRL,QAAQX,6BAA6B3Q,OAAOwR,MAAR;AAAA,MAAA,EANpB;AAAA,MAQlBnP,qBAAqByO,iBAAuB,CAAC9Q,OAAOwR,WAAY;AAAA,QAC9DX,OAAO;AAAA,QACPY,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRR,cAAc3P;AAAAA,QACd8P,QAAQX,6BAA6B3Q,OAAOwR,MAAR;AAAA,MAAA,EANjB;AAAA,MAQrBtD,iBAAiB4C,WAAe9Q,CAAU,UAAA;AAAA,QACxC6Q,OAAO;AAAA,QACPS,QAAQtR,MAAMzB,YAAY;AAAA,MAAA,EAFX;AAAA,MAIjBA,UAAUuS,OAAA;AAAA,IA7HL;AAAA,EAAA,CAHF;AAmIR;ACvYYc,MAAAA,OAAOxX,WAAqC,eACvD,IACAC,KACA;AAFA,eAAE4B;AAAAA;AAAAA,IAAM4V,UAAU,MAAM;AAAA,IAAE;AAAA,MAA1B,IAA+BvX,wBAA/B,IAA+BA;AAAAA,IAA7B2B;AAAAA,IAAM4V;AAAAA;;AAGFpW,QAAAA,OAAOqW,QAAQ7V,QAAQA,KAAKoD,SAAS,cAAcpD,KAAKoP,QAAQ0G,SAAS,IAA3D;AACpB,QAAMC,aACJ/V,8BAAMoD,UAAS,sBAAsBpD,WAAKoP,QAAQ4G,oBAAbhW,mBAA8B+V,aAAa;AAC5EE,QAAAA,YAAYC,aAAaH,UAAD;AAE1BI,MAAAA,OAAO;AACPC,MAAAA;AACAC,MAAAA;AAEJ,MAAIrW,MAAM;AACAA,YAAAA,KAAKoD;AAAAA,WACN,aAAa;AACZ5D,YAAAA;AAAM2W,iBAAQ,IAAG3W,KAAK8W;AAEjBtW,iBAAAA,KAAKoP,QAAQmH,eAAe,WAAW;AAEhD;AAAA,MACD;AAAA,WAEI,YAAY;AACfJ,eAAOnW,KAAKoP,QAAQ/C;AAEXrM,iBAAAA,KAAKoP,QAAQmH,eAAe,WAAW;AAEhD;AAAA,MACD;AAAA,WAEI,cAAc;AACX,cAAA;AAAA,UAAEC;AAAAA,UAAIC,UAAU;AAAA,UAAIC,OAAO;AAAA,YAAO1W,KAAKoP;AAE7C,YAAIoH,MAAM;AAAc,iBAAA,UAASA,cAAcC,gBAAgBC;AAE/D;AAAA,MACD;AAAA,WAEI,cAAc;AACT,eAAA,OAAM1W,KAAKoP,QAAQuH;AAE3B;AAAA,MACD;AAAA,WAEI,qBAAqB;AACxBR,eAAQ,IAAGF,gCAAa;AACxBI,gBAAQrW,KAAKoP,QAAQiH;AAErB;AAAA,MACD;AAAA;AAGO,cAAA,IAAIO,WAAY,sBAAsB5W,KAAaoD,QAAnD;AAAA;AAAA,EAEX;AAEQyT,uBAAYC,OAAsC;AACzDlB,YAAQkB,KAAD;AAEHA,QAAAA,MAAMC;AAAkB;AAOxBD,QAAAA,MAAME,cAAcC;AAAmB,aAAOH,MAAMI;AAEpDlX,QAAAA,QAAQA,KAAKoD,SAAS,qBAAqB;AACzC+T,UAAAA;AAEA,UAAA;AACFA,eAAO,IAAIC,IAAK,0BAAyBjB,MAAlC,EAA0CgB;AAAAA,eAC1CE;AACCA,gBAAAA,MAAO,+BAA8BlB,QAAQkB,KAArD;AAAA,MACD;AAEGlB,UAAAA,QAAQ,QAAQA,SAASgB,MAAM;AACjCL,cAAMI,eAAN;AACMI,cAAAA,OAAOR,MAAMQ;AAEnBC,uBAAeD,KAAKE,SAASC,cAAcN,IAA5B,GAAoC;AAAA,UACjDO,UAAU;AAAA,UACVrB;AAAAA,QAAAA,CAFY;AAKViB,YAAAA,KAAKjK,SAAS8J,SAASA;AAAMG,eAAKK,QAAQC,UAAU,IAAI,IAAIT,IAA/B;AAAA,MAClC;AAAA,IACF;AAAA,EACF;AAED,6BACG,UAAD;AAAA,IAAU;AAAA,IAAV,oEAES9Y;MAAa;AAAA,MAAU;AAAA,MAAgB,SAASwY;AAAAA,IAAAA,EAAvD;AAAA,EAAA,CAHJ;AAMD,CAlG6B;ACE5B,yBAAA,kBACAvP,QACA,UACW;AACJ,SAAAa,KAAqB,kBAAkBb,QAAM,QAAQ,EAAE,OAC5D,CAAC,KAAK,EAAE,UAAU,YAAY;AACtB,UAAA,SAAS,UAAU,QAAQ;AAC3B,UAAA,aAAa,oBAAoB,MAAM;AAEtC,WAAA,iCACF,MADE;AAAA,OAEJ,aAAa,kCACR,IAAI,cACL;AAAA,IACL;AAAA,EAEJ,GACA,CACF,CAAA;AACF;AAGE,yBAAA,WACA,eAA6D,QAClD;AACJ,SAAA;AAAA,IACL,UAAU;AAAA,KACP,gBAAgB,CAAC,SAAS,GAAG,CAAC,CAAC,QAAQ,kBAAmB;AAAA,IAC3D,OAAO,OAAO,UAAU,WAAW,GAAG,MAAM,QAAQ,MAAM,SAAS;AAAA,EAAA,EACnE;AAEN;ACNA,MAAMuQ,iBAAe7Z,OAAO2X,IAAD,EAAOjF,WAAW;AAAA,EAC3CC,mBAAmBC,CAAAA,SACjB,CAAC,CAAC,UAAU,WAAW,SAAS,QAAQ,aAAa,SAAS,WAA7D,EAA0EC,SACzED,KAAKvP,UADN;AAFwC,CAAxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAsBjByP,UAAY;AAAA,IACZpC,CAAAA,MACAC,cACE,CAACD,EAAE5H,SAAS4H,EAAEoJ,OAAOpJ,EAAEa,MAAMb,EAAEqJ,WAAWrJ,EAAEZ,KAA5C,GACA,CAAC,CACChH,UAAU,QACVgR,QAAQ,WACRvI,OAAO,UACPwI,YAAY;AAAA,EAAEhK,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAqD6J,OAAO;AAA5D,GACZlK,QAAQ;AAAA,EAAEC,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OACJ;AACJ,QAAMC,WAAW;AAAA,IACflJ,OAAO;AAAA,MAAEmJ,OAAO;AAAA,MAAIC,QAAQ;AAAA,MAAIC,OAAO;AAAA,IAAK7I,EAAAA;AAAAA,IAC5C6F,MAAM;AAAA,EAAA;AAGDvG,SAAAA;AAAAA,mBACIb,cAAc+J,SAAD;AAAA,2BACL;AAAA,IAAEM,QAAQ;AAAA,IAAGC,SAAS;AAAA,IAAGC,MAAM;AAAA,EAAMT,EAAAA;AAAAA,qBAC3C;AAAA,IAAEI,OAAO;AAAA,IAAYC,QAAQ;AAAA,IAAaC,OAAO;AAAA,EAAc7I,EAAAA;AAAAA,uBAC5D,GAAE0I,SAASlJ,QAAQkJ,SAAS7C;AAAAA,YACxC;AAAA,IACAoD,MAAM3J;AAAAA,4BACUb,cAAcF,KAAD;AAAA;AAAA,4BAEb,CAAC,SAAS,cAAc,UAAU,YAAlC,EACX/O,IAAIuV,CAAAA,aAAa,GAAEA,4BADR,EAEXhN,KAAK,IAFM;AAAA;AAAA;AAAA,8BAKEmR,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,GAAzC,EAA8CC;;;;8BAI9CF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;;;IAGjEC,SAAS/J;AAAAA;AAAAA,4CAEuBb,cAAcF,KAAD;AAAA,4BAC7B,CAAC,SAAS,cAAc,YAAxB,EACX/O,IAAIuV,CAAAA,aAAa,GAAEA,4BADR,EAEXhN,KAAK,IAFM;AAAA;AAAA;AAAA,8CAKkBmR,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,GAAzC,EAA8CC;yBACnEF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,GAAzC,EAA8CC;;;;8CAIzBF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;yBACpEF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;;;IAG5DE,QAAQhK;AAAAA,4BACQb,cAAcF,KAAD;AAAA;AAAA,4BAEb,CAAC,aAAa,YAAd,EACX/O,IAAIuV,cAAa,GAAEA,gBADR,EAEXhN,KAAK,IAFM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAchBwR,OAAOjK;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,yBAKM4J,YAAYzK,cAAc+J,SAAD,CAAd,EAA2BC,MAAM,GAA5C,EAAiD3W;;;;yBAIjDoX,YAAYzK,cAAc+J,SAAD,CAAd,EAA2BC,MAAM,GAA5C,EAAiD3W;;;IAG9D0X,QAAQlK;AAAAA,4BACQb,cAAcF,KAAD;AAAA;AAAA;AAAA,8BAGX2K,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;kCAC3CF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;4BACrD,CAAC,aAAa,YAAd,EACX5Z,IAAIuV,cAAa,GAAEA,eADR,EAEXhN,KAAK,IAFM;AAAA;AAAA;AAAA;AAAA,oCAMQmR,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;;;;;kCAKjDF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,IAAzC,EAA+CC;;;IAGrEK,QAAQnK;AAAAA;AAAAA;AAAAA,kBAGF4J,YAAYzK,cAAcF,KAAD,CAAd,EAAuBmL,QAAQ,IAA1C,EAAgDN;kBAChDF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,GAAzC,EAA8CQ,SAAS,IAAvD,EAA6DP,IAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oBAgBjEF,YAAYzK,cAAcF,KAAD,CAAd,EAAuBmL,QAAQ,GAA1C,EAA+CN;oBAC/CF,YAAYzK,cAAcF,KAAD,CAAd,EAAuB4K,OAAO,GAAzC,EAA8CQ,SAAS,IAAvD,EAA6DP,IAAM;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAkB3EQ,QAAQtK;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,8BAYUb,cAAcF,KAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAc/BhH,EAAAA;AAAAA;AAEL,CAxKU;AAAA,IA0KbsS,aAAe;AAAA;AAmBbC,MAAAA,WAASlb,WAAqC,iBAClD,IAeAC,KACA;AAhBA,eACEY;AAAAA;AAAAA,IACAsD;AAAAA,IACAtC;AAAAA,IACA8G;AAAAA,IACAgR;AAAAA,IACAvI;AAAAA,IACAwI;AAAAA,IACAjK;AAAAA,IACAwL;AAAAA,IACAvN;AAAAA,IACA2F;AAAAA,IACA6H;AAAAA,MAZF,IAaKlb,wBAbL,IAaKA;AAAAA,IAZHW;AAAAA,IACAsD;AAAAA,IACAtC;AAAAA,IACA8G;AAAAA,IACAgR;AAAAA,IACAvI;AAAAA,IACAwI;AAAAA,IACAjK;AAAAA,IACAwL;AAAAA,IACAvN;AAAAA,IACA2F;AAAAA,IACA6H;AAAAA;AAMA,6BAAC1B,gBAAD,iCACMxZ,cADN;AAAA,IAEE;AAAA,IACA;AAAA,IACA,WAAW0V,GAAGyF,MAAQC,gBAAgB1N,OAAO,MAAR,CAAhB,GAAkCwN,SAA1C;AAAA,IAEb;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IAbF,UAeGjX,YAAY,OAAO,gBAAgBA;AAAAA,EAAAA,EAhBxC;AAmBD,CArCwB;AAyClB,6BAA2B+R,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkB0E,UAAQ;AAAA,IACvCjW,MAAM;AAAA,IACNwR,OAAO;AAAA,IACP7Q,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAELvS,UAAUuS,UAAgB;AAAA,QAAE6E,aAAa;AAAA,MAAA,CAA/B;AAAA,MACV1Z,MAAM6U,OAAW;AAAA,QACfK,cAAc;AAAA,UACZ9R,MAAM;AAAA,UACNgM,SAAS;AAAA,YACP0G,QAAQ;AAAA,YACRS,cAAc;AAAA,UAFP;AAAA,QAFG;AAAA,MAAA,CADV;AAAA,MASNzP,SAAS+N,iBAAuB;AAAA,QAC9BD,OAAO;AAAA,QACPU,kBAAkB;AAAA,QAClBtT,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAQ6F,OAAO;AAAA,QAAA,GACxB;AAAA,UAAE7F,OAAO;AAAA,UAAW6F,OAAO;AAAA,QAAA,GAC3B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAS6F,OAAO;AAAA,QAAA,GACzB;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,CAPnB;AAAA,QASTM,cAAc;AAAA,MAAA,CAZP;AAAA,MAcT4C,OAAOjD,yBAA+B;AAAA,QACpCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAQ7F,OAAO;AAAA,UAAQkG,MAAM;AAAA,QAAA,GACtC;AAAA,UAAEL,OAAO;AAAA,UAAW7F,OAAO;AAAA,UAAWkG,MAAM;AAAA,QAAA,GAC5C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,CAHnC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPT;AAAA,MASP3F,MAAMsF,yBAA+B;AAAA,QACnCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAS7F,OAAO;AAAA,UAASkG,MAAM;AAAA,QAAA,GACxC;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAS7F,OAAO;AAAA,UAASkG,MAAM;AAAA,QAAA,CAHjC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPV;AAAA,MASNpH,OAAO+G,gBAAsB,CAAC9Q,OAAOwR,WAAW;;AACxCzO,cAAAA,UAAU/C,MAAM+C;AACtB,cAAMuO,SAASsE,0BAAkC7S,SAASyO,MAAzB,MAAlBoE,mBAAoD5K,WAAU;AAEtE,eAAA;AAAA,UAAE2K,aAAa;AAAA,UAASrE;AAAAA,QAAAA;AAAAA,MAA/B,CAJK;AAAA,MAMP0C,WAAWlD,gBAAsB;AAAA,QAC/BD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFJ;AAAA,MAIXJ,WAAWzE,UAtDN;AAAA,MAuDL9I,OAAO8I,MAvDF;AAAA,MAwDLnD,QAAQmD,OAAA;AAAA,IAxDH;AAAA,EAAA,CAHF;AA8DR;ACvWM,MAAM,eAAe;AAAA,EAC1B,OAAO;AAAA,IACL,KAAK;AAAA,IACL,YAAY,EAAE,OAAO,KAAK,QAAQ,IAAI;AAAA,EACxC;AAAA,EACA,OAAO;AAAA,IACL,KAAK;AAAA,IACL,YAAY,EAAE,OAAO,KAAK,QAAQ,IAAI;AAAA,EACxC;AACF;AC+CA,mBAAmB+E,KAAwC;AAClD,SAAA,IAAIC,QAA0B,CAACC,SAASC,WAAW;AAClDC,UAAAA,QAAQ,IAAIC;AAEZC,UAAAA,SAAS,MAAMJ,QAAQE,KAAD;AAC5BA,UAAMG,UAAUJ;AAChBC,UAAMJ,MAAMA;AAAAA,EAAAA,CALP;AAOR;AAED,oBAAoB7N,OAAgC;AAClD,QAAMqO,aAAaC,QAAQC,KAAK/E,CAAUA,WAAAA,OAAOgF,YAAY,IAA1C;AACnB,QAAMC,YAAYJ,cAAcrO,SAAS4N,mBAAmB5N,OAAOqO,WAAWpb,EAAnB;AACrDyb,QAAAA,gBACJD,aAAa,QAAQA,UAAUzL,MAAMqG,SAAS,OAAO,UAAW,GAAEoF,UAAUzL,MAAMA;AAE7EsL,SAAAA,QAAQtb,IAAIwW,CAAU,WAAA;AACrBmF,UAAAA,WAAWf,mBAAmB5N,OAAOwJ,OAAOvW,EAAf;AAEnC,QAAI0b,YAAY,QAAQnF,OAAOgF,YAAY,QAAQG,SAAS3L,MAAMqG,SAAS;AAAa,aAAA;AAEhF,WAAA,eAAcG,OAAOgF,eAAepO,KAAKqJ,IAAID,OAAOgF,UAAUG,SAAS3L,MAAMA,KAAzC;AAAA,EAAA,CALvC,EAOJrL,OAAO,CAAC6L,SAA2CA,QAAQ,IAPvD,EAQJrL,OAAO,CAACyW,aAAaC,eAAgB,GAAEA,eAAeD,eAAeF,aARjE;AASR;AAED,MAAMI,iBAAiB7c,OAAOC,IAAIyS,WAAW;AAAA,EAC3CC,mBAAmBC,CAAAA,SACjB,CAAC,CAAC,UAAU,WAAW,UAAU,gBAAgB,aAAa,WAAW,YAAxE,EAAsFC,SACrFD,KAAKvP,UADN;AAFwC,CAAtB;AAAA;AAAA;AAAA,IAgBnByP,UAAY;AAAA,IACZI,WAAa;AAAA,IACbC,UAAY;AAAA,IACZJ,gBAAkB;AAAA,IAClBK,aAAe;AAAA,IACf1C,CAAAA,MACAC,cACE,CAACD,EAAEjM,OAAH,GACA,CAAC,CAACA,UAAU,OAAOoM;AAAAA,mBACNpM;AAAAA,OAHF;AAAA;AAQjB,MAAMqY,mBAAmB9c,OAAO+c;AAAAA;AAAAA;AAS1BC,MAAAA,iBAAiB7c,WAAW,gBAChC;AAAA,EACEa;AAAAA,EACA+M;AAAAA,EACA2F;AAAAA,EACAC;AAAAA,EACAzS;AAAAA,EACA0S;AAAAA,EACAC;AAAAA,EACAoJ;AAAAA,EACAjb;AAAAA,EACAyC;AAAAA,EACAqP;AAAAA,EACA4H,4BAAcwB,aAAalB;AAAAA,EAC3BT;AAAAA,GAEFnb,KACA;AACM+c,QAAAA,WAAWC,QAAQlc,IAAD;AAClByU,QAAAA,aAAaC,UAAUhC,MAAD;AACtBiC,QAAAA,gBAAgBC,aAAahC,SAAD;AAClC,QAAMuJ,WAAWF,sCAAU9L,aAAY8L,SAAS9L,YAAYqK,aAAYE;AACxE,QAAM0B,iBAAiBH,sCAAU9L,aAAY8L,qCAAUI,aAAa7B,aAAY6B;AAChF,QAAM,CAACC,oBAAoBC,yBAAyBjX,SAA4B,IAApB;AACtDkX,QAAAA,cAAcC;AAEpBlX,YAAU,MAAM;AACV6W,QAAAA;AAAgB;AAEhBM,QAAAA,YAAY;AAENP,cAAAA,QAAD,EACNQ,KAAK7B,CAAS,UAAA;AACT,UAAA,CAAC4B,WAAW;AACQ,8BAAA;AAAA,UAAE7P,OAAOiO,MAAM8B;AAAAA,UAAc7P,QAAQ+N,MAAM+B;AAAAA,QAAAA,CAA5C;AAAA,MACtB;AAAA,IAJL,CAAA,EAMGC,MAAMC,QAAQ5E,KANjB;AAQA,WAAO,MAAM;AACC,kBAAA;AAAA,IAAA;AAAA,EADd,GAGC,CAACiE,gBAAgBD,QAAjB,CAhBM;AAkBT,QAAME,aAAaD,0CAAkBE;AAErC,MAAI,CAACD;AAAmB,WAAA;AAExB,QAAMW,aAAa1C,MAAQC,gBAAgB1N,OAAQ,GAAEwP,WAAWxP,SAAtB,CAAhB;AAE1B,6BACG,gBAAD;AAAA,IACE,IAAI/L,OAAO2V,OAAO;AAAA,IAClB;AAAA,IACA;AAAA,IACA;AAAA,IACA,WAAW5B,GAAGwF,WAAW2C,UAAZ;AAAA,IACb;AAAA,IACA;AAAA,IACA;AAAA,IACA,QAAQvI;AAAAA,IACR;AAAA,IACA,WAAWE;AAAAA,IAEV6H,UAAAA,cACCnZ,oBAAC,kBAAD;AAAA,MAAkB,KAAK8Y;AAAAA,MAAU,KAAKJ;AAAAA,IAAAA,CAD5B,IAGV1Y,oBAAC,WAAD;AAAA,MACE,QAAO;AAAA,MACP,KAAK8Y;AAAAA,MACL,OAAOc,WAAWpQ,KAAD;AAAA,MACjB,KAAKkP;AAAAA,MACL,OAAOM,WAAWxP;AAAAA,MAClB,QAAQwP,WAAWtP;AAAAA,IAAAA,CANrB;AAAA,EAAA,CAjBN;AA4BD,CA9EgC;AAkF1B,6BAA2BoI,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBqG,gBAAgB;AAAA,IAC/C5X,MAAM;AAAA,IACNwR,OAAO;AAAA,IACP7Q,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL3V,MAAM2V,QAFD;AAAA,MAGLoG,SAASpG,UAAgB;AAAA,QAAED,OAAO;AAAA,MAAA,CAAzB;AAAA,MACT5U,MAAM6U,OAAW;AAAA,QAAED,OAAO;AAAA,MAAA,CAApB;AAAA,MACN7I,OAAO8I,MALF;AAAA,MAMLnD,QAAQmD,OANH;AAAA,MAOLlD,SAASkD,QAPJ;AAAA,MAQLjD,QAAQiD,OARH;AAAA,MASLhD,cAAcgD,aATT;AAAA,MAUL/C,WAAW+C,QAVN;AAAA,MAWLpS,SAASoS,kBAAA;AAAA,IAXJ;AAAA,EAAA,CAHF;AAiBR;AC9LD,MAAMuH,cAAc,MAClB7Z,oBAAA,OAAA;AAAA,EAAK,OAAM;AAAA,EAA6B,OAAM;AAAA,EAAK,QAAO;AAAA,EAAK,SAAQ;AAAA,EACrE,8BAAA,QAAA;AAAA,IACE,GAAE;AAAA,IACF,MAAK;AAAA,IACL,eAAc;AAAA,IACd,gBAAe;AAAA,IACf,aAAY;AAAA,EAAA,CALd;AADF,CADF;AAYA,MAAM8Z,eAAe,MACnB9Z,oBAAA,OAAA;AAAA,EAAK,OAAM;AAAA,EAA6B,OAAM;AAAA,EAAK,QAAO;AAAA,EAAK,SAAQ;AAAA,EACrE,8BAAA,QAAA;AAAA,IACE,GAAE;AAAA,IACF,MAAK;AAAA,IACL,eAAc;AAAA,IACd,gBAAe;AAAA,IACf,aAAY;AAAA,EAAA,CALd;AADF,CAAA;AAYF,MAAMgJ,cAAYvN,OAAOC;AAAAA;AAAAA;AAAAA;AA0BzB,MAAMqe,UAAUte,OAAOC,IAAIyS,WAAW;AAAA,EACpCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAD,EAAWC,SAASD,IAApB;AADQ,CAAtB;AAAA;AAAA;AAAA;AAAA,IAMZE,UAAY;AAAA;AAAA;AAAA;AAAA;AAAA;AAOhB,MAAMyL,QAAQve,OAAOC,IAAIyS,WAAW;AAAA,EAClCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,YAAD,EAAeC,SAASD,IAAxB;AADM,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAcVlC,CAAAA,MACAC,cACE,CAACD,EAAEzB,UAAH,GACA,CAAC,CAACA,aAAa;AAAA,EAAEc,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAqD6J,OAAO;AAA5D,OAAqEnJ;AAAAA,sBACpEb,cAAcf,UAAD;AAAA,OAHlB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAajB,MAAMuP,OAAOxe,OAAOC,IAAIyS,WAAW;AAAA,EACjCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,OAAD,EAAUC,SAASD,IAAnB;AADK,CAAtB;AAAA;AAAA;AAAA;AAAA,aAQA7M,CAAAA,UAAUA,MAAMsR,SAAS,SAAS;AAAA;AAAA;AAAA;AAAA,IAI3C3G,CAAAA,MACAC,cACE,CAACD,EAAEZ,KAAH,GACA,CAAC,CAACA,QAAQ;AAAA,EAAEC,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,iBAClEb,cAAcF,KAAD;AAAA,OAHb;AAAA;AAQjB,MAAM2O,QAAQze,OAAOkS,OAAOjS,GAAR,EAAayS,WAAW;AAAA,EAC1CC,mBAAmBC,UAAQ,CAAC,CAAC,YAAY,YAAb,EAA2BC,SAASD,IAApC;AADc,CAA9B;AAAA;AAAA,IAOVlC,CAAAA,MACAC,cACE,CAACD,EAAEgO,QAAH,GACA,CAAC,CAACA,WAAW,OAAO7N;AAAAA,sBACJ,MAAM6N;AAAAA,qBACP,MAAMA;AAAAA,qBACN,MAAMA;AAAAA,OALV;AAAA;AAAA,IASbhO,CAAAA,MAAKC,cAAc,CAACD,EAAE8C,UAAH,GAAgB,CAAC,CAACA,aAAa,cAAe;AAAA,EAAEA;AAAF,EAA/C;AAAA;AAGtB,MAAMmL,OAAO3e,OAAOkS,OAAOjS,GAAR,EAAayS,WAAW;AAAA,EACzCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,KAAD,EAAQC,SAASD,IAAjB;AADa,CAA9B;AAAA;AAAA;AAAA;AAAA,IAMTlC,CAAAA,MACAC,cACE,CAACD,EAAEkO,GAAH,GACA,CAAC,CAACA,MAAM;AAAA,EAAE7N,OAAO;AAAA,EAAGqG,MAAM;AAAlB,OAA8BvG;AAAAA,oBACvB,GAAE,CAAC+N,IAAI7N,QAAQ,IAAI6N,IAAIxH;AAAAA;AAAAA,cAE9BqH;AAAAA,uBACU,GAAEG,IAAI7N,QAAQ,IAAI6N,IAAIxH;AAAAA;AAAAA,OAN7B;AAAA;AAYjB,MAAMyH,SAAO7e,OAAOkS,OAAOjS,GAAR;AAAA;AAAA;AAAA;AAKnB,MAAM6e,WAAW9e,OAAOwe,IAAD,EAAO9L,WAAW;AAAA,EACvCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,UAAD,EAAaC,SAASD,IAAtB;AADW,CAAxB;AAAA,IAGblC,CAAAA,MACAC,cAAc,CAACD,EAAEvD,QAAH,GAAuB,CAAC,CAACA,WAAW,cAAc;AACtDA,UAAAA;AAAAA,SACD;AACI0D,aAAAA;AAAAA;AAAAA;AAAAA,SAGJ;AACIA,aAAAA;AAAAA;AAAAA;AAAAA;AAIAA,aAAAA;AAAAA;AAAAA;AAAAA;AAIZ,CAfY;AAAA;AAAA;AAAA,cAkBH0N;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAOd,MAAMQ,YAAY/e,OAAOwe,IAAD,EAAO9L,WAAW;AAAA,EACxCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,UAAD,EAAaC,SAASD,IAAtB;AADY,CAAxB;AAAA,IAGdlC,CAAAA,MACAC,cAAc,CAACD,EAAEvD,QAAH,GAAuB,CAAC,CAACA,WAAW,cAAc;AACtDA,UAAAA;AAAAA,SACD;AACI0D,aAAAA;AAAAA;AAAAA;AAAAA,SAGJ;AACIA,aAAAA;AAAAA;AAAAA;AAAAA;AAIAA,aAAAA;AAAAA;AAAAA;AAAAA;AAIZ,CAfY;AAAA;AAAA;AAAA,cAkBH0N;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAOd,MAAMS,WAAWhf,OAAOC;AAAAA;AAAAA;AAIxB,MAAMgf,OAAOjf,OAAOC,IAAIyS,WAAW;AAAA,EACjCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,OAAD,EAAUC,SAASD,IAAnB;AADK,CAAtB;AAAA,aAGA7M,CAAAA,UAAUA,MAAMsR,SAAS,SAAS;AAAA;AAAA;AAAA,IAG3C3G,CAAAA,MACAC,cACE,CAACD,EAAEZ,KAAH,GACA,CAAC,CAACA,QAAQ;AAAA,EAAEC,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,iBAClEb,cAAcF,KAAD;AAAA,OAHb;AAAA;AAQjB,MAAMoP,MAAMlf,OAAOC,IAAIyS,WAAW;AAAA,EAChCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAD,EAAWC,SAASD,IAApB;AADI,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,aAwBC7M,CAAAA,UAAUA,MAAMoZ,SAAS,KAAK;AAAA,cAC7BpZ,CAAAA,UAAUA,MAAMoZ,SAAS,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA,kDAKMpZ,CAAAA,UAAUA,MAAMoZ,SAAS,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,kDAM7BpZ,CAAAA,UAAUA,MAAMoZ,SAAS,IAAI;AAAA;AAAA;AAI/E,MAAMC,kBAAkB;AACxB,MAAMC,aAAa,CAACC,IAAYC,aAAqBD,KAAUC,KAAAA;AAEzDC,MAAAA,WAAWrf,WAAW,mBAC1B;AAAA,EACEsf,SAAS,CADX;AAAA,EAEE1R;AAAAA,EACA2F;AAAAA,EACAgL,UAAUgB;AAAAA,EACVjI,MAAMkI;AAAAA,EACNf;AAAAA,EACAgB;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC,WAAW;AAAA,EACXpW,QAAQ;AAAA,EACRqW;AAAAA,EACAC;AAAAA,GAEFjgB,KACA;AACM,QAAA,CAAC6V,OAAOqK,YAAY9Z,SAAS,CAAD;AAC5B+Z,QAAAA,QAAQxV,OAAO,CAAD;AACdyV,QAAAA,aAAaC,KAAK,GAAGhB,OAAOzJ,QAAQC,KAAnB;AACjByI,QAAAA,WAAW5W,cAAc4X,kBAAD,KAAwB;AAChDjI,QAAAA,OAAO3P,cAAc6X,cAAD,KAAoB;AAC9C,QAAMe,WAAWF,aAAa9B;AAC9B,QAAMiC,YAAYxS,KAAKyS,aAAa5K,SAAS0I,YAAYjH,OAAO,CAA9C;AACZoJ,QAAAA,YAAY1S,KAAKyS,KAAKJ,aAAa/I,IAAvB;AAClB,QAAMqJ,cAAcD,cAAc;AAC5BE,QAAAA,aAAaF,cAAcF,YAAY;AACvCK,QAAAA,WAAWnY,YACfoY,CAAgB,iBAAA;AACVA,QAAAA,iBAAiB;AAAG;AAElBC,UAAAA,YAAYD,eAAe9S,KAAKgT,IAAIF,YAAT;AAC3BG,UAAAA,YAAYF,YAAY,IAAIzB,OAAO4B,MAAMX,QAAb,IAAyBjB,OAAO4B,MAAM,GAAGb,UAAhB;AACrDc,UAAAA,WAAWJ,YAAY/S,KAAKqJ,IAAI4J,UAAUpL,QAAQyB,OAAOtJ,KAAKgT,IAAIF,YAAT,CAAlC;AAE7BX,aAASrK,QAAQqL,QAAT;AAAA,EAAA,GAEV,CAAC7B,QAAQxJ,OAAOuK,YAAYE,UAAUjJ,IAAtC,CAV0B;AAatB8J,QAAAA,YAAY7Y,aAAa;AAAA,IAAEhE,GAAG;AAAA,IAAGO,YAAY;AAAA,MAAEG,MAAM;AAAA,MAAUoc,WAAW;AAAA,IAA7B;AAAA,EAAA,CAArB;AACxBC,QAAAA,WAAWC,WACf;AAAA,IACEC,QAAQ,CAAC;AAAA,MAAEC,UAAU,CAACC;AAAAA,MAAKC,OAAO,CAACxC;AAAAA,MAAKC;AAAAA,UAAe;AACrDgC,gBAAUrY,MAAM;AAAA,QAAExE,GAAGmd;AAAAA,MAAAA,CAArB;AACMzW,YAAAA,UAAUiU,WAAWC,IAAIC,QAAL;AAAA,IAH9B;AAAA,IAKEwC,WAAW,MAAM;AACfR,gBAAUrY,MAAM;AAAA,QAAExE,GAAG;AAAA,MAAA,CAArB;AAEI6b,UAAAA,MAAMnV,UAAUgU;AAAiB4B,iBAAS,CAAD;AAAA,eACpCT,MAAMnV,UAAU,CAACgU;AAAiB4B,iBAAS,EAAD;AAAA,IACpD;AAAA,EAAA,GAEH;AAAA,IACEgB,MAAM;AAAA,MACJC,MAAM;AAAA,MACNC,QAAQ;AAAA,QAAE9U,MAAM;AAAA,QAAGC,OAAO;AAAA,MAFtB;AAAA,MAGJ8U,YAAY;AAAA,IAHR;AAAA,EAAA,CAdiB;AAsB3B1b,YAAU,MAAM;AACV,QAAA,CAAC0Z,YAAYzB,aAAa;AAAG4B,eAAS,CAAD;AAAA,EAAA,GACxC,CAACH,UAAUzB,QAAX,CAFM;AAITjY,YAAU,MAAM;AACd,QAAI,CAAC0Z;AAAU,aAAO,MAAM;AAAA,MAAA;AAEtBiC,UAAAA,aAAaC,YAAY,MAAOtB,aAAaT,SAAS,CAAD,IAAMU,SAAS,CAAD,GAAMjX,QAAQ,GAAzD;AAEvB,WAAA,MAAMuY,cAAcF,UAAD;AAAA,KACzB,CAACjC,UAAUpW,OAAOiX,UAAUD,UAA5B,CANM;AAQT,8BACG,SAAD;AAAA,IACE;AAAA,IACA,WAAWhL,GAAGhI,KAAD;AAAA,IACb;AAAA,IACA,UAAU;AAAA,IACV,WAAW5E,CAAK,MAAA;AACNA,cAAAA,EAAEC;AAAAA,aACH;AACH4X,mBAAS,CAAD;AACR;AAAA,aACG;AACHA,mBAAS,EAAD;AACR;AAAA;AAAA,IAZR;AAAA,IAAA,UAAA,CAiBEuB,qBAAChV,aAAD;AAAA,MAAA,UAAA,CACEhJ,oBAAC,UAAD;AAAA,QAAA,8BACGsa,QAAS4C,iCAAAA,SAAV,IAAUA;AAAAA,UAAY,SAASF;AAAAA,UAA/B,8BACG,MAAD;AAAA,YACE;AAAA,YACA,SAAS;AAAA,cAAE7c,GAAI,GAAE,CAAE,OAAMga,YAAY8B;AAAAA,YAFvC;AAAA,YAGE,YAAY;AAAA,cACV9b,GAAG;AAAA,gBACDU,MAAM;AAAA,gBACNC,MAAM,CAAC,OAAO,MAAM,MAAM,CAApB;AAAA,gBACN2E,UAAU;AAAA,cAHT;AAAA,YAJP;AAAA,YAAA,UAWGyV,OAAO1e,IAAI,CAAC;AAAA,cAAEgF,OAAOyc;AAAAA,cAAYpZ;AAAAA,sCAC/B,OAAD;AAAA,cACE,IAAIA;AAAAA,cAEJ,UAAUsW;AAAAA,cACV,YAAYE;AAAAA,cACZ,aAAazW,CAAKA,MAAAA,EAAE+P,eALtB;AAAA,cAME,SAAS/P,CAAK,MAAA;AACRoX,oBAAAA,MAAMnV,YAAY;AAAGjC,oBAAE+P,eAAF;AAAA,cAP7B;AAAA,cAAA,8BAUG+C,gBAAD;AAAA,gBACE,OAAO,CAAC;AAAA,kBAAEjL,UAAU;AAAA,kBAAWD,OAAO;AAAA,oBAAEA,OAAO;AAAA,oBAAKqG,MAAM;AAAA,kBAApB;AAAA,gBAAA,CAA/B;AAAA,gBACP,MAAMoL,WAAWthB;AAAAA,gBACjB,SAASshB,WAAWvF;AAAAA,gBACpB,MAAMuF,WAAWxgB;AAAAA,gBACjB,QAAQoe;AAAAA,gBACR,cAAcC;AAAAA,cAAAA,CANhB;AAAA,YAVF,GAEOjX,GAFP,CADD;AAAA,UAAA,CAXH;AAAA,QAAA,EADF;AAAA,MAAA,CAFJ,GAsCE7E,oBAAC,UAAD;AAAA,QACE,SAAS,MAAMyc,SAAS,EAAD;AAAA,QACvB,UAAUjB;AAAAA,QAEV,OAAOC;AAAAA,QACP,QAAQ,CAACF,cAAcgB;AAAAA,QALzB,8BAOG,OAAD;AAAA,UAAO,YAAYb;AAAAA,UAAnB,UACE1b,oBAAC,aAAD,EAAA;AAAA,QAAA,CADF;AAAA,MAAA,CA7CJ,GAiDEA,oBAAC,WAAD;AAAA,QACE,SAAS,MAAMyc,SAAS,CAAD;AAAA,QACvB,UAAUjB;AAAAA,QAEV,OAAOC;AAAAA,QACP,QAAQ,CAACF,cAAciB;AAAAA,QALzB,8BAOG,OAAD;AAAA,UAAO,YAAYd;AAAAA,UAAnB,UACE1b,oBAAC,cAAD,EAAA;AAAA,QAAA,CADF;AAAA,MAAA,CAxDJ,CAAA;AAAA,IAAA,CAjBF,GA+EEA,oBAAC,MAAD;AAAA,MAAM,OAAO2b;AAAAA,MAAU,QAAQ,CAACL;AAAAA,MAC7B4C,UAAAA,MAAMrf,KAAK;AAAA,QAAE4S,QAAQ2K;AAAAA,MAAAA,CAArB,EAAkC5f,IAAI,CAAC2hB,GAAGC,0BACxC,KAAD;AAAA,QAAa,QAAQA,MAAM9B;AAAAA,QAAW,SAAS,MAAMG,SAAS2B,IAAI9B,SAAL;AAAA,MAA7D,GAAU8B,CAAV,CADD;AAAA,IAAA,CAhFL,CAAA;AAAA,EAAA,CADF;AAuFD,CAvK0B;AA2KpB,6BAA2BtM,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkB6I,UAAU;AAAA,IACzCpa,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL4I,QAAQ5I,OAAa;AAAA,QACnBM,QAAQ,CACN;AAAA,UAAE/N,KAAKwZ,KAAP;AAAA,UAAe7c,OAAO,CAAA;AAAA,QAAA,GACtB;AAAA,UAAEqD,KAAKwZ,KAAP;AAAA,UAAe7c,OAAO,CAAA;AAAA,QAAA,GACtB;AAAA,UAAEqD,KAAKwZ,KAAP;AAAA,UAAe7c,OAAO,CAAA;AAAA,QAAA,CAHhB;AAAA,MAAA,CADF;AAAA,MAORgI,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OAbH;AAAA,MAcL6H,UAAU7H,iBAAuB9Q,CAAS,UAAA;;AACxC,cAAM0Z,SAAS1Z,MAAM0Z;AACfoD,cAAAA,eAAepD,uCAAQzJ,WAARyJ,YAAkB;AAEhC,eAAA;AAAA,UACL7I,OAAO;AAAA,UACPM,cAAc;AAAA,UACdM,KAAK;AAAA,UACLpJ,KAAKyU;AAAAA,UACLpL,MAAM;AAAA,QAAA;AAAA,MALR,CAJQ;AAAA,MAYVA,MAAMZ,iBAAuB,CAAC9Q,OAAOwR,WAAW;;AACxCmH,cAAAA,WAAW3Y,MAAM2Y;AACjBoE,cAAAA,gBAAgBnH,+BAAmB+C,UAAUnH,MAAX,MAAlBoE,mBAAsC5K,UAAtC4K,YAA+C;AAE9D,eAAA;AAAA,UACL/E,OAAO;AAAA,UACPM,cAAc;AAAA,UACdM,KAAK;AAAA,UACLpJ,KAAK0U;AAAAA,UACLrL,MAAM;AAAA,QAAA;AAAA,MALR,CAJI;AAAA,MAYNmI,gBAAgB/I,yBAA+B;AAAA,QAC7CD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAO7F,OAAO;AAAA,UAAckG,MAAM;AAAA,QAAA,GAC3C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAYkG,MAAM;AAAA,QAAA,CAHrC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPA;AAAA,MAShB0H,KAAK/H,KAAW;AAAA,QACdD,OAAO;AAAA,QACPa,MAAM;AAAA,QACNP,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAAlB;AAAA,MAAA,CAHX;AAAA,MAKL+I,UAAUtJ,WAAe;AAAA,QAAED,OAAO;AAAA,MAAA,CAAxB;AAAA,MACV7M,OAAO8M,SAAa9Q,CAAU,UAAA;AAAA,QAC5B6Q,OAAO;AAAA,QACPO,QAAQ;AAAA,QACRK,KAAK;AAAA,QACLC,MAAM;AAAA,QACNC,QAAQ;AAAA,QACRL,QAAQ,CAACtR,MAAMoa;AAAAA,MAAAA,EANV;AAAA,MAQPL,YAAYjJ,WAAe;AAAA,QAAEM,QAAQ;AAAA,QAAMP,OAAO;AAAA,MAAA,CAAtC;AAAA,MACZmJ,eAAelJ,yBAA+B9Q,CAAU,UAAA;AAAA,QACtD6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAW7F,OAAO;AAAA,UAAWkG,MAAM;AAAA,QAAA,CAHrC;AAAA,QAKTC,cAAc;AAAA,QACdG,QAAQtR,MAAM+Z,eAAe;AAAA,MAAA,EARhB;AAAA,MAUfE,YAAYnJ,gBAAsB9Q,CAAU,UAAA;AAAA,QAC1C6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAM+Z,eAAe;AAAA,MAAA,EAHnB;AAAA,MAKZG,iBAAiBpJ,gBAAsB9Q,CAAU,UAAA;AAAA,QAC/C6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAM+Z,eAAe;AAAA,MAAA,EAHd;AAAA,MAKjBD,UAAUhJ,WAAe;AAAA,QAAEM,QAAQ;AAAA,QAAMP,OAAO;AAAA,MAAA,CAAtC;AAAA,MACVsJ,UAAUrJ,gBAAsB9Q,CAAU,UAAA;AAAA,QACxC6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAM8Z,aAAa;AAAA,MAAA,EAHnB;AAAA,MAKVO,aAAavJ,OAxFR;AAAA,MAyFLwJ,mBAAmBxJ,aAAA;AAAA,IAzFd;AAAA,EAAA,CAJF;AAgGR;ACthBD,MAAMkM,UAAQ/iB,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAMrB,MAAM+iB,UAAQhjB,OAAOC;AAAAA;AAAAA;AAIrB,MAAMgjB,UAAUjjB,OAAOC;AAAAA;AAAAA;AAAAA;AAKvB,MAAMsN,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CACjB,SAAA,CAAC,CACC,UACA,WACA,QACA,SACA,OACA,cACA,cACA,eACA,cACA,WAVD,EAWCC,SAASD,IAXV;AAFmC,CAAtB;AAAA;AAAA,IA2BdE,UAAY;AAAA,IACZpC,CAAAA,MACAC,cAAc,CAACD,EAAEa,IAAH,GAAmB,CAAC,CAACA,OAAO,cAAc;AAC9CA,UAAAA;AAAAA,SACD;AACIV,aAAAA;AAAAA;AAAAA;AAAAA,cAGHmS;AAAAA;AAAAA;AAAAA;AAAAA,SAID;AACInS,aAAAA;AAAAA;AAAAA;AAAAA,cAGHmS;AAAAA;AAAAA;AAAAA;AAAAA;AAKGnS,aAAAA;AAAAA;AAAAA;AAAAA,cAGHmS;AAAAA;AAAAA;AAAAA;AAAAA;AAKT,CA3BY;AAAA;AAAA,IA6BbC;AAAAA,MACEvS,CAAAA,MACAC,cACE,CAACD,EAAEkO,GAAH,GACA,CAAC,CAACA,SAAS/N;AAAAA,sBACG+N,OAAO,OAAO,IAAK,GAAEA,IAAI7N,QAAQ,IAAI6N,IAAIxH;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,SAH5C;AAAA;AAAA;AAAA,IAgBf2L;AAAAA,MACErS,CAAAA,MACAC,cAAc,CAACD,EAAEoJ,KAAH,GAAoB,CAAC,CAACA,QAAQ,eAAe;AACjDA,UAAAA;AAAAA,SACD;AACIjJ,aAAAA;AAAAA;AAAAA;AAAAA,SAGJ;AACIA,aAAAA;AAAAA;AAAAA;AAAAA;AAIAA,aAAAA;AAAAA;AAAAA;AAAAA;AAIZ,CAfY;AAAA,MAgBbH,OACAC,cACE,CAACD,EAAE5H,SAAS4H,EAAEwS,YAAYxS,EAAEyS,aAAazS,EAAE0S,UAA3C,GACA,CAAC,CACCta,UAAU,UACVoa,aAAa;AAAA,EAAEnT,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,GACbmJ,cAAc;AAAA,EAAEpT,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAqD6J,OAAO;AAA5D,GACdoJ,aAAa,kBACT;AACIta,UAAAA;AAAAA,SACD;AACI+H,aAAAA;AAAAA,gCACWuS;AAAAA,yBACPpT,cAAcmT,WAAD;AAAA,8BACRnT,cAAckT,UAAD;AAAA;AAAA,SAE1B;AACIrS,aAAAA;AAAAA;AAAAA,yBAEIb,cAAcmT,WAAD;AAAA,gCACNC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gCAgBApT,cAAckT,UAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gCAYblT,cAAckT,UAAD;AAAA;AAAA;AAAA,SAG5B;AACIrS,aAAAA;AAAAA,gCACWuS;AAAAA,yBACPpT,cAAcmT,WAAD;AAAA;AAAA,oCAEFnT,cAAckT,UAAD;AAAA;AAAA,SAEhC;AACIrS,aAAAA;AAAAA;AAAAA,gCAEWuS;AAAAA,yBACPpT,cAAcmT,WAAD;AAAA,oCACFnT,cAAckT,UAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gCAejBlT,cAAckT,UAAD;AAAA;AAAA;AAAA;AAIxBrS,aAAAA;AAAAA,gCACWuS;AAAAA;AAAAA,yBAEPpT,cAAcmT,WAAD;AAAA;AAAA;AAAA;AAAA;AAK7B,CAzFU;AAAA;AAAA;AAAA,IA6FfH;AAAAA,MACEtS,CAAAA,MACAC,cACE,CAACD,EAAE2S,YAAY3S,EAAE4S,SAAjB,GACA,CAAC,CACCD,aAAa;AAAA,EAAEtT,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,GACbsJ,YAAY,kBACRzS;AAAAA,0BACYyS;AAAAA,mBACPtT,cAAcqT,UAAD;AAAA,SAPb;AAAA;AAAA;AAanB,MAAME,eAAe,CAACC,SAAoC;AACxD,MAAIA,QAAQ;AAAa,WAAA;AAAA,MAAEC,MAAM;AAAA,MAAGC,OAAO;AAAA,MAAGC,SAAS;AAAA,MAAGC,SAAS;AAAA,IAAA;AAE7DC,QAAAA,WAAW,IAAIC,KAAKN,IAAT,EAAeO,YAAYD,KAAKE;AAEjD,MAAIH,YAAY;AAAU,WAAA;AAAA,MAAEJ,MAAM;AAAA,MAAGC,OAAO;AAAA,MAAGC,SAAS;AAAA,MAAGC,SAAS;AAAA,IAAA;AAEhE9B,MAAAA,QAAQ3T,KAAKgT,IAAI0C,QAAT,IAAqB;AAE3BJ,QAAAA,OAAOtV,KAAK8V,MAAMnC,QAAQ,KAAnB;AACbA,WAAS2B,OAAO;AAEVC,QAAAA,QAAQvV,KAAK8V,MAAMnC,QAAQ,IAAnB,IAA2B;AACzCA,WAAS4B,QAAQ;AAEXC,QAAAA,UAAUxV,KAAK8V,MAAMnC,QAAQ,EAAnB,IAAyB;AACzCA,WAAS6B,UAAU;AAEnB,QAAMC,UAAUM,SAASC,OAAOrC,QAAQ,EAAT,GAAc,EAArB;AAEjB,SAAA;AAAA,IAAE2B;AAAAA,IAAMC;AAAAA,IAAOC;AAAAA,IAASC;AAAAA,EAAAA;AAChC;AAEKQ,MAAAA,YAAYjkB,WAAW,oBAC3B;AAAA,EACEa;AAAAA,EACA0S;AAAAA,EACA3F;AAAAA,EACAyV;AAAAA,EACA1a;AAAAA,EACAyI;AAAAA,EACAuI;AAAAA,EACA8E;AAAAA,EACAyE;AAAAA,EACAC;AAAAA,EACAH;AAAAA,EACAC;AAAAA,EACAF;AAAAA,EACAmB;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,GAEFpkB,KACA;AACA,QAAM,CAAC;AAAA,IAAEqjB;AAAAA,IAAMC;AAAAA,IAAOC;AAAAA,IAASC;AAAAA,KAAWa,gBAAgBje,SAAS+c,aAAaC,IAAD,CAAb;AAElE/c,YAAU,MAAM;AACD8c,iBAAAA,aAAaC,IAAD,CAAb;AAENpB,UAAAA,aAAaC,YAAY,MAAM;AACtBkB,mBAAAA,aAAaC,IAAD,CAAb;AAAA,OACX,GAF2B;AAIvB,WAAA,MAAMlB,cAAcF,UAAD;AAAA,EAAA,GACzB,CAACoB,IAAD,CARM;AAUT,8BACGjW,aAAD;AAAA,IACE;AAAA,IACA;AAAA,IACA,WAAWwI,GAAGhI,KAAD;AAAA,IACb;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IAbF,UAAA,CAeEwU,qBAAC,SAAD;AAAA,MAAA,UAAA,CACEhe,oBAACwe,SAAD;AAAA,QACE,8BAAA,QAAA;AAAA,UAAOU,UAAAA;AAAAA,QAAAA,CAAP;AAAA,MAAA,CAFJ,GAIElf,oBAACye,SAAD;AAAA,QAAA,UAAQqB,aAAa,OAAO,SAASA;AAAAA,MAAAA,CAJvC,CAAA;AAAA,IAAA,CAfF,GAqBE9B,qBAAC,SAAD;AAAA,MAAA,UAAA,CACEhe,oBAACwe,SAAD;AAAA,QACE,8BAAA,QAAA;AAAA,UAAOW,UAAAA;AAAAA,QAAAA,CAAP;AAAA,MAAA,CAFJ,GAIEnf,oBAACye,SAAD;AAAA,QAAA,UAAQsB,cAAc,OAAO,UAAUA;AAAAA,MAAAA,CAJzC,CAAA;AAAA,IAAA,CArBF,GA2BE/B,qBAAC,SAAD;AAAA,MAAA,UAAA,CACEhe,oBAACwe,SAAD;AAAA,QACE,8BAAA,QAAA;AAAA,UAAOY,UAAAA;AAAAA,QAAAA,CAAP;AAAA,MAAA,CAFJ,GAIEpf,oBAACye,SAAD;AAAA,QAAA,UAAQuB,gBAAgB,OAAO,YAAYA;AAAAA,MAAAA,CAJ7C,CAAA;AAAA,IAAA,CA3BF,GAiCEhC,qBAAC,SAAD;AAAA,MAAA,UAAA,CACEhe,oBAACwe,SAAD;AAAA,QACE,8BAAA,QAAA;AAAA,UAAOa,UAAAA;AAAAA,QAAAA,CAAP;AAAA,MAAA,CAFJ,GAIErf,oBAACye,SAAD;AAAA,QAAA,UAAQwB,gBAAgB,OAAO,YAAYA;AAAAA,MAAAA,CAJ7C,CAAA;AAAA,IAAA,CAjCF,CAAA;AAAA,EAAA,CADF;AA0CD,CA5E2B;AAgFrB,6BAA2BnO,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkByN,WAAW;AAAA,IAC1Chf,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL2M,MAAM3M,OAAW,MAAO;AAAA,QACtBM,QAAQ,IAAI2M,KAAKA,KAAKE,IAAL,IAAa,MAAO,KAAK,KAAK,KAAK,CAA5C,EAA+CU,YAA/C;AAAA,MAAA,EADJ;AAAA,MAGN5b,SAAS+N,yBAA+B;AAAA,QACtCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UACEL,OAAO;AAAA,UACP7F,OAAO;AAAA,UACPkG,MAAM;AAAA,QAAA,GAER;AAAA,UAAEL,OAAO;AAAA,UAAW7F,OAAO;AAAA,UAAWkG,MAAM;AAAA,QAAA,GAC5C;AAAA,UACEL,OAAO;AAAA,UACP7F,OAAO;AAAA,UACPkG,MAAM;AAAA,QAAA,GAER;AAAA,UAAEL,OAAO;AAAA,UAAS7F,OAAO;AAAA,UAASkG,MAAM;AAAA,QAAA,CAbjC;AAAA,QAeTC,cAAc;AAAA,MAAA,CAjBP;AAAA,MAmBT4C,OAAOjD,yBAA+B;AAAA,QACpCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAQ7F,OAAO;AAAA,UAAQkG,MAAM;AAAA,QAAA,GACtC;AAAA,UAAEL,OAAO;AAAA,UAAW7F,OAAO;AAAA,UAAWkG,MAAM;AAAA,QAAA,GAC5C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,CAHnC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPT;AAAA,MASP3F,MAAMsF,yBAA+B;AAAA,QACnCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAS7F,OAAO;AAAA,UAASkG,MAAM;AAAA,QAAA,GACxC;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAS7F,OAAO;AAAA,UAASkG,MAAM;AAAA,QAAA,CAHjC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPV;AAAA,MASN0H,KAAK/H,KAAW;AAAA,QACdM,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAIqG,MAAM;AAAA,UAAnB;AAAA,QAAA,CAA/B;AAAA,QACRR,OAAO;AAAA,QACPa,MAAM;AAAA,QACND,KAAK;AAAA,QACLpJ,KAAK;AAAA,QACL8I,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAAlB;AAAA,MAAA,CANX;AAAA,MAQLgM,YAAYvM,KAAW;AAAA,QAAED,OAAO;AAAA,MAAA,CAApB;AAAA,MACZuM,aAAatM,gBAAsB;AAAA,QACjCD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFF;AAAA,MAIbwH,YAAYrM,gBAAsB;AAAA,QAChCD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFH;AAAA,MAIZ4H,WAAWzM,KAAW;AAAA,QAAED,OAAO;AAAA,MAAA,CAApB;AAAA,MACXyM,YAAYxM,gBAAsB;AAAA,QAChCD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFH;AAAA,MAIZ3N,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OApEH;AAAA,MAqELwN,WAAWxN,UAAgB;AAAA,QAAED,OAAO;AAAA,QAAc8E,aAAa;AAAA,MAAA,CAApD;AAAA,MACX4I,YAAYzN,UAAgB;AAAA,QAAED,OAAO;AAAA,QAAe8E,aAAa;AAAA,MAAA,CAArD;AAAA,MACZ6I,cAAc1N,UAAgB;AAAA,QAC5BD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFD;AAAA,MAId8I,cAAc3N,UAAgB;AAAA,QAC5BD,OAAO;AAAA,QACP8E,aAAa;AAAA,MAAA,CAFD;AAAA,IA3ET;AAAA,EAAA,CAJF;AAqFR;AClaD,MAAMiJ,yBAAyB3kB,OAAOC,IAAIyS,WAAW;AAAA,EACnDC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAD,EAAWC,SAASD,IAApB;AADuB,CAAtB;AAAA;AAAA;AAAA,IAK3BE,UAAY;AAAA;AAGhB,MAAMvF,cAAYvN,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAQzB,MAAM2kB,OAAO5kB,OAAOC,IAAIyS,WAAW;AAAA,EACjCC,mBAAmBC,UAAQ,CAAC,CAAC,WAAW,SAAS,WAArB,EAAkCC,SAASD,IAA3C;AADK,CAAtB;AAAA,IAOTlC,CACAC,MAAAA,cACE,CAACD,EAAE5H,SAAS4H,EAAEmU,WAAWnU,EAAEZ,KAA3B,GACA,CAAC,CACChH,UAAU,SACV+b,YAAY;AAAA,EAAE9T,OAAO;AAAA,EAAGqG,MAAM;AAAlB,GACZtH,QAAQ;AAAA,EAAEC,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OACJ;AACIlR,UAAAA;AAAAA,SACD;AAAA,SACA;AAAA,SACA;AACI+H,aAAAA;AAAAA,qCACkBgU,aAAa,OAChC,QACC,GAAEA,UAAU9T,QAAQ8T,UAAUzN;AAAAA,qCACZtO;AAAAA,qCACAkH,cAAcF,KAAD;AAAA;AAAA,SAGnC;AACIe,aAAAA;AAAAA,wBACM,GAAEgU,UAAU9T,QAAQ8T,UAAUzN;AAAAA;AAAAA,kBAErC,CACA,SACApH,cAAc;AAAA,QAAED,QAAQD,MAAMC;AAAAA,QAAQiK,OAAO;AAAA,MAAhC,CAAA,GACbhK,cAAcF,KAAD,GACbE,cAAc;AAAA,QAAED,QAAQD,MAAMC;AAAAA,QAAQiK,OAAO;AAAA,MAAA,CAAhC,CAJb,EAKA1Q,KAAK,IALL;AAAA;AAAA;AAAA;AAWA,YAAA,IAAIwb,MAAO,mBAAkBhc,UAA7B;AAAA;AAEX,CApCU;AAAA;AAwCXic,MAAAA,UAAU5kB,WAAW,kBACzB;AAAA,EAAEa;AAAAA,EAAI8H;AAAAA,EAAS+b;AAAAA,EAAW/U;AAAAA,EAAO/B;AAAAA,EAAO2F;AAAAA,GACxCtT,KACA;AACA,6BACG,wBAAD;AAAA,IAAwB;AAAA,IAAU;AAAA,IAAQ,WAAW2V,GAAGhI,KAAD;AAAA,IAAS;AAAA,IAAhE,8BACGR,aAAD;AAAA,MAAA,8BAEG,MAAD;AAAA,QAAM;AAAA,QAAkB;AAAA,QAAsB;AAAA,MAAA,CAA9C;AAAA,IAAA,CAFF;AAAA,EAAA,CAFJ;AAQD,CAZyB;AAgBnB,6BAA2B8I,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBoO,SAAS;AAAA,IACxC3f,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL/N,SAAS+N,iBAAuB;AAAA,QAC9BD,OAAO;AAAA,QACPU,kBAAkB;AAAA,QAClBtT,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAS6F,OAAO;AAAA,QAAA,GACzB;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAW6F,OAAO;AAAA,QAAA,CAJpB;AAAA,QAMTM,cAAc;AAAA,MAAA,CATP;AAAA,MAWT2N,WAAWhO,iBAAuB;AAAA,QAChCD,OAAO;AAAA,QACPM,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAFA;AAAA,QAGhCpT,SAAS,CAAC;AAAA,UAAE+M,OAAO;AAAA,UAAM6F,OAAO;AAAA,UAAUK,MAAM;AAAA,QAAA,CAAvC;AAAA,MAAA,CAHA;AAAA,MAKXnH,OAAO+G,gBAAsB;AAAA,QAAE6E,aAAa;AAAA,MAAA,CAArC;AAAA,MACP3N,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OAAA;AAAA,IAvBH;AAAA,EAAA,CAJF;AA8BR;AC5HD,MAAMtJ,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAD,EAAWC,SAASD,IAApB;AADU,CAAtB;AAAA;AAAA,IAIdE,UAAY;AAAA;AAGhB,MAAMkS,cAAe;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAuBrB,MAAMC,eAAa;AAEbC,MAAAA,QAAQ/kB,WAAW,gBACvB;AAAA,EAAEa;AAAAA,EAAI+M;AAAAA,EAAO2F;AAAAA,EAAQyR,OAAOH;AAAAA,GAC5B5kB,KACA;AACA,QAAM,CAACsJ,WAAW0b,gBAAgB5e,SAAgC,IAAxB;AACpC,QAAA,CAAC6e,cAAcC,mBAAmB9e,SAAS,KAAD;AAEhD2E,4BAA0B,MAAM;AAC9Bma,oBAAgB,IAAD;AAAA,EADQ,GAEtB,CAFsB,CAAA;AAIzBjT,sBAAoBjS,KAAK,MAAMsJ,WAAW,CAACA,SAAD,CAAvB;AAEnBjD,YAAU,MAAM;AAGV,QAAA,CAACiD;AAAW;AAEhB,UAAM6b,SAAS7b,UAAUY,cAAckb,iBAAiB9b,WAAW+b,WAAWC,cAAc;AAAA,MAC1FC,WAAWC,MAAe;AACxB,eAAOA,KAAKC,QAAQC,kBAAkBb,eAClCQ,WAAWM,gBACXN,WAAWO;AAAAA,MAChB;AAAA,IAAA,CALY;AAQf,UAAMC,QAAmB,CAAA;AAEzB,WAAOV,OAAOW,SAAP;AAAyBC,YAAAA,KAAKZ,OAAOa;AAOL,2CAAA;AACrC,eAASzD,IAAI,GAAGA,IAAIsD,MAAMjQ,QAAQ2M,KAAK;AAC/B,cAAA,IAAI9G,QAAcC,CAAW,YAAA;;AACjC,gBAAM8J,OAAOK,MAAMtD;AACb0D,gBAAAA,SAAST,KAAKtb,cAAcgc,cAAcrB,YAAjC;AAEfoB,iBAAOE,cAAcX,KAAKW;AAC1B9D,gBAAMrf,KAAKwiB,KAAKY,UAAhB,EAA4BvjB,QAAQ,CAAC;AAAA,YAAEwjB;AAAAA,YAAM1V;AAAAA,gBAAY;AAChD2V,mBAAAA,aAAaD,MAAM1V,KAA1B;AAAA,UAAA,CADF;AAIOmL,iBAAAA,SAAS,MAAMJ;AACfK,iBAAAA,UAAU,MAAML;AAElB6K,qBAAAA,eAAAA,mBAAYC,aAAaP,QAAQT;AACjCe,qBAAAA,eAAAA,mBAAYE,YAAYjB;AAEzB,cAAA,CAACS,OAAOS,aAAa,KAApB;AAAmC;QAAA,CAfpC;AAAA,MAiBP;AAAA,IACF;AAEoB,0BAAA,EAAG9I,MAAM3E,CAAS,UAAA;AAErC4E,cAAQ5E,MAAMA,KAAd;AAAA,IAAA,CAFF;AAAA,EAAA,GAIC,CAAC3P,WAAWyb,IAAZ,CAhDM;AAkDT,MAAIE,iBAAiB;AAAc,WAAA;AAEnC,6BACG9X,aAAD;AAAA,IACE,KAAK6X;AAAAA,IACL;AAAA,IACA,WAAWrP,GAAGhI,KAAD;AAAA,IACb;AAAA,IACA,yBAAyB;AAAA,MAAEgZ,QAAQ5B;AAAAA,IAAV;AAAA,EAAA,CAN7B;AASD,CA1EuB;AA8EjB,6BAA2B9O,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBuO,OAAO;AAAA,IACtC9f,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAELsO,MAAMtO,WAAe;AAAA,QAAED,OAAO;AAAA,QAAQoQ,MAAM;AAAA,MAAA,CAAtC;AAAA,MACNjZ,OAAO8I,MAAY;AAAA,QAAEC,QAAQD,MAAYE,QAAQC;AAAAA,MAAAA,CAA1C;AAAA,MACPtD,QAAQmD,OAAA;AAAA,IAJH;AAAA,EAAA,CAJF;AAWR;AC7ID,IAAIoQ;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,aAAa,qBAAoB,OAAO;AAC1C,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,UAAU;AAAA,IACV,UAAU;AAAA,IACV,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACXa,MAAA,SAAS,OAAO,OAAO;AAAA,EAClC,QAAQ;AAAA,EACR,SAAS;AAAA,EACT,MAAM;AACR,CAAU;AAIG,MAAA,QAAQ,OAAO,OAAO;AAAA,EACjC,OAAO;AAAA,EACP,QAAQ;AAAA,EACR,OAAO;AACT,CAAU;AAIG,MAAA,YAAY,OAAO,OAAO;AAAA,EACrC,OAAO;AAAA,EACP,MAAM;AACR,CAAU;AAaV,MAAMpjB,YAAU,cAAqB,CAAA,CAAW;AAER,0BAAA;AACtC,SAAO,WAAWA,SAAO;AAC3B;AAEA,MAAM,EAAE,aAAaA;AC7Bd,yBAAuB,MAAoB;AACxC,UAAA;AAAA,SACD,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,sBAAsB,OAAO;AAAA;AAEnD;AAEO,kCAAkC,MAAoB;AACnD,UAAA;AAAA,SACD,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,sBAAsB,OAAO;AAAA;AAEnD;AAEA,gCAAgC,MAAoB;AAC1C,UAAA;AAAA,SACD,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA,SAEJ,MAAM;AACF,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,sBAAsB,OAAO;AAAA;AAEnD;AAEO,8BAA8B,OAAsB;AACjD,UAAA;AAAA,SACD,OAAO;AACH,aAAA;AAAA,SAEJ,OAAO;AACH,aAAA;AAAA,SAEJ,OAAO;AACH,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,uBAAuB,QAAQ;AAAA;AAErD;AAEO,gCAAgC,UAAoB,OAAyB;AAC1E,UAAA;AAAA,SACD,UAAU;AACb,aAAO,QAAQ,yBAAyB;AAAA,SAErC,UAAU;AACb,aAAO,QAAQ,yBAAyB;AAAA;AAGlC,YAAA,IAAI,MAAM,0BAA0B,WAAW;AAAA;AAE3D;AAEO,oCAAoC,UAA4B;AAC7D,UAAA;AAAA,SACD,UAAU;AACN,aAAA;AAAA,SAEJ,UAAU;AACN,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,0BAA0B,WAAW;AAAA;AAE3D;AAEO,4BAA0B,UAA4B;AACnD,UAAA;AAAA,SACD,UAAU;AACN,aAAA;AAAA,SAEJ,UAAU;AACN,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,0BAA0B,WAAW;AAAA;AAE3D;AAEA,qCAAqC,UAAoB;AAC/C,UAAA;AAAA,SACD,UAAU;AACN,aAAA;AAAA,SAEJ,UAAU;AACN,aAAA;AAAA;AAGD,YAAA,IAAI,MAAM,0BAA0B,WAAW;AAAA;AAE3D;AAEmC,oBAAA;AAC1B,SAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOH,CACA,UAAA,cACE,CAAC,MAAM,OAAO,MAAM,MAAM,MAAM,UAAU,MAAM,UAAU,GAC1D,CAAC;AAAA,IACC,QAAQ,OAAO;AAAA,IACf,OAAO,MAAM;AAAA,IACb,WAAW,UAAU;AAAA,IACrB,aAAa,EAAE,QAAQ,EAAE,KAAK,GAAG,YAAY,GAAG,WAAW,KAAK,OAAO,EAAE;AAAA,QACrE;AAAA,qBACO,uBAAuB,IAAI,OAAO,yBAAyB,IAAI;AAAA,2BACzD,qBAAqB,KAAK;AAAA,0BAC3B,uBAAuB,UAAU,MAAM,KAAK;AAAA,mBACnDsjB,mBAAiB,QAAQ;AAAA,8BACd,2BAA2B,QAAQ;AAAA;AAAA;AAAA;AAAA,4BAIrC,cAAc,UAAU;AAAA;AAAA;AAAA;AAAA,qBAI/B,4BAA4B,QAAQ;AAAA;AAAA,SAGnD;AAAA;AAEN;AC9JO,yBAAuB5V,MAAoB;AACxCA,UAAAA;AAAAA,SACD6V,MAAMC;AACF,aAAA;AAAA,SAEJD,MAAME;AACF,aAAA;AAAA,SAEJF,MAAMG;AACF,aAAA;AAAA;AAGD,YAAA,IAAIzC,MAAO,sBAAqBvT,OAAhC;AAAA;AAEX;AAED,MAAMiW,SAAOxnB,OAAOynB,MAAM/U,WAAW;AAAA,EACnCC,mBAAmB,CAACC,MAAM8U,qBACxB,CAAC,CAAC,SAAS,QAAQ,YAAY,cAAc,OAA5C,EAAqD7U,SAASD,KAAKvP,UAAnE,KACDqkB,iBAAiB9U,IAAD;AAHiB,CAAxB;AAAA,IAKT+U,SAAW;AAAA,IACX5hB,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,sBACX+W,gBAAcrW,IAAD;AAAA,sBACbqW,gBAAcrW,IAAD;AAAA,OAJlB;AAAA;AAajB,IAAA,UAAepR,WAAoC,eACjD,IACAC,KACA;AAFA,eAAEiZ;AAAAA,YAAQ;AAAA,IAAOwO;AAAAA,MAAjB,IAA0BxnB,wBAA1B,IAA0BA;AAAAA,IAAxBgZ;AAAAA,IAAewO;AAAAA;AAGX,QAAA;AAAA,IAAE/N;AAAAA,IAAOvI;AAAAA,IAAMuW;AAAAA,IAAUC;AAAAA,MAAeC,eAA9C;AAGE,6BAACR,QAAD,iCACMnnB,cADN;AAAA,IAEE;AAAA,IACA;AAAA,IACA;AAAA,IAEA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,EATJ;AAYD,CAlBwB;ACrCzB,MAAMkN,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,SAAS,QAAV,EAAoBC,SAASD,KAAKvP,UAAlC;AADU,CAAtB;AAAA;AAAA;AAAA,IAQdyP,UAAY;AAAA;AAGhB,MAAMkQ,UAAQhjB,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAUrB,MAAMgoB,UAAQjoB,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAUrB,MAAMob,SAASrb,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAatB,IAAA,gBAAeE,WAAW,sBACxB;AAAA,EAAEob;AAAAA,EAAW7H;AAAAA,GACbtT,KACa;AACb,8BACGmN,aAAD;AAAA,IAAW;AAAA,IAAU;AAAA,IAAsB;AAAA,IACzC,UAAA,CAAAgV,qBAAA,OAAA;AAAA,MAAK,OAAO;AAAA,QAAE2F,SAAS;AAAA,QAAQC,eAAe;AAAA,QAAU3S,cAAc;AAAA,MAAtE;AAAA,MAAA,UAAA,CACEjR,oBAACye,SAAD,CAAA,CAAA,GACCze,oBAAA0jB,SAFH,CAAA,CAAA,CAAA;AAAA,IAAA,CAAA,GAIA1F,qBAAA,OAAA;AAAA,MAAK,OAAO;AAAA,QAAE2F,SAAS;AAAA,QAAQC,eAAe;AAAA,QAAU3S,cAAc;AAAA,MAAtE;AAAA,MAAA,UAAA,CACEjR,oBAACye,SAAD,CAAA,CAAA,GACCze,oBAAA0jB,SAFH,CAAA,CAAA,CAAA;AAAA,IAAA,CAAA,GAIA1jB,oBAAA,OAAA;AAAA,MAAK,OAAO;AAAA,QAAE2jB,SAAS;AAAA,QAAQC,eAAe;AAAA,QAAUC,gBAAgB;AAAA,MAAxE;AAAA,MAAA,UACE7jB,oBAAC,QAAD,EAAA;AAAA,IAAA,CAVJ,CAAA;AAAA,EAAA,CADF;AAeD,CAnBwB;ACxClB,uBAAuBgN,MAAoB;AACxCA,UAAAA;AAAAA,SACD6V,MAAMC;AACF,aAAA;AAAA,SAEJD,MAAME;AACF,aAAA;AAAA,SAEJF,MAAMG;AACF,aAAA;AAAA;AAGD,YAAA,IAAIzC,MAAO,sBAAqBvT,OAAhC;AAAA;AAEX;AAED,0BAA0BuW,UAA4B;AAC5CA,UAAAA;AAAAA,SACDO,UAAUC;AACN,aAAA;AAAA,SAEJD,UAAUE;AACN,aAAA;AAAA;AAGD,YAAA,IAAIzD,MAAO,0BAAyBgD,WAApC;AAAA;AAEX;AAED,MAAMN,SAAOxnB,OAAO4W,MAAMlE,WAAW;AAAA,EACnCC,mBAAmB,CAACC,MAAM8U,qBACxB,CAAC,CAAC,YAAY,QAAQ,aAAa,WAAlC,EAA+C7U,SAASD,KAAKvP,UAA7D,KACDqkB,iBAAiB9U,IAAD;AAHiB,CAAxB;AAAA;AAAA;AAAA,IAYTwI,aAAe;AAAA,IACfrV,WACA4K,cACE,CAAC5K,MAAMwL,MAAMxL,MAAM+hB,UAAU/hB,MAAMgU,SAAnC,GACA,CAAC,CAACxI,OAAO6V,MAAME,QAAQQ,WAAWO,UAAUC,OAAOvO,eAAelJ;AAAAA,sBAClD+W,cAAcrW,IAAD;AAAA,iBAClBwI,aAAa,OAAOoN,iBAAiBW,QAAD,IAAa9X,cAAc+J,SAAD;AAAA,OAJ9D;AAAA;AAWjB,iBAA8BhU,OAA2B;AACjD,QAAA;AAAA,IAAE+hB;AAAAA,IAAUvW;AAAAA,IAAMiX;AAAAA,IAAgBC;AAAAA,MAAmBT,eAA3D;AAGE,6BAACR,QAAD,iCACMzhB,QADN;AAAA,IAEE;AAAA,IACA;AAAA,IACA,WAAWyiB;AAAAA,IACX,WAAWC;AAAAA,EAAAA,EANf;AASD;AC/DD,IAAA,2BAAetoB,WAAoC,mCACjD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAI6P;AAAAA,IAAMpN;AAAAA,IAAOqP,YAAY;AAAA,MAA3C,IAAqDroB,wBAArD,IAAqDA;AAAAA,IAAnDW;AAAAA,IAAI4V;AAAAA,IAAY6P;AAAAA,IAAMpN;AAAAA,IAAOqP;AAAAA;AAI7B,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC0jB,SAAD,iCACM5nB,cADN;AAAA,MAEE,cAAYuW;AAAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAK;AAAA,MACL,OAAOyC,SAAS;AAAA,IAAA,EATpB,CAAA;AAAA,EAAA,CADF;AAcD,CAlBwB;ACPzB,MAAMmO,OAAOxnB,OAAO2oB,SAASjW,WAAW;AAAA,EACtCC,mBAAmB,CAACC,MAAM8U,qBACxB,CAAC,CAAC,SAAS,SAAS,QAAQ,YAAY,YAAvC,EAAqD7U,SAASD,KAAKvP,UAAnE,KACDqkB,iBAAiB9U,IAAD;AAHoB,CAA3B;AAAA;AAAA,IAMT+U,SAAW;AAAA;AAOf,IAAA,WAAexnB,WAAuC,mBACpD,IACAC,KACA;AAFA,eAAEiZ;AAAAA,YAAQ;AAAA,IAAOwO;AAAAA,MAAjB,IAA0BxnB,wBAA1B,IAA0BA;AAAAA,IAAxBgZ;AAAAA,IAAewO;AAAAA;AAGX,QAAA;AAAA,IAAE/N;AAAAA,IAAOvI;AAAAA,IAAMuW;AAAAA,IAAUC;AAAAA,MAAeC,eAA9C;AAGE,6BAAC,MAAD,iCACM3nB,cADN;AAAA,IAEE;AAAA,IACA,MAAM;AAAA,IACN;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EAAA,EATJ;AAYD,CAlBwB;ACPzB,IAAA,qBAAeF,WAAuC,6BACpD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAIyC;AAAAA,IAAOqP,YAAY;AAAA,MAArC,IAA+CroB,wBAA/C,IAA+CA;AAAAA,IAA7CW;AAAAA,IAAI4V;AAAAA,IAAYyC;AAAAA,IAAOqP;AAAAA;AAIvB,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC,UAAD,iCAAclE,cAAd;AAAA,MAA2B,cAAYuW;AAAAA,MAAO;AAAA,MAAU;AAAA,MAAQ,OAAOyC,SAAS;AAAA,IAAA,EAFlF,CAAA;AAAA,EAAA,CADF;AAMD,CAVwB;ACIzB,6BAA2B;AAAA,EACzBtJ,QAAQ;AAAA,IAAEE,KAAK2Y;AAAAA,IAAG1Y,YAAY2Y;AAAAA,IAAG1Y,WAAW2Y;AAAAA;AAAAA,EAC5C9O,OAAO7T;AAAAA,GAIN;AACD,SAAO4iB,YAAM;AAAA,IAAEH;AAAAA,IAAGC;AAAAA,IAAGC;AAAAA,EAAAA,CAAT,EAAc9O,MAAM7T,CAAzB,EAA4B6iB,YAAY,uBAAuB;AACvE;AAED,MAAMzb,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,MAAD,EAASC,SAASD,IAAlB;AADU,CAAtB;AAAA;AAAA,IAId7M,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,kBACfoY,cAAQ1X,IAAD;AAAA,iBACR0X,cAAQ1X,IAAD;AAAA,OAJP;AAAA;AASjB,MAAM2X,eAAelpB,OAAOC,IAAIyS,WAAW;AAAA,EACzCC,mBAAmBC,UAAQ,CAAC,CAAC,YAAY,OAAb,EAAsBC,SAASD,IAA/B;AADa,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUjB7M,CAAAA,UACA4K,cACE,CAAC5K,MAAM+hB,QAAP,GACA,CAAC,CAACA,WAAWO,UAAUC,WAAWzX;AAAAA,wBAChBsY,uBAAuBrB,UAAU/hB,MAAMsT,KAAjB;AAAA,4BAClB+P,2BAA2BtB,QAAD;AAAA,OAJrC;AAAA;AASjB,MAAMuB,iBAAiBrpB,OAAOynB,MAAM/U,WAAW;AAAA,EAC7CC,mBAAmB,CAACC,MAAM8U,qBACxB,CAAC,CAAC,QAAQ,cAAc,YAAY,OAAnC,EAA4C7U,SAASD,IAArD,KAA8D8U,iBAAiB9U,IAAD;AAFpC,CAAxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAiBbsW;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gBAKMA;AAAAA,MACVnjB,WACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAAC;AAAA,EAAEhY,SAAS;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA/C;AAAA,EAAoD6J,QAAQ;AAAA,IAAM,CAAA,OAAQnJ;AAAAA,8BACtDb,cAAc;AAAA,EAAED;AAAAA,EAAQiK;AAAV,CAAD;AAAA,SAHxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAcXjU,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,4BACToY,cAAQ1X,IAAD,IAAS;AAAA;AAAA;AAAA,WAHvB;AAAA;AAAA,QASbxL,WACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAAC;AAAA,EAAEhY,SAAS;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA/C;AAAA,EAAoD6J,QAAQ;AAAA,IAAM,CAAA,OAAQnJ;AAAAA,4BAC1DyY,oBAAkB;AAAA,EAAEvZ;AAAAA,EAAQiK;AAAV,CAAD;AAAA,WAHxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,gBAWLkP;AAAAA,QACRnjB,CAAAA,UACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAACA,aAAa;AAAA,EAAEhY,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,4BAChEb,cAAc+X,UAAD;AAAA,WAHpB;AAAA;AAAA;AAAA;AAAA;AAAA,gBAULmB;AAAAA,QACRnjB,CAAAA,UACA4K,cACE,CAAC5K,MAAM+hB,QAAP,GACA,CAAC,CAACA,WAAWO,UAAUC,WAAWzX;AAAAA,4BAChBsY,uBAAuBrB,UAAU/hB,MAAMsT,KAAjB;AAAA,WAH7B;AAAA;AAAA;AAAA;AAmBrB,IAAA,WAAelZ,WAAoC,mBACjD,IACAC,KACA;AAFA,eAAEiZ;AAAAA;AAAAA,IAAOkC;AAAAA,IAAWtO;AAAAA,IAAO4a;AAAAA,MAA3B,IAAoCxnB,wBAApC,IAAoCA;AAAAA,IAAlCgZ;AAAAA,IAAOkC;AAAAA,IAAWtO;AAAAA,IAAO4a;AAAAA;AAGrB,QAAA;AAAA,IAAEtW;AAAAA,IAAMuW;AAAAA,IAAUC;AAAAA,MAAeC,eAAvC;AAEA,8BACGza,aAAD;AAAA,IAAW;AAAA,IACT,UAAA,CAAAhJ,oBAAC,gBAAD,iCACMlE,cADN;AAAA,MAEE,MAAK;AAAA,MACL;AAAA,MACA;AAAA,MAEA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,EATJ,GAWEkE,oBAAC,cAAD;AAAA,MAAc;AAAA,MAAsB;AAAA,MAAc;AAAA,MAAoB;AAAA,IAAA,CAXxE,CAAA;AAAA,EAAA,CADF;AAeD,CArBwB;AC/IzB,MAAMglB,gBAAcvpB,OAAOgjB,OAAD;AAAA;AAAA;AAAA;AAAA,IAItBjd,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,sBACX2Y,gBAAmBjY,IAAD;AAAA,sBAClBiY,gBAAmBjY,IAAD;AAAA,OAJvB;AAAA;AASjB,MAAMkY,sBAAoBzpB,OAAO0pB;AAAAA;AAAAA;AAejC,IAAA,qBAAevpB,WAAoC,6BACjD,IACAC,KACA;AAFA,eAAEynB;AAAAA;AAAAA,IAAM7mB;AAAAA,IAAIylB;AAAAA,IAAM7P,QAAQ;AAAA,IAAI7F,QAAQ;AAAA,IAAOsI;AAAAA,MAA7C,IAAuDhZ,wBAAvD,IAAuDA;AAAAA,IAArDwnB;AAAAA,IAAM7mB;AAAAA,IAAIylB;AAAAA,IAAM7P;AAAAA,IAAY7F;AAAAA,IAAesI;AAAAA;AAGvC,QAAA;AAAA,IAAE9H;AAAAA,MAASyW,eAAjB;AAES2B,wBAAa7Q,OAAyC;AAC7D+O,SAAK+B,cAAcnD,MAAM3N,MAAME,cAAc6Q,OAA7C;AAAA,EACD;AAED,8BACGN,eAAD;AAAA,IAAa,SAASvoB;AAAAA,IAAI;AAAA,IAA1B,UAAA,CACEuD,oBAACklB,qBAAD;AAAA,MACE,8BAAC,UAAD,iCACMppB,cADN;AAAA,QAEE,cAAYuW;AAAAA,QACZ,SAAS7F;AAAAA,QACT,UAAU4Y;AAAAA,QACV;AAAA,QACA;AAAA,QACA,OAAOtQ,SAAS;AAAA,MAAA,EAPlB;AAAA,IADF,CAAA,GAWCzC,KAZH;AAAA,EAAA,CADF;AAgBD,CA1BwB;ACjCzB,MAAMkT,YAAY9pB,OAAOgjB,OAAD;AAAA;AAAA;AAIxB,MAAMuG,gBAAcvpB,OAAOgjB,OAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAU1B,MAAMyG,oBAAoBzpB,OAAO0pB;AAAAA;AAAAA;AAmBjC,IAAA,2BAAevpB,WAQb,mCACA,IASAC,KACA;AAVA,eACE2pB;AAAAA;AAAAA,IACAnT,QAAQ;AAAA,IACRoT;AAAAA,IACAjZ,QAAQ,CAJV;AAAA,IAKEkZ;AAAAA,IACAvB,YAAY;AAAA,MANd,IAOKroB,wBAPL,IAOKA;AAAAA,IANH0pB;AAAAA,IACAnT;AAAAA,IACAoT;AAAAA,IACAjZ;AAAAA,IACAkZ;AAAAA,IACAvB;AAAAA;AAKIvW,QAAAA,SAASpH,OAAO;AAAA,IACpBmf,UAAU;AAAA,MAAEC,cAAcH,aAAa,QAAQjZ,MAAMiF,WAAW;AAAA,MAAGoU,cAAc;AAAA,IAAvE;AAAA,EAAA,CADS;AAIrB/X,sBAAoBjS,KAAK,MAAM+R,OAAO/G,SAAS,CAA5B,CAAA;AAEVue,wBAAa7Q,OAAyC;AAC7D3G,WAAO/G,QAAQ8e,SAASC,eACtBH,aAAa,QACb,CAAClR,MAAME,cAAc6Q,WACrB9Y,MAAMrL,OAAOuL,CAAKA,MAAAA,MAAM6H,MAAME,cAAcjI,KAA5C,EAAmDiF,WAAW;AAEhEiU,aAASnR,KAAD;AAAA,EACT;AAGC,8BAAA,OAAA;AAAA,IAAA,UAAA,CACG,CAAC4P,iCAAc,WAAD;AAAA,MAAY9R,UAAAA;AAAAA,IAAAA,CAD7B,GAEGmT,YAAY/lB,QAAQjD,IAAIspB,CAAAA,gCACtBd,eAAD;AAAA,MAA6B,SAASc,OAAOrpB;AAAAA,MAA7C,UAAA,CACEuD,oBAAC,mBAAD;AAAA,QACE,8BAAC,UAAD,iCACMlE,cADN;AAAA,UAEE,cAAYuW;AAAAA,UACZ,UAAU+S;AAAAA,UACV,SAAS5Y,MAAM8B,SAASwX,OAAO5D,IAAtB;AAAA,UACT,IAAI4D,OAAOrpB;AAAAA,UACX,OAAOqpB,OAAO5D;AAAAA,QAAAA,EANhB;AAAA,MAAA,CAFJ,GAWG4D,OAAO5D,IAXV;AAAA,IAAA,GAAkB4D,OAAOrpB,EAAzB,CADD,CAFH;AAAA,EAAA,CADF;AAoBD,CAvDwB;AC5BzB,2BAA2B;AAAA,EACzB+O,QAAQ;AAAA,IAAEE,KAAK2Y;AAAAA,IAAG1Y,YAAY2Y;AAAAA,IAAG1Y,WAAW2Y;AAAAA,MAAM;AAAA,IAAE7Y,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAD7D;AAAA,EAEzB6J,OAAO7T;AAAAA,GACM;AACb,SAAO4iB,YAAM;AAAA,IAAEH;AAAAA,IAAGC;AAAAA,IAAGC;AAAAA,EAAAA,CAAT,EAAc9O,MAAM7T,CAAzB,EAA4B6iB,YAAY,uBAAuB;AACvE;AAED,MAAMzb,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,UAAQ,CAAC,CAAC,MAAD,EAASC,SAASD,KAAKvP,UAAvB;AADU,CAAtB;AAAA;AAAA,IAId0C,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,kBACfoY,cAAQ1X,IAAD;AAAA,iBACR0X,cAAQ1X,IAAD;AAAA,OAJP;AAAA;AASjB,MAAM+Y,kBAAkBtqB,OAAOC,IAAIyS,WAAW;AAAA,EAC5CC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,YAAY,OAAb,EAAsBC,SAASD,KAAKvP,UAApC;AADgB,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUpB0C,CAAAA,UACA4K,cACE,CAAC5K,MAAM+hB,QAAP,GACA,CAAC,CAACA,WAAWO,UAAUC,WAAWzX;AAAAA,wBAChBsY,uBAAuBrB,UAAU/hB,MAAMsT,KAAjB;AAAA,4BAClB+P,2BAA2BtB,QAAD;AAAA,OAJrC;AAAA;AASjB,MAAMyC,oBAAoBvqB,OAAOynB,MAC9B/U,WAAW;AAAA,EACVC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,cAAc,YAAY,OAA3B,EAAoCC,SAASD,KAAKvP,UAAlD;AADlB,CADY,EAIvBmnB,MAAM;AAAA,EAAEplB,MAAM;AAAR,CAJiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,UAchBklB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,gBAKMA;AAAAA,MACVvkB,CAAAA,UACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAACA,aAAa;AAAA,EAAEhY,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,8BAC5Db,cAAc+X,UAAD;AAAA,SAHxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QAkBXhiB,CAAAA,UACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAACA,aAAa;AAAA,EAAEhY,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,gCAC5DyY,kBAAkBvB,UAAD;AAAA,WAH5B;AAAA;AAAA;AAAA;AAAA;AAAA,gBAULuC;AAAAA,QACRvkB,CAAAA,UACA4K,cACE,CAAC5K,MAAMgiB,UAAP,GACA,CAAC,CAACA,aAAa;AAAA,EAAEhY,QAAQ;AAAA,IAAEE,KAAK;AAAA,IAAGC,YAAY;AAAA,IAAGC,WAAW;AAAA,EAA9C;AAAA,EAAmD6J,OAAO;AAA1D,OAAmEnJ;AAAAA,4BAChEb,cAAc+X,UAAD;AAAA,WAHpB;AAAA;AAAA;AAAA;AAAA;AAAA,gBAULuC;AAAAA,QACRvkB,CAAAA,UACA4K,cACE,CAAC5K,MAAM+hB,QAAP,GACA,CAAC,CAACA,WAAWO,UAAUC,WAAWzX;AAAAA,4BAChBsY,uBAAuBrB,UAAU/hB,MAAMsT,KAAjB;AAAA,WAH7B;AAAA;AAAA;AAAA;AAmBrB,IAAA,cAAelZ,WAAoC,sBACjD,IACAC,KACA;AAFA,eAAEiZ;AAAAA;AAAAA,IAAOkC;AAAAA,IAAWtO;AAAAA,IAAO4a;AAAAA,MAA3B,IAAoCxnB,wBAApC,IAAoCA;AAAAA,IAAlCgZ;AAAAA,IAAOkC;AAAAA,IAAWtO;AAAAA,IAAO4a;AAAAA;AAGrB,QAAA;AAAA,IAAEtW;AAAAA,IAAMuW;AAAAA,IAAUC;AAAAA,MAAeC,eAAvC;AAEA,8BACGza,aAAD;AAAA,IAAW;AAAA,IACT,UAAA,CAAAhJ,oBAAC,mBAAD,iCACMlE,cADN;AAAA,MAEE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,EANJ,GAQEkE,oBAAC,iBAAD;AAAA,MAAiB;AAAA,MAAsB;AAAA,MAAc;AAAA,MAAoB;AAAA,IAAA,CAR3E,CAAA;AAAA,EAAA,CADF;AAYD,CAlBwB;ACjIzB,MAAMglB,cAAcvpB,OAAOgjB,OAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAU1B,MAAMyH,uBAAuBzqB,OAAO0pB;AAAAA;AAAAA;AAmBpC,IAAA,8BAAevpB,WAQb,sCACA,IASAC,KACA;AAVA,eACE2pB;AAAAA;AAAAA,IACAnT,QAAQ;AAAA,IACR7F,QAAQ;AAAA,IACRiZ,WAAW;AAAA,IACXtB,YAAY;AAAA,IACZuB;AAAAA,MANF,IAOK5pB,wBAPL,IAOKA;AAAAA,IANH0pB;AAAAA,IACAnT;AAAAA,IACA7F;AAAAA,IACAiZ;AAAAA,IACAtB;AAAAA,IACAuB;AAAAA;AAKI9X,QAAAA,SAASpH,OAAO;AAAA,IACpBmf,UAAU;AAAA,MAAEC,cAAcH,aAAa,QAAQjZ,UAAU;AAAA,MAAIqZ,cAAc;AAAA,IAAjE;AAAA,EAAA,CADS;AAIrB/X,sBAAoBjS,KAAK,MAAM+R,OAAO/G,SAAS,CAA5B,CAAA;AAEVue,wBAAa7Q,OAAyC;AAC7D3G,WAAO/G,QAAQ8e,SAASC,eAAeH,aAAa,QAAQ,CAAClR,MAAME,cAAc6Q;AAEjFI,aAASnR,KAAD;AAAA,EACT;AAGC,8BAAA,OAAA;AAAA,IAAA,UAAA,CACG,CAAC4P,iCAAc1F,SAAD;AAAA,MAAO,IAAG;AAAA,MAAKpM,UAAAA;AAAAA,IAAAA,CADhC,GAEGmT,YAAY/lB,QAAQjD,IAAIspB,CAAAA,gCACtB,aAAD;AAAA,MAA6B,SAASA,OAAOrpB;AAAAA,MAAI,cAAY4V;AAAAA,MAA7D,UAAA,CACErS,oBAAC,sBAAD;AAAA,QACE,8BAAC,aAAD,iCACMlE,cADN;AAAA,UAEE,UAAUspB;AAAAA,UACV,SAAS5Y,UAAUsZ,OAAO5D;AAAAA,UAC1B,IAAI4D,OAAOrpB;AAAAA,UACX,OAAOqpB,OAAO5D;AAAAA,QAAAA,EALhB;AAAA,MAAA,CAFJ,GAUG4D,OAAO5D,IAVV;AAAA,IAAA,GAAkB4D,OAAOrpB,EAAzB,CADD,CAFH;AAAA,EAAA,CADF;AAmBD,CAnDwB;ACvBzB,MAAMuM,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAAA,SACjB,CAAC,CAAC,SAAS,SAAS,QAAQ,YAAY,YAAvC,EAAqDC,SAASD,KAAKvP,UAAnE;AAFmC,CAAtB;AAAA,IAIdskB,SAAW;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAYX5hB,CACA4K,UAAAA,cACE,CAAC5K,MAAMwL,MAAMxL,MAAM+hB,QAAnB,GACA,CAAC,CAACvW,OAAO6V,MAAME,QAAQQ,WAAWO,UAAUC,WAAWzX;AAAAA,sBACvC+W,gBAAcrW,IAAD;AAAA,sBACbqW,gBAAcrW,IAAD;AAAA;AAAA;AAAA;AAAA;AAAA,mBAKhBmZ,yBAAyBnZ,IAAD;AAAA;AAAA;AAAA;AAAA,8BAIb4V,mBAAiBW,QAAD;AAAA;AAAA,OAb7B;AAAA;AAmBjB,MAAM6C,SAAS3qB,OAAO4qB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AA0BtB,IAAA,0BAAezqB,WAAqC,kCAClD,IAUAC,KACA;AAXA,eACEY;AAAAA;AAAAA,IACA+oB;AAAAA,IACAhZ,QAAQ;AAAA,IACR6F,QAAQ;AAAA,IACRyC,QAAQ;AAAA,IACRqP,YAAY;AAAA,IACZb;AAAAA,MAPF,IAQKxnB,wBARL,IAQKA;AAAAA,IAPHW;AAAAA,IACA+oB;AAAAA,IACAhZ;AAAAA,IACA6F;AAAAA,IACAyC;AAAAA,IACAqP;AAAAA,IACAb;AAAAA;AAKI,QAAA;AAAA,IAAE/N;AAAAA,IAAOvI;AAAAA,IAAMuW;AAAAA,IAAUC;AAAAA,MAAeC,eAA9C;AAGE,8BAAAlZ,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CADtC,GAEE2L,qBAAChV,aAAD;AAAA,MACE;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MAEA,UAAA,CAAAhJ,oBAAA,QAAA;AAAA,QAAA,UAAOwM,UAAU,KAAK,MAAMA;AAAAA,MAAAA,CAA5B,GACAwR,qBAAC,QAAD,iCAAYliB,cAAZ;AAAA,QAAyB,cAAYuW;AAAAA,QAAO;AAAA,QAAU;AAAA,QAAQ;AAAA,QAC5D,UAAA,CAAArS,oBAAA,UAAA;AAAA,UAAQ,OAAM;AAAA,UAAd,UAAA;AAAA,QAAA,CADF,GAEGwlB,YAAY/lB,QAAQjD,IAAIspB,CAAAA,+BACvB,UAAA;AAAA,UAAwB,OAAOA,OAAO5D;AAAAA,UAAtC,UACG4D,OAAO5D;AAAAA,QAAAA,GADG4D,OAAOrpB,EAApB,CADD,CAFH;AAAA,MAAA,EARF,CAAA;AAAA,IAAA,CAFF,CAAA;AAAA,EAAA,CADF;AAsBD,CArCwB;ACrDzB,IAAA,yBAAeb,WAQb,iCAAgC,IAAiCC,KAAK;AAAtC,eAAEgF;AAAAA;AAAAA,MAAF,IAAW/E,wBAAX,IAAWA;AAAAA,IAAT+E;AAAAA;AAC3BA,SAAAA,SAAS,WAEbb,oBAAA,0DAA4BlE;IAAa;AAAA,EAAA,EAA1C,IAEAkE,oBAAC,6BAAD,iCAAiClE,cAAjC;AAAA,IAA8C;AAAA,EAAA,EAJhD;AAMD,CAfwB;ACRzB,IAAA,wBAAeF,WAAoC,gCACjD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAI6P;AAAAA,IAAMpN;AAAAA,IAAOqP,YAAY;AAAA,MAA3C,IAAqDroB,wBAArD,IAAqDA;AAAAA,IAAnDW;AAAAA,IAAI4V;AAAAA,IAAY6P;AAAAA,IAAMpN;AAAAA,IAAOqP;AAAAA;AAI7B,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC0jB,SAAD,iCACM5nB,cADN;AAAA,MAEE,cAAYuW;AAAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAK;AAAA,MACL,OAAOyC,SAAS;AAAA,IAAA,EATpB,CAAA;AAAA,EAAA,CADF;AAcD,CAlBwB;ACAzB,IAAA,kBAAelZ,WAAoC,0BACjD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAI6P;AAAAA,IAAMpN;AAAAA,IAAOqP,YAAY;AAAA,MAA3C,IAAqDroB,wBAArD,IAAqDA;AAAAA,IAAnDW;AAAAA,IAAI4V;AAAAA,IAAY6P;AAAAA,IAAMpN;AAAAA,IAAOqP;AAAAA;AAI7B,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC0jB,SAAD,iCACM5nB,cADN;AAAA,MAEE,cAAYuW;AAAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAK;AAAA,MACL,OAAOyC,SAAS;AAAA,IAAA,EATpB,CAAA;AAAA,EAAA,CADF;AAcD,CAlBwB;ACAzB,IAAA,gBAAelZ,WAAoC,wBACjD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAI6P;AAAAA,IAAMpN;AAAAA,IAAOqP,YAAY;AAAA,MAA3C,IAAqDroB,wBAArD,IAAqDA;AAAAA,IAAnDW;AAAAA,IAAI4V;AAAAA,IAAY6P;AAAAA,IAAMpN;AAAAA,IAAOqP;AAAAA;AAI7B,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC0jB,SAAD,iCACM5nB,cADN;AAAA,MAEE,cAAYuW;AAAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAK;AAAA,MACL,OAAOyC,SAAS;AAAA,IAAA,EATpB,CAAA;AAAA,EAAA,CADF;AAcD,CAlBwB;ACAzB,IAAA,mBAAelZ,WAAoC,2BACjD,IACAC,KACA;AAFA,eAAEY;AAAAA;AAAAA,IAAI4V,QAAQ;AAAA,IAAI6P;AAAAA,IAAMpN;AAAAA,IAAOqP,YAAY;AAAA,MAA3C,IAAqDroB,wBAArD,IAAqDA;AAAAA,IAAnDW;AAAAA,IAAI4V;AAAAA,IAAY6P;AAAAA,IAAMpN;AAAAA,IAAOqP;AAAAA;AAI7B,8BAAA5Z,UAAA;AAAA,IAAA,UAAA,CACG,CAAC4Z,iCAAc1F,SAAD;AAAA,MAAO,SAAShiB;AAAAA,MAAK4V,UAAAA;AAAAA,IAAAA,CAArB,GACfrS,oBAAC0jB,SAAD,iCACM5nB,cADN;AAAA,MAEE,cAAYuW;AAAAA,MACZ;AAAA,MACA;AAAA,MACA;AAAA,MACA,MAAK;AAAA,MACL,OAAOyC,SAAS;AAAA,IAAA,EATpB,CAAA;AAAA,EAAA,CADF;AAcD,CAlBwB;ACLzB,MAAM2J,QAAQhjB,OAAOC,IAAIyS,WAAW;AAAA,EAClCC,mBAAmBC,UAAQ,CAAC,CAAC,MAAD,EAASC,SAASD,KAAKvP,UAAvB;AADM,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASV0C,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,8BACHga,cAAmBtZ,IAAD;AAAA,sBAC1B,MAAMsZ,cAAmBtZ,IAAD;AAAA,sBACxB,MAAMsZ,cAAmBtZ,IAAD;AAAA,OAL7B;AAAA;AAUjB,MAAM0W,SAAQjoB,OAAOC,IAAIyS,WAAW;AAAA,EAClCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,SAAS,MAAV,EAAkBC,SAASD,KAAKvP,UAAhC;AADM,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IASV0C,CACA4K,UAAAA,cACE,CAAC5K,MAAM+T,OAAO/T,MAAMwL,IAApB,GACA,CAAC,CAACuI,QAAQgR,OAAOC,SAASxZ,OAAO6V,MAAME,YAAYzW;AAAAA,sBACnC2Y,gBAAmBjY,IAAD;AAAA,sBAClBiY,gBAAmBjY,IAAD;AAAA,yBACfyZ,qBAAqBlR,KAAD;AAAA,OAL5B;AAAA;AAU4C,iCAAA;AACrD,QAAA;AAAA,IAAEvI;AAAAA,IAAMuI;AAAAA,MAAUkO,eAAxB;AAGE,8BAAAlZ,UAAA;AAAA,IAAA,UAAA,CACEvK,oBAAC,OAAD;AAAA,MAAO;AAAA,IAAA,CADT,GAEEA,oBAAC,QAAD;AAAA,MAAO;AAAA,MAAc;AAAA,IAAA,CAFvB,CAAA;AAAA,EAAA,CADF;AAMD;AC1CD,qCAAqCwlB,aAA6CnT,OAAe;AACtFmT,UAAAA,gBAAe,CAAA,GAAI9oB;AAAAA,SACrB;AACK,aAAA,GAAE2V;AAAAA,SAEP;AACK,aAAA,GAAEA;AAAAA,SAEP;AACK,aAAA,GAAEA;AAAAA,SAEP;AACK,aAAA,GAAEA;AAAAA,SAEP;AAAA,SACA;AAAA,SACA;AAAA;AAEK,aAAA,GAAEA;AAAAA;AAEf;AAED,6BAA6BmT,aAA6C;AAC/DA,UAAAA,gBAAe,CAAA,GAAI9oB;AAAAA,SACrB;AACIgqB,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA,SAEJ;AACIC,aAAAA;AAAAA;AAGAR,aAAAA;AAAAA;AAEZ;AAkB6B,eAAA;AAAA,EAC5BlB;AAAAA,EACA2B,gBAAgB;AAAA,IACd1qB;AAAAA,IACA4V,QAAQ;AAAA,IACR8E;AAAAA,IACAsO,WAAW;AAAA,IACX3S,SAAS;AAAA,IACTjS,OAAO;AAAA,IACPsjB,YAAY;AAAA;AAAA,GAEO;AACfiD,QAAAA,mBAAmBC,oBAAoB7B,WAAD;AACtCtC,QAAAA,QAAQ1c,OASZ,IATkB;AAWpB,MAAI,CAACgf;AAAoB,WAAAxlB,oBAAC,uBAAR,CAAA,CAAA;AAEE,sBAAA;AACdsnB,QAAAA;AAEApE,QAAAA,MAAMrc,SAAS;AACX,YAAA;AAAA,QAAE8e,WAAW,CAAA;AAAA,UAAwBzC,MAAMrc;AAE7C8e,UAAAA,SAASC;AAAc0B,uBAAgB,GAAEjV;AAEzCsT,UAAAA,SAASE;AAA6B0B,uBAAAA,4BAA4B/B,aAAanT,KAAd;AAAA,IACtE;AAEMiV,WAAAA;AAAAA,EACR;AAED,6BACGE,SAAD;AAAA,IAAa,MAAMhC,YAAYtD;AAAAA,IAAM;AAAA,IAArC,UACG,CAAC;AAAA,MAAEuF;AAAAA,MAAOnE;AAAAA,UACTxQ,uEACa2U;MAAO,KAAKvE;AAAAA,MAAO,MAAK;AAAA,IAAA,EAAnC,IAEAljB,oBAAC,kBAAD,iCACMynB,QADN;AAAA,MAEE;AAAA,MACA;AAAA,MACA;AAAA,MACA,KAAKvE;AAAAA,MACL;AAAA,MACA,OAAOwE,MAAMpE,KAAKqE,SAASF,MAAMvF,IAArB,KAA8BwF,MAAMpE,KAAKsE,QAAQH,MAAMvF,IAApB;AAAA,MAC/C;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IAAA,EAXF;AAAA,EAAA,CANR;AAuBD;ACtJD,IAAI;AAEJ,sBAAoB;AAAES,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,eAAe,uBAAsB,OAAO;AAC9C,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,EACZ,GAAK,KAAK,GAAG,MAAO,MAAkB,sBAAM,cAAc,KAAK;AAAA,IAC3D,MAAM;AAAA,IACN,aAAa;AAAA,IACb,WAAW;AAAA,EACf,GAAkB,sBAAM,cAAc,UAAU;AAAA,IAC5C,QAAQ;AAAA,IACR,IAAI;AAAA,IACJ,IAAI;AAAA,IACJ,GAAG;AAAA,IACH,eAAe;AAAA,EACnB,CAAG,GAAgB,sBAAM,cAAc,QAAQ;AAAA,IAC3C,eAAe;AAAA,IACf,GAAG;AAAA,EACP,CAAG,CAAC,EAAE;AACN;ACrBA,MAAMkF,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AASb,MAAMC,OAAOtsB,OAAOusB,YAAD;AAAA;AAAA,eAEJH;AAAAA;AAAAA;AAIgC,mBAAA;AACtC,SAAA7nB,oBAAC,MAAR,CAAA,CAAA;AACD;ACfC,+BAAA,gBACA,EAAE,eAIF;AACA,QAAM,CAAC,WAAW,gBAAgB,SAAyC,IAAI;AACzE,QAAA,CAAC,OAAO,YAAY,SACxB,MAAM,cAAc,CAAC,EAAE,KAAK,IAAI,CAClC;AAEA,QAAM,cAAc;AAEpB,YAAU,MAAM;AACd,QAAI,CAAC;AAAa;AAEd,QAAA,uBAAuB,sBAAsB,2BAA2B;AAE5E,WAAO,MAAM;AACX,2BAAqB,oBAAoB;AAAA,IAAA;AAGJ,2CAAA;AACrC,UAAI,kBAAkB;AAAM;AAE5B,UAAI,aAAa;AAAM,uBAAe,sBAAsB,EAAE,QAAQ,OAAO,SAAS,GAAG;AAEnF,YAAA,IAAI,CAAC,MAAM,UAAU;AACzB,YAAI,QAAQ;AAAM;AAElB,uBAAe,2BAA2B,EAAE,OAAO,QAAQ,OAAO,IAAI,GAAG;AAAA,MAAA,CAC1E;AAED,6BAAuB,sBAAsB,2BAA2B;AAAA,IAC1E;AAAA,KACC,CAAC,gBAAgB,WAAW,OAAO,WAAW,CAAC;AAElD,QAAM,WAAW,QACf,MACE,MAAM,KAAK,EAAE,QAAQ,cAAc,EAAG,CAAA,EAAE,IACtC,CAAC,GAAG,UAAU,CAAC,SAAyC;AACtD,aAAS,CAAM,QAAA,CAAC,GAAG,IAAG,MAAM,GAAG,KAAK,GAAG,MAAM,GAAG,IAAG,MAAM,QAAQ,CAAC,CAAC,CAAC;AAAA,EAExE,CAAA,GACF,CAAC,aAAa,QAAQ,CACxB;AAEA,SAAO,EAAE,WAAW,cAAc,OAAO,SAAS;AACpD;ACKA,MAAMioB,0BAA0B;AAEhC,yBAAyBjb,MAAoB;AACnCA,UAAAA;AAAAA,SACD6V,MAAMC;AACF,aAAA;AAAA,SAEJD,MAAME;AACF,aAAA;AAAA,SAEJF,MAAMG;AACF,aAAA;AAAA;AAGD,YAAA,IAAIzC,MAAO,sBAAqBvT,OAAhC;AAAA;AAEX;AAEM,MAAMkb,aAAa;AAAA,EACxBC,MAAM;AAAA,EACNC,QAAQ;AAAA,EACRC,OAAO;AAHiB;AAgC1B,MAAMC,WAAW7sB,OAAO6nB,KAAKnV,WAAW;AAAA,EACtCC,mBAAmBC,UAAQ,CAAC,CAAC,QAAQ,SAAS,QAAlB,EAA4BC,SAASD,IAArC;AADU,CAAvB;AAAA;AAAA;AAAA;AAAA,IASb7M,CAAAA,UACA4K,cACE,CAAC5K,MAAMwL,IAAP,GACA,CAAC,CAACA,OAAO6V,MAAME,YAAYzW;AAAAA,qBACZic,gBAAgBvb,IAAD;AAAA,OAHnB;AAAA,IAMbuB,UAAY;AAAA;AAGhB,MAAMQ,aAAWtT,OAAOC,IAAIyS,WAAW;AAAA,EACrCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,QAAQ,SAAS,UAAU,WAA5B,EAAyCC,SAASD,IAAlD;AADS,CAAtB;AAAA;AAAA;AAAA,IAKbW,YAAc;AAAA;AAGlB,4BAA4BwZ,WAA8B;AAChDA,UAAAA;AAAAA,SACDN,WAAWC;AACP,aAAA;AAAA,SACJD,WAAWG;AACP,aAAA;AAAA;AAEA,aAAA;AAAA;AAEZ;AAED,MAAM/S,eAAe7Z,OAAO,CAAC+F,8BAC1BsV,2CAAWtV;EAAO,IAAG;AAAtB,EADyB,CAAA,EAExB2M,WAAW;AAAA,EACZC,mBAAmBC,UAAQ,CAAC,CAAC,WAAD,EAAcC,SAASD,KAAKvP,UAA5B;AADhB,CAFO;AAAA;AAAA;AAAA;AAAA,IAWjB0C,CACA4K,UAAAA,cACE,CAAC5K,MAAMwL,MAAMxL,MAAMgnB,SAAnB,GACA,CAAC,CAACxb,OAAO6V,MAAME,QAAQyF,YAAYN,WAAWE,YAAY9b;AAAAA,sBAC1C2Y,gBAAmBjY,IAAD;AAAA,sBAClBiY,gBAAmBjY,IAAD;AAAA,kBACtByb,mBAAmBD,SAAD;AAAA;AAAA;AAAA,OALnB;AAAA;AAYjB,MAAME,iBAAiBjtB,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAO9B,MAAMitB,gBAAgBltB,OAAOC;AAAAA;AAAAA;AAI7B,MAAMktB,eAAentB,OAAO0Q;AAAAA;AAAAA;AAAAA;AAAAA;AAM5B,oCAAoCqZ,aAA0B;AACpDA,UAAAA,YAAY9oB;AAAAA,SACb;AACI,aAAA;AAAA,SAEJ;AACH,aAAO;SAEJ;AAAA,SACA;AAAA,SACA;AAAA,SACA;AAAA,SACA;AAAA,SACA;AAAA,SACA;AAAA;AAEI,aAAA;AAAA;AAEZ;AAED,MAAMmsB,sBAAsBC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAetBC,MAAAA,OAAOntB,WAAW,eACtB;AAAA,EACEa;AAAAA,EACAusB;AAAAA,EACA9sB,QAAQ+sB;AAAAA,EACRC,cAAc;AAAA,EACdC;AAAAA,EACA5T;AAAAA,EACAvI;AAAAA,EACAuW;AAAAA,EACAC;AAAAA,EACAnJ;AAAAA,EACA7Q;AAAAA,EACA2F;AAAAA,EACAia;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAvF;AAAAA,EACAC;AAAAA,GAEFroB,KACA;AACMK,QAAAA,SAASutB,QAAQ;;AAAMR,0DAAY/sB,WAAZ+sB,YAAsB;KAAI,CAACA,UAAD,CAAjC;AAChBS,QAAAA,OAAOD,QAAQ;;AAAMR,0DAAYS,SAAZT,YAAoB;KAAI,CAACA,UAAD,CAA/B;AACd,QAAA;AAAA,IAAExqB,MAAM;AAAA,MAAEzB;AAAAA,QAAU,CAAA;AAAA,MAAO2sB,SAASX,OAAD;AACnC,QAAA,CAACY,qBAAqBC,YAAYhB,mBAAD;AACvC,QAAM,CAACiB,OAAOC,YAAY9nB,SAA6B,IAArB;AAClC,QAAM,CAAC+nB,iBAAiBC,sBACtBhoB,SAAyD,IAAjD;AACJ,QAAA,CAACioB,eAAeC,oBAAoBloB,SAAiB,MACzD/F,OAAOyF,OAAO,CAACyoB,KAAKC,cAAc;AAC1B7E,UAAAA,cAAcxoB,SAASA,MAAM2U,QAAQoG,KAAK0P,CAASA,UAAAA,MAAMhrB,OAAO4tB,UAAUC,aAAnD;AACvB3X,UAAAA,eAAe0X,YAAYA,UAAU1X,eAAe;AAE1D,QAAI6S,aAAa;AACf4E,UAAI5E,YAAYtD,QACdvP,gBAAgB,OAAO4X,2BAA2B/E,WAAD,IAAgB7S;AAAAA,IACpE;AAEMyX,WAAAA;AAAAA,EAAAA,GACN,CAAA,CAVH,CADgD;AAalD,QAAMI,aAAaR,mDAAiB9tB;AAC9B,QAAA;AAAA,IAAEiJ;AAAAA,IAAWslB;AAAAA,MAAUC,sBAAsBF,YAAY;AAAA,IAAEG,aAAazuB,OAAOuV;AAAAA,EAAAA,CAAnC;AAC5C,QAAA,CAACmZ,QAAQC,aAAa5oB,SAAS,KAAD;AAC9B6oB,QAAAA,UAAUtkB,OAA0B,IAApB;AAEtBsH,sBACEjS,KACA,MAAO;AAAA,IACLiU,cAAc;AACLga,aAAAA,iBAAiBlY,UAAUmZ,OAAOjB,KAAD,IAAU;AAAA,IAF/C;AAAA,IAILG;AAAAA,EAEF,IAAA,CAACH,OAAOG,kBAAR,CARiB;AAWnB/nB,YAAU,MAAM;AACdiD,cAAU2kB,KAAD;AAAA,EAAA,GACR,CAAC3kB,WAAW2kB,KAAZ,CAFM;AAIT5nB,YAAU,MAAM;AACV,QAAA,CAAC0oB;AAAQ;AAETI,QAAAA,YAAYC,WAAW,MAAMJ,UAAU,KAAD,GAAS,IAAzB;AAEnB,WAAA,MAAMK,aAAaF,SAAD;AAAA,EAAA,GACxB,CAACJ,MAAD,CANM;AAQe,0BAAA;AAAA,IAAEN;AAAAA,KAAsB;AAC9C,WAAOttB,SAASA,MAAM2U,QAAQoG,KAAK0P,CAAS6C,UAAAA,kBAAkB7C,MAAMhrB,EAApD;AAAA,EACjB;AAED,8BAA4B0uB,QAAa;AAAA,IAAEC;AAAAA,IAAeC;AAAAA,IAAWC;AAAAA,KAAkB;AACrF,QAAItuB,OAAO;AACT,YAAM2U,UAAoB,CAAA;AAE1BzV,aAAOwC,QAAQ+oB,CAAS,UAAA;AAChBjC,cAAAA,cAAc+F,eAAe9D,KAAD;AAElC,YAAIjC,aAAa;AACT/mB,gBAAAA,OAAO0sB,OAAO3F,YAAYtD;AAEhC,cAAIzjB,MAAM;AACRkT,oBAAQiQ,KAAK;AAAA,cAAE4J,UAAU/D,MAAM6C;AAAAA,cAAe7rB;AAAAA,YAAAA,CAA9C;AAEIgpB,gBAAAA,MAAMgE,UAAU;AACLC,2BAAAA,QACV,GAAEzD,2BAA2BzC,YAAYtD,QAC1CyJ,KAAKC,UAAUntB,IAAf,CAFF;AAAA,YAID;AAAA,UACF;AAAA,QACF;AAAA,MAAA,CAhBH;AAmBI,UAAA;AACF,cAAMmrB,kBAAkB;AAAA,UACtBprB,WAAW;AAAA,YAAE0kB,OAAO;AAAA,cAAEzkB,MAAM;AAAA,gBAAEuqB,SAAShsB,MAAMP;AAAAA,gBAAIkV;AAAAA,cAArB;AAAA,YAAR;AAAA,UAAT;AAAA,QAAA,CADU;AAGvBkZ,kBAAU,IAAD;AACTV,yBAAiB0B,CACf3vB,SAAAA,OAAOyF,OACL,CAACyoB,KAAK3C,UAAU;AACRjC,gBAAAA,cAAc+F,eAAe9D,KAAD;AAElC,cAAIjC,aAAa;AACT/mB,kBAAAA,OAAO0sB,OAAO3F,YAAYtD;AAE5BzjB,gBAAAA,QAAQgpB,MAAMgE;AAAiB,qBAAA,iCAAKrB,MAAL;AAAA,iBAAW5E,YAAYtD,OAAOzjB;AAAAA,cAAAA;AAAAA,UAClE;AAEM2rB,iBAAAA;AAAAA,QAAAA,GAET,mBAAKyB,KAZP,CADc;AAgBP;AAELf,YAAAA,QAAQjkB,WAAW;AAAMikB,kBAAQjkB,QAAQilB;eACtChX;AACG,kBAAA;AAAA,UAAEA,OAAO;AAAA,QAAA,CAAV;AAAA,MAAA,UACD;AACRsW,sBAAc,KAAD;AAAA,MACd;AAAA,IACF;AAAA,EACF;AAEDlpB,YAAU,MAAM;AACdioB,qBAAiB0B,CACf3vB,SAAAA,OAAOyF,OACL,CAACyoB,KAAKC,cAAc;AACZ7E,YAAAA,cACJxoB,SAASA,MAAM2U,QAAQoG,KAAK0P,CAASA,UAAAA,MAAMhrB,OAAO4tB,UAAUC,aAAnD;AAEP9E,UAAAA,eAAe6E,UAAUoB,UAAU;AACrC,cAAMM,cAAcC,aAAaC,QAC9B,GAAEhE,2BAA2BzC,YAAYtD,MADxB;AAIpB,YAAI6J,aAAa;AACX,cAAA;AACF3B,gBAAI5E,YAAYtD,QAAQyJ,KAAKrb,MAAMyb,WAAX;AAAA,mBACjBnnB;UAER;AAAA,QACF;AAAA,MACF;AAEMwlB,aAAAA;AAAAA,IAAAA,GAET,mBAAKyB,KArBP,CADc;AAAA,EAAA,GAyBf,CAAC3vB,QAAQc,KAAT,CA1BM;AA4BT,6BACGkvB,UAAD;AAAA,IACE,OAAO;AAAA,MAAE3W;AAAAA,MAAOvI;AAAAA,MAAMuW;AAAAA,MAAUC;AAAAA,MAAYS;AAAAA,MAAgBC;AAAAA,IAD9D;AAAA,IAAA,UAGG8E,WAAW,OACVhpB,oBAAC6R,eAAD;AAAA,MAAa,KAAKkY;AAAAA,MAAU,WAAWvY,GAAGhI,KAAD;AAAA,MAAS;AAAA,IAAA,CAAlD,IAEAxJ,oBAAAuK,UAAA;AAAA,MAAA,8BACG,QAAD;AAAA,QACE,UAAU4hB;AAAAA,QACV;AAAA,QACA,eAAe;AAAA,UAAErX,OAAO;AAAA,QAH1B;AAAA,QAIE,oBAJF;AAAA,QAAA,UAMGsX,CAAU,WAAA;AACHtX,gBAAAA,QAAQsX,OAAOC,UAAUD,OAAOC,OAAOvX;AACvC8S,gBAAAA,SAAS1rB,OACZM,IAAIirB,CAAS,UAAA;AACNjC,kBAAAA,cAAc+F,eAAe9D,KAAD;AAGhCjC,mBAAAA,eACAkC,MAAM0E,OAAOzE,SAASnC,YAAYtD,IAA7B,KACLwF,MAAM0E,OAAOxE,QAAQpC,YAAYtD,IAA5B;AAAA,UAAA,CAPI,EAUZ/gB,OAAOmrB,CAAW,YAAA,OAAOA,YAAY,QAVzB;AAab,sCAAA/hB,UAAA;AAAA,YAAA,UAAA,CACEyT,qBAAC,UAAD;AAAA,cACE,KAAK+L;AAAAA,cACL;AAAA,cACA,WAAWvY,GAAGhI,KAAD;AAAA,cACb;AAAA,cACA;AAAA,cACA,UAAU4iB,OAAOD;AAAAA,cACjB,SAASC,OAAOG;AAAAA,cAChB,YARF;AAAA,cAUGrwB,UAAAA,CAAAA,OAAOM,IAAI,CAACirB,OAAO/V,UAAU;AACtB8T,sBAAAA,cAAc+F,eAAe9D,KAAD;AAElC,2CACG1Y,YAAD;AAAA,kBAEE,KAAK0b,MAAM/Y;AAAAA,kBACX;AAAA,kBACA;AAAA,kBACA,QAAQ2I;AAAAA,kBACR,WAAWA;AAAAA,kBANb,8BAQG,OAAD;AAAA,oBAAO;AAAA,oBAA0B,gBAAgBoN;AAAAA,kBAAAA,CAAjD;AAAA,gBAAA,GAPKA,MAAMhrB,EADb;AAAA,cAAA,CAJH,GAgBDuhB,qBAACjP,YAAD;AAAA,gBACE,KAAK0b,MAAMvuB,OAAOuV;AAAAA,gBAClB;AAAA,gBACA,OAAOvV,OAAOuV;AAAAA,gBACd,QAAQ4I;AAAAA,gBACR,WAAWA;AAAAA,gBALb,UAAA,CAOEra,oBAAC,cAAD;AAAA,kBACE,MAAK;AAAA,kBACL,UAAUosB,OAAOI,gBAAgB5B;AAAAA,kBACjC;AAAA,kBACA;AAAA,kBACA,OAAOpH;AAAAA,kBACP,SAAS6F;AAAAA,kBACT,WAAWC;AAAAA,kBACX,OAAOC;AAAAA,kBACP,WAAWC;AAAAA,kBACX,WAAWJ;AAAAA,kBAEVgD,UAAAA,OAAOI,eACLxsB,oBAAA,SAAD,CAAA,CAAA,IACE4qB,SACF5qB,oBAAC,eAAD;AAAA,oBAAA,UACEA,oBAACysB,YAAD,EAAA;AAAA,kBADF,CAAA,IAIAvD;AAAAA,gBAAAA,CA1BN,GA6BItB,QAAOnW,SAAS,KAAKqD,+BACpB,gBAAD;AAAA,kBAAA,UAAA,CACG8S,OAAOprB,IAAI8vB,CAAAA,gCACT,cAAD;AAAA,oBAA6BA,UAAAA;AAAAA,kBAAAA,GAAVA,OAAnB,CADD,GAGAxX,SAAS,4BAAS,cAAD;AAAA,oBAAeA,UAAAA;AAAAA,kBAAAA,CAJnC,CAAA;AAAA,gBAAA,CA9BJ,CAAA;AAAA,cAAA,CA1BF,CAAA;AAAA,YAAA,CAAA,GAiECqU,cAAc,4BAAS,MAAD;AAAA,cAAM,KAAK2B;AAAAA,cAAS,QAApB;AAAA,cAA2B,MAAM3B;AAAAA,YAAAA,CAlE1D,CAAA;AAAA,UAAA,CADF;AAAA,QAsED;AAAA,MAAA,CA1FH;AAAA,IAAA,CADF;AAAA,EAAA,CAPN;AAwGD,CAvQsB;AA2QhB,6BAA2BrX,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkB2W,MAAM;AAAA,IACrCloB,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL0W,SAAS1W,MAFJ;AAAA,MAGLpW,QAAQoW,gBAHH;AAAA,MAIL6W,YAAY7W,OAAW9Q,CAAU,UAAA;AAAA,QAC/B6Q,OAAO;AAAA,QAEP5S,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,GAC7B;AAAA,UAAE7F,OAAO;AAAA,UAAY6F,OAAO;AAAA,QAAA,CAFrB;AAAA,QAITS,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAPf;AAAA,MASZ3O,KAAK/H,KAAW9Q,CAAU,UAAA;AAAA,QACxBoR,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAIqG,MAAM;AAAA,UAAnB;AAAA,QAAA,CAA/B;AAAA,QACRR,OAAO;AAAA,QACPM,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAHR;AAAA,QAIxBC,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAJtB;AAAA,MAMLzT,OAAOjD,yBAA+B9Q,CAAU,UAAA;AAAA,QAC9C6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAQ7F,OAAO+Z,OAAOmG;AAAAA,UAAMha,MAAM;AAAA,QAAA,GAC3C;AAAA,UAAEL,OAAO;AAAA,UAAW7F,OAAO+Z,OAAOC;AAAAA,UAAS9T,MAAM;AAAA,QAAA,GACjD;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO+Z,OAAOoG;AAAAA,UAAQja,MAAM;AAAA,QAAA,CAHxC;AAAA,QAKTC,cAAc4T,OAAOC;AAAAA,QACrB1T,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EARpB;AAAA,MAUPhc,MAAMsF,yBAA+B9Q,CAAU,UAAA;AAAA,QAC7C6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAS7F,OAAOqW,MAAMC;AAAAA,UAAOpQ,MAAM;AAAA,QAAA,GAC5C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAOqW,MAAME;AAAAA,UAAQrQ,MAAM;AAAA,QAAA,GAC9C;AAAA,UAAEL,OAAO;AAAA,UAAS7F,OAAOqW,MAAMG;AAAAA,UAAOtQ,MAAM;AAAA,QAAA,CAHrC;AAAA,QAKTC,cAAckQ,MAAME;AAAAA,QACpBjQ,QAAQtR,gCAAOwnB,YAAW;AAAA,MAAA,EARtB;AAAA,MAUNzF,UAAUjR,yBAA+B9Q,CAAU,UAAA;AAAA,QACjD6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAc7F,OAAOsX,UAAUC;AAAAA,UAAOrR,MAAM;AAAA,QAAA,GACrD;AAAA,UAAEL,OAAO;AAAA,UAAa7F,OAAOsX,UAAUE;AAAAA,UAAMtR,MAAM;AAAA,QAAA,CAF5C;AAAA,QAITC,cAAcmR,UAAUC;AAAAA,QACxBjR,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAPjB;AAAA,MASV/E,gBAAgB3R,UAAgB;AAAA,QAAED,OAAO;AAAA,MAAA,CAAzB;AAAA,MAChB6R,gBAAgB5R,gBAAsB,CAAC9Q,OAAOwR,WAAW;AACjDF,cAAAA,SAAStR,MAAMwnB,WAAW;AAC1B4D,cAAAA,qBAAqBprB,MAAM+hB;AAC3BA,cAAAA,WAAWnM,mBAA6BwV,oBAAoB5Z,MAA/B;AAE5B,eAAA;AAAA,UACLF;AAAAA,UACAT,OAAO;AAAA,UACP8E,aACEoM,sCAAU/W,WAAUsX,UAAUE,OAAO,2BAA2B;AAAA,QAAA;AAAA,MAJpE,CALc;AAAA,MAYhBoF,iBAAiB9W,UAAgB;AAAA,QAAED,OAAO;AAAA,MAAA,CAAzB;AAAA,MACjBmR,YAAYlR,gBAAsB9Q,CAAU,UAAA;AAAA,QAC1C6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAHf;AAAA,MAMZM,iBAAiBhX,gBAAsB9Q,CAAU,UAAA;AAAA,QAC/C6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAHV;AAAA,MAKjBE,aAAa5W,UAAgB9Q,CAAU,UAAA;AAAA,QACrC6Q,OAAO;AAAA,QACP8E,aAAa;AAAA,QACbrE,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAHd;AAAA,MAKbK,eAAe/W,iBAAuB9Q,CAAU,UAAA;AAAA,QAC9C6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAQ6F,OAAO;AAAA,QAAA,GACxB;AAAA,UAAE7F,OAAO;AAAA,UAAW6F,OAAO;AAAA,QAAA,GAC3B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAS6F,OAAO;AAAA,QAAA,GACzB;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,GAC1B;AAAA,UAAE7F,OAAO;AAAA,UAAU6F,OAAO;AAAA,QAAA,CAPnB;AAAA,QASTM,cAAc;AAAA,QACdG,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAZZ;AAAA,MAcfO,aAAajX,iBAAuB9Q,CAAU,UAAA;AAAA,QAC5C6Q,OAAO;AAAA,QACPS,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EAFd;AAAA,MAKbQ,iBAAiBlX,yBAA+B9Q,CAAU,UAAA;AAAA,QACxD6Q,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAQ7F,OAAO0b,WAAWC;AAAAA,UAAMzV,MAAM;AAAA,QAAA,GAC/C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO0b,WAAWE;AAAAA,UAAQ1V,MAAM;AAAA,QAAA,GACnD;AAAA,UAAEL,OAAO;AAAA,UAAS7F,OAAO0b,WAAWG;AAAAA,UAAO3V,MAAM;AAAA,QAAA,CAH1C;AAAA,QAKTC,cAAcuV,WAAWE;AAAAA,QACzBtV,QAAQtR,MAAMwnB,WAAW;AAAA,MAAA,EARV;AAAA,MAUjBxf,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BG,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAKqG,MAAM;AAAA,UAApB;AAAA,QAAA,CAA/B;AAAA,QACRF,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAHT;AAAA,MAKP1D,QAAQmD,OAAA;AAAA,IAhHH;AAAA,EAAA,CAJF;AAuHR;AClmBD,IAAIoQ;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,EACZ,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACTA,MAAMmK,kBAAkBpxB,OAAOC;AAAAA,IAK3ByQ,CAAAA,MACAC,cACE,CAACD,EAAE2gB,MAAH,GACA,CAAC,CAACA,SAAS;AAAA,EAAEtgB,OAAO;AAAA,EAAGqG,MAAM;AAAlB,OAA8BvG;AAAAA,wBACvBH,EAAE4gB,QAAQ,QAAS,GAAED,OAAOtgB,QAAQ,IAAIsgB,OAAOja;AAAAA,yBAC9C1G,EAAE6gB,OAAO,QAAS,GAAEF,OAAOtgB,QAAQ,IAAIsgB,OAAOja;AAAAA,OAJtD;AAAA;ACNjB,MAAMoa,oBAAkBxxB,OAAOC,IAAIyS,WAAW;AAAA,EAC5CC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,SAAS,QAAV,EAAoBC,SAASD,KAAKvP,UAAlC;AADgB,CAAtB;AAAA,WAGb0C,WAASA,MAAMgI;AAAAA,YACdhI,CAAUA,UAAAA,MAAM0rB,WAAW,OAAO,KAAK;AAAA;AAAA,mBAEhC1rB,CAAUA,UAAAA,MAAM0rB,WAAW,OAAO,IAAI;AAAA;AAAA;AAMzD,MAAMC,UAAQ,CAAC;AAAA,EAAE3jB,OAAO;AAAT,GAAe;AAAA,EAAEA,OAAO;AAAT,GAAe;AAAA,EAAEA,OAAO;AAAT,GAAe;AAAA,EAAEA,OAAO;AAAA,EAAI0jB,QAAQ;AAArB,CAA9C;AAE2B,0BAAA;AAAA,EAAEJ;AAAAA,GAA8B;AAErE,6BAAAviB,UAAA;AAAA,IACG4iB,UAAAA,QAAM3wB,IAAI,CAACiB,MAAM2gB,0BACf,iBAAD;AAAA,MAAyB;AAAA,MAAgB,OAAOA,MAAM;AAAA,MAAG,MAAMA,MAAM+O,QAAM1b,SAAS;AAAA,MAClF,8BAACwb,mBAAoBxvB,mBAAAA,KAArB;AAAA,IADF,GAAsB2gB,CAAtB,CADD;AAAA,EAAA,CAFL;AASD;AC7BD,IAAIsE;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,gBAAgB,wBAAuB,OAAO;AAChD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACdA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,WAAW,mBAAkB,OAAO;AACtC,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACdA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,gBAAgB,wBAAuB,OAAO;AAChD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACdA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,UAAU;AAAA,IACV,UAAU;AAAA,IACV,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACMA,MAAM0K,uBAAuB;AAI7B,MAAMC,iBAAe5xB,OAAOC,IAAIyS,WAAW;AAAA,EACzCC,mBAAmBC,UAAQ,CAAC,CAAC,UAAD,EAAaC,SAASD,KAAKvP,UAA3B;AADa,CAAtB;AAAA;AAAA;AAAA,UAKX0C,CAAUA,UAAAA,MAAMoH,aAAa,SAAS,IAAI;AAAA,WACzCpH,CAAUA,UAAAA,MAAMoH,aAAa,UAAU,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,WAM3CwkB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAUX,MAAME,SAASxF;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAWf,MAAMyF,oBAAoB9xB,OAAOC;AAAAA;AAAAA;AAAAA,cAGnB2xB;AAAAA;AAAAA,iBAEGC;AAAAA;AAAAA;AAIjB,MAAME,qBAAqB/xB,OAAO2X,IAAD,EAAOjF,WAAW;AAAA,EACjDC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,SAAS,WAAV,EAAuBC,SAASD,KAAKvP,UAArC;AADqB,CAAxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAavB+X,aAAe;AAAA,IACf1K,CACAC,MAAAA,cAAc,CAACD,EAAEZ,OAAOY,EAAE4K,SAAZ,GAAiC,CAAC,CAACxL,OAAOwL,YAAY,CAAQ,OAAA;AACpErB,QAAAA,WAAWqB,UAAUrB,YAAY;AAAA,IAAElJ,OAAO;AAAA,IAAIqG,MAAM;AAAA,EAAA;AAC1D,QAAM4a,aAAa1W,UAAU0W,cAAc,OAAO,WAAW1W,UAAU0W;AACjEC,QAAAA,YAAY3W,UAAU2W,aAAa;AACzC,QAAMC,gBAAgB5W,UAAU4W,iBAAiB,OAAO,OAAO5W,UAAU4W;AACnEC,QAAAA,gBAAgB7W,UAAU6W,iBAAiB;AAE1CthB,SAAAA;AAAAA,iBACIf,SAAS,OAAO,UAAUE,cAAcF,KAAD;AAAA,qBAClC,GAAEmK,SAASlJ,QAAQkJ,SAAS7C;AAAAA,uBAC3B4a;AAAAA,sBACDC,UAAUpf,SAAS,QAAnB,IAA+B,WAAW;AAAA,0BACtCqf,iBAAiB,OAAO,WAAY,GAAEA;AAAAA,0BACtCC,cAActf,SAAS,WAAvB,IAAsC,cAAc;AAAA;AAEzE,CAfY;AAAA;AAAA;AAAA;AAAA;AAAA;AA8BjB,wBAAsB,IAA8C;AAA9C,eAAE/C;AAAAA;AAAAA,MAAF,IAAYzP,wBAAZ,IAAYA;AAAAA,IAAVyP;AAAAA;AAEf,6BAAC,oBAAD,iCAAwBzP,cAAxB;AAAA,IAAqC,OAAO+xB,mBAAmBtiB,KAAD;AAAA,EAAA,EAArE;AACD;AAcsC,wBAAA,IAOhB;AAPgB,eACrC8G;AAAAA;AAAAA,IACAyb,QAAQ;AAAA,IACRX,gBAAQ,CAH6B;AAAA,IAIrC3X;AAAAA,IACAjK;AAAAA,MALqC,IAMlCzP,wBANkC,IAMlCA;AAAAA,IALHuW;AAAAA,IACAyb;AAAAA,IACAX;AAAAA,IACA3X;AAAAA,IACAjK;AAAAA;AAGMpG,QAAAA,YAAYqB,OAAuB,IAAjB;AAClB,QAAA,CAACoC,UAAUmlB,eAAe9rB,SAAmB,MAAX;AAExC2E,4BAA0B,MAAM;AAE5BzB,QAAAA,UAAU0B,WACV1B,UAAU0B,QAAQd,cAAcC,YAAagoB,aAC3C7oB,UAAU0B,QAAQonB,aAAab,sBACjC;AACAW,kBAAY,OAAD;AAAA,IAAA,OACN;AACLA,kBAAY,MAAD;AAAA,IACZ;AAAA,EAAA,GACA,CAACA,WAAD,CAVsB;AAYzB,8BACG,mBAAD;AAAA,IAAmB,KAAK5oB;AAAAA,IACtB,UAAA,CAAAnF,oBAAC8W,UAAD,iCACMhb,cADN;AAAA,MAEE,WAAW+xB,mBAAmBrY,SAAD;AAAA,MAC7B,OAAOqY,mBAAmBtiB,KAAD;AAAA,MAEzB,+BAAA,OAAA;AAAA,QAAK,OAAO;AAAA,UAAEoY,SAAS;AAAA,UAAQ1U,YAAY;AAAA,QAA3C;AAAA,QACE,UAAA,CAAAjP,oBAAA,QAAA;AAAA,UAAM,OAAO;AAAA,YAAEgR,aAAa;AAAA,UAA5B;AAAA,UAAkCqB,UAAAA;AAAAA,QAAAA,CAAlC,GACA2L,qBAAA,QAAA;AAAA,UAAM,OAAO;AAAA,YAAE2F,SAAS;AAAA,YAAeuK,MAAM;AAAA,UAA7C;AAAA,UAAA,UAAA,CACGJ,UAAU,WAAY9tB,oBAAAmuB,eADzB,CAAA,CAAA,GAEGL,UAAU,UAAU9tB,oBAACouB,UAAD,CAAA,CAAA,GACpBN,UAAU,gBAAiB9tB,oBAAAquB,eAAD,CAAA,CAAA,GAC1BP,UAAU,kBAAkB9tB,oBAACsuB,iBAJhC,CAAA,CAAA,CAAA;AAAA,QAAA,CAFF,CAAA;AAAA,MAAA,CAAA;AAAA,IAAA,EANJ,GAgBEtuB,oBAACqtB,gBAAD;AAAA,MAAc;AAAA,MAAd,UACGF,OAAM3wB,IAAI,CAAC;AAAA,QAAEC;AAAAA,QAAIoQ;AAAAA,0CACf0hB,gBAAD,iCAAkB1hB,UAAlB;AAAA,QAA2B,KAAKpQ;AAAAA,MAAAA,IAC7BoQ,QAAQwF,KADX,CADD;AAAA,IAAA,CAjBL,CAAA;AAAA,EAAA,CADF;AA0BD;ACnLD,IAAIqQ;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,aAAa,qBAAoB,OAAO;AAC1C,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,OAAO;AAAA,EACX,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,UAAU;AAAA,IACV,UAAU;AAAA,IACV,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACMA,MAAM2K,eAAe5xB,OAAOC,IAAIyS,WAAW;AAAA,EACzCC,mBAAmBC,UAAQ,CAAC,CAAC,MAAD,EAASC,SAASD,KAAKvP,UAAvB;AADa,CAAtB;AAAA,aAGR0C,CAAAA,UAAUA,MAAMgtB,OAAO,SAAS;AAAA;AAAA;AAAA;AAK7C,MAAMC,eAAahzB,OAAOqb,QAAD;AAAA;AAAA;AAIzB,MAAM4X,eAAajzB,OAAO2X,IAAD,EAAOjF,WAAW;AAAA,EACzCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,aAAa,OAAd,EAAuBC,SAASD,KAAKvP,UAArC;AADa,CAAxB;AAAA;AAAA;AAAA;AAAA;AAAA,IAUf+X,aAAe;AAAA,IACf1K,CAAAA,MACAC,cACE,CAACD,EAAEZ,KAAH,GACA,CAAC,CAACA,WAAWe;AAAAA,iBACFf,SAAS,OAAO,UAAUE,cAAcF,KAAD;AAAA,OAHvC;AAAA;AAgBjB,sBAAsB,IAA8C;AAA9C,eAAEA;AAAAA;AAAAA,MAAF,IAAYzP,wBAAZ,IAAYA;AAAAA,IAAVyP;AAAAA;AAEf,6BAACmjB,cAAD,iCAAgB5yB,cAAhB;AAAA,IAA6B,OAAO+xB,mBAAmBtiB,KAAD;AAAA,EAAA,EAA7D;AACD;AAe4C,8BAAA,IAQtB;AARsB,eAC3C8G;AAAAA;AAAAA,IACAyb;AAAAA,IACAX,gBAAQ,CAHmC;AAAA,IAI3CwB,UAAU,MAAM;AAAA,IAAE;AAAA,IAClBpjB;AAAAA,IACAiK;AAAAA,MAN2C,IAOxC1Z,wBAPwC,IAOxCA;AAAAA,IANHuW;AAAAA,IACAyb;AAAAA,IACAX;AAAAA,IACAwB;AAAAA,IACApjB;AAAAA,IACAiK;AAAAA;AAGM,QAAA,CAACoZ,QAAQC,aAAa5sB,SAAS,KAAD;AAElC,8BAAAsI,UAAA;AAAA,IACE,UAAA,CAAAvK,oBAACyuB,cAAD,iCACM3yB,cADN;AAAA,MAEE,WAAW+xB,mBAAmBrY,SAAD;AAAA,MAC7B,OAAOqY,mBAAmBtiB,KAAD;AAAA,MACzB,eAAe,MAAMsjB,UAAUhD,CAAAA,SAAQ,CAACA,IAAV;AAAA,MAE9B,+BAAA,OAAA;AAAA,QAAK,OAAO;AAAA,UAAElI,SAAS;AAAA,UAAQ1U,YAAY;AAAA,QAA3C;AAAA,QACE,UAAA,CAAAjP,oBAAA,QAAA;AAAA,UAAM,OAAO;AAAA,YAAEgR,aAAa;AAAA,UAA5B;AAAA,UAAkCqB,UAAAA;AAAAA,QAAAA,CAAlC,GACArS,oBAAA,QAAA;AAAA,UAAM,OAAO;AAAA,YAAE2jB,SAAS;AAAA,YAAeuK,MAAM;AAAA,UAA7C;AAAA,UACE,+BAAA3jB,UAAA;AAAA,YAAA,UAAA,CACGujB,UAAU,WAAY9tB,oBAAAmuB,eADzB,CAAA,CAAA,GAEGL,UAAU,UAAU9tB,oBAACouB,UAAD,CAAA,CAAA,GACpBN,UAAU,gBAAiB9tB,oBAAAquB,eAAD,CAAA,CAAA,GAC1BP,UAAU,kBAAkB9tB,oBAACsuB,iBAJhC,CAAA,CAAA,CAAA;AAAA,UAAA,CAAA;AAAA,QAAA,CAHJ,CAAA;AAAA,MAAA,CAAA;AAAA,IAAA,EAPJ,GAmBEtuB,oBAAC,cAAD;AAAA,MAAc,MAAM4uB;AAAAA,MAApB,UACGzB,OAAM3wB,IAAI,CAAC;AAAA,QAAEC;AAAAA,QAAIoQ;AAAAA,0CACf,cAAD,iCAAkBA,UAAlB;AAAA,QAA2B,KAAKpQ;AAAAA,QAAI,SAASkyB;AAAAA,MAAAA,IAC1C9hB,QAAQwF,KADX,CADD;AAAA,IAAA,CApBL,CAAA;AAAA,EAAA,CADF;AA6BD;AClGD,4BAA0B7Q,OAA2C;AAC7D,QAAuCA,YAArCgU;AAAAA;AAAAA,IAAWjK;AAAAA,MAA0B/J,IAAhB1F,wBAAgB0F,IAAhB1F;AAAAA,IAArB0Z;AAAAA,IAAWjK;AAAAA;AAGjB,6BAACuL,UAAD,iCACMhb,cADN;AAAA,IAEE,WAAW+xB,mBAAmBrY,SAAD;AAAA,IAC7B,OAAOqY,mBAAmBtiB,KAAD;AAAA,EAAA,EAJ7B;AAOD;AAED,MAAMkjB,aAAahzB,OAAOqzB,kBAAD;AAAA;AAAA;AAIzB,MAAM9lB,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,aAAa,mBAAmB,MAAjC,EAAyCC,SAASD,KAAKvP,UAAvD;AADU,CAAtB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAedqN,CACAC,MAAAA,cAAc,CAACD,EAAE6Q,WAAW7Q,EAAEjD,eAAhB,GAA2C,CAAC,CAAC8T,WAAW9T,qBACpE8T,aAAa,OACT1Q;AAAAA;AAAAA,cAGAA;AAAAA;AAAAA,gCAEsBpD,mBAAmB,OAAO,UAAUuC,cAAcvC,eAAD;AAAA,yBACxDiD,EAAEqiB,OACV,uBACA,eAAc;AAAA,EAAEO,YAAY;AAAA,EAAIC,WAAW;AAA7B,EAAmChS;AAAAA,cACpD;AAAA,EACA+R,YAAY;AAAA,IAAE3nB,KAAK;AAAA,IAAGE,QAAQ;AAAA,IAAGwB,OAAO;AAAA,EADxC;AAAA,EAEAkmB,WAAW;AAAA,IAAE5nB,KAAK;AAAA,IAAGE,QAAQ;AAAA,IAAGuB,MAAM;AAAA,EAA3B;AAFX,EAGAmU;AAAAA,WAdG;AAAA;AAmBjB,MAAMiS,qBAAqBxzB,OAAOyxB,OAAO/e,WAAW;AAAA,EAClDC,mBAAmBC,UAAQ,CAAC,CAAC,OAAD,EAAUC,SAASD,KAAKvP,UAAxB;AADsB,CAAzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAWvBqN,CAAAA,MACAC,cACE,CAACD,EAAEZ,KAAH,GACA,CAAC,CAACA,WAAWe;AAAAA,iBACFf,SAAS,OAAO,6BAA6BE,cAAcF,KAAD;AAAA,OAH1D;AAAA;AAiBkB,oBAAA;AAAA,EACjCyR;AAAAA,EACA9T;AAAAA,EACAslB,OAAO;AAAA,EACPU;AAAAA,EACA/B,gBAAQ,CALyB;AAAA,EAMjCwB,UAAU,MAAM;AAAA,EAAE;AAAA,GACG;AACrB,8BACG3lB,aAAD;AAAA,IAAW;AAAA,IAAsB;AAAA,IAAkC;AAAA,IAAnE,UAAA,CAEEhJ,oBAAC,oBAAD;AAAA,MAAoB,OAAOkvB;AAAAA,MAAgB,SAASP;AAAAA,MAApD,UACE3uB,oBAACmvB,YAAD,EAAA;AAAA,IAAA,CADF,GAGAnvB,oBAAA,OAAA;AAAA,MACE,OAAO;AAAA,QAAE2jB,SAAS;AAAA,QAAQC,eAAe;AAAA,QAAU3U,YAAY;AAAA,QAAUmgB,YAAY;AAAA,MADvF;AAAA,MAAA,UAGGjC,OAAM3wB,IAAIiB,CAAAA,8BACR4xB,YAAD;AAAA,QACG5xB,UAAAA,CAAAA,KAAKoD,SAAS,gCACZ,YAAD,iCAAgBpD,KAAKoP,UAArB;AAAA,UAA8B,SAAS8hB;AAAAA,UACpClxB,UAAAA,KAAKoP,QAAQwF;AAAAA,QADhB,EAAA,GAID5U,KAAKoD,SAAS,kCAAeyuB,sBAAD,iCAAoB7xB,KAAKoP,UAAzB;AAAA,UAAkC;AAAA,QAAA,EANjE,CAAA;AAAA,MAAA,GAAepP,KAAKhB,EAApB,CADD;AAAA,IAAA,CARL,CAAA;AAAA,EAAA,CADF;AAsBD;AC3ED,MAAMuM,cAAYvN,OAAO8zB,IAAIphB,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,UAAU,aAAa,QAAxB,EAAkCC,SAASD,KAAKvP,UAAhD;AADU,CAAtB;AAAA;AAAA;AAAA,IASdyP,UAAY;AAAA,IACZsI,aAAe;AAAA,IACf1K,CAAAA,MACAC,cACE,CAACD,EAAE2gB,MAAH,GACA,CAAC,CAACA,SAAS;AAAA,EAAEtgB,OAAO;AAAA,EAAGqG,MAAM;AAAlB,OAA8BvG;AAAAA,eAChCwgB,OAAOtgB,QAAQsgB,OAAOja;AAAAA,OAHpB;AAAA;AAQjB,MAAM2c,iBAAiB/zB,OAAOC,IAAIyS,WAAW;AAAA,EAC3CC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,aAAa,qBAAd,EAAqCC,SAASD,KAAKvP,UAAnD;AADe,CAAtB;AAAA;AAAA;AAAA;AAAA,IASnBqN,CACAC,MAAAA,cACE,CAACD,EAAEqc,WAAWrc,EAAEsjB,mBAAhB,GACA,CAAC,CAACjH,YAAY,YAAYiH,yBAAyBnjB;AAAAA,mBACtCmjB,uBAAuB,OAAO,SAAS;AAAA,2BAC/BjH;AAAAA,OAJV;AAAA;AASjB,MAAMkH,oBAAoBj0B,OAAOyxB,OAAO/e,WAAW;AAAA,EACjDC,mBAAmBC,CACjB,SAAA,CAAC,CAAC,uBAAuB,aAAa,OAArC,EAA8CC,SAASD,KAAKvP,UAA5D;AAF8C,CAAzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAgBtBqN,CACAC,MAAAA,cACE,CAACD,EAAEsjB,qBAAqBtjB,EAAEqc,WAAWrc,EAAEZ,KAAvC,GACA,CAAC,CAACkkB,qBAAqBjH,YAAY,YAAYjd,WAAWe;AAAAA,mBAC7CmjB,uBAAuB,OAAO,SAAS;AAAA,2BAC/BjH;AAAAA,iBACVjd,SAAS,OAAO,6BAA6BE,cAAcF,KAAD;AAAA,OAL1D;AAAA;AAajB,0BAA0B/J,OAA2C;AAC7D,QAAuCA,YAArCgU;AAAAA;AAAAA,IAAWjK;AAAAA,MAA0B/J,IAAhB1F,wBAAgB0F,IAAhB1F;AAAAA,IAArB0Z;AAAAA,IAAWjK;AAAAA;AAGjB,6BAACuL,UAAD,iCACMhb,cADN;AAAA,IAEE,WAAW+xB,mBAAmBrY,SAAD;AAAA,IAC7B,OAAOqY,mBAAmBtiB,KAAD;AAAA,EAAA,EAJ7B;AAOD;AAED,MAAM4L,cAAc;AAAA,EAClBE,KAAK;AAAA,EACL2B,YAAY;AAAA,IAAExP,OAAO;AAAA,IAAIE,QAAQ;AAAA,EAArB;AAFM;AAKdimB,MAAAA,aAAa/zB,WAAkC,qBACnD;AAAA,EACEa;AAAAA,EACA0wB,gBAAQ,CAFV;AAAA,EAGEyC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAzH;AAAAA,EACAsE;AAAAA,EACA2C;AAAAA,EACAS;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACA5mB;AAAAA,EACA2F;AAAAA,GAEFtT,KACA;AACM,QAAA,CAAC+yB,QAAQC,aAAa5sB,SAAS,KAAD;AAEpC,8BACG+G,aAAD;AAAA,IACE;AAAA,IACA;AAAA,IACA,WAAWwI,GAAGhI,KAAD;AAAA,IACb;AAAA,IACA,WAAWomB;AAAAA,IACX;AAAA,IANF,UAAA,CAQGC,aAAa,4BACXnY,gBAAD;AAAA,MACE,SAASsY;AAAAA,MACT,MAAMF;AAAAA,MACN,MAAMG;AAAAA,MACN;AAAA,MACA,OAAOF;AAAAA,IAAAA,CALT,GAQF/R,qBAAA,OAAA;AAAA,MAAK,OAAO;AAAA,QAAE2F,SAAS;AAAA,QAAQ0M,UAAU;AAAA,QAAGxM,gBAAgB;AAAA,MAA5D;AAAA,MAAA,UAAA,CACE7jB,oBAAC,gBAAD;AAAA,QAAgB;AAAA,QAAsB;AAAA,QAAtC,UACGmtB,OAAM1b,SAAS,IACd0b,OAAM3wB,IAAI,CAACiB,MAAM2gB,MACfJ,qBAAC,iBAAD;AAAA,UAEE;AAAA,UACA,OAAOI,MAAM;AAAA,UACb,MAAMA,MAAM+O,OAAM1b,SAAS;AAAA,UAE1BhU,UAAAA,CAAAA,KAAKoD,SAAS,gCACZ,kBAAD,iCAAsBpD,KAAKoP,UAA3B;AAAA,YAAqCpP,UAAAA,KAAKoP,QAAQwF;AAAAA,UAPtD,EAAA,GASG5U,KAAKoD,SAAS,kCAAe,gBAAmBpD,mBAAAA,KAAKoP,QATxD,CAAA;AAAA,WACOpP,KAAKhB,EADZ,CADF,wBAcC,kBAAD;AAAA,UAAkB;AAAA,QAAA,CAAlB;AAAA,MAAA,CAjBN,GAoBEuD,oBAAC,mBAAD;AAAA,QACE;AAAA,QAEA,OAAOkwB;AAAAA,QACP;AAAA,QACA,SAAS,MAAMrB,UAAU,IAAD;AAAA,QAL1B,UAOE7uB,oBAACswB,iBAAD,EAAA;AAAA,MAAA,CA3BJ,GA6BEtwB,oBAAC,YAAD;AAAA,QACE,WAAWyvB;AAAAA,QACX,iBAAiBW;AAAAA,QACjB,gBAAgBD;AAAAA,QAChB;AAAA,QACA,SAAS,MAAMtB,UAAU,KAAD;AAAA,QACxB,MAAMD;AAAAA,MAAAA,CAnCV,CAAA;AAAA,IAAA,CAjBF,CAAA;AAAA,EAAA,CADF;AA0DD,CAjF4B;AAqFtB,6BAA2B9c,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBud,YAAY;AAAA,IAC3C9uB,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL6a,OAAO7a,gBAFF;AAAA,MAGLsd,eAAetd,UAAgB9Q,CAAS,UAAA;AACtC,cAAM2rB,SAAQ3rB,MAAM2rB;AAEb,eAAA;AAAA,UACL9a,OAAO;AAAA,UACPS,QAAQqa,UAAS,QAAQA,OAAM1b,WAAW;AAAA,QAAA;AAAA,MAF5C,CAHa;AAAA,MAQfoe,UAAUvd,WAAe;AAAA,QAAEM,QAAQ;AAAA,QAAMP,OAAO;AAAA,MAAA,CAAtC;AAAA,MACVyd,UAAUxd,QAAY9Q,CAAU,UAAA;AAAA,QAC9B6Q,OAAO;AAAA,QACPS,QAAQtR,MAAMquB,aAAa;AAAA,MAAA,EAFnB;AAAA,MAIVE,WAAWzd,iBAAuB9Q,CAAU,UAAA;AAAA,QAC1CoR,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAKqG,MAAM;AAAA,UAApB;AAAA,QAAA,CAA/B;AAAA,QACRR,OAAO;AAAA,QACPY,KAAK;AAAA,QACLpJ,KAAK;AAAA,QAELpK,SAAS,CAAC;AAAA,UAAE+M,OAAO;AAAA,UAAM6F,OAAO;AAAA,UAAUK,MAAM;AAAA,QAAA,CAAvC;AAAA,QACTI,QAAQtR,MAAMquB,aAAa;AAAA,MAAA,EAPlB;AAAA,MASXG,aAAa1d,UAAgB9Q,CAAU,UAAA;AAAA,QACrC6Q,OAAO;AAAA,QACPS,QAAQtR,MAAMquB,aAAa;AAAA,MAAA,EAFhB;AAAA,MAIbI,UAAU3d,OAAW9Q,CAAU,UAAA;AAAA,QAC7B6Q,OAAO;AAAA,QACPS,QAAQtR,MAAMquB,aAAa;AAAA,MAAA,EAFnB;AAAA,MAIVrH,WAAWlW,yBAA+B;AAAA,QACxCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAQ7F,OAAO;AAAA,UAAckG,MAAM;AAAA,QAAA,GAC5C;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAO7F,OAAO;AAAA,UAAYkG,MAAM;AAAA,QAAA,CAHlC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPL;AAAA,MASXma,QAAQxa,KAAW;AAAA,QACjBM,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAIqG,MAAM;AAAA,UAAnB;AAAA,QAAA,CAA/B;AAAA,QACRR,OAAO;AAAA,QACPY,KAAK;AAAA,QACLpJ,KAAK;AAAA,QACLqJ,MAAM;AAAA,QACNP,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAAlB;AAAA,MAAA,CANR;AAAA,MAQR4c,qBAAqBnd,iBAAuB;AAAA,QAC1CD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE+M,OAAO;AAAA,UAAc6F,OAAO;AAAA,QAAA,GAC9B;AAAA,UAAE7F,OAAO;AAAA,UAAa6F,OAAO;AAAA,QAAA,CAFtB;AAAA,MAAA,CAFU;AAAA,MAOrB6d,yBAAyB5d,gBAAsB,CAAC9Q,OAAOwR,WAAW;AAC1Dyc,cAAAA,sBAAsBjuB,MAAMiuB;AAC5B3c,cAAAA,SAAS,CAACsE,mBAAmBqY,qBAAqBzc,MAAtB;AAE3B,eAAA;AAAA,UACLX,OAAO;AAAA,UACP8E,aAAa;AAAA,UACbrE;AAAAA,QAAAA;AAAAA,MAHF,CAJuB;AAAA,MAUzBqd,0BAA0B7d,gBAAsB,CAAC9Q,OAAOwR,WAAW;AAC3Dyc,cAAAA,sBAAsBjuB,MAAMiuB;AAC5B3c,cAAAA,SAAS,CAACsE,mBAAmBqY,qBAAqBzc,MAAtB;AAE3B,eAAA;AAAA,UACLX,OAAO;AAAA,UACP8E,aAAa;AAAA,UACbrE;AAAAA,QAAAA;AAAAA,MAHF,CAJwB;AAAA,MAU1Bsd,2BAA2B9d,gBAAsB,CAAC9Q,OAAOwR,WAAW;AAC5Dyc,cAAAA,sBAAsBjuB,MAAMiuB;AAC5B3c,cAAAA,SAAS,CAACsE,mBAAmBqY,qBAAqBzc,MAAtB;AAE3B,eAAA;AAAA,UACLX,OAAO;AAAA,UACP8E,aAAa;AAAA,UACbrE;AAAAA,QAAAA;AAAAA,MAHF,CAJyB;AAAA,MAU3BtJ,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OAAA;AAAA,IA3FH;AAAA,EAAA,CAJF;AAkGR;ACnUD,MAAM9W,kBAAkBC,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAS/B,IAAeE,eAAAA,WAAkC,sBAAqB4F,OAAc3F,KAAK;AAErF,6BAAC,iBAAD,iCAAqB2F,QAArB;AAAA,IAA4B;AAAA,IAC1B,8BAAA,OAAA;AAAA,MACE,OAAM;AAAA,MACN,OAAM;AAAA,MACN,QAAO;AAAA,MACP,OAAO;AAAA,QAAEzF,UAAU;AAAA,MAJrB;AAAA,MAME,8BAAA,QAAA;AAAA,QACE,GAAG;AAAA,QACH,GAAG;AAAA,QACH,OAAM;AAAA,QACN,QAAO;AAAA,QACP,aAAa;AAAA,QACb,iBAAgB;AAAA,QAChB,MAAK;AAAA,QACL,QAAO;AAAA,QACP,IAAG;AAAA,QACH,IAAG;AAAA,MAAA,CAVL;AAAA,IAAA,CANF;AAAA,EAAA,EAFJ;AAuBD,CAxBwB;ACIzB,MAAMw0B,YAAYC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IASdC,UAAY;AAAA;AAGhB,MAAM/hB,OAAOjT,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAMpB,MAAMqT,WAAWtT,OAAOC,IAAIyS,WAAW;AAAA,EACrCC,mBAAmBC,CAAAA,SAAQ,CAAC,CAAC,QAAQ,SAAS,UAAU,WAA5B,EAAyCC,SAASD,KAAKvP,SAAAA,CAAvD;AADS,CAAtB;AAAA;AAAA;AAAA,IAKbkQ,YAAc;AAAA;AAUZ0hB,MAAAA,OAAO90B,WAAW,cACtB;AAAA,EAAEmE;AAAAA,EAAUwM;AAAAA,EAAaiD;AAAAA,EAAQC;AAAAA,GACjC5T,KACA;AAEE,8BAAA0O,UAAA;AAAA,IAAA,UAAA,CACGvK,oBAAA,WADH,CAAA,CAAA,uBAEG,sBAAD;AAAA,MAAsB;AAAA,MAAU,OAAO;AAAA,QAAE0K,YAAY;AAAA,MAArD;AAAA,MAAgE;AAAA,MAAhE,8BACG,MAAD;AAAA,QACG3K,UAAAA,YAAYA,SAASoD,SAASsO,SAAS,IACtC1R,SAASoD,SAAS3G,IAAI,CAAC+I,OAAOmM,8BAC3B,UAAD;AAAA,UAEE,MAAM3R,SAAS4R;AAAAA,UACf;AAAA,UACA;AAAA,UACA;AAAA,UALF,8BAOGC,WAAD;AAAA,YAAS,SAASrM;AAAAA,UAAAA,CAAlB;AAAA,QAAA,GANKA,MAAMV,GADb,CADF,IAYC7E,oBAAA,cAAD,CAAA,CAAA;AAAA,MAAA,CAdJ;AAAA,IAAA,CAHJ,CAAA;AAAA,EAAA,CADF;AAwBD,CA5BsB;AAgChB,6BAA2B8R,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBse,MAAM;AAAA,IACrC7vB,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPS,QAAQ;AAAA,IACRtR,OAAO;AAAA,MACLzB,UAAUuS,OADL;AAAA,MAEL/F,aAAa+F,cAFR;AAAA,MAGL9C,QAAQ8C,KAHH;AAAA,MAIL7C,WAAW6C,KAAA;AAAA,IAJN;AAAA,EAAA,CAJF;AAWR;AC7FD,IAAIoQ;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,qBAAqB,6BAA4B,OAAO;AAC1D,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,mBAAmB,2BAA0B,OAAO;AACtD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,qBAAqB,6BAA4B,OAAO;AAC1D,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,qBAAqB,6BAA4B,OAAO;AAC1D,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,eAAe,uBAAsB,OAAO;AAC9C,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,sBAAsB,8BAA6B,OAAO;AAC5D,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,mBAAmB,2BAA0B,OAAO;AACtD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,kBAAkB,0BAAyB,OAAO;AACpD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,mBAAmB,2BAA0B,OAAO;AACtD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,oBAAoB,4BAA2B,OAAO;AACxD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,iBAAiB,yBAAwB,OAAO;AAClD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,gBAAgB,wBAAuB,OAAO;AAChD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACfA,IAAIA;AAEJ,sBAAoB;AAAEC,eAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAOA,WAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,mBAAmB,2BAA0B,OAAO;AACtD,SAAoB,sBAAM,cAAc,OAAOA,WAAS;AAAA,IACtD,OAAO;AAAA,IACP,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,EACb,GAAK,KAAK,GAAGD,WAAUA,WAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACQO,MAAMiO,qBAAqB,CAChC;AAAA,EAAE9vB,MAAM;AAAA,EAAawR,OAAO;AAAA,EAAaK,MAAM1S,oBAAC4wB,oBAAhD,EAAA;AAAA,EAAoEpN,YAAY;AAAhF,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAWwR,OAAO;AAAA,EAAWK,MAAM1S,oBAAC6wB,kBAA5C,EAAA;AAAA,EAA8DrN,YAAY;AAA1E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAAC8wB,mBAA9C,EAAA;AAAA,EAAiEtN,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAAC+wB,mBAA9C,EAAA;AAAA,EAAiEvN,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAUwR,OAAO;AAAA,EAAUK,MAAM1S,oBAACgxB,iBAA1C,EAAA;AAAA,EAA2DxN,YAAY;AAAvE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAawR,OAAO;AAAA,EAAaK,MAAM1S,oBAACixB,oBAAhD,EAAA;AAAA,EAAoEzN,YAAY;AAAhF,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAACkxB,mBAA9C,EAAA;AAAA,EAAiE1N,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAUwR,OAAO;AAAA,EAAUK,MAAM1S,oBAACmxB,iBAA1C,EAAA;AAAA,EAA2D3N,YAAY;AAAvE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAawR,OAAO;AAAA,EAAaK,MAAM1S,oBAACoxB,oBAAhD,EAAA;AAAA,EAAoE5N,YAAY;AAAhF,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAUwR,OAAO;AAAA,EAAUK,MAAM1S,oBAACqxB,iBAA1C,EAAA;AAAA,EAA2D7N,YAAY;AAAvE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAOwR,OAAO;AAAA,EAAOK,MAAM1S,oBAACsxB,cAApC,EAAA;AAAA,EAAkD9N,YAAY;AAA9D,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAACuxB,mBAA9C,EAAA;AAAA,EAAiE/N,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAcwR,OAAO;AAAA,EAAcK,MAAM1S,oBAACwxB,qBAAlD,EAAA;AAAA,EAAuEhO,YAAY;AAAnF,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAWwR,OAAO;AAAA,EAAWK,MAAM1S,oBAACyxB,kBAA5C,EAAA;AAAA,EAA8DjO,YAAY;AAA1E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAAC0xB,mBAA9C,EAAA;AAAA,EAAiElO,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAUwR,OAAO;AAAA,EAAUK,MAAM1S,oBAAC2xB,iBAA1C,EAAA;AAAA,EAA2DnO,YAAY;AAAvE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAUwR,OAAO;AAAA,EAAUK,MAAM1S,oBAAC4xB,iBAA1C,EAAA;AAAA,EAA2DpO,YAAY;AAAvE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAWwR,OAAO;AAAA,EAAWK,MAAM1S,oBAAC6xB,kBAA5C,EAAA;AAAA,EAA8DrO,YAAY;AAA1E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAYwR,OAAO;AAAA,EAAYK,MAAM1S,oBAAC8xB,mBAA9C,EAAA;AAAA,EAAiEtO,YAAY;AAA7E,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAASwR,OAAO;AAAA,EAASK,MAAM1S,oBAAC+xB,gBAAxC,EAAA;AAAA,EAAwDvO,YAAY;AAApE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAQwR,OAAO;AAAA,EAAQK,MAAM1S,oBAACgyB,eAAtC,EAAA;AAAA,EAAqDxO,YAAY;AAAjE,GACA;AAAA,EAAE3iB,MAAM;AAAA,EAAWwR,OAAO;AAAA,EAAWK,MAAM1S,oBAACiyB,kBAA5C,EAAA;AAAA,EAA8DzO,YAAY;AAA1E,CAtBgC;ACjBlC,MAAMyJ,kBAAkBxxB,OAAOC;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAO/B,MAAMyxB,QAAQ,CAAC;AAAA,EAAE1wB,IAAI;AAAN,GAAa;AAAA,EAAEA,IAAI;AAAN,GAAa;AAAA,EAAEA,IAAI;AAAN,CAA3B;AAIiC,gCAAA;AAAA,EAAEqwB;AAAAA,GAA8B;AAE3E,6BAAAviB,UAAA;AAAA,IACG4iB,UAAAA,MAAM3wB,IAAI,CAACiB,MAAM2gB,0BACf,iBAAD;AAAA,MAEE;AAAA,MACA,OAAOA,MAAM;AAAA,MACb,MAAMA,MAAM+O,MAAM1b,SAAS;AAAA,MAJ7B,UAMEzR,oBAAC,iBAAD,EAAA;AAAA,IAAA,GALKvC,KAAKhB,EADZ,CADD;AAAA,EAAA,CAFL;AAcD;ACMD,MAAMuM,cAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,SAAS,UAAU,WAApB,EAAiCC,SAASD,KAAKvP,UAA/C;AADU,CAAtB;AAAA;AAAA;AAAA;AAAA,IASdyP,UAAY;AAAA,IACZpC,CAAAA,MACAC,cACE,CAACD,EAAEqc,SAAH,GACA,CAAC,CAACA,YAAY,cAAclc;AAAAA,2BACPkc;AAAAA,OAHV;AAAA;AAQjB,MAAMkG,eAAajzB,OAAO2X,IAAD,EAAOjF,WAAW;AAAA,EACzCC,mBAAmBC,CAAAA,SACjB,CAAC,CAAC,cAAc,SAAS,QAAQ,cAAc,QAAQ,iBAAtD,EAAyEC,SACxED,KAAKvP,UADN;AAFsC,CAAxB;AAAA;AAAA,WAcR0C,WAASA,MAAMgiB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAOtBrX,CAAAA,MACAC,cACE,CAACD,EAAEoJ,OAAOpJ,EAAEa,MAAMb,EAAE+lB,YAAY/lB,EAAE+hB,MAAM/hB,EAAEjD,eAA1C,GACA,CAAC,CAACqM,QAAQ,SAASvI,OAAO,UAAUklB,aAAa,QAAQhE,MAAMhlB,qBAAqBoD;AAAAA,mBACvEiJ,UAAU,UAAU,IAAI;AAAA,EAAEI,OAAO;AAAA,EAAIC,QAAQ;AAAA,EAAIC,OAAO;AAAhC,EAAqC7I;AAAAA,yBACvD;AAAA,EAAEmlB,QAAQ;AAAA,EAAOpc,SAAS;AAAA,EAAOqc,OAAO;AAAA,EAAGtc,QAAQ;AAAnD,EAAuDP;AAAAA,sBAC1DA,UAAU,UACpB,gBACArM,mBAAmB,OACnB,iBACAuC,cAAcvC,eAAD;AAAA;AAAA;AAAA,YAGb;AAAA,EACA3I,MAAM;AAAA,EACN8xB,MAAM/lB;AAAAA;AAAAA;AAAAA,EAGNgmB,QAAQhmB;AAAAA;AAAAA;AAAAA,EAGRimB,MAAMjmB;AAAAA;AAAAA;AARN,EAWA4lB;AAAAA;AAAAA;AAAAA;AAAAA,kBAIMhE,QAAQ,OACZ3Y,UAAU,WAAWrM,mBAAmB,OACtC,iBACA,UACFuC,cAAcyiB,IAAD;AAAA,mBACR;AAAA,EAAEvY,OAAO;AAAA,EAAIC,QAAQ;AAAA,EAAIC,OAAO;AAAhC,EAAqC7I;AAAAA,oBACpC;AAAA,EAAE2I,OAAO;AAAA,EAAIC,QAAQ;AAAA,EAAIC,OAAO;AAAhC,EAAqC7I;AAAAA;AAAAA,OAjCxC;AAAA;AAuCXwlB,MAAAA,cAAc52B,WAAW,sBAC7B;AAAA,EACEa;AAAAA,EACA0wB,OAAO;AAAA,IAAEA;AAAAA,IAAOnZ;AAAAA,MAAiB;AAAA,IAAEmZ,OAAO,CAAT;AAAA,IAAanZ,cAAc;AAAA,EAF9D;AAAA,EAGEuB;AAAAA,EACAvI;AAAAA,EACAklB;AAAAA,EACAhE;AAAAA,EACAhlB;AAAAA,EACAsf;AAAAA,EACAsE;AAAAA,EACAtjB;AAAAA,EACA2F;AAAAA,GAEFtT,KACA;AACA,6BACGmN,aAAD;AAAA,IAAW;AAAA,IAAU;AAAA,IAAQ,WAAWwI,GAAGhI,KAAD;AAAA,IAAS;AAAA,IAAsB;AAAA,IAAzE,UACG2jB,OAAM1b,SAAS,IACd0b,OAAM3wB,IAAI,CAACiB,MAAM2gB,MAAM;AACf0H,YAAAA,SAAS6K,mBAAmB5Y,KAAK0a,CAAAA,MAAKA,EAAE5xB,SAASpD,KAAKoP,QAAQhM,IAArD;AAEf,UAAI,CAACilB;AAAQ,cAAM,IAAIvF,MAAO,6BAA4B9iB,KAAKoP,QAAQhM,MAApD;AAEnB,iCACG,iBAAD;AAAA,QAEE;AAAA,QACA,OAAOud,MAAM;AAAA,QACb,MAAMA,MAAM+O,OAAM1b,SAAS;AAAA,QAJ7B,8BAMGid,cAAD;AAAA,UACE;AAAA,UACA,YAAY5I,OAAOtC;AAAAA,UACnB;AAAA,UACA;AAAA,UACA,MAAM;AAAA,YAAE3iB,MAAM;AAAA,YAAYgM,SAAS;AAAA,cAAE/C,KAAKrM,KAAKoP,QAAQ/C;AAAAA,cAAKkK;AAAAA,YAAzB;AAAA,UALrC;AAAA,UAME;AAAA,UACA;AAAA,UAPF,UASG8R,UAAU,OAAO,OAAOA,OAAOpT;AAAAA,QAAAA,CATlC;AAAA,MAAA,GALKjV,KAAKhB,EADZ;AAAA,IAAA,CANJ,IA2BAuD,oBAAC,wBAAD;AAAA,MAAwB;AAAA,IAAA,CAAxB;AAAA,EAAA,CA9BN;AAkCD,CAlD6B;AAsDvB,6BAA2B8R,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkBogB,aAAa;AAAA,IAC5C3xB,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL6a,OAAO7a,cAAkB;AAAA,QACvBM,QAAQ;AAAA,UACNua,OAAO,CACL;AAAA,YACE1wB,IAAI;AAAA,YACJoQ,SAAS;AAAA,cAAEhM,MAAM;AAAA,cAAYiJ,KAAK;AAAA,YAAzB;AAAA,UAAA,GAEX;AAAA,YACErN,IAAI;AAAA,YACJoQ,SAAS;AAAA,cAAEhM,MAAM;AAAA,cAAaiJ,KAAK;AAAA,YAA1B;AAAA,UAAA,GAEX;AAAA,YACErN,IAAI;AAAA,YACJoQ,SAAS;AAAA,cAAEhM,MAAM;AAAA,cAAWiJ,KAAK;AAAA,YAAxB;AAAA,UAAA,CAXN;AAAA,UAcPkK,cAAc;AAAA,QAfR;AAAA,MAAA,CADH;AAAA,MAmBPuB,OAAOjD,yBAA+B9Q,CAAS,UAAA;AAC7C,cAAM2rB,SAAQ3rB,MAAM2rB;AAEb,eAAA;AAAA,UACL9a,OAAO;AAAA,UACP5S,SAAS,CACP;AAAA,YAAE4S,OAAO;AAAA,YAAS7F,OAAO;AAAA,YAASkG,MAAM;AAAA,UAAA,GACxC;AAAA,YAAEL,OAAO;AAAA,YAAU7F,OAAO;AAAA,YAAUkG,MAAM;AAAA,UAAA,GAC1C;AAAA,YAAEL,OAAO;AAAA,YAAW7F,OAAO;AAAA,YAAWkG,MAAM;AAAA,UAAA,GAC5C;AAAA,YAAEL,OAAO;AAAA,YAAU7F,OAAO;AAAA,YAAUkG,MAAM;AAAA,UAAA,CAJnC;AAAA,UAMTC,cAAc;AAAA,UACdG,QAAQqa,UAAS,QAAQA,OAAMA,MAAM1b,WAAW;AAAA,QAAA;AAAA,MATlD,CAHK;AAAA,MAePzE,MAAMsF,yBAA+B9Q,CAAS,UAAA;AAC5C,cAAM2rB,SAAQ3rB,MAAM2rB;AAEb,eAAA;AAAA,UACL9a,OAAO;AAAA,UACP5S,SAAS,CACP;AAAA,YAAE4S,OAAO;AAAA,YAAS7F,OAAO;AAAA,YAASkG,MAAM;AAAA,UAAA,GACxC;AAAA,YAAEL,OAAO;AAAA,YAAU7F,OAAO;AAAA,YAAUkG,MAAM;AAAA,UAAA,GAC1C;AAAA,YAAEL,OAAO;AAAA,YAAS7F,OAAO;AAAA,YAASkG,MAAM;AAAA,UAAA,CAHjC;AAAA,UAKTC,cAAc;AAAA,UACdG,QAAQqa,UAAS,QAAQA,OAAMA,MAAM1b,WAAW;AAAA,QAAA;AAAA,MARlD,CAHI;AAAA,MAcNygB,YAAY5f,iBAAuB9Q,CAAS,UAAA;AAC1C,cAAM2rB,SAAQ3rB,MAAM2rB;AACpB,cAAMra,SAASqa,UAAS,QAAQA,OAAMA,MAAM1b,WAAW;AAEhD,eAAA;AAAA,UACLY,OAAO;AAAA,UACP5S,SAAS,CACP;AAAA,YAAE+M,OAAO;AAAA,YAAQ6F,OAAO;AAAA,UAAA,GACxB;AAAA,YAAE7F,OAAO;AAAA,YAAQ6F,OAAO;AAAA,UAAA,GACxB;AAAA,YAAE7F,OAAO;AAAA,YAAU6F,OAAO;AAAA,UAAA,GAC1B;AAAA,YAAE7F,OAAO;AAAA,YAAQ6F,OAAO;AAAA,UAAA,CAJjB;AAAA,UAMTM,cAAc;AAAA,UACdI,kBAAkB;AAAA,UAClBD;AAAAA,QAAAA;AAAAA,MAVF,CAJU;AAAA,MAiBZob,MAAM5b,gBAAsB9Q,CAAS,UAAA;AACnC,cAAM2rB,SAAQ3rB,MAAM2rB;AACpB,cAAMra,SAASqa,UAAS,QAAQA,OAAMA,MAAM1b,WAAW;AAEhD,eAAA;AAAA,UACLY,OAAO;AAAA,UACPS;AAAAA,QAAAA;AAAAA,MAFF,CAJI;AAAA,MASN5J,iBAAiBoJ,gBAAsB9Q,CAAS,UAAA;AAC9C,cAAM2rB,SAAQ3rB,MAAM2rB;AACpB,cAAMra,SAASqa,UAAS,QAAQA,OAAMA,MAAM1b,WAAW;AAEhD,eAAA;AAAA,UACLY,OAAO;AAAA,UACPS;AAAAA,QAAAA;AAAAA,MAFF,CAJe;AAAA,MASjB0V,WAAWlW,yBAA+B;AAAA,QACxCD,OAAO;AAAA,QACP5S,SAAS,CACP;AAAA,UAAE4S,OAAO;AAAA,UAAc7F,OAAO;AAAA,UAAckG,MAAM;AAAA,QAAA,GAClD;AAAA,UAAEL,OAAO;AAAA,UAAU7F,OAAO;AAAA,UAAUkG,MAAM;AAAA,QAAA,GAC1C;AAAA,UAAEL,OAAO;AAAA,UAAY7F,OAAO;AAAA,UAAYkG,MAAM;AAAA,QAAA,CAHvC;AAAA,QAKTC,cAAc;AAAA,MAAA,CAPL;AAAA,MASXma,QAAQxa,KAAW;AAAA,QACjBM,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAIqG,MAAM;AAAA,UAAnB;AAAA,QAAA,CAA/B;AAAA,QACRR,OAAO;AAAA,QACPY,KAAK;AAAA,QACLpJ,KAAK;AAAA,QACLqJ,MAAM;AAAA,QACNP,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAGqG,MAAM;AAAA,QAAlB;AAAA,MAAA,CANR;AAAA,MAQRrJ,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OAAa;AAAA,QACnBM,QAAQ,CACN;AAAA,UACEnG,UAAU;AAAA,UACVD,OAAO;AAAA,YACLuE,WAAW;AAAA,cAAEvE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YADzB;AAAA,YAEL7B,aAAa;AAAA,YACbC,cAAc;AAAA,cAAEzE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAH5B;AAAA,YAIL3B,YAAY;AAAA,UAJP;AAAA,QAAA,CAHH;AAAA,MAAA,CADF;AAAA,IA1GH;AAAA,EAAA,CAJF;AA6HR;AC9QM,uBACL,cAC+B;AAC/B,QAAM,EAAE,OAAO,SAAS,SAAS,oBAAoB;AAAA,IACnD,MAAM,gBAAgB;AAAA,IACtB,WAAW,EAAE,KAAK,gBAAgB,OAAO,CAAC,YAAY,IAAI,GAAG;AAAA,EAAA,CAC9D;AAEG,MAAA,gBAAgB,QAAQ,SAAS;AAAa,WAAA;AAElD,SAAO,6BAAM,aAAa;AAC5B;ACVA,MAAM,SAAS,CAA2C,GAAM,MAAS,EAAE,OAAO,CAAC;AACnF,MAAM,cAAc,CAAC,EAAE,OAAO,EAAE,cAAmB,SAAS,MAAM;AAClE,MAAM,cAAc,CAAC,EAAE,eAAoB;AAE3C,MAAM,YACJ,CAAC,aACD,CAAC,OAAwD;AAAxD,eAAS,EAAP,OAAO,OAAT,IAAS,SAAE,YAAF,IAAY,wBAAZ,IAAY,CAAV,WAA4B,iBAAvC,IAAuC,CAArC;AAAsD,0CACpD,OADoD;AAAA,IAEvD,OAAO,kCACF,cACC,QACA;AAAA,MACE,OAAO;AAAA,QACL,QAAQ,SAAS,KAAK,CAAC,MAAW,KAAK,EAAE,OAAO,MAAM,QAAQ;AAAA,QAC9D,OAAO,MAAM;AAAA,MACf;AAAA,IAAA,IAEF,CAAC;AAAA,EAET;AAAA;AAEW,MAAA,0BAA0B,CACrC,QACA,aAC6B;AAC7B,QAAM,UAAU,CAAC,GAAG,IAAI,IAAI,OAAO,IAAI,WAAW,EAAE,OAAO,SAAS,IAAI,WAAW,CAAC,CAAC,CAAC;AAE/E,SAAA,QAAQ,IAAI,CAAC,aAAmB;AAAA,IACrC;AAAA,IACA,OAAO,kCACD,oBAAmB,QAAQ,QAAQ,KAAK,EAAE,OAAO,MAAM,QACvD,oBAAmB,UAAU,UAAU,CAAK,MAAA,CAAC,KAAK,EAAE,OAAO,CAAC,EAAA,GAAK;AAAA,EAEvE,EAAA;AACJ;AAEA,2BACE,OACuC;AACvC,QAAM,aAAa,cAAc,SAAS,MAAM,EAAE;AAElD,QAAM,YAAY;AAAA,IACf,cAAc,WAAW,MAAM,IAAI,WAAW,KAAM,CAAC;AAAA,IACrD,SAAS,MAAM,MAAM,IAAI,WAAW,KAAM,CAAC;AAAA,EAE3C,EAAA,OAAO,MAAM,EACb,OAAO,OAAO;AAEX,QAAA,EAAE,OAAO,YAAY,MAAM,YAAY,OAAO,SAAS,gBAAgB;AAAA,IAC3E,MAAM,aAAa,QAAQ,UAAU,WAAW;AAAA,IAChD,WAAW,EAAE,KAAK,UAAU;AAAA,EAAA,CAC7B;AAEK,QAAA,EAAE,WAAW,OAAO;AAE1B,MAAI,cAAc;AAAa,WAAA;AAExB,SAAA,wBACJ,cAAc,WAAW,MAAM,IAAI,UAAU,QAAQ,CAAC,KAAM,IAC5D,SAAS,MAAM,MAAM,IAAI,UAAU,QAAQ,CAAC,KAAM,CAAA,CACrD;AACF;AC1EA,MAAMwhB,OAAOj3B,OAAO0pB;AAAAA,IAChBhZ,OACAC,cACE,CAACD,EAAEwmB,eAAH,GACA,CAAC,CACC;AAAA,EACEpnB;AAAAA,EACAqnB;AAAAA,EACAld;AAAAA,EACA+X;AAAAA,EACAoF;AAAAA,EACAlF;AAAAA,EACAmF;AAAAA,EACAC;AAAAA,EACAC;AAAAA,EACAC;AAAAA,IACE,CAAA,OACA3mB;AAAAA,UACFf,SAAS,OACP,KACAe;AAAAA,uBACWb,cAAcF,KAAD;AAAA;AAAA;AAAA,UAG1BqnB,cAAc,OACZ,KACAtmB;AAAAA,8BACkBsmB;AAAAA;AAAAA;AAAAA,UAGpBld,YAAY,QAAQA,SAASlJ,SAAS,QAAQkJ,SAAS7C,QAAQ,OAC7D,KACAvG;AAAAA,2BACgB,GAAEoJ,SAASlJ,QAAQkJ,SAAS7C;AAAAA;AAAAA;AAAAA,UAG9C4a,cAAc,OACZ,KACAnhB;AAAAA,6BACiBmhB;AAAAA;AAAAA;AAAAA,UAGnBoF,cAAc,OACZ,KACAvmB;AAAAA,6BACiBumB;AAAAA;AAAAA;AAAAA,UAGnBlF,iBAAiB,OACf,KACArhB;AAAAA,gCACoBqhB,gBAAgB;AAAA;AAAA;AAAA,UAGtCoF,aAAa,QAAQC,iBAAiB,OACpC,KACA1mB;AAAAA,iCACqB,CACjB4mB,QAAQH,SAAD,KAAe,aACtBG,QAAQF,aAAD,KAAmB,cAFT,EAIhB7xB,OAAO+xB,OAJS,EAKhBnuB,KAAK,GALW;AAAA;AAAA;AAAA,UAQvB+tB,aAAa,OACX,KACAxmB;AAAAA,gCACoBwmB,cAAc,OAAO,cAAc;AAAA;AAAA;AAAA,UAGzDG,UAAU,OACR,KACA3mB;AAAAA,4BACgB2mB,WAAW,OAAO,WAAW;AAAA;AAAA,SAGnDE,qBA3EW;AAAA;AAmFY,cAAA,IAA+C;AAA/C,eAAE3mB;AAAAA;AAAAA,MAAF,IAAY1Q,wBAAZ,IAAYA;AAAAA,IAAV0Q;AAAAA;AACvBmmB,QAAAA,kBAAkBS,kBAAkB5mB,KAAD;AAElC,6BAAC,MAAD,iCAAU1Q,cAAV;AAAA,IAAuB;AAAA,EAAA,EAA9B;AACD;ACrGD,MAAMu3B,kBAAkB;AAEqC,sCAAA;AACpD,SAAA;AAAA,IACLC,WAAW;AAAA,MAAEC;AAAAA,MAAMxzB;AAAAA,OAAYyzB,SAASC,MAAM;AACxCF,UAAAA,KAAK1yB,SAASwyB,iBAAiB;AACjC,mCAAQ,MAAD;AAAA,UAAM,OAAOE,KAAK90B,KAAKi1B,IAAI,OAAd;AAAA,UAAyB3zB;AAAAA,QAAAA,CAA7C;AAAA,MACD;AAED,aAAO0zB,KAAP;AAAA,IACD;AAAA,EAAA;AAEJ;ACLD,MAAME,cAAcl4B,OAAOC;AAAAA;AAAAA,IAEvByQ,CAAAA,MACAC,cAAc,CAACD,EAAEynB,SAAH,GAAwB,CAAC,CAACA,eACtCA,aAAa,OACTtnB,QACAA;AAAAA,0BACgBsnB;AAAAA,WAJT;AAAA;AAAA,IAQbznB,CAAAA,MACAA,EAAE0nB,OAAO,eACLvnB;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,YAMA;AAAA;AAKR,IAAA,QAAe1Q,WAAkC,gBAC/C,KACAC,KACA;AAFA,iBAAE+3B;AAAAA;AAAAA,MAAF,KAAgB93B,wBAAhB,KAAgBA;AAAAA,IAAd83B;AAAAA;AAGK,6BAAC,aAAD,iCAAiB93B,cAAjB;AAAA,IAA8B;AAAA,IAAU;AAAA,EAAA,EAA/C;AACD,CALwB;AC/BoC,sCAAA;AACpD,SAAA;AAAA,IACLg4B,YAAYtyB,OAAOgyB,SAASC,MAAmB;AACvC,YAAA;AAAA,QAAEpS;AAAAA,QAAMY;AAAAA,QAAYliB;AAAAA,UAAayB;AACvC,YAAMuyB,aAAa;AAAA,QAAEH,WAAWvS,KAAK5iB,KAAKi1B,IAAI,WAAd;AAAA,MAAA;AAExBrS,cAAAA,KAAKxgB;AAAAA,aACN;AAED,qCAAC,OAAD,gDAAWohB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA,aAMG;AAED,qCAAC,OAAD,gDAAWkiB,aAAgB8R,aAA3B;AAAA,YAAuC,IAAG;AAAA,YACvCh0B;AAAAA,UAAAA,EAFL;AAAA;AAOA,iBAAO0zB,KAAP;AAAA;AAAA,IAEL;AAAA,EAAA;AAEJ;ACnED,MAAM/E,aAAajzB,OAAO2X,IAAD;AAAA;AAAA;AAIoB,sBAAA;AACpC,SAAA;AAAA,IACL4gB,aAAaxyB,OAAOgyB,SAASC,MAAM;AAC3B,YAAA;AAAA,QAAExR;AAAAA,QAAYliB;AAAAA,QAAUshB;AAAAA,UAAS7f;AAE/B6f,cAAAA,KAAKxgB;AAAAA,aACN,QAAQ;AACL,gBAAA;AAAA,YAAEpC;AAAAA,cAAS4iB;AAGf,qCAAC,YAAD,iCAAgBY,aAAhB;AAAA,YAA4B,MAAMxjB,KAAKw1B,KAAvC;AAAA,YACGl0B;AAAAA,UAAAA,EAFL;AAAA,QAKD;AAAA,iBAEQ;AACP,iBAAO0zB,KAAP;AAAA,QACD;AAAA;AAAA,IAEJ;AAAA,EAAA;AAEJ;AC7ByC,mBAAA;AACjC,SAAA;AAAA,IACLO,aAAaxyB,OAAOgyB,SAASC,MAAM;AAC3B,YAAA;AAAA,QAAExR;AAAAA,QAAYliB;AAAAA,QAAUshB;AAAAA,UAAS7f;AAE/B6f,cAAAA,KAAKxgB;AAAAA,aACN,QAAQ;AACX,8EAAiBohB;YAAaliB;AAAAA,UAAAA,EAA9B;AAAA,QACD;AAAA,aAEI,eAAe;AAClB,6EAAgBkiB;YAAaliB;AAAAA,UAAAA,EAA7B;AAAA,QACD;AAAA,aAEI,aAAa;AAChB,6EAAgBkiB;YAAaliB;AAAAA,UAAAA,EAA7B;AAAA,QACD;AAAA,iBAEQ;AACP,iBAAO0zB,KAAP;AAAA,QACD;AAAA;AAAA,IAEJ;AAAA,EAAA;AAEJ;ACTYS,MAAAA,iBAAiBz4B,OAC5BG,WAA+B,yBAC7B,KACAC,KACA;AAFA,iBAAEsb;AAAAA,gCAAc;AAAA,MAAhB,KAAyCrb,wBAAzC,KAAyCA;AAAAA,IAAvCqb;AAAAA;AAGIgd,QAAAA,UAAU1K,QACd,MAAM,CAAC2K,SAAShhB,WAAI,GAAIihB,QAAO,GAAIC,2BAAyBC,GAAAA,2BAAAA,CAAtD,GACN,CAFqB,CAAA;AAMrB,6BAACC,QAAD,iCACM14B,cADN;AAAA,IAEE;AAAA,IACA,WAAW;AAAA,IACX;AAAA,IACA;AAAA,EAAA,EANJ;AASD,CAlBS,CADwB;AAAA;AAAA;AAAA;AAAA;AAAA;ACwBpC,MAAM24B,uBAAuBh5B,OAAOy4B,cAAD,EAAiB/lB,WAAW;AAAA,EAC7DC,mBAAmBC,UAAQ,CAAC,CAAC,QAAD,EAAWC,SAASD,KAAKvP,UAAzB;AADiC,CAAlC;AAAA,IAGzByP,UAAY;AAAA;AAGhB,MAAMmmB,cAAyB;AAAA,EAC7Bzf,UAAU;AAAA,IAAEyM,OAAO,CAAC;AAAA,MAAEiT,QAAQ;AAAA,MAAkB9zB,MAAM;AAAA,MAAsB6gB,OAAO,CAAA;AAAA,IAAA,CAAhE;AAAA,EADU;AAAA,EAE7BjjB,MAAM,CAAA;AAFuB;AAK/B,MAAMm2B,wBAAwB;AAIxBC,MAAAA,OAAOj5B,WAAW,eACtB;AAAA,EAAEa;AAAAA,EAAIq4B;AAAAA,EAAMtrB;AAAAA,EAAO2F;AAAAA,GACnBtT,KACA;AACA,QAAM,CAACk5B,QAAQC,aAAa/yB,SAAwB,IAAhB;AACpC,QAAM,CAAC+nB,iBAAiBC,sBACtBhoB,SAAyD,IAAjD;AACV,QAAMuoB,aAAaR,mDAAiB8K;AAEpChnB,sBACEjS,KACA,MAAO;AAAA,IACLiU,cAAc;AACZ,YAAMmlB,KAAKF,iCAAQG,YAAY,CAApB;AAEJD,aAAAA,cAAcrjB,UAAUmZ,OAAOkK,EAAD,IAAO;AAAA,IAJzC;AAAA,IAMLhL;AAAAA,EAEF,IAAA,CAAC8K,QAAQ9K,kBAAT,CAViB;AAanB/nB,YAAU,MAAM;AACV6yB,QAAAA;AAAQvK,+CAAY2K,eAAeJ;AAAAA,EAA3B,GACX,CAACvK,YAAYuK,MAAb,CAFM;AAqBT,QAAM,CAACvoB,OAAO4oB,YAAYnzB,SAAS,MAAM;AACjC,UAAyC6yB,2BAAQJ,aAA/CW;AAAAA;AAAAA,QAAuCP,IAAzBQ,iCAAyBR,IAAzBQ;AAAAA,MAAdD;AAAAA;AAEDE,WAAAA,MAAMC,SAASF,oBAAf;AAAA,EAAA,CAHyB;AAK5B,QAAA,CAACG,cAAcC,mBAAmBzzB,SAAS,IAAD;AAEhDC,YAAU,MAAM;AACd,QAAIuzB,cAAc;AACVE,YAAAA,YAAYJ,MAAMC,SAASV,sBAAQJ,WAAvB;AAElBU,eAASQ,kBACPA,aAAaP,UAAUQ,YACnBN,MAAMC,SAASG,UAAUG,OAAO;AAAA,QAAEC,mBAAmB;AAAA,MAAA,CAAtC,CAAf,IACAJ,SAHE;AAAA,IAKT;AAAA,EAAA,GACA,CAACF,cAAcX,IAAf,CAVM;AAYT5yB,YAAU,MAAM;AACVuzB,QAAAA;AAAc;AAEZzK,UAAAA,YAAYgL,OAAO/K,WAAW,MAAM;AACxCyK,sBAAgB,IAAD;AAAA,OACdd,qBAFe;AAIlB,WAAO,MAAM;AACXoB,aAAO9K,aAAaF,SAApB;AAAA,IAAA;AAAA,EADF,GAGC,CAACyK,YAAD,CAVM;AAYT,wBAAsBQ,QAAuB;AAC3Cb,aAASa,OAAOzpB,KAAhB;AAEIypB,QAAAA,OAAOzpB,UAAUA,OAAO;AAC1BkpB,sBAAgB,KAAD;AAEflL,+CAAY9E,SAASuQ;AAAAA,IACtB;AAAA,EACF;AAIKC,QAAAA,iBAAiB1vB,OAAOgkB,UAAD;AACzB0L,MAAAA,eAAervB,YAAY2jB;AAAY0L,mBAAervB,UAAU2jB;AAC9D2L,QAAAA,cAAc7xB,YAAY,MAAM;;AACpC4xB,yBAAervB,YAAfqvB,mBAAwBE;AAAAA,EADK,GAE5B,CAF4B,CAAA;AAG/B,QAAMC,gBAAgB/xB,YACpB,CAACiQ,OAA2Bif,SAAiBC,SAAoB;;AAC3D6C,QAAAA,QAAQC,OAAOhiB,KAAf,GAAuB;AACzB2hB,2BAAervB,YAAfqvB,mBAAwBM;AAEjB,aAAA;AAAA,IACR;AAEGF,QAAAA,QAAQG,OAAOliB,KAAf,GAAuB;AACzB2hB,2BAAervB,YAAfqvB,mBAAwBQ;AAEjB,aAAA;AAAA,IACR;AAED,QAAIC,SAAS,QAAD,EAAWpiB,KAAnB,GAA2B;AAC7B2hB,2BAAervB,YAAfqvB,mBAAwBU;AAEjB,aAAA;AAAA,IACR;AAED,WAAOnD,KAAP;AAAA,EApB6B,GAsB/B,CAtB+B,CAAA;AAyB3Bta,QAAAA,cAAcC;AAGlB,6BAAC,sBAAD;AAAA,IAEE;AAAA,IACA,KAAK4b;AAAAA,IACL,WAAWxjB,GAAGhI,KAAD;AAAA,IACb,UAAU,CAAC2P;AAAAA,IACX;AAAA,IACA;AAAA,IACA,UAAUiM;AAAAA,IACV,SAAS+Q;AAAAA,IACT,WAAWE;AAAAA,IAEX,QAAQzxB,CAAKA,MAAAA,EAAE+P,eAAF;AAAA,EAAA,CAbjB;AAgBD,CAtIsB;AA0IhB,6BAA2B7C,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkByiB,MAAM;AAAA,IACrCh0B,MAAM;AAAA,IACNwR,OAAO;AAAA,IACP7Q,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAELwiB,MAAMxiB,SAAe,MAAO;AAAA,QAC1BM,QAAQ;AAAA,UACNqC,UAAU;AAAA,YACRyM,OAAO,CACL;AAAA,cACEiT,QAAQ;AAAA,cACR9zB,MAAM;AAAA,cACN6gB,OAAO,CACL;AAAA,gBACEiT,QAAQ;AAAA,gBACRG,MAAM+B,MAAM,CAAD;AAAA,gBACXC,OAAO,CACL;AAAA,kBACEnC,QAAQ;AAAA,kBACR9zB,MAAM;AAAA,kBACNpC,MAAM;AAAA,oBACJ+N,OAAO;AAAA,sBACL/P,IAAI;AAAA,sBACJiM,OAAO,CACL;AAAA,wBACE+D,UAAU;AAAA,wBACVD,OAAO;AAAA,0BAAEkJ,UAAU;AAAA,4BAAElJ,OAAO;AAAA,4BAAIqG,MAAM;AAAA,0BAAnB;AAAA,wBAAZ;AAAA,sBAAA,GAET;AAAA,wBACEpG,UAAU;AAAA,wBACVD,OAAO;AAAA,0BACLihB,YAAY;AAAA,0BACZ/X,UAAU;AAAA,4BAAElJ,OAAO;AAAA,4BAAIqG,MAAM;AAAA,0BAFxB;AAAA,0BAGLggB,YAAY;AAAA,wBAHP;AAAA,sBAAA,CAPJ;AAAA,oBAFF;AAAA,kBADH;AAAA,gBAAA,CAJH;AAAA,cAAA,CAJJ;AAAA,YAAA,CAJJ;AAAA,UADC;AAAA,QADJ;AAAA,MAAA,EADJ;AAAA,MA2CNrpB,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BG,QAAQ,CAAC;AAAA,UAAEnG,UAAU;AAAA,UAAWD,OAAO;AAAA,YAAEA,OAAO;AAAA,YAAKqG,MAAM;AAAA,UAApB;AAAA,QAAA,CAA/B;AAAA,QACRF,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAHT;AAAA,MAKP1D,QAAQmD,OAAa;AAAA,QACnBM,QAAQ,CACN;AAAA,UACEnG,UAAU;AAAA,UACVD,OAAO;AAAA,YACLuE,WAAW;AAAA,YACXC,aAAa;AAAA,YACbC,cAAc;AAAA,cAAEzE,OAAO;AAAA,cAAIqG,MAAM;AAAA,YAH5B;AAAA,YAIL3B,YAAY;AAAA,UAJP;AAAA,QAAA,CAHH;AAAA,MAAA,CADF;AAAA,IAlDH;AAAA,EAAA,CAHF;AAoER;AC/OD,MAAMlI,YAAYvN,OAAOC,IAAIyS,WAAW;AAAA,EACtCC,mBAAmBC,CAAQ,SAAA,CAAC,CAAC,UAAU,cAAX,EAA2BC,SAASD,KAAKvP,UAAzC;AADU,CAAtB;AAAA;AAAA;AAAA;AAAA,IAMdyP,UAAY;AAAA,IACZC,gBAAkB;AAAA;AAGtB,MAAMuoB,eAAe,KAAK;AAE1B,MAAMC,QAAQp7B,WAAW,gBACvB;AAAA,EAAEa;AAAAA,EAAIw6B;AAAAA,EAAOztB;AAAAA,EAAO2F;AAAAA,EAAQG;AAAAA,GAC5BzT,KACA;AACMq7B,QAAAA,aAAaD,SAASA,MAAMntB,OAAO,QAAQO,YAAYC,QAAQ2sB,MAAMntB,GAA1B;AAEjD,6BACG,WAAD;AAAA,IAAW;AAAA,IAAU;AAAA,IAAQ,WAAW0H,GAAGhI,KAAD;AAAA,IAAS;AAAA,IAAgB;AAAA,IACjE,8BAAA,OAAA;AAAA,MAAK,OAAO;AAAA,QAAEZ,UAAU;AAAA,QAAY2H,YAAa,GAAE,MAAMwmB;AAAAA,MAAzD;AAAA,MACE,8BAAA,OAAA;AAAA,QAAK,OAAO;AAAA,UAAEnuB,UAAU;AAAA,UAAYxB,KAAK;AAAA,UAAGyB,MAAM;AAAA,UAAGC,OAAO;AAAA,UAAGxB,QAAQ;AAAA,QAAvE;AAAA,QAAA,UACG4vB,eAAe,OACdl3B,oBAAC,8CACKi3B;UACJ,OAAM;AAAA,UACN,QAAO;AAAA,UACP,QAAQ;AAAA,YACNzsB,OAAO;AAAA,cAAEC,eAAe;AAAA,gBAAEC,YAAYusB,SAAS,QAAQ,CAACA,MAAME;AAAAA,cAAtC;AAAA,YADlB;AAAA,YAENpsB,QAAQ;AAAA,cACNtL,SAAS;AAAA,gBACPuL,kBAAkBisB,SAAS,QAAQA,MAAMG,SAAS,OAAO,SAAS;AAAA,cAD3D;AAAA,YADH;AAAA,UAFF;AAAA,QAAA,EAJV,IAcAp3B,oBAAA,OAAA;AAAA,UAAK,OAAM;AAAA,UAAO,KAAK2Y,aAAase,MAAM5f;AAAAA,UAAK,KAAI;AAAA,QAAA,CAAnD;AAAA,MAAA,CAhBJ;AAAA,IAAA,CADF;AAAA,EAAA,CAFJ;AAyBD,CA/BuB;AAmCjB,2BAA2BvF,SAAuB;AAChDA,SAAAA,QAAQM,kBAAkB4kB,OAAO;AAAA,IACtCn2B,MAAM;AAAA,IACNwR,OAAO;AAAA,IACPK,MAAM;AAAA,IACNlR,OAAO;AAAA,MACL/E,IAAI6V,UADC;AAAA,MAEL2kB,OAAO3kB,QAAY;AAAA,QAAEM,QAAQ;AAAA,UAAEukB,UAAU;AAAA,QAAZ;AAAA,MAAA,CAAtB;AAAA,MACP3tB,OAAO8I,MAAY;AAAA,QACjBC,QAAQD,MAAYE,QAAQC;AAAAA,QAC5BE,cAAc;AAAA,UAAEnG,OAAO;AAAA,UAAKqG,MAAM;AAAA,QAApB;AAAA,MAAA,CAFT;AAAA,MAIP1D,QAAQmD,OAPH;AAAA,MAQLhD,cAAcgD,aAAA;AAAA,IART;AAAA,EAAA,CAJF;AAeR;AC1DM,mCAAmC,SAAuB;AACzD,QAAA,yBAAyB+kB,oBAAqB,OAAO;AACrD,QAAA,4BAA4BC,oBAAwB,OAAO;AAC3D,QAAA,8BAA8BC,oBAA0B,OAAO;AAC/D,QAAA,+BAA+BC,oBAA2B,OAAO;AACjE,QAAA,6BAA6BC,oBAAyB,OAAO;AAC7D,QAAA,2BAA2BC,oBAAuB,OAAO;AACzD,QAAA,0BAA0BC,oBAAsB,OAAO;AACvD,QAAA,2BAA2BC,oBAAuB,OAAO;AACzD,QAAA,gCAAgCC,oBAA4B,OAAO;AACnE,QAAA,0BAA0BC,oBAAsB,OAAO;AACvD,QAAA,iCAAiCC,oBAA6B,OAAO;AACrE,QAAA,0BAA0BC,oBAAsB,OAAO;AACvD,QAAA,2BAA2BC,kBAAuB,OAAO;AAE/D,SAAO,MAAM;AACY;AACG;AACE;AACC;AACF;AACF;AACD;AACC;AACK;AACN;AACO;AACP;AACA;AACC;EAAA;AAE7B;AC1DA,MAAMvX,aAAa;AAOS,qBAAA;AAAA,EAAEwX;AAAAA,EAAMC;AAAAA,GAAwB;AAC1Dj2B,YAAU,MAAM;AACRiD,UAAAA,YAAY8P,SAAS8M,cAAc,KAAvB;AAElB5c,cAAUizB,YAAYF;AAEhBlX,UAAAA,SAAS/L,SAASgM,iBAAiB9b,WAAW+b,WAAWC,YAAhD;AACf,UAAMkX,UAA+B,CAAA;AAE9BrX,WAAAA,OAAOW,YAAY;AACxB,UAAIX,OAAOa,uBAAuByW;AAA2B1W,gBAAAA,KAAKZ,OAAOa,WAApB;AAAA,IACtD;AAEDwW,YAAQ35B,QAAQ65B,CAAgB,iBAAA;;AACxBC,YAAAA,mBAAmBvjB,SAAS8M,cAAcrB,UAAvB;AAEzB8X,uBAAiBxW,cAAcuW,aAAavW;AAC5C9D,YAAMrf,KAAK05B,aAAatW,UAAxB,EAAoCvjB,QAAQ,CAAC;AAAA,QAAEwjB;AAAAA,QAAM1V;AAAAA,YAAY;AAC9C2V,yBAAAA,aAAaD,MAAM1V,KAApC;AAAA,MAAA,CADF;AAIa4V,yBAAAA,eAAAA,mBAAYqW,aAAaD,kBAAkBD;AAAAA,IAAxD,CARF;AAWM7W,UAAAA,QAAQxD,MAAMrf,KAAKsG,UAAUuzB,UAArB;AAELvkB,aAAAA,KAAKwkB,OAAO,GAAGjX,KAAxB;AAEA,WAAO,MAAM;AACXA,YAAMhjB,QAAQ2iB,CAAQ,SAAA;;AACfe,mBAAAA,eAAAA,mBAAYE,YAAYjB;AAAAA,MAA7B,CADF;AAII8W,UAAAA,WAAW;AAAM;AAEfS,YAAAA,UAAU,IAAIC,SAASV,OAAb;AAEZ,UAAA;AACK;MAAA,QACP;AAAA,MAED;AAAA,IAAA;AAAA,EAbH,GAeC,CAACD,MAAMC,OAAP,CA1CM;AA4CF,SAAA;AACR;ACvDD,YAA2B,GAAY,GAAqB;AAC1D,MAAI,MAAM;AAAG,WAAO,MAAM,KAAK,MAAM,KAAK,IAAI,MAAM,IAAI;AAEjD,SAAA,MAAM,KAAK,MAAM;AAC1B;ACFA,MAAM,kBAAEW,qBAAmB,OAAO;AAElC,MAAM,eAAe,CAAC,GAAY,MAAwB;AACpD,MAAA,GAAG,GAAG,CAAC;AAAU,WAAA;AAEjB,MAAA,OAAO,MAAM,YAAY,MAAM,QAAQ,OAAO,MAAM,YAAY,MAAM;AAAa,WAAA;AAEjF,QAAA,QAAQ,OAAO,KAAK,CAAC;AACrB,QAAA,QAAQ,OAAO,KAAK,CAAC;AAEvB,MAAA,MAAM,WAAW,MAAM;AAAe,WAAA;AAE1C,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK,GAAG;AAExC,QAAI,CAACA,iBAAe,KAAK,GAAG,MAAM,EAAE,KAAK,CAAC,GAAG,EAAE,MAAM,KAAK,EAAE,MAAM,GAAG;AAAU,aAAA;AAAA,EACjF;AAEO,SAAA;AACT;AClBA,MAAM,EAAE,mBAAmB,OAAO;AAE5B,MAAA,YAAY,CAAC,GAAY,MAAwB;AACjD,MAAA,aAAa,GAAG,CAAC;AAAU,WAAA;AAE3B,MAAA,OAAO,MAAM,YAAY,MAAM,QAAQ,OAAO,MAAM,YAAY,MAAM;AAAa,WAAA;AAEjF,QAAA,QAAQ,OAAO,KAAK,CAAC;AACrB,QAAA,QAAQ,OAAO,KAAK,CAAC;AAEvB,MAAA,MAAM,WAAW,MAAM;AAAe,WAAA;AAE1C,WAAS,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK,GAAG;AACxC,QACE,CAAC,eAAe,KAAK,GAAG,MAAM,EAAE,KAEhC,CAAC,UAAU,EAAE,MAAM,KAAK,EAAE,MAAM,GAAG;AAE5B,aAAA;AAAA,EACX;AAEO,SAAA;AACT;ACwBA,MAAMC,iBAAiB;AAAA,EACrBC,UAAU;AAAA,EACVlsB,WACE;AAHmB;AAOvB,MAAMmsB,kBAAkB;AAExB,MAAMC,2BAA2B,CAC/B,SACA,QACA,QACA,SACA,QACA,UACA,YACA,UAR+B;AAWjC,0BAA0BC,SAAkE;AAC1F,SAAOnrB,SAASxR,IAAI8T,QAAM6oB,QAAQjB,IAAT,GAAgBj6B,CAAW,YAAA;AAClD,QAAI,OAAOA,YAAY;AAAiBA,aAAAA;AAEpC,QAAA,CAACg7B,gBAAgB/yB,KAAKjI,QAAQ4C,IAA7B;AAA2C,aAAA;AAE1CgE,UAAAA,MAAM5G,QAAQ4G,MAAO,GAAEs0B,QAAQ18B,MAAMwB,QAAQ4G,QAAQs0B,QAAQ18B;AAE5DslB,WAAAA,cAAc9jB,QAAQ4C,MAAM,iCAAK5C,QAAQuD,QAAb;AAAA,MAAoBqD;AAAAA,IAAAA,EAAnC;AAAA,EAAA,CAPf;AASR;AAED,MAAMu0B,8BAA8B,CAAC;AAAA,EACnClB;AAAAA,EACAmB;AAAAA,EACAC;AAAAA,EACAxuB;AAAAA,EACAqtB;AAAAA,MACc;AAAA,EACdD;AAAAA,EACAmB;AAAAA,EACAC;AAAAA,EACAxuB;AAAAA,EACAqtB;AALc;AAaT,MAAMoB,sBAAsBzQ;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAmC5B,MAAM0Q,mBAAmB1Q;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAqBX,eAAA;AAAA,EAAE7rB;AAAAA,EAAMw8B,UAAU;AAAA,GAA6B;;AAC5DtgB,QAAAA,cAAcC;AACpB,QAAM,CAACsgB,UAAUC,eAAe13B,SAAShF,KAAKy8B,QAAN;AAKxCE,WAA4CL,qBAAqB;AAAA,IAC/D/6B,WAAW;AAAA,MAAE/B,IAAIQ,KAAKR;AAAAA,IADyC;AAAA,IAE/Do9B,MAAM1gB,gBAAgB;AAAA,IACtB2gB,aAAa;AAAA,IACbC,YAAYt7B,MAAM;AACZA,UAAAA,QAAQ;AAAM;AAEZu7B,YAAAA,cAAcN,SAASl9B,IAAI48B,2BAAb;AACda,YAAAA,cAAcx7B,KAAKxB,KAAKy8B,SAASl9B,IAAI48B,2BAAvB;AAEhBc,UAAAA,UAAUD,aAAaD,WAAd;AAA4B;AAE7Bv7B,kBAAAA,KAAKxB,KAAKy8B,QAAX;AAAA,IACZ;AAAA,EAAA,CAbK;AAeF,QAAA;AAAA,IAAEj7B,MAAM07B;AAAAA,MAAaP,SAA6BJ,kBAAkB;AAAA,IACxEh7B,WAAW;AAAA,MAAE/B,IAAIQ,KAAKC,KAAKT;AAAAA,IAD6C;AAAA,IAExEo9B,MAAM1gB,gBAAgB;AAAA,IACtB2gB,aAAa;AAAA,EAAA,CAHoB;AAM7BM,QAAAA,UAAUn9B,WAAKo9B,KAAKD,YAAVn9B,YAAqB87B;AAC/B,QAAA;AAAA,IAAEuB;AAAAA,IAAOC;AAAAA,IAAaC;AAAAA,IAAUC;AAAAA,MAAgBx9B,KAAKo9B;AACrD,QAAA;AAAA,IAAEK;AAAAA,IAAcC;AAAAA,MAAsB19B,KAAK29B;AAE3CC,QAAAA,uBAAuBpR,QAAQ,MAAM;AACrC0Q,QAAAA,sCAAUj9B,SAAQ,MAAM;AACnBD,aAAAA,KAAK69B,MACTt+B,IAAI,CAAC;AAAA,QAAEu+B;AAAAA,QAAQz1B;AAAAA,YAAe;AAC7B,eAAQ,GAAEy1B,OAAOC,QAAQ,MAAM,GAArB,KAA6B11B,SAASP;OAF7C,EAIJA,KAAK,GAJD;AAAA,IAKR;AAEMo1B,WAAAA,SAASj9B,KAAK+9B,YAAYC,MAC9B/5B,OAAO,CAACg6B,SAA2CA,QAAQ,IADvD,EAEJ3+B,IAAI,CAAC;AAAA,MAAE4+B;AAAAA,MAAgB/Z,MAAM;AAAA,QAAE0Z;AAAAA,QAAQz1B;AAAAA;AAAAA,UAAiB;AACvD,YAAM+1B,0BAA0B/1B,SAC7BnE,OAAOoD,aACN62B,eAAeE,KAAKC,mBAAiBA,cAAcC,cAAcj3B,QAAQi3B,SAAzE,CAF4B,EAI7Bh/B,IAAI+H,aAAWA,QAAQi3B,SAJM,EAK7Bz2B;AAEK,aAAA,GAAEg2B,OAAOC,QAAQ,MAAM,GAArB,KAA6BK;AAAAA,IAAAA,CAVpC,EAYJt2B,KAAK,GAZD;AAAA,EAAA,GAaN,CAACo1B,UAAUl9B,IAAX,CAtBiC;AAwB9Bw+B,QAAAA,mBAAmBhS,QACvB,MAAMiQ,SAASv4B,OAAOg4B,CAAYM,YAAAA,UAAUN,QAAQE,iBAAiBF,QAAQG,WAAvE,GACN,CAACI,QAAD,CAF8B;AAI1BgC,QAAAA,eAAejS,QACnB,MAAMgS,iBAAiBt6B,OAAOg4B,CAAAA,YAAWA,QAAQruB,aAAa6wB,MAAxD,GACN,CAACF,gBAAD,CAF0B;AAKtBG,QAAAA,uBAAuBp1B,OAAoC,IAA9B;AACnCtE,YAAU,MAAM;;AACR25B,UAAAA,qDAA8Ch1B,yBAAW,IAC5D1F,OAAO26B,CAAAA,oBAAmBA,gBAAgB3D,WAAW,IAD1B,EAE3Bh3B,OAAO26B,CAAAA,oBAAmB,CAACJ,aAAaJ,KAAKnC,aAAW2C,gBAAgBr/B,OAAO08B,QAAQ18B,EAA5D,CAFA;AAI9Bo/B,0BAAsBn9B,QAAQq9B,CAAoB,qBAAA;AAChD,UAAIA,iBAAiB5D,WAAW;AAAM;AAEhCS,YAAAA,UAAU,IAAIC,SAASkD,iBAAiB5D,OAA9B;AAEZ,UAAA;AACK;MAAA,QACP;AAAA,MAED;AAAA,IAAA,CATH;AAYAyD,yBAAqB/0B,UAAU60B;AAAAA,EAAAA,GAC9B,CAACA,YAAD,CAlBM;AAqBP,8BAAAnxB,UAAA;AAAA,IAAA,UAAA,CACEyT,qBAAC,MAAD;AAAA,MACE,UAAA,CAAAhe,oBAAA,SAAA;AAAA,QACI,UAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAAA,CADJ,GAWAA,oBAAA,QAAA;AAAA,QAAM,KAAI;AAAA,QAAO,MAAMo6B,QAAQpB;AAAAA,QAAU,MAAMoB,QAAQttB;AAAAA,MAAAA,CAZzD,GAcG4tB,gBAAgB16B,oBAAA,QAAA;AAAA,QAAM,KAAI;AAAA,QAAY,MAAM06B;AAAAA,MAAAA,CAd/C,GAgBGC,qBAAqB36B,oBAAA,QAAA;AAAA,QAAM,MAAK;AAAA,QAAS,SAAQ;AAAA,MAAA,CAhBpD,GAkBGs6B,SACCtc,qBAAAzT,UAAA;AAAA,QACE,UAAA,CAAAvK,oBAAA,SAAA;AAAA,UAAQs6B,UAAAA;AAAAA,QAAAA,CAAR,GACAt6B,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAW,SAASs6B;AAAAA,QAAAA,CAAnC,GACAt6B,oBAAA,QAAA;AAAA,UAAM,MAAK;AAAA,UAAgB,SAASs6B;AAAAA,QAAAA,CAApC,GACAt6B,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAO,SAASs6B;AAAAA,QAAAA,CAJjC,CAAA;AAAA,MAAA,CAnBJ,GA2BGC,eACCvc,qBAAAzT,UAAA;AAAA,QACE,UAAA,CAAAvK,oBAAA,QAAA;AAAA,UAAM,MAAK;AAAA,UAAc,SAASu6B;AAAAA,QAAAA,CAAlC,GACAv6B,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAiB,SAASu6B;AAAAA,QAAAA,CAAzC,GACAv6B,oBAAA,QAAA;AAAA,UAAM,MAAK;AAAA,UAAsB,SAASu6B;AAAAA,QAAAA,CAA1C,GACAv6B,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAc,SAASu6B;AAAAA,QAAAA,CAJxC,CAAA;AAAA,MAAA,CA5BJ,GAoCGC,YAAYx6B,oBAAA,QAAA;AAAA,QAAM,MAAK;AAAA,QAAW,SAASw6B;AAAAA,MAAAA,CApC9C,GAsCGC,eACCzc,qBAAAzT,UAAA;AAAA,QACE,UAAA,CAAAvK,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAW,SAASy6B,YAAY3tB;AAAAA,QAAAA,CAA/C,GACA9M,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAgB,SAASy6B,YAAY3tB;AAAAA,QAAAA,CAApD,GACA9M,oBAAA,QAAA;AAAA,UAAM,MAAK;AAAA,UAAgB,SAASy6B,YAAY3tB;AAAAA,QAAAA,CAAhD,GACA9M,oBAAA,QAAA;AAAA,UAAM,MAAK;AAAA,UAAe,SAASy6B,YAAY3tB;AAAAA,QAAAA,CAA/C,GACA9M,oBAAA,QAAA;AAAA,UAAM,UAAS;AAAA,UAAQ,SAASy6B,YAAY3tB;AAAAA,QAAAA,CAL9C,CAAA;AAAA,MAAA,CAAA,GASD+tB,yBAAyB,0BACxBtwB,UAAA;AAAA,QACE,8BAAA,QAAA;AAAA,UACE,KAAI;AAAA,UACJ,MAAO,2CAA0CswB;AAAAA,QAAAA,CAFnD;AAAA,MADF,CAAA,GAQDa,aAAal/B,IAAIw/B,gBAAjB,EAAmCx/B,IAAIuD,CACtCiO,aAAAA,SAASxR,IAAIuD,UAAUwF,CAAS,UAAA;AAC9B,YAAI,OAAOA,UAAU;AAAiBA,iBAAAA;AAElC2zB,YAAAA,yBAAyB5qB,SAAS/I,MAAM1E,IAAxC;AAAgE0E,iBAAAA;AAE7D,eAAA;AAAA,MALT,CAAA,CADD,CAzDH;AAAA,IAAA,CADF,GAqEEvF,oBAAC,mBAAD;AAAA,MAAmB,mBAAmBi8B,wBAAwBh/B,KAAKR,EAAN;AAAA,IArE/D,CAAA,GAuEGg/B,iBACEt6B,OAAOg4B,CAAWA,YAAAA,QAAQruB,aAAa6wB,MAAAA,EACvCn/B,IAAI28B,CACH,YAAAn5B,oBAAC,aAAD;AAAA,MAA8B,MAAMm5B,QAAQjB;AAAAA,MAAM,SAASiB,QAAQhB;AAAAA,IAAAA,GAAjDgB,QAAQ18B,EAA1B,CAHH,CAvEH;AAAA,EAAA,CADF;AA+ED;AChUD,IAAI;AAEJ,oBAAoB;AAAE,aAAW,OAAO,UAAU,SAAU,QAAQ;AAAE,aAAS,IAAI,GAAG,IAAI,UAAU,QAAQ,KAAK;AAAE,UAAI,SAAS,UAAU;AAAI,eAAS,OAAO,QAAQ;AAAE,YAAI,OAAO,UAAU,eAAe,KAAK,QAAQ,GAAG,GAAG;AAAE,iBAAO,OAAO,OAAO;AAAA,QAAK;AAAA;IAAM;AAAC,WAAO;AAAA;AAAW,SAAO,SAAS,MAAM,MAAM,SAAS;AAAI;AAI7T,IAAI,eAAe,uBAAsB,OAAO;AAC9C,SAAoB,sBAAM,cAAc,OAAO,SAAS;AAAA,IACtD,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,SAAS;AAAA,IACT,OAAO;AAAA,EACX,GAAK,KAAK,GAAG,SAAU,SAAqB,sBAAM,cAAc,QAAQ;AAAA,IACpE,UAAU;AAAA,IACV,UAAU;AAAA,IACV,GAAG;AAAA,EACJ,CAAA,EAAE;AACL;ACbA,MAAMy/B,WAAWzgC,OAAO,KAAD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAmBV0gC,MAAAA,oBAAoBvgC,WAAW,4BAC1C;AAAA,EAAEk5B;AAAAA,GACFj5B,KACA;AACA,8BACG,UAAD;AAAA,IAAU;AAAA,IACR,UAAA,CAACmE,oBAAAo8B,cAAD,CAAA,CAAA,uBACA,QAAA;AAAA,MAAOtH,UAAAA;AAAAA,IAAAA,CAFT,CAAA;AAAA,EAAA,CADF;AAMD,CAV0C;ACpB3C,iBAAiB,KAAK;AAMpB,MAAI,IAAI;AAER,MAAI,GACA,IAAI,GACJ,MAAM,IAAI;AAEd,SAAO,OAAO,GAAG,EAAE,GAAG,OAAO,GAAG;AAC9B,QAAI,IAAI,WAAW,CAAC,IAAI,MAAQ,KAAI,WAAW,EAAE,CAAC,IAAI,QAAS,IAAK,KAAI,WAAW,EAAE,CAAC,IAAI,QAAS,KAAM,KAAI,WAAW,EAAE,CAAC,IAAI,QAAS;AACxI,QAEC,KAAI,SAAU,aAAe,QAAM,MAAM,SAAU;AACpD,SAEA,MAAM;AACN,QAEC,KAAI,SAAU,aAAe,QAAM,MAAM,SAAU,MAEnD,KAAI,SAAU,aAAe,QAAM,MAAM,SAAU;AAAA,EACrD;AAGD,UAAQ;AAAA,SACD;AACH,WAAM,KAAI,WAAW,IAAI,CAAC,IAAI,QAAS;AAAA,SAEpC;AACH,WAAM,KAAI,WAAW,IAAI,CAAC,IAAI,QAAS;AAAA,SAEpC;AACH,WAAK,IAAI,WAAW,CAAC,IAAI;AACzB,UAEC,KAAI,SAAU,aAAe,QAAM,MAAM,SAAU;AAAA;AAKxD,OAAK,MAAM;AACX,MAEC,KAAI,SAAU,aAAe,QAAM,MAAM,SAAU;AACpD,SAAS,MAAI,MAAM,QAAQ,GAAG,SAAS,EAAE;AAC3C;ACpDA,IAAI,eAAe;AAAA,EACjB,yBAAyB;AAAA,EACzB,mBAAmB;AAAA,EACnB,kBAAkB;AAAA,EAClB,kBAAkB;AAAA,EAClB,SAAS;AAAA,EACT,cAAc;AAAA,EACd,iBAAiB;AAAA,EACjB,aAAa;AAAA,EACb,SAAS;AAAA,EACT,MAAM;AAAA,EACN,UAAU;AAAA,EACV,cAAc;AAAA,EACd,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,WAAW;AAAA,EACX,SAAS;AAAA,EACT,YAAY;AAAA,EACZ,aAAa;AAAA,EACb,cAAc;AAAA,EACd,YAAY;AAAA,EACZ,eAAe;AAAA,EACf,gBAAgB;AAAA,EAChB,iBAAiB;AAAA,EACjB,WAAW;AAAA,EACX,eAAe;AAAA,EACf,cAAc;AAAA,EACd,kBAAkB;AAAA,EAClB,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,SAAS;AAAA,EACT,OAAO;AAAA,EACP,SAAS;AAAA,EACT,SAAS;AAAA,EACT,QAAQ;AAAA,EACR,QAAQ;AAAA,EACR,MAAM;AAAA,EACN,iBAAiB;AAAA,EAEjB,aAAa;AAAA,EACb,cAAc;AAAA,EACd,aAAa;AAAA,EACb,iBAAiB;AAAA,EACjB,kBAAkB;AAAA,EAClB,kBAAkB;AAAA,EAClB,eAAe;AAAA,EACf,aAAa;AACf;AC/CA,iBAAiB,IAAI;AACnB,MAAI,SAAQ,uBAAO,OAAO,IAAI;AAC9B,SAAO,SAAU,KAAK;AACpB,QAAI,OAAM,SAAS;AAAW,aAAM,OAAO,GAAG,GAAG;AACjD,WAAO,OAAM;AAAA,EACjB;AACA;ACAA,IAAI,iBAAiB;AACrB,IAAI,iBAAiB;AAErB,IAAI,mBAAmB,2BAA0B,UAAU;AACzD,SAAO,SAAS,WAAW,CAAC,MAAM;AACpC;AAEA,IAAI,qBAAqB,6BAA4B,OAAO;AAC1D,SAAO,SAAS,QAAQ,OAAO,UAAU;AAC3C;AAEA,IAAI,mBAAkC,wBAAQ,SAAU,WAAW;AACjE,SAAO,iBAAiB,SAAS,IAAI,YAAY,UAAU,QAAQ,gBAAgB,KAAK,EAAE;AAC5F,CAAC;AAED,IAAI,oBAAoB,4BAA2B,KAAK,OAAO;AAC7D,UAAQ;AAAA,SACD;AAAA,SACA,iBACH;AACE,UAAI,OAAO,UAAU,UAAU;AAC7B,eAAO,MAAM,QAAQ,gBAAgB,SAAU,OAAO,IAAI,IAAI;AAC5D,mBAAS;AAAA,YACP,MAAM;AAAA,YACN,QAAQ;AAAA,YACR,MAAM;AAAA,UACpB;AACY,iBAAO;AAAA,QACnB,CAAW;AAAA,MACF;AAAA,IACF;AAAA;AAGL,MAAIuH,aAAS,SAAS,KAAK,CAAC,iBAAiB,GAAG,KAAK,OAAO,UAAU,YAAY,UAAU,GAAG;AAC7F,WAAO,QAAQ;AAAA,EAChB;AAED,SAAO;AACT;AA8BA,6BAA6B,aAAa,YAAY,eAAe;AACnE,MAAI,iBAAiB,MAAM;AACzB,WAAO;AAAA,EACR;AAED,MAAI,cAAc,qBAAqB,QAAW;AAKhD,WAAO;AAAA,EACR;AAED,UAAQ,OAAO;AAAA,SACR,WACH;AACE,aAAO;AAAA,IACR;AAAA,SAEE,UACH;AACE,UAAI,cAAc,SAAS,GAAG;AAC5B,iBAAS;AAAA,UACP,MAAM,cAAc;AAAA,UACpB,QAAQ,cAAc;AAAA,UACtB,MAAM;AAAA,QAClB;AACU,eAAO,cAAc;AAAA,MACtB;AAED,UAAI,cAAc,WAAW,QAAW;AACtC,YAAI,OAAO,cAAc;AAEzB,YAAI,SAAS,QAAW;AAGtB,iBAAO,SAAS,QAAW;AACzB,qBAAS;AAAA,cACP,MAAM,KAAK;AAAA,cACX,QAAQ,KAAK;AAAA,cACb,MAAM;AAAA,YACtB;AACc,mBAAO,KAAK;AAAA,UACb;AAAA,QACF;AAED,YAAI,SAAS,cAAc,SAAS;AAMpC,eAAO;AAAA,MACR;AAED,aAAO,uBAAuB,aAAa,YAAY,aAAa;AAAA,IACrE;AAAA,SAEE,YACH;AACE,UAAI,gBAAgB,QAAW;AAC7B,YAAI,iBAAiB;AACrB,YAAI,SAAS,cAAc,WAAW;AACtC,iBAAS;AACT,eAAO,oBAAoB,aAAa,YAAY,MAAM;AAAA,MAG3D;AAED;AAAA,IACD;AAAA;AAoBL,MAAI,cAAc,MAAM;AACtB,WAAO;AAAA,EACR;AAED,MAAI,SAAS,WAAW;AACxB,SAAO,WAAW,SAAY,SAAS;AACzC;AAEA,gCAAgC,aAAa,YAAY,KAAK;AAC5D,MAAI,SAAS;AAEb,MAAI,MAAM,QAAQ,GAAG,GAAG;AACtB,aAAS,IAAI,GAAG,IAAI,IAAI,QAAQ,KAAK;AACnC,gBAAU,oBAAoB,aAAa,YAAY,IAAI,EAAE,IAAI;AAAA,IAClE;AAAA,EACL,OAAS;AACL,aAAS,QAAQ,KAAK;AACpB,UAAI,QAAQ,IAAI;AAEhB,UAAI,OAAO,UAAU,UAAU;AAC7B,YAAI,cAAc,QAAQ,WAAW,WAAW,QAAW;AACzD,oBAAU,OAAO,MAAM,WAAW,SAAS;AAAA,QACrD,WAAmB,mBAAmB,KAAK,GAAG;AACpC,oBAAU,iBAAiB,IAAI,IAAI,MAAM,kBAAkB,MAAM,KAAK,IAAI;AAAA,QAC3E;AAAA,MACT,OAAa;AACL,YAAI,SAAS,2BAA2B,OAAuC;AAC7E,gBAAM,IAAI,MAAM,iFAAiF;AAAA,QAClG;AAED,YAAI,MAAM,QAAQ,KAAK,KAAK,OAAO,MAAM,OAAO,YAAa,eAAc,QAAQ,WAAW,MAAM,QAAQ,SAAY;AACtH,mBAAS,KAAK,GAAG,KAAK,MAAM,QAAQ,MAAM;AACxC,gBAAI,mBAAmB,MAAM,GAAG,GAAG;AACjC,wBAAU,iBAAiB,IAAI,IAAI,MAAM,kBAAkB,MAAM,MAAM,GAAG,IAAI;AAAA,YAC/E;AAAA,UACF;AAAA,QACX,OAAe;AACL,cAAI,eAAe,oBAAoB,aAAa,YAAY,KAAK;AAErE,kBAAQ;AAAA,iBACD;AAAA,iBACA,iBACH;AACE,wBAAU,iBAAiB,IAAI,IAAI,MAAM,eAAe;AACxD;AAAA,YACD;AAAA,qBAGD;AAKE,wBAAU,OAAO,MAAM,eAAe;AAAA,YACvC;AAAA;AAAA,QAEN;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAED,SAAO;AACT;AAEA,IAAI,eAAe;AASnB,IAAI;AACJ,IAAI,kBAAkB,0BAAyB,MAAM,YAAY,aAAa;AAC5E,MAAI,KAAK,WAAW,KAAK,OAAO,KAAK,OAAO,YAAY,KAAK,OAAO,QAAQ,KAAK,GAAG,WAAW,QAAW;AACxG,WAAO,KAAK;AAAA,EACb;AAED,MAAI,aAAa;AACjB,MAAI,SAAS;AACb,WAAS;AACT,MAAI,UAAU,KAAK;AAEnB,MAAI,WAAW,QAAQ,QAAQ,QAAQ,QAAW;AAChD,iBAAa;AACb,cAAU,oBAAoB,aAAa,YAAY,OAAO;AAAA,EAClE,OAAS;AAKL,cAAU,QAAQ;AAAA,EACnB;AAGD,WAAS,IAAI,GAAG,IAAI,KAAK,QAAQ,KAAK;AACpC,cAAU,oBAAoB,aAAa,YAAY,KAAK,EAAE;AAE9D,QAAI,YAAY;AAKd,gBAAU,QAAQ;AAAA,IACnB;AAAA,EACF;AAYD,eAAa,YAAY;AACzB,MAAI,iBAAiB;AACrB,MAAI;AAEJ,SAAQ,SAAQ,aAAa,KAAK,MAAM,OAAO,MAAM;AACnD,sBAAkB,MAClB,MAAM;AAAA,EACP;AAED,MAAI,OAAOC,QAAW,MAAM,IAAI;AAehC,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA,MAAM;AAAA,EACV;AACA;ACvTA,IAAI,YAAY;AAYhB,IAAI,iBAAiB,yBAAwB,QAAO,YAAY,aAAa;AAC3E,MAAI,YAAY,OAAM,MAAM,MAAM,WAAW;AAE7C,MAKC,iBAAgB,SAIjB,cAAc,UAAW,OAAM,WAAW,eAAe,QAAW;AAClE,WAAM,WAAW,aAAa,WAAW;AAAA,EAC1C;AACH;AACA,IAAI,eAAe,uBAAsB,QAAO,YAAY,aAAa;AACvE,iBAAe,QAAO,YAAY,WAAW;AAC7C,MAAI,YAAY,OAAM,MAAM,MAAM,WAAW;AAE7C,MAAI,OAAM,SAAS,WAAW,UAAU,QAAW;AACjD,QAAI,UAAU;AAEd,OAAG;AACiB,aAAM,OAAO,eAAe,UAAU,MAAM,YAAY,IAAI,SAAS,OAAM,OAAO,IAAI;AAExG,gBAAU,QAAQ;AAAA,IACxB,SAAa,YAAY;AAAA,EACtB;AACH;ACtBA,kCACE,OACA,mBACW;AACL,QAAA,EAAE,eAAe,kBAAkB;AAElC,SAAA,kCACD,WAAW,SAAS,qBAAqB,KAAK,KAAK;AAAA,IACrD,UAAU;AAAA,EACZ,IACG,gBACD;AAAA,IACE,+BAAO;AAAA,IACP,+BAAO;AAAA,IACP,+BAAO;AAAA,IACP,UAAU,+BAAO,MAAM;AAAA,IACvB,+BAAO;AAAA,EAAA,GAET,CAAC,CAAC,OAAO,QAAQ,SAAS,QAAQ,kBAAmB;;AAAA,0FAC/C,WAAW,SAAS,qBAAqB,KAAK,KAAK;AAAA,MACrD,OAAO,oBAAc,KAAK,MAAnB,YAAwB;AAAA,IACjC,IACI,WAAW,SAAS,qBAAqB,MAAM,KAAK;AAAA,MACtD,WAAW,qBAAe,iCAAQ,SAAS,MAAhC,YAAqC;AAAA,MAChD,aAAa,qBAAe,iCAAQ,WAAW,MAAlC,YAAuC;AAAA,MACpD,cAAc,qBAAe,iCAAQ,YAAY,MAAnC,YAAwC;AAAA,MACtD,YAAY,qBAAe,iCAAQ,UAAU,MAAjC,YAAsC;AAAA,IACpD,IACI,WAAW,SAAS,qBAAqB,OAAO,KAAK;AAAA,MACvD,YAAY,sBAAgB,mCAAS,UAAU,MAAnC,YAAwC;AAAA,MACpD,cAAc,uBAAgB,mCAAS,YAAY,MAArC,aAA0C;AAAA,MACxD,eAAe,sBAAgB,mCAAS,aAAa,MAAtC,YAA2C;AAAA,MAC1D,aAAa,sBAAgB,mCAAS,WAAW,MAApC,YAAyC;AAAA,IACxD,IACI,WAAW,SAAS,qBAAqB,MAAM,KAAK;AAAA,MACtD,WAAW,yBAAmB,iCAAQ,SAAS,MAApC,YAAyC;AAAA,MACpD,aAAa,yBAAmB,iCAAQ,WAAW,MAAtC,YAA2C;AAAA,MACxD,cAAc,yBAAmB,iCAAQ,YAAY,MAAvC,YAA4C;AAAA,MAC1D,YAAY,yBAAmB,iCAAQ,UAAU,MAArC,YAA0C;AAAA,IACxD,IACI,WAAW,SAAS,qBAAqB,YAAY,KAAK;AAAA,MAC5D,qBAAqB,2BAAqB,6CAAc,mBAAmB,MAAtD,YAA2D;AAAA,MAChF,sBAAsB,2BAAqB,6CAAc,oBAAoB,MAAvD,YAA4D;AAAA,MAClF,yBAAyB,2BAAqB,6CAAc,uBAAuB,MAA1D,YAA+D;AAAA,MACxF,wBAAwB,2BAAqB,6CAAc,sBAAsB,MAAzD,YAA8D;AAAA,IACxF;AAAA,GAEJ;AAGF,yBAAuB,eAA6D;AAClF,QAAI,iBAAiB;AAAa,aAAA;AAE3B,WAAA,GAAG,cAAc,QAAQ,cAAc;AAAA,EAChD;AAEA,0BACE,gBACe;AACf,QAAI,kBAAkB;AAAa,aAAA;AAEnC,QAAI,mBAAmB;AAAe,aAAA;AAE/B,WAAA,GAAG,eAAe,QAAQ,eAAe;AAAA,EAClD;AAEA,2BACE,iBACe;AACf,QAAI,mBAAmB;AAAa,aAAA;AAE7B,WAAA,GAAG,gBAAgB,QAAQ,gBAAgB;AAAA,EACpD;AAEA,8BAA4B,YAA0D;AACpF,QAAI,cAAc;AAAa,aAAA;AAEzB,UAAA,EAAE,OAAO,OAAO,OAAU,WAAA;AACzB,WAAA,GAAG,SAAS,OAAO,QAAQ,OAAO,UACvC,SAAS,OAAO,cAAc,KAAK,IAAI;AAAA,EAE3C;AAEA,gCACE,cACe;AACf,QAAI,gBAAgB;AAAa,aAAA;AAE1B,WAAA,GAAG,aAAa,QAAQ,aAAa;AAAA,EAC9C;AACF;AAEA,MAAM,8BAA8B;AAEpC,MAAM,qBAAqB,aAAM,iCAAN,aAAsC,MAAM;AACvE,MAAM,WAAW,OAAO,WAAW;AAI5B,2BACL,kBACA,mBAC4B;AACtB,QAAA,QAAQ,yBAAyB,kBAAkB,iBAAiB;AAEtE,MAAA;AAAU,WAAOhwB,MAAI,KAAK;AAE9B,QAAM,aAAa,gBAAgB,CAAC,KAAK,GAAG,MAAM,UAAU;AAE5D,qBAAmB,MAAM;AACV,iBAAA,OAAO,YAAY,KAAK;AAAA,EAAA,CACtC;AAEM,SAAA,GAAG,MAAM,OAAO,WAAW;AACpC;ACzH8D,oBAAA;AAAA,EAC5D,MAAM;AAAA,EACN;AAAA,EACA;AAAA,GACW;AACX,SAAO,SAAS,QAAQ,GAAG,UAAU,CAAC;AACxC;ACbO,iCACL,MACA,YACyB;AACjB,SAAA,sBAAQ,WAAW,OAAO;AACpC;ACQO,uBACL,MACA,YACsB;;AAChB,QAAA,SAAS,SAAuB,gBAAgB;AAAA,IACpD,WAAW,EAAE,KAAK,CAAC,6BAAM,QAAQ,EAAE;AAAA,IACnC,MAAM,8BAAM,aAAY;AAAA,EAAA,CACzB;AAED,MAAI,SAAS,QAAW;AAChB,UAAA,EAAE,iBAAiB,WAAW;AAEpC,QAAI,iBAAiB;AAAkB,aAAA;AAEnC,QAAA;AACA,QAAA;AACa,qBAAAkY,YAAM,WAAW,OAAO,YAAY;AAAA,IAAA,QACnD;AACA,qBAAeA,YAAM;AAAA,IACvB;AAEO,WAAA,aAAa,MAAM;EAC5B;AAEA,QAAM,CAAC,UAAU,mBAAO,SAAP,mBAAa,aAAb,YAAyB,CAAC,IAAI;AAE/C,SAAOA,YAAM,EAAE,GAAG,iCAAQ,KAAK,GAAG,iCAAQ,YAAY,GAAG,iCAAQ,UAAW,CAAA,EACzE,MAAM,KAAK,KAAK,EAChB,IAAA,EACA;AACL;ACtCO,iCACL,MACyB;AACzB,SAAO,6BAAM;AACf;ACTO,8BAA8B,MAAuD;;AACnF,SAAA,cAAQ,IAAI,MAAZ,mBAAe;AACxB;ACQkE,0BAAA;AAAA,EAChE+X;AAAAA,EACA99B;AAAAA,EACAsB;AAAAA,GACwC;AAChCtB,SAAAA,uBAAQ,CAAIkD,GAAAA,OAClB,CAAC66B,UAAUC,SAASC,CAEhB,qBAAA18B,oBAAC,cAAD;AAAA,IAAc,YAAYu8B,WAAWI,OAAO97B;AAAAA,IAAM,MAAM47B,KAAKjwB;AAAAA,IAA7D,UACGA,CAASgwB,UAAAA,SAAS,CAAChwB,OAAkC,GAAGkwB,gBAAtC,CAAD;AAAA,EAAA,CADpB,GAIJ38B,QAPK,EAQL,CAAA,CARK;AASR;ACxBM,mBACL,mBACA,mBACuB;AACf,SAAA,gDAAqB,kBAAkB,OAAO;AACxD;ACCO,+BACL,MACA,YACuB;AACf,SAAA,sBAAQ,yCAAY,OAAO;AACrC;ACHoE,2BAAA;AAAA,EAClEw8B;AAAAA,EACA99B;AAAAA,EACAsB;AAAAA,GAC4B;AACrB0B,SAAAA,OAAOm7B,QAAQL,WAAWI,OAAO97B,IAAjC,EAAuCg8B,YAC5C,CAACL,UAAU,CAAC33B,KAAKi4B,uBACfC,CAAAA,0CAEK,cAAD;AAAA,IAAc,YAAYD;AAAAA,IAAmB,MAAMr+B,6BAAOoG;AAAAA,IAA1D,UACG2H,WAASgwB,SAAS,iCAAKO,oBAAL;AAAA,OAAyBl4B,MAAM2H;AAAAA,IAAAA,EAAhC;AAAA,EAAA,CALrB,GAQLzM,QARK,EASL,CAAA,CATF;AAUD;ACvBM,0BACL,MACA,YACyB;AACjB,SAAA,sBAAQ,WAAW,OAAO;AACpC;ACLO,2BACL,MACA,YAC0B;AAClB,SAAA,sBAAQ,WAAW,OAAO;AACpC;ACiE0D,sBAAA;AAAA,EACxDtB;AAAAA,EACA89B;AAAAA,EACAx8B;AAAAA,GACoC;AAC5Bw8B,UAAAA,WAAW17B;AAAAA,SACZm8B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAACx+B,MAA6B89B,UAA9B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASCq8B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAAC1+B,MAA2B89B,UAA5B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASCu8B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAAC5+B,MAA8B89B,UAA/B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASCy8B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAAC9+B,MAA6B89B,UAA9B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASC28B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAACh/B,MAA2B89B,UAA5B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASC68B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAACl/B,MAA0B89B,UAA3B;AAAA,QAEX/vB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASC+8B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAACp/B,IAHf;AAAA,QAKG+N,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASCi9B;AACH,iCACG,YAAD;AAAA,QAEE,MAAMC;AAAAA,QACN,YAAY,CAACt/B,IAHf;AAAA,QAKG+N,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,GAJb+vB,WAAW17B,IADlB;AAAA,SASCm9B;AACH,iCACG,mBAAD;AAAA,QAAmB;AAAA,QAAwB;AAAA,QACxCxxB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,CAFtB;AAAA,SAMGyxB;AACH,iCACG,kBAAD;AAAA,QAAkB;AAAA,QAAwB;AAAA,QACvCzxB,UAAAA,CAASzM,UAAAA,SAASyM,KAAD;AAAA,MAAA,CAFtB;AAAA;AAOOzM,aAAAA,SAAStB,IAAhB;AAAA;AAEL;ACrJD,yBAAiC;AACxB,SAAA;AACR;AAED,kBACE+N,OACA0xB,YACA18B,OACiC;AAC3B28B,QAAAA,aAAaC;AACnB,QAAM3+B,UAAUgqB,QACd,MACE,OAAOyU,WAAWz+B,YAAY,aAC1By+B,WAAWz+B,QAAQ+B,OAAO28B,UAA1B,IACAD,WAAWz+B,SACjB,CAAC+B,OAAO28B,UAAR,CALqB;AAQhB1U,SAAAA,QACL,MACEhqB,QAAQ8S,WAAW8rB,yBAAyB5rB,YACxCnG,MAAI4K,gBAAgB1K,OAAO/M,QAAQkT,YAAhB,CAAhB,IACHnG,OACN,CAACA,OAAO/M,QAAQkT,cAAclT,QAAQ8S,MAAtC,CALY;AAOf;AAiB0B,oBAAA;AAAA,EAAEtU;AAAAA,EAAS8B;AAAAA,GAA0C;;AACxEu+B,QAAAA,QAAQC;AACRC,QAAAA,+BAA+Bh4B,OACnCi4B,4CAAgDH,MAAMI,YAAYzgC,QAAQ4C,IAA1E,MAAA49B,YAAmF,CAAA,CAD1C;AAG3C,QAAMj9B,QAAQvD,QAAQuD;AAEfC,SAAAA,OAAOm7B,QAAQ4B,6BAA6B33B,OAA5C,EAAqDg2B,YAC1D,CAACL,UAAU,CAACmC,UAAUT,gBACpBU,CAAc,eAAA;AACJV,YAAAA,WAAWr9B;AAAAA,WACZm8B;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAE;AAAAA,WACAC;AACH,mCACG,cAAD;AAAA,UAAc,YAAYC;AAAAA,UAAY,MAAM18B,MAAMm9B;AAAAA,UAAlD,UACGnyB,WAASgwB,SAAS,iCAAKoC,aAAL;AAAA,aAAkBD,WAAWnyB;AAAAA,UAAAA,EAA9B;AAAA,QAAA,CAFtB;AAAA,WAMGqyB;AACH,mCACG,YAAD;AAAA,UAEE,MAAMC;AAAAA,UACN,YAAY,CAACt9B,MAAMm9B,WAAWT,UAAlB;AAAA,UAHd,UAKG1xB,WAASgwB,SAAS,iCAAKoC,aAAL;AAAA,aAAkBD,WAAWnyB;AAAAA,UAAAA,EAA9B;AAAA,QAAA,GAJb0xB,WAAWr9B,IADlB;AAAA,WASCyR,MAAYysB;AACf,mCACG,YAAD;AAAA,UAEE,MAAMC;AAAAA,UACN,YAAY,CAACx9B,MAAMm9B,WAAWT,YAAY18B,KAA9B;AAAA,UAHd,UAKGgL,WAASgwB,SAAS,iCAAKoC,aAAL;AAAA,aAAkBD,WAAWnyB;AAAAA,UAAAA,EAA9B;AAAA,QAAA,GAJb0xB,WAAWr9B,IADlB;AAAA,WASCyR,MAAY2sB;AACf,mCACG,YAAD;AAAA,UAEE,MAAMpR;AAAAA,UACN,YAAY,CAACrsB,MAAMm9B,SAAP;AAAA,UAHd,UAKGnyB,WAASgwB,SAAS,iCAAKoC,aAAL;AAAA,aAAkBD,WAAWnyB;AAAAA,UAAAA,EAA9B;AAAA,QAAA,GAJb0xB,WAAWr9B,IADlB;AAAA;AAUF,eAAO27B,SAAS,iCAAKoC,aAAL;AAAA,WAAkBD,WAAWn9B,MAAMm9B;AAAAA,QAAAA,EAApC;AAAA;AAAA,EAAA,GAGvB5+B,QAzDK,EA0DL,CAAA,CA1DK;AA2DR;ACnID,uCACEm/B,UACuB;AACvB,QAAMpqB,QAAQ4E,QAAQ5E;AAEdA,UAAAA,QAAQ,IAAIzY,SAAS;AAC3B,QAAI,OAAOA,KAAK,OAAO,YAAYA,KAAK,GAAGiS,SAAS,iCAAjB;AAAqD;AAEjFwG,WAAAA,MAAMqqB,MAAMzlB,SAASrd,IAArB;AAAA,EAAA;AAGH+iC,QAAAA,eAAelK,YAAYgK,QAAD;AAEhCxlB,UAAQ5E,QAAQA;AAETsqB,SAAAA;AACR;AAED,MAAMC,kCAAkCC,UAA0C;AAAA,EAChFC,oBAAoB;AACbC,SAAAA,YAAYC,8BAA8B,IAAD,CAA9C;AAAA,EACD;AAAA,EAEDC,qBAAqB;AACdF,SAAAA,YAAYC,8BAA8B,IAAD,CAA9C;AAAA,EACD;AAAA,EAEDD,YAAY34B,SAAgC;AACpC,UAAA;AAAA,MAAE+I;AAAAA,QAAa,KAAKpO;AAEtBoO,QAAAA,YAAY;AAAM;AAEtB,QAAI,OAAOA,aAAa;AAAYA,eAAS/I,OAAD;AAAA;AACvC+I,eAAS/I,UAAUA;AAAAA,EACzB;AAAA,EAED84B,SAAS;AACA,+BAAAp1B,UAAA;AAAA,MAAG,UAAA,KAAK/I,MAAMzB;AAAAA,IAAAA,CAArB;AAAA,EACD;AApB+E;AA2B3E,MAAM6/B,cAAchkC,WAAoD,sBAC7E4F,OACA3F,KACA;AACO,6BAAC,2BAAD,iCAA+B2F,QAA/B;AAAA,IAAsC,UAAU3F;AAAAA,EAAAA,EAAvD;AACD,CALoC;ACvBxBuC,MAAAA,2BAA2BqgC,eAAjC;AAYP,4BAA4BH,OAAsC;AACzD,SAAA;AAAA,IACLlsB,kBAAkBytB,WAAW;AAAA,MAAEh/B;AAAAA,MAAMwR;AAAAA,MAAOK,OAAO;AAAA,MAAUI,SAAS;AAAA,MAAOtR;AAAAA,OAAS;AAC9Es+B,YAAAA,sBAAsBxB,MAAMyB,SAChCC,wBAAwBn/B,MAAM;AAAA,QAAEwR;AAAAA,QAAOK;AAAAA,QAAMI;AAAAA,MAAAA,GAAUtR,wBAAS,CAAzC,CAAA,CADG;AAI5B,YAAMy+B,2BAA2B3B,MAAMyB,SACrCG,6BAA6Br/B,MAAMg/B,UADJ;AAIjC,aAAO,MAAM;AACQ;AACK;MAAA;AAAA,IAE3B;AAAA,EAAA;AAEJ;AAEYM,MAAAA,eAAeC,mBAAmBhiC,wBAAD;AAE9CiiC,0BAA0BF,YAAD;AAEzB,MAAM7gC,UAAUC,cAAcnB,wBAAD;AAQG,yBAAA;AAAA,EAC9BsB;AAAAA,EACAK;AAAAA,EACAugC;AAAAA,GACoC;AACpC,QAAM,CAAChC,OAAOiC,YAAYt+B,SAAS,MAAM;AACjCq8B,UAAAA,SAAQG,eAAyB;AAAA,MACrC+B,gBAAgBpiC,yBAAyBsgC,SADJ;AAAA,MAErC4B;AAAAA,IAAAA,CAFY;AAKPhC,WAAAA;AAAAA,EAAAA,CANyB;AASlCp8B,YAAU,MAAM;;AACRu+B,UAAAA,sBAAsBviB,MAAMrf,KAAKyhC,mDAAc1D,cAAd0D,YAA2B,CAAA,CAAtC,EAA0C9jC,IACpE,CAAC,CAACkkC,aAAaC,iBACbrC,MAAMyB,SAASa,uBAAuBnC,eAAyBiC,aAAaC,WAAtC,CAAD,CAArC,CAFwB;AAK5B,WAAO,MAAM;AACXF,0BAAoB/hC,QAAQmiC,CAAsB,uBAAA;AAC9B;MAAA,CADpB;AAAA,IAAA;AAAA,EADF,GAKC,CAACvC,OAAOgC,YAAR,CAXM;AAaTp+B,YAAU,MAAM;AAERiX,UAAAA,cAAc6c,OAAO5wB,WAAW4wB;AAElC7c,QAAAA;AAAwC;AAEgB,iDAAA;AACpD2nB,YAAAA,sBAAsB,MAAM,OAAO;AAEhCxC,eAAAA,CAAAA,WACPwC,oBAAoBC,eAAe;AAAA,QACjCP,gBAAgBlC,OAAMI,SADW;AAAA,QAEjCh/B,QAAQA,OAAO5B;AAAAA,MAFjB,CAAA,CADM;AAAA,IAMT;AAAA,EAAA,GACA,CAAC4B,MAAD,CAhBM;AAmBP,SAAAM,oBAAC,QAAQ,UAAT;AAAA,IAAkB,OAAOs+B;AAAAA,IAAzB,8BACG,mBAAD;AAAA,MAAmB;AAAA,MAAiBv+B;AAAAA,IAAAA,CAApC;AAAA,EAAA,CAFJ;AAKD;AAED,MAAMihC,cAAczhC,cAA6B,IAAhB;AAEjC,2BAA0C;AACjCI,SAAAA,WAAWqhC,WAAD;AAClB;AAEmC,qBAAA;AAC5BC,QAAAA,eAAeC;AAEjBD,MAAAA,gBAAgB;AAAY,UAAA,IAAI1gB,MAAM,gDAAV;AAEzB0gB,SAAAA;AACR;AAO4B,sBAAA;AAAA,EAAExkC;AAAAA,EAAIsD;AAAAA,GAA+B;AACzD,SAAAC,oBAAC,YAAY,UAAb;AAAA,IAAsB,OAAOvD;AAAAA,IAAKsD;AAAAA,EAAAA,CAAzC;AACD;AAED,MAAMohC,kBAAkB5hC,cAA6B,IAAhB;AAErC,0BAAyC;AAChCI,SAAAA,WAAWwhC,eAAD;AAClB;AAI2C,oBAAA;AACnCxhC,SAAAA,WAAWL,OAAD;AAClB;AAED,qBAAwB8hC,UAAkC;AAClD9C,QAAAA,QAAQC;AAEd,SAAO8C,iCAAiC/C,MAAMgD,WAAWhD,MAAMI,UAAUJ,MAAMI,UAAU0C,QAAlD;AACxC;AAED,sBAAsBvgC,MAA8C;AAClE,SAAO0gC,YAAYC,CAAS/C,UAAAA,kBAA4B+C,OAAO3gC,IAAnC,CAAV;AACnB;AAEM,sBAAsB2S,YAAsD;AAC3EktB,QAAAA,cAAce;AAEbF,SAAAA,YAAYC,CAAAA,UACjBd,eAAe,QAAQltB,cAAc,OACjC,OACAirB,aAAuB+C,OAAOd,aAAaltB,UAA3C,CAHY;AAKnB;AAED,qBAAqBktB,aAAgD;AACnE,SAAOa,YAAYC,CAAS/C,UAAAA,YAAsB+C,OAAOd,WAA7B,CAAV;AACnB;AAEyC,0BAAA;AACjCa,SAAAA,YAAYC,CAAAA,UAAS/C,eAAyB+C,KAAzB,CAAV;AACnB;AAID,uBAAiC;AACzBlD,QAAAA,QAAQ3+B,WAAWL,OAAD;AAEjBg/B,SAAAA,MAAMyB;AACd;AAKD,+BAA+B2B,WAAmB;AAC1CC,QAAAA,mBAAmBn7B,OAAOkT,QAAQ5E,KAAT;AACzB8sB,QAAAA,aAAap7B,OAAO,KAAD;AAErBo7B,MAAAA,WAAW/6B,YAAY,OAAO;AACxBiO,YAAAA,QAAQ,IAAIzY,SAAS;AAC3B,UACE,OAAOA,KAAK,OAAO,YACnBA,KAAK,GAAGiS,SAAS,2CAAjB,KACAjS,KAAK,GAAGiS,SAAU,gCAA+BozB,cAAjD,GACA;AACA;AAAA,MACD;AAEMC,aAAAA,iBAAiB96B,QAAQ,GAAGxK,IAA5B;AAAA,IAAA;AAGTulC,eAAW/6B,UAAU;AAAA,EACtB;AACF;AAMD,MAAMg7B,cAAcC,KAClBlmC,WAAW,sBACT;AAAA,EAAEmmC;AAAAA,GACFlmC,KACa;AACPyjC,QAAAA,aAAY0C,aAAaD,YAAYlhC,IAAb;AACxB,QAAA,CAAC+M,QAAQC,aAAa5L,SAAyB,IAAjB;AACpC,QAAM,CAACm9B,cAAc6C,mBAAmBhgC,SAAgC,IAAxB;AAEhD6L,sBAAoBjS,KAAK,MAAM+R,0BAAUwxB,cAAc,CAACxxB,QAAQwxB,YAAT,CAApC;AAEI,wBAAA,gBAAeyC,aAAY3f,SAA7B;AAEjBod,MAAAA,cAAa,MAAM;AACrB,+BAAQ,mBAAD;AAAA,MAAmB;AAAA,MAAiC,MAAK;AAAA,IAAA,CAAhE;AAAA,EACD;AAED,6BACG,aAAD;AAAA,IAAa,KAAK2C;AAAAA,IAAlB,8BACG,YAAD;AAAA,MAAY,SAASF;AAAAA,MAArB,UACGvgC,CAAS,UAAA0gC,8BAAC,6CAAc1gC;QAAO,KAAKugC,YAAYl9B;AAAAA,QAAK,KAAKgJ;AAAAA,MAAAA,EAAjD;AAAA,IAAA,CADZ;AAAA,EAAA,CAFJ;AAOD,CAvBS,CADY;AA2BxB,MAAMs0B,yBAAyB5iC,cAAc,KAAD;AAM5C,MAAM6iC,mBAAmBN,KACvBlmC,WAAW,2BACT;AAAA,EAAEymC;AAAAA,GACFxmC,KACa;;AACP,QAAA;AAAA,IAAEiZ;AAAAA,IAAOrW;AAAAA,MAASm7B,SAAS0I,kCAAkC;AAAA,IACjE9jC,WAAW;AAAA,MAAE/B,IAAI4lC,iBAAiB71B;AAAAA,IAAvB;AAAA,EAAA,CADmB;AAG1B+1B,QAAAA,oBAAoB9jC,mCAAM1B,kBAAN0B,mBAAqBA;AACzC+jC,QAAAA,2BAA2BC,YAAYJ,iBAAiBx9B,GAAlB;AAExCiQ,MAAAA,SAAS,MAAM;AACjB,+BAAQ,mBAAD;AAAA,MAAmB;AAAA,MAAiC,MAAK;AAAA,IAAA,CAAhE;AAAA,EACD;AAEGytB,MAAAA,qBAAqB,MAAM;AAC7B,+BACG,mBAAD;AAAA,MACE;AAAA,MACA,MAAK;AAAA,IAAA,CAHT;AAAA,EAMD;AAEMC,SAAAA,4BAA4B,OACjCxiC,oBAAC,UAAD;AAAA,IAAU,UAAUwiC;AAAAA,IAA0B;AAAA,EAAA,CAA9C,IAECxiC,oBAAA,uBAAuB,UAAxB;AAAA,IAAiC,OAAO;AAAA,IAAxC,8BACG,aAAD;AAAA,MAAa,aAAauiC;AAAAA,MAAmB;AAAA,IAAA,CAA7C;AAAA,EAAA,CAJJ;AAOD,CA9BS,CADiB;AAsChB3wB,MAAAA,YAAUkwB,KACrBlmC,WAAW,kBAAiB;AAAA,EAAEqC;AAAAA,GAAyBpC,KAAgC;AACrF,QAAM2X,aAAavV,QAAQ4G;AACrBk7B,QAAAA,WAAW2C;AACXhC,QAAAA,cAAce;AACd,QAAA,CAAC7zB,QAAQC,aAAa5L,SAAkB,IAAV;AAC9B0gC,QAAAA,4BAA4BhjC,WAAWwiC,sBAAD;AAE5Cr0B,sBAAoBjS,KAAK,MAAM+R,QAAQ,CAACA,MAAD,CAApB;AAEnB1L,YAAU,MAAM;AACd,QAAIw+B,eAAe,QAAQiC;AAA2B;AAE/C5C,WAAAA,SAAS6C,8BAA8BlC,aAAaltB,YAAY5F,MAA1B,CAA9B;AAAA,EAAA,GACd,CAACmyB,UAAUW,aAAaltB,YAAY5F,QAAQ+0B,yBAA5C,CAJM;AAMTzgC,YAAU,MAAM;AACd,QAAIw+B,eAAe,QAAQiC;AAA2B;AAE/C5C,WAAAA,SAAS8C,qBAAqBnC,aAAaltB,UAAd,CAArB;AAAA,KACd,CAACusB,UAAUW,aAAaltB,YAAYmvB,yBAApC,CAJM;AAMT,SAAOlE,mBAA6BxgC,OAA7B,wBACJ,kBAAD;AAAA,IAAmC,KAAK4P;AAAAA,IAAW,kBAAkB5P;AAAAA,EAAAA,GAA9CuV,UAAvB,IAEAxT,oBAAC,aAAD;AAAA,IAA8B,KAAK6N;AAAAA,IAAW,aAAa5P;AAAAA,KAAzCuV,UAAlB;AAEH,CA1BS,CADe;AAkC3B,MAAMsvB,WAAWhB,KACflmC,WAAW,mBAAkB;AAAA,EAAEqZ;AAAAA,GAA2BpZ,KAAgC;AAEtF,SAAAmE,oBAAC,gBAAgB,UAAjB;AAAA,IAA0B,OAAOiV,UAASpQ;AAAAA,IAA1C,8BACG+M,WAAD;AAAA,MAAS;AAAA,MAAU,SAASqD,UAAS0rB;AAAAA,IAAAA,CAArC;AAAA,EAAA,CAFJ;AAKD,CANS,CADS;AAcRoC,MAAAA,oBAAoBjB,KAC/BlmC,WAAW,4BACT;AAAA,EAAEonC;AAAAA,GACFnnC,KACa;AACPoZ,QAAAA,YAAWwtB,YAAYO,kBAAkBn+B,GAAnB;AAExBoQ,MAAAA,aAAY,MAAM;AACpB,+BAAQ,mBAAD;AAAA,MAAmB;AAAA,MAAiC,MAAK;AAAA,IAAA,CAAhE;AAAA,EACD;AAED,6BAAQ,UAAD;AAAA,IAAU;AAAA,IAAU;AAAA,EAAA,CAA3B;AACD,CAXS,CADyB;;"}
|