Skip to content

Latest commit

 

History

History

01.React

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 

Workshop 1 - Kanban App in React

✔️ Learn the basics of React with TypeScript

✔️ Use the component library Material UI to quickly build a great UI

✔️ Have an overview of front end development


Step 0: Initialization

The goal of this workshop is to create a Kanban-like application using the React library in Typescript.

React is an open-source library created at Facebook to build User Interfaces. It is widely used because of the high performance it offers with its Virtual DOM, reusable components making it easy to build a complex UI step by step and the easier learning curve compared to other frameworks like Angular.

As you go through this workshop you'll come up with a lot of files, and it's important to keep them organized.
Here we're gonna use a structure based on file types, do your best to keep your project clean 😉

We're also going to use TypeScript, a superset of JavaScript to add static typing, which has some benefits such as early bug detection or improved IDE suggestions. Here is an overview of the differences if you want to learn more about it.

All the installation steps required to do the exercises are detailed in the SETUP.md


Step 1: Create your first component

Components are the core of React. They represent a single element in a web page, like a text box, a button, a div etc. All combined together, they create a fully working web page. These components are re-usable, they prevent you from code duplication.

You will learn how to create components right now in the first step!

In this workshop, we recommend you to use Functional Components, instead of Javascript classes. Here is a little explanation of the differences.

Delete all the files in src/ excepted index.tsx and App.tsx, they won't be useful for this workshop.
You can also remove all the content in App.tsx to create your component from scratch 🚀

In src/App.tsx, create a component that will display the application title, which is just a string. In Typescript, we must specify the type of the return value of the function: for all TSX React components, you can use JSX.Element.

function Title(): JSX.Element {
    return (...)
}

Then in your app function, you should have this:

function App(): JSX.Element {
    return <Title />;
}
✔️ Result preview

The background was added with simple CSS


Step 2: Show content with Components from Material UI

Now that you know how to create a component in React, let's get into Material UI. Material UI is a library of pre-built components that you can use in your React app. Discover here the advantages of using a components library such as Material UI.

The goal of this task is to create the TaskCard component: this component will represent a task with all its information, including:

  • A title
  • A description
  • A due date

To do so, you must use the Material UI Components, such as Card or Typography.

Feel free to choose the MUI components you want to create a great design 🚀

Create a components folder in your src folder.
From now on, you will add one file per component inside it, with the name of your component as the filename.
For instance, the TaskCard component should be located in src/components/TaskCard.tsx.

You have to export your functions to reuse them in your src/App.tsx.

You can put the task's data directly in your code, we'll cover props in the next step to make your component generic 😜

✔️ Result preview

Step 3: Show all the tasks from a list with props

At this moment, you know how to create a single component and how to add it to your application.
But what if you need to show a list of components that you cannot determine in advance? For example a list of tasks 🤔

To do so, create and use a TaskList component that will show all the tasks iteratively, with a Typescript type to represent the tasks and their information.

You can store your tasks in a JSON file as an array.
Then, import it in your TaskList component and use the Javascript map method to iterate through your tasks.

Finally, use React Props to pass values of each task from your TaskList to the TaskCard component.

💡 When you create a component through an iteration, don't forget to pass a unique key in component props!

✔️ Result preview

Step 4: Create interactive components using useState

From now, you are able to create static components that don't interact with the user. We will now create dynamic components to allow the user to add a new task to the list, using React hooks.

To create a task, we need to create forms where the user can enter a title, a description and a due date with a button to validate. Let's create them with Material UI!

Let's then use the useState hook to handle user input and button clicks!

💡 Mix the usage of useState with props!

We recommend you to create a small '+' button in one of the corner of your app that will open a small window containing the title and description forms as well as the button to add the task.

💡 You can customize your hooks to avoid unwanted cases, such as an empty field.

✔️ Result preview

Step 5: Discover another hook: React contexts

In the previous step, we told you that you could pass your useState hooks into your components props. This way to do can be a bit annoying as you have to pass the variable into props from all the children from the component you created it.

To solve this problem, we can use contexts. React contexts are another type of React hooks, allowing the same things as useState does, but using a slightly different syntax and behavior.
It's a great way to pass data used in whole parts of your application, such as themes (dark/light mode), user language, or in the case of our small app, tasks !
You can wrap your components in a Provider like the sample code below and access the value in any of its sub-component!

function Component(): JSX.Element {
    const [variable, setter] = useState<any>());

    return (
        <TaskContext.Provider value={{ variable, setter }}>
            ...
        </TaskContext.Provider>
    );
}

Bonus

Congratulations, you now have a functional Kanban style app to keep yourself organized in all your future projects!

You can still enhance it's behavior, here are some examples:

  • You can add a background to your application
  • You can add a Delete button on each task to delete it
  • You can add a real due date using Calendars
  • You can link your application to a backend and a database to properly store your tasks (EPyTodo ?)

💡 We suggest you to take a look at NextJS or Remix!


Authors


Reza Rahemtola

Florian Lauch

Laure Gagner

Nicolas Heude

Organization


LinkedIn logo Instagram logo Twitter logo Discord logo

Website logo

🚀 Don't hesitate to follow us on our different networks, and put a star 🌟 on PoC's repositories.