@nitive/whitepaper-react
Version:
React components automatically generated by whitepaper-bem
50 lines (46 loc) • 3.06 kB
JavaScript
function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
import React from 'react';
import PropTypes from 'prop-types';
import { Bem } from '../../_internal/bem';
import './_font/theme_font_ibm.post.css';
import './_font/theme_font_museo.post.css';
import './_color/theme_color_whitepaper-alert.post.css';
import './_color/theme_color_whitepaper-brand.post.css';
import './_color/theme_color_whitepaper-default.post.css';
import './_color/theme_color_whitepaper-inverse.post.css';
import './_color/theme_color_whitepaper-normal.post.css';
import './_color/theme_color_whitepaper-success.post.css';
import './_color/theme_color_whitepaper-system.post.css';
import './_color/theme_color_whitepaper-warning.post.css';
import './_gap/theme_gap_large.post.css';
import './_gap/theme_gap_medium.post.css';
import './_gap/theme_gap_small.post.css';
import './_breakpoint/theme_breakpoint_default.post.css';
import './_menu/theme_menu_default.post.css';
import './_size/theme_size_default.post.css';
import './_space/theme_space_default.post.css';
var modNames = ['breakpoint', 'color', 'font', 'gap', 'menu', 'size', 'space'];
export function Theme(_ref) {
var additionalModNames = _ref.modNames,
props = _objectWithoutProperties(_ref, ["modNames"]);
return React.createElement(Bem, _extends({
block: "theme"
}, props, {
modNames: modNames.concat(additionalModNames || []),
getHtml: undefined
}));
}
Theme.propTypes = {
tag: PropTypes.string,
className: PropTypes.string,
modNames: PropTypes.arrayOf(PropTypes.string),
breakpoint: PropTypes.oneOf(['default']),
color: PropTypes.oneOf(['whitepaper-alert', 'whitepaper-brand', 'whitepaper-default', 'whitepaper-inverse', 'whitepaper-normal', 'whitepaper-success', 'whitepaper-system', 'whitepaper-warning']),
font: PropTypes.oneOf(['ibm', 'museo']),
gap: PropTypes.oneOf(['large', 'medium', 'small']),
menu: PropTypes.oneOf(['default']),
size: PropTypes.oneOf(['default']),
space: PropTypes.oneOf(['default'])
};