Comments (3)
This is how I imagine it
import styled from 'styled-components'
import {
space,
color,
width,
fontSize,
flexWrap,
flexDirection,
alignItems,
justifyContent,
flex,
order,
alignSelf,
themeGet
} from 'styled-system'
export const Box = styled('div')({
boxSizing: 'border-box'
},
space,
color,
width,
fontSize,
flex,
order,
alignSelf,
props => props.css,
props => {
if (props.gutter) {
return {
padding: `${parseInt(props.theme.space[props.gutter], 10) / 2}px`
}
}
}
)
Box.displayName = 'Box'
Box.propTypes = {
...space.propTypes,
...color.propTypes,
...width.propTypes,
...fontSize.propTypes,
}
const FlexWrapper = styled(Box)({
display: 'flex'
},
flexWrap,
flexDirection,
alignItems,
justifyContent,
props => {
if (props.gutter) {
return {
margin: `${(parseInt(props.theme.space[props.gutter], 10) / 2) * -1}px;`,
padding: 0
}
}
}
)
FlexWrapper.displayName = 'Flex'
FlexWrapper.propTypes = {
...flexWrap.propTypes,
...flexDirection.propTypes,
...alignItems.propTypes,
...justifyContent.propTypes
}
export const Flex = class extends React.Component {
renderChildren = () => {
const { children } = this.props
return React.Children
.map(children, (child) => React.cloneElement(child, {
gutter: this.props.gutter
}))
}
render() {
return <FlexWrapper {...this.props}>
{this.renderChildren()}
</FlexWrapper>
}
}
<Flex flexWrap='wrap' gutter={1}>
<Box width={1/2}>
<Area />
</Box>
<Box width={1/2}>
<Area />
</Box>
</Flex>
from grid.
@pea there's a horizontal scroll bar that appears when the columns go edge to edge with the border, is there a way to fix that other than using overflow-x: hidden
?
from grid.
I'd recommend making a wrapper around the Flex
component that handles this sort of thing by applying props to its direct children. This library is meant to be lower-level and only directly affect styles of the components themselves
from grid.
Related Issues (20)
- Problem of layout HOT 1
- Responsive maxWidth Container HOT 2
- error 'styled-components' required for `@rebass/grid/emotion` HOT 11
- Support string template as `css` HOT 1
- Gutters HOT 3
- website is down ATM HOT 2
- styled-space > @rebass/space ? HOT 2
- Site offline? HOT 1
- web application with many entity and large data with grid HOT 1
- Themes that use objects for responsive values aren't working as expected HOT 1
- What is the correct import location for ThemeProvider? HOT 1
- Migration guide/ adapted README for 'css' prop removal HOT 2
- TypeScript support after name change HOT 1
- Support html5 elements HOT 1
- invalid url in the heading of github HOT 1
- Grid sub domain link no longer valid in repository description. HOT 1
- the above error occurred
- upgrade to latest styled-system v5 HOT 1
- How to provide css for different breakpoints HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from grid.