Skip to content

Commit

Permalink
VUU83: Add layout management documentation
Browse files Browse the repository at this point in the history
- Configuring local/remote
- Running the remote server
  • Loading branch information
cfisher-scottlogic committed Nov 17, 2023
1 parent 77e2472 commit e5ebaea
Show file tree
Hide file tree
Showing 2 changed files with 66 additions and 21 deletions.
74 changes: 53 additions & 21 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,11 +10,13 @@ https://vuu.finos.org/docs/introduction/intro

## Installation - Server

### Prerequisites
### Vuu Server

#### Prerequisites

See the [Docs](https://vuu.finos.org/docs/getting_started/developing) for Java versions and install dependencies you need to have.

OS X & Linux:
#### OS X & Linux:

```sh
#In your favourite code directory...
Expand All @@ -29,40 +31,41 @@ cd vuu
mvn exec:exec
```

Windows:
#### Windows:

```sh
this should be the same as Linux & macos just with windows adjusted paths
```

## Installation - Client
### Layout Server

The UI scripts all run from the vuu/vuu-ui directory.
Layout management requires persisting layouts. Layouts can either be persisted locally or remotely. The remote implementation requires spinning up a Springboot server instance, but is more robust and reflective of a real-world application.

```sh
#from top-level vuu repo (not vuu child directory in repo)
cd vuu-ui
npm install
npm run build
npm run build:app
```
#### Choosing local or remote

You can now open the demo app in your browser at https://127.0.0.1:8443/index.html
Changing whether local/remote is used is configured with the following flag:

Alternatively, you may choose to run the demo app in Electron. First install Electron in the tools/electron folder:
1. Open `finos-vuu\vuu-ui\showcase\vite.config.js`
2. Set `"process.env.LOCAL"` flag to `true` for local, or `false` for remote

The local implementation is default. It uses browser local storage. If you have chosen the remote implementation, ensure you are running the remote server.

#### Running the remote server

You can run the remote server from IntelliJ or via CLI. Once running, use `http://localhost:8081/api/swagger` to review endpoints and contracts. It uses an in-memory H2 database, and can be accessed at `http://localhost:8081/api/h2-console`.

##### CLI

```sh
#from top-level vuu repo (not vuu child directory in repo)
cd vuu-ui/tools/electron
npm install
cd layout-server
mvn spring-boot:run
```

Then, back in vuu-ui, run the launch script"
##### From IntelliJ

```sh
#from vuu/vuu-ui
npm run launch:demo:electron
```
1. Follow steps 3-5 outlined in 'Configuring IntelliJ' below
2. Select 'LayoutServer' config and click run

## Configuring IntelliJ

Expand All @@ -89,6 +92,35 @@ npm run build
8. In IntelliJ, select 'SimulMain' config and click run
9. If you get a 'certificate-unknown' error, set 'Allow invalid certificates for resources loaded from localhost' to 'Enabled' in your chrome settings

## Installation - Client

The UI scripts all run from the vuu/vuu-ui directory.

```sh
#from top-level vuu repo (not vuu child directory in repo)
cd vuu-ui
npm install
npm run build
npm run build:app
```

You can now open the demo app in your browser at https://127.0.0.1:8443/index.html

Alternatively, you may choose to run the demo app in Electron. First install Electron in the tools/electron folder:

```sh
#from top-level vuu repo (not vuu child directory in repo)
cd vuu-ui/tools/electron
npm install
```

Then, back in vuu-ui, run the launch script"

```sh
#from vuu/vuu-ui
npm run launch:demo:electron
```

## Usage example

```
Expand Down
13 changes: 13 additions & 0 deletions layout-server/src/main/resources/LayoutServer.run.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<component name="ProjectRunConfigurationManager">
<configuration default="false" name="LayoutServer" type="SpringBootApplicationConfigurationType"
factoryName="Spring Boot">
<option name="ALTERNATIVE_JRE_PATH" value="BUNDLED"/>
<option name="ALTERNATIVE_JRE_PATH_ENABLED" value="true"/>
<module name="layout-server"/>
<option name="SPRING_BOOT_MAIN_CLASS"
value="org.finos.vuu.layoutserver.LayoutServerApplication"/>
<method v="2">
<option name="Make" enabled="true"/>
</method>
</configuration>
</component>

0 comments on commit e5ebaea

Please sign in to comment.