react-magma-dom 5.1.0-rc.20 → 5.1.0-rc.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Popover/Popover.d.ts +0 -1
- package/dist/esm/index.js +28 -23
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +28 -23
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/dist/utils/index.d.ts +1 -0
- package/package.json +1 -1
|
@@ -112,5 +112,4 @@ export interface PopoverContextInterface {
|
|
|
112
112
|
}
|
|
113
113
|
export declare const PopoverContext: React.Context<PopoverContextInterface>;
|
|
114
114
|
export declare function hasActiveElementsChecker(ref: any): boolean;
|
|
115
|
-
export declare function isElementInteractive(element: EventTarget | null): boolean;
|
|
116
115
|
export declare const Popover: React.ForwardRefExoticComponent<PopoverProps & React.RefAttributes<HTMLDivElement>>;
|
package/dist/esm/index.js
CHANGED
|
@@ -472,6 +472,15 @@ var mergeRefs = function mergeRefs() {
|
|
|
472
472
|
});
|
|
473
473
|
};
|
|
474
474
|
};
|
|
475
|
+
function isElementInteractive(element) {
|
|
476
|
+
if (!element || !(element instanceof HTMLElement)) return false;
|
|
477
|
+
var tag = element.tagName.toLowerCase();
|
|
478
|
+
if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex') && element.tabIndex >= 0) {
|
|
479
|
+
if (tag === 'a' && !element.href) return false;
|
|
480
|
+
return !element.hasAttribute('disabled');
|
|
481
|
+
}
|
|
482
|
+
return false;
|
|
483
|
+
}
|
|
475
484
|
|
|
476
485
|
function _extends$1() {
|
|
477
486
|
return _extends$1 = Object.assign ? Object.assign.bind() : function (n) {
|
|
@@ -8520,7 +8529,7 @@ var StyledContainer$2 = /*#__PURE__*/_styled("div", {
|
|
|
8520
8529
|
styles: "display:inline-block"
|
|
8521
8530
|
} : {
|
|
8522
8531
|
name: "1r5gb7q",
|
|
8523
|
-
styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport function isElementInteractive(element) {\r\n    if (!element || !(element instanceof HTMLElement))\r\n        return false;\r\n    const tag = element.tagName.toLowerCase();\r\n    if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) ||\r\n        element.hasAttribute('tabindex')) {\r\n        if (tag === 'a' && !element.href)\r\n            return false;\r\n        return !element.hasAttribute('disabled');\r\n    }\r\n    return false;\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget) && !hoverable) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n            toggleRef.current?.focus();\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
|
|
8532
|
+
styles: "display:inline-block/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Popover.tsx"],"names":[],"mappings":"AAiBmC","file":"Popover.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { offset, flip, autoUpdate, arrow, shift, useFloating, } from '@floating-ui/react';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { isElementInteractive, resolveProps, useForkedRef, useGenerateId, } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var PopoverPosition;\r\n(function (PopoverPosition) {\r\n    PopoverPosition[\"bottom\"] = \"bottom\";\r\n    PopoverPosition[\"top\"] = \"top\";\r\n})(PopoverPosition || (PopoverPosition = {}));\r\nexport var PopoverAlignment;\r\n(function (PopoverAlignment) {\r\n    PopoverAlignment[\"center\"] = \"center\";\r\n    PopoverAlignment[\"start\"] = \"start\";\r\n    PopoverAlignment[\"end\"] = \"end\";\r\n})(PopoverAlignment || (PopoverAlignment = {}));\r\nconst StyledContainer = styled.div `\n  display: inline-block;\n`;\r\nexport const PopoverContext = React.createContext({\r\n    isOpen: false,\r\n    setIsOpen: () => false,\r\n});\r\nexport function hasActiveElementsChecker(ref) {\r\n    return (Array.from(ref.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"]), video') || []).filter((element) => {\r\n        const style = window.getComputedStyle(element);\r\n        return (element instanceof HTMLElement &&\r\n            style.display !== 'none' &&\r\n            style.visibility !== 'hidden' &&\r\n            !element.hasAttribute('disabled'));\r\n    }).length > 0);\r\n}\r\nexport const Popover = React.forwardRef((props, forwardedRef) => {\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef();\r\n    const contentRef = React.useRef(null);\r\n    const popoverContentId = React.useRef('');\r\n    const popoverTriggerId = React.useRef('');\r\n    const arrowRef = React.useRef(null);\r\n    const hasActiveElements = React.useMemo(() => hasActiveElementsChecker(contentRef), [contentRef, contentRef.current]);\r\n    const { onClose, onOpen, position = PopoverPosition.bottom, children, testId, maxHeight, width, hoverable, isDisabled, hasPointer = true, openByDefault, id: defaultId, apiRef, focusTrap, alignment = PopoverAlignment.center, ...other } = props;\r\n    React.useEffect(() => {\r\n        if (apiRef) {\r\n            apiRef.current = {\r\n                closePopoverManually(event) {\r\n                    closePopover(event);\r\n                },\r\n                openPopoverManually(event) {\r\n                    openPopover();\r\n                },\r\n            };\r\n        }\r\n        if (openByDefault) {\r\n            openPopover();\r\n        }\r\n    }, []);\r\n    React.useEffect(() => {\r\n        const handleEsc = event => {\r\n            if (event.key === 'Escape' && isOpen) {\r\n                closePopover(event);\r\n            }\r\n        };\r\n        window.addEventListener('keydown', handleEsc);\r\n        return () => {\r\n            window.removeEventListener('keydown', handleEsc);\r\n        };\r\n    }, [isOpen]);\r\n    const popoverId = useGenerateId(defaultId);\r\n    popoverTriggerId.current = `${popoverId}_trigger`;\r\n    popoverContentId.current = `${popoverId}_content`;\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const handleMouseOver = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(true);\r\n        }\r\n    };\r\n    const handleMouseLeave = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            setIsOpen(false);\r\n        }\r\n    };\r\n    function openPopover() {\r\n        setIsOpen(true);\r\n        if (!hoverable) {\r\n            toggleRef.current.focus();\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closePopover(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget) && !hoverable) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            if (isOpen) {\r\n                event.stopPropagation();\r\n            }\r\n            closePopover(event);\r\n            toggleRef.current?.focus();\r\n        }\r\n    }\r\n    function handlePopoverBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closePopover(event);\r\n        }\r\n    }\r\n    const placement = React.useMemo(() => {\r\n        return alignment === PopoverAlignment.center\r\n            ? position\r\n            : `${position}-${alignment}`;\r\n    }, [position, alignment]);\r\n    const { refs, floatingStyles, context, elements, update } = useFloating({\r\n        //flip() - Changes the placement of the floating element to keep it in view.\r\n        //offset() - Translates the floating element along the specified axes. (Space between the Trigger and the Content).\r\n        //shift() - Shifts the floating element along the specified axes to keep it in view within the clipping context or viewport.\r\n        //arrow() - Positions an arrow element pointing at the reference element, ensuring proper alignment.\r\n        middleware: [\r\n            flip(),\r\n            shift({ padding: 12 }),\r\n            offset(hasPointer ? 12 : 4),\r\n            arrow({ element: arrowRef }),\r\n        ],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        const referenceElement = elements.reference;\r\n        const floatingElement = elements.floating;\r\n        if (isOpen && referenceElement && floatingElement) {\r\n            return autoUpdate(referenceElement, floatingElement, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = width === 'target'\r\n        ? `${refs.reference.current?.getBoundingClientRect().width}px`\r\n        : typeof width === 'number'\r\n            ? `${width}px`\r\n            : width;\r\n    const onFocus = () => {\r\n        if (hoverable && !isDisabled && !hasActiveElements) {\r\n            openPopover();\r\n        }\r\n    };\r\n    return (React.createElement(PopoverContext.Provider, { value: {\r\n            floatingStyles,\r\n            position: placement,\r\n            closePopover,\r\n            popoverTriggerId,\r\n            popoverContentId,\r\n            openPopover,\r\n            isInverse,\r\n            isOpen,\r\n            maxHeight: maxHeightString,\r\n            width: widthString,\r\n            contentRef,\r\n            setIsOpen,\r\n            setFloating: refs.setFloating,\r\n            setReference: refs.setReference,\r\n            arrowRef,\r\n            arrowContext: context,\r\n            toggleRef,\r\n            isDisabled,\r\n            hoverable,\r\n            hasPointer,\r\n            focusTrap,\r\n            hasActiveElements,\r\n        } },\r\n        React.createElement(StyledContainer, Object.assign({}, other, { onKeyDown: handleKeyDown, onBlur: handlePopoverBlur, ref: ref, \"data-testid\": testId, onMouseOver: handleMouseOver, onMouseLeave: handleMouseLeave, id: popoverId, onFocus: onFocus }), children)));\r\n});\r\n//# sourceMappingURL=Popover.js.map"]} */",
|
|
8524
8533
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$b
|
|
8525
8534
|
});
|
|
8526
8535
|
var PopoverContext = /*#__PURE__*/React__default.createContext({
|
|
@@ -8536,15 +8545,6 @@ function hasActiveElementsChecker(ref) {
|
|
|
8536
8545
|
return element instanceof HTMLElement && style.display !== 'none' && style.visibility !== 'hidden' && !element.hasAttribute('disabled');
|
|
8537
8546
|
}).length > 0;
|
|
8538
8547
|
}
|
|
8539
|
-
function isElementInteractive(element) {
|
|
8540
|
-
if (!element || !(element instanceof HTMLElement)) return false;
|
|
8541
|
-
var tag = element.tagName.toLowerCase();
|
|
8542
|
-
if (['button', 'input', 'select', 'textarea', 'a'].includes(tag) || element.hasAttribute('tabindex')) {
|
|
8543
|
-
if (tag === 'a' && !element.href) return false;
|
|
8544
|
-
return !element.hasAttribute('disabled');
|
|
8545
|
-
}
|
|
8546
|
-
return false;
|
|
8547
|
-
}
|
|
8548
8548
|
var Popover = /*#__PURE__*/React__default.forwardRef(function (props, forwardedRef) {
|
|
8549
8549
|
var _refs$reference$curre;
|
|
8550
8550
|
var _React$useState = React__default.useState(false),
|
|
@@ -13894,7 +13894,7 @@ var Container$2 = /*#__PURE__*/_styled("div", {
|
|
|
13894
13894
|
styles: "display:inline-block;position:relative"
|
|
13895
13895
|
} : {
|
|
13896
13896
|
name: "11ffxfj",
|
|
13897
|
-
styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        toggleRef.current?.focus();\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    dropdownButtonId.current = useGenerateId();\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
|
|
13897
|
+
styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { isElementInteractive, resolveProps, useForkedRef, useGenerateId, } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        if (event && event.type === 'blur') {\r\n            const relatedTarget = event.relatedTarget;\r\n            if (!isElementInteractive(relatedTarget)) {\r\n                toggleRef.current?.focus();\r\n            }\r\n        }\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    dropdownButtonId.current = useGenerateId();\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
|
|
13898
13898
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
13899
13899
|
});
|
|
13900
13900
|
var DropdownContext = /*#__PURE__*/createContext({
|
|
@@ -13953,9 +13953,14 @@ var Dropdown = /*#__PURE__*/forwardRef(function (props, forwardedRef) {
|
|
|
13953
13953
|
onOpen && typeof onOpen === 'function' && onOpen();
|
|
13954
13954
|
}
|
|
13955
13955
|
function closeDropdown(event) {
|
|
13956
|
-
var _toggleRef$current;
|
|
13957
13956
|
setIsOpen(false);
|
|
13958
|
-
(
|
|
13957
|
+
if (event && event.type === 'blur') {
|
|
13958
|
+
var relatedTarget = event.relatedTarget;
|
|
13959
|
+
if (!isElementInteractive(relatedTarget)) {
|
|
13960
|
+
var _toggleRef$current;
|
|
13961
|
+
(_toggleRef$current = toggleRef.current) == null || _toggleRef$current.focus();
|
|
13962
|
+
}
|
|
13963
|
+
}
|
|
13959
13964
|
onClose && typeof onClose === 'function' && onClose(event);
|
|
13960
13965
|
}
|
|
13961
13966
|
function getFilteredItem() {
|
|
@@ -20635,7 +20640,7 @@ function buildLabelPadding(props) {
|
|
|
20635
20640
|
}
|
|
20636
20641
|
}
|
|
20637
20642
|
var TagStyling = function TagStyling(props) {
|
|
20638
|
-
return /*#__PURE__*/css("border:", props.theme.tag.border, ";border-radius:", props.theme.spaceScale.spacing05, ";background:", buildButtonBackground$1(props), ";color:", buildButtonTextColor(props), ";box-shadow:", buildBoxShadow$1(props), ";font-family:", props.theme.bodyFont, ";display:", props.theme.tag.display, ";align-items:", props.theme.tag.alignItems, ";justify-content:", props.theme.tag.justifyContent, ";font-size:", props.size === 'small' ? "" + props.theme.typeScale.size01.fontSize : "" + props.theme.typeScale.size02.fontSize, ";font-weight:", props.size === 'small' ? "500" : "inherit", ";letter-spacing:", props.size === 'small' ? "" + props.theme.typeScale.size01.letterSpacing : "" + props.theme.typeScale.size02.letterSpacing, ";min-width:", props.size === 'small' ? props.theme.spaceScale.spacing10 : props.theme.spaceScale.spacing12, ";padding:", buildTagPadding(props), ";svg:first-of-type{opacity:", props.disabled ? buildSvgOpacity(props) : 'inherit', ";height:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";}svg:last-child{opacity:", buildSvgOpacity(props), ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";};label:TagStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAyLgC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20643
|
+
return /*#__PURE__*/css("border:", props.theme.tag.border, ";border-radius:", props.theme.spaceScale.spacing05, ";background:", buildButtonBackground$1(props), ";color:", buildButtonTextColor(props), ";box-shadow:", buildBoxShadow$1(props), ";font-family:", props.theme.bodyFont, ";display:", props.theme.tag.display, ";align-items:", props.theme.tag.alignItems, ";justify-content:", props.theme.tag.justifyContent, ";font-size:", props.size === 'small' ? "" + props.theme.typeScale.size01.fontSize : "" + props.theme.typeScale.size02.fontSize, ";font-weight:", props.size === 'small' ? "500" : "inherit", ";letter-spacing:", props.size === 'small' ? "" + props.theme.typeScale.size01.letterSpacing : "" + props.theme.typeScale.size02.letterSpacing, ";min-width:", props.size === 'small' ? props.theme.spaceScale.spacing10 : props.theme.spaceScale.spacing12, ";padding:", buildTagPadding(props), ";svg:first-of-type{opacity:", props.disabled ? buildSvgOpacity(props) : 'inherit', ";height:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";}svg:last-child{opacity:", buildSvgOpacity(props), ";width:", props.size === 'small' ? props.theme.iconSizes.xSmall + "px" : props.theme.iconSizes.small + "px", ";};label:TagStyling;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAyLgC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20639
20644
|
};
|
|
20640
20645
|
var StyledButton$5 = /*#__PURE__*/_styled("button", {
|
|
20641
20646
|
target: "e10ye2342",
|
|
@@ -20644,17 +20649,17 @@ var StyledButton$5 = /*#__PURE__*/_styled("button", {
|
|
|
20644
20649
|
return props.disabled ? 'not-allowed' : 'pointer';
|
|
20645
20650
|
}, ";&:focus{outline-offset:2px;outline:2px solid ", function (props) {
|
|
20646
20651
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
20647
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA8NmC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20652
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA8NmC","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20648
20653
|
var StyledSpan$3 = /*#__PURE__*/_styled("span", {
|
|
20649
20654
|
target: "e10ye2341",
|
|
20650
20655
|
label: "StyledSpan"
|
|
20651
20656
|
})(TagStyling, ";cursor:", function (props) {
|
|
20652
20657
|
return props.disabled ? 'not-allowed' : 'inherit';
|
|
20653
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAyO+B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20658
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AAyO+B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20654
20659
|
var LabelWrap = /*#__PURE__*/_styled("span", {
|
|
20655
20660
|
target: "e10ye2340",
|
|
20656
20661
|
label: "LabelWrap"
|
|
20657
|
-
})("padding:", buildLabelPadding, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA6O8B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, getNodeText(labelText));\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size }, rest, { theme: theme }), children),\r\n        onDelete && (React.createElement(CancelIcon, { \"aria-label\": deleteAriaLabel, size: theme.iconSizes.small }))));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20662
|
+
})("padding:", buildLabelPadding, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Tag.tsx"],"names":[],"mappings":"AA6O8B","file":"Tag.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { CancelIcon } from 'react-magma-icons';\r\nimport { I18nContext } from '../../i18n';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { getNodeText } from '../../utils';\r\nexport var TagColor;\r\n(function (TagColor) {\r\n    TagColor[\"default\"] = \"default\";\r\n    TagColor[\"primary\"] = \"primary\";\r\n    TagColor[\"lowContrast\"] = \"lowContrast\";\r\n    TagColor[\"highContrast\"] = \"highContrast\";\r\n})(TagColor || (TagColor = {}));\r\nexport var TagSize;\r\n(function (TagSize) {\r\n    TagSize[\"medium\"] = \"medium\";\r\n    TagSize[\"small\"] = \"small\";\r\n})(TagSize || (TagSize = {}));\r\nfunction buildBoxShadow(props) {\r\n    if (props.color === 'lowContrast') {\r\n        if (props.isInverse) {\r\n            if (props.disabled) {\r\n                return `0 0 0 1px ${transparentize(0.8, props.theme.colors.neutral100)}`;\r\n            }\r\n            return `0 0 0 1px ${transparentize(0.5, props.theme.colors.neutral100)}`;\r\n        }\r\n        if (props.disabled) {\r\n            return `0 0 0 1px ${props.theme.colors.neutral300}`;\r\n        }\r\n        return `inset 0 0 0  1px ${props.theme.colors.neutral400}`;\r\n    }\r\n}\r\nfunction buildButtonBackground(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state background colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return `none`;\r\n                default:\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.tertiary500;\r\n            case 'lowContrast':\r\n                return `none;`;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return props.theme.colors.neutral500;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state background colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n            case 'highContrast':\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n            case 'lowContrast':\r\n                return props.theme.colors.neutral100;\r\n            default:\r\n                return transparentize(0.4, props.theme.colors.neutral300);\r\n        }\r\n    }\r\n    // Default state background colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.primary;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral300;\r\n    }\r\n}\r\nfunction buildButtonTextColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.disabled) {\r\n            // Disabled inverse state text colors\r\n            switch (props.color) {\r\n                case 'primary':\r\n                case 'highContrast':\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n                case 'lowContrast':\r\n                    return transparentize(0.7, props.theme.colors.neutral100);\r\n                default:\r\n                    return transparentize(0.6, props.theme.colors.neutral100);\r\n            }\r\n        }\r\n        // Inverse text colors\r\n        switch (props.color) {\r\n            case 'primary':\r\n                return props.theme.colors.primary600;\r\n            case 'lowContrast':\r\n                return props.theme.colors.tertiary500;\r\n            case 'highContrast':\r\n                return props.theme.colors.neutral700;\r\n            default:\r\n                return props.theme.colors.neutral100;\r\n        }\r\n    }\r\n    else if (props.disabled && !props.isInverse) {\r\n        // Disabled state text colors\r\n        return transparentize(0.4, props.theme.colors.neutral500);\r\n    }\r\n    // Default state text colors\r\n    switch (props.color) {\r\n        case 'primary':\r\n            return props.theme.colors.neutral100;\r\n        case 'highContrast':\r\n            return props.theme.colors.neutral100;\r\n        case 'lowContrast':\r\n            return props.theme.colors.neutral700;\r\n        default:\r\n            return props.theme.colors.neutral700;\r\n    }\r\n}\r\nfunction buildSvgOpacity(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === 'lowContrast' && props.disabled) {\r\n            return '30%';\r\n        }\r\n        if (props.onClick || props.onDelete) {\r\n            if (props.disabled) {\r\n                return '40%';\r\n            }\r\n            return '75%';\r\n        }\r\n    }\r\n    if (props.onClick || props.onDelete) {\r\n        if (props.disabled) {\r\n            return '60%';\r\n        }\r\n        return '75%';\r\n    }\r\n    if (props.color === 'lowContrast' && props.disabled) {\r\n        return '30%';\r\n    }\r\n    else if (props.disabled) {\r\n        return '40%';\r\n    }\r\n    return '1';\r\n}\r\nfunction buildTagPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `${props.theme.spaceScale.spacing02} 6px`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `${props.theme.spaceScale.spacing02} 6px`;\r\n    }\r\n}\r\nfunction buildLabelPadding(props) {\r\n    if (props.icon) {\r\n        switch (props.size) {\r\n            case 'small':\r\n                return `0 ${props.theme.spaceScale.spacing02}`;\r\n            default:\r\n                return `0 ${props.theme.spaceScale.spacing03}`;\r\n        }\r\n    }\r\n    switch (props.size) {\r\n        case 'small':\r\n            return `0 ${props.theme.spaceScale.spacing02}`;\r\n        default:\r\n            return `0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n}\r\nconst TagStyling = props => css `\n  border: ${props.theme.tag.border};\n  border-radius: ${props.theme.spaceScale.spacing05};\n  background: ${buildButtonBackground(props)};\n  color: ${buildButtonTextColor(props)};\n  box-shadow: ${buildBoxShadow(props)};\n  font-family: ${props.theme.bodyFont};\n  display: ${props.theme.tag.display};\n  align-items: ${props.theme.tag.alignItems};\n  justify-content: ${props.theme.tag.justifyContent};\n  font-size: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.fontSize}`\r\n    : `${props.theme.typeScale.size02.fontSize}`};\n  font-weight: ${props.size === 'small' ? `500` : `inherit`};\n  letter-spacing: ${props.size === 'small'\r\n    ? `${props.theme.typeScale.size01.letterSpacing}`\r\n    : `${props.theme.typeScale.size02.letterSpacing}`};\n  min-width: ${props.size === 'small'\r\n    ? props.theme.spaceScale.spacing10\r\n    : props.theme.spaceScale.spacing12};\n  padding: ${buildTagPadding(props)};\n  svg:first-of-type {\n    opacity: ${props.disabled ? buildSvgOpacity(props) : 'inherit'};\n    height: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n  svg:last-child {\n    opacity: ${buildSvgOpacity(props)};\n    width: ${props.size === 'small'\r\n    ? `${props.theme.iconSizes.xSmall}px`\r\n    : `${props.theme.iconSizes.small}px`};\n  }\n`;\r\nconst StyledButton = styled.button `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'pointer')};\n  &:focus {\n    outline-offset: 2px;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n`;\r\nconst StyledSpan = styled.span `\n  ${TagStyling};\n  cursor: ${props => (props.disabled ? 'not-allowed' : 'inherit')};\n`;\r\nconst LabelWrap = styled.span `\n  padding: ${buildLabelPadding};\n`;\r\nfunction getStyledTag(isClickable) {\r\n    return isClickable ? StyledButton : StyledSpan;\r\n}\r\nexport const Tag = React.forwardRef((props, ref) => {\r\n    const { children, color, labelText = children, onClick, onDelete, isInverse: isInverseProp, size = TagSize.medium, testId, ...rest } = props;\r\n    const theme = React.useContext(ThemeContext);\r\n    const isInverse = useIsInverse(isInverseProp);\r\n    const i18n = React.useContext(I18nContext);\r\n    const nodeLabel = getNodeText(labelText);\r\n    const deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\\{labelText\\}/g, nodeLabel);\r\n    const { icon } = props;\r\n    const StyledTag = getStyledTag(Boolean(onClick || onDelete));\r\n    function handleClick() {\r\n        if (onClick && typeof onClick === 'function') {\r\n            onClick();\r\n        }\r\n        else if (onDelete && typeof onDelete === 'function') {\r\n            onDelete();\r\n        }\r\n    }\r\n    return (React.createElement(StyledTag, Object.assign({ \"aria-label\": onDelete ? deleteAriaLabel : nodeLabel, color: color, icon: icon, onClick: handleClick, isInverse: isInverse, ref: ref, \"data-testid\": props.testId, size: size, theme: theme }, rest),\r\n        icon,\r\n        React.createElement(LabelWrap, Object.assign({ size: size, theme: theme }, rest), children),\r\n        onDelete && React.createElement(CancelIcon, { size: theme.iconSizes.small })));\r\n});\r\n//# sourceMappingURL=Tag.js.map"]} */"));
|
|
20658
20663
|
function getStyledTag(isClickable) {
|
|
20659
20664
|
return isClickable ? StyledButton$5 : StyledSpan$3;
|
|
20660
20665
|
}
|
|
@@ -20672,7 +20677,8 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
20672
20677
|
var theme = useContext(ThemeContext);
|
|
20673
20678
|
var isInverse = useIsInverse(isInverseProp);
|
|
20674
20679
|
var i18n = useContext(I18nContext);
|
|
20675
|
-
var
|
|
20680
|
+
var nodeLabel = getNodeText(labelText);
|
|
20681
|
+
var deleteAriaLabel = i18n.tag.deleteAriaLabel.replace(/\{labelText\}/g, nodeLabel);
|
|
20676
20682
|
var icon = props.icon;
|
|
20677
20683
|
var StyledTag = getStyledTag(Boolean(onClick || onDelete));
|
|
20678
20684
|
function handleClick() {
|
|
@@ -20683,6 +20689,7 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
20683
20689
|
}
|
|
20684
20690
|
}
|
|
20685
20691
|
return /*#__PURE__*/createElement(StyledTag, Object.assign({
|
|
20692
|
+
"aria-label": onDelete ? deleteAriaLabel : nodeLabel,
|
|
20686
20693
|
color: color,
|
|
20687
20694
|
icon: icon,
|
|
20688
20695
|
onClick: handleClick,
|
|
@@ -20692,13 +20699,11 @@ var Tag = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
20692
20699
|
size: size,
|
|
20693
20700
|
theme: theme
|
|
20694
20701
|
}, rest), icon, /*#__PURE__*/createElement(LabelWrap, Object.assign({
|
|
20695
|
-
size: size
|
|
20696
|
-
}, rest, {
|
|
20702
|
+
size: size,
|
|
20697
20703
|
theme: theme
|
|
20698
|
-
}), children), onDelete &&
|
|
20699
|
-
"aria-label": deleteAriaLabel,
|
|
20704
|
+
}, rest), children), onDelete && /*#__PURE__*/createElement(CancelIcon, {
|
|
20700
20705
|
size: theme.iconSizes.small
|
|
20701
|
-
}))
|
|
20706
|
+
}));
|
|
20702
20707
|
});
|
|
20703
20708
|
|
|
20704
20709
|
var ToastsContext = /*#__PURE__*/createContext({
|