-
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.
- Loading branch information
1 parent
3b0f64e
commit 8db8449
Showing
8 changed files
with
146 additions
and
8 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
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,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 | ||
*/ | ||
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
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,99 @@ | ||
import { SignInButton, SignInFormItem, SignInTitle } from '@/components/auth'; | ||
import { VerticalForm } from '@/components/common'; | ||
import { config, showToast } from '@/lib'; | ||
import manageUserAccess from '@/lib/api/UserAccessAPI'; | ||
import withAccessType from '@/lib/hoc/withAccessType'; | ||
import { CookieService, PermissionService, ValidationService } from '@/lib/services'; | ||
import { UserAccessUpdates } from '@/lib/types/apiRequests'; | ||
import { CookieType } from '@/lib/types/enums'; | ||
import { getMessagesFromError } from '@/lib/utils'; | ||
import { AxiosError } from 'axios'; | ||
import { GetServerSideProps } from 'next'; | ||
import { SubmitHandler, useForm } from 'react-hook-form'; | ||
import { AiOutlineMail } from 'react-icons/ai'; | ||
import { BsPerson } from 'react-icons/bs'; | ||
|
||
function reportError(title: string, error: unknown) { | ||
if (error instanceof AxiosError && error.response?.data?.error) { | ||
showToast(title, getMessagesFromError(error.response.data.error).join('\n\n')); | ||
} else if (error instanceof Error) { | ||
showToast(title, error.message); | ||
} else { | ||
showToast(title, 'Unknown error'); | ||
} | ||
} | ||
|
||
const ManageUserAccessPage = () => { | ||
const { | ||
register, | ||
handleSubmit, | ||
formState: { errors }, | ||
} = useForm<UserAccessUpdates>(); | ||
|
||
const onSubmit: SubmitHandler<UserAccessUpdates> = async ({ user, accessType }) => { | ||
try { | ||
const token = CookieService.getClientCookie(CookieType.ACCESS_TOKEN); | ||
const updatedUsers = await manageUserAccess(token, user, accessType); | ||
if (updatedUsers && updatedUsers.length > 0 && updatedUsers[0]?.email) { | ||
showToast(`User access type updated for user ${updatedUsers[0].email}!`); | ||
} | ||
} catch (error) { | ||
reportError('Failed to update user access type', error); | ||
} | ||
}; | ||
|
||
return ( | ||
<VerticalForm onEnterPress={handleSubmit(onSubmit)}> | ||
<SignInTitle text="Manage User Access" /> | ||
<SignInFormItem | ||
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} | ||
/> | ||
<SignInFormItem | ||
icon={<BsPerson />} | ||
element="select" | ||
name="user access" | ||
options={[ | ||
'RESTRICTED', | ||
'STANDARD', | ||
'STAFF', | ||
'ADMIN', | ||
'MARKETING', | ||
'MERCH_STORE_MANAGER', | ||
'MERCH_STORE_DISTRIBUTOR', | ||
]} | ||
placeholder="User access" | ||
formRegister={register('accessType')} | ||
error={errors.user} | ||
/> | ||
<SignInButton | ||
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, | ||
config.homeRoute | ||
); |