@ucloud-fe/react-components 1.3.16 → 1.3.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/main.min.js +1 -1
- package/lib/components/Button/style/index.js +13 -13
- package/package.json +1 -1
|
@@ -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;
|