#NOTE:
This is my version of this demo app -- if you are interested, I highly recommend you get the empty version from Cory House's GitHub path below and work through it yourself.
###TODO based on course challenges...
- Author administration (with blocking logic when the author has a course) (DONE)
- Delete course (DONE)
- Hide empty course list (DONE)
- Unsaved changes messages (DONE) [but ugly, need to use navigation confirmation trick and add testing]
- Client-side validation (category and length data, etc.) (DONE)
- Handle 404s (ManageCoursePage/ManageAuthorPage); (DONE) [not convinced these are the best-structured]
- Show # courses in header (DONE)
- Pagination
- Sort course table (DONE)
- Revert abandoned changes
###TODO based on my own challenges... :)
- Allow sort by header click, with arrow display.
- Use unsaved changes custom route dialog solutions from http://stackoverflow.com/questions/35275344/how-to-use-a-custom-component-with-react-router-route-transitions/35793421#35793421 or http://stackoverflow.com/questions/35770438/show-custom-dialog-setrouteleavehook-or-history-listenbefore-react-router-redux
#Starter Kit for Building Applications in React and Redux in ES6 on Pluralsight
- Install Node 6. Need to run multiple versions of Node? Use nvm or nvm-windows
- Clone this repository. -
git clone https://github.com/coryhouse/pluralsight-redux-starter.git
or download the zip - Make sure you're in the directory you just created. -
cd pluralsight-redux-starter
- Install Node Packages. -
npm install
- Run the app. -
npm start -s
This will run the automated build process, start up a webserver, and open the application in your default browser. When doing development with this kit, this command will continue watching files all your files. Every time you hit save the code is rebuilt, linting runs, and tests run automatically. Note: The -s flag is optional. It enables silent mode which suppresses unnecessary messages during the build. - Disable safe write to assure hot reloading works properly.
- Install React developer tools and Redux Dev Tools in Chrome.
- Having issues? See below.
- Run
npm install
- If you forget to do this, you'll see this:babel-node: command not found
. - Make sure the path doesn't include any spaces, or install the latest version of eslint-watch which adds support for paths containing spaces:
npm install [email protected]
- Make sure you're running the latest version of Node.
- Use Node 5.12.0 if you're having issues on Windows. Node 6 has issues on some Windows machines.
- Don't run the project from a symbolic link. It will cause issues with file watches.
- Using VSCode's built in Terminal? Try it on the native command line instead. There are known issues in recent versions of VSCode's terminal.
- Use path.resolve on all path references in both the dev and prod webpack.config. See this commit for an example.
- Delete any .eslintrc that you're storing in your user directory, or add this line to the .eslintrc for this project.
- Disable any ESLint plugin / custom rules that you've enabled within your editor since these will conflict with the ESLint rules defined in the course.
###Production Dependencies
Dependency | Use |
---|---|
babel-polyfill | Polyfill for Babel features that cannot be transpiled |
bootstrap | CSS Framework |
jquery | Only used to support toastr |
react | React library |
react-dom | React library for DOM rendering |
react-redux | Redux library for connecting React components to Redux |
react-router | React library for routing |
react-router-redux | Keep React Router in sync with Redux application state |
redux | Library for unidirectional data flows |
redux-thunk | Async redux library |
toastr | Display messages to the user |
###Development Dependencies
Dependency | Use |
---|---|
babel-cli | Babel Command line interface |
babel-core | Babel Core for transpiling the new JavaScript to old |
babel-loader | Adds Babel support to Webpack |
babel-plugin-react-display-name | Add displayName to React.createClass calls |
babel-preset-es2015 | Babel preset for ES2015 |
babel-preset-react | Add JSX support to Babel |
babel-preset-react-hmre | Hot reloading preset for Babel |
babel-register | Register Babel to transpile our Mocha tests |
cheerio | Supports querying DOM with jQuery like syntax - Useful in testing and build process for HTML manipulation |
colors | Adds color support to terminal |
compression | Add gzip support to Express |
cross-env | Cross-environment friendly way to handle environment variables |
css-loader | Add CSS support to Webpack |
enzyme | Simplified JavaScript Testing utilities for React |
eslint | Lints JavaScript |
eslint-plugin-import | Advanced linting of ES6 imports |
eslint-plugin-react | Adds additional React-related rules to ESLint |
eslint-watch | Add watch functionality to ESLint |
eventsource-polyfill | Polyfill to support hot reloading in IE |
expect | Assertion library for use with Mocha |
express | Serves development and production builds |
extract-text-webpack-plugin | Extracts CSS into separate file for production build |
file-loader | Adds file loading support to Webpack |
jsdom | In-memory DOM for testing |
mocha | JavaScript testing library |
nock | Mock HTTP requests for testing |
npm-run-all | Display results of multiple commands on single command line |
open | Open app in default browser |
react-addons-test-utils | Adds React TestUtils |
redux-immutable-state-invariant | Warn when Redux state is mutated |
redux-mock-store | Mock Redux store for testing |
rimraf | Delete files |
style-loader | Add Style support to Webpack |
url-loader | Add url loading support to Webpack |
webpack | Bundler with plugin system and integrated development server |
webpack-dev-middleware | Adds middleware support to webpack |
webpack-hot-middleware | Adds hot reloading to webpack |