UNPKG

@teamsparta/stack-button

Version:
325 lines (321 loc) 10.1 kB
"use strict"; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // src/IconButton/IconButton.style.ts var IconButton_style_exports = {}; __export(IconButton_style_exports, { adjustTouchableCss: () => adjustTouchableCss2, buttonBaseCss: () => buttonBaseCss2, buttonIconSizeCss: () => buttonIconSizeCss, buttonRadiusCss: () => buttonRadiusCss, buttonRoundedCss: () => buttonRoundedCss2, buttonSizeCss: () => buttonSizeCss, disabledCss: () => disabledCss2, iconButtonVariants: () => iconButtonVariants }); module.exports = __toCommonJS(IconButton_style_exports); var import_react2 = require("@emotion/react"); var import_stack_tokens2 = require("@teamsparta/stack-tokens"); var import_stack_utils2 = require("@teamsparta/stack-utils"); // src/Button/Button.style.ts var import_react = require("@emotion/react"); var import_stack_font = require("@teamsparta/stack-font"); var import_stack_tokens = require("@teamsparta/stack-tokens"); var import_stack_utils = require("@teamsparta/stack-utils"); var bgColorVar = "--stack-button-bg-color"; var hoverBgColorVar = "--stack-button-hover-bg-color"; var textColorVar = "--stack-button-text-color"; var borderColorVar = "--stack-button-border-color"; var buttonVariants = { // todo "solid-primary": { [bgColorVar]: import_stack_tokens.vars.button.solidPrimary.background, [hoverBgColorVar]: import_stack_tokens.vars.button.solidPrimary.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.solidPrimary.text }, "solid-secondary": { [bgColorVar]: import_stack_tokens.vars.button.solidSecondary.background, [hoverBgColorVar]: import_stack_tokens.vars.button.solidSecondary.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.solidSecondary.text }, "solid-tertiary": { [bgColorVar]: import_stack_tokens.vars.button.solidTertiary.background, [hoverBgColorVar]: import_stack_tokens.vars.button.solidTertiary.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.solidTertiary.text }, "solid-error": { [bgColorVar]: import_stack_tokens.vars.button.solidError.background, [hoverBgColorVar]: import_stack_tokens.vars.button.solidError.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.solidError.text }, // done "outline-primary": { [bgColorVar]: import_stack_tokens.vars.button.outlinePrimary.background, [hoverBgColorVar]: import_stack_tokens.vars.button.outlinePrimary.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.outlinePrimary.text, [borderColorVar]: import_stack_tokens.vars.button.outlinePrimary.border }, "outline-secondary": { [bgColorVar]: import_stack_tokens.vars.button.outlineSecondary.background, [hoverBgColorVar]: import_stack_tokens.vars.button.outlineSecondary.backgroundHover, [textColorVar]: import_stack_tokens.vars.button.outlineSecondary.text, [borderColorVar]: import_stack_tokens.vars.button.outlineSecondary.border }, "outline-tertiary": {}, "outline-error": {} }; var buttonBaseCss = (0, import_react.css)({ position: "relative", display: "inline-flex", alignItems: "center", justifyContent: "center", cursor: "pointer", outline: "none", transition: "background-color 0.08s ease-in-out", backgroundColor: (0, import_stack_utils.getVar)(bgColorVar), border: `1px solid ${(0, import_stack_utils.getVar)(borderColorVar)}`, color: (0, import_stack_utils.getVar)(textColorVar), userSelect: "none", "@media (hover: hover) and (pointer: fine)": { "&:hover:not(:disabled)": { backgroundColor: (0, import_stack_utils.getVar)(hoverBgColorVar) } }, "&:active:not(:disabled)": { backgroundColor: (0, import_stack_utils.getVar)(hoverBgColorVar) }, "&:focus": { outline: "revert" } }); var buttonChildrenCss = (0, import_react.css)({ display: "flex", alignItems: "center", justifyContent: "center", whiteSpace: "nowrap", "&[data-loading='true']": { opacity: 0 } }); var buttonRoundedCss = (0, import_react.css)({ borderRadius: "999px" }); var addonCss = (0, import_react.css)({ display: "inline-flex", alignItems: "center", justifyContent: "center", "& > svg": { color: `${(0, import_stack_utils.getVar)(textColorVar)} !important` }, "&[data-loading='true']": { opacity: 0 } }); var loadingContainerCss = (0, import_react.css)({ cursor: "not-allowed" }); var spinnerContainerCss = (0, import_react.css)({ position: "absolute", top: 0, left: 0, width: "100%", height: "100%", display: "flex", alignItems: "center", justifyContent: "center" }); var adjustTouchableCss = (0, import_react.css)({ display: "block", position: "absolute", minWidth: "48px", minHeight: "48px", width: "100%", height: "100%" }); var disabledCss = (0, import_react.css)({ opacity: "0.35", cursor: "not-allowed" }); // src/IconButton/IconButton.style.ts var iconButtonSizeVariants = { xs: { width: "36px", height: "36px", padding: "10px" }, sm: { width: "40px", height: "40px", padding: "12px" }, md: { width: "48px", height: "48px", padding: "14px" }, lg: { width: "52px", height: "52px", padding: "16px" }, xl: { width: "56px", height: "56px", padding: "16px" } }; var iconButtonRadiusVariants = { xs: { borderRadius: "6px" }, sm: { borderRadius: "6px" }, md: { borderRadius: "8px" }, lg: { borderRadius: "8px" }, xl: { borderRadius: "8px" } }; var iconButtonIconVariants = { xs: { svg: { width: "16px", height: "16px" } }, sm: { svg: { width: "16px", height: "16px" } }, md: { svg: { width: "20px", height: "20px" } }, lg: { svg: { width: "20px", height: "20px" } }, xl: { svg: { width: "24px", height: "24px" } } }; var iconButtonVariants = { "solid-primary": { [bgColorVar]: import_stack_tokens2.vars.button.solidPrimary.background, [hoverBgColorVar]: import_stack_tokens2.vars.button.solidPrimary.backgroundHover, [textColorVar]: import_stack_tokens2.vars.button.solidPrimary.text }, "solid-secondary": { [bgColorVar]: import_stack_tokens2.vars.button.solidSecondary.background, [hoverBgColorVar]: import_stack_tokens2.vars.button.solidSecondary.backgroundHover, [textColorVar]: import_stack_tokens2.vars.button.solidSecondary.text }, "solid-tertiary": { [bgColorVar]: import_stack_tokens2.vars.button.solidTertiary.background, [hoverBgColorVar]: import_stack_tokens2.vars.button.solidTertiary.backgroundHover, [textColorVar]: import_stack_tokens2.vars.button.solidTertiary.text }, "outline-primary": { [bgColorVar]: import_stack_tokens2.vars.button.outlinePrimary.background, [hoverBgColorVar]: import_stack_tokens2.vars.button.outlinePrimary.backgroundHover, [borderColorVar]: import_stack_tokens2.vars.button.outlinePrimary.border, [textColorVar]: import_stack_tokens2.vars.button.outlinePrimary.text }, "outline-secondary": { [bgColorVar]: import_stack_tokens2.vars.button.outlineSecondary.background, [hoverBgColorVar]: import_stack_tokens2.vars.button.outlineSecondary.backgroundHover, [borderColorVar]: import_stack_tokens2.vars.button.outlineSecondary.border, [textColorVar]: import_stack_tokens2.vars.button.outlineSecondary.text }, // NOTE: outline-tertiary 미사용 "outline-tertiary": {} }; var buttonBaseCss2 = (0, import_react2.css)({ position: "relative", display: "inline-flex", alignItems: "center", justifyContent: "center", cursor: "pointer", outline: "none", transition: "background-color 0.08s ease-in-out", backgroundColor: (0, import_stack_utils2.getVar)(bgColorVar), border: `1px solid ${(0, import_stack_utils2.getVar)(borderColorVar)}`, userSelect: "none", "@media (hover: hover) and (pointer: fine)": { "&:hover:not(:disabled)": { backgroundColor: (0, import_stack_utils2.getVar)(hoverBgColorVar) } }, "&:active:not(:disabled)": { backgroundColor: (0, import_stack_utils2.getVar)(hoverBgColorVar) }, "&:focus": { outline: "revert" } }); var buttonIconSizeCss = (sizes) => sizes.map( ({ breakpoint, size }) => import_react2.css` @media screen and (min-width: ${breakpoint}px) { ${iconButtonIconVariants[size]} } ` ); var buttonSizeCss = (sizes) => sizes.map( ({ breakpoint, size }) => import_react2.css` @media screen and (min-width: ${breakpoint}px) { ${iconButtonSizeVariants[size]} } ` ); var buttonRadiusCss = (sizes) => sizes.map( ({ breakpoint, size }) => import_react2.css` @media screen and (min-width: ${breakpoint}px) { ${iconButtonRadiusVariants[size]} } ` ); var buttonRoundedCss2 = (0, import_react2.css)({ borderRadius: "999px" }); var adjustTouchableCss2 = (0, import_react2.css)({ display: "block", position: "absolute", minWidth: "48px", minHeight: "48px", width: "100%", height: "100%" }); var disabledCss2 = (0, import_react2.css)({ opacity: "0.35", cursor: "not-allowed" }); // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { adjustTouchableCss, buttonBaseCss, buttonIconSizeCss, buttonRadiusCss, buttonRoundedCss, buttonSizeCss, disabledCss, iconButtonVariants });