Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/davesnx/react-palm-tree
https://github.com/davesnx/react-palm-tree
Last synced: 14 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/davesnx/react-palm-tree
- Owner: davesnx
- License: mit
- Created: 2023-10-03T18:22:34.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2023-10-18T04:10:50.000Z (about 1 year ago)
- Last Synced: 2024-10-31T17:26:14.699Z (2 months ago)
- Language: OCaml
- Size: 49.8 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# react-palm-tree
Example of a Melange project using opam with Fetch and Json decoding
---
A simple project template using [Melange](https://github.com/melange-re/melange)
with [opam](https://opam.ocaml.org/).If you are looking for a template with esy, check [melange-esy-template](https://github.com/melange-re/melange-esy-template).
## Quick Start
```shell
make init# In separate terminals:
make watch
make serve
```When running `make init`, you may encounter an error like this:
```
[ERROR] Could not determine which packages to install for this switch:
* Missing dependency:
- melange >= 1.0.0
no matching version
```To address this, first run `opam update`, then rerun `make init`.
### React
React support is provided by
[`reason-react`](https://github.com/reasonml/reason-react/). The entry
point of the sample React app is [`src/ReactApp.re`](src/ReactApp.re).## Commands
You can see all available commands by running `make help` or just `make`. Here
are a few of the most useful ones:- `make init`: set up opam local switch and download OCaml, Melange and
JavaScript dependencies
- `make install`: install OCaml, Melange and JavaScript dependencies
- `make watch`: watch for the filesystem and have Melange rebuild on every
change
- `make serve`: serve the application with a local HTTP server## JavaScript output
Since Melange just compiles source files into JavaScript files, it can be used
for projects on any JavaScript platform - not just the browser.The template includes two `melange.emit` stanza for two separate apps. This
stanza tells Dune to generate JavaScript files using Melange, and specifies in
which folder the JavaScript files should be placed, by leveraging the `target`
field:
- The React app JavaScript files will be placed in `_build/default/src/output/*`.
- The NodeJS app JavaScript files will be placed in `_build/default/src/node/*`.So for example, [`src/Hello.ml`](src/Hello.ml) (using OCaml syntax) can be run with
`node`:```bash
node _build/default/src/node/src/Hello.js
```Similarly, `_build/default/src/output/src/ReactApp.js` can be passed as entry to a bundler
like Webpack:```bash
webpack --mode production --entry ./_build/default/src/output/src/ReactApp.js
```