3fa04620e7
* Remove Deploy To Now buttons * Remove remaining buttons
77 lines
2.1 KiB
Markdown
77 lines
2.1 KiB
Markdown
# Example app using ReasonML & ReasonReact components
|
|
|
|
## How to use
|
|
|
|
### Using `create-next-app`
|
|
|
|
Execute [`create-next-app`](https://github.com/segmentio/create-next-app) with [Yarn](https://yarnpkg.com/lang/en/docs/cli/create/) or [npx](https://github.com/zkat/npx#readme) to bootstrap the example:
|
|
|
|
```bash
|
|
npx create-next-app --example with-reasonml with-reasonml-app
|
|
# or
|
|
yarn create next-app --example with-reasonml with-reasonml-app
|
|
```
|
|
|
|
### Download manually
|
|
|
|
Download the example:
|
|
|
|
```bash
|
|
curl https://codeload.github.com/zeit/next.js/tar.gz/canary | tar -xz --strip=2 next.js-canary/examples/with-reasonml
|
|
cd with-reasonml
|
|
```
|
|
|
|
Install it and run:
|
|
|
|
```bash
|
|
npm install
|
|
npm run dev
|
|
# or
|
|
yarn
|
|
yarn dev
|
|
```
|
|
|
|
Build and run:
|
|
|
|
```bash
|
|
npm run build
|
|
npm run start
|
|
# or
|
|
yarn build
|
|
yarn start
|
|
```
|
|
|
|
Deploy it to the cloud with [now](https://zeit.co/now) ([download](https://zeit.co/download))
|
|
|
|
```bash
|
|
now
|
|
```
|
|
|
|
### Recommendation:
|
|
|
|
Run BuckleScript build system `bsb -w` and `next -w` separately. For the sake
|
|
of simple convention, `npm run dev` run both `bsb` and `next` concurrently.
|
|
However, this doesn't offer the full [colorful and very, very, veeeery nice
|
|
error
|
|
output](https://reasonml.github.io/blog/2017/08/25/way-nicer-error-messages.html)
|
|
experience that ReasonML can offer, don't miss it!
|
|
|
|
There are 2 convenience scripts to facilitate running these separate processes:
|
|
|
|
1. `npm run dev:reason` - This script will start the ReasonML toolchain in
|
|
watch mode to re-compile whenever you make changes.
|
|
2. `npm run dev:next` - This script will start the next.js development server
|
|
so that you will be able to access your site at the location output by the
|
|
script. This will also hot reload as you make changes.
|
|
|
|
You should start the scripts in the presented order.
|
|
|
|
## The idea behind the example
|
|
|
|
This example features:
|
|
|
|
- An app that mixes together JavaScript and ReasonML components and functions
|
|
- An app with two pages which has a common Counter component
|
|
- That Counter component maintain the counter inside its module. This is used
|
|
primarily to illustrate that modules get initialized once and their state
|
|
variables persist in runtime
|