@cimpress/react-components
Version:
React components to support the MCP styleguide
96 lines (88 loc) • 3.14 kB
JavaScript
;
var __rest = (this && this.__rest) || function (s, e) {
var t = {};
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
t[p] = s[p];
if (s != null && typeof Object.getOwnPropertySymbols === "function")
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
t[p[i]] = s[p[i]];
}
return t;
};
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ButtonGroup = ButtonGroup;
const react_1 = __importDefault(require("react"));
const css_1 = require("@emotion/css");
const cvar_1 = __importDefault(require("./theme/cvar"));
const btnGrpCss = (0, css_1.css) `
position: relative;
display: inline-block;
vertical-align: middle;
`;
const btnGrpJustifiedCss = (0, css_1.css) `
button {
display: inline-block;
border-right: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-top: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-bottom: 1px solid ${(0, cvar_1.default)('color-button-primary')};
&:not(:first-child) {
border-radius: 0;
border-left: none;
}
&:not(:last-child) {
border-radius: 0;
}
&:first-child {
border-left: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-top-left-radius: 2px;
border-bottom-left-radius: 2px;
}
&:last-child {
border-top-right-radius: 2px;
border-bottom-right-radius: 2px;
}
}
`;
const btnGrpVerticalCss = (0, css_1.css) `
button {
display: block;
border-bottom: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-left: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-right: 1px solid ${(0, cvar_1.default)('color-button-primary')};
&:not(:first-child) {
border-radius: 0;
border-top: none;
}
&:not(:last-child) {
border-radius: 0;
}
&:first-child {
border-top: 1px solid ${(0, cvar_1.default)('color-button-primary')};
border-top-left-radius: 2px;
border-top-right-radius: 2px;
}
&:last-child {
border-bottom-left-radius: 2px;
border-bottom-right-radius: 2px;
}
}
`;
const hoverActiveBorderCss = (0, css_1.css) `
button {
&:hover {
border-color: ${(0, cvar_1.default)('color-button-primary')};
}
&:active {
border-color: ${(0, cvar_1.default)('color-button-primary')};
}
}
`;
function ButtonGroup(_a) {
var { variant = 'justified', className = '' } = _a, props = __rest(_a, ["variant", "className"]);
return (react_1.default.createElement("div", Object.assign({ className: (0, css_1.cx)('crc-button-group', btnGrpCss, { [btnGrpVerticalCss]: variant === 'vertical', [btnGrpJustifiedCss]: variant !== 'vertical' }, hoverActiveBorderCss, className) }, props), props.children));
}
//# sourceMappingURL=ButtonGroup.js.map