UI Guidelines
Pre-requisites :
One should know how to create single-page React applications
Keep updated with the latest versions and hooks of React.
The strong base on Javascript
ES6 features.
Basic knowledge of Cascading Style Sheet(CSS) & SCSS.
Including media query styles and pseudo-classes
Guidelines and Principles:
Clone the repository - GitHub - egovernments/DIGIT-OSS: eGov Foundation's Open source repository of the DIGIT
Install the dependencies
For Mono-UI DIGIT-OSS/frontend/mono-ui/web/rainmaker at master · egovernments/DIGIT-OSS
sudo apt-get update
sudo apt-get install node.js (version 12)
sudo apt-get install npm
apt install yarn
yarn install
yarn run go
yarn run dev:employee
for Employee Appyarn run dev:citizen
for Citizen App
For Micro-UI DIGIT-OSS/frontend/micro-ui/web/micro-ui-internals at master · egovernments/DIGIT-OSS
sudo apt-get update
sudo apt-get install node.js (version 14)
sudo apt-get install npm
apt install yarn
yarn install
yarn build
yarn start
Git branching and guidelines:
Identify the Jira ticket with the ticket ID.
Create a feature branch with Ticket ID as the branch name. ex: UM-1331 (either from master or develop depending on the above-mentioned use cases).
Commit message format : <Ticket-ID : Ticket-description>
Unit testing performed in the dev environment with the feature branch
New Feature Implementation -
Use the ‘develop‘ branch to implement the latest releases/features.
Merge master to the ‘develop’ branch frequently.
git merge master (code currently pointing to release branch)
Push day-to-day changes or features to the ‘develop’ branch.
git push
Merge the' develop' branch to the master copy and raise the PR to master before every release cycle.
Previous release bugs -
Fix the issues in the feature branch from the latest 'master'.
Raise PR to ‘master’ after dev testing on the feature branch.
Once merged to master, cherry-pick the commit id to the 'develop' branch.
Provide both master and develop branch builds to the QA team.
Do’s and Dont’s while working with EGOV UI
DO’s
Always take a pull before doing any changes.
All the commits should be tagged with Jira Tickets - ID and description.
Frequently keep develop branch up-to-date with the master branch.
Resolve any conflicts before pushing to the origin/branch.
Once any feature/issue is fixed, the unit test must be done in the feature branch locally and then in the dev environment as a dev sign-off step.
Make sure while giving builds to the QA team, the corresponding Ticket ID is marked “DONE“.
Delete all the unused branches on a frequent basis.
Have a look at the Security guidelines Security Guidelines Handbook
DONT’s
Do not give random branch names and random commit messages.
Do not push the commits without resolving conflicts.
Do not just test locally without testing in the dev environment and give dev sign-off.
Do not move the ticket status to “DONE” unless it's tested in dev and builds are shared.
Do not merge code to master or develop branches without reviewing the code.
Do not push the changes unless the branch you working on is up-to-date with the remote branch.
Do not copy any codebase of any module and junk the folder with unused codes.
Localization Naming Convention:
Always use only localization codes, don't hard code direct messages in the code.
if any hardcoded messages then they won’t be translated into the user-selected language
Use the t() function to translate the code to the Localised message.
The Localisation code should not contain space and be lowercase.
Localization Search call based on Module wise
curl --location --request POST 'https://dev.digit.org/localization/messages/v1/_search?locale=en_IN&tenantId=pb&module=rainmaker-bnd' \ --header 'Content-Type: application/json' \ --data-raw '{ "RequestInfo": { "apiId" : "emp", "ver" : "1.0", "ts" : "10-03-2017 00:00:00", "action" : "create", "did" : "1", "key" : "abcdkey", "msgId" : "20170310130900", "requesterId" : "rajesh", "authToken" : "06afae01-c9d8-49b3-8f75-f10ba5a4ee62", "userInfo" : { "id" : 1 } }, "tenantId" : "pb" }'
Troubleshooting:
Troubleshoot using Browser network Tab