grommet
Version:
focus on the essential experience
48 lines (47 loc) • 2.61 kB
JavaScript
;
exports.__esModule = true;
exports.StyledText = void 0;
var _styledComponents = _interopRequireWildcard(require("styled-components"));
var _utils = require("../../utils");
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
var sizeStyle = function sizeStyle(props) {
var size = props.size || 'medium';
var data = props.theme.text[size];
if (data) {
return (0, _styledComponents.css)(["font-size:", ";line-height:", ";"], data.size, data.height);
}
return (0, _styledComponents.css)(["font-size:", ";line-height:normal;"], size);
};
var truncateStyle = "\n white-space: nowrap;\n max-width: 100%;\n overflow: hidden;\n text-overflow: ellipsis;\n";
var colorStyle = (0, _styledComponents.css)(["color:", ";"], function (props) {
return (0, _utils.normalizeColor)(props.colorProp, props.theme);
});
var weightStyle = (0, _styledComponents.css)(["font-weight:", ";"], function (props) {
return props.weight;
});
var wordBreakStyle = (0, _styledComponents.css)(["word-break:", ";"], function (props) {
return props.wordBreak;
});
var fontFamily = (0, _styledComponents.css)(["font-family:", ";"], function (props) {
return props.theme.text.font.family;
});
var StyledText = exports.StyledText = (0, _styledComponents["default"])('span').withConfig(_utils.styledComponentsConfig).withConfig({
displayName: "StyledText",
componentId: "sc-1sadyjn-0"
})(["", " ", " ", " ", " ", " ", " ", " ", " ", ""], _utils.genericStyles, function (props) {
return sizeStyle(props);
}, function (props) {
return props.textAlign && _utils.textAlignStyle;
}, function (props) {
return props.truncate && truncateStyle;
}, function (props) {
return props.colorProp && colorStyle;
}, function (props) {
return props.weight && weightStyle;
}, function (props) {
return props.wordBreak && wordBreakStyle;
}, function (props) {
return props.theme.text.font && props.theme.text.font.family && fontFamily;
}, function (props) {
return props.theme.text && props.theme.text.extend;
});