Skip to content

Latest commit

 

History

History
148 lines (91 loc) · 7.48 KB

README.md

File metadata and controls

148 lines (91 loc) · 7.48 KB

Kanban Project Management

Kanban Project Management is a web application to manage software development projects.

Kanban is a workflow management method for defining, managing, and improving services that deliver knowledge work. It aims to help you visualize your > work, maximize efficiency, and improve continuously.

Demo

Check out the live application on:

demo

Features 🚀

Some of the things you can do with Kanban Project Management:

  • Create, read, update, delete and list (CRUDL) projects.
  • Filter and sort projects.
  • Add users to a project.
  • Create, read, update, delete and list issues of each project
  • Filter issues.
  • Assign issues to users.
  • Drag and drop an issue onto the kanban board.
  • Create, read, update, delete and list comments of each issue.

Built with 🛠️

Frontend

Frontend Tech stack

  • Angular - An Application Design Framework and Development Platform for creating efficient and sophisticated single-page apps.
  • NgRx - NgRx Store provides reactive state management for Angular apps inspired by Redux.
  • NG-ZORRO - An enterprise-class Angular UI component library based on Ant Design.
  • ngx-quill - An Angular module for the Quill Rich Text Editor
  • RxJS - A javascript library for reactive programming using Observables, to make it easier to compose asynchronous or callback-based code.
  • TypeScript - TypeScript is an open-source language which builds on JavaScript, one of the world’s most used tools, by adding static type definitions.
  • angular/cdk/drag-drop - Provides you with a way to easily and declaratively create drag-and-drop interfaces.

Backend

Backend Tech Stack

  • NestJS - A progressive Node.js framework for building efficient, reliable and scalable server-side applications.
  • MongoDB - A NoSQL database.
  • mongoose - An elegant mongodb object modeling for Node.js
  • mongoose-sequence - This plugin lets you create fields which autoincrement their value.

Getting started 🏁

Open in Visual Studio Code

To clone and run this application, you'll need Git and Node.js (which comes with npm) installed on your computer. From your command line:

  • git clone https://github.com/sldiaz04us/kanban-project-management.git
  • cd kanban-project-management/
  • npm run install:all to install all dependencies (frontend and backend)

You can install the frontend and backend dependencies individually with npm run install:frontend and npm run install:backend respectively.

To start the backend and frontend applications, you must run the commands on two different terminals.

Backend application

Before you run the application, you'll also need:

  • Set up MongoDB Atlas, a cloud MongoDB service.

    The reason why I recommend this option is due to the use of transactions to execute multiple operations in isolation and potentially undo all the operations if one of them fails. In the application, when a project is deleted, all its issues and the comments for each of those issues are also deleted.

    To execute transactions, there must be replicas of the database, and MongoDB Atlas offers this configuration out of the box.

    If you want a local configuration of mongodb, take a look at this article Creating a MongoDB replica set using Docker.

  • In the backend folder of the project, you'll find the file .env.stage.dev, change the value of MONGODB_URI with the database connection string from the previous step.

    MONGODB_URI=mongodb+srv://admin:<password>@cluster0.dmpdr.mongodb.net/myFirstDatabase?retryWrites=true&w=majority
    

    Replace <password> with the password for the admin user. Replace myFirstDatabase with the name of the database that connections will use by default.

  • npm run start:backend, this command runs the backend application implemented in NestJS.

  • The server is listening on http://localhost:3000/

  • npm run seed:database, this command, as its name suggests, seeds the database with some data.

Since there is no Authentication System in place, for the application to work as expected, there must be at least one user in the database.

After the database is seeded, you'll find:

  • A Sample Kanban Project with one issue.
  • Five predefined users
    • Myself (Sergio Lopez Diaz)
    • Richard Hendricks
    • Gilfoyle
    • Dinesh
    • Big Head

You can run the command to seed the database whenever you want, there is no need to stop the backend application for that.

Frontend application

  • npm run start:frontend, this command runs the frontend application implemented in Angular.
  • Navigate to http://localhost:4200/

What's missing❓

An Authentication and Authorization System

The application uses the same user by default. In a real product, the application must have an authentication system, where users can register and participate in the entire development process of one or more projects.

Unit/Integration tests 🧪

I skipped writing test for this project.

Accessibility ♿

Not all components have properly defined aria attributes, visual focus indicators, etc.

Author: Sergio López Díaz ✍️

You can find out more about me and my projects on:

Support 🤝

Give a ⭐️ if you like this project!

Thanks a lot for stopping by and supporting me!

You may also like ⁉️

Credits

Inspired by trungk18/jira-clone-angular and Jira Software

License 📝

Feel free to use my code on your project. Please put a reference to this repository.

This project is under the MIT license. See the LICENSE for more information.