description |
---|
Screen to update muster roll status based on different roles |
Objective: To view and modify the attendance days and perform various actions like verify, reject and approve based on roles.
Users can navigate to this screen by clicking on the muster roll id on the inbox page.
View Attendance Screen
Initially, the muster has 'Submitted' status. Junior Engineer can view, Edit, Verify and Reject the Attendance.
-
Verify: Clicking on the ‘Verify’ action button verifies the existing muster and the user is redirected to the success page
-
Edit: Clicking on the ‘Edit’ action button displays the extra details in the table. The working days can be edited. Based on that ‘Modified Amount’ is updated dynamically.
View Attendance in Edit mode
As soon as the user updates anything ‘Action’ button changes to the ‘Save’ button. On click of Save, muster is verified with updated details and the user is redirected to the success page.
Attendance Verified Success Screen
-
Reject: Clicking on the ‘Reject’ action displays a popup where the user can provide any comments and reject the muster.
Attendance Reject Modal
On 'Confirm Reject', muster will be rejected and the user will be redirected to the success page.
Attendance Rejected Success Screen
The municipal Engineer can view, Approve, and Reject the attendance which is verified by Junior Engineer
-
Approve: Clicking on the ‘Approve action displays a popup where the user can provide any comments and approve the muster.
Attendance Approve Modal
On 'Approve Attendance', the muster will be approved and the user will be redirected to the success page.
Attendance Approved Success Screen
-
The municipal Engineer can also reject the attendance verified by Jr Engineer by clicking on the 'Reject' action.
Modify attendance technical implementation where all actions are handled can be found in the below file.
Hooks used
To update muster (modify, verify, reject, approve, resubmit), ‘useUpdateAttendance’ is used which updated muster roll details.
{% embed url="https://github.com/egovernments/DIGIT-Works/blob/develop/frontend/micro-ui/web/micro-ui-internals/packages/libraries/src/hooks/attendance/useUpdateAttendance.js" %}
APIs used
Endpoint:
/muster-roll/v1/_update
Sample curl for Update muster API:
curl --location --request POST 'https://works-dev.digit.org/muster-roll/v1/_update' \
--header 'Content-Type: application/json' \
--data-raw '{
"RequestInfo": {
"apiId": "asset-services",
"ver": null,
"ts": null,
"action": null,
"did": null,
"key": null,
"msgId": "search with from and to values",
"authToken": "6ea7d654-234c-4da6-a43f-8b83a3100593",
"userInfo": {
"id": 172,
"uuid": "5ce80dd3-b1c0-42fd-b8f6-a2be456db31c",
"userName": "8070102021",
"name": "test3",
"mobileNumber": "8070102021",
"emailId": "[email protected]",
"locale": null,
"type": "EMPLOYEE",
"roles": [
{
"code": "JUNIOR_ENGINEER",
"name": "JUNIOR ENGINEER",
"tenantId": "pb.amritsar"
}
]
}
},
"musterRoll": {
"tenantId": "pb.amritsar",
"id":"856eb55f-48c7-4439-a046-0d53ed3a99f1"
},
"workflow": {
"action": "VERIFY",
"comments": "Verify muster roll",
"assignees": []
}
}'
Wage seeker skills data is fetched from MDMS using 'getMultipleTypesWithFilter' service.
const getWageSeekerSkills = async () => {
const skills = {}
const response = await Digit.MDMSService.getMultipleTypesWithFilter(Digit.ULBService.getStateId(), "common-masters", [{"name": "WageSeekerSkills"}])
response?.['common-masters']?.WageSeekerSkills.forEach(item => (skills[item.code] = item))
return skills
}
Localisation keys are added under the ‘rainmaker-attendencemgmt’ locale module. In future, if any new labels are implemented in the attendance module they should also be pushed in the locale DB under rainmaker-attendencemgmt locale module. Below is an example of a few locale labels for Hindi and English.
{
"code": "ATM_ACTUAL_WORKING_DAYS",
"message": "वास्तविक कार्य दिवस",
"module": "rainmaker-attendencemgmt",
"locale": "hi_IN"
}
{
"code": "ATM_ACTUAL_WORKING_DAYS",
"message": "Actual Working Days",
"module": "rainmaker-attendencemgmt",
"locale": "en_IN"
}
The content on this screen is rendered based on the configuration passed on ApplicationDetails template component. Its implementation can be found in the below file.
{% embed url="https://github.com/egovernments/DIGIT-Works/blob/develop/frontend/micro-ui/web/micro-ui-internals/packages/modules/templates/ApplicationDetails/index.js" %}
API | Role Code | Action Id | Actions |
---|---|---|---|
/muster-roll/v1/_update | JUNIOR_ENGINEER | 38 |
|
/muster-roll/v1/_update | MUNICIPAL_ENGINEER | 38 |
|