Skip to content

bimdata/platform

Repository files navigation

BIMData Platform

This repository host the BIMData Platform project. The Platform is a Vue 3.x application bundled with Vite.

Pre-requisites

You need:

Install & Run ⬇️ 🏃

Backend setup

In order for the platform to work properly it should be able to interact with its backend service. The platform-back repository host the source code of the service.

The backend is a python app built with Django REST framework.
You should refer to its README to set it up on your development environment before moving to the application setup.

Application setup

Here are the instructions to get the platform up and running on your development environment:

  • (1) Get the sources
$ git clone git@github.com:bimdata/platform.git
$ cd platform/
  • (2) Install dependencies
$ npm install
  • (3) Setup local env
$ cp .env.example .env.local

Open .env.local with your favorite text editor and set the variable VUE_APP_OIDC_CLIENT_ID to one of your client ID. If you don't know what a "client ID" is then you should have a look at the documentation and follow the steps to create an application.

  • (4) Run the platform
$ npm run dev
  • (5) Have a coffee and start coding... ☕ </>

Tests 🛂 ✅

This project comes with a set of end-to-end tests built with Cypress.

Before you can run the tests you need to have a working test environment. To do so copy the example env file:

$ cp cyress.env.json.example cypress.env.json

Then open it and set variables values as appropriate:

  • APP_BASE_URL: will be used by Cypress as baseUrl
  • AUTH_BASE_URL: authentication server
  • IAM_BASE_URL: identity server

Start the platform locally (only needed if your APP_BASE_URL point to localhost):

npm run dev

Finally start and open Cypress using the following command:

$ npm run test:e2e

☝️ Important Note

In order for the tests to work properly you must run the setup tests first. This will create random test users that will be used in all other tests.

Once your tests are completed you can run the teardown tests to delete tests users.

Build 📦

The platform can be built for production like environment using the following command:

$ npm run build

This will create a dist/ directory that contain the bundled application ready to be deployed.

Development process

There are 3 process banches: develop, release and master.

  • develop is the main development branch. All feature branches should be merged into develop using pull requests.
  • release is the pre-production branch. All fix branches should be merged into release using pull requests. The release branch must be merged into develop once a PR is merged.
  • master is the production branch. The release branch must be merged into master once a release is ready.

This setup allows us to have unstable features in develop while not blocking fix to be shipped in production.

BIMData Viewer

When a new version of the Viewer is released, the develop branch is automatically updated to use this version. When a new stable version of the Viewer is released, the release branch is automatically updated to use this version.

Internationalization

When adding code in develop branch it will trigger an update on POEditor.

License

The content of this repository is published under the terms of the GNU LGPL-3.0.

You are free to copy, modify, and distribute BIMData Platform under the terms of the LGPL 3.0.
See LICENSE for more details.