Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gnidan/foodtastechess-client
Chess game by Team Food Taste for CS451 - Client Web-app
https://github.com/gnidan/foodtastechess-client
Last synced: 23 days ago
JSON representation
Chess game by Team Food Taste for CS451 - Client Web-app
- Host: GitHub
- URL: https://github.com/gnidan/foodtastechess-client
- Owner: gnidan
- License: mit
- Created: 2015-07-07T22:25:37.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2015-08-27T21:20:54.000Z (about 9 years ago)
- Last Synced: 2024-10-07T18:41:29.882Z (about 1 month ago)
- Language: JavaScript
- Size: 1.27 MB
- Stars: 1
- Watchers: 6
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# React Starterkit
This react starterkit provides a prepared development environment based on [gulp](https://github.com/gulpjs/gulp), [stylus](https://github.com/LearnBoost/stylus) and [webpack](https://github.com/webpack/webpack). The internal data flow is handled with [Reflux](https://github.com/spoike/refluxjs) and the routing is managed with the [React-Router](https://github.com/rackt/react-router).
####[Demo](http://wbkd.github.io/react-starterkit)
This starterkit does not include some fancy UI stuff but is a lightweight starting point for your next react app.## Get the kit
```
$ git clone https://github.com/wbkd/react-starterkit.git && cd react-starterkit
```## Installation
Install all dependencies.
```
$ npm install
```## Development
Builds the application and starts a webserver with livereload. By default the webserver starts at port 1337.
You can define a port with `$ gulp --port 3333`.```
$ gulp
```## Build
Builds a minified version of the application in the dist folder.
```
$ gulp build --type production
```## Testing
We use [jest](http://facebook.github.io/jest/) to test our application.
You can run the tests that are defined under [app/scripts/\_\_tests__](./app/scripts/__tests__) with```
$ npm test```
In order to test files that are using the react-router we had to add [stubRouterContext.jsx](./test-utils/stubRouterContext.jsx) which we found [here](https://github.com/rackt/react-router/blob/master/docs/guides/testing.md).
## Javascript
Javascript entry file: `app/scripts/main.js`
**Reflux**
We are using Reflux, which is an implemantion of the [Flux Architecture](http://facebook.github.io/flux/docs/overview.html). If you want to read more about Reflux, check out the readme of the [reflux git repo](https://github.com/spoike/refluxjs).
**React-Router**
The routing is done with the [react-router](https://github.com/rackt/react-router). It's especially great for SPA's. We would recommend to read the [guide](https://github.com/rackt/react-router/blob/master/docs/guides/overview.md) to get an overview of the router features.
**ES6 with babel**
We are working with the webpack [babel loader](https://github.com/babel/babel-loader) in order to load our .js/.jsx files. Babel allows you to use ES6 features like class, arrow functions and [much more](https://babeljs.io/docs/compare/).
## CSS
CSS entry file: `app/stylus/main.styl`
**Stylus**
As you can see we are using stylus to preprocess our .styl files. If you didn't work with a css preprocessor before the [stylus page](http://learnboost.github.io/stylus/) is a good starting point to get to know what stylus can do for you.
If you want to use third-party CSS you just include it via `@import 'path/to/your/third-party-styles.css'` at the top of the main.styl file.## Webpack Hints
You can find the webpack configuration in the [webpack.config.js file](./webpack.config.js).
We use the babel-loader in order to load .jsx and .js files via webpack. If it's possible install all your dependencies with NPM. Packages installed with NPM can be used like this:```language-javascript
var moduleXYZ = require('moduleXYZ');
```
You can find all loaders in this [list](http://webpack.github.io/docs/list-of-loaders.html).###Requirements
* node
* npm
* gulp