Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/anuraghazra/quickerpoll
QuickerPoll is a crowd-sourced real-time polling app created with React and Nodejs.
https://github.com/anuraghazra/quickerpoll
express mlab mongo nodejs react rest rest-api
Last synced: 3 months ago
JSON representation
QuickerPoll is a crowd-sourced real-time polling app created with React and Nodejs.
- Host: GitHub
- URL: https://github.com/anuraghazra/quickerpoll
- Owner: anuraghazra
- Created: 2019-02-22T14:26:49.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-08-22T14:58:38.000Z (over 1 year ago)
- Last Synced: 2024-10-11T13:31:16.656Z (3 months ago)
- Topics: express, mlab, mongo, nodejs, react, rest, rest-api
- Language: JavaScript
- Homepage: https://quickerpoll.herokuapp.com
- Size: 3.86 MB
- Stars: 22
- Watchers: 2
- Forks: 8
- Open Issues: 34
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# QuickerPoll
QuickerPoll is a crowd-sourced real-time polling app created with React and Nodejs. QuickerPoll lets you create edit, update, delete public polls and vote on them publicly. This project is just an example of using react, nodejs and restfull apis all together*NOTE : please do not create any violating contents here as is this database is publicly visible and i'm not responsibe for any violating content*
## API Endpoints:
### GET - GET POLLS
```js
// GET ALL POLLS
/api/polls ->
[
{
name: String,
votes: [Object],
_id: String,
request: {
type: 'GET',
url: `/api/polls/${_id}`
}
}
]// GET SINGLE POLL
/api/polls/:poll_id ->
{
name: String,
votes: [Object],
_id: String,
request: {
type: 'GET',
url: `/api/polls/`
}
}
```### POST - CREATE POLLS
```js
// PAYLOAD TO SEND
payload = {
name: String,
votes: [
{
name : String,
value: Number,
color: String
}
]
}/api/polls ->
{
name: String,
votes: [Object],
request: {
type: 'GET',
url: `/api/polls/_id`
}
}```
### PATCH - UPDATE POLLS
```js
// PAYLOAD TO SEND
payload = [
{"propName" : "name", "value" : "new name"},
{"propName" : "votes.0.value", "value" : "80"},
...
]/api/polls/:poll_id ->
{
message: 'Poll has been updated!',
request: {
type: 'GET',
url: `/api/polls/_id`
}
}
```### PATCH - VOTE POLLS
```js
// PAYLOAD TO SEND
payload = vote_id : String/api/polls/cast/:poll_id ->
{
name: String,
votes: [Object],
_id: String,
message: 'Thanks for voting!',
request: {
type: 'GET',
url: `/api/polls/_id`
}
}
```### DELETE - DELETE POLL
```js
/api/polls/:poll_id ->
{
message: 'Successfully deleted the poll',
request: {
type: 'GET',
url: `/api/polls`
}
}
```## Get Started
Clone the repo to your local machine
```bash
git clone https://github.com/anuraghazra/QuickerPoll.git
```Install all the dependencies
```bash
npm install
```Start the application on localhost:3000
```bash
npm run dev
```### NPM Commands
start the application
```bash
npm run dev
```start the backend server
```bash
npm start
```watch for changes in server
```bash
npm run watch-server
```in the ./clients folder to build react front-end type
```bash
npm run build
```## Tools Used
* [React](https://reactjs.org)
* [AntDesign](https://ant.design)
* [Nodejs](https://nodejs.org/)
* [Heroku](https://heroku.com/)
* [Express](https://expressjs.com/)
* [Axios](https://github.com/axios/axios)
* [Mongoosejs](https://mongoosejs.com/)
* [mLab](https://mlab.com/)Made with :heart: and javascript