@wordpress/components
Version:
UI components for WordPress.
79 lines (76 loc) • 162 kB
JavaScript
import _styled from "@emotion/styled/base";
function _EMOTION_STRINGIFIED_CSS_ERROR__() { 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)."; }
/**
* External dependencies
*/
import { css, keyframes } from '@emotion/react';
import * as DropdownMenu from '@radix-ui/react-dropdown-menu';
/**
* Internal dependencies
*/
import { COLORS, font, rtl } from '../utils';
import { space } from '../ui/utils/space';
import Icon from '../icon';
const ANIMATION_PARAMS = {
SLIDE_AMOUNT: '2px',
DURATION: '400ms',
EASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )'
};
const ITEM_PREFIX_WIDTH = space(7);
const ITEM_PADDING_INLINE_START = space(2);
const ITEM_PADDING_INLINE_END = space(2.5);
const slideUpAndFade = keyframes({
'0%': {
opacity: 0,
transform: `translateY(${ANIMATION_PARAMS.SLIDE_AMOUNT})`
},
'100%': {
opacity: 1,
transform: 'translateY(0)'
}
});
const slideRightAndFade = keyframes({
'0%': {
opacity: 0,
transform: `translateX(-${ANIMATION_PARAMS.SLIDE_AMOUNT})`
},
'100%': {
opacity: 1,
transform: 'translateX(0)'
}
});
const slideDownAndFade = keyframes({
'0%': {
opacity: 0,
transform: `translateY(-${ANIMATION_PARAMS.SLIDE_AMOUNT})`
},
'100%': {
opacity: 1,
transform: 'translateY(0)'
}
});
const slideLeftAndFade = keyframes({
'0%': {
opacity: 0,
transform: `translateX(${ANIMATION_PARAMS.SLIDE_AMOUNT})`
},
'100%': {
opacity: 1,
transform: 'translateX(0)'
}
});
const baseContent = /*#__PURE__*/css("min-width:220px;background-color:", COLORS.ui.background, ";border-radius:6px;padding:", space(2), ";box-shadow:0.1px 4px 16.4px -0.5px rgba( 0, 0, 0, 0.1 ),0px 5.5px 7.8px -0.3px rgba( 0, 0, 0, 0.1 ),0px 2.7px 3.8px -0.2px rgba( 0, 0, 0, 0.1 ),0px 0.7px 1px rgba( 0, 0, 0, 0.1 );animation-duration:", ANIMATION_PARAMS.DURATION, ";animation-timing-function:", ANIMATION_PARAMS.EASING, ";will-change:transform,opacity;&[data-side='top']{animation-name:", slideDownAndFade, ";}&[data-side='right']{animation-name:", slideLeftAndFade, ";}&[data-side='bottom']{animation-name:", slideUpAndFade, ";}&[data-side='left']{animation-name:", slideRightAndFade, ";}@media ( prefers-reduced-motion ){animation-duration:0s;}" + (process.env.NODE_ENV === "production" ? "" : ";label:baseContent;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["@wordpress/components/src/dropdown-menu-v2/styles.ts"],"names":[],"mappings":"AAwDuB","file":"@wordpress/components/src/dropdown-menu-v2/styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport * as DropdownMenu from '@radix-ui/react-dropdown-menu';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl } from '../utils';\nimport { space } from '../ui/utils/space';\nimport Icon from '../icon';\n\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst ITEM_PREFIX_WIDTH = space( 7 );\nconst ITEM_PADDING_INLINE_START = space( 2 );\nconst ITEM_PADDING_INLINE_END = space( 2.5 );\n\nconst slideUpAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideRightAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideLeftAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst baseContent = css`\n\tmin-width: 220px;\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: 6px;\n\tpadding: ${ space( 2 ) };\n\tbox-shadow: 0.1px 4px 16.4px -0.5px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 5.5px 7.8px -0.3px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 2.7px 3.8px -0.2px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 0.7px 1px rgba( 0, 0, 0, 0.1 );\n\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\twill-change: transform, opacity;\n\n\t&[data-side='top'] {\n\t\tanimation-name: ${ slideDownAndFade };\n\t}\n\n\t&[data-side='right'] {\n\t\tanimation-name: ${ slideLeftAndFade };\n\t}\n\n\t&[data-side='bottom'] {\n\t\tanimation-name: ${ slideUpAndFade };\n\t}\n\n\t&[data-side='left'] {\n\t\tanimation-name: ${ slideRightAndFade };\n\t}\n\n\t@media ( prefers-reduced-motion ) {\n\t\tanimation-duration: 0s;\n\t}\n`;\n\nconst itemPrefix = css`\n\twidth: ${ ITEM_PREFIX_WIDTH };\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Prefixes don't get affected by the item's inline start padding */\n\tmargin-inline-start: calc( -1 * ${ ITEM_PADDING_INLINE_START } );\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n`;\n\nconst itemSuffix = css`\n\twidth: max-content;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Push prefix to the inline-end of the item */\n\tmargin-inline-start: auto;\n\t/* Minimum space between the item's content and suffix */\n\tpadding-inline-start: ${ space( 6 ) };\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n\n\t/*\n\t\tOverride color in normal conditions, but inherit the item's color\n\t  for altered conditions.\n\n\t\tTODO:\n\t\t  - For now, used opacity like for disabled item, which makes it work\n\t\t\t  regardless of the theme\n\t\t  - how do we translate this for themes? Should we have a new variable\n\t\tfor \"secondary\" text?\n\t*/\n\topacity: 0.6;\n\n\t[data-highlighted] > &,\n\t[data-state='open'] > &,\n\t[data-disabled] > & {\n\t\topacity: 1;\n\t}\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t${ itemPrefix }\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\t${ itemSuffix }\n`;\n\nconst baseItem = css`\n\tall: unset;\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\tcolor: ${ COLORS.gray[ 900 ] };\n\tborder-radius: 3px;\n\tdisplay: flex;\n\talign-items: center;\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PADDING_INLINE_START };\n\tposition: relative;\n\tuser-select: none;\n\toutline: none;\n\n\t&[data-disabled] {\n\t\t/*\n\t\t\tTODO:\n\t\t\t  - we need a disabled color in the Theme variables\n\t\t\t  - design specs use opacity instead of setting a new text color\n\t\t*/\n\t\topacity: 0.5;\n\t\tpointer-events: none;\n\t}\n\n\t&[data-highlighted] {\n\t\t/*\n\t\t\tTODO: reconcile with global focus styles\n\t\t\t(incl high contrast mode fallbacks)\n\t\t */\n\n\t\tbackground-color: ${ COLORS.ui.theme };\n\t\tcolor: white;\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&:not( :has( ${ ItemPrefixWrapper } ) ) {\n\t\tpadding-inline-start: ${ ITEM_PREFIX_WIDTH };\n\t}\n`;\n\nexport const Content = styled( DropdownMenu.Content )`\n\t${ baseContent }\n`;\nexport const SubContent = styled( DropdownMenu.SubContent )`\n\t${ baseContent }\n`;\n\nexport const Item = styled( DropdownMenu.Item )`\n\t${ baseItem }\n`;\nexport const CheckboxItem = styled( DropdownMenu.CheckboxItem )`\n\t${ baseItem }\n`;\nexport const RadioItem = styled( DropdownMenu.RadioItem )`\n\t${ baseItem }\n`;\nexport const SubTrigger = styled( DropdownMenu.SubTrigger )`\n\t&[data-state='open']:not( [data-highlighted] ) {\n\t\t/* TODO: use variable */\n\t\tbackground-color: rgba( 56, 88, 233, 0.04 );\n\t\tcolor: ${ COLORS.ui.theme };\n\t}\n\n\t${ baseItem }\n`;\n\nexport const Label = styled( DropdownMenu.Label )`\n\tbox-sizing: border-box;\n\tdisplay: flex;\n\talign-items: center;\n\tmin-height: ${ space( 8 ) };\n\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PREFIX_WIDTH };\n\t/* TODO: color doesn't match available UI variables */\n\tcolor: ${ COLORS.gray[ 700 ] };\n\n\t/* TODO: font size doesn't match available ones via \"font\" utils */\n\tfont-size: 11px;\n\tline-height: 1.4;\n\tfont-weight: 500;\n\ttext-transform: uppercase;\n`;\n\nexport const Separator = styled( DropdownMenu.Separator )`\n\theight: 1px;\n\t/* TODO: doesn't match border color from variables */\n\tbackground-color: ${ COLORS.ui.borderDisabled };\n\t/* Negative horizontal margin to make separator go from side to side */\n\tmargin: ${ space( 2 ) } 0;\n`;\n\nexport const ItemIndicator = styled( DropdownMenu.ItemIndicator )`\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n`;\n\nexport const SubmenuRtlChevronIcon = styled( Icon )`\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1) translateX(${ space( 2 ) })`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1) translateX(${ space( 2 ) })`,\n\t\t}\n\t)() }\n`;\n"]} */");
const itemPrefix = /*#__PURE__*/css("width:", ITEM_PREFIX_WIDTH, ";display:inline-flex;align-items:center;justify-content:center;margin-inline-start:calc( -1 * ", ITEM_PADDING_INLINE_START, " );margin-top:", space(-2), ";margin-bottom:", space(-2), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:itemPrefix;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["@wordpress/components/src/dropdown-menu-v2/styles.ts"],"names":[],"mappings":"AA0FsB","file":"@wordpress/components/src/dropdown-menu-v2/styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport * as DropdownMenu from '@radix-ui/react-dropdown-menu';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl } from '../utils';\nimport { space } from '../ui/utils/space';\nimport Icon from '../icon';\n\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst ITEM_PREFIX_WIDTH = space( 7 );\nconst ITEM_PADDING_INLINE_START = space( 2 );\nconst ITEM_PADDING_INLINE_END = space( 2.5 );\n\nconst slideUpAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideRightAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideLeftAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst baseContent = css`\n\tmin-width: 220px;\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: 6px;\n\tpadding: ${ space( 2 ) };\n\tbox-shadow: 0.1px 4px 16.4px -0.5px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 5.5px 7.8px -0.3px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 2.7px 3.8px -0.2px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 0.7px 1px rgba( 0, 0, 0, 0.1 );\n\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\twill-change: transform, opacity;\n\n\t&[data-side='top'] {\n\t\tanimation-name: ${ slideDownAndFade };\n\t}\n\n\t&[data-side='right'] {\n\t\tanimation-name: ${ slideLeftAndFade };\n\t}\n\n\t&[data-side='bottom'] {\n\t\tanimation-name: ${ slideUpAndFade };\n\t}\n\n\t&[data-side='left'] {\n\t\tanimation-name: ${ slideRightAndFade };\n\t}\n\n\t@media ( prefers-reduced-motion ) {\n\t\tanimation-duration: 0s;\n\t}\n`;\n\nconst itemPrefix = css`\n\twidth: ${ ITEM_PREFIX_WIDTH };\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Prefixes don't get affected by the item's inline start padding */\n\tmargin-inline-start: calc( -1 * ${ ITEM_PADDING_INLINE_START } );\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n`;\n\nconst itemSuffix = css`\n\twidth: max-content;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Push prefix to the inline-end of the item */\n\tmargin-inline-start: auto;\n\t/* Minimum space between the item's content and suffix */\n\tpadding-inline-start: ${ space( 6 ) };\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n\n\t/*\n\t\tOverride color in normal conditions, but inherit the item's color\n\t  for altered conditions.\n\n\t\tTODO:\n\t\t  - For now, used opacity like for disabled item, which makes it work\n\t\t\t  regardless of the theme\n\t\t  - how do we translate this for themes? Should we have a new variable\n\t\tfor \"secondary\" text?\n\t*/\n\topacity: 0.6;\n\n\t[data-highlighted] > &,\n\t[data-state='open'] > &,\n\t[data-disabled] > & {\n\t\topacity: 1;\n\t}\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t${ itemPrefix }\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\t${ itemSuffix }\n`;\n\nconst baseItem = css`\n\tall: unset;\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\tcolor: ${ COLORS.gray[ 900 ] };\n\tborder-radius: 3px;\n\tdisplay: flex;\n\talign-items: center;\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PADDING_INLINE_START };\n\tposition: relative;\n\tuser-select: none;\n\toutline: none;\n\n\t&[data-disabled] {\n\t\t/*\n\t\t\tTODO:\n\t\t\t  - we need a disabled color in the Theme variables\n\t\t\t  - design specs use opacity instead of setting a new text color\n\t\t*/\n\t\topacity: 0.5;\n\t\tpointer-events: none;\n\t}\n\n\t&[data-highlighted] {\n\t\t/*\n\t\t\tTODO: reconcile with global focus styles\n\t\t\t(incl high contrast mode fallbacks)\n\t\t */\n\n\t\tbackground-color: ${ COLORS.ui.theme };\n\t\tcolor: white;\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&:not( :has( ${ ItemPrefixWrapper } ) ) {\n\t\tpadding-inline-start: ${ ITEM_PREFIX_WIDTH };\n\t}\n`;\n\nexport const Content = styled( DropdownMenu.Content )`\n\t${ baseContent }\n`;\nexport const SubContent = styled( DropdownMenu.SubContent )`\n\t${ baseContent }\n`;\n\nexport const Item = styled( DropdownMenu.Item )`\n\t${ baseItem }\n`;\nexport const CheckboxItem = styled( DropdownMenu.CheckboxItem )`\n\t${ baseItem }\n`;\nexport const RadioItem = styled( DropdownMenu.RadioItem )`\n\t${ baseItem }\n`;\nexport const SubTrigger = styled( DropdownMenu.SubTrigger )`\n\t&[data-state='open']:not( [data-highlighted] ) {\n\t\t/* TODO: use variable */\n\t\tbackground-color: rgba( 56, 88, 233, 0.04 );\n\t\tcolor: ${ COLORS.ui.theme };\n\t}\n\n\t${ baseItem }\n`;\n\nexport const Label = styled( DropdownMenu.Label )`\n\tbox-sizing: border-box;\n\tdisplay: flex;\n\talign-items: center;\n\tmin-height: ${ space( 8 ) };\n\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PREFIX_WIDTH };\n\t/* TODO: color doesn't match available UI variables */\n\tcolor: ${ COLORS.gray[ 700 ] };\n\n\t/* TODO: font size doesn't match available ones via \"font\" utils */\n\tfont-size: 11px;\n\tline-height: 1.4;\n\tfont-weight: 500;\n\ttext-transform: uppercase;\n`;\n\nexport const Separator = styled( DropdownMenu.Separator )`\n\theight: 1px;\n\t/* TODO: doesn't match border color from variables */\n\tbackground-color: ${ COLORS.ui.borderDisabled };\n\t/* Negative horizontal margin to make separator go from side to side */\n\tmargin: ${ space( 2 ) } 0;\n`;\n\nexport const ItemIndicator = styled( DropdownMenu.ItemIndicator )`\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n`;\n\nexport const SubmenuRtlChevronIcon = styled( Icon )`\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1) translateX(${ space( 2 ) })`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1) translateX(${ space( 2 ) })`,\n\t\t}\n\t)() }\n`;\n"]} */");
const itemSuffix = /*#__PURE__*/css("width:max-content;display:inline-flex;align-items:center;justify-content:center;margin-inline-start:auto;padding-inline-start:", space(6), ";margin-top:", space(-2), ";margin-bottom:", space(-2), ";opacity:0.6;[data-highlighted]>&,[data-state='open']>&,[data-disabled]>&{opacity:1;}" + (process.env.NODE_ENV === "production" ? "" : ";label:itemSuffix;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["@wordpress/components/src/dropdown-menu-v2/styles.ts"],"names":[],"mappings":"AA0GsB","file":"@wordpress/components/src/dropdown-menu-v2/styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport * as DropdownMenu from '@radix-ui/react-dropdown-menu';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl } from '../utils';\nimport { space } from '../ui/utils/space';\nimport Icon from '../icon';\n\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst ITEM_PREFIX_WIDTH = space( 7 );\nconst ITEM_PADDING_INLINE_START = space( 2 );\nconst ITEM_PADDING_INLINE_END = space( 2.5 );\n\nconst slideUpAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideRightAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideLeftAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst baseContent = css`\n\tmin-width: 220px;\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: 6px;\n\tpadding: ${ space( 2 ) };\n\tbox-shadow: 0.1px 4px 16.4px -0.5px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 5.5px 7.8px -0.3px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 2.7px 3.8px -0.2px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 0.7px 1px rgba( 0, 0, 0, 0.1 );\n\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\twill-change: transform, opacity;\n\n\t&[data-side='top'] {\n\t\tanimation-name: ${ slideDownAndFade };\n\t}\n\n\t&[data-side='right'] {\n\t\tanimation-name: ${ slideLeftAndFade };\n\t}\n\n\t&[data-side='bottom'] {\n\t\tanimation-name: ${ slideUpAndFade };\n\t}\n\n\t&[data-side='left'] {\n\t\tanimation-name: ${ slideRightAndFade };\n\t}\n\n\t@media ( prefers-reduced-motion ) {\n\t\tanimation-duration: 0s;\n\t}\n`;\n\nconst itemPrefix = css`\n\twidth: ${ ITEM_PREFIX_WIDTH };\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Prefixes don't get affected by the item's inline start padding */\n\tmargin-inline-start: calc( -1 * ${ ITEM_PADDING_INLINE_START } );\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n`;\n\nconst itemSuffix = css`\n\twidth: max-content;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Push prefix to the inline-end of the item */\n\tmargin-inline-start: auto;\n\t/* Minimum space between the item's content and suffix */\n\tpadding-inline-start: ${ space( 6 ) };\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n\n\t/*\n\t\tOverride color in normal conditions, but inherit the item's color\n\t  for altered conditions.\n\n\t\tTODO:\n\t\t  - For now, used opacity like for disabled item, which makes it work\n\t\t\t  regardless of the theme\n\t\t  - how do we translate this for themes? Should we have a new variable\n\t\tfor \"secondary\" text?\n\t*/\n\topacity: 0.6;\n\n\t[data-highlighted] > &,\n\t[data-state='open'] > &,\n\t[data-disabled] > & {\n\t\topacity: 1;\n\t}\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t${ itemPrefix }\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\t${ itemSuffix }\n`;\n\nconst baseItem = css`\n\tall: unset;\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\tcolor: ${ COLORS.gray[ 900 ] };\n\tborder-radius: 3px;\n\tdisplay: flex;\n\talign-items: center;\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PADDING_INLINE_START };\n\tposition: relative;\n\tuser-select: none;\n\toutline: none;\n\n\t&[data-disabled] {\n\t\t/*\n\t\t\tTODO:\n\t\t\t  - we need a disabled color in the Theme variables\n\t\t\t  - design specs use opacity instead of setting a new text color\n\t\t*/\n\t\topacity: 0.5;\n\t\tpointer-events: none;\n\t}\n\n\t&[data-highlighted] {\n\t\t/*\n\t\t\tTODO: reconcile with global focus styles\n\t\t\t(incl high contrast mode fallbacks)\n\t\t */\n\n\t\tbackground-color: ${ COLORS.ui.theme };\n\t\tcolor: white;\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&:not( :has( ${ ItemPrefixWrapper } ) ) {\n\t\tpadding-inline-start: ${ ITEM_PREFIX_WIDTH };\n\t}\n`;\n\nexport const Content = styled( DropdownMenu.Content )`\n\t${ baseContent }\n`;\nexport const SubContent = styled( DropdownMenu.SubContent )`\n\t${ baseContent }\n`;\n\nexport const Item = styled( DropdownMenu.Item )`\n\t${ baseItem }\n`;\nexport const CheckboxItem = styled( DropdownMenu.CheckboxItem )`\n\t${ baseItem }\n`;\nexport const RadioItem = styled( DropdownMenu.RadioItem )`\n\t${ baseItem }\n`;\nexport const SubTrigger = styled( DropdownMenu.SubTrigger )`\n\t&[data-state='open']:not( [data-highlighted] ) {\n\t\t/* TODO: use variable */\n\t\tbackground-color: rgba( 56, 88, 233, 0.04 );\n\t\tcolor: ${ COLORS.ui.theme };\n\t}\n\n\t${ baseItem }\n`;\n\nexport const Label = styled( DropdownMenu.Label )`\n\tbox-sizing: border-box;\n\tdisplay: flex;\n\talign-items: center;\n\tmin-height: ${ space( 8 ) };\n\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PREFIX_WIDTH };\n\t/* TODO: color doesn't match available UI variables */\n\tcolor: ${ COLORS.gray[ 700 ] };\n\n\t/* TODO: font size doesn't match available ones via \"font\" utils */\n\tfont-size: 11px;\n\tline-height: 1.4;\n\tfont-weight: 500;\n\ttext-transform: uppercase;\n`;\n\nexport const Separator = styled( DropdownMenu.Separator )`\n\theight: 1px;\n\t/* TODO: doesn't match border color from variables */\n\tbackground-color: ${ COLORS.ui.borderDisabled };\n\t/* Negative horizontal margin to make separator go from side to side */\n\tmargin: ${ space( 2 ) } 0;\n`;\n\nexport const ItemIndicator = styled( DropdownMenu.ItemIndicator )`\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n`;\n\nexport const SubmenuRtlChevronIcon = styled( Icon )`\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1) translateX(${ space( 2 ) })`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1) translateX(${ space( 2 ) })`,\n\t\t}\n\t)() }\n`;\n"]} */");
export const ItemPrefixWrapper = _styled("span", process.env.NODE_ENV === "production" ? {
target: "e1kdzosf11"
} : {
target: "e1kdzosf11",
label: "ItemPrefixWrapper"
})(itemPrefix, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["@wordpress/components/src/dropdown-menu-v2/styles.ts"],"names":[],"mappings":"AA8I4C","file":"@wordpress/components/src/dropdown-menu-v2/styles.ts","sourcesContent":["/**\n * External dependencies\n */\nimport styled from '@emotion/styled';\nimport { css, keyframes } from '@emotion/react';\nimport * as DropdownMenu from '@radix-ui/react-dropdown-menu';\n\n/**\n * Internal dependencies\n */\nimport { COLORS, font, rtl } from '../utils';\nimport { space } from '../ui/utils/space';\nimport Icon from '../icon';\n\nconst ANIMATION_PARAMS = {\n\tSLIDE_AMOUNT: '2px',\n\tDURATION: '400ms',\n\tEASING: 'cubic-bezier( 0.16, 1, 0.3, 1 )',\n};\n\nconst ITEM_PREFIX_WIDTH = space( 7 );\nconst ITEM_PADDING_INLINE_START = space( 2 );\nconst ITEM_PADDING_INLINE_END = space( 2.5 );\n\nconst slideUpAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideRightAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst slideDownAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateY(-${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateY(0)' },\n} );\n\nconst slideLeftAndFade = keyframes( {\n\t'0%': {\n\t\topacity: 0,\n\t\ttransform: `translateX(${ ANIMATION_PARAMS.SLIDE_AMOUNT })`,\n\t},\n\t'100%': { opacity: 1, transform: 'translateX(0)' },\n} );\n\nconst baseContent = css`\n\tmin-width: 220px;\n\tbackground-color: ${ COLORS.ui.background };\n\tborder-radius: 6px;\n\tpadding: ${ space( 2 ) };\n\tbox-shadow: 0.1px 4px 16.4px -0.5px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 5.5px 7.8px -0.3px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 2.7px 3.8px -0.2px rgba( 0, 0, 0, 0.1 ),\n\t\t0px 0.7px 1px rgba( 0, 0, 0, 0.1 );\n\tanimation-duration: ${ ANIMATION_PARAMS.DURATION };\n\tanimation-timing-function: ${ ANIMATION_PARAMS.EASING };\n\twill-change: transform, opacity;\n\n\t&[data-side='top'] {\n\t\tanimation-name: ${ slideDownAndFade };\n\t}\n\n\t&[data-side='right'] {\n\t\tanimation-name: ${ slideLeftAndFade };\n\t}\n\n\t&[data-side='bottom'] {\n\t\tanimation-name: ${ slideUpAndFade };\n\t}\n\n\t&[data-side='left'] {\n\t\tanimation-name: ${ slideRightAndFade };\n\t}\n\n\t@media ( prefers-reduced-motion ) {\n\t\tanimation-duration: 0s;\n\t}\n`;\n\nconst itemPrefix = css`\n\twidth: ${ ITEM_PREFIX_WIDTH };\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Prefixes don't get affected by the item's inline start padding */\n\tmargin-inline-start: calc( -1 * ${ ITEM_PADDING_INLINE_START } );\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n`;\n\nconst itemSuffix = css`\n\twidth: max-content;\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n\t/* Push prefix to the inline-end of the item */\n\tmargin-inline-start: auto;\n\t/* Minimum space between the item's content and suffix */\n\tpadding-inline-start: ${ space( 6 ) };\n\t/*\n\t\tNegative margin allows the suffix to be as tall as the whole item\n\t\t(incl. padding) before increasing the items' height. This can be useful,\n\t\te.g., when using icons that are bigger than 20x20 px\n\t*/\n\tmargin-top: ${ space( -2 ) };\n\tmargin-bottom: ${ space( -2 ) };\n\n\t/*\n\t\tOverride color in normal conditions, but inherit the item's color\n\t  for altered conditions.\n\n\t\tTODO:\n\t\t  - For now, used opacity like for disabled item, which makes it work\n\t\t\t  regardless of the theme\n\t\t  - how do we translate this for themes? Should we have a new variable\n\t\tfor \"secondary\" text?\n\t*/\n\topacity: 0.6;\n\n\t[data-highlighted] > &,\n\t[data-state='open'] > &,\n\t[data-disabled] > & {\n\t\topacity: 1;\n\t}\n`;\n\nexport const ItemPrefixWrapper = styled.span`\n\t${ itemPrefix }\n`;\n\nexport const ItemSuffixWrapper = styled.span`\n\t${ itemSuffix }\n`;\n\nconst baseItem = css`\n\tall: unset;\n\tfont-size: ${ font( 'default.fontSize' ) };\n\tfont-family: inherit;\n\tfont-weight: normal;\n\tline-height: 20px;\n\tcolor: ${ COLORS.gray[ 900 ] };\n\tborder-radius: 3px;\n\tdisplay: flex;\n\talign-items: center;\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PADDING_INLINE_START };\n\tposition: relative;\n\tuser-select: none;\n\toutline: none;\n\n\t&[data-disabled] {\n\t\t/*\n\t\t\tTODO:\n\t\t\t  - we need a disabled color in the Theme variables\n\t\t\t  - design specs use opacity instead of setting a new text color\n\t\t*/\n\t\topacity: 0.5;\n\t\tpointer-events: none;\n\t}\n\n\t&[data-highlighted] {\n\t\t/*\n\t\t\tTODO: reconcile with global focus styles\n\t\t\t(incl high contrast mode fallbacks)\n\t\t */\n\n\t\tbackground-color: ${ COLORS.ui.theme };\n\t\tcolor: white;\n\t}\n\n\tsvg {\n\t\tfill: currentColor;\n\t}\n\n\t&:not( :has( ${ ItemPrefixWrapper } ) ) {\n\t\tpadding-inline-start: ${ ITEM_PREFIX_WIDTH };\n\t}\n`;\n\nexport const Content = styled( DropdownMenu.Content )`\n\t${ baseContent }\n`;\nexport const SubContent = styled( DropdownMenu.SubContent )`\n\t${ baseContent }\n`;\n\nexport const Item = styled( DropdownMenu.Item )`\n\t${ baseItem }\n`;\nexport const CheckboxItem = styled( DropdownMenu.CheckboxItem )`\n\t${ baseItem }\n`;\nexport const RadioItem = styled( DropdownMenu.RadioItem )`\n\t${ baseItem }\n`;\nexport const SubTrigger = styled( DropdownMenu.SubTrigger )`\n\t&[data-state='open']:not( [data-highlighted] ) {\n\t\t/* TODO: use variable */\n\t\tbackground-color: rgba( 56, 88, 233, 0.04 );\n\t\tcolor: ${ COLORS.ui.theme };\n\t}\n\n\t${ baseItem }\n`;\n\nexport const Label = styled( DropdownMenu.Label )`\n\tbox-sizing: border-box;\n\tdisplay: flex;\n\talign-items: center;\n\tmin-height: ${ space( 8 ) };\n\n\tpadding: ${ space( 2 ) } ${ ITEM_PADDING_INLINE_END } ${ space( 2 ) }\n\t\t${ ITEM_PREFIX_WIDTH };\n\t/* TODO: color doesn't match available UI variables */\n\tcolor: ${ COLORS.gray[ 700 ] };\n\n\t/* TODO: font size doesn't match available ones via \"font\" utils */\n\tfont-size: 11px;\n\tline-height: 1.4;\n\tfont-weight: 500;\n\ttext-transform: uppercase;\n`;\n\nexport const Separator = styled( DropdownMenu.Separator )`\n\theight: 1px;\n\t/* TODO: doesn't match border color from variables */\n\tbackground-color: ${ COLORS.ui.borderDisabled };\n\t/* Negative horizontal margin to make separator go from side to side */\n\tmargin: ${ space( 2 ) } 0;\n`;\n\nexport const ItemIndicator = styled( DropdownMenu.ItemIndicator )`\n\tdisplay: inline-flex;\n\talign-items: center;\n\tjustify-content: center;\n`;\n\nexport const SubmenuRtlChevronIcon = styled( Icon )`\n\t${ rtl(\n\t\t{\n\t\t\ttransform: `scaleX(1) translateX(${ space( 2 ) })`,\n\t\t},\n\t\t{\n\t\t\ttransform: `scaleX(-1) translateX(${ space( 2 ) })`,\n\t\t}\n\t)() }\n`;\n"]} */"));
export const ItemSuffixWrapper = _styled("span", process.env.NODE_ENV === "production" ? {
target: "e1kdzosf10"
} : {
target: "e1kdzosf10",
label: "ItemSuffixWrapper"
})(itemSuffix, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkB3b3JkcHJlc3MvY29tcG9uZW50cy9zcmMvZHJvcGRvd24tbWVudS12Mi9zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0o0QyIsImZpbGUiOiJAd29yZHByZXNzL2NvbXBvbmVudHMvc3JjL2Ryb3Bkb3duLW1lbnUtdjIvc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBFeHRlcm5hbCBkZXBlbmRlbmNpZXNcbiAqL1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3NzLCBrZXlmcmFtZXMgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgKiBhcyBEcm9wZG93bk1lbnUgZnJvbSAnQHJhZGl4LXVpL3JlYWN0LWRyb3Bkb3duLW1lbnUnO1xuXG4vKipcbiAqIEludGVybmFsIGRlcGVuZGVuY2llc1xuICovXG5pbXBvcnQgeyBDT0xPUlMsIGZvbnQsIHJ0bCB9IGZyb20gJy4uL3V0aWxzJztcbmltcG9ydCB7IHNwYWNlIH0gZnJvbSAnLi4vdWkvdXRpbHMvc3BhY2UnO1xuaW1wb3J0IEljb24gZnJvbSAnLi4vaWNvbic7XG5cbmNvbnN0IEFOSU1BVElPTl9QQVJBTVMgPSB7XG5cdFNMSURFX0FNT1VOVDogJzJweCcsXG5cdERVUkFUSU9OOiAnNDAwbXMnLFxuXHRFQVNJTkc6ICdjdWJpYy1iZXppZXIoIDAuMTYsIDEsIDAuMywgMSApJyxcbn07XG5cbmNvbnN0IElURU1fUFJFRklYX1dJRFRIID0gc3BhY2UoIDcgKTtcbmNvbnN0IElURU1fUEFERElOR19JTkxJTkVfU1RBUlQgPSBzcGFjZSggMiApO1xuY29uc3QgSVRFTV9QQURESU5HX0lOTElORV9FTkQgPSBzcGFjZSggMi41ICk7XG5cbmNvbnN0IHNsaWRlVXBBbmRGYWRlID0ga2V5ZnJhbWVzKCB7XG5cdCcwJSc6IHtcblx0XHRvcGFjaXR5OiAwLFxuXHRcdHRyYW5zZm9ybTogYHRyYW5zbGF0ZVkoJHsgQU5JTUFUSU9OX1BBUkFNUy5TTElERV9BTU9VTlQgfSlgLFxuXHR9LFxuXHQnMTAwJSc6IHsgb3BhY2l0eTogMSwgdHJhbnNmb3JtOiAndHJhbnNsYXRlWSgwKScgfSxcbn0gKTtcblxuY29uc3Qgc2xpZGVSaWdodEFuZEZhZGUgPSBrZXlmcmFtZXMoIHtcblx0JzAlJzoge1xuXHRcdG9wYWNpdHk6IDAsXG5cdFx0dHJhbnNmb3JtOiBgdHJhbnNsYXRlWCgtJHsgQU5JTUFUSU9OX1BBUkFNUy5TTElERV9BTU9VTlQgfSlgLFxuXHR9LFxuXHQnMTAwJSc6IHsgb3BhY2l0eTogMSwgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScgfSxcbn0gKTtcblxuY29uc3Qgc2xpZGVEb3duQW5kRmFkZSA9IGtleWZyYW1lcygge1xuXHQnMCUnOiB7XG5cdFx0b3BhY2l0eTogMCxcblx0XHR0cmFuc2Zvcm06IGB0cmFuc2xhdGVZKC0keyBBTklNQVRJT05fUEFSQU1TLlNMSURFX0FNT1VOVCB9KWAsXG5cdH0sXG5cdCcxMDAlJzogeyBvcGFjaXR5OiAxLCB0cmFuc2Zvcm06ICd0cmFuc2xhdGVZKDApJyB9LFxufSApO1xuXG5jb25zdCBzbGlkZUxlZnRBbmRGYWRlID0ga2V5ZnJhbWVzKCB7XG5cdCcwJSc6IHtcblx0XHRvcGFjaXR5OiAwLFxuXHRcdHRyYW5zZm9ybTogYHRyYW5zbGF0ZVgoJHsgQU5JTUFUSU9OX1BBUkFNUy5TTElERV9BTU9VTlQgfSlgLFxuXHR9LFxuXHQnMTAwJSc6IHsgb3BhY2l0eTogMSwgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScgfSxcbn0gKTtcblxuY29uc3QgYmFzZUNvbnRlbnQgPSBjc3NgXG5cdG1pbi13aWR0aDogMjIwcHg7XG5cdGJhY2tncm91bmQtY29sb3I6ICR7IENPTE9SUy51aS5iYWNrZ3JvdW5kIH07XG5cdGJvcmRlci1yYWRpdXM6IDZweDtcblx0cGFkZGluZzogJHsgc3BhY2UoIDIgKSB9O1xuXHRib3gtc2hhZG93OiAwLjFweCA0cHggMTYuNHB4IC0wLjVweCByZ2JhKCAwLCAwLCAwLCAwLjEgKSxcblx0XHQwcHggNS41cHggNy44cHggLTAuM3B4IHJnYmEoIDAsIDAsIDAsIDAuMSApLFxuXHRcdDBweCAyLjdweCAzLjhweCAtMC4ycHggcmdiYSggMCwgMCwgMCwgMC4xICksXG5cdFx0MHB4IDAuN3B4IDFweCByZ2JhKCAwLCAwLCAwLCAwLjEgKTtcblx0YW5pbWF0aW9uLWR1cmF0aW9uOiAkeyBBTklNQVRJT05fUEFSQU1TLkRVUkFUSU9OIH07XG5cdGFuaW1hdGlvbi10aW1pbmctZnVuY3Rpb246ICR7IEFOSU1BVElPTl9QQVJBTVMuRUFTSU5HIH07XG5cdHdpbGwtY2hhbmdlOiB0cmFuc2Zvcm0sIG9wYWNpdHk7XG5cblx0JltkYXRhLXNpZGU9J3RvcCddIHtcblx0XHRhbmltYXRpb24tbmFtZTogJHsgc2xpZGVEb3duQW5kRmFkZSB9O1xuXHR9XG5cblx0JltkYXRhLXNpZGU9J3JpZ2h0J10ge1xuXHRcdGFuaW1hdGlvbi1uYW1lOiAkeyBzbGlkZUxlZnRBbmRGYWRlIH07XG5cdH1cblxuXHQmW2RhdGEtc2lkZT0nYm90dG9tJ10ge1xuXHRcdGFuaW1hdGlvbi1uYW1lOiAkeyBzbGlkZVVwQW5kRmFkZSB9O1xuXHR9XG5cblx0JltkYXRhLXNpZGU9J2xlZnQnXSB7XG5cdFx0YW5pbWF0aW9uLW5hbWU6ICR7IHNsaWRlUmlnaHRBbmRGYWRlIH07XG5cdH1cblxuXHRAbWVkaWEgKCBwcmVmZXJzLXJlZHVjZWQtbW90aW9uICkge1xuXHRcdGFuaW1hdGlvbi1kdXJhdGlvbjogMHM7XG5cdH1cbmA7XG5cbmNvbnN0IGl0ZW1QcmVmaXggPSBjc3NgXG5cdHdpZHRoOiAkeyBJVEVNX1BSRUZJWF9XSURUSCB9O1xuXHRkaXNwbGF5OiBpbmxpbmUtZmxleDtcblx0YWxpZ24taXRlbXM6IGNlbnRlcjtcblx0anVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cdC8qIFByZWZpeGVzIGRvbid0IGdldCBhZmZlY3RlZCBieSB0aGUgaXRlbSdzIGlubGluZSBzdGFydCBwYWRkaW5nICovXG5cdG1hcmdpbi1pbmxpbmUtc3RhcnQ6IGNhbGMoIC0xICogJHsgSVRFTV9QQURESU5HX0lOTElORV9TVEFSVCB9ICk7XG5cdC8qXG5cdFx0TmVnYXRpdmUgbWFyZ2luIGFsbG93cyB0aGUgc3VmZml4IHRvIGJlIGFzIHRhbGwgYXMgdGhlIHdob2xlIGl0ZW1cblx0XHQoaW5jbC4gcGFkZGluZykgYmVmb3JlIGluY3JlYXNpbmcgdGhlIGl0ZW1zJyBoZWlnaHQuIFRoaXMgY2FuIGJlIHVzZWZ1bCxcblx0XHRlLmcuLCB3aGVuIHVzaW5nIGljb25zIHRoYXQgYXJlIGJpZ2dlciB0aGFuIDIweDIwIHB4XG5cdCovXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMiApIH07XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAtMiApIH07XG5gO1xuXG5jb25zdCBpdGVtU3VmZml4ID0gY3NzYFxuXHR3aWR0aDogbWF4LWNvbnRlbnQ7XG5cdGRpc3BsYXk6IGlubGluZS1mbGV4O1xuXHRhbGlnbi1pdGVtczogY2VudGVyO1xuXHRqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblx0LyogUHVzaCBwcmVmaXggdG8gdGhlIGlubGluZS1lbmQgb2YgdGhlIGl0ZW0gKi9cblx0bWFyZ2luLWlubGluZS1zdGFydDogYXV0bztcblx0LyogTWluaW11bSBzcGFjZSBiZXR3ZWVuIHRoZSBpdGVtJ3MgY29udGVudCBhbmQgc3VmZml4ICovXG5cdHBhZGRpbmctaW5saW5lLXN0YXJ0OiAkeyBzcGFjZSggNiApIH07XG5cdC8qXG5cdFx0TmVnYXRpdmUgbWFyZ2luIGFsbG93cyB0aGUgc3VmZml4IHRvIGJlIGFzIHRhbGwgYXMgdGhlIHdob2xlIGl0ZW1cblx0XHQoaW5jbC4gcGFkZGluZykgYmVmb3JlIGluY3JlYXNpbmcgdGhlIGl0ZW1zJyBoZWlnaHQuIFRoaXMgY2FuIGJlIHVzZWZ1bCxcblx0XHRlLmcuLCB3aGVuIHVzaW5nIGljb25zIHRoYXQgYXJlIGJpZ2dlciB0aGFuIDIweDIwIHB4XG5cdCovXG5cdG1hcmdpbi10b3A6ICR7IHNwYWNlKCAtMiApIH07XG5cdG1hcmdpbi1ib3R0b206ICR7IHNwYWNlKCAtMiApIH07XG5cblx0Lypcblx0XHRPdmVycmlkZSBjb2xvciBpbiBub3JtYWwgY29uZGl0aW9ucywgYnV0IGluaGVyaXQgdGhlIGl0ZW0ncyBjb2xvclxuXHQgIGZvciBhbHRlcmVkIGNvbmRpdGlvbnMuXG5cblx0XHRUT0RPOlxuXHRcdCAgLSBGb3Igbm93LCB1c2VkIG9wYWNpdHkgbGlrZSBmb3IgZGlzYWJsZWQgaXRlbSwgd2hpY2ggbWFrZXMgaXQgd29ya1xuXHRcdFx0ICByZWdhcmRsZXNzIG9mIHRoZSB0aGVtZVxuXHRcdCAgLSBob3cgZG8gd2UgdHJhbnNsYXRlIHRoaXMgZm9yIHRoZW1lcz8gU2hvdWxkIHdlIGhhdmUgYSBuZXcgdmFyaWFibGVcblx0XHRmb3IgXCJzZWNvbmRhcnlcIiB0ZXh0P1xuXHQqL1xuXHRvcGFjaXR5OiAwLjY7XG5cblx0W2RhdGEtaGlnaGxpZ2h0ZWRdID4gJixcblx0W2RhdGEtc3RhdGU9J29wZW4nXSA+ICYsXG5cdFtkYXRhLWRpc2FibGVkXSA+ICYge1xuXHRcdG9wYWNpdHk6IDE7XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtUHJlZml4V3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuXHQkeyBpdGVtUHJlZml4IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtU3VmZml4V3JhcHBlciA9IHN0eWxlZC5zcGFuYFxuXHQkeyBpdGVtU3VmZml4IH1cbmA7XG5cbmNvbnN0IGJhc2VJdGVtID0gY3NzYFxuXHRhbGw6IHVuc2V0O1xuXHRmb250LXNpemU6ICR7IGZvbnQoICdkZWZhdWx0LmZvbnRTaXplJyApIH07XG5cdGZvbnQtZmFtaWx5OiBpbmhlcml0O1xuXHRmb250LXdlaWdodDogbm9ybWFsO1xuXHRsaW5lLWhlaWdodDogMjBweDtcblx0Y29sb3I6ICR7IENPTE9SUy5ncmF5WyA5MDAgXSB9O1xuXHRib3JkZXItcmFkaXVzOiAzcHg7XG5cdGRpc3BsYXk6IGZsZXg7XG5cdGFsaWduLWl0ZW1zOiBjZW50ZXI7XG5cdHBhZGRpbmc6ICR7IHNwYWNlKCAyICkgfSAkeyBJVEVNX1BBRERJTkdfSU5MSU5FX0VORCB9ICR7IHNwYWNlKCAyICkgfVxuXHRcdCR7IElURU1fUEFERElOR19JTkxJTkVfU1RBUlQgfTtcblx0cG9zaXRpb246IHJlbGF0aXZlO1xuXHR1c2VyLXNlbGVjdDogbm9uZTtcblx0b3V0bGluZTogbm9uZTtcblxuXHQmW2RhdGEtZGlzYWJsZWRdIHtcblx0XHQvKlxuXHRcdFx0VE9ETzpcblx0XHRcdCAgLSB3ZSBuZWVkIGEgZGlzYWJsZWQgY29sb3IgaW4gdGhlIFRoZW1lIHZhcmlhYmxlc1xuXHRcdFx0ICAtIGRlc2lnbiBzcGVjcyB1c2Ugb3BhY2l0eSBpbnN0ZWFkIG9mIHNldHRpbmcgYSBuZXcgdGV4dCBjb2xvclxuXHRcdCovXG5cdFx0b3BhY2l0eTogMC41O1xuXHRcdHBvaW50ZXItZXZlbnRzOiBub25lO1xuXHR9XG5cblx0JltkYXRhLWhpZ2hsaWdodGVkXSB7XG5cdFx0Lypcblx0XHRcdFRPRE86IHJlY29uY2lsZSB3aXRoIGdsb2JhbCBmb2N1cyBzdHlsZXNcblx0XHRcdChpbmNsIGhpZ2ggY29udHJhc3QgbW9kZSBmYWxsYmFja3MpXG5cdFx0ICovXG5cblx0XHRiYWNrZ3JvdW5kLWNvbG9yOiAkeyBDT0xPUlMudWkudGhlbWUgfTtcblx0XHRjb2xvcjogd2hpdGU7XG5cdH1cblxuXHRzdmcge1xuXHRcdGZpbGw6IGN1cnJlbnRDb2xvcjtcblx0fVxuXG5cdCY6bm90KCA6aGFzKCAkeyBJdGVtUHJlZml4V3JhcHBlciB9ICkgKSB7XG5cdFx0cGFkZGluZy1pbmxpbmUtc3RhcnQ6ICR7IElURU1fUFJFRklYX1dJRFRIIH07XG5cdH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDb250ZW50ID0gc3R5bGVkKCBEcm9wZG93bk1lbnUuQ29udGVudCApYFxuXHQkeyBiYXNlQ29udGVudCB9XG5gO1xuZXhwb3J0IGNvbnN0IFN1YkNvbnRlbnQgPSBzdHlsZWQoIERyb3Bkb3duTWVudS5TdWJDb250ZW50IClgXG5cdCR7IGJhc2VDb250ZW50IH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJdGVtID0gc3R5bGVkKCBEcm9wZG93bk1lbnUuSXRlbSApYFxuXHQkeyBiYXNlSXRlbSB9XG5gO1xuZXhwb3J0IGNvbnN0IENoZWNrYm94SXRlbSA9IHN0eWxlZCggRHJvcGRvd25NZW51LkNoZWNrYm94SXRlbSApYFxuXHQkeyBiYXNlSXRlbSB9XG5gO1xuZXhwb3J0IGNvbnN0IFJhZGlvSXRlbSA9IHN0eWxlZCggRHJvcGRvd25NZW51LlJhZGlvSXRlbSApYFxuXHQkeyBiYXNlSXRlbSB9XG5gO1xuZXhwb3J0IGNvbnN0IFN1YlRyaWdnZXIgPSBzdHlsZ