@input-output-hk/front-end-site-components
Version:
Opinionated React components for IOHK's front-end web team
243 lines (227 loc) • 37.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _styledComponents = require("styled-components");
var _theme = require("@input-output-hk/front-end-core-libraries/build/theme");
function _templateObject() {
var data = (0, _taggedTemplateLiteral2["default"])(["\n html {\n max-width: 100%;\n overflow-x: hidden;\n background-color: ", ";\n box-sizing: border-box;\n font-size: 62.5%;\n }\n\n *,\n *:before,\n *:after {\n box-sizing:inherit;\n }\n\n hr {\n height: 0.1rem;\n color: ", ";\n background-color: ", ";\n border: none;\n }\n\n body {\n color: ", ";\n margin: 0;\n background-color: ", ";\n -ms-overflow-style: -ms-autohiding-scrollbar;\n min-height: 100vh;\n }\n\n body,\n input,\n textarea {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h1 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h2 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h3 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h4 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h5 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n h6 {\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n letter-spacing: ", ";\n text-transform: ", ";\n ", "\n }\n\n small {\n color: ", ";\n }\n\n ul,\n ol {\n list-style-position: inside;\n margin-left:0;\n padding: 0;\n }\n\n a {\n outline-width: 0.5rem;\n color: ", ";\n transition: color 0.1s ease-in-out;\n text-decoration: none;\n\n &:hover {\n color: ", ";\n }\n }\n\n img {\n max-width: 100%;\n height: auto;\n }\n"]);
_templateObject = function _templateObject() {
return data;
};
return data;
}
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function getProperty(key) {
return key.replace(/([A-Z])/g, function (_, upper) {
return "-".concat(upper.toLowerCase());
});
}
function getResponsiveFontCSS(font, baseFontSize, defaultLetterSpacing) {
var baseCSS = '';
var excludedKeys = ['font-family', 'font-size', 'font-weight', 'line-height', 'letter-spacing', 'text-transform'];
var responsiveKeys = [];
Object.keys(font).forEach(function (key) {
if (key.match(/^@/)) {
responsiveKeys.push(key);
} else if (!excludedKeys.includes(key)) {
baseCSS += "".concat(getProperty(key), ": ").concat(font[key], ";");
}
});
var responsiveConfig = {};
responsiveKeys.forEach(function (key) {
responsiveConfig[key] = _objectSpread({}, font[key]);
if (responsiveConfig[key].fontSize !== undefined) responsiveConfig[key].fontSize = (0, _theme.getFontSize)(responsiveConfig[key].fontSize, baseFontSize);
if (responsiveConfig[key].letterSpacing !== undefined) responsiveConfig[key].letterSpacing = (0, _theme.getLetterSpacing)(responsiveConfig[key].letterSpacing, defaultLetterSpacing);
});
var responsiveCSS = Object.keys(responsiveConfig).map(function (query) {
var styles = Object.keys(responsiveConfig[query]).map(function (key) {
return "".concat(getProperty(key), ": ").concat(responsiveConfig[query][key], ";");
}).join('');
return "".concat(query, " { ").concat(styles, " }");
}).join('');
return "".concat(baseCSS).concat(responsiveCSS);
}
function getNumericValue(value, defaultValue) {
if (value === undefined || value === null) return defaultValue;
return value;
}
var _default = (0, _styledComponents.createGlobalStyle)(_templateObject(), function (_ref) {
var theme = _ref.theme;
return theme.colors.background["default"];
}, function (_ref2) {
var theme = _ref2.theme;
return theme.colors.text.primary;
}, function (_ref3) {
var theme = _ref3.theme;
return theme.colors.text.primary;
}, function (_ref4) {
var theme = _ref4.theme;
return theme.colors.text.primary;
}, function (_ref5) {
var theme = _ref5.theme;
return theme.colors.background["default"];
}, function (_ref6) {
var theme = _ref6.theme;
return theme.typography.body.fontFamily || theme.typography.fontFamily;
}, function (_ref7) {
var theme = _ref7.theme;
return (0, _theme.getFontSize)(theme.typography.body.fontSize, theme.typography.baseFontSize);
}, function (_ref8) {
var theme = _ref8.theme;
return getNumericValue(theme.typography.body.fontWeight, theme.typography.fontWeight);
}, function (_ref9) {
var theme = _ref9.theme;
return getNumericValue(theme.typography.body.lineHeight, theme.typography.lineHeight);
}, function (_ref10) {
var theme = _ref10.theme;
return (0, _theme.getLetterSpacing)(theme.typography.body.letterSpacing, theme.typography.letterSpacing);
}, function (_ref11) {
var theme = _ref11.theme;
return theme.typography.body.textTransform || theme.typography.textTransform;
}, function (_ref12) {
var theme = _ref12.theme;
return getResponsiveFontCSS(theme.typography.body, theme.typography.baseFontSize);
}, function (_ref13) {
var theme = _ref13.theme;
return theme.typography.h1.fontFamily || theme.typography.fontFamily;
}, function (_ref14) {
var theme = _ref14.theme;
return (0, _theme.getFontSize)(theme.typography.h1.fontSize, theme.typography.baseFontSize);
}, function (_ref15) {
var theme = _ref15.theme;
return getNumericValue(theme.typography.h1.fontWeight, theme.typography.fontWeight);
}, function (_ref16) {
var theme = _ref16.theme;
return getNumericValue(theme.typography.h1.lineHeight, theme.typography.lineHeight);
}, function (_ref17) {
var theme = _ref17.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h1.letterSpacing, theme.typography.letterSpacing);
}, function (_ref18) {
var theme = _ref18.theme;
return theme.typography.h1.textTransform || theme.typography.textTransform;
}, function (_ref19) {
var theme = _ref19.theme;
return getResponsiveFontCSS(theme.typography.h1, theme.typography.baseFontSize);
}, function (_ref20) {
var theme = _ref20.theme;
return theme.typography.h2.fontFamily || theme.typography.fontFamily;
}, function (_ref21) {
var theme = _ref21.theme;
return (0, _theme.getFontSize)(theme.typography.h2.fontSize, theme.typography.baseFontSize);
}, function (_ref22) {
var theme = _ref22.theme;
return getNumericValue(theme.typography.h2.fontWeight, theme.typography.fontWeight);
}, function (_ref23) {
var theme = _ref23.theme;
return getNumericValue(theme.typography.h2.lineHeight, theme.typography.lineHeight);
}, function (_ref24) {
var theme = _ref24.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h2.letterSpacing, theme.typography.letterSpacing);
}, function (_ref25) {
var theme = _ref25.theme;
return theme.typography.h2.textTransform || theme.typography.textTransform;
}, function (_ref26) {
var theme = _ref26.theme;
return getResponsiveFontCSS(theme.typography.h2, theme.typography.baseFontSize);
}, function (_ref27) {
var theme = _ref27.theme;
return theme.typography.h3.fontFamily || theme.typography.fontFamily;
}, function (_ref28) {
var theme = _ref28.theme;
return (0, _theme.getFontSize)(theme.typography.h3.fontSize, theme.typography.baseFontSize);
}, function (_ref29) {
var theme = _ref29.theme;
return getNumericValue(theme.typography.h3.fontWeight, theme.typography.fontWeight);
}, function (_ref30) {
var theme = _ref30.theme;
return getNumericValue(theme.typography.h3.lineHeight, theme.typography.lineHeight);
}, function (_ref31) {
var theme = _ref31.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h3.letterSpacing, theme.typography.letterSpacing);
}, function (_ref32) {
var theme = _ref32.theme;
return theme.typography.h3.textTransform || theme.typography.textTransform;
}, function (_ref33) {
var theme = _ref33.theme;
return getResponsiveFontCSS(theme.typography.h3, theme.typography.baseFontSize);
}, function (_ref34) {
var theme = _ref34.theme;
return theme.typography.h4.fontFamily || theme.typography.fontFamily;
}, function (_ref35) {
var theme = _ref35.theme;
return (0, _theme.getFontSize)(theme.typography.h4.fontSize, theme.typography.baseFontSize);
}, function (_ref36) {
var theme = _ref36.theme;
return getNumericValue(theme.typography.h4.fontWeight, theme.typography.fontWeight);
}, function (_ref37) {
var theme = _ref37.theme;
return getNumericValue(theme.typography.h4.lineHeight, theme.typography.lineHeight);
}, function (_ref38) {
var theme = _ref38.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h4.letterSpacing, theme.typography.letterSpacing);
}, function (_ref39) {
var theme = _ref39.theme;
return theme.typography.h4.textTransform || theme.typography.textTransform;
}, function (_ref40) {
var theme = _ref40.theme;
return getResponsiveFontCSS(theme.typography.h4, theme.typography.baseFontSize);
}, function (_ref41) {
var theme = _ref41.theme;
return theme.typography.h5.fontFamily || theme.typography.fontFamily;
}, function (_ref42) {
var theme = _ref42.theme;
return (0, _theme.getFontSize)(theme.typography.h5.fontSize, theme.typography.baseFontSize);
}, function (_ref43) {
var theme = _ref43.theme;
return getNumericValue(theme.typography.h5.fontWeight, theme.typography.fontWeight);
}, function (_ref44) {
var theme = _ref44.theme;
return getNumericValue(theme.typography.h5.lineHeight, theme.typography.lineHeight);
}, function (_ref45) {
var theme = _ref45.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h5.letterSpacing, theme.typography.letterSpacing);
}, function (_ref46) {
var theme = _ref46.theme;
return theme.typography.h5.textTransform || theme.typography.textTransform;
}, function (_ref47) {
var theme = _ref47.theme;
return getResponsiveFontCSS(theme.typography.h5, theme.typography.baseFontSize);
}, function (_ref48) {
var theme = _ref48.theme;
return theme.typography.h6.fontFamily || theme.typography.fontFamily;
}, function (_ref49) {
var theme = _ref49.theme;
return (0, _theme.getFontSize)(theme.typography.h6.fontSize, theme.typography.baseFontSize);
}, function (_ref50) {
var theme = _ref50.theme;
return getNumericValue(theme.typography.h6.fontWeight, theme.typography.fontWeight);
}, function (_ref51) {
var theme = _ref51.theme;
return getNumericValue(theme.typography.h6.lineHeight, theme.typography.lineHeight);
}, function (_ref52) {
var theme = _ref52.theme;
return (0, _theme.getLetterSpacing)(theme.typography.h6.letterSpacing, theme.typography.letterSpacing);
}, function (_ref53) {
var theme = _ref53.theme;
return theme.typography.h6.textTransform || theme.typography.textTransform;
}, function (_ref54) {
var theme = _ref54.theme;
return getResponsiveFontCSS(theme.typography.h6, theme.typography.baseFontSize);
}, function (_ref55) {
var theme = _ref55.theme;
return theme.colors.text.secondary;
}, function (_ref56) {
var theme = _ref56.theme;
return theme.colors.primary.main;
}, function (_ref57) {
var theme = _ref57.theme;
return theme.colors.primary.light;
});
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Styles.js"],"names":["getProperty","key","replace","_","upper","toLowerCase","getResponsiveFontCSS","font","baseFontSize","defaultLetterSpacing","baseCSS","excludedKeys","responsiveKeys","Object","keys","forEach","match","push","includes","responsiveConfig","fontSize","undefined","letterSpacing","responsiveCSS","map","query","styles","join","getNumericValue","value","defaultValue","createGlobalStyle","theme","colors","background","text","primary","typography","body","fontFamily","fontWeight","lineHeight","textTransform","h1","h2","h3","h4","h5","h6","secondary","main","light"],"mappings":"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","sourcesContent":["import { createGlobalStyle } from 'styled-components'\nimport { getFontSize, getLetterSpacing } from '@input-output-hk/front-end-core-libraries/build/theme'\n\nfunction getProperty (key) {\n  return key.replace(/([A-Z])/g, (_, upper) => `-${upper.toLowerCase()}`)\n}\n\nfunction getResponsiveFontCSS (font, baseFontSize, defaultLetterSpacing) {\n  let baseCSS = ''\n  const excludedKeys = [ 'font-family', 'font-size', 'font-weight', 'line-height', 'letter-spacing', 'text-transform' ]\n  const responsiveKeys = []\n  Object.keys(font).forEach(key => {\n    if (key.match(/^@/)) {\n      responsiveKeys.push(key)\n    } else if (!excludedKeys.includes(key)) {\n      baseCSS += `${getProperty(key)}: ${font[key]};`\n    }\n  })\n\n  const responsiveConfig = {}\n  responsiveKeys.forEach(key => {\n    responsiveConfig[key] = { ...font[key] }\n    if (responsiveConfig[key].fontSize !== undefined) responsiveConfig[key].fontSize = getFontSize(responsiveConfig[key].fontSize, baseFontSize)\n    if (responsiveConfig[key].letterSpacing !== undefined) responsiveConfig[key].letterSpacing = getLetterSpacing(responsiveConfig[key].letterSpacing, defaultLetterSpacing)\n  })\n\n  const responsiveCSS = Object.keys(responsiveConfig).map(query => {\n    const styles = Object.keys(responsiveConfig[query]).map(key => {\n      return `${getProperty(key)}: ${responsiveConfig[query][key]};`\n    }).join('')\n\n    return `${query} { ${styles} }`\n  }).join('')\n\n  return `${baseCSS}${responsiveCSS}`\n}\n\nfunction getNumericValue (value, defaultValue) {\n  if (value === undefined || value === null) return defaultValue\n  return value\n}\n\nexport default createGlobalStyle`\n  html {\n    max-width: 100%;\n    overflow-x: hidden;\n    background-color: ${({ theme }) => theme.colors.background.default};\n    box-sizing: border-box;\n    font-size: 62.5%;\n  }\n\n  *,\n  *:before,\n  *:after {\n    box-sizing:inherit;\n  }\n\n  hr {\n    height: 0.1rem;\n    color: ${({ theme }) => theme.colors.text.primary};\n    background-color: ${({ theme }) => theme.colors.text.primary};\n    border: none;\n  }\n\n  body {\n    color: ${({ theme }) => theme.colors.text.primary};\n    margin: 0;\n    background-color: ${({ theme }) => theme.colors.background.default};\n    -ms-overflow-style: -ms-autohiding-scrollbar;\n    min-height: 100vh;\n  }\n\n  body,\n  input,\n  textarea {\n    font-family: ${({ theme }) => theme.typography.body.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.body.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.body.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.body.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.body.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.body.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.body, theme.typography.baseFontSize)}\n  }\n\n  h1 {\n    font-family: ${({ theme }) => theme.typography.h1.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h1.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h1.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h1.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h1.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h1.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h1, theme.typography.baseFontSize)}\n  }\n\n  h2 {\n    font-family: ${({ theme }) => theme.typography.h2.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h2.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h2.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h2.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h2.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h2.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h2, theme.typography.baseFontSize)}\n  }\n\n  h3 {\n    font-family: ${({ theme }) => theme.typography.h3.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h3.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h3.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h3.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h3.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h3.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h3, theme.typography.baseFontSize)}\n  }\n\n  h4 {\n    font-family: ${({ theme }) => theme.typography.h4.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h4.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h4.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h4.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h4.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h4.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h4, theme.typography.baseFontSize)}\n  }\n\n  h5 {\n    font-family: ${({ theme }) => theme.typography.h5.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h5.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h5.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h5.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h5.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h5.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h5, theme.typography.baseFontSize)}\n  }\n\n  h6 {\n    font-family: ${({ theme }) => theme.typography.h6.fontFamily || theme.typography.fontFamily};\n    font-size: ${({ theme }) => getFontSize(theme.typography.h6.fontSize, theme.typography.baseFontSize)};\n    font-weight: ${({ theme }) => getNumericValue(theme.typography.h6.fontWeight, theme.typography.fontWeight)};\n    line-height: ${({ theme }) => getNumericValue(theme.typography.h6.lineHeight, theme.typography.lineHeight)};\n    letter-spacing: ${({ theme }) => getLetterSpacing(theme.typography.h6.letterSpacing, theme.typography.letterSpacing)};\n    text-transform: ${({ theme }) => theme.typography.h6.textTransform || theme.typography.textTransform};\n    ${({ theme }) => getResponsiveFontCSS(theme.typography.h6, theme.typography.baseFontSize)}\n  }\n\n  small {\n    color: ${({ theme }) => theme.colors.text.secondary};\n  }\n\n  ul,\n  ol {\n    list-style-position: inside;\n    margin-left:0;\n    padding: 0;\n  }\n\n  a {\n    outline-width: 0.5rem;\n    color: ${({ theme }) => theme.colors.primary.main};\n    transition: color 0.1s ease-in-out;\n    text-decoration: none;\n\n    &:hover {\n      color: ${({ theme }) => theme.colors.primary.light};\n    }\n  }\n\n  img {\n    max-width: 100%;\n    height: auto;\n  }\n`\n"]}