A note on backends
As you probably know by now, Hajk consists of three separate applications: Client, Admin and Backend. If this concept is new to you, please see the description here.
Prior to 2021, Backend was a .NET project. In the spring of 2021, the Hajk NodeJS backend became available, finally making Hajk an OS-independent webGIS solution. At the time of writing (mid 2021), some features are exclusively available in the NodeJS backend, but otherwise the both backends have similar functionality and API.
- Latest LTS of NodeJS
- Latest Git
- Visual Studio 2019 (for the .NET backend)
The Client (new-client
), Admin (new-admin
) and NodeJS backend (new-backend
) applications can be built and deployed on any OS supported by recent Git and Node versions (tested on macOS, Windows and Linux).
The .NET backend (backend
) component, requires Visual Studio 2019 for Windows.
Please note that if you plan on working on the obsolete Hajk 2 branch, you must use Visual Studio 2015 instead.
End-user documentation can be found in Hajk's Wiki. Writing user documentation is a very important way of contributing to the project and suits well for organizations that wish to contribute but lack coding capabilities.
Hajk is built using Material Design components from the Material UI project. Make sure to familiarize yourself with all the available components. It is crucial for the user experience that the design principles are followed throughout the system.
Hajk strictly enforces the use of Git Feature Branch Workflow as described in this document.
Create an issue on GitHub. You will need the issue number to give your branch a good name in the steps that follow.
In short, developing a new feature, would look something like:
- Always fetch latest with
git fetch
. - Make sure you are in the develop branch by
git checkout develop
. - Make sure that you've pulled all latest changes with
git pull
. - Create a new branch and give it a name that relates to the issue you created on GitHub. E.g. if you created an issue called "Add a blue button" and it has issue number #1234, your branch should be called
feature/1234-blue-button
. You create this branch by runninggit checkout -b feature/1234-blue-button
- Don't forget to set upstream so that your newly created branch is pushed to GitHub:
git push --set-upstream origin feature/1234-blue-button
- Code…
- Regularly commit changes to your branch with
git commit -S -m "A good comment, can be multiline."
. (Note, the-S
flag signs your commit, and signing commits is something you really should be doing.) - Regularly push your changes to GitHub with
git push
- Regularly merge changes from develop into your branch. That means that you will incorporate recent changes in develop and your local branch will stay up-to-date with latest developments. This is the really important part. You can do it like this:
git checkout develop && git fetch && git pull && git checkout feature/1234-blue-button && git merge develop
- When you're done coding, go to GitHub and create a new pull request. Make sure that you want to merge your branch into
develop
. - Administrators overlooking the project will get notified when you create your PR, take a look at the code and if everything looks fine merge it into
develop
and delete your feature branch from GitHub. You will still have a copy of your feature branch locally, but it can be safely removed by runninggit branch -d feature/1234-blue-button
.
Hajk uses ESLint and Prettier to enforce code formatting across the project.
🔥 Code that gets checked in must follow those rules. 🔥
The new-client
directory contains .eslint
file, so it's easy to follow the rules. The recommended way is to use an editor that has extensions for ESLint and Prettier. It is also highly recommended to make the editor run Prettier on each file save (i.e. in VSCode it can be controlled by the formatOnSave: true
flag).
For a simple guide on setting up VSCode with ESLint, Prettier and some , see this presentation. (Swedish only)
It is also super easy to get Prettier running with almost any editor. Please refer to the docs.