react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
217 lines (177 loc) • 21.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.Row = exports.Col = undefined;
var _keys = require('babel-runtime/core-js/object/keys');
var _keys2 = _interopRequireDefault(_keys);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var Grid = function Grid(_ref) {
var className = _ref.className,
frame = _ref.frame,
children = _ref.children,
props = (0, _objectWithoutProperties3.default)(_ref, ['className', 'frame', 'children']);
var gridClassNames = (0, _classnames2.default)(className, 'slds-grid', 'slds-grid--vertical', frame ? 'slds-grid--frame' : null);
return _react2.default.createElement(
'div',
(0, _extends3.default)({ className: gridClassNames }, props),
children
);
};
function adjustCols(colNum, large) {
if (colNum > 6) {
return large ? 12 : 6;
}
return colNum;
}
var Col = function Col(props) {
var className = props.className,
padded = props.padded,
align = props.align,
noFlex = props.noFlex,
order = props.order,
orderSmall = props.orderSmall,
orderMedium = props.orderMedium,
orderLarge = props.orderLarge,
cols = props.cols,
colsSmall = props.colsSmall,
colsMedium = props.colsMedium,
colsLarge = props.colsLarge,
totalCols = props.totalCols,
totalColsSmall = props.totalColsSmall,
totalColsMedium = props.totalColsMedium,
totalColsLarge = props.totalColsLarge,
children = props.children,
pprops = (0, _objectWithoutProperties3.default)(props, ['className', 'padded', 'align', 'noFlex', 'order', 'orderSmall', 'orderMedium', 'orderLarge', 'cols', 'colsSmall', 'colsMedium', 'colsLarge', 'totalCols', 'totalColsSmall', 'totalColsMedium', 'totalColsLarge', 'children']);
var rowClassNames = (0, _classnames2.default)(className, padded ? 'slds-col--padded' + (/^(medium|large)$/.test(padded) ? '-' + padded : '') : 'slds-col', align ? 'slds-align-' + align : null, noFlex ? 'slds-no-flex' : null, order ? 'slds-order--' + order : null, orderSmall ? 'slds-small-order--' + orderSmall : null, orderMedium ? 'slds-medium-order--' + orderMedium : null, orderLarge ? 'slds-large-order--' + orderLarge : null, cols && totalCols ? 'slds-size--' + cols + '-of-' + adjustCols(totalCols, true) : null, colsSmall && totalColsSmall ? 'slds-small-size--' + colsSmall + '-of-' + adjustCols(totalColsSmall) : null, colsMedium && totalColsMedium ? 'slds-medium-size--' + colsMedium + '-of-' + adjustCols(totalColsMedium) : null, colsLarge && totalColsMedium ? 'slds-large-size--' + colsLarge + '-of-' + adjustCols(totalColsLarge, true) : null);
return _react2.default.createElement(
'div',
(0, _extends3.default)({ className: rowClassNames }, pprops),
children
);
};
exports.Col = Col;
var COL_ALIGNS = ['top', 'medium', 'bottom'];
Col.propTypes = {
className: _propTypes2.default.string,
padded: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.string]),
align: _propTypes2.default.oneOf(COL_ALIGNS),
noFlex: _propTypes2.default.bool,
order: _propTypes2.default.number,
orderSmall: _propTypes2.default.number,
orderMedium: _propTypes2.default.number,
orderLarge: _propTypes2.default.number,
nowrap: _propTypes2.default.bool,
cols: _propTypes2.default.number,
colsSmall: _propTypes2.default.number,
colsMedium: _propTypes2.default.number,
colsLarge: _propTypes2.default.number,
totalCols: _propTypes2.default.number,
totalColsSmall: _propTypes2.default.number,
totalColsMedium: _propTypes2.default.number,
totalColsLarge: _propTypes2.default.number,
children: _propTypes2.default.node
};
Grid.propTypes = {
className: _propTypes2.default.string,
frame: _propTypes2.default.bool,
children: _propTypes2.default.node
};
var Row = exports.Row = function (_Component) {
(0, _inherits3.default)(Row, _Component);
function Row() {
(0, _classCallCheck3.default)(this, Row);
return (0, _possibleConstructorReturn3.default)(this, (Row.__proto__ || (0, _getPrototypeOf2.default)(Row)).apply(this, arguments));
}
(0, _createClass3.default)(Row, [{
key: 'renderColumn',
value: function renderColumn(colProps, child) {
if (child.type !== _react2.default.createElement(Col, null).type) {
return _react2.default.createElement(
Col,
colProps,
child
);
}
/* eslint-disable no-param-reassign */
var childProps = (0, _keys2.default)(colProps).reduce(function (cprops, key) {
cprops[key] = child.props[key] || colProps[key];
return cprops;
}, {});
return _react2.default.cloneElement(child, childProps);
}
}, {
key: 'render',
value: function render() {
var _props = this.props,
className = _props.className,
align = _props.align,
nowrap = _props.nowrap,
nowrapSmall = _props.nowrapSmall,
nowrapMedium = _props.nowrapMedium,
nowrapLarge = _props.nowrapLarge,
cols = _props.cols,
colsSmall = _props.colsSmall,
colsMedium = _props.colsMedium,
colsLarge = _props.colsLarge,
children = _props.children,
props = (0, _objectWithoutProperties3.default)(_props, ['className', 'align', 'nowrap', 'nowrapSmall', 'nowrapMedium', 'nowrapLarge', 'cols', 'colsSmall', 'colsMedium', 'colsLarge', 'children']);
var rowClassNames = (0, _classnames2.default)(className, 'slds-grid', align ? 'slds-grid--align-' + align : null, nowrap ? 'slds-nowrap' : 'slds-wrap', nowrapSmall ? 'slds-nowrap--small' : null, nowrapMedium ? 'slds-nowrap--medium' : null, nowrapLarge ? 'slds-nowrap--large' : null);
var totalCols = cols || function () {
var cnt = 0;
_react2.default.Children.forEach(children, function (child) {
cnt += child.props.cols || 1;
});
return cnt;
}();
var colProps = {
totalCols: totalCols,
totalColsSmall: colsSmall || totalCols,
totalColsMedium: colsMedium || totalCols,
totalColsLarge: colsLarge || totalCols
};
return _react2.default.createElement(
'div',
(0, _extends3.default)({ className: rowClassNames }, props),
_react2.default.Children.map(children, this.renderColumn.bind(this, colProps))
);
}
}]);
return Row;
}(_react.Component);
var ROW_ALIGNS = ['center', 'space', 'spread'];
Row.propTypes = {
className: _propTypes2.default.string,
align: _propTypes2.default.oneOf(ROW_ALIGNS),
nowrap: _propTypes2.default.bool,
nowrapSmall: _propTypes2.default.bool,
nowrapMedium: _propTypes2.default.bool,
nowrapLarge: _propTypes2.default.bool,
cols: _propTypes2.default.number,
colsSmall: _propTypes2.default.number,
colsMedium: _propTypes2.default.number,
colsLarge: _propTypes2.default.number,
children: _propTypes2.default.node
};
exports.default = Grid;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Grid.js"],"names":["Grid","className","frame","children","props","gridClassNames","adjustCols","colNum","large","Col","padded","align","noFlex","order","orderSmall","orderMedium","orderLarge","cols","colsSmall","colsMedium","colsLarge","totalCols","totalColsSmall","totalColsMedium","totalColsLarge","pprops","rowClassNames","test","COL_ALIGNS","propTypes","string","oneOfType","bool","oneOf","number","nowrap","node","Row","colProps","child","type","childProps","reduce","cprops","key","cloneElement","nowrapSmall","nowrapMedium","nowrapLarge","cnt","Children","forEach","map","renderColumn","bind","ROW_ALIGNS"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;AACA;;;;AACA;;;;;;AAEA,IAAMA,OAAO,SAAPA,IAAO,OAA8C;AAAA,MAA3CC,SAA2C,QAA3CA,SAA2C;AAAA,MAAhCC,KAAgC,QAAhCA,KAAgC;AAAA,MAAzBC,QAAyB,QAAzBA,QAAyB;AAAA,MAAZC,KAAY;;AACzD,MAAMC,iBAAiB,0BACrBJ,SADqB,EACV,WADU,EACG,qBADH,EAErBC,QAAQ,kBAAR,GAA6B,IAFR,CAAvB;AAIA,SACE;AAAA;AAAA,6BAAK,WAAYG,cAAjB,IAAuCD,KAAvC;AACID;AADJ,GADF;AAKD,CAVD;;AAYA,SAASG,UAAT,CAAoBC,MAApB,EAA4BC,KAA5B,EAAmC;AACjC,MAAID,SAAS,CAAb,EAAgB;AACd,WAAOC,QAAQ,EAAR,GAAa,CAApB;AACD;AACD,SAAOD,MAAP;AACD;;AAEM,IAAME,MAAM,SAANA,GAAM,CAACL,KAAD,EAAW;AAAA,MAE1BH,SAF0B,GAOxBG,KAPwB,CAE1BH,SAF0B;AAAA,MAEfS,MAFe,GAOxBN,KAPwB,CAEfM,MAFe;AAAA,MAEPC,KAFO,GAOxBP,KAPwB,CAEPO,KAFO;AAAA,MAEAC,MAFA,GAOxBR,KAPwB,CAEAQ,MAFA;AAAA,MAG1BC,KAH0B,GAOxBT,KAPwB,CAG1BS,KAH0B;AAAA,MAGnBC,UAHmB,GAOxBV,KAPwB,CAGnBU,UAHmB;AAAA,MAGPC,WAHO,GAOxBX,KAPwB,CAGPW,WAHO;AAAA,MAGMC,UAHN,GAOxBZ,KAPwB,CAGMY,UAHN;AAAA,MAI1BC,IAJ0B,GAOxBb,KAPwB,CAI1Ba,IAJ0B;AAAA,MAIpBC,SAJoB,GAOxBd,KAPwB,CAIpBc,SAJoB;AAAA,MAITC,UAJS,GAOxBf,KAPwB,CAITe,UAJS;AAAA,MAIGC,SAJH,GAOxBhB,KAPwB,CAIGgB,SAJH;AAAA,MAK1BC,SAL0B,GAOxBjB,KAPwB,CAK1BiB,SAL0B;AAAA,MAKfC,cALe,GAOxBlB,KAPwB,CAKfkB,cALe;AAAA,MAKCC,eALD,GAOxBnB,KAPwB,CAKCmB,eALD;AAAA,MAKkBC,cALlB,GAOxBpB,KAPwB,CAKkBoB,cALlB;AAAA,MAM1BrB,QAN0B,GAOxBC,KAPwB,CAM1BD,QAN0B;AAAA,MAMbsB,MANa,0CAOxBrB,KAPwB;;AAQ5B,MAAMsB,gBAAgB,0BACpBzB,SADoB,EAEpBS,+BACqB,mBAAmBiB,IAAnB,CAAwBjB,MAAxB,UAAsCA,MAAtC,GAAiD,EADtE,IAEE,UAJkB,EAKpBC,wBAAsBA,KAAtB,GAAgC,IALZ,EAMpBC,SAAS,cAAT,GAA0B,IANN,EAOpBC,yBAAuBA,KAAvB,GAAiC,IAPb,EAQpBC,oCAAkCA,UAAlC,GAAiD,IAR7B,EASpBC,sCAAoCA,WAApC,GAAoD,IAThC,EAUpBC,oCAAkCA,UAAlC,GAAiD,IAV7B,EAWpBC,QAAQI,SAAR,mBAAkCJ,IAAlC,YAA6CX,WAAWe,SAAX,EAAsB,IAAtB,CAA7C,GAA6E,IAXzD,EAYpBH,aAAaI,cAAb,yBACsBJ,SADtB,YACsCZ,WAAWgB,cAAX,CADtC,GACqE,IAbjD,EAcpBH,cAAcI,eAAd,0BACuBJ,UADvB,YACwCb,WAAWiB,eAAX,CADxC,GACwE,IAfpD,EAgBpBH,aAAaG,eAAb,yBACsBH,SADtB,YACsCd,WAAWkB,cAAX,EAA2B,IAA3B,CADtC,GAC2E,IAjBvD,CAAtB;AAmBA,SACE;AAAA;AAAA,6BAAK,WAAYE,aAAjB,IAAsCD,MAAtC;AACItB;AADJ,GADF;AAKD,CAhCM;;;AAkCP,IAAMyB,aAAa,CACjB,KADiB,EAEjB,QAFiB,EAGjB,QAHiB,CAAnB;;AAMAnB,IAAIoB,SAAJ,GAAgB;AACd5B,aAAW,oBAAU6B,MADP;AAEdpB,UAAQ,oBAAUqB,SAAV,CAAoB,CAC1B,oBAAUC,IADgB,EAE1B,oBAAUF,MAFgB,CAApB,CAFM;AAMdnB,SAAO,oBAAUsB,KAAV,CAAgBL,UAAhB,CANO;AAOdhB,UAAQ,oBAAUoB,IAPJ;AAQdnB,SAAO,oBAAUqB,MARH;AASdpB,cAAY,oBAAUoB,MATR;AAUdnB,eAAa,oBAAUmB,MAVT;AAWdlB,cAAY,oBAAUkB,MAXR;AAYdC,UAAQ,oBAAUH,IAZJ;AAadf,QAAM,oBAAUiB,MAbF;AAcdhB,aAAW,oBAAUgB,MAdP;AAedf,cAAY,oBAAUe,MAfR;AAgBdd,aAAW,oBAAUc,MAhBP;AAiBdb,aAAW,oBAAUa,MAjBP;AAkBdZ,kBAAgB,oBAAUY,MAlBZ;AAmBdX,mBAAiB,oBAAUW,MAnBb;AAoBdV,kBAAgB,oBAAUU,MApBZ;AAqBd/B,YAAU,oBAAUiC;AArBN,CAAhB;;AAwBApC,KAAK6B,SAAL,GAAiB;AACf5B,aAAW,oBAAU6B,MADN;AAEf5B,SAAO,oBAAU8B,IAFF;AAGf7B,YAAU,oBAAUiC;AAHL,CAAjB;;IAMaC,G,WAAAA,G;;;;;;;;;;iCACEC,Q,EAAUC,K,EAAO;AAC5B,UAAIA,MAAMC,IAAN,KAAgB,8BAAC,GAAD,OAAD,CAAUA,IAA7B,EAAmC;AACjC,eAAO;AAAC,aAAD;AAAUF,kBAAV;AAAuBC;AAAvB,SAAP;AACD;;AAED;AACA,UAAME,aAAa,oBAAYH,QAAZ,EAAsBI,MAAtB,CAA6B,UAACC,MAAD,EAASC,GAAT,EAAiB;AAC/DD,eAAOC,GAAP,IAAcL,MAAMnC,KAAN,CAAYwC,GAAZ,KAAoBN,SAASM,GAAT,CAAlC;AACA,eAAOD,MAAP;AACD,OAHkB,EAGhB,EAHgB,CAAnB;AAIA,aAAO,gBAAME,YAAN,CAAmBN,KAAnB,EAA0BE,UAA1B,CAAP;AACD;;;6BAEQ;AAAA,mBAKH,KAAKrC,KALF;AAAA,UAELH,SAFK,UAELA,SAFK;AAAA,UAEMU,KAFN,UAEMA,KAFN;AAAA,UAEawB,MAFb,UAEaA,MAFb;AAAA,UAEqBW,WAFrB,UAEqBA,WAFrB;AAAA,UAEkCC,YAFlC,UAEkCA,YAFlC;AAAA,UAEgDC,WAFhD,UAEgDA,WAFhD;AAAA,UAGL/B,IAHK,UAGLA,IAHK;AAAA,UAGCC,SAHD,UAGCA,SAHD;AAAA,UAGYC,UAHZ,UAGYA,UAHZ;AAAA,UAGwBC,SAHxB,UAGwBA,SAHxB;AAAA,UAILjB,QAJK,UAILA,QAJK;AAAA,UAIQC,KAJR;;AAMP,UAAMsB,gBAAgB,0BACpBzB,SADoB,EACT,WADS,EAEpBU,8BAA4BA,KAA5B,GAAsC,IAFlB,EAGpBwB,SAAS,aAAT,GAAyB,WAHL,EAIpBW,cAAc,oBAAd,GAAqC,IAJjB,EAKpBC,eAAe,qBAAf,GAAuC,IALnB,EAMpBC,cAAc,oBAAd,GAAqC,IANjB,CAAtB;AAQA,UAAM3B,YAAYJ,QAAS,YAAM;AAC/B,YAAIgC,MAAM,CAAV;AACA,wBAAMC,QAAN,CAAeC,OAAf,CAAuBhD,QAAvB,EAAiC,UAACoC,KAAD,EAAW;AAC1CU,iBAAOV,MAAMnC,KAAN,CAAYa,IAAZ,IAAoB,CAA3B;AACD,SAFD;AAGA,eAAOgC,GAAP;AACD,OANyB,EAA1B;AAOA,UAAMX,WAAW;AACfjB,4BADe;AAEfC,wBAAgBJ,aAAaG,SAFd;AAGfE,yBAAiBJ,cAAcE,SAHhB;AAIfG,wBAAgBJ,aAAaC;AAJd,OAAjB;AAMA,aACE;AAAA;AAAA,iCAAK,WAAYK,aAAjB,IAAsCtB,KAAtC;AACI,wBAAM8C,QAAN,CAAeE,GAAf,CAAmBjD,QAAnB,EAA6B,KAAKkD,YAAL,CAAkBC,IAAlB,CAAuB,IAAvB,EAA6BhB,QAA7B,CAA7B;AADJ,OADF;AAKD;;;;;AAGH,IAAMiB,aAAa,CACjB,QADiB,EAEjB,OAFiB,EAGjB,QAHiB,CAAnB;;AAMAlB,IAAIR,SAAJ,GAAgB;AACd5B,aAAW,oBAAU6B,MADP;AAEdnB,SAAO,oBAAUsB,KAAV,CAAgBsB,UAAhB,CAFO;AAGdpB,UAAQ,oBAAUH,IAHJ;AAIdc,eAAa,oBAAUd,IAJT;AAKde,gBAAc,oBAAUf,IALV;AAMdgB,eAAa,oBAAUhB,IANT;AAOdf,QAAM,oBAAUiB,MAPF;AAQdhB,aAAW,oBAAUgB,MARP;AASdf,cAAY,oBAAUe,MATR;AAUdd,aAAW,oBAAUc,MAVP;AAWd/B,YAAU,oBAAUiC;AAXN,CAAhB;;kBAeepC,I","file":"Grid.js","sourcesContent":["import React, { Component } from 'react';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\n\nconst Grid = ({ className, frame, children, ...props }) => {\n  const gridClassNames = classnames(\n    className, 'slds-grid', 'slds-grid--vertical',\n    frame ? 'slds-grid--frame' : null\n  );\n  return (\n    <div className={ gridClassNames } { ...props }>\n      { children }\n    </div>\n  );\n};\n\nfunction adjustCols(colNum, large) {\n  if (colNum > 6) {\n    return large ? 12 : 6;\n  }\n  return colNum;\n}\n\nexport const Col = (props) => {\n  const {\n    className, padded, align, noFlex,\n    order, orderSmall, orderMedium, orderLarge,\n    cols, colsSmall, colsMedium, colsLarge,\n    totalCols, totalColsSmall, totalColsMedium, totalColsLarge,\n    children, ...pprops,\n  } = props;\n  const rowClassNames = classnames(\n    className,\n    padded ?\n      `slds-col--padded${/^(medium|large)$/.test(padded) ? `-${padded}` : ''}` :\n      'slds-col',\n    align ? `slds-align-${align}` : null,\n    noFlex ? 'slds-no-flex' : null,\n    order ? `slds-order--${order}` : null,\n    orderSmall ? `slds-small-order--${orderSmall}` : null,\n    orderMedium ? `slds-medium-order--${orderMedium}` : null,\n    orderLarge ? `slds-large-order--${orderLarge}` : null,\n    cols && totalCols ? `slds-size--${cols}-of-${adjustCols(totalCols, true)}` : null,\n    colsSmall && totalColsSmall ?\n      `slds-small-size--${colsSmall}-of-${adjustCols(totalColsSmall)}` : null,\n    colsMedium && totalColsMedium ?\n      `slds-medium-size--${colsMedium}-of-${adjustCols(totalColsMedium)}` : null,\n    colsLarge && totalColsMedium ?\n      `slds-large-size--${colsLarge}-of-${adjustCols(totalColsLarge, true)}` : null\n  );\n  return (\n    <div className={ rowClassNames } { ...pprops }>\n      { children }\n    </div>\n  );\n};\n\nconst COL_ALIGNS = [\n  'top',\n  'medium',\n  'bottom',\n];\n\nCol.propTypes = {\n  className: PropTypes.string,\n  padded: PropTypes.oneOfType([\n    PropTypes.bool,\n    PropTypes.string,\n  ]),\n  align: PropTypes.oneOf(COL_ALIGNS),\n  noFlex: PropTypes.bool,\n  order: PropTypes.number,\n  orderSmall: PropTypes.number,\n  orderMedium: PropTypes.number,\n  orderLarge: PropTypes.number,\n  nowrap: PropTypes.bool,\n  cols: PropTypes.number,\n  colsSmall: PropTypes.number,\n  colsMedium: PropTypes.number,\n  colsLarge: PropTypes.number,\n  totalCols: PropTypes.number,\n  totalColsSmall: PropTypes.number,\n  totalColsMedium: PropTypes.number,\n  totalColsLarge: PropTypes.number,\n  children: PropTypes.node,\n};\n\nGrid.propTypes = {\n  className: PropTypes.string,\n  frame: PropTypes.bool,\n  children: PropTypes.node,\n};\n\nexport class Row extends Component {\n  renderColumn(colProps, child) {\n    if (child.type !== (<Col />).type) {\n      return <Col { ...colProps }>{ child }</Col>;\n    }\n\n    /* eslint-disable no-param-reassign */\n    const childProps = Object.keys(colProps).reduce((cprops, key) => {\n      cprops[key] = child.props[key] || colProps[key];\n      return cprops;\n    }, {});\n    return React.cloneElement(child, childProps);\n  }\n\n  render() {\n    const {\n      className, align, nowrap, nowrapSmall, nowrapMedium, nowrapLarge,\n      cols, colsSmall, colsMedium, colsLarge,\n      children, ...props,\n    } = this.props;\n    const rowClassNames = classnames(\n      className, 'slds-grid',\n      align ? `slds-grid--align-${align}` : null,\n      nowrap ? 'slds-nowrap' : 'slds-wrap',\n      nowrapSmall ? 'slds-nowrap--small' : null,\n      nowrapMedium ? 'slds-nowrap--medium' : null,\n      nowrapLarge ? 'slds-nowrap--large' : null\n    );\n    const totalCols = cols || (() => {\n      let cnt = 0;\n      React.Children.forEach(children, (child) => {\n        cnt += child.props.cols || 1;\n      });\n      return cnt;\n    })();\n    const colProps = {\n      totalCols,\n      totalColsSmall: colsSmall || totalCols,\n      totalColsMedium: colsMedium || totalCols,\n      totalColsLarge: colsLarge || totalCols,\n    };\n    return (\n      <div className={ rowClassNames } { ...props }>\n        { React.Children.map(children, this.renderColumn.bind(this, colProps)) }\n      </div>\n    );\n  }\n}\n\nconst ROW_ALIGNS = [\n  'center',\n  'space',\n  'spread',\n];\n\nRow.propTypes = {\n  className: PropTypes.string,\n  align: PropTypes.oneOf(ROW_ALIGNS),\n  nowrap: PropTypes.bool,\n  nowrapSmall: PropTypes.bool,\n  nowrapMedium: PropTypes.bool,\n  nowrapLarge: PropTypes.bool,\n  cols: PropTypes.number,\n  colsSmall: PropTypes.number,\n  colsMedium: PropTypes.number,\n  colsLarge: PropTypes.number,\n  children: PropTypes.node,\n};\n\n\nexport default Grid;\n"]}