react-magma-dom 3.7.0-next.1 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.js +13 -16
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +190 -193
- 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/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import React__default, { createContext, forwardRef, useContext, createElement, Children, cloneElement, useState, useEffect, Fragment, useRef, useCallback, useLayoutEffect, useMemo, Component, isValidElement } from 'react';
|
|
2
|
-
import _styled from '@emotion/styled-base';
|
|
3
2
|
import _styled$1 from '@emotion/styled';
|
|
4
3
|
import { css, ClassNames, jsx, Global } from '@emotion/core';
|
|
5
4
|
import { CloseIcon, InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, ChevronRightIcon, ClearIcon, CheckBoxIcon, CheckBoxOutlineBlankIcon, IndeterminateCheckBoxIcon, NorthIcon, SouthIcon, SortDoubleArrowIcon, ArrowDropDownIcon, WestIcon, EastIcon, ArrowBackIcon, ArrowForwardIcon, KeyboardIcon, EventIcon, ArrowDropUpIcon, ArrowRightIcon, ArrowLeftIcon, CheckIcon, ExpandMoreIcon, ExpandLessIcon, ArrowBackIosIcon, ArrowForwardIosIcon, RadioButtonCheckedIcon, RadioButtonUncheckedIcon, SearchIcon, CancelIcon, ScheduleIcon, FolderIcon, ArticleIcon } from 'react-magma-icons';
|
|
5
|
+
import _styled from '@emotion/styled-base';
|
|
6
6
|
import ReactDOM__default, { flushSync as flushSync$1 } from 'react-dom';
|
|
7
7
|
import isEqual from 'react-fast-compare';
|
|
8
8
|
import 'warning';
|
|
@@ -3087,7 +3087,7 @@ var ProgressRing = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
3087
3087
|
});
|
|
3088
3088
|
|
|
3089
3089
|
var _excluded$5 = ["additionalContent", "children", "closeAriaLabel", "forceDismiss", "hasTimerRing", "id", "isDismissed", "isDismissible", "isExiting", "isPaused", "isToast", "onDismiss", "testId", "toastDuration", "variant"];
|
|
3090
|
-
var _templateObject$1, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7;
|
|
3090
|
+
var _templateObject$1, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
|
|
3091
3091
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$3() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
3092
3092
|
var typedStyled$1 = _styled$1;
|
|
3093
3093
|
var VARIANT_ICON = {
|
|
@@ -3227,7 +3227,7 @@ var StyledAlert = /*#__PURE__*/typedStyled$1.div(_templateObject$1 || (_template
|
|
|
3227
3227
|
}, function (props) {
|
|
3228
3228
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
3229
3229
|
}, function (props) {
|
|
3230
|
-
return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width:", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3230
|
+
return props.isToast && /*#__PURE__*/css("animation:", props.isExiting ? "slideout " + transitionDuration + "ms" : "slidein " + transitionDuration + "ms", ";min-width:375px;margin:0 auto;@media (max-width:", props.theme.breakpoints.small, "px){min-width:0;width:100%;};label:StyledAlert;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+JQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3231
3231
|
}, function (props) {
|
|
3232
3232
|
return buildLinkColor(props);
|
|
3233
3233
|
}, function (props) {
|
|
@@ -3236,7 +3236,7 @@ var StyledAlert = /*#__PURE__*/typedStyled$1.div(_templateObject$1 || (_template
|
|
|
3236
3236
|
var StyledAlertInner = /*#__PURE__*/typedStyled$1.div(_templateObject2 || (_templateObject2 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n background: ", ";\n border: 1px solid ", ";\n border-radius: ", ";\n color: ", ";\n display: flex;\n position: relative;\n\n ", "\n"])), buildAlertBackground, buildAlertBorder, function (props) {
|
|
3237
3237
|
return props.theme.borderRadius;
|
|
3238
3238
|
}, buildAlertColor, function (props) {
|
|
3239
|
-
return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3239
|
+
return props.isToast && /*#__PURE__*/css("box-shadow:", props.isInverse ? "0 2px 8px 0 " + curriedTransparentize(0.3, props.theme.colors.neutral900) : "0 2px 8px 0 " + curriedTransparentize(0.6, props.theme.colors.neutral900), ";padding-right:0;height:", props.theme.spaceScale.spacing11, ";;label:StyledAlertInner;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAqOQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3240
3240
|
});
|
|
3241
3241
|
var AlertContents = /*#__PURE__*/typedStyled$1.div(_templateObject3 || (_templateObject3 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-items: ", ";\n align-self: center;\n flex-grow: 1;\n font-family: ", ";\n padding: ", " 0;\n display: ", ";\n margin-right: ", ";\n @media (max-width: ", "px) {\n padding-left: 0;\n }\n"])), function (props) {
|
|
3242
3242
|
return props.additionalContent ? 'center' : '';
|
|
@@ -3260,25 +3260,22 @@ var IconWrapperStyles = process.env.NODE_ENV === "production" ? {
|
|
|
3260
3260
|
} : {
|
|
3261
3261
|
name: "15kwy3e-IconWrapperStyles",
|
|
3262
3262
|
styles: "align-items:center;display:flex;flex-shrink:0;margin-right:1px;;label:IconWrapperStyles;",
|
|
3263
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3263
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiQ8B","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
3264
3264
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
3265
3265
|
};
|
|
3266
|
-
var IconWrapper = /*#__PURE__*/
|
|
3267
|
-
target: "e126n3g80",
|
|
3268
|
-
label: "IconWrapper"
|
|
3269
|
-
})(IconWrapperStyles, " padding:0 ", function (props) {
|
|
3266
|
+
var IconWrapper = /*#__PURE__*/typedStyled$1.span(_templateObject5 || (_templateObject5 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", "\n padding: 0 ", " 0 ", ";\n\n @media (max-width: ", "px) {\n padding: 0 ", ";\n svg {\n width: 20px;\n }\n }\n"])), IconWrapperStyles, function (props) {
|
|
3270
3267
|
return props.theme.spaceScale.spacing03;
|
|
3271
|
-
},
|
|
3268
|
+
}, function (props) {
|
|
3272
3269
|
return props.theme.spaceScale.spacing04;
|
|
3273
|
-
},
|
|
3270
|
+
}, function (props) {
|
|
3274
3271
|
return props.theme.breakpoints.small;
|
|
3275
|
-
},
|
|
3272
|
+
}, function (props) {
|
|
3276
3273
|
return props.theme.spaceScale.spacing03;
|
|
3277
|
-
}, ";svg{width:20px;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAuQgC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/core';\r\nimport isPropValid from '@emotion/is-prop-valid';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { InfoIcon, CheckCircleIcon, WarningIcon, ErrorIcon, CloseIcon, } from 'react-magma-icons';\r\nimport { ButtonVariant } from '../Button';\r\nimport { IconButton } from '../IconButton';\r\nimport { ProgressRing } from '../ProgressRing';\r\nimport { useGenerateId } from '../../utils';\r\nimport { I18nContext } from '../../i18n';\r\nimport { InverseContext, useIsInverse } from '../../inverse';\r\nimport styled from '@emotion/styled';\r\nconst typedStyled = styled;\r\nexport const VARIANT_ICON = {\r\n    info: InfoIcon,\r\n    success: CheckCircleIcon,\r\n    warning: WarningIcon,\r\n    danger: ErrorIcon,\r\n};\r\nexport var AlertVariant;\r\n(function (AlertVariant) {\r\n    AlertVariant[\"info\"] = \"info\";\r\n    AlertVariant[\"success\"] = \"success\";\r\n    AlertVariant[\"warning\"] = \"warning\";\r\n    AlertVariant[\"danger\"] = \"danger\";\r\n})(AlertVariant || (AlertVariant = {}));\r\nexport const transitionDuration = 500;\r\nexport function buildAlertBackground(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success700;\r\n            case 'warning':\r\n                return props.theme.colors.warning700;\r\n            case 'danger':\r\n                return props.theme.colors.danger700;\r\n            default:\r\n                return props.theme.colors.info700;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success100;\r\n        case 'warning':\r\n            return props.theme.colors.warning100;\r\n        case 'danger':\r\n            return props.theme.colors.danger100;\r\n        default:\r\n            return props.theme.colors.info100;\r\n    }\r\n}\r\nexport function buildAlertBorder(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success300;\r\n            case 'warning':\r\n                return props.theme.colors.warning300;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info300;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildAlertColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success500;\r\n        case 'warning':\r\n            return props.theme.colors.warning500;\r\n        case 'danger':\r\n            return props.theme.colors.danger500;\r\n        default:\r\n            return props.theme.colors.info500;\r\n    }\r\n}\r\nexport function buildLinkColor(props) {\r\n    if (props.isInverse) {\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return props.theme.colors.success200;\r\n            case 'warning':\r\n                return props.theme.colors.warning200;\r\n            case 'danger':\r\n                return props.theme.colors.danger200;\r\n            default:\r\n                return props.theme.colors.info200;\r\n        }\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success700;\r\n        case 'warning':\r\n            return props.theme.colors.warning700;\r\n        case 'danger':\r\n            return props.theme.colors.danger700;\r\n        default:\r\n            return props.theme.colors.info700;\r\n    }\r\n}\r\nexport function buildLinkHoverColor(props) {\r\n    if (props.isInverse) {\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    switch (props.variant) {\r\n        case 'success':\r\n            return props.theme.colors.success;\r\n        case 'warning':\r\n            return props.theme.colors.warning;\r\n        case 'danger':\r\n            return props.theme.colors.danger;\r\n        default:\r\n            return props.theme.colors.info;\r\n    }\r\n}\r\nconst StyledAlert = typedStyled.div `\n  align-items: stretch;\n  animation: ${props => props.isExiting\r\n    ? `fadeout ${transitionDuration}ms`\r\n    : `fadein ${transitionDuration}ms`};\n  display: flex;\n  flex-direction: column;\n  font-size: ${props => props.theme.typeScale.size03.fontSize};\n  font-family: ${props => props.theme.bodyFont};\n  line-height: ${props => props.theme.typeScale.size03.lineHeight};\n  margin-bottom: ${props => props.theme.spaceScale.spacing06};\n  max-width: 100%;\n  padding: 0;\n  position: relative;\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    font-size: ${props => props.theme.typeScale.size02.fontSize};\n    letter-spacing: ${props => props.theme.typeScale.size02.letterSpacing};\n    line-height: ${props => props.theme.typeScale.size02.lineHeight};\n  }\n\n  &:focus {\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n  }\n\n  ${props => props.isToast &&\r\n    css `\n      animation: ${props.isExiting\r\n        ? `slideout ${transitionDuration}ms`\r\n        : `slidein ${transitionDuration}ms`};\n      min-width: 375px;\n      margin: 0 auto;\n\n      @media (max-width: ${props.theme.breakpoints.small}px) {\n        min-width: 0;\n        width: 100%;\n      }\n    `}\n\n  @keyframes fadein {\n    from {\n      opacity: 0;\n    }\n    to {\n      opacity: 1;\n    }\n  }\n\n  @keyframes fadeout {\n    from {\n      opacity: 1;\n    }\n    to {\n      opacity: 0;\n    }\n  }\n\n  @keyframes slidein {\n    from {\n      left: -500px;\n    }\n    to {\n      left: 0;\n    }\n  }\n\n  @keyframes slideout {\n    from {\n      left: 0;\n    }\n    to {\n      left: -500px;\n    }\n  }\n\n  a {\n    color: ${props => buildLinkColor(props)};\n    font-weight: 400;\n    text-decoration: underline;\n    &:not([disabled]) {\n      &:focus,\n      &:hover {\n        color: ${props => buildLinkHoverColor(props)};\n      }\n    }\n  }\n`;\r\nconst StyledAlertInner = typedStyled.div `\n  background: ${buildAlertBackground};\n  border: 1px solid ${buildAlertBorder};\n  border-radius: ${props => props.theme.borderRadius};\n  color: ${buildAlertColor};\n  display: flex;\n  position: relative;\n\n  ${props => props.isToast &&\r\n    css `\n      box-shadow: ${props.isInverse\r\n        ? `0 2px 8px 0 ${transparentize(0.3, props.theme.colors.neutral900)}`\r\n        : `0 2px 8px 0 ${transparentize(0.6, props.theme.colors.neutral900)}`};\n      padding-right: 0;\n      height: ${props.theme.spaceScale.spacing11};\n    `}\n`;\r\nconst AlertContents = typedStyled.div `\n  align-items: ${props => (props.additionalContent ? 'center' : '')};\n  align-self: center;\n  flex-grow: 1;\n  font-family: ${props => props.theme.bodyFont};\n  padding: ${props => props.theme.spaceScale.spacing04} 0;\n  display: ${props => (props.additionalContent ? 'flex' : '')};\n  margin-right: ${props => props.additionalContent && !props.isDismissible\r\n    ? props.theme.spaceScale.spacing03\r\n    : ''};\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding-left: 0;\n  }\n`;\r\nexport const AdditionalContentWrapper = typedStyled.div `\n  flex: 1 0 auto;\n  justify-content: flex-end;\n  display: flex;\n  margin-left: ${props => props.theme.spaceScale.spacing05};\n`;\r\nconst IconWrapperStyles = css `\n  align-items: center;\n  display: flex;\n  flex-shrink: 0;\n  margin-right: 1px;\n`;\r\nconst IconWrapper = styled.span `\n  ${IconWrapperStyles}\n  padding: 0 ${props => props.theme.spaceScale.spacing03} 0 ${props => props.theme.spaceScale.spacing04};\n\n  @media (max-width: ${props => props.theme.breakpoints.small}px) {\n    padding: 0 ${props => props.theme.spaceScale.spacing03};\n    svg {\n      width: 20px;\n    }\n  }\n`;\r\nconst ProgressRingWrapper = typedStyled.div `\n  margin-top: 6px;\n  position: absolute;\n  top: auto;\n  right: ${props => props.theme.spaceScale.spacing02};\n`;\r\nconst DismissibleIconWrapper = typedStyled.span `\n  ${IconWrapperStyles}\n  margin-left: ${props => props.additionalContent ? props.theme.spaceScale.spacing03 : ''};\n`;\r\nconst whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];\r\nconst shouldForwardProp = prop => {\r\n    return isPropValid(prop) || whitelistProps.includes(prop);\r\n};\r\nconst DismissButton = typedStyled(IconButton, { shouldForwardProp }) `\n  align-self: stretch;\n  border-radius: 0 ${props => props.theme.borderRadius}\n    ${props => props.theme.borderRadius} 0;\n  color: inherit;\n  height: auto;\n  margin: ${props => (props.isToast ? '4px' : '0 -1px 0 0')};\n  padding: ${props => props.isToast\r\n    ? `0 ${props.theme.spaceScale.spacing04}`\r\n    : `0 ${props.theme.spaceScale.spacing03}`};\n  width: auto;\n  &:not(:disabled):hover {\n    background: none;\n    color: inherit;\n  }\n  &:focus:not(:disabled) {\n    background: none;\n    color: inherit;\n    outline: 2px solid\n      ${props => props.isInverse\r\n    ? props.theme.colors.focusInverse\r\n    : props.theme.colors.focus};\n    outline-offset: 0 !important;\n  }\n  &:not(:disabled):active {\n    background: none;\n    color: inherit;\n  }\n`;\r\nfunction renderIcon(variant = 'info', isToast, theme) {\r\n    const Icon = VARIANT_ICON[variant];\r\n    return (React.createElement(IconWrapper, { isToast: isToast, theme: theme },\r\n        React.createElement(Icon, { size: theme.iconSizes.medium })));\r\n}\r\nexport const AlertBase = React.forwardRef((props, ref) => {\r\n    const { additionalContent, children, closeAriaLabel, forceDismiss, hasTimerRing, id: defaultId, isDismissed, isDismissible, isExiting: externalIsExiting, isPaused, isToast, onDismiss, testId, toastDuration, variant, ...other } = props;\r\n    const id = useGenerateId(defaultId);\r\n    const [isExiting, setIsExiting] = React.useState(false);\r\n    const isInverse = useIsInverse(props.isInverse);\r\n    React.useEffect(() => {\r\n        if (isExiting) {\r\n            setTimeout(() => {\r\n                setIsExiting(false);\r\n                onDismiss && typeof onDismiss === 'function' && onDismiss();\r\n            }, transitionDuration - 300);\r\n        }\r\n    }, [isExiting]);\r\n    React.useEffect(() => {\r\n        if (isDismissed) {\r\n            handleDismiss();\r\n        }\r\n    }, [isDismissed]);\r\n    function handleDismiss() {\r\n        setIsExiting(true);\r\n    }\r\n    const theme = React.useContext(ThemeContext);\r\n    const i18n = React.useContext(I18nContext);\r\n    function progressRingColor() {\r\n        if (isInverse) {\r\n            return theme.colors.neutral100;\r\n        }\r\n        switch (props.variant) {\r\n            case 'success':\r\n                return theme.colors.success500;\r\n            case 'warning':\r\n                return theme.colors.warning500;\r\n            case 'danger':\r\n                return theme.colors.danger500;\r\n            default:\r\n                return theme.colors.info500;\r\n        }\r\n    }\r\n    return (React.createElement(StyledAlert, Object.assign({}, other, { \"data-testid\": testId, id: id, tabIndex: -1, isInverse: isInverse, isExiting: isExiting, isToast: isToast, ref: ref, theme: theme, variant: variant }),\r\n        React.createElement(InverseContext.Provider, { value: { isInverse } },\r\n            React.createElement(StyledAlertInner, { isInverse: isInverse, isToast: isToast, theme: theme, variant: variant },\r\n                renderIcon(variant, isToast, theme),\r\n                React.createElement(AlertContents, { additionalContent: additionalContent, isDismissible: isDismissible, theme: theme },\r\n                    React.createElement(\"span\", null, children),\r\n                    additionalContent && (React.createElement(AdditionalContentWrapper, { theme: theme }, additionalContent))),\r\n                isDismissible && (React.createElement(DismissibleIconWrapper, { isInverse: isInverse, variant: variant, theme: theme },\r\n                    hasTimerRing && isToast && (React.createElement(ProgressRingWrapper, { theme: theme },\r\n                        React.createElement(ProgressRing, { color: progressRingColor(), isActive: !isPaused }))),\r\n                    React.createElement(DismissButton, { alertVariant: variant, \"aria-label\": closeAriaLabel\r\n                            ? closeAriaLabel\r\n                            : i18n.alert.dismissAriaLabel, icon: React.createElement(CloseIcon, { size: hasTimerRing\r\n                                ? theme.iconSizes.xSmall\r\n                                : theme.iconSizes.small }), isInverse: isInverse, isToast: isToast, onClick: forceDismiss || handleDismiss, theme: theme, variant: ButtonVariant.link })))))));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
3278
|
-
var ProgressRingWrapper = /*#__PURE__*/typedStyled$1.div(
|
|
3274
|
+
});
|
|
3275
|
+
var ProgressRingWrapper = /*#__PURE__*/typedStyled$1.div(_templateObject6 || (_templateObject6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n margin-top: 6px;\n position: absolute;\n top: auto;\n right: ", ";\n"])), function (props) {
|
|
3279
3276
|
return props.theme.spaceScale.spacing02;
|
|
3280
3277
|
});
|
|
3281
|
-
var DismissibleIconWrapper = /*#__PURE__*/typedStyled$1.span(
|
|
3278
|
+
var DismissibleIconWrapper = /*#__PURE__*/typedStyled$1.span(_templateObject7 || (_templateObject7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n ", "\n margin-left: ", ";\n"])), IconWrapperStyles, function (props) {
|
|
3282
3279
|
return props.additionalContent ? props.theme.spaceScale.spacing03 : '';
|
|
3283
3280
|
});
|
|
3284
3281
|
var whitelistProps = ['icon', 'isInverse', 'theme', 'variant'];
|
|
@@ -3287,7 +3284,7 @@ var shouldForwardProp = function shouldForwardProp(prop) {
|
|
|
3287
3284
|
};
|
|
3288
3285
|
var DismissButton = /*#__PURE__*/typedStyled$1(IconButton, {
|
|
3289
3286
|
shouldForwardProp: shouldForwardProp
|
|
3290
|
-
})(
|
|
3287
|
+
})(_templateObject8 || (_templateObject8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n align-self: stretch;\n border-radius: 0 ", "\n ", " 0;\n color: inherit;\n height: auto;\n margin: ", ";\n padding: ", ";\n width: auto;\n &:not(:disabled):hover {\n background: none;\n color: inherit;\n }\n &:focus:not(:disabled) {\n background: none;\n color: inherit;\n outline: 2px solid\n ", ";\n outline-offset: 0 !important;\n }\n &:not(:disabled):active {\n background: none;\n color: inherit;\n }\n"])), function (props) {
|
|
3291
3288
|
return props.theme.borderRadius;
|
|
3292
3289
|
}, function (props) {
|
|
3293
3290
|
return props.theme.borderRadius;
|