@workos-inc/widgets 1.0.1 → 1.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +65 -0
- package/dist/cjs/api/api-provider.d.ts +26 -0
- package/dist/cjs/api/api-provider.d.ts.map +1 -0
- package/dist/cjs/api/api-provider.js +123 -0
- package/dist/cjs/api/api-provider.js.map +1 -0
- package/dist/cjs/api/constants.d.ts +2 -0
- package/dist/cjs/api/constants.d.ts.map +1 -0
- package/dist/cjs/api/constants.js +5 -0
- package/dist/cjs/api/constants.js.map +1 -0
- package/dist/cjs/api/endpoint.d.ts +957 -0
- package/dist/cjs/api/endpoint.d.ts.map +1 -0
- package/dist/cjs/api/endpoint.js +856 -0
- package/dist/cjs/api/endpoint.js.map +1 -0
- package/dist/cjs/api/errors.d.ts +33 -0
- package/dist/cjs/api/errors.d.ts.map +1 -0
- package/dist/cjs/api/errors.js +40 -0
- package/dist/cjs/api/errors.js.map +1 -0
- package/dist/cjs/api/index.d.ts +3 -0
- package/dist/cjs/api/index.d.ts.map +1 -0
- package/dist/cjs/api/index.js +19 -0
- package/dist/cjs/api/index.js.map +1 -0
- package/dist/cjs/api/utils.d.ts +10 -0
- package/dist/cjs/api/utils.d.ts.map +1 -0
- package/dist/cjs/api/utils.js +42 -0
- package/dist/cjs/api/utils.js.map +1 -0
- package/dist/cjs/api/widgets-api-client.d.ts +21 -0
- package/dist/cjs/api/widgets-api-client.d.ts.map +1 -0
- package/dist/cjs/api/widgets-api-client.js +61 -0
- package/dist/cjs/api/widgets-api-client.js.map +1 -0
- package/dist/cjs/card-list.d.ts +6 -0
- package/dist/cjs/card-list.d.ts.map +1 -0
- package/dist/cjs/card-list.js +13 -0
- package/dist/cjs/card-list.js.map +1 -0
- package/dist/cjs/index.d.ts +3 -0
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +7 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/add-mfa-dialog.d.ts +9 -0
- package/dist/cjs/lib/add-mfa-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/add-mfa-dialog.js +135 -0
- package/dist/cjs/lib/add-mfa-dialog.js.map +1 -0
- package/dist/cjs/lib/api/user.d.ts +13 -57
- package/dist/cjs/lib/api/user.d.ts.map +1 -1
- package/dist/cjs/lib/api/user.js +44 -314
- package/dist/cjs/lib/api/user.js.map +1 -1
- package/dist/cjs/lib/change-password-dialog.d.ts +8 -0
- package/dist/cjs/lib/change-password-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/change-password-dialog.js +97 -0
- package/dist/cjs/lib/change-password-dialog.js.map +1 -0
- package/dist/cjs/lib/copy-button.d.ts +8 -0
- package/dist/cjs/lib/copy-button.d.ts.map +1 -0
- package/dist/cjs/lib/copy-button.js +63 -0
- package/dist/cjs/lib/copy-button.js.map +1 -0
- package/dist/cjs/lib/delete-user-dialog.d.ts +2 -2
- package/dist/cjs/lib/delete-user-dialog.d.ts.map +1 -1
- package/dist/cjs/lib/delete-user-dialog.js +1 -1
- package/dist/cjs/lib/delete-user-dialog.js.map +1 -1
- package/dist/cjs/lib/edit-user-profile-dialog.d.ts +10 -0
- package/dist/cjs/lib/edit-user-profile-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/edit-user-profile-dialog.js +85 -0
- package/dist/cjs/lib/edit-user-profile-dialog.js.map +1 -0
- package/dist/cjs/lib/edit-user-role-dialog.d.ts +12 -0
- package/dist/cjs/lib/edit-user-role-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/{edit-user-details-dialog.js → edit-user-role-dialog.js} +11 -7
- package/dist/cjs/lib/edit-user-role-dialog.js.map +1 -0
- package/dist/cjs/lib/elements.d.ts +1 -0
- package/dist/cjs/lib/elements.d.ts.map +1 -1
- package/dist/cjs/lib/elements.js +10 -4
- package/dist/cjs/lib/elements.js.map +1 -1
- package/dist/cjs/lib/elevated-access.d.ts +8 -0
- package/dist/cjs/lib/elevated-access.d.ts.map +1 -0
- package/dist/cjs/lib/elevated-access.js +130 -0
- package/dist/cjs/lib/elevated-access.js.map +1 -0
- package/dist/cjs/lib/generic-error.d.ts +4 -0
- package/dist/cjs/lib/generic-error.d.ts.map +1 -0
- package/dist/cjs/lib/generic-error.js +57 -0
- package/dist/cjs/lib/generic-error.js.map +1 -0
- package/dist/cjs/lib/icon-panel.d.ts +3 -0
- package/dist/cjs/lib/icon-panel.d.ts.map +1 -0
- package/dist/cjs/lib/icon-panel.js +16 -0
- package/dist/cjs/lib/icon-panel.js.map +1 -0
- package/dist/cjs/lib/icons.d.ts +3 -0
- package/dist/cjs/lib/icons.d.ts.map +1 -0
- package/dist/cjs/lib/icons.js +8 -0
- package/dist/cjs/lib/icons.js.map +1 -0
- package/dist/cjs/lib/invite-user-dialog.d.ts.map +1 -1
- package/dist/cjs/lib/invite-user-dialog.js +7 -5
- package/dist/cjs/lib/invite-user-dialog.js.map +1 -1
- package/dist/cjs/lib/logout-all-sessions-dialog.d.ts +9 -0
- package/dist/cjs/lib/logout-all-sessions-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/logout-all-sessions-dialog.js +52 -0
- package/dist/cjs/lib/logout-all-sessions-dialog.js.map +1 -0
- package/dist/cjs/lib/logout-dialog.d.ts +10 -0
- package/dist/cjs/lib/logout-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/logout-dialog.js +58 -0
- package/dist/cjs/lib/logout-dialog.js.map +1 -0
- package/dist/cjs/lib/marker.d.ts +14 -0
- package/dist/cjs/lib/marker.d.ts.map +1 -0
- package/dist/cjs/lib/marker.js +38 -0
- package/dist/cjs/lib/marker.js.map +1 -0
- package/dist/cjs/lib/oauth-icons.d.ts +4 -0
- package/dist/cjs/lib/oauth-icons.d.ts.map +1 -0
- package/dist/cjs/lib/oauth-icons.js +67 -0
- package/dist/cjs/lib/oauth-icons.js.map +1 -0
- package/dist/cjs/lib/organization-switcher.d.ts +24 -0
- package/dist/cjs/lib/organization-switcher.d.ts.map +1 -0
- package/dist/cjs/lib/organization-switcher.js +35 -0
- package/dist/cjs/lib/organization-switcher.js.map +1 -0
- package/dist/cjs/lib/otp-input.d.ts +20 -0
- package/dist/cjs/lib/otp-input.d.ts.map +1 -0
- package/dist/cjs/lib/otp-input.js +174 -0
- package/dist/cjs/lib/otp-input.js.map +1 -0
- package/dist/cjs/lib/resend-invite-dialog.d.ts +2 -2
- package/dist/cjs/lib/resend-invite-dialog.d.ts.map +1 -1
- package/dist/cjs/lib/resend-invite-dialog.js +1 -1
- package/dist/cjs/lib/resend-invite-dialog.js.map +1 -1
- package/dist/cjs/lib/reset-mfa-dialog.d.ts +9 -0
- package/dist/cjs/lib/reset-mfa-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/reset-mfa-dialog.js +60 -0
- package/dist/cjs/lib/reset-mfa-dialog.js.map +1 -0
- package/dist/cjs/lib/revoke-invite-dialog.d.ts +2 -2
- package/dist/cjs/lib/revoke-invite-dialog.d.ts.map +1 -1
- package/dist/cjs/lib/revoke-invite-dialog.js +1 -1
- package/dist/cjs/lib/revoke-invite-dialog.js.map +1 -1
- package/dist/cjs/lib/save-button.d.ts +11 -0
- package/dist/cjs/lib/save-button.d.ts.map +1 -0
- package/dist/cjs/lib/save-button.js +47 -0
- package/dist/cjs/lib/save-button.js.map +1 -0
- package/dist/cjs/lib/set-password-dialog.d.ts +8 -0
- package/dist/cjs/lib/set-password-dialog.d.ts.map +1 -0
- package/dist/cjs/lib/set-password-dialog.js +80 -0
- package/dist/cjs/lib/set-password-dialog.js.map +1 -0
- package/dist/cjs/lib/use-dialog-close.d.ts +2 -0
- package/dist/cjs/lib/use-dialog-close.d.ts.map +1 -0
- package/dist/cjs/lib/use-dialog-close.js +43 -0
- package/dist/cjs/lib/use-dialog-close.js.map +1 -0
- package/dist/cjs/lib/use-security-settings.d.ts +11 -0
- package/dist/cjs/lib/use-security-settings.d.ts.map +1 -0
- package/dist/cjs/lib/use-security-settings.js +39 -0
- package/dist/cjs/lib/use-security-settings.js.map +1 -0
- package/dist/cjs/lib/user-actions-dropdown.d.ts +2 -2
- package/dist/cjs/lib/user-actions-dropdown.d.ts.map +1 -1
- package/dist/cjs/lib/user-actions-dropdown.js +8 -4
- package/dist/cjs/lib/user-actions-dropdown.js.map +1 -1
- package/dist/cjs/lib/user-profile.d.ts +11 -0
- package/dist/cjs/lib/user-profile.d.ts.map +1 -0
- package/dist/cjs/lib/user-profile.js +36 -0
- package/dist/cjs/lib/user-profile.js.map +1 -0
- package/dist/cjs/lib/user-security.d.ts +11 -0
- package/dist/cjs/lib/user-security.d.ts.map +1 -0
- package/dist/cjs/lib/user-security.js +64 -0
- package/dist/cjs/lib/user-security.js.map +1 -0
- package/dist/cjs/lib/user-sessions.d.ts +12 -0
- package/dist/cjs/lib/user-sessions.d.ts.map +1 -0
- package/dist/cjs/lib/user-sessions.js +72 -0
- package/dist/cjs/lib/user-sessions.js.map +1 -0
- package/dist/cjs/lib/users-filter.d.ts +2 -2
- package/dist/cjs/lib/users-filter.d.ts.map +1 -1
- package/dist/cjs/lib/users-filter.js.map +1 -1
- package/dist/cjs/lib/users-management-context.d.ts +0 -9
- package/dist/cjs/lib/users-management-context.d.ts.map +1 -1
- package/dist/cjs/lib/users-management-context.js +13 -26
- package/dist/cjs/lib/users-management-context.js.map +1 -1
- package/dist/cjs/lib/users-management-state.d.ts +3 -3
- package/dist/cjs/lib/users-management-state.d.ts.map +1 -1
- package/dist/cjs/lib/users-management-state.js.map +1 -1
- package/dist/cjs/lib/users-management.d.ts +3 -4
- package/dist/cjs/lib/users-management.d.ts.map +1 -1
- package/dist/cjs/lib/users-management.js +8 -26
- package/dist/cjs/lib/users-management.js.map +1 -1
- package/dist/cjs/lib/utils.d.ts +10 -2
- package/dist/cjs/lib/utils.d.ts.map +1 -1
- package/dist/cjs/lib/utils.js +18 -0
- package/dist/cjs/lib/utils.js.map +1 -1
- package/dist/cjs/organization-switcher.client.d.ts +8 -0
- package/dist/cjs/organization-switcher.client.d.ts.map +1 -0
- package/dist/cjs/organization-switcher.client.js +37 -0
- package/dist/cjs/organization-switcher.client.js.map +1 -0
- package/dist/cjs/user-profile.client.d.ts +7 -0
- package/dist/cjs/user-profile.client.d.ts.map +1 -0
- package/dist/cjs/user-profile.client.js +31 -0
- package/dist/cjs/user-profile.client.js.map +1 -0
- package/dist/cjs/user-security.client.d.ts +7 -0
- package/dist/cjs/user-security.client.d.ts.map +1 -0
- package/dist/cjs/user-security.client.js +27 -0
- package/dist/cjs/user-security.client.js.map +1 -0
- package/dist/cjs/user-sessions.client.d.ts +12 -0
- package/dist/cjs/user-sessions.client.d.ts.map +1 -0
- package/dist/cjs/user-sessions.client.js +48 -0
- package/dist/cjs/user-sessions.client.js.map +1 -0
- package/dist/cjs/users-management.client.d.ts +2 -1
- package/dist/cjs/users-management.client.d.ts.map +1 -1
- package/dist/cjs/users-management.client.js +12 -43
- package/dist/cjs/users-management.client.js.map +1 -1
- package/dist/esm/api/api-provider.d.ts +26 -0
- package/dist/esm/api/api-provider.d.ts.map +1 -0
- package/dist/esm/api/api-provider.js +94 -0
- package/dist/esm/api/api-provider.js.map +1 -0
- package/dist/esm/api/constants.d.ts +2 -0
- package/dist/esm/api/constants.d.ts.map +1 -0
- package/dist/esm/api/constants.js +2 -0
- package/dist/esm/api/constants.js.map +1 -0
- package/dist/esm/api/endpoint.d.ts +957 -0
- package/dist/esm/api/endpoint.d.ts.map +1 -0
- package/dist/esm/api/endpoint.js +774 -0
- package/dist/esm/api/endpoint.js.map +1 -0
- package/dist/esm/api/errors.d.ts +33 -0
- package/dist/esm/api/errors.d.ts.map +1 -0
- package/dist/esm/api/errors.js +34 -0
- package/dist/esm/api/errors.js.map +1 -0
- package/dist/esm/api/index.d.ts +3 -0
- package/dist/esm/api/index.d.ts.map +1 -0
- package/dist/esm/api/index.js +3 -0
- package/dist/esm/api/index.js.map +1 -0
- package/dist/esm/api/utils.d.ts +10 -0
- package/dist/esm/api/utils.d.ts.map +1 -0
- package/dist/esm/api/utils.js +36 -0
- package/dist/esm/api/utils.js.map +1 -0
- package/dist/esm/api/widgets-api-client.d.ts +21 -0
- package/dist/esm/api/widgets-api-client.d.ts.map +1 -0
- package/dist/esm/api/widgets-api-client.js +56 -0
- package/dist/esm/api/widgets-api-client.js.map +1 -0
- package/dist/esm/card-list.d.ts +6 -0
- package/dist/esm/card-list.d.ts.map +1 -0
- package/dist/esm/card-list.js +9 -0
- package/dist/esm/card-list.js.map +1 -0
- package/dist/esm/index.d.ts +3 -0
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/add-mfa-dialog.d.ts +9 -0
- package/dist/esm/lib/add-mfa-dialog.d.ts.map +1 -0
- package/dist/esm/lib/add-mfa-dialog.js +109 -0
- package/dist/esm/lib/add-mfa-dialog.js.map +1 -0
- package/dist/esm/lib/api/user.d.ts +13 -57
- package/dist/esm/lib/api/user.d.ts.map +1 -1
- package/dist/esm/lib/api/user.js +44 -313
- package/dist/esm/lib/api/user.js.map +1 -1
- package/dist/esm/lib/change-password-dialog.d.ts +8 -0
- package/dist/esm/lib/change-password-dialog.d.ts.map +1 -0
- package/dist/esm/lib/change-password-dialog.js +71 -0
- package/dist/esm/lib/change-password-dialog.js.map +1 -0
- package/dist/esm/lib/copy-button.d.ts +8 -0
- package/dist/esm/lib/copy-button.d.ts.map +1 -0
- package/dist/esm/lib/copy-button.js +37 -0
- package/dist/esm/lib/copy-button.js.map +1 -0
- package/dist/esm/lib/delete-user-dialog.d.ts +2 -2
- package/dist/esm/lib/delete-user-dialog.d.ts.map +1 -1
- package/dist/esm/lib/delete-user-dialog.js +1 -1
- package/dist/esm/lib/delete-user-dialog.js.map +1 -1
- package/dist/esm/lib/edit-user-profile-dialog.d.ts +10 -0
- package/dist/esm/lib/edit-user-profile-dialog.d.ts.map +1 -0
- package/dist/esm/lib/edit-user-profile-dialog.js +59 -0
- package/dist/esm/lib/edit-user-profile-dialog.js.map +1 -0
- package/dist/esm/lib/edit-user-role-dialog.d.ts +12 -0
- package/dist/esm/lib/edit-user-role-dialog.d.ts.map +1 -0
- package/dist/esm/lib/{edit-user-details-dialog.js → edit-user-role-dialog.js} +10 -6
- package/dist/esm/lib/edit-user-role-dialog.js.map +1 -0
- package/dist/esm/lib/elements.d.ts +1 -0
- package/dist/esm/lib/elements.d.ts.map +1 -1
- package/dist/esm/lib/elements.js +9 -3
- package/dist/esm/lib/elements.js.map +1 -1
- package/dist/esm/lib/elevated-access.d.ts +8 -0
- package/dist/esm/lib/elevated-access.d.ts.map +1 -0
- package/dist/esm/lib/elevated-access.js +104 -0
- package/dist/esm/lib/elevated-access.js.map +1 -0
- package/dist/esm/lib/generic-error.d.ts +4 -0
- package/dist/esm/lib/generic-error.d.ts.map +1 -0
- package/dist/esm/lib/generic-error.js +31 -0
- package/dist/esm/lib/generic-error.js.map +1 -0
- package/dist/esm/lib/icon-panel.d.ts +3 -0
- package/dist/esm/lib/icon-panel.d.ts.map +1 -0
- package/dist/esm/lib/icon-panel.js +13 -0
- package/dist/esm/lib/icon-panel.js.map +1 -0
- package/dist/esm/lib/icons.d.ts +3 -0
- package/dist/esm/lib/icons.d.ts.map +1 -0
- package/dist/esm/lib/icons.js +5 -0
- package/dist/esm/lib/icons.js.map +1 -0
- package/dist/esm/lib/invite-user-dialog.d.ts.map +1 -1
- package/dist/esm/lib/invite-user-dialog.js +7 -5
- package/dist/esm/lib/invite-user-dialog.js.map +1 -1
- package/dist/esm/lib/logout-all-sessions-dialog.d.ts +9 -0
- package/dist/esm/lib/logout-all-sessions-dialog.d.ts.map +1 -0
- package/dist/esm/lib/logout-all-sessions-dialog.js +26 -0
- package/dist/esm/lib/logout-all-sessions-dialog.js.map +1 -0
- package/dist/esm/lib/logout-dialog.d.ts +10 -0
- package/dist/esm/lib/logout-dialog.d.ts.map +1 -0
- package/dist/esm/lib/logout-dialog.js +32 -0
- package/dist/esm/lib/logout-dialog.js.map +1 -0
- package/dist/esm/lib/marker.d.ts +14 -0
- package/dist/esm/lib/marker.d.ts.map +1 -0
- package/dist/esm/lib/marker.js +9 -0
- package/dist/esm/lib/marker.js.map +1 -0
- package/dist/esm/lib/oauth-icons.d.ts +4 -0
- package/dist/esm/lib/oauth-icons.d.ts.map +1 -0
- package/dist/esm/lib/oauth-icons.js +39 -0
- package/dist/esm/lib/oauth-icons.js.map +1 -0
- package/dist/esm/lib/organization-switcher.d.ts +24 -0
- package/dist/esm/lib/organization-switcher.d.ts.map +1 -0
- package/dist/esm/lib/organization-switcher.js +29 -0
- package/dist/esm/lib/organization-switcher.js.map +1 -0
- package/dist/esm/lib/otp-input.d.ts +20 -0
- package/dist/esm/lib/otp-input.d.ts.map +1 -0
- package/dist/esm/lib/otp-input.js +148 -0
- package/dist/esm/lib/otp-input.js.map +1 -0
- package/dist/esm/lib/resend-invite-dialog.d.ts +2 -2
- package/dist/esm/lib/resend-invite-dialog.d.ts.map +1 -1
- package/dist/esm/lib/resend-invite-dialog.js +1 -1
- package/dist/esm/lib/resend-invite-dialog.js.map +1 -1
- package/dist/esm/lib/reset-mfa-dialog.d.ts +9 -0
- package/dist/esm/lib/reset-mfa-dialog.d.ts.map +1 -0
- package/dist/esm/lib/reset-mfa-dialog.js +34 -0
- package/dist/esm/lib/reset-mfa-dialog.js.map +1 -0
- package/dist/esm/lib/revoke-invite-dialog.d.ts +2 -2
- package/dist/esm/lib/revoke-invite-dialog.d.ts.map +1 -1
- package/dist/esm/lib/revoke-invite-dialog.js +1 -1
- package/dist/esm/lib/revoke-invite-dialog.js.map +1 -1
- package/dist/esm/lib/save-button.d.ts +11 -0
- package/dist/esm/lib/save-button.d.ts.map +1 -0
- package/dist/esm/lib/save-button.js +44 -0
- package/dist/esm/lib/save-button.js.map +1 -0
- package/dist/esm/lib/set-password-dialog.d.ts +8 -0
- package/dist/esm/lib/set-password-dialog.d.ts.map +1 -0
- package/dist/esm/lib/set-password-dialog.js +54 -0
- package/dist/esm/lib/set-password-dialog.js.map +1 -0
- package/dist/esm/lib/use-dialog-close.d.ts +2 -0
- package/dist/esm/lib/use-dialog-close.d.ts.map +1 -0
- package/dist/esm/lib/use-dialog-close.js +17 -0
- package/dist/esm/lib/use-dialog-close.js.map +1 -0
- package/dist/esm/lib/use-security-settings.d.ts +11 -0
- package/dist/esm/lib/use-security-settings.d.ts.map +1 -0
- package/dist/esm/lib/use-security-settings.js +36 -0
- package/dist/esm/lib/use-security-settings.js.map +1 -0
- package/dist/esm/lib/user-actions-dropdown.d.ts +2 -2
- package/dist/esm/lib/user-actions-dropdown.d.ts.map +1 -1
- package/dist/esm/lib/user-actions-dropdown.js +8 -4
- package/dist/esm/lib/user-actions-dropdown.js.map +1 -1
- package/dist/esm/lib/user-profile.d.ts +11 -0
- package/dist/esm/lib/user-profile.d.ts.map +1 -0
- package/dist/esm/lib/user-profile.js +27 -0
- package/dist/esm/lib/user-profile.js.map +1 -0
- package/dist/esm/lib/user-security.d.ts +11 -0
- package/dist/esm/lib/user-security.d.ts.map +1 -0
- package/dist/esm/lib/user-security.js +32 -0
- package/dist/esm/lib/user-security.js.map +1 -0
- package/dist/esm/lib/user-sessions.d.ts +12 -0
- package/dist/esm/lib/user-sessions.d.ts.map +1 -0
- package/dist/esm/lib/user-sessions.js +40 -0
- package/dist/esm/lib/user-sessions.js.map +1 -0
- package/dist/esm/lib/users-filter.d.ts +2 -2
- package/dist/esm/lib/users-filter.d.ts.map +1 -1
- package/dist/esm/lib/users-filter.js.map +1 -1
- package/dist/esm/lib/users-management-context.d.ts +0 -9
- package/dist/esm/lib/users-management-context.d.ts.map +1 -1
- package/dist/esm/lib/users-management-context.js +13 -25
- package/dist/esm/lib/users-management-context.js.map +1 -1
- package/dist/esm/lib/users-management-state.d.ts +3 -3
- package/dist/esm/lib/users-management-state.d.ts.map +1 -1
- package/dist/esm/lib/users-management-state.js.map +1 -1
- package/dist/esm/lib/users-management.d.ts +3 -4
- package/dist/esm/lib/users-management.d.ts.map +1 -1
- package/dist/esm/lib/users-management.js +9 -27
- package/dist/esm/lib/users-management.js.map +1 -1
- package/dist/esm/lib/users-search.d.ts +1 -1
- package/dist/esm/lib/users-search.d.ts.map +1 -1
- package/dist/esm/lib/utils.d.ts +10 -2
- package/dist/esm/lib/utils.d.ts.map +1 -1
- package/dist/esm/lib/utils.js +16 -0
- package/dist/esm/lib/utils.js.map +1 -1
- package/dist/esm/organization-switcher.client.d.ts +8 -0
- package/dist/esm/organization-switcher.client.d.ts.map +1 -0
- package/dist/esm/organization-switcher.client.js +33 -0
- package/dist/esm/organization-switcher.client.js.map +1 -0
- package/dist/esm/user-profile.client.d.ts +7 -0
- package/dist/esm/user-profile.client.d.ts.map +1 -0
- package/dist/esm/user-profile.client.js +27 -0
- package/dist/esm/user-profile.client.js.map +1 -0
- package/dist/esm/user-security.client.d.ts +7 -0
- package/dist/esm/user-security.client.d.ts.map +1 -0
- package/dist/esm/user-security.client.js +23 -0
- package/dist/esm/user-security.client.js.map +1 -0
- package/dist/esm/user-sessions.client.d.ts +12 -0
- package/dist/esm/user-sessions.client.d.ts.map +1 -0
- package/dist/esm/user-sessions.client.js +44 -0
- package/dist/esm/user-sessions.client.js.map +1 -0
- package/dist/esm/users-management.client.d.ts +2 -1
- package/dist/esm/users-management.client.d.ts.map +1 -1
- package/dist/esm/users-management.client.js +12 -20
- package/dist/esm/users-management.client.js.map +1 -1
- package/dist/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +18 -4
- package/src/api/api-provider.tsx +141 -0
- package/src/api/constants.ts +1 -0
- package/src/api/endpoint.ts +3057 -0
- package/src/api/errors.ts +48 -0
- package/src/api/index.ts +2 -0
- package/src/api/utils.ts +42 -0
- package/src/api/widgets-api-client.ts +86 -0
- package/src/card-list.tsx +26 -0
- package/src/index.ts +3 -0
- package/src/lib/add-mfa-dialog.tsx +379 -0
- package/src/lib/api/user.ts +54 -458
- package/src/lib/card-list.css +3 -0
- package/src/lib/change-password-dialog.tsx +290 -0
- package/src/lib/copy-button.tsx +53 -0
- package/src/lib/delete-user-dialog.tsx +9 -6
- package/src/lib/edit-user-profile-dialog.tsx +181 -0
- package/src/lib/{edit-user-details-dialog.tsx → edit-user-role-dialog.tsx} +12 -9
- package/src/lib/elements.tsx +34 -1
- package/src/lib/elevated-access.tsx +261 -0
- package/src/lib/generic-error.tsx +70 -0
- package/src/lib/icon-panel.tsx +26 -0
- package/src/lib/icons.tsx +21 -0
- package/src/lib/invite-user-dialog.tsx +15 -10
- package/src/lib/logout-all-sessions-dialog.tsx +82 -0
- package/src/lib/logout-dialog.tsx +85 -0
- package/src/lib/marker.css +81 -0
- package/src/lib/marker.tsx +39 -0
- package/src/lib/oauth-icons.tsx +138 -0
- package/src/lib/organization-switcher.tsx +156 -0
- package/src/lib/otp-input.tsx +276 -0
- package/src/lib/resend-invite-dialog.tsx +9 -6
- package/src/lib/reset-mfa-dialog.tsx +104 -0
- package/src/lib/revoke-invite-dialog.tsx +9 -6
- package/src/lib/save-button.css +60 -0
- package/src/lib/save-button.tsx +113 -0
- package/src/lib/set-password-dialog.tsx +204 -0
- package/src/lib/use-dialog-close.tsx +19 -0
- package/src/lib/use-security-settings.tsx +49 -0
- package/src/lib/user-actions-dropdown.tsx +10 -6
- package/src/lib/user-profile.tsx +247 -0
- package/src/lib/user-security.tsx +187 -0
- package/src/lib/user-sessions.tsx +204 -0
- package/src/lib/users-filter.tsx +2 -2
- package/src/lib/users-management-context.tsx +21 -36
- package/src/lib/users-management-state.ts +3 -3
- package/src/lib/users-management.tsx +21 -77
- package/src/lib/utils.ts +30 -2
- package/src/organization-switcher.client.tsx +77 -0
- package/src/styles.css +44 -0
- package/src/user-profile.client.tsx +51 -0
- package/src/user-security.client.tsx +51 -0
- package/src/user-sessions.client.tsx +96 -0
- package/src/users-management.client.tsx +28 -39
- package/dist/cjs/lib/api/role.d.ts +0 -9
- package/dist/cjs/lib/api/role.d.ts.map +0 -1
- package/dist/cjs/lib/api/role.js +0 -115
- package/dist/cjs/lib/api/role.js.map +0 -1
- package/dist/cjs/lib/edit-user-details-dialog.d.ts +0 -12
- package/dist/cjs/lib/edit-user-details-dialog.d.ts.map +0 -1
- package/dist/cjs/lib/edit-user-details-dialog.js.map +0 -1
- package/dist/esm/lib/api/role.d.ts +0 -9
- package/dist/esm/lib/api/role.d.ts.map +0 -1
- package/dist/esm/lib/api/role.js +0 -110
- package/dist/esm/lib/api/role.js.map +0 -1
- package/dist/esm/lib/edit-user-details-dialog.d.ts +0 -12
- package/dist/esm/lib/edit-user-details-dialog.d.ts.map +0 -1
- package/dist/esm/lib/edit-user-details-dialog.js.map +0 -1
- package/src/lib/api/role.ts +0 -147
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"user-sessions.client.js","sourceRoot":"","sources":["../../src/user-sessions.client.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAGb,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,YAAY,IAAI,0BAA0B,GAC3C,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AAejD,MAAM,CAAC,MAAM,YAAY,GAAgC,CAAC,KAAK,EAAE,EAAE;IACjE,MAAM,OAAO,GAAG,eAAe,EAAE,CAAC;IAElC,OAAO,CACL,KAAC,WAAW,IAAC,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,YACvD,KAAC,mBAAmB,IAClB,gBAAgB,EACd,kBAAkB,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,GAElE,GACU,CACf,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,mBAAmB,GAAG,CAAC,EAC3B,gBAAgB,GAGjB,EAAE,EAAE;IACH,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,aAAa,GAAG,WAAW,EAAE,CAAC;IACpC,MAAM,qBAAqB,GAAG,wBAAwB,CAAC,gBAAgB,CAAC,CAAC;IAEzE,IACE,CAAC,UAAU;QACX,aAAa,CAAC,SAAS;QACvB,qBAAqB,CAAC,SAAS,EAC/B,CAAC;QACD,OAAO,KAAC,mBAAmB,KAAG,CAAC;IACjC,CAAC;IAED,IAAI,aAAa,CAAC,OAAO,IAAI,qBAAqB,CAAC,OAAO,EAAE,CAAC;QAC3D,OAAO,CACL,KAAC,iBAAiB,IAChB,KAAK,EAAE,aAAa,CAAC,KAAK,IAAI,qBAAqB,CAAC,KAAK,GACzD,CACH,CAAC;IACJ,CAAC;IAED,OAAO,CACL,KAAC,aAAa,IAAC,iBAAiB,EAAE,iBAAiB,YACjD,KAAC,0BAA0B,IACzB,YAAY,EAAE,aAAa,CAAC,IAAI,EAAE,IAAI,IAAI,EAAE,EAC5C,gBAAgB,EAAE,qBAAqB,CAAC,IAAI,IAAI,EAAE,GAClD,GACY,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,SAAS,wBAAwB,CAAC,gBAAyB;IACzD,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,EAAE,CAAC;IAE/B,OAAO,QAAQ,CAAC;QACd,QAAQ,EAAE,CAAC,WAAW,CAAC;QACvB,OAAO,EAAE,KAAK,IAAI,EAAE;YAClB,IAAI,gBAAgB,EAAE,CAAC;gBACrB,OAAO,gBAAgB,CAAC;YAC1B,CAAC;YAED,MAAM,GAAG,GAAG,MAAM,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YAC7C,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC;YAC9B,OAAO,MAAM,CAAC,GAAG,CAAC;QACpB,CAAC;KACF,CAAC,CAAC;AACL,CAAC;AAED,SAAS,SAAS,CAAC,WAAmB;IACpC,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAoB,CAAC;AACxE,CAAC"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
+
import { AuthToken } from "./api";
|
|
1
2
|
import * as React from "react";
|
|
2
3
|
export interface UsersManagementProps {
|
|
3
|
-
authToken:
|
|
4
|
+
authToken: AuthToken;
|
|
4
5
|
}
|
|
5
6
|
export declare const UsersManagement: React.FC<UsersManagementProps>;
|
|
6
7
|
//# sourceMappingURL=users-management.client.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users-management.client.d.ts","sourceRoot":"","sources":["../../src/users-management.client.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"users-management.client.d.ts","sourceRoot":"","sources":["../../src/users-management.client.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAe,SAAS,EAAY,MAAM,OAAO,CAAC;AACzD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAY/B,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAc1D,CAAC"}
|
|
@@ -1,30 +1,22 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import
|
|
4
|
-
import { useRoles } from "./lib/api/role";
|
|
3
|
+
import { ApiProvider, useRoles } from "./api";
|
|
5
4
|
import { useUsers } from "./lib/api/user";
|
|
6
5
|
import { useIsHydrated } from "./lib/use-is-hydrated";
|
|
7
6
|
import { UsersManagementError, UsersManagementLoading, UsersManagement as UsersManagementPresentational, } from "./lib/users-management";
|
|
8
|
-
import { UsersManagementContextProvider
|
|
9
|
-
import { useUsersManagementState, } from "./lib/users-management-state";
|
|
7
|
+
import { UsersManagementContextProvider } from "./lib/users-management-context";
|
|
10
8
|
import { ErrorBoundary } from "./lib/error-boundary";
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
9
|
+
import { useWorkOsApiUrl } from "./lib/widgets-context";
|
|
10
|
+
export const UsersManagement = ({ authToken, }) => {
|
|
11
|
+
const baseUrl = useWorkOsApiUrl();
|
|
12
|
+
return (_jsx(ErrorBoundary, { FallbackComponent: UsersManagementError, children: _jsx(ApiProvider, { authToken: authToken, baseUrl: baseUrl, children: _jsx(UsersManagementContextProvider, { children: _jsx(UsersManagementContent, {}) }) }) }));
|
|
15
13
|
};
|
|
16
|
-
|
|
14
|
+
const UsersManagementContent = () => {
|
|
17
15
|
const isHydrated = useIsHydrated();
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
: authToken,
|
|
23
|
-
state,
|
|
24
|
-
dispatch,
|
|
25
|
-
}), [authToken, state, dispatch]);
|
|
26
|
-
const rolesQuery = useRoles(context);
|
|
27
|
-
const usersQuery = useUsers(context);
|
|
16
|
+
const rolesQuery = useRoles({
|
|
17
|
+
query: { initialData: [] },
|
|
18
|
+
});
|
|
19
|
+
const usersQuery = useUsers();
|
|
28
20
|
if (usersQuery.isLoading ||
|
|
29
21
|
rolesQuery.isLoading ||
|
|
30
22
|
usersQuery.isPending ||
|
|
@@ -35,6 +27,6 @@ export const UsersManagement = ({ authToken = null, }) => {
|
|
|
35
27
|
if (usersQuery.isError || rolesQuery.isError) {
|
|
36
28
|
return (_jsx(UsersManagementError, { error: usersQuery.error || rolesQuery.isError }));
|
|
37
29
|
}
|
|
38
|
-
return (_jsx(ErrorBoundary, { FallbackComponent: UsersManagementError, children: _jsx(
|
|
30
|
+
return (_jsx(ErrorBoundary, { FallbackComponent: UsersManagementError, children: _jsx(UsersManagementPresentational, { userData: usersQuery.data, rolesData: rolesQuery.data, isPending: usersQuery.isFetching, disableRolesFilter: rolesQuery.isPending || rolesQuery.isFetching }) }));
|
|
39
31
|
};
|
|
40
32
|
//# sourceMappingURL=users-management.client.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users-management.client.js","sourceRoot":"","sources":["../../src/users-management.client.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,
|
|
1
|
+
{"version":3,"file":"users-management.client.js","sourceRoot":"","sources":["../../src/users-management.client.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb,OAAO,EAAE,WAAW,EAAa,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEzD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EACL,oBAAoB,EACpB,sBAAsB,EACtB,eAAe,IAAI,6BAA6B,GACjD,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,8BAA8B,EAAE,MAAM,gCAAgC,CAAC;AAChF,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAMxD,MAAM,CAAC,MAAM,eAAe,GAAmC,CAAC,EAC9D,SAAS,GACV,EAAE,EAAE;IACH,MAAM,OAAO,GAAG,eAAe,EAAE,CAAC;IAElC,OAAO,CACL,KAAC,aAAa,IAAC,iBAAiB,EAAE,oBAAoB,YACpD,KAAC,WAAW,IAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,YACjD,KAAC,8BAA8B,cAC7B,KAAC,sBAAsB,KAAG,GACK,GACrB,GACA,CACjB,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,sBAAsB,GAAG,GAAG,EAAE;IAClC,MAAM,UAAU,GAAG,aAAa,EAAE,CAAC;IACnC,MAAM,UAAU,GAAG,QAAQ,CAAC;QAC1B,KAAK,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE;KAC3B,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,QAAQ,EAAE,CAAC;IAE9B,IACE,UAAU,CAAC,SAAS;QACpB,UAAU,CAAC,SAAS;QACpB,UAAU,CAAC,SAAS;QACpB,2EAA2E;QAC3E,CAAC,UAAU,EACX,CAAC;QACD,OAAO,KAAC,sBAAsB,KAAG,CAAC;IACpC,CAAC;IAED,IAAI,UAAU,CAAC,OAAO,IAAI,UAAU,CAAC,OAAO,EAAE,CAAC;QAC7C,OAAO,CACL,KAAC,oBAAoB,IAAC,KAAK,EAAE,UAAU,CAAC,KAAK,IAAI,UAAU,CAAC,OAAO,GAAI,CACxE,CAAC;IACJ,CAAC;IAED,OAAO,CACL,KAAC,aAAa,IAAC,iBAAiB,EAAE,oBAAoB,YACpD,KAAC,6BAA6B,IAC5B,QAAQ,EAAE,UAAU,CAAC,IAAI,EACzB,SAAS,EAAE,UAAU,CAAC,IAAI,EAC1B,SAAS,EAAE,UAAU,CAAC,UAAU,EAChC,kBAAkB,EAAE,UAAU,CAAC,SAAS,IAAI,UAAU,CAAC,UAAU,GACjE,GACY,CACjB,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"root":["../src/index.ts","../src/users-management.client.tsx","../src/workos-widgets.client.tsx","../src/lib/constants.ts","../src/lib/delete-user-dialog.tsx","../src/lib/edit-user-
|
|
1
|
+
{"root":["../src/card-list.tsx","../src/index.ts","../src/organization-switcher.client.tsx","../src/user-profile.client.tsx","../src/user-security.client.tsx","../src/user-sessions.client.tsx","../src/users-management.client.tsx","../src/workos-widgets.client.tsx","../src/api/api-provider.tsx","../src/api/constants.ts","../src/api/endpoint.ts","../src/api/errors.ts","../src/api/index.ts","../src/api/utils.ts","../src/api/widgets-api-client.ts","../src/lib/add-mfa-dialog.tsx","../src/lib/change-password-dialog.tsx","../src/lib/constants.ts","../src/lib/copy-button.tsx","../src/lib/delete-user-dialog.tsx","../src/lib/edit-user-profile-dialog.tsx","../src/lib/edit-user-role-dialog.tsx","../src/lib/elements.tsx","../src/lib/elevated-access.tsx","../src/lib/error-boundary.tsx","../src/lib/errors.ts","../src/lib/generic-error.tsx","../src/lib/icon-panel.tsx","../src/lib/icons.tsx","../src/lib/invite-user-dialog.tsx","../src/lib/logout-all-sessions-dialog.tsx","../src/lib/logout-dialog.tsx","../src/lib/marker.tsx","../src/lib/oauth-icons.tsx","../src/lib/organization-switcher.tsx","../src/lib/otp-input.tsx","../src/lib/resend-invite-dialog.tsx","../src/lib/reset-mfa-dialog.tsx","../src/lib/revoke-invite-dialog.tsx","../src/lib/save-button.tsx","../src/lib/search-provider.tsx","../src/lib/set-password-dialog.tsx","../src/lib/use-dialog-close.tsx","../src/lib/use-is-hydrated.ts","../src/lib/use-layout-effect.ts","../src/lib/use-security-settings.tsx","../src/lib/user-actions-dropdown.tsx","../src/lib/user-profile.tsx","../src/lib/user-security.tsx","../src/lib/user-sessions.tsx","../src/lib/users-filter.tsx","../src/lib/users-management-context.tsx","../src/lib/users-management-state.ts","../src/lib/users-management.tsx","../src/lib/users-search.tsx","../src/lib/utils.ts","../src/lib/widgets-context.ts","../src/lib/api/config.ts","../src/lib/api/user.ts","../global.d.ts"],"version":"5.6.3"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"root":["../src/index.ts","../src/users-management.client.tsx","../src/workos-widgets.client.tsx","../src/lib/constants.ts","../src/lib/delete-user-dialog.tsx","../src/lib/edit-user-
|
|
1
|
+
{"root":["../src/card-list.tsx","../src/index.ts","../src/organization-switcher.client.tsx","../src/user-profile.client.tsx","../src/user-security.client.tsx","../src/user-sessions.client.tsx","../src/users-management.client.tsx","../src/workos-widgets.client.tsx","../src/api/api-provider.tsx","../src/api/constants.ts","../src/api/endpoint.ts","../src/api/errors.ts","../src/api/index.ts","../src/api/utils.ts","../src/api/widgets-api-client.ts","../src/lib/add-mfa-dialog.tsx","../src/lib/change-password-dialog.tsx","../src/lib/constants.ts","../src/lib/copy-button.tsx","../src/lib/delete-user-dialog.tsx","../src/lib/edit-user-profile-dialog.tsx","../src/lib/edit-user-role-dialog.tsx","../src/lib/elements.tsx","../src/lib/elevated-access.tsx","../src/lib/error-boundary.tsx","../src/lib/errors.ts","../src/lib/generic-error.tsx","../src/lib/icon-panel.tsx","../src/lib/icons.tsx","../src/lib/invite-user-dialog.tsx","../src/lib/logout-all-sessions-dialog.tsx","../src/lib/logout-dialog.tsx","../src/lib/marker.tsx","../src/lib/oauth-icons.tsx","../src/lib/organization-switcher.tsx","../src/lib/otp-input.tsx","../src/lib/resend-invite-dialog.tsx","../src/lib/reset-mfa-dialog.tsx","../src/lib/revoke-invite-dialog.tsx","../src/lib/save-button.tsx","../src/lib/search-provider.tsx","../src/lib/set-password-dialog.tsx","../src/lib/use-dialog-close.tsx","../src/lib/use-is-hydrated.ts","../src/lib/use-layout-effect.ts","../src/lib/use-security-settings.tsx","../src/lib/user-actions-dropdown.tsx","../src/lib/user-profile.tsx","../src/lib/user-security.tsx","../src/lib/user-sessions.tsx","../src/lib/users-filter.tsx","../src/lib/users-management-context.tsx","../src/lib/users-management-state.ts","../src/lib/users-management.tsx","../src/lib/users-search.tsx","../src/lib/utils.ts","../src/lib/widgets-context.ts","../src/lib/api/config.ts","../src/lib/api/user.ts","../global.d.ts"],"version":"5.6.3"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@workos-inc/widgets",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.1",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"exports": {
|
|
@@ -42,8 +42,12 @@
|
|
|
42
42
|
"sideEffects": false,
|
|
43
43
|
"dependencies": {
|
|
44
44
|
"@radix-ui/react-compose-refs": "^1.0.0",
|
|
45
|
-
"@radix-ui/react-
|
|
45
|
+
"@radix-ui/react-form": "^0.1.2",
|
|
46
|
+
"@radix-ui/react-icons": "^1.3.1",
|
|
47
|
+
"@radix-ui/react-popover": "^1.1.6",
|
|
48
|
+
"@radix-ui/react-use-controllable-state": "^1.1.0",
|
|
46
49
|
"clsx": "^2.0.0",
|
|
50
|
+
"ua-parser-js": "^2.0.2",
|
|
47
51
|
"use-debounce": "^10.0.4"
|
|
48
52
|
},
|
|
49
53
|
"peerDependencies": {
|
|
@@ -53,20 +57,30 @@
|
|
|
53
57
|
"react-dom": ">=18"
|
|
54
58
|
},
|
|
55
59
|
"devDependencies": {
|
|
56
|
-
"@radix-ui/themes": "^3.1
|
|
60
|
+
"@radix-ui/themes": "^3.2.1",
|
|
57
61
|
"@tanstack/react-query": "^5.59.20",
|
|
58
62
|
"@types/node": "^20.16.6",
|
|
59
63
|
"@types/react": "^18.3.12",
|
|
60
64
|
"@types/react-dom": "^18.3.1",
|
|
65
|
+
"orval": "^7.5.0",
|
|
61
66
|
"react": "^18.3.1",
|
|
62
67
|
"react-dom": "^18.3.1",
|
|
63
68
|
"typescript": "^5.6.2",
|
|
64
69
|
"@repo/typescript-config": "0.0.0"
|
|
65
70
|
},
|
|
71
|
+
"typesVersions": {
|
|
72
|
+
"*": {
|
|
73
|
+
"*": [
|
|
74
|
+
"./src/api/*"
|
|
75
|
+
]
|
|
76
|
+
}
|
|
77
|
+
},
|
|
66
78
|
"scripts": {
|
|
67
79
|
"build": "npm run clean:dist && tsc -b ./tsconfig.cjs.json ./tsconfig.esm.json",
|
|
80
|
+
"build:ci": "tsc --noEmit",
|
|
68
81
|
"clean": "rm -rf .turbo && rm -rf node_modules && npm run clean:dist",
|
|
69
|
-
"clean:dist": "rm -rf dist"
|
|
82
|
+
"clean:dist": "rm -rf dist",
|
|
83
|
+
"generate-api": "orval --config ./orval.config.ts"
|
|
70
84
|
},
|
|
71
85
|
"main": "./dist/cjs/index.js",
|
|
72
86
|
"module": "./dist/esm/index.js",
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
|
|
3
|
+
export type AuthToken = string | (() => Promise<string>);
|
|
4
|
+
|
|
5
|
+
interface ElevatedAccess {
|
|
6
|
+
token: string;
|
|
7
|
+
expiresAt: string;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
interface ApiConfig {
|
|
11
|
+
authToken: Promise<string> | string;
|
|
12
|
+
authTokenQueryKey: string;
|
|
13
|
+
baseUrl: string;
|
|
14
|
+
elevatedAccess?: ElevatedAccess;
|
|
15
|
+
setElevatedAccess: (elevatedAccess?: ElevatedAccess) => void;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const ApiContext = React.createContext<ApiConfig | undefined>(undefined);
|
|
19
|
+
|
|
20
|
+
interface ApiProviderProps {
|
|
21
|
+
authToken: AuthToken;
|
|
22
|
+
baseUrl: string;
|
|
23
|
+
children: React.ReactNode;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export const ApiProvider = ({
|
|
27
|
+
authToken,
|
|
28
|
+
baseUrl,
|
|
29
|
+
children,
|
|
30
|
+
}: ApiProviderProps) => {
|
|
31
|
+
const authTokenPromiseOrString =
|
|
32
|
+
typeof authToken === "string" ? authToken : authToken();
|
|
33
|
+
const [elevatedAccess, setElevatedAccess] = React.useState<ElevatedAccess>();
|
|
34
|
+
const elevatedAccessTimeout = React.useRef<NodeJS.Timeout>();
|
|
35
|
+
|
|
36
|
+
// This effect manages the expiration of elevated access tokens
|
|
37
|
+
// When an elevated access token is present, it checks every 30 seconds if the token has expired
|
|
38
|
+
// If the token has expired (current time > expiration time), it clears the elevated access
|
|
39
|
+
React.useEffect(() => {
|
|
40
|
+
if (elevatedAccessTimeout.current) {
|
|
41
|
+
clearInterval(elevatedAccessTimeout.current);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
if (elevatedAccess) {
|
|
45
|
+
elevatedAccessTimeout.current = setInterval(() => {
|
|
46
|
+
const now = new Date();
|
|
47
|
+
const expiresAtDate = new Date(elevatedAccess.expiresAt);
|
|
48
|
+
|
|
49
|
+
// Reset the elevated access if it has expired
|
|
50
|
+
if (now > expiresAtDate) {
|
|
51
|
+
setElevatedAccess(undefined);
|
|
52
|
+
}
|
|
53
|
+
}, 30_000); // every 30 seconds
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
return () => {
|
|
57
|
+
if (elevatedAccessTimeout.current) {
|
|
58
|
+
clearInterval(elevatedAccessTimeout.current);
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}, [elevatedAccess]);
|
|
62
|
+
|
|
63
|
+
const value = React.useMemo(
|
|
64
|
+
() => ({
|
|
65
|
+
authToken: authTokenPromiseOrString,
|
|
66
|
+
authTokenQueryKey: getAuthTokenQueryKey(authTokenPromiseOrString),
|
|
67
|
+
baseUrl,
|
|
68
|
+
elevatedAccess,
|
|
69
|
+
setElevatedAccess,
|
|
70
|
+
}),
|
|
71
|
+
[authTokenPromiseOrString, baseUrl, elevatedAccess, setElevatedAccess],
|
|
72
|
+
);
|
|
73
|
+
|
|
74
|
+
return <ApiContext.Provider value={value}>{children}</ApiContext.Provider>;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
export const useApi = () => {
|
|
78
|
+
const context = React.useContext(ApiContext);
|
|
79
|
+
|
|
80
|
+
if (context === undefined) {
|
|
81
|
+
throw new Error("useApi must be used within an ApiProvider");
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
return context;
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
export const useElevatedAccessToken = () => {
|
|
88
|
+
const { elevatedAccess, setElevatedAccess } = useApi();
|
|
89
|
+
|
|
90
|
+
return { elevatedAccess, setElevatedAccess };
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
// Map promises to a UUID that they can be identified by
|
|
94
|
+
const PromiseKey = new WeakMap<Promise<string>, string>();
|
|
95
|
+
/*
|
|
96
|
+
*
|
|
97
|
+
* @param getAccessToken - Async function that returns a promise that resolves to a string
|
|
98
|
+
* @returns a resolved string or null from the access token promise
|
|
99
|
+
*/
|
|
100
|
+
function getAuthTokenQueryKey(
|
|
101
|
+
authTokenPromiseOrString: Promise<string> | string,
|
|
102
|
+
): string {
|
|
103
|
+
// Need to go by equality of the promise to avoid scenarios where
|
|
104
|
+
// 1. The promise is the same, but the function changes
|
|
105
|
+
// 2. The function is the same, but the promise is different ⚠️
|
|
106
|
+
//
|
|
107
|
+
// This does have the unfortunate side effect where if the function result
|
|
108
|
+
// isn't memoized somehow, then it will invalidate the query on every render.
|
|
109
|
+
// This doesn't occur with the current use case of getAccessToken from
|
|
110
|
+
// useAuth, but could in a custom implementation.
|
|
111
|
+
//
|
|
112
|
+
// Other things I explored:
|
|
113
|
+
// 1. Removing promise api, and force user to resolve the promise
|
|
114
|
+
// themselves. The user can already do this with the string API, so
|
|
115
|
+
// it's not necessary, and they could run into issues 1, or 2 if
|
|
116
|
+
// implemented wrong.
|
|
117
|
+
// 2. Memoizing the function - this results in issue 2, where the function
|
|
118
|
+
// is static, but the promise changes. I believe this actually is the
|
|
119
|
+
// case with useAuth since it only sets the client once on initialization,
|
|
120
|
+
// and binds the function to the client after that promise resolves.
|
|
121
|
+
|
|
122
|
+
if (typeof authTokenPromiseOrString === "string") {
|
|
123
|
+
return authTokenPromiseOrString;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
const authTokenPromise = authTokenPromiseOrString;
|
|
127
|
+
|
|
128
|
+
// Cannot memoize on the function because it could remain the same while
|
|
129
|
+
// returning a different promise (and useAuth behaves this way).
|
|
130
|
+
|
|
131
|
+
const promiseKey = PromiseKey.get(authTokenPromise);
|
|
132
|
+
|
|
133
|
+
// Side effect, but we we're using a weak map, so it should be pretty safe
|
|
134
|
+
if (!promiseKey) {
|
|
135
|
+
const newPromiseKey = `${Math.random()}`;
|
|
136
|
+
PromiseKey.set(authTokenPromise, newPromiseKey);
|
|
137
|
+
return newPromiseKey;
|
|
138
|
+
} else {
|
|
139
|
+
return promiseKey;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const WIDGETS_API_VERSION = "1";
|