This repository should be used as the starting point for every frontend-related project that gets build for the government of Flanders. This project is built using Nuxt 3.x and Vue 3.x. Ever since these newer versions of these libraries got released, the government of Flanders also released a third version of their webcomponents which works with these newer versions. The needed configuration has already been set up, so that you can start using these components immediately. The libraries are
"@govflanders/vl-ui-design-system-style"
"@govflanders/vl-ui-design-system-vue3"
Documentation about these webcomponents can be found in Storybook page. If the link does not work anymore, feel free to contact someone from the development team via their Slack channel #design-system-vue3-alpha
.
# install dependencies
$ yarn install
# serve with hot reload at localhost:3000
$ yarn run dev
# build for production and launch server
$ yarn run build
For detailed explanation on how things work, check out the documentation
You can create the following extra directories, some of which have special behaviors. Only pages
is required; you can delete them if you don't want to use their functionality.
The assets directory contains your uncompiled assets such as Stylus or Sass files, images, or fonts.
More information about the usage of this directory in the documentation.
The components directory contains your Vue.js components. Components make up the different parts of your page and can be reused and imported into your pages, layouts and even other components.
The composables directory contains reusable helper functions that can be reused in your components or pages.
The content directory serves as the file-based CMS of the whole project. We use a library called nuxt/content
that allows us to import all the content of our website into components/pages across the project.
More information about the usage of this directory in the documentation.
Layouts are a great help when you want to change the look and feel of your Nuxt app, whether you want to include a sidebar or have distinct layouts for mobile and desktop.
More information about the usage of this directory in the documentation.
This directory contains your application views and routes. Nuxt will read all the *.vue
files inside this directory and setup Vue Router automatically.
More information about the usage of this directory in the documentation.
The plugins directory contains JavaScript plugins that you want to run before instantiating the root Vue.js Application. This is the place to add Vue plugins and to inject functions or constants. Every time you need to use Vue.use()
, you should create a file in plugins/
and add its path to plugins in nuxt.config.ts
.
More information about the usage of this directory in the documentation.
The middleware directory contains your application middleware. Middleware lets you define custom functions that can be run before rendering a page. This is a great place to add locale detection, authentication, or any other logic you want to run before a page is rendered.
More information about the usage of this directory in the documentation.
The css directory contains your custom imported css or Sass files. We use this to import the custom styling from the @govflanders/vl-ui-design-system-style
library. you should create a file in css/
and add its path to css in nuxt.config.ts
.
Custom directory that contains our customly defined typescript config files. Can be used shorthandedly in your code:
import type { NavigationMenu } from '~/types/navigationMenu'
This file serves as a config file, specifically for npm. We use this file to store our required tokens for the private npm repositoires such as @govflanders/vl-ui-design-system-style
and @govflanders/vl-ui-design-system-vue3
. More information about this file can be found in the documentation.
In this file, we mention a secret authentication token.
registry.npmjs.org/:_authToken=${NPM_TOKEN}
This is a secret token that needs to exist in your own session. If you try installing the dependencies without this token present, it will not work. You can set a token using the command below, where NPM_TOKEN
contains the actual token. For more information, please read this stackoverflow issue.
export NPM_TOKEN="${NPM_TOKEN}"
This file serves as a secret file to contain all our API-keys, tokens,... that we don't want to expose to the outside world. This file should never be added inside the repository for security purposes. In the .env.example
file, you can see which tokens and API-keys are required to run this project. Place the actual values inside the .env
folder on your local device.
Since Vue 3.x
, nuxt uses Vite as its preferred bundler over Webpack. This means that environment variables are passed in a different manner from the backend to the frontend. You can access the environment variables by using
import.meta.env.VITE_ENVIRONMENT
Only variables using the
VITE_
prefix are passed to the frontend. Never pass secret variables, such as API-tokens to the frontend as these will be up for grabs
For code formatting purposes, we use a tool called Prettier. Prettier is a handy tool that can be used to streamline code-formatting across a development team. In this repository, you can find a specific configuration file for this tool called .prettierrc
which contains our ruleset. This set can be extended based on the project's needs. Don't forget to install Prettier itself in your IDE to get the full effect of this tool.
ESlint is a linting tool that will try and find problems with your JavaScript/TypeScript code as you are writing it. This will help minimize any potential bugs in our production code. For this tool, there is a separate configuration file called eslintrc.ts
that contains the ruleset we want to enforce. This ruleset can be extended with any amount of rules that can be found here. Don't forget to install ESlint itself in your IDE to get the full effect of this tool.
For the deployment the public path must be set to the target path on the target server. Otherwise Reverse proxy configuration is very difficult and multiple webapplications cannot be deployed behind the same reverse proxy.
The Dockerfile.base builds a base image. The Dockerfile.build build the deployment image.
By seperation allows to focus in the first to get an image that contains all dependencies to make a build. The second allows to include minor changes without the need to rebuild all dependencies.
The first image will take between 5 to 30 minutes to create. While the next less than 2 minutes requires. So by this separation, a developer can use the two Docker images to rebuild a new version without the need for a dependency check and repull of the dependencies.
- on the terminal ensure that NPM_TOKEN is set as environment variable
- make build-base
- make build
TODO [ ] Make a configuration that switches between a development build and a production build. (First ensure that the build is production see TODO 1.) [ ] Add a line in the Makefile to extract the package-lock.json file [ ] Document better the build procedure and the necessary steps.
This project supports the use of query parameters. These parameters can be used to filter the content of the page. You can refer to the filter.config.ts
file for the correct keys. The parameters are as follows:
http://localhost:3000/standaarden/?type=TBD
http://localhost:3000/standaarden/?usage=Aanbevolen+(vrijwillig)
http://localhost:3000/standaarden/?category=applicatieprofiel
http://localhost:3000/standaarden/?status=erkende-standaard
The project has a CI/CD pipeline that is triggered by changes to the standaarden JSON inside the https://github.com/Informatievlaanderen/oslo-standaarden repository.
The project is split up in two parts
This is the base image that contains all the dependencies to build the project. This image should be remade when the dependencies change or if new features are developed. You can use the make build-base
command to build this image and the publish-base
to publish it to the docker registry.
This is the image that contains the build of the project. This image should be remade whenever the /content
changes. Each change to the content requires a new build to be made. This build is triggered by the JSON file in the oslo-standaarden repository.
On the server there runs a cronjob inside the docker environment that will poll the docker registry for new images based on the SHA of the image. If a new image is found, it will pull the image and restart the service. This guarantees that the service is always up to date with the latest changes.
There are two important branches in this project: main
and standaarden
. The main
branch is the branch that contains the latest version of the project with just the code and features. There should never be any config files in this branch. The standaarden
branch is the branch that contains the latest version of the project with the latest version of the standaarden JSON and the required config files of each standard.
When you want to add a new feature to the project, you should follow these steps:
- Create a new branch from the
main
branch. This can be done automatically from JIRA or manually. - Develop the feature in this branch.
- When the feature is ready, create a pull request to the
main
branch. - When the pull request is approved, merge the feature into the
main
branch. - Merge the main branch with the
standaarden
branch.