GithubHelp home page GithubHelp logo

react-ut / reapp Goto Github PK

View Code? Open in Web Editor NEW

This project forked from reapp/reapp

0.0 2.0 0.0 170 KB

Reapp - next gen hybrid apps

Home Page: http://www.reapp.io

License: MIT License

JavaScript 100.00%

reapp's Introduction

What is it?

Reapp is everything you need to build amazing apps with React: a collection of packages that work together, our UI kit, and a CLI that scaffolds your app and includes a server and build system.

Join the chat at https://gitter.im/reapp/reapp

Installation

Installation is done through npm:

npm install -g reapp

Generate a new base reapp stack with:

reapp new [name]

And finally in your app directory, run it on localhost:3010:

reapp run

CLI

The CLI has two main functions that it helps you with. The first is creating new apps. For now, it simply makes a bare clone of a repo we keep updated with the current best-practice. The goal is eventually to have a variety of baseline repo's to choose from.

It also lets you run your app, using reapp-server, a simple express server that works well with the default app structure.

CLI Usage:

Usage: reapp [command]

  new [name]  creates a directory with a new reapp-starter scaffold
  run         runs a reapp application with express/webpack-dev-server
  build       builds a reapp application to a bundle in ./build
  debug       use this to for opening issues!

The build and run commands take a variety of options to help ease your development, such as:

Usage: reapp-run [options]

  -d, --debug          output extra information for debugging
  -p, --port [number]  specify a port [number]
  -h, --host [host]    specify hostname
  -b, --bind [address] specify bind address if different from host
  -e, --env [env]      specify an enivornment
  -t, --tool [tool]    specify a webpack devtool
Usage: reapp-build [options]

  -d, --debug  output extra information for debugging
  --no-assets  only build the js
  --no-js      only build the assets

Running & Building

Use reapp run to server your app locally, by default at localhost:3010. The run command has a few options to help you out:

  • reapp run -d (debug) to output information on how it's running your app
  • reapp run -e production (env=production) to run your app in production mode, which is much faster
  • reapp run -t source-map (tool=source-map) to have full sourcemaps rather than the "eval" style sourcemaps we default to

You also have the same flags available to build commands.

The build command is used once you're ready to deploy your app (to either the web or to cordova). For now, we provide two types of builds:

  • reapp build by default sets the platform to web, for mobile sites.
  • reapp build ios targets Cordova ios devices.

When you run reapp build you'll notice a new ./build folder where your assets have been copied to. For example, a reapp build ios will build to ./build/ios. reapp build goes to ./build/web.

It will also copy your assets for you. Here's an example of running reapp build ios:

./assets/shared/* => ./build/ios
./assets/ios/* => ./build/ios
./assets/ios/index.html => (Webpack inserts CSS/JS references) => ./build/ios/index.html

This allows a lot of flexibility. You can share assets between builds, or have exclusive ones for a platform. Leave an asset in the base ./assets folder and it won't be copied at all, but you can still require() it within your app.

A good case for shared assets is your Cordova config.xml. Leave it in ./assets/shared and it'll output for all your builds.

See more on custom builds.

Structure of your applications

You can see the exact app that's generated through the reapp-starter repo. Only the /app/app.js entrypoint and /assets/web/index.html is "necessary". For now, it's very simple:

/app
  /components
  /theme
  app.js
  routes.js
/assets
  /web
    index.html
  /ios
    index.html
  /shared
/config (optional)

/app/app.js is your entry point. Everything in the app folder should be pretty self-explanatory. /assets contains static assets as explained in the Running & Building section. In general, you'll place your assets into shared or the specific platform subdirectory.

The /theme folder is reapp-ui specific. You can find docs for it in the repo, but it also should be pretty easy to understand.

If you place a build.webpack.js or run.webpack.js in your /config dir, the reapp CLI will use these configs when you run reapp build or reapp run. To see some example configs, check out the files in the ./config folder of the reapp-pack repo.

Your First App

There are a number of pieces we've included in a reapp. Let's explore a few of them in order of when you'll encounter them in your codebase. Think of this as a tour of a reapp app, giving an introduction to packages as we encounter them.

You can check out the reapp project on Github for more info.

To start, you'll want to open ./package.json. Notice we have the following packages:

You also have an entry point defined as app/app.js. This starts your app. The most important part here is the routing. Lets start there.

./app/routes (reapp-routes)

We've rolled our own simple DSL for routes. It saves you a lot of time, essentially saving you from having to do bunch of typing as long as you keep your components structure consistent with the routes.

We map these routes to react-router by default.

You'll notice that the pre-defined routes all perfectly map to the structure of ./app/components. To see more about how this works, check out reapp-routes.

This is the reapp-routes syntax. The key to note here is the require that is passed to the routes function at the top level, which is how it dynamically requires your components based on the route tree.

./app/theme reapp-ui (UI Kit)

The next theme we require is the ./app/theme/theme.js file. They have three things they need: constants, styles, and animations. You can just use the included iOS theme, but we've included the ./app/theme folder as an example of how you can easily customize themes.

For more documentation on themes, read here.

More reading

Custom builds

Reapp-pack takes in an object that lets you configure your builds. It provides you with default config files, but you can override them if you need custom Webpack loaders.

The build system generates your Webpack config using reapp-pack.

  • reapp run looks for: ./config/run.config.js
  • reapp build looks for: ./config/build.config.js
  • reapp build [platform] looks for: ./config/build.[platform].config.js

Place a config in your ./config/[run/build].[platform].config.js to override the default.

Here's an example config:

module.exports = {
  entry: './app/app.js',
  devtool: 'none',
  target: 'web',
  env: 'production',
  linkModules: true,
  debug: true,
  separateStylesheet: true,
  minify: true
};

You can also provide the following options that are passed to Webpack:

  loaders: array
  modulesDirectories: array
  prefetch: array

Why Reapp?

Reapp wasn't built purposefully to be a framework. Instead, it started as a UI kit. From that kit, two apps were built. While this isn't a lot, it was enough to see repetition between the two that could be extracted.

From those two apps, over a period of months, we extracted a set of packages, ensuring to keep each of them completely independent. It was an experiment in seeing if a framework was necessary.

What we found was this: if you can subscribe to a certain file structure, you can avoid the framework. With that file structure, we can provide helpers via a CLI. Bootstrap your app in one command and you have a mature build system built in, without having to do anything.

Really, Reapp is simple. You could even just use the UI kit and roll your own app. We just went through that headache, and decided to make it easier to avoid it if you like how we make apps.

Example Apps

We have two example apps you can check the source to:

Development Environment

Sublime users, here's a guide for getting syntax highlighting, snippets and linting that works with babel.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.