Nicolas Fuentes Maturana 39cdcff53d Merge pull request #48 in TEA/dafa-web-monorepo from feature/TV-335 to develop
Squashed commit of the following:

commit 8135e484f44885875bd28dbb0cb7f89fdb7223fa
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Sat Aug 14 19:32:56 2021 +0200

    TV-335 refactoring validators

commit f85a832f9f3e7161380b4b204639a71129eee2fb
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Sat Aug 14 18:18:30 2021 +0200

    TV-335 refactoring

commit 81e03f9377ae3ea4d1e2a196d1074e2e620472b1
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 17:51:33 2021 +0200

    TV-335 spelling

commit 8542d0d20743e6a6d777c083e3559416b96529bc
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 17:48:10 2021 +0200

    TV-335 review fixes

commit 07a5da0576d2d42f043b54cb655aac2070ab218c
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 13:22:15 2021 +0200

    TV-335 use digi layout gutters for margins

commit 9c99d78b10a4c7414d83005ba1847ddd5420d7f5
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 11:47:32 2021 +0200

    TV-335 added ChangeDetectorRef, refactoring submitForm

commit 21b4e3ca5d72b3cedfd0795ef2d924f3380d167b
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 11:09:40 2021 +0200

    TV-335 refactoring due to review comments

commit 9e389c7e67e56e9965453822c38c5fce44e99b35
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Fri Aug 13 00:43:57 2021 +0200

    TV-335 refactoring

commit e3c98416bea1ff705b17bd5bdd85112cbff13c91
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 18:56:21 2021 +0200

    TV-335 invalidFormMessage

commit f3f54fc8c331b7b00a4ebef72e80e7fb56640985
Merge: e68eb7c 466abd1
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 16:55:33 2021 +0200

    Merge branch 'develop' into feature/TV-335

commit e68eb7cb09aecb2252f542bece1228db453d3cf6
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 16:49:40 2021 +0200

    TV-335 email validator

commit eee201919eca8186e0864a69e5f80fd696e40b91
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 16:23:30 2021 +0200

    TV-335 post mock data api, notification alert

commit 46b185ad82ac5946ccfdf173a960fde7261e51bd
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 11:56:43 2021 +0200

    TV-335 prepare method for post request

commit 8b983fbf34ff39b6252cff9bfdc904d6aeeb3a46
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 11:54:25 2021 +0200

    TV-335 routing

commit 01bac9359100a22c3fafa482e828e88727c7ab29
Author: fueno <nicolas.fuentes-maturana@arbetsformedlingen.se>
Date:   Thu Aug 12 11:53:30 2021 +0200

    TV-335 employee-invite component
2021-08-17 09:35:10 +02:00
2021-03-16 13:00:57 +01:00
2021-03-16 13:00:57 +01:00
2021-03-16 13:00:57 +01:00
2021-03-16 13:11:11 +01:00
2021-05-04 15:55:21 +02:00
2021-03-16 13:00:57 +01:00
2021-05-18 09:48:21 +02:00
2021-05-18 11:27:06 +02:00
2021-03-16 13:00:57 +01:00
2021-03-16 13:00:57 +01:00
2021-03-16 13:00:57 +01:00
2021-04-06 07:34:04 +02:00

DAFA-web

The project was generated using Nx.

Quick Start & Documentation

For all commands we will refer to the npm scripts located inside package.json. When using these commands, you do not need to have @angular/cli installed globally on your computer.

To get started, clone the repository and run npm install in the root of the project, this will install all dependencies.

Development server DAFA-web

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

Dotnet API

Run npm run start:api to run against the Dotnet API.

Generate an application

Run npm run new-app my-app to generate an application. When using Nx, you can create multiple applications and libraries in the same workspace.

Generate a library

Run npm run new-lib my-lib to generate a library. Libraries are shareable across libraries and applications. They can be imported from @dafa-web-monorepo/mylib.

Code scaffolding

Run npm run new-component my-component --project=my-app to generate a new component.

Build DAFA-web

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

Dotnet API

Run npm run build:api to build the project using the Dotnet API.

Running unit tests on DAFA-web

Run npm run test to execute the unit tests via Jest.

Run npm run nx affected:test to execute the unit tests affected by a change.

Running end-to-end tests on DAFA-web

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

Run npm run nx affected:e2e to execute the end-to-end tests affected by a change.

Understand your workspace

Run npm run nx dep-graph to see a diagram of the dependencies of your projects.

Git workflow

  • Use branching model Gitflow.

    • Example: feature/TV-XXXX or bugfix/TV-XXXX
    • A useful CLI helper tool can be used: gitflow-avh.
  • Clone origin, create feature/bugfix branches and push back to origin.

  • Don't forget to commit and push your changes regulary!

  • Create a pull request for each feature branch.

  • When merging the pull request, follow conventional commits structure inside the merge message.

    • The merge-message, which follows conventional commits, will be added to the CHANGELOG after a release is made.

    • A commit message could look like this: feat(startpage): Added headings and description to the startpage (TV-1234).

    • The changelog would look something like this:

      ### Features
      
      - **startpage:** Added headings and description to the startpage ([TV-1234](https://jira.arbetsformedlingen.se/browse/TV-1234)) ([commit-hash](https://bitbucket.arbetsformedlingen.se/projects/tea/repos/dafa-web-monorepo/commits/commit-hash))
      
  • Upon merge, Open Shift will deploy the application to AUTO and TEST.

Release and deploy

We use a semi-automated release and deploy to different test-enviroments. A release script is used in combination with semantic-release to add the correct version of the application and changes to the changelog. The deployments are made depending on which branches are updated:

  • develop is automatically deployed to AUTO and TEST.
  • next is automatically deployed to SYS.
  • main is automatically deployed to ACC. After this is completed, a question needs to be answered whether the image should be deployed to PROD.

Deploy to SYS

To deploy the application to SYS you need to create a release. Make sure you are in the develop branch and are up-to-date with origin. Then run npm run release. This will:

  • Update the CHANGELOG.md and copies the CHANGELOG to assets.
  • Bump the applications version according to semantic versioning.
  • Commits the CHANGELOG to develop and pushes it to origin.
  • Merge develop into next and pushes next to origin.

Open Shift will deploy the application to SYS.

Release to ACC and PROD

To release the latest version of next to ACC and eventually to PROD; a pull request should be created to merge next into main. The next branch is protected and will not be deleted upon merge.

Open Shift will deploy the application to ACC and a question inside the pipeline is asked if the application also should be deployed to PROD. This question will persist for 24 hours.

General Nx documentation

Nx Documentation

10-minute video showing all Nx features

Interactive Tutorial

Description
No description provided
Readme 3.8 MiB
Languages
TypeScript 64.6%
HTML 18.9%
JavaScript 8.9%
SCSS 6.3%
Groovy 0.8%
Other 0.5%