Skip to content

Latest commit

 

History

History
187 lines (178 loc) · 4.61 KB

README.md

File metadata and controls

187 lines (178 loc) · 4.61 KB

styled-components-workshop

Styled-components workshop for GSG community

💅

Stage-0 (Setting up 🚧)

In this stage we will setting up the core files for the workshop.

cd stage-0
npm i
npm start

stage-1 (The old school 👴)

In this stage we will build a simple To Do React app with ordinary css style. you can find the source code here.

cd stage-1
npm i
npm start
  • we have created a ToDoApp directory inside stage-1/src/ with index.js and ToDoApp.css files.
  • we used BEM styling convention.

stage-2 (switch to styled-components 💅)

In this stage we will switch to styled-components.

cd stage-2
npm i
npm install styled-components
npm start
  • Create StyledComponents.js file. In StyledComponents.js add import styled from 'styled-components';.
  • Create new components using styled-components with same style in ToDoApp.css. for example:
    .to-do-app {
      display: flex;
      flex-direction: column;
      width: 400px;
      margin: 0 auto;
    }
    
    .to-do-app__heading--sub{
      color: #61dafb;
      font-size: 20px;
      font-family: 'Bree Serif', serif;
      font-weight: 100;
      margin: 10px auto;
    }
    would be:
    export const ToDoWrapper = styled.div`
      display: flex;
      flex-direction: column;
      width: 400px;
      margin: 0 auto;
    `
    export const SubHeading = styled.h4`
      color: #61dafb;
      font-size: 20px;
      font-family: 'Bree Serif', serif;
      font-weight: 100;
      margin: 10px auto;
    `
  • In ToDoApp/index.js
    import { ToDoWrapper, SubHeading, ... } from './StyledComponents'
  • Replace the HTML tags with the new components.
    <div className="to-do-app">
      <h4 className="to-do-app__heading to-do-app__heading--sub">Add your To-Do's here</h4>
    </div>
    <ToDoWrapper>
      <SubHeading>Add your To-Dos here</SubHeading>
      ...
    </ToDoWrapper>

Looks more prettier? 😏

  • Now you can delete ToDoApp.css 😈

stage-3 (More modularization 🔥)

In this stage we will try to modularize our code.

cd stage-3
npm i
npm start
  • Take a look on StyledComponents.js and try to find out similar code lines.

    export const Input = styled.input`
      border: solid 1px #60c1da;
      border-radius: 4px;
      cursor: pointer;
      display: inline-block;
      font: inherit;
      font-weight: 600;
      margin: 0.85em 0;
      padding: 6px 24px;
      text-align: center;
      vertical-align: middle;
      background-color: #fff;
      color: #60c1da;
      outline: none;
    `
    export const AddButton = styled.button`
      border: solid 1px #60c1da;
      border-radius: 4px;
      color: #fff;
      cursor: pointer;
      display: inline-block;
      font: inherit;
      font-weight: 600;
      margin: 0.85em 0;
      padding: 6px 24px;
      text-align: center;
      vertical-align: middle;
      background-color: #60c1da;
      outline: none;
    `
    export const DeleteButton = styled.button`
      border: solid 1px #e90c27;
      border-radius: 4px;
      color: #fff;
      cursor: pointer;
      display: inline-block;
      font: inherit;
      font-weight: 600;
      margin: 0.85em 0;
      padding: 6px 24px;
      text-align: center;
      vertical-align: middle;
      background-color: #e90c27;
      outline: none;
    `
  • To easily make a new component that inherits the styling of another, just wrap it in the styled() constructor.

  • Make two extends from Input component:

    export const AddButton = styled(Input)`
      border: solid 1px #60c1da;
      background-color: #60c1da;
      color: #fff
    
    `
    export const DeleteButton = styled(Input)`
      border: solid 1px #e90c27;
      background-color: #e90c27;
      color: #fff
    `

    AddButton and DeleteButton are instance if input html tag! 😮

    How could i use it as Buttons?

    If you want to keep all the styling you've applied to a component but just switch out what's being ultimately rendered (be it a different HTML tag or a different custom component), you can use the "as" prop to do this at runtime.

      <AddButton type='submit' as="button">
        Add
      </AddButton>
  • for more modularization we can use props

    // ToDoApp/StyledComponents.js
    export const Button = styled(Input)`
      border: solid 1px #${(props)=> props.delete ? 'e90c27' : '60c1da'};
      background-color: #${(props)=> props.delete ? 'e90c27' : '60c1da'};
      color: #fff
    `
    // ToDoApp/index.js
    
    // the default button
    <Button type='submit' as="button">
      Add
    </Button>
    
    //DeleteButton
    <Button as="button" delete>
      Add
    </Button>