vote-management-system
This Project is build on VueJS Framework and Vuetify as CSS framework, there is an automated tets case setup using testcafe.
The Firebase has been for hosting the application please find below the url also the code is checkout in github at below location
Application Url : https://vote-management-application.web.app/
GitHub Url : https://github.com/Pranoy-Prabhakar/vote-management-application
Description of Project
The application is a single page application which is divided in three sections. On the first section, the user can create a poll with up to 10 options. In the central one, the user can vote by selecting one of the options and pressing the “vote” button. On the right, the chart will update based on the questions created and the votes that each question got.
Use cases
- As the owner, I want to change my poll question.
- As the owner, I want to add, edit or remove the options of my poll.
- As the owner, I want to reset the whole form, including answers.
- As the user, I want to see the UI refresh automatically when something changes.
- As the respondent, I want to send several answers.
- As the respondent, I want to see the changes in real time.
Non Functional Requirement
- All fields have a limit of 80 characters.
- When the limit is reached, fields should be disabled.
- There should be always at least 2 options.
- The user can vote as many times as possible.
- The reset button should reset the whole UI: question, options and answers.
- It is mandatory to provide a deployment URL and source code.
- You can use 3rd party libraries or frameworks to develop this assignment.
- Writing automated tests is a plus.
- You must provide a README.md file with instructions
Assumptions
As the above information were high level, I have made below assumption
- The Addition of the options can only be possible at the end
- user can delete or edit the options from the list
- option must not be a duplicate, in case user enters flash the message on the screen
- Changing the options or question will remove the chart report
Project setup
npm install
Compiles and hot-reloads for development
npm run serve
Compiles and minifies for production
npm run build
Lints and fixes files
npm run lint