Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/saulosilva/voting-server
learning React.js
https://github.com/saulosilva/voting-server
Last synced: 19 days ago
JSON representation
learning React.js
- Host: GitHub
- URL: https://github.com/saulosilva/voting-server
- Owner: SauloSilva
- Created: 2016-09-26T04:10:07.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2016-10-02T16:12:17.000Z (over 8 years ago)
- Last Synced: 2024-10-31T10:27:57.804Z (2 months ago)
- Language: JavaScript
- Size: 447 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Voting Server
**Logic**
The idea is that we'll have a collection of things to vote from: Movies, songs, programming languages, Horse JS quotes, anything. The app will put them against each other in pairs, so that on each round people can vote for their favorite of the pair. When there's just one thing left, that's the winner.
For example, here's how a vote on the best Danny Boyle film could go:
![img](./public/images/vote_logic.png)
## The Architecture
The system will technically consist of two applications: There's a browser app we'll make with React that provides both the user interfaces, and a server app we'll make for Node that handles the voting logic. Communication between the two will be done using WebSockets.
We're going to use Redux to organize the application code both on the client and on the server. For holding the state we'll use Immutable data structures.
[**Reference**](http://teropa.info/blog/2015/09/10/full-stack-redux-tutorial.html)
## How start APPs
- Install npms:
```
npm install
```- Run server:
```
npm run start
```- Run webpack:
```
webpack && webpack-dev-server
```- Open `/dist/index.html` in your brownser
- Run test:
`npm run test`