An open API service indexing awesome lists of open source software.

https://github.com/joyapisi/to-do-list

To Do List is a simple a simple web page that displays a list of To Do tasks. It is built using webpack and served by a webpack dev server.
https://github.com/joyapisi/to-do-list

css eslint javascript stylelint webpack

Last synced: 10 months ago
JSON representation

To Do List is a simple a simple web page that displays a list of To Do tasks. It is built using webpack and served by a webpack dev server.

Awesome Lists containing this project

README

          

# To Do List

HTML, CSS and JavaScript To Do List Project

# 📗 Table of Contents

- [📖 About the Project](#about-project)
- [🛠 Built With](#built-with)
- - [Tech Stack](#tech-stack)
- - [Key Features](#key-features)
- [🎥 Video Explanation](#video-explanation)
- [🚀 Live Demo](#live-demo)
- [💻 Getting Started](#getting-started)
- [Setup](#set-up)
- [Prerequisites](#prerequisites)
- [Install](#install)
- - [Install webpack](#webhint-installation)
- - [Install linters](#linter-installation)
- [👥 Authors](#authors)
- [🔭 Future Features](#future-features)
- [🤝 Contributing](#contributing)
- [⭐️ Show your support](#support)
- [🙏 Acknowledgements](#acknowledgements)
- [❓ FAQ](#faq)
- [📝 License](#license)

# 📖 [To_Do_List]

**[To_Do_List]** is a simple a simple web page that displays a list of To Do tasks inserted by a user. It is built using webpack and served by a webpack dev server.

## 🛠 Built With

### Tech Stack

Javascript runtime environment

JS Packages

Version control

### Key Features

- **[Webpack]**
- **[Desktop-Version]**
- **[Dynamic-Design]**

(back to top)

## 🎥 Video Explanation Coming soon!

## 🚀 Live Demo Live Demo

## 💻 Getting Started

Creating your first "To DO List" project

To get a local copy up and running, follow these steps.

### Prerequisites

In order to run this project you need:

-A Git hub account
-Git bash
-Node JS
-Webpack
-Visual Studio Code as your code editor

# Setup

Clone this repository to your desired folder:

```sh
cd my-folder
git clone[(https://github.com/joyapisi/To-Do-List.git)]
```
## Understand Set Up Requirements
Since this code is using webpack, run `npm start` in your terminal to run it instead of using the live server.

## Understand Set Up Requirements

### Define webpack

webpackis a static module bundler for modern JavaScript applications. When webpack processes your application, it internally builds a dependency graph from one or more entry points and then combines every module your project needs into one or more bundles, which are static assets to serve your content from.

### Define Linters

A linter is a tool to help you improve your code. You can learn more about Linters here: (source: ()).

#### Advantages of Linting:

1. Fewer errors in production- The use of linters helps to diagnose and fix technical issues such as code smells. As a result, fewer defects make their way to production.
2. Achieving a more readable and consistent style, through the enforcement of its rules.
3. Having more secure and performant code.
4. Having an objective and measurable assessment of code quality.
5. Having fewer discussions about code style and aesthetic choices during code reviews.

# Install webpack and linters

## Install webpack

- Follow the instructions here to set up webpack.

### Steps to Install webpack

- In the link above, go through these topics in order:

## Install Linters

Linters for various programming languages are available for use, e.g. Rubocop for Ruby or ESLint for JavaScript.

There are many ways you can integrate a linter in your workflow:

-text editor plugin
-GitHub Actions
-GitHub apps

### Steps to Install Linters

**Note:** The npm package manager is going to create a node_modules directory to install all of your dependencies. You shouldn't commit that directory. To avoid that, you can create a .gitignore file and add node_modules to it:

# .gitignore

node_modules/

## ESLint

Run

```
npm install --save-dev eslint@7.x eslint-config-airbnb-base@14.x eslint-plugin-import@2.x babel-eslint@10.x
```

## Web Hint

This is a customizable linting tool that helps you improve your site's accessibility, speed, cross-browser compatibility, and more by checking your code for best practices and common errors.

**NOTE:** If you are using Windows, make sure you initialize npm to create `package.json` file.

```
npm init -y
```

1. Run
```
npm install --save-dev hint@7.x
```
_how to use npm: (https://docs.npmjs.com/downloading-and-installing-node-js-and-npm)._
2. Copy [.hintrc](.hintrc) to the root directory of your project.
3. **Do not make any changes in config files - they represent style guidelines that you share with your team - which is a group of all Microverse students.**
- If you think that change is necessary - open a [Pull Request in this repository](../README.md#contributing) and let your code reviewer know about it.
4. Run
```
npx hint .
```
[Copy contents of .eslintrc.json to the root directory of your project](https://github.com/microverseinc/linters-config/blob/master/html-css-js/.eslintrc.json)
5. Fix validation errors.

### [Stylelint](https://stylelint.io/)

A mighty, modern linter that helps you avoid errors and enforce conventions in your styles.

1. Run

npm install --save-dev stylelint@13.x stylelint-scss@3.x stylelint-config-standard@21.x stylelint-csstree-validator@1.x
not sure how to use npm? Read this.

2. Copy .stylelintrc.json to the root directory of your project.

3. **Do not make any changes in config files - they represent style guidelines that you share with your team - which is a group of all Microverse students.**

If you think that change is necessary - open a Pull Request in this repository and let your code reviewer know about it. 4. Run npx stylelint "\*_/_.{css,scss}" on the root of your directory of your project.

5. Fix linter errors.

6. **IMPORTANT NOTE:** feel free to research auto-correct options for Stylelint if you get a flood of errors but keep in mind that correcting style errors manually will help you to make a habit of writing a clean code!

(back to top)

## 👥 Authors

👤 **Joy Phoebe**

- GitHub: (https://github.com/joyapisi)
- Twitter: (https://twitter.com/joyapisi)
- LinkedIn: (https://http://www.linkedin.com/in/joy-phoebe-00b80a13a)

## 🤝 Contributing

## 🔭 Future Features

# **[Feature-1]**

- Add more styling (aesthetics)

# **[Feature-2]**

- Add mobile version

(back to top)

Contributions, issues, and feature requests are welcome!

Feel free to check the [issues page](https://github.com/joyapisi/To-Do-List/issues).

## ⭐️ Show your support

If you like this project, kindly leave a comment below and share it with someone who enjoys coding! Coding is all about continuous learning and allowing yourself to be a beginner. Keep going!

## 🙏 Acknowledgments

I'm thankful to Microverse for providing a study platform which guided me through this project.

## ❓ FAQ

- **[Question_1]**
An easier and quicker way to understand webpack?

- This YouTubevideo will help you understand webpack better and in details

- **[Question_2]**
Where can I download node JS for installation?

- Node Js can be downloaded here-

## 📝 License

This project is [MIT](https://choosealicense.com/licenses/mit/) licensed.

(back to top)