Skip to content

Aam-Digital/ndb-core

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Release Version Build Status Code Climate Test Coverage E2E Tests Guides Doc CoverageDocs Known Vulnerabilities

Aam Digital

Empowering social workers with simple to use software.

For more information about the software and a free demo system visit www.aam-digital.com.

For more information about the code including guides see the separate Developer Documentation


Installation, Use & Deployment

You can directly run the system using Docker. More information in our Aam-Digital/ndb-setup repository. In that case you do not have to clone this repository and install all the dependencies as everything is packaged into the docker image already.

Configuration

The custom configuration for your service instance is set in the assets/config.json file. You can copy the assets/config.default.json as a starting point.

Nextcloud (webdav) Integration

You can integrate Aam Digital with an existing Nextcloud server to allow users to update photos on their own. To avoid CORS issues the webdav URL in your config.json should be a relative URL in combination with a reverse-proxy that is forwarding to the actual Nextcloud server address:

assets/config.json:

  "webdav": {
    "remote_url": "nextcloud/"
  }

proxy.conf.json (for local development):

  "/nextcloud": {
    "target": "https://<your-nextcloud-server>/remote.php/webdav",
    "secure": true,
    "changeOrigin": true,
    "pathRewrite": {
      "^/nextcloud": ""
    }
  }

docker-compose.yml (for production server):

  environment:
    WEBDAV_URL: https://<your-nextcloud-server>/remote.php/webdav

Development

Setup

  1. This project depends on npm (NodeJS) to setup its dependencies. Please make sure you have npm installed.
  2. git clone this repository to get all the code with its configuration and requirements.
  3. npm install the dependencies (external libraries and packages)
  4. create a config file assets/config.json by copying the default config assets/config.default.json that is part of the repository.
  5. npm run start to run your local dev server and get started.

Documentation

Our detailed Developer Documentation provides tutorials, guides, concepts and an API reference.

Code Style

We use prettier to enforce a consistent formatting of code to make the project easier to read. The project is set up with a git pre-commit hook to automatically format your commits according to these rules.

Using Angular CLI

This project is built upon Angular. If you are unfamiliar with the framework and Angular CLI go check out the Angular CLI README or use use ng help. The following sections give you a brief overview.

Development server

Run npm run start for a dev server. Navigate to http://localhost:4200/. The app will automatically reload if you change any of the source files.

Code scaffolding (Generate new modules and components)

You can use Angular CLI to add new code to the project. Run ng generate component component-name to generate a new component. You can also use ng generate directive|pipe|service|class|module.

Build

Run ng build -prod to build the project. The build artifacts will be stored in the dist/ directory. Use the -prod flag for a production build.

Running unit tests

Run ng test to execute the unit tests via Karma.

Running end-to-end tests

Run npm run e2e to execute the end-to-end tests via Cypress in the terminal.

Run npm run e2e-open to execute the end-to-end tests via Cypress own User Interface.

Build a docker image locally

Deployment on a server can be done through a docker image, our ndb-setup project provides tools and a starting point to run the system using docker. For more information about Docker, please refer to their official documentation.

To learn more about the build process, see /build.


Contribute

Our project is completely run by volunteers. Contributions welcome!

We are trying hard to make it easy for you to join in. As a starting point, please refer to our CONTRIBUTING page.