2015-10-19 00:22:07 +02:00
OpenSupports v4.0
2015-12-29 21:56:23 +01:00
2016-01-26 22:05:09 +01:00
[![Build Status ](https://codeship.com/projects/3faec3f0-908d-0133-1dce-661fcf0def08/status?branch=master )](https://codeship.com/projects/124436/)
2015-08-16 01:47:51 +02:00
============
2016-04-17 23:43:11 +02:00
### Getting up and running FRONT-END (client folder)
2015-12-26 23:57:34 +01:00
0. update `sudo apt-get update`
2015-12-26 23:46:48 +01:00
1. Clone this repo
2015-12-29 16:44:08 +01:00
2. Install node 4.x version
2015-12-29 21:56:23 +01:00
- `sudo apt-get install curl`
- `curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash -`
- `sudo apt-get install -y nodejs`
2015-12-26 23:46:48 +01:00
3. Install npm `sudo apt-get install npm`
4. Install gulp `sudo npm install -g gulp`
5. Go to repo `cd os4-react`
2016-01-26 22:05:09 +01:00
6. Install dependences `npm install`
7. Rebuild node-sass `npm rebuild node-sass`
2015-12-29 16:44:08 +01:00
8. Run `gulp dev`
9. Go to the main app: `http://localhost:3000/app` or the component demo `http://localhost:3000/demo`
2016-01-26 22:05:09 +01:00
10. Your browser will automatically be opened and directed to the browser-sync proxy address
2016-03-05 01:06:40 +01:00
12. Use `gulp dev --api` to disable fixtures and use the real php server api (it must be running at :8080).
2015-12-26 23:43:39 +01:00
2016-01-26 22:05:09 +01:00
Now that `gulp dev` is running, the server is up as well and serving files from the `/build` directory. Any changes in the `/src` directory will be automatically processed by Gulp and the changes will be injected to any open browsers pointed at the proxy address.
2015-08-16 01:47:51 +02:00
2016-04-30 00:12:36 +02:00
#### Frontend Unit Testing
1. Do the steps described before
2. Install mocha "sudo npm install -g mocha"
3. Run `npm test` to run the tests
2016-04-17 23:43:11 +02:00
### Getting up and running BACK-END (server folder)
2015-08-16 01:47:51 +02:00
2016-01-26 22:05:09 +01:00
1. Clone this repo
2016-03-05 01:06:40 +01:00
2. [Install PHP5 ](http://www.howtogeek.com/howto/ubuntu/installing-php5-and-apache-on-ubuntu/ )
3. [Create MySQL Database ](#markdown-header-create-mysql-database )
4. [Install composer ](https://www.digitalocean.com/community/tutorials/how-to-install-and-use-composer-on-ubuntu-14-04 )
5. Go to `cd os4-react/api`
6. Run `composer install`
7. Run the server with `php -S localhost:8080`
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
### Create MySQL Database
2015-10-19 00:25:54 +02:00
2015-10-19 00:22:07 +02:00
1. Install mysql-server
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
Ubuntu
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
`sudo apt-get install mysql-server`
2016-01-26 22:05:09 +01:00
2015-10-19 00:22:07 +02:00
Cent OS
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
`sudo yum install mysql-server`
`/etc/init.d/mysqld start`
2015-08-16 01:47:51 +02:00
2016-01-26 22:05:09 +01:00
2. Access the mysql shell
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
`mysql -u root -p`
2015-08-16 01:47:51 +02:00
2015-10-19 01:37:04 +02:00
3. Create a new database
2015-08-16 01:47:51 +02:00
2015-10-19 00:22:07 +02:00
`CREATE DATABASE os_dev;`
2015-08-16 01:47:51 +02:00
2015-10-19 01:37:04 +02:00
4. Assign privileges to user
2015-08-16 01:47:51 +02:00
2015-10-19 01:37:04 +02:00
`GRANT ALL PRIVILEGES ON os_dev.* To 'os_dev'@'localhost' IDENTIFIED BY 'os_dev';`
2015-08-16 01:47:51 +02:00
2015-10-19 00:29:29 +02:00
6. Run the MySQL server
`sudo /etc/init.d/mysql start`
2015-08-16 01:47:51 +02:00
##### Production Task
Just as there is the `gulp dev` task for development, there is also a `gulp prod` task for putting your project into a production-ready state. This will run each of the tasks, while also adding the image minification task discussed above. There is also an empty `gulp deploy` task that is included when running the production task. This deploy task can be fleshed out to automatically push your production-ready site to your hosting setup.
2016-01-26 22:05:09 +01:00
**Reminder:** When running the production task, gulp will not fire up the express server and serve your index.html. This task is designed to be run before the `deploy` step that may copy the files from `/build` to a production web server.