-
Notifications
You must be signed in to change notification settings - Fork 290
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(clerk-js,shared,types): Remove invalid email addresses from inpu…
…t for Organization Invitation (#1869) In invite members screen of the <OrganizationProfile /> component, consume any invalid email addresses as they are returned in the API error and remove them from the input automatically.
- Loading branch information
1 parent
9b644d7
commit a46d6fe
Showing
6 changed files
with
80 additions
and
6 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 |
---|---|---|
@@ -0,0 +1,7 @@ | ||
--- | ||
'@clerk/clerk-js': patch | ||
'@clerk/shared': patch | ||
'@clerk/types': patch | ||
--- | ||
|
||
In invite members screen of the <OrganizationProfile /> component, consume any invalid email addresses as they are returned in the API error and remove them from the input automatically. |
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 |
---|---|---|
|
@@ -133,6 +133,65 @@ describe('InviteMembersPage', () => { | |
).toBeInTheDocument(), | ||
); | ||
}); | ||
|
||
it('removes duplicate emails from input after error', async () => { | ||
const { wrapper, fixtures } = await createFixtures(f => { | ||
f.withOrganizations(); | ||
f.withUser({ | ||
email_addresses: ['[email protected]'], | ||
organization_memberships: [{ name: 'Org1', role: 'admin' }], | ||
}); | ||
}); | ||
|
||
fixtures.clerk.organization?.inviteMembers.mockRejectedValueOnce( | ||
new ClerkAPIResponseError('Error', { | ||
data: [ | ||
{ | ||
code: 'duplicate_record', | ||
long_message: | ||
'There are already pending invitations for the following email addresses: [email protected]', | ||
message: 'duplicate invitation', | ||
meta: { email_addresses: ['[email protected]'] }, | ||
}, | ||
], | ||
status: 400, | ||
}), | ||
); | ||
const { getByRole, userEvent, getByTestId } = render(<InviteMembersPage />, { wrapper }); | ||
await userEvent.type(getByTestId('tag-input'), '[email protected]'); | ||
await userEvent.click(getByRole('button', { name: 'Send invitations' })); | ||
|
||
expect(getByTestId('tag-input')).not.toHaveValue(); | ||
}); | ||
|
||
it('removes blocked/not allowed emails from input after error', async () => { | ||
const { wrapper, fixtures } = await createFixtures(f => { | ||
f.withOrganizations(); | ||
f.withUser({ | ||
email_addresses: ['[email protected]'], | ||
organization_memberships: [{ name: 'Org1', role: 'admin' }], | ||
}); | ||
}); | ||
|
||
fixtures.clerk.organization?.inviteMembers.mockRejectedValueOnce( | ||
new ClerkAPIResponseError('Error', { | ||
data: [ | ||
{ | ||
code: 'not_allowed_access', | ||
long_message: '[email protected] is not allowed to access this application.', | ||
message: 'Access not allowed.', | ||
meta: { identifiers: ['[email protected]'] }, | ||
}, | ||
], | ||
status: 403, | ||
}), | ||
); | ||
const { getByRole, userEvent, getByTestId } = render(<InviteMembersPage />, { wrapper }); | ||
await userEvent.type(getByTestId('tag-input'), '[email protected]'); | ||
await userEvent.click(getByRole('button', { name: 'Send invitations' })); | ||
|
||
expect(getByTestId('tag-input')).not.toHaveValue(); | ||
}); | ||
}); | ||
|
||
describe('Navigation', () => { | ||
|
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