diff --git a/frontend/src/components/layout/Navbar.vue b/frontend/src/components/layout/Navbar.vue index aed18ad92..86cc8f9cb 100644 --- a/frontend/src/components/layout/Navbar.vue +++ b/frontend/src/components/layout/Navbar.vue @@ -64,6 +64,7 @@ onMounted(() => { }, { label: 'User Management', + route: RouteName.USER_MANAGEMENT, access: Permissions.NAVIGATION_HOUSING_USER_MANAGEMENT }, { diff --git a/frontend/src/components/user/UserCreateModal.vue b/frontend/src/components/user/UserCreateModal.vue new file mode 100644 index 000000000..908de8029 --- /dev/null +++ b/frontend/src/components/user/UserCreateModal.vue @@ -0,0 +1,154 @@ + + + diff --git a/frontend/src/components/user/UserManageModal.vue b/frontend/src/components/user/UserManageModal.vue new file mode 100644 index 000000000..04bb57fba --- /dev/null +++ b/frontend/src/components/user/UserManageModal.vue @@ -0,0 +1,109 @@ + + + diff --git a/frontend/src/components/user/UserTable.vue b/frontend/src/components/user/UserTable.vue new file mode 100644 index 000000000..32bc2c6e2 --- /dev/null +++ b/frontend/src/components/user/UserTable.vue @@ -0,0 +1,138 @@ + + + diff --git a/frontend/src/router/index.ts b/frontend/src/router/index.ts index d2594fee8..f712249b0 100644 --- a/frontend/src/router/index.ts +++ b/frontend/src/router/index.ts @@ -138,6 +138,11 @@ const routes: Array = [ } ] }, + { + path: '/user', + name: RouteName.USER_MANAGEMENT, + component: () => import('@/views/user/UserManagementView.vue') + }, { path: '/:pathMatch(.*)*', name: RouteName.NOT_FOUND, diff --git a/frontend/src/services/permissionService.ts b/frontend/src/services/permissionService.ts index de6fc369f..6b098fb93 100644 --- a/frontend/src/services/permissionService.ts +++ b/frontend/src/services/permissionService.ts @@ -25,6 +25,7 @@ export enum Permissions { NAVIGATION_HOUSING_SUBMISSIONS = 'housing.submissions', NAVIGATION_HOUSING_SUBMISSIONS_SUB = 'housing.submissions.sub', NAVIGATION_HOUSING_USER_MANAGEMENT = 'housing.usermanagement', + NAVIGATION_HOUSING_USER_MANAGEMENT_ADMIN = 'housing.usermanagementadmin', NAVIGATION_DEVELOPER = 'developer', TESTING_ROLE_OVERRIDE = 'testing.role.override' @@ -41,7 +42,8 @@ const PermissionMap = [ Permissions.NAVIGATION_HOUSING_ENQUIRY, Permissions.NAVIGATION_HOUSING_SUBMISSION, Permissions.NAVIGATION_HOUSING_SUBMISSIONS, - Permissions.NAVIGATION_HOUSING_USER_MANAGEMENT + Permissions.NAVIGATION_HOUSING_USER_MANAGEMENT, + Permissions.NAVIGATION_HOUSING_USER_MANAGEMENT_ADMIN ] }, { diff --git a/frontend/src/types/User.ts b/frontend/src/types/User.ts index c57fc3720..48d0bdad0 100644 --- a/frontend/src/types/User.ts +++ b/frontend/src/types/User.ts @@ -8,6 +8,8 @@ export type User = { identityId: string | null; idp: string; lastName: string; + role?: string; + status?: string; userId: string; username: string; elevatedRights: boolean; diff --git a/frontend/src/utils/constants/application.ts b/frontend/src/utils/constants/application.ts index 09e739329..14469a104 100644 --- a/frontend/src/utils/constants/application.ts +++ b/frontend/src/utils/constants/application.ts @@ -3,7 +3,7 @@ */ import { NIL } from 'uuid'; -import { AccessRole, BasicResponse } from '../enums/application'; +import { AccessRole, BasicResponse, Roles } from '../enums/application'; export const ACCESS_ROLES_LIST = [ AccessRole.PCNS_ADMIN, @@ -20,6 +20,8 @@ export const PCNS_CONTACT = { subject: 'Reporting an Issue with PCNS' }; +export const ROLES = [Roles.NAVIGATOR, Roles.READ_ONLY]; + export const SYSTEM_USER = NIL; export const YES_NO_LIST = [BasicResponse.YES, BasicResponse.NO]; diff --git a/frontend/src/utils/enums/application.ts b/frontend/src/utils/enums/application.ts index 8f01cca91..d0cac3198 100644 --- a/frontend/src/utils/enums/application.ts +++ b/frontend/src/utils/enums/application.ts @@ -52,7 +52,14 @@ export enum RouteName { OIDC_CALLBACK = 'oidc_callback', OIDC_LOGIN = 'oidc_login', - OIDC_LOGOUT = 'oidc_logout' + OIDC_LOGOUT = 'oidc_logout', + + USER_MANAGEMENT = 'user_management' +} + +export enum Roles { + NAVIGATOR = 'Navigator', + READ_ONLY = 'Read-only' } export enum StorageKey { diff --git a/frontend/src/views/user/UserManagementView.vue b/frontend/src/views/user/UserManagementView.vue new file mode 100644 index 000000000..5488772e2 --- /dev/null +++ b/frontend/src/views/user/UserManagementView.vue @@ -0,0 +1,222 @@ + + + +