2015-06-18 19:35:50 +02:00
|
|
|
# UXBox #
|
|
|
|
|
2016-02-04 23:04:38 +02:00
|
|
|
[![Travis Badge](https://img.shields.io/travis/uxbox/uxbox/master.svg)](https://travis-ci.org/uxbox/uxbox "Travis Badge")
|
|
|
|
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
## Development Environment ##
|
2016-02-04 23:04:38 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
### Introduction ###
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
The development environment consists in a docker container that mounts your local
|
|
|
|
copy of the uxbox souce code directory tree and executes a tmux inside the container
|
|
|
|
in order to facilitate execute multiple processes inside.
|
2015-06-18 19:35:50 +02:00
|
|
|
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
### System requirements ###
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
You should have `docker` installed in your system in order to set up properly
|
|
|
|
the uxbox development enviroment.
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
In debian like linux distributions you can install it executing:
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
```bash
|
|
|
|
sudo apt-get install docker
|
2015-06-18 19:35:50 +02:00
|
|
|
```
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
### Build the docker image ###
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
In order to build the docker image, you should clone **uxbox-docker** repository:
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
```bash
|
|
|
|
git clone git@github.com:uxbox/uxbox-docker.git
|
2015-06-18 19:35:50 +02:00
|
|
|
```
|
2016-03-01 19:50:30 +02:00
|
|
|
|
|
|
|
And build the image executing that:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
cd uxbox-docker
|
|
|
|
sudo docker build --rm=true -t uxbox .
|
2015-06-18 19:35:50 +02:00
|
|
|
```
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
### Start the docker image ###
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
The docker development environment consists in a tmux executed inside the docker
|
|
|
|
container giving you the ability to execute multiple processes like one virtual
|
|
|
|
machine.
|
2016-01-20 18:48:23 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
**Requires a minimum knowledge of tmux usage in order to use that development
|
|
|
|
environment.**
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
For start it, staying in this repository, execte:
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
```bash
|
|
|
|
./scripts/docker
|
2015-06-18 19:35:50 +02:00
|
|
|
```
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
This command will start a new named container, if you stops it and starts again
|
|
|
|
the data is conserved because the same container will be resumed again.
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
|
|
|
|
### First steps inside ###
|
|
|
|
|
|
|
|
Now having the the container running and tmux open inside the container, you are
|
|
|
|
free to execute any commands and open many shells as you want. The basic frontend
|
|
|
|
development requires at least *two shells*.
|
|
|
|
|
|
|
|
In the first shell (the defaul one) execute:
|
|
|
|
|
|
|
|
```bash
|
2015-06-18 19:35:50 +02:00
|
|
|
npm run watch
|
|
|
|
```
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
That command will launch the gulp process that compiles sass and template file
|
|
|
|
and will keep watching for recomplie the sass files when they are changed.
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
For create a new shell just press the following key shortcut: **Ctr+b c**.
|
|
|
|
|
|
|
|
Once the new shell is created, execute the clojurescript compiler process:
|
|
|
|
|
|
|
|
```bash
|
|
|
|
npm run figwheel
|
2015-06-18 19:35:50 +02:00
|
|
|
```
|
|
|
|
|
2016-03-01 19:50:30 +02:00
|
|
|
You can use **Ctrl+b w** for switch between the existing shells and **Ctrl+b &** for
|
|
|
|
kill the current shell.
|
|
|
|
|
|
|
|
|
|
|
|
## Other topics ##
|
2015-06-18 19:35:50 +02:00
|
|
|
|
2016-01-20 18:48:23 +02:00
|
|
|
### Transformation from HTML to hiccup ###
|
2015-06-18 19:35:50 +02:00
|
|
|
|
|
|
|
For transforming the generated HTMLs to hiccup form, execute the following command:
|
|
|
|
|
|
|
|
```
|
|
|
|
$ lein with-profile +front hicv 2clj resources/public/templates/*.html
|
|
|
|
```
|
|
|
|
|
|
|
|
The `.clj` files in the `hicv` directory will contain the hiccup versions of the HTML templates.
|
|
|
|
|
|
|
|
|
|
|
|
## License ##
|
|
|
|
|
|
|
|
TODO
|