/hapi-cycle

Hapi + Cycle + Webpack/HMR/CSS Modules

Primary LanguageCSS

HapiCycle

HapiCycle is a basic starter kit to get you going with a straight-forward isomorphic/universal Cycle.js app.

WORK IN PROGRESS

HapiCycle is currently a WIP and the skeleton app may not yet be following ideal FRP/Cycle conventions/best-practices and the Webpack config hasn't been fully optimized. Pull requests are welcome!

Features / Libraries included

  • Cycle.js
  • Hapi API/server configured to render your Cycle.js app on the server-side
  • Waterline ORM via Dogwater, preconfigured with Memory adapter
  • A skeleton Cycle app under ./src/ui/ providing basic user CRUD functionality as an example/starting point for your app. Includes a bunch of helpful components such as:
    • ./src/ui/components/alerts – Alerts that automatically dismiss after an elapsed time
    • ./src/ui/components/label-input – Inputs with label elements that behave like the HTML5 placeholder attribute, but with animations and better accessibility
    • ./src/ui/components/layout – A layout wrapper component that wraps your pages with a common layout VTree
  • Webpack preconfigured with:
  • Bootstrap's LESS source is included by default, if you don't want it just run: rm -rf ./assets/styles/bs/
  • Animate.css for easy transitions
  • FontAwesome for easy to use vector icons

Getting Started

  1. $ git clone https://github.com/wyqydsyq/hapi-cycle.git hapi-cycle/ && cd hapi-cycle/
  2. $ npm install
  3. $ npm run launch
  4. Open http://localhost:1337/ in your browser.

TODO

  1. Optimize Webpack config – currently all assets are bundled in both server and client configs. We need one of these configs to bundle the assets and the other one to alias/refer to the already-bundled assets instead of rebundling them.
  2. Follow FRP/Cycle best practices – some components need refactoring to be more efficient and readable. A few files are importing modules that don't get used.
  3. Improve configurability – Make some basic development/production environment-specific configurations. HMR shouldn't be registered in server.js and shouldn't be injected into the client.js bundle in production.
  4. Set up API scaffold/boilerplate - API routes/handlers are currently just defined in ./src/server.js, ideally they should be set up as a seperate file for each handler with a single routes.js mapping route paths to handlers.
  5. Make a Yeoman generator – Porting this into a Yeoman generator would broaden the awareness/appeal and make using this a bit easier for those who already use Yeoman for scaffolding apps.