-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
added page to manage user access (#137)
* added page to manage user access * addressed feedback * removed ADMIN from manage user access dropdown * removed unnecessary placeholder property * fixed bugs after merge * fixed errors * fixed more errors * addressed feedback * Fix compatibility --------- Co-authored-by: Alex Zhang <[email protected]> Co-authored-by: Alex Zhang <[email protected]>
- Loading branch information
1 parent
1937b7e
commit 824f846
Showing
7 changed files
with
146 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,7 +2,7 @@ | |
align-items: center; | ||
display: flex; | ||
flex-direction: column; | ||
|
||
text-align: center; | ||
|
||
.pfp { | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import { config } from '@/lib'; | ||
import type { ModifyUserAccessLevelResponse, PrivateProfile } from '@/lib/types/apiResponses'; | ||
import axios from 'axios'; | ||
|
||
/** | ||
* Update current user's access level | ||
* @param token Authorization bearer token | ||
* @param user Email of the user whose access is being updated | ||
* @param accessType The user's updated access type | ||
* @returns The updated user profile | ||
*/ | ||
export const manageUserAccess = async ( | ||
token: string, | ||
user: string, | ||
accessType: string | ||
): Promise<PrivateProfile[]> => { | ||
const accessUpdates = [{ user: user, accessType: accessType }]; | ||
|
||
const requestUrl = `${config.api.baseUrl}${config.api.endpoints.admin.access}`; | ||
|
||
const response = await axios.patch<ModifyUserAccessLevelResponse>( | ||
requestUrl, | ||
{ accessUpdates: accessUpdates }, | ||
{ | ||
headers: { | ||
Authorization: `Bearer ${token}`, | ||
}, | ||
} | ||
); | ||
|
||
return response.data.updatedUsers; | ||
}; | ||
|
||
export default manageUserAccess; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
import { AdminAPI } from '@/lib/api'; | ||
import { CookieService } from '@/lib/services'; | ||
import { APIHandlerProps } from '@/lib/types'; | ||
import { UserAccessUpdates } from '@/lib/types/apiRequests'; | ||
import { PrivateProfile } from '@/lib/types/apiResponses'; | ||
import { CookieType } from '@/lib/types/enums'; | ||
|
||
const manageUserAccess = async (data: UserAccessUpdates & APIHandlerProps<PrivateProfile[]>) => { | ||
const { user, accessType, onSuccessCallback, onFailCallback } = data; | ||
|
||
try { | ||
const token = CookieService.getClientCookie(CookieType.ACCESS_TOKEN); | ||
const updatedUsers = await AdminAPI.manageUserAccess(token, user, accessType); | ||
onSuccessCallback?.(updatedUsers); | ||
} catch (e: any) { | ||
onFailCallback?.(e); | ||
} | ||
}; | ||
|
||
export default manageUserAccess; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
import { | ||
VerticalForm, | ||
VerticalFormButton, | ||
VerticalFormItem, | ||
VerticalFormTitle, | ||
} from '@/components/common'; | ||
import { showToast } from '@/lib'; | ||
import withAccessType from '@/lib/hoc/withAccessType'; | ||
import manageUserAccess from '@/lib/managers/AdminUserManager'; | ||
import { PermissionService, ValidationService } from '@/lib/services'; | ||
import { UserAccessUpdates } from '@/lib/types/apiRequests'; | ||
import { UserAccessType } from '@/lib/types/enums'; | ||
import { reportError } from '@/lib/utils'; | ||
import { GetServerSideProps } from 'next'; | ||
import { SubmitHandler, useForm } from 'react-hook-form'; | ||
import { AiOutlineMail } from 'react-icons/ai'; | ||
import { BsPerson } from 'react-icons/bs'; | ||
|
||
const ManageUserAccessPage = () => { | ||
const { | ||
register, | ||
handleSubmit, | ||
formState: { errors }, | ||
} = useForm<UserAccessUpdates>(); | ||
|
||
const onSubmit: SubmitHandler<UserAccessUpdates> = async ({ user, accessType }) => { | ||
manageUserAccess({ | ||
user, | ||
accessType, | ||
onSuccessCallback: updatedUsers => { | ||
showToast(`User access type updated for user ${updatedUsers[0]?.email}!`); | ||
}, | ||
onFailCallback: error => { | ||
reportError('Failed to update user access type', error); | ||
}, | ||
}); | ||
}; | ||
|
||
return ( | ||
<VerticalForm onEnterPress={handleSubmit(onSubmit)}> | ||
<VerticalFormTitle text="Manage User Access" /> | ||
<VerticalFormItem | ||
icon={<AiOutlineMail />} | ||
element="input" | ||
name="user" | ||
type="email" | ||
placeholder="Email ([email protected])" | ||
formRegister={register('user', { | ||
validate: email => { | ||
const validation = ValidationService.isValidEmail(email); | ||
return validation.valid || validation.error; | ||
}, | ||
})} | ||
error={errors.user} | ||
/> | ||
<VerticalFormItem | ||
icon={<BsPerson />} | ||
element="select" | ||
name="User Access" | ||
options={Object.values(UserAccessType).filter(option => option !== 'ADMIN')} | ||
formRegister={register('accessType')} | ||
error={errors.user} | ||
placeholder="" | ||
/> | ||
<VerticalFormButton | ||
type="button" | ||
display="button1" | ||
text="Submit" | ||
onClick={handleSubmit(onSubmit)} | ||
/> | ||
</VerticalForm> | ||
); | ||
}; | ||
|
||
export default ManageUserAccessPage; | ||
|
||
const getServerSidePropsFunc: GetServerSideProps = async () => ({ | ||
props: {}, | ||
}); | ||
|
||
export const getServerSideProps = withAccessType( | ||
getServerSidePropsFunc, | ||
PermissionService.canViewAdminPage | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters