@ucloud-fe/react-components 1.3.16 → 1.3.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -42,7 +42,7 @@ var sizeMixin = function sizeMixin(props) {
42
42
  (0, _newArrowCheck2.default)(this, _this);
43
43
  var size = props.size,
44
44
  DT = props.theme.designTokens;
45
- return /*#__PURE__*/(0, _core.css)("height:", (0, _style.getHeightBySize)(DT, size), ";line-height:", (0, _style.getHeightBySize)(DT, size), ";padding:0 ", (0, _style.getPaddingBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA2Cc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
45
+ return /*#__PURE__*/(0, _core.css)("height:", (0, _style.getHeightBySize)(DT, size), ";line-height:", (0, _style.getHeightBySize)(DT, size), ";padding:0 ", (0, _style.getPaddingBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA2Cc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
46
46
  }.bind(void 0);
47
47
 
48
48
  var transitionProperty = 'width,height,border,background,color,fill,box-shadow';
@@ -114,7 +114,7 @@ var styleTypeMixin = function styleTypeMixin(props) {
114
114
  boxShadow: 'none',
115
115
  transition: "".concat(transitionProperty, " ").concat(_style.transitionFlat)
116
116
  };
117
- return /*#__PURE__*/(0, _core.css)(disabled ? disabledTheme : styleTypeTheme[styleType], ";", (disabled || styleType === 'border' || styleType === 'border-gray') && /*#__PURE__*/(0, _core.css)("border-width:", DT.T_LINE_WIDTH_BASE, ";border-style:solid;padding:0 ", (0, _style.offsetPaddingBySize)(DT, size, -1), ";line-height:", (0, _style.offsetHeightBySize)(DT, size, -2), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA4HW","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAyHc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
117
+ return /*#__PURE__*/(0, _core.css)(disabled ? disabledTheme : styleTypeTheme[styleType], ";", (disabled || styleType === 'border' || styleType === 'border-gray') && /*#__PURE__*/(0, _core.css)("border-width:", DT.T_LINE_WIDTH_BASE, ";border-style:solid;padding:0 ", (0, _style.offsetPaddingBySize)(DT, size, -1), ";line-height:", (0, _style.offsetHeightBySize)(DT, size, -2), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA4HW","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */")), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAyHc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
118
118
  }.bind(void 0);
119
119
 
120
120
  var shapeMixin = function shapeMixin(props) {
@@ -125,13 +125,13 @@ var shapeMixin = function shapeMixin(props) {
125
125
 
126
126
  switch (shape) {
127
127
  case 'circle':
128
- return /*#__PURE__*/(0, _core.css)("border-radius:50% !important;padding:0;overflow:hidden;width:", (0, _style.getHeightBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA6IsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
128
+ return /*#__PURE__*/(0, _core.css)("border-radius:50% !important;padding:0;overflow:hidden;width:", (0, _style.getHeightBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA6IsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
129
129
 
130
130
  case 'square':
131
- return /*#__PURE__*/(0, _core.css)("padding:0;overflow:hidden;width:", (0, _style.getHeightBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoJsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
131
+ return /*#__PURE__*/(0, _core.css)("padding:0;overflow:hidden;width:", (0, _style.getHeightBySize)(DT, size), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoJsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
132
132
 
133
133
  default:
134
- return /*#__PURE__*/(0, _core.css)(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA0JsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */");
134
+ return /*#__PURE__*/(0, _core.css)(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA0JsB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */");
135
135
  }
136
136
  }.bind(void 0);
137
137
 
@@ -141,7 +141,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
141
141
  } : {
142
142
  name: "mcz7kx",
143
143
  styles: "top:0px;left:0px;bottom:0px;right:0px;",
144
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAqLe","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */",
144
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAqLe","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */",
145
145
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
146
146
  };
147
147
 
@@ -149,13 +149,13 @@ var loadingMixin = function loadingMixin(props) {
149
149
  (0, _newArrowCheck2.default)(this, _this);
150
150
  var DT = props.theme.designTokens,
151
151
  styleType = props.styleType;
152
- return /*#__PURE__*/(0, _core.css)("position:relative;pointer-events:none;&:before{position:absolute;top:-1px;left:-1px;bottom:-1px;right:-1px;background:", DT.T_BUTTON_COMMON_COLOR_MASK, ";opacity:0.6;content:'';border-radius:inherit;z-index:1;transition:opacity 0.2s;", styleType === 'primary' && _ref, "}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoKc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
152
+ return /*#__PURE__*/(0, _core.css)("position:relative;pointer-events:none;&:before{position:absolute;top:-1px;left:-1px;bottom:-1px;right:-1px;background:", DT.T_BUTTON_COMMON_COLOR_MASK, ";opacity:0.6;content:'';border-radius:inherit;z-index:1;transition:opacity 0.2s;", styleType === 'primary' && _ref, "}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoKc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
153
153
  }.bind(void 0);
154
154
 
155
155
  var checkedMixin = function checkedMixin(props) {
156
156
  (0, _newArrowCheck2.default)(this, _this);
157
157
  var DT = props.theme.designTokens;
158
- return /*#__PURE__*/(0, _core.css)("color:", DT.T_COLOR_TEXT_PRIMARY_DEFAULT, ";fill:", DT.T_COLOR_TEXT_PRIMARY_DEFAULT, ";background:", DT.T_COLOR_BG_DEFAULT_HOVER, ";border-color:", DT.T_COLOR_LINE_PRIMARY_DEFAULT, ";box-shadow:", DT.T_SHADOW_BUTTON_HOVER, ";:hover{background:", DT.T_COLOR_BG_DEFAULT_HOVER, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoMc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
158
+ return /*#__PURE__*/(0, _core.css)("color:", DT.T_COLOR_TEXT_PRIMARY_DEFAULT, ";fill:", DT.T_COLOR_TEXT_PRIMARY_DEFAULT, ";background:", DT.T_COLOR_BG_DEFAULT_HOVER, ";border-color:", DT.T_COLOR_LINE_PRIMARY_DEFAULT, ";box-shadow:", DT.T_SHADOW_BUTTON_HOVER, ";:hover{background:", DT.T_COLOR_BG_DEFAULT_HOVER, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoMc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
159
159
  }.bind(void 0);
160
160
 
161
161
  var classNameMixin = function classNameMixin(_ref3) {
@@ -176,7 +176,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
176
176
  } : {
177
177
  name: "8atqhb",
178
178
  styles: "width:100%;",
179
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAmPW","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */",
179
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoPW","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */",
180
180
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
181
181
  };
182
182
 
@@ -188,7 +188,7 @@ var buttonStyleMixin = function buttonStyleMixin(props) {
188
188
  checked = props.checked,
189
189
  block = props.block;
190
190
  var DT = theme.designTokens;
191
- return /*#__PURE__*/(0, _core.css)("margin:0;box-sizing:border-box;border-radius:", DT.T_CORNER_SM, ";text-align:center;text-decoration:none;cursor:pointer;outline:none;font-size:", DT.T_TYPO_FONT_SIZE_1, ";white-space:nowrap;display:inline-flex;align-items:center;vertical-align:middle;", sizeMixin(props), ";", styleTypeMixin(props), ";", shape && shapeMixin(props), ";", loading && loadingMixin(props), ";", checked && checkedMixin(props), ";", block && _ref2, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA+Nc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
191
+ return /*#__PURE__*/(0, _core.css)("margin:0;box-sizing:border-box;border-radius:", DT.T_CORNER_SM, ";text-align:center;text-decoration:none;cursor:pointer;outline:none;font-size:", DT.T_TYPO_FONT_SIZE_1, ";white-space:nowrap;display:inline-flex;align-items:center;justify-content:center;vertical-align:middle;", sizeMixin(props), ";", styleTypeMixin(props), ";", shape && shapeMixin(props), ";", loading && loadingMixin(props), ";", checked && checkedMixin(props), ";", block && _ref2, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA+Nc","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
192
192
  }.bind(void 0);
193
193
  /* eslint-disable @typescript-eslint/no-unused-vars */
194
194
 
@@ -224,7 +224,7 @@ var SButton = (0, _style.sWrap)({
224
224
  })(( /*#__PURE__*/0, _styledBase.default)(Button, {
225
225
  target: "efyr0h00",
226
226
  label: "SButton"
227
- })(buttonStyleMixin, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAyQG","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
227
+ })(buttonStyleMixin, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AA0QG","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
228
228
  exports.SButton = SButton;
229
229
  var SButtonA = (0, _style.sWrap)({
230
230
  className: classNameMixin
@@ -235,6 +235,6 @@ var SButtonA = (0, _style.sWrap)({
235
235
  label: "SButtonA"
236
236
  })(function (props) {
237
237
  (0, _newArrowCheck2.default)(this, _this);
238
- return /*#__PURE__*/(0, _core.css)(buttonStyleMixin(props), ";;label:SButtonA;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoRkB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
239
- }.bind(void 0), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAmRI","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
238
+ return /*#__PURE__*/(0, _core.css)(buttonStyleMixin(props), ";;label:SButtonA;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAqRkB","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
239
+ }.bind(void 0), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/Button/style/index.tsx"],"names":[],"mappings":"AAoRI","file":"../../../../src/components/Button/style/index.tsx","sourcesContent":["import React, { HTMLAttributes } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/core';\nimport classnames from 'classnames';\n\nimport config from 'src/config';\nimport {\n    inlineBlockWithVerticalMixin,\n    sWrap,\n    Theme,\n    getHeightBySize,\n    getPaddingBySize,\n    offsetPaddingBySize,\n    transitionFlat,\n    offsetHeightBySize\n} from 'src/style';\n\nimport { StyleTypes, Sizes, Shapes } from '../shared';\n\nconst { prefixCls: _prefixCls } = config;\nconst prefixCls = _prefixCls + '-button';\nexport const iconCls = prefixCls + '-icon';\n\ninterface SButtonProps {\n    styleType: typeof StyleTypes[number];\n    size: typeof Sizes[number];\n    shape?: typeof Shapes[number];\n    loading?: boolean;\n    disabled?: boolean;\n    fakeDisabled?: boolean;\n    checkAble?: boolean;\n    checked?: boolean;\n    block?: boolean;\n}\ntype SButtonPropsWithTag = SButtonProps & HTMLAttributes<HTMLButtonElement>;\ntype SButtonPropsFinal = SButtonPropsWithTag & { theme: Theme };\n\nconst sizeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        height: ${getHeightBySize(DT, size)};\n        line-height: ${getHeightBySize(DT, size)};\n        padding: 0 ${getPaddingBySize(DT, size)};\n    `;\n};\n\nconst transitionProperty = 'width,height,border,background,color,fill,box-shadow';\n\nconst styleTypeMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType,\n        checkAble,\n        disabled,\n        size\n    } = props;\n\n    const styleTypeTheme = {\n        primary: {\n            color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            fill: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT,\n            border: 'none',\n            background: DT.T_BUTTON_PRIMARY_COLOR_BG_DEFAULT,\n            boxShadow: DT.T_SHADOW_BUTTON_PRIMARY,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_BUTTON_PRIMARY_COLOR_TEXT_DEFAULT\n            },\n            ':hover,:active': {\n                background: DT.T_BUTTON_PRIMARY_COLOR_BG_HOVER,\n                boxShadow: DT.T_SHADOW_BUTTON_PRIMARY_HOVER\n            }\n        },\n        border: {\n            color: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            fill: DT.T_COLOR_TEXT_DEFAULT_DARK,\n            background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n            border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_DARK}`,\n            boxShadow: DT.T_SHADOW_BUTTON_DEFAULT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_DARK\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                border: `1px solid ${DT.T_COLOR_LINE_DEFAULT_LIGHT}`,\n                background: DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT,\n                boxShadow: DT.T_SHADOW_BUTTON_HOVER\n            }\n        },\n        'border-gray': {\n            color: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            fill: DT.T_COLOR_TEXT_DEFAULT_LIGHT,\n            borderColor: DT.T_COLOR_LINE_DEFAULT_LIGHT,\n            background: DT.T_COLOR_BG_DEFAULT_LIGHT,\n            transition: `${transitionProperty} ${transitionFlat}`,\n            ':link,:visited': {\n                color: DT.T_COLOR_TEXT_DEFAULT_LIGHT\n            },\n            ':hover,:active': {\n                color: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                fill: DT.T_COLOR_TEXT_PRIMARY_DEFAULT,\n                borderColor: DT.T_COLOR_LINE_PRIMARY_HOVER,\n                background: checkAble ? DT.T_COLOR_BG_DEFAULT_LIGHT : DT.T_BUTTON_SECONDARY_COLOR_BG_DEFAULT\n            }\n        }\n    };\n    const disabledTheme = {\n        background: DT.T_COLOR_BG_DISABLED_LIGHT,\n        color: DT.T_COLOR_TEXT_DISABLED,\n        fill: DT.T_COLOR_TEXT_DISABLED,\n        cursor: 'default',\n        borderColor: DT.T_COLOR_LINE_DISABLED_LIGHT,\n        boxShadow: 'none',\n        transition: `${transitionProperty} ${transitionFlat}`\n    };\n    return css`\n        ${disabled ? disabledTheme : styleTypeTheme[styleType]};\n        ${(disabled || styleType === 'border' || styleType === 'border-gray') &&\n        css`\n            border-width: ${DT.T_LINE_WIDTH_BASE};\n            border-style: solid;\n            padding: 0 ${offsetPaddingBySize(DT, size, -1)};\n            line-height: ${offsetHeightBySize(DT, size, -2)};\n        `};\n    `;\n};\n\nconst shapeMixin = (props: SButtonPropsFinal) => {\n    const {\n        size,\n        shape,\n        theme: { designTokens: DT }\n    } = props;\n    switch (shape) {\n        case 'circle':\n            return css`\n                border-radius: 50% !important;\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        case 'square':\n            return css`\n                padding: 0;\n                overflow: hidden;\n                width: ${getHeightBySize(DT, size)};\n            `;\n        default:\n            return css``;\n    }\n};\n\nconst loadingMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT },\n        styleType\n    } = props;\n\n    return css`\n        position: relative;\n        pointer-events: none;\n\n        &:before {\n            position: absolute;\n            top: -1px;\n            left: -1px;\n            bottom: -1px;\n            right: -1px;\n            background: ${DT.T_BUTTON_COMMON_COLOR_MASK};\n            opacity: 0.6;\n            content: '';\n            border-radius: inherit;\n            z-index: 1;\n            transition: opacity 0.2s;\n            ${styleType === 'primary' &&\n            css`\n                top: 0px;\n                left: 0px;\n                bottom: 0px;\n                right: 0px;\n            `}\n        }\n    `;\n};\n\nconst checkedMixin = (props: SButtonPropsFinal) => {\n    const {\n        theme: { designTokens: DT }\n    } = props;\n\n    return css`\n        color: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        fill: ${DT.T_COLOR_TEXT_PRIMARY_DEFAULT};\n        background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        border-color: ${DT.T_COLOR_LINE_PRIMARY_DEFAULT};\n        box-shadow: ${DT.T_SHADOW_BUTTON_HOVER};\n        :hover {\n            background: ${DT.T_COLOR_BG_DEFAULT_HOVER};\n        }\n    `;\n};\n\nconst classNameMixin = ({ size, styleType, shape, loading, disabled, fakeDisabled, checked }: SButtonProps) =>\n    classnames(\n        prefixCls,\n        `${prefixCls}-size-${size}`,\n        `${prefixCls}-styletype-${styleType}`,\n        shape && `${prefixCls}-${shape}`,\n        loading && `${prefixCls}-loading`,\n        disabled && `${prefixCls}-disabled`,\n        fakeDisabled && `${prefixCls}-disabled-fake`,\n        checked && `${prefixCls}-checked`\n    );\n\nconst buttonStyleMixin = <T extends SButtonProps & { theme: Theme }>(props: T) => {\n    const { theme, loading, shape, checked, block } = props;\n    const { designTokens: DT } = theme;\n    return css`\n        margin: 0;\n        box-sizing: border-box;\n        border-radius: ${DT.T_CORNER_SM};\n        text-align: center;\n        text-decoration: none;\n        cursor: pointer;\n        outline: none;\n        font-size: ${DT.T_TYPO_FONT_SIZE_1};\n        white-space: nowrap;\n        display: inline-flex;\n        align-items: center;\n        justify-content: center;\n        vertical-align: middle;\n\n        ${sizeMixin(props)};\n        ${styleTypeMixin(props)};\n        ${shape && shapeMixin(props)};\n        ${loading && loadingMixin(props)};\n        ${checked && checkedMixin(props)};\n        ${block &&\n        css`\n            width: 100%;\n        `};\n    `;\n};\n\n/* eslint-disable @typescript-eslint/no-unused-vars */\nconst Button = ({\n    loading,\n    styleType,\n    disabled,\n    fakeDisabled,\n    onClick,\n    checkAble,\n    block,\n    ...rest\n}: SButtonPropsWithTag) => (\n    <button disabled={disabled && !fakeDisabled} onClick={!disabled ? onClick : undefined} {...rest} />\n);\n/* eslint-enable @typescript-eslint/no-unused-vars */\nexport const SButton = sWrap<SButtonProps, HTMLButtonElement>({\n    className: classNameMixin\n})(styled(Button)(buttonStyleMixin));\n\nexport const SButtonA = sWrap<SButtonProps, HTMLAnchorElement>(\n    {\n        className: classNameMixin\n    },\n    {\n        ignoreProps: ['disabled', 'fakeDisabled', 'checked', 'checkAble', 'loading']\n    }\n)(\n    styled('a')(props => {\n        return css`\n            ${buttonStyleMixin(props)};\n        `;\n    })\n);\n"]} */"));
240
240
  exports.SButtonA = SButtonA;