rofrischmann/fela

View on GitHub
benchmarks/src/implementations/inline-styles/View.js

Summary

Maintainability
A
2 hrs
Test Coverage
/* eslint-disable react/prop-types */
import React from 'react';

const compose = (s1, s2) => {
  if (s1 && s2) {
    return { ...s1, ...s2 };
  } else {
    return s1 || s2;
  }
};

class View extends React.Component {
  render() {
    const { style, ...other } = this.props;
    return <div {...other} style={compose(viewStyle, style)} />;
  }
}

const viewStyle = {
  alignItems: 'stretch',
  borderWidth: 0,
  borderStyle: 'solid',
  boxSizing: 'border-box',
  display: 'flex',
  flexBasis: 'auto',
  flexDirection: 'column',
  flexShrink: 0,
  margin: 0,
  padding: 0,
  position: 'relative',
  // fix flexbox bugs
  minHeight: 0,
  minWidth: 0
};

export default View;