@atproto/oauth-provider 0.3.1 → 0.5.0
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/.linguirc +57 -0
- package/CHANGELOG.md +29 -0
- package/LICENSE.txt +1 -1
- package/dist/account/account-manager.d.ts +17 -3
- package/dist/account/account-manager.d.ts.map +1 -1
- package/dist/account/account-manager.js +102 -8
- package/dist/account/account-manager.js.map +1 -1
- package/dist/account/account-store.d.ts +81 -15
- package/dist/account/account-store.d.ts.map +1 -1
- package/dist/account/account-store.js +70 -19
- package/dist/account/account-store.js.map +1 -1
- package/dist/account/sign-in-data.d.ts +28 -0
- package/dist/account/sign-in-data.d.ts.map +1 -0
- package/dist/account/sign-in-data.js +16 -0
- package/dist/account/sign-in-data.js.map +1 -0
- package/dist/account/sign-up-data.d.ts +26 -0
- package/dist/account/sign-up-data.d.ts.map +1 -0
- package/dist/account/sign-up-data.js +11 -0
- package/dist/account/sign-up-data.js.map +1 -0
- package/dist/assets/app/bundle-manifest.json +598 -6
- package/dist/assets/app/index-ItwwtJ8r.js +36 -0
- package/dist/assets/app/index-ItwwtJ8r.js.map +1 -0
- package/dist/assets/app/main-B_dNxQo_.js +4 -0
- package/dist/assets/app/main-B_dNxQo_.js.map +1 -0
- package/dist/assets/app/main-CSatvmRR.css +3 -0
- package/dist/assets/app/main-CSatvmRR.js +306 -0
- package/dist/assets/app/main-CSatvmRR.js.map +1 -0
- package/dist/assets/app/messages-BQeltXSF.js +4 -0
- package/dist/assets/app/messages-BQeltXSF.js.map +1 -0
- package/dist/assets/app/messages-BQkEhfjg.js +4 -0
- package/dist/assets/app/messages-BQkEhfjg.js.map +1 -0
- package/dist/assets/app/messages-BUjKj_UJ.js +4 -0
- package/dist/assets/app/messages-BUjKj_UJ.js.map +1 -0
- package/dist/assets/app/messages-BWIQa8fO.js +4 -0
- package/dist/assets/app/messages-BWIQa8fO.js.map +1 -0
- package/dist/assets/app/messages-BaNVb0bp.js +4 -0
- package/dist/assets/app/messages-BaNVb0bp.js.map +1 -0
- package/dist/assets/app/messages-BaizVXcF.js +4 -0
- package/dist/assets/app/messages-BaizVXcF.js.map +1 -0
- package/dist/assets/app/messages-BfoClA1Y.js +4 -0
- package/dist/assets/app/messages-BfoClA1Y.js.map +1 -0
- package/dist/assets/app/messages-BsKGDZnC.js +4 -0
- package/dist/assets/app/messages-BsKGDZnC.js.map +1 -0
- package/dist/assets/app/messages-Bu-TJhml.js +4 -0
- package/dist/assets/app/messages-Bu-TJhml.js.map +1 -0
- package/dist/assets/app/messages-BvOKnBQk.js +4 -0
- package/dist/assets/app/messages-BvOKnBQk.js.map +1 -0
- package/dist/assets/app/messages-BxDzCiWz.js +4 -0
- package/dist/assets/app/messages-BxDzCiWz.js.map +1 -0
- package/dist/assets/app/messages-CDgFOy4S.js +4 -0
- package/dist/assets/app/messages-CDgFOy4S.js.map +1 -0
- package/dist/assets/app/messages-CLbTz0o9.js +4 -0
- package/dist/assets/app/messages-CLbTz0o9.js.map +1 -0
- package/dist/assets/app/messages-CNwSh0t7.js +4 -0
- package/dist/assets/app/messages-CNwSh0t7.js.map +1 -0
- package/dist/assets/app/messages-CSMNJ6P8.js +4 -0
- package/dist/assets/app/messages-CSMNJ6P8.js.map +1 -0
- package/dist/assets/app/messages-CZQUw3mp.js +4 -0
- package/dist/assets/app/messages-CZQUw3mp.js.map +1 -0
- package/dist/assets/app/messages-CZT41oVp.js +4 -0
- package/dist/assets/app/messages-CZT41oVp.js.map +1 -0
- package/dist/assets/app/messages-C_b-d3t8.js +4 -0
- package/dist/assets/app/messages-C_b-d3t8.js.map +1 -0
- package/dist/assets/app/messages-C_u3MTc2.js +4 -0
- package/dist/assets/app/messages-C_u3MTc2.js.map +1 -0
- package/dist/assets/app/messages-Cn8nHZic.js +4 -0
- package/dist/assets/app/messages-Cn8nHZic.js.map +1 -0
- package/dist/assets/app/messages-CtDywJUm.js +4 -0
- package/dist/assets/app/messages-CtDywJUm.js.map +1 -0
- package/dist/assets/app/messages-CurtIjBF.js +4 -0
- package/dist/assets/app/messages-CurtIjBF.js.map +1 -0
- package/dist/assets/app/messages-Cv6zIbaP.js +4 -0
- package/dist/assets/app/messages-Cv6zIbaP.js.map +1 -0
- package/dist/assets/app/messages-D1eLQuPE.js +4 -0
- package/dist/assets/app/messages-D1eLQuPE.js.map +1 -0
- package/dist/assets/app/messages-D8vHEaYW.js +4 -0
- package/dist/assets/app/messages-D8vHEaYW.js.map +1 -0
- package/dist/assets/app/messages-DJ1Q4GeC.js +4 -0
- package/dist/assets/app/messages-DJ1Q4GeC.js.map +1 -0
- package/dist/assets/app/messages-DRL3exqd.js +4 -0
- package/dist/assets/app/messages-DRL3exqd.js.map +1 -0
- package/dist/assets/app/messages-DWLPQRTp.js +4 -0
- package/dist/assets/app/messages-DWLPQRTp.js.map +1 -0
- package/dist/assets/app/messages-DjVaE9YE.js +4 -0
- package/dist/assets/app/messages-DjVaE9YE.js.map +1 -0
- package/dist/assets/app/messages-DqpMfFJR.js +4 -0
- package/dist/assets/app/messages-DqpMfFJR.js.map +1 -0
- package/dist/assets/app/messages-ETjhJBEN.js +4 -0
- package/dist/assets/app/messages-ETjhJBEN.js.map +1 -0
- package/dist/assets/app/messages-EUKrgrGn.js +4 -0
- package/dist/assets/app/messages-EUKrgrGn.js.map +1 -0
- package/dist/assets/app/messages-QQrOUcPW.js +4 -0
- package/dist/assets/app/messages-QQrOUcPW.js.map +1 -0
- package/dist/assets/app/messages-e2QGqFL6.js +4 -0
- package/dist/assets/app/messages-e2QGqFL6.js.map +1 -0
- package/dist/assets/app/messages-p61py7gD.js +4 -0
- package/dist/assets/app/messages-p61py7gD.js.map +1 -0
- package/dist/assets/asset.d.ts +1 -0
- package/dist/assets/asset.d.ts.map +1 -1
- package/dist/assets/assets-middleware.d.ts.map +1 -1
- package/dist/assets/assets-middleware.js +12 -7
- package/dist/assets/assets-middleware.js.map +1 -1
- package/dist/assets/index.d.ts +3 -2
- package/dist/assets/index.d.ts.map +1 -1
- package/dist/assets/index.js +13 -1
- package/dist/assets/index.js.map +1 -1
- package/dist/client/client-store.d.ts +3 -3
- package/dist/client/client-store.d.ts.map +1 -1
- package/dist/client/client-store.js +6 -5
- package/dist/client/client-store.js.map +1 -1
- package/dist/device/device-manager.d.ts +12 -13
- package/dist/device/device-manager.d.ts.map +1 -1
- package/dist/device/device-manager.js +5 -3
- package/dist/device/device-manager.js.map +1 -1
- package/dist/device/device-store.d.ts +3 -3
- package/dist/device/device-store.d.ts.map +1 -1
- package/dist/device/device-store.js +10 -9
- package/dist/device/device-store.js.map +1 -1
- package/dist/dpop/dpop-manager.d.ts +15 -7
- package/dist/dpop/dpop-manager.d.ts.map +1 -1
- package/dist/dpop/dpop-manager.js +17 -3
- package/dist/dpop/dpop-manager.js.map +1 -1
- package/dist/dpop/dpop-nonce.d.ts +11 -5
- package/dist/dpop/dpop-nonce.d.ts.map +1 -1
- package/dist/dpop/dpop-nonce.js +47 -38
- package/dist/dpop/dpop-nonce.js.map +1 -1
- package/dist/errors/handle-unavailable-error.d.ts +11 -0
- package/dist/errors/handle-unavailable-error.d.ts.map +1 -0
- package/dist/errors/handle-unavailable-error.js +19 -0
- package/dist/errors/handle-unavailable-error.js.map +1 -0
- package/dist/errors/invalid-request-error.d.ts +6 -8
- package/dist/errors/invalid-request-error.d.ts.map +1 -1
- package/dist/errors/invalid-request-error.js +10 -8
- package/dist/errors/invalid-request-error.js.map +1 -1
- package/dist/lib/csp/index.d.ts +18 -0
- package/dist/lib/csp/index.d.ts.map +1 -0
- package/dist/lib/csp/index.js +72 -0
- package/dist/lib/csp/index.js.map +1 -0
- package/dist/lib/hcaptcha.d.ts +177 -0
- package/dist/lib/hcaptcha.d.ts.map +1 -0
- package/dist/lib/hcaptcha.js +155 -0
- package/dist/lib/hcaptcha.js.map +1 -0
- package/dist/lib/html/build-document.d.ts +11 -3
- package/dist/lib/html/build-document.d.ts.map +1 -1
- package/dist/lib/html/build-document.js +51 -15
- package/dist/lib/html/build-document.js.map +1 -1
- package/dist/lib/http/middleware.d.ts.map +1 -1
- package/dist/lib/http/middleware.js +4 -1
- package/dist/lib/http/middleware.js.map +1 -1
- package/dist/lib/http/request.d.ts +18 -3
- package/dist/lib/http/request.d.ts.map +1 -1
- package/dist/lib/http/request.js +56 -23
- package/dist/lib/http/request.js.map +1 -1
- package/dist/lib/http/response.d.ts +4 -2
- package/dist/lib/http/response.d.ts.map +1 -1
- package/dist/lib/http/response.js +23 -5
- package/dist/lib/http/response.js.map +1 -1
- package/dist/lib/locale.d.ts +15 -0
- package/dist/lib/locale.d.ts.map +1 -0
- package/dist/lib/locale.js +17 -0
- package/dist/lib/locale.js.map +1 -0
- package/dist/lib/util/function.d.ts +2 -2
- package/dist/lib/util/function.d.ts.map +1 -1
- package/dist/lib/util/function.js.map +1 -1
- package/dist/lib/util/type.d.ts +88 -1
- package/dist/lib/util/type.d.ts.map +1 -1
- package/dist/lib/util/type.js +41 -0
- package/dist/lib/util/type.js.map +1 -1
- package/dist/metadata/build-metadata.d.ts +2 -2
- package/dist/metadata/build-metadata.d.ts.map +1 -1
- package/dist/metadata/build-metadata.js.map +1 -1
- package/dist/oauth-errors.d.ts +1 -0
- package/dist/oauth-errors.d.ts.map +1 -1
- package/dist/oauth-errors.js +3 -1
- package/dist/oauth-errors.js.map +1 -1
- package/dist/oauth-hooks.d.ts +60 -3
- package/dist/oauth-hooks.d.ts.map +1 -1
- package/dist/oauth-hooks.js +3 -3
- package/dist/oauth-hooks.js.map +1 -1
- package/dist/oauth-provider.d.ts +28 -22
- package/dist/oauth-provider.d.ts.map +1 -1
- package/dist/oauth-provider.js +212 -211
- package/dist/oauth-provider.js.map +1 -1
- package/dist/oauth-verifier.d.ts +1 -1
- package/dist/oauth-verifier.d.ts.map +1 -1
- package/dist/oauth-verifier.js +2 -1
- package/dist/oauth-verifier.js.map +1 -1
- package/dist/output/build-authorize-data.d.ts +0 -1
- package/dist/output/build-authorize-data.d.ts.map +1 -1
- package/dist/output/build-authorize-data.js +0 -1
- package/dist/output/build-authorize-data.js.map +1 -1
- package/dist/output/build-customization-data.d.ts +232 -0
- package/dist/output/build-customization-data.d.ts.map +1 -0
- package/dist/output/build-customization-data.js +145 -0
- package/dist/output/build-customization-data.js.map +1 -0
- package/dist/output/output-manager.d.ts +16 -9
- package/dist/output/output-manager.d.ts.map +1 -1
- package/dist/output/output-manager.js +78 -42
- package/dist/output/output-manager.js.map +1 -1
- package/dist/output/send-authorize-redirect.d.ts +9 -6
- package/dist/output/send-authorize-redirect.d.ts.map +1 -1
- package/dist/output/send-authorize-redirect.js +20 -14
- package/dist/output/send-authorize-redirect.js.map +1 -1
- package/dist/output/send-web-page.d.ts +7 -2
- package/dist/output/send-web-page.d.ts.map +1 -1
- package/dist/output/send-web-page.js +37 -21
- package/dist/output/send-web-page.js.map +1 -1
- package/dist/request/request-manager.d.ts +1 -1
- package/dist/request/request-manager.d.ts.map +1 -1
- package/dist/request/request-manager.js +4 -4
- package/dist/request/request-manager.js.map +1 -1
- package/dist/request/request-store.d.ts +3 -3
- package/dist/request/request-store.d.ts.map +1 -1
- package/dist/request/request-store.js +11 -10
- package/dist/request/request-store.js.map +1 -1
- package/dist/token/token-store.d.ts +4 -4
- package/dist/token/token-store.d.ts.map +1 -1
- package/dist/token/token-store.js +13 -12
- package/dist/token/token-store.js.map +1 -1
- package/package.json +46 -21
- package/rollup.config.js +61 -17
- package/src/account/account-manager.ts +159 -8
- package/src/account/account-store.ts +127 -32
- package/src/account/sign-in-data.ts +15 -0
- package/src/account/sign-up-data.ts +11 -0
- package/src/assets/app/app.tsx +31 -16
- package/src/assets/app/backend-data.ts +15 -60
- package/src/assets/app/backend-types.ts +66 -0
- package/src/assets/app/components/forms/button-toggle-visibility.tsx +43 -0
- package/src/assets/app/components/forms/button.tsx +60 -0
- package/src/assets/app/components/forms/fieldset.tsx +55 -0
- package/src/assets/app/components/forms/form-card-async.tsx +103 -0
- package/src/assets/app/components/forms/form-card.tsx +49 -0
- package/src/assets/app/components/forms/input-checkbox.tsx +73 -0
- package/src/assets/app/components/forms/input-container.tsx +107 -0
- package/src/assets/app/components/forms/input-email-address.tsx +66 -0
- package/src/assets/app/components/forms/input-new-password.tsx +62 -0
- package/src/assets/app/components/forms/input-password.tsx +88 -0
- package/src/assets/app/components/forms/input-text.tsx +76 -0
- package/src/assets/app/components/forms/input-token.tsx +94 -0
- package/src/assets/app/components/forms/wizard-card.tsx +116 -0
- package/src/assets/app/components/layouts/layout-title-page.tsx +77 -0
- package/src/assets/app/components/layouts/layout-welcome.tsx +73 -0
- package/src/assets/app/components/utils/account-identifier.tsx +23 -0
- package/src/assets/app/components/utils/account-image.tsx +33 -0
- package/src/assets/app/components/utils/admonition.tsx +52 -0
- package/src/assets/app/components/utils/client-name.tsx +45 -0
- package/src/assets/app/components/utils/error-card.tsx +93 -0
- package/src/assets/app/components/utils/error-message.tsx +62 -0
- package/src/assets/app/components/utils/help-card.tsx +46 -0
- package/src/assets/app/components/utils/icons.tsx +88 -0
- package/src/assets/app/components/utils/link-anchor.tsx +28 -0
- package/src/assets/app/components/utils/link-title.tsx +26 -0
- package/src/assets/app/components/utils/multi-lang-string.tsx +56 -0
- package/src/assets/app/components/utils/password-strength-label.tsx +37 -0
- package/src/assets/app/components/utils/password-strength-meter.tsx +58 -0
- package/src/assets/app/components/{url-viewer.tsx → utils/url-viewer.tsx} +9 -6
- package/src/assets/app/hooks/use-api.ts +128 -55
- package/src/assets/app/hooks/use-async-action.ts +120 -0
- package/src/assets/app/hooks/use-browser-color-scheme.ts +31 -0
- package/src/assets/app/hooks/use-csrf-token.ts +1 -1
- package/src/assets/app/hooks/use-random-string.ts +37 -0
- package/src/assets/app/hooks/use-stepper.ts +87 -0
- package/src/assets/app/index.html +182 -0
- package/src/assets/app/lib/api.ts +248 -79
- package/src/assets/app/lib/clsx.ts +5 -8
- package/src/assets/app/lib/json-client.ts +94 -0
- package/src/assets/app/lib/password.ts +98 -0
- package/src/assets/app/lib/ref.ts +17 -0
- package/src/assets/app/locales/an/messages.po +492 -0
- package/src/assets/app/locales/ast/messages.po +492 -0
- package/src/assets/app/locales/ca/messages.po +492 -0
- package/src/assets/app/locales/da/messages.po +492 -0
- package/src/assets/app/locales/de/messages.po +492 -0
- package/src/assets/app/locales/el/messages.po +492 -0
- package/src/assets/app/locales/en/messages.po +492 -0
- package/src/assets/app/locales/en-GB/messages.po +492 -0
- package/src/assets/app/locales/es/messages.po +492 -0
- package/src/assets/app/locales/eu/messages.po +492 -0
- package/src/assets/app/locales/fi/messages.po +492 -0
- package/src/assets/app/locales/fr/messages.po +492 -0
- package/src/assets/app/locales/ga/messages.po +492 -0
- package/src/assets/app/locales/gl/messages.po +492 -0
- package/src/assets/app/locales/hi/messages.po +492 -0
- package/src/assets/app/locales/hu/messages.po +492 -0
- package/src/assets/app/locales/ia/messages.po +492 -0
- package/src/assets/app/locales/id/messages.po +492 -0
- package/src/assets/app/locales/it/messages.po +492 -0
- package/src/assets/app/locales/ja/messages.po +492 -0
- package/src/assets/app/locales/km/messages.po +492 -0
- package/src/assets/app/locales/ko/messages.po +492 -0
- package/src/assets/app/locales/load.ts +8 -0
- package/src/assets/app/locales/locale-context.ts +19 -0
- package/src/assets/app/locales/locale-provider.tsx +112 -0
- package/src/assets/app/locales/locale-selector.tsx +58 -0
- package/src/assets/app/locales/locales.ts +168 -0
- package/src/assets/app/locales/ne/messages.po +492 -0
- package/src/assets/app/locales/nl/messages.po +492 -0
- package/src/assets/app/locales/pl/messages.po +492 -0
- package/src/assets/app/locales/pt-BR/messages.po +492 -0
- package/src/assets/app/locales/ro/messages.po +492 -0
- package/src/assets/app/locales/ru/messages.po +492 -0
- package/src/assets/app/locales/sv/messages.po +492 -0
- package/src/assets/app/locales/th/messages.po +492 -0
- package/src/assets/app/locales/tr/messages.po +492 -0
- package/src/assets/app/locales/uk/messages.po +492 -0
- package/src/assets/app/locales/vi/messages.po +492 -0
- package/src/assets/app/locales/zh-CN/messages.po +492 -0
- package/src/assets/app/locales/zh-HK/messages.po +492 -0
- package/src/assets/app/locales/zh-TW/messages.po +492 -0
- package/src/assets/app/main.css +23 -2
- package/src/assets/app/main.tsx +24 -8
- package/src/assets/app/views/authorize/accept/accept-form.tsx +150 -0
- package/src/assets/app/views/authorize/accept/accept-view.tsx +70 -0
- package/src/assets/app/views/authorize/authorize-view.tsx +180 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-confirm-form.tsx +88 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-request-form.tsx +80 -0
- package/src/assets/app/views/authorize/reset-password/reset-password-view.tsx +127 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-form.tsx +244 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-picker.tsx +116 -0
- package/src/assets/app/views/authorize/sign-in/sign-in-view.tsx +145 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-account-form.tsx +140 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-disclaimer.tsx +51 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-handle-form.tsx +289 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-hcaptcha-form.tsx +108 -0
- package/src/assets/app/views/authorize/sign-up/sign-up-view.tsx +158 -0
- package/src/assets/app/views/authorize/welcome/welcome-view.tsx +56 -0
- package/src/assets/app/views/error/error-view.tsx +31 -0
- package/src/assets/asset.ts +1 -0
- package/src/assets/assets-middleware.ts +13 -8
- package/src/assets/index.ts +15 -2
- package/src/client/client-store.ts +10 -12
- package/src/device/device-manager.ts +14 -15
- package/src/device/device-store.ts +9 -15
- package/src/dpop/dpop-manager.ts +20 -8
- package/src/dpop/dpop-nonce.ts +58 -40
- package/src/errors/handle-unavailable-error.ts +18 -0
- package/src/errors/invalid-request-error.ts +10 -8
- package/src/lib/csp/index.ts +98 -0
- package/src/lib/hcaptcha.ts +182 -0
- package/src/lib/html/build-document.ts +60 -16
- package/src/lib/http/middleware.ts +4 -3
- package/src/lib/http/request.ts +81 -28
- package/src/lib/http/response.ts +22 -9
- package/src/lib/locale.ts +21 -0
- package/src/lib/util/function.ts +0 -3
- package/src/lib/util/type.ts +130 -1
- package/src/metadata/build-metadata.ts +2 -1
- package/src/oauth-errors.ts +1 -0
- package/src/oauth-hooks.ts +69 -3
- package/src/oauth-provider.ts +410 -315
- package/src/oauth-verifier.ts +3 -1
- package/src/output/build-authorize-data.ts +1 -3
- package/src/output/build-customization-data.ts +189 -0
- package/src/output/output-manager.ts +111 -48
- package/src/output/send-authorize-redirect.ts +43 -36
- package/src/output/send-web-page.ts +40 -26
- package/src/request/request-manager.ts +4 -4
- package/src/request/request-store.ts +12 -16
- package/src/token/token-store.ts +14 -18
- package/tailwind.config.js +5 -0
- package/tsconfig.backend.tsbuildinfo +1 -1
- package/tsconfig.frontend.tsbuildinfo +1 -1
- package/tsconfig.tools.tsbuildinfo +1 -1
- package/vite.config.mjs +16 -0
- package/.postcssrc.yml +0 -3
- package/dist/assets/app/main.css +0 -3
- package/dist/assets/app/main.js +0 -20
- package/dist/assets/app/main.js.map +0 -1
- package/dist/output/customization.d.ts +0 -27
- package/dist/output/customization.d.ts.map +0 -1
- package/dist/output/customization.js +0 -88
- package/dist/output/customization.js.map +0 -1
- package/src/assets/app/components/accept-form.tsx +0 -137
- package/src/assets/app/components/account-identifier.tsx +0 -18
- package/src/assets/app/components/account-picker.tsx +0 -127
- package/src/assets/app/components/button.tsx +0 -34
- package/src/assets/app/components/client-name.tsx +0 -37
- package/src/assets/app/components/fieldset.tsx +0 -26
- package/src/assets/app/components/form-card.tsx +0 -47
- package/src/assets/app/components/help-card.tsx +0 -42
- package/src/assets/app/components/icons/alert-icon.tsx +0 -5
- package/src/assets/app/components/icons/at-symbol-icon.tsx +0 -5
- package/src/assets/app/components/icons/caret-right-icon.tsx +0 -5
- package/src/assets/app/components/icons/lock-icon.tsx +0 -5
- package/src/assets/app/components/icons/token-icon.tsx +0 -5
- package/src/assets/app/components/icons/util.tsx +0 -17
- package/src/assets/app/components/info-card.tsx +0 -45
- package/src/assets/app/components/input-checkbox.tsx +0 -47
- package/src/assets/app/components/input-container.tsx +0 -37
- package/src/assets/app/components/input-layout.tsx +0 -47
- package/src/assets/app/components/input-text.tsx +0 -69
- package/src/assets/app/components/layout-title-page.tsx +0 -60
- package/src/assets/app/components/layout-welcome.tsx +0 -74
- package/src/assets/app/components/sign-in-form.tsx +0 -337
- package/src/assets/app/components/sign-up-account-form.tsx +0 -194
- package/src/assets/app/components/sign-up-disclaimer.tsx +0 -44
- package/src/assets/app/views/accept-view.tsx +0 -55
- package/src/assets/app/views/authorize-view.tsx +0 -106
- package/src/assets/app/views/error-view.tsx +0 -36
- package/src/assets/app/views/sign-in-view.tsx +0 -111
- package/src/assets/app/views/sign-up-view.tsx +0 -86
- package/src/assets/app/views/welcome-view.tsx +0 -54
- package/src/output/customization.ts +0 -118
@@ -1,337 +0,0 @@
|
|
1
|
-
import { ReactNode, SyntheticEvent, useCallback, useState } from 'react'
|
2
|
-
|
3
|
-
import {
|
4
|
-
InvalidCredentialsError,
|
5
|
-
SecondAuthenticationFactorRequiredError,
|
6
|
-
} from '../lib/api'
|
7
|
-
import { clsx } from '../lib/clsx'
|
8
|
-
import { Override } from '../lib/util'
|
9
|
-
import { Button } from './button'
|
10
|
-
import { FormCard, FormCardProps } from './form-card'
|
11
|
-
import { AtSymbolIcon } from './icons/at-symbol-icon'
|
12
|
-
import { LockIcon } from './icons/lock-icon'
|
13
|
-
import { InfoCard } from './info-card'
|
14
|
-
import { InputCheckbox } from './input-checkbox'
|
15
|
-
import { InputText } from './input-text'
|
16
|
-
import { TokenIcon } from './icons/token-icon'
|
17
|
-
import { Fieldset } from './fieldset'
|
18
|
-
|
19
|
-
export type SignInFormOutput = {
|
20
|
-
username: string
|
21
|
-
password: string
|
22
|
-
remember?: boolean
|
23
|
-
}
|
24
|
-
|
25
|
-
export type SignInFormProps = Override<
|
26
|
-
FormCardProps,
|
27
|
-
{
|
28
|
-
onSubmit: (credentials: SignInFormOutput) => void | PromiseLike<void>
|
29
|
-
submitLabel?: ReactNode
|
30
|
-
submitAria?: string
|
31
|
-
|
32
|
-
onCancel?: () => void
|
33
|
-
cancelLabel?: ReactNode
|
34
|
-
cancelAria?: string
|
35
|
-
|
36
|
-
accountSection?: ReactNode
|
37
|
-
sessionSection?: ReactNode
|
38
|
-
secondFactorSection?: ReactNode
|
39
|
-
|
40
|
-
usernameDefault?: string
|
41
|
-
usernameReadonly?: boolean
|
42
|
-
usernameLabel?: string
|
43
|
-
usernamePlaceholder?: string
|
44
|
-
usernameAria?: string
|
45
|
-
usernamePattern?: string
|
46
|
-
usernameFormat?: string
|
47
|
-
|
48
|
-
passwordLabel?: string
|
49
|
-
passwordPlaceholder?: string
|
50
|
-
passwordWarning?: ReactNode
|
51
|
-
passwordAria?: string
|
52
|
-
passwordPattern?: string
|
53
|
-
passwordFormat?: string
|
54
|
-
|
55
|
-
secondFactorLabel?: string
|
56
|
-
secondFactorPlaceholder?: string
|
57
|
-
secondFactorAria?: string
|
58
|
-
secondFactorPattern?: string
|
59
|
-
secondFactorFormat?: string
|
60
|
-
secondFactorHint?: string
|
61
|
-
secondFactorParseValue?: (value: string) => string | false
|
62
|
-
|
63
|
-
rememberVisible?: boolean
|
64
|
-
rememberDefault?: boolean
|
65
|
-
rememberLabel?: string
|
66
|
-
rememberAria?: string
|
67
|
-
}
|
68
|
-
>
|
69
|
-
|
70
|
-
export function SignInForm({
|
71
|
-
onSubmit,
|
72
|
-
submitAria = 'Next',
|
73
|
-
submitLabel = submitAria,
|
74
|
-
|
75
|
-
onCancel = undefined,
|
76
|
-
cancelAria = 'Cancel',
|
77
|
-
cancelLabel = cancelAria,
|
78
|
-
|
79
|
-
accountSection = 'Account',
|
80
|
-
sessionSection = 'Session',
|
81
|
-
secondFactorSection = '2FA Confirmation',
|
82
|
-
|
83
|
-
usernameDefault = '',
|
84
|
-
usernameReadonly = false,
|
85
|
-
usernameLabel = 'Username or email address',
|
86
|
-
usernameAria = usernameLabel,
|
87
|
-
usernamePlaceholder = usernameLabel,
|
88
|
-
usernamePattern = undefined,
|
89
|
-
usernameFormat = 'valid email address or username',
|
90
|
-
|
91
|
-
passwordLabel = 'Password',
|
92
|
-
passwordAria = passwordLabel,
|
93
|
-
passwordPlaceholder = passwordLabel,
|
94
|
-
passwordPattern = undefined,
|
95
|
-
passwordFormat = 'non empty string',
|
96
|
-
passwordWarning = (
|
97
|
-
<>
|
98
|
-
<p className="font-bold text-brand leading-8">Warning</p>
|
99
|
-
<p>
|
100
|
-
Please verify the domain name of the website before entering your
|
101
|
-
password. Never enter your password on a domain you do not trust.
|
102
|
-
</p>
|
103
|
-
</>
|
104
|
-
),
|
105
|
-
|
106
|
-
secondFactorLabel = 'Confirmation code',
|
107
|
-
secondFactorAria = secondFactorLabel,
|
108
|
-
secondFactorPlaceholder = secondFactorLabel,
|
109
|
-
secondFactorPattern = '^[A-Z2-7]{5}-[A-Z2-7]{5}$',
|
110
|
-
secondFactorFormat = 'XXXXX-XXXXX',
|
111
|
-
secondFactorHint = 'Check your $1 email for a login code and enter it here.',
|
112
|
-
secondFactorParseValue = checkAndFormatEmailOtpCode,
|
113
|
-
|
114
|
-
rememberVisible = true,
|
115
|
-
rememberDefault = false,
|
116
|
-
rememberLabel = 'Remember this account on this device',
|
117
|
-
rememberAria = rememberLabel,
|
118
|
-
|
119
|
-
...props
|
120
|
-
}: SignInFormProps) {
|
121
|
-
const [focused, setFocused] = useState(false)
|
122
|
-
const [loading, setLoading] = useState(false)
|
123
|
-
const [secondFactor, setSecondFactor] = useState<null | {
|
124
|
-
type: 'emailOtp'
|
125
|
-
hint: string
|
126
|
-
}>(null)
|
127
|
-
|
128
|
-
const [errorMessage, setErrorMessage] = useState<string | null>(null)
|
129
|
-
|
130
|
-
const resetState = useCallback(() => {
|
131
|
-
setSecondFactor(null)
|
132
|
-
setErrorMessage(null)
|
133
|
-
}, [])
|
134
|
-
|
135
|
-
const passwordReadonly = secondFactor != null
|
136
|
-
|
137
|
-
const doSubmit = useCallback(
|
138
|
-
async (
|
139
|
-
event: SyntheticEvent<
|
140
|
-
HTMLFormElement & {
|
141
|
-
username: HTMLInputElement
|
142
|
-
password: HTMLInputElement
|
143
|
-
remember?: HTMLInputElement
|
144
|
-
secondFactor?: HTMLInputElement
|
145
|
-
},
|
146
|
-
SubmitEvent
|
147
|
-
>,
|
148
|
-
) => {
|
149
|
-
event.preventDefault()
|
150
|
-
|
151
|
-
const credentials: SignInFormOutput = {
|
152
|
-
username: event.currentTarget.username.value,
|
153
|
-
password: event.currentTarget.password.value,
|
154
|
-
remember: event.currentTarget.remember?.checked,
|
155
|
-
}
|
156
|
-
|
157
|
-
if (secondFactor) {
|
158
|
-
const element = event.currentTarget.secondFactor
|
159
|
-
if (!element) throw new Error('Second factor input not found')
|
160
|
-
const value = secondFactorParseValue(element.value)
|
161
|
-
if (!value) {
|
162
|
-
setSecondFactor({
|
163
|
-
type: secondFactor.type,
|
164
|
-
hint: `Make sure to match the format: ${secondFactorFormat}`,
|
165
|
-
})
|
166
|
-
return
|
167
|
-
}
|
168
|
-
credentials[secondFactor.type] = value
|
169
|
-
}
|
170
|
-
|
171
|
-
setLoading(true)
|
172
|
-
setErrorMessage(null)
|
173
|
-
try {
|
174
|
-
await onSubmit(credentials)
|
175
|
-
} catch (err) {
|
176
|
-
if (err instanceof SecondAuthenticationFactorRequiredError) {
|
177
|
-
setSecondFactor({
|
178
|
-
type: err.type,
|
179
|
-
hint: err.hint,
|
180
|
-
})
|
181
|
-
} else {
|
182
|
-
setErrorMessage(parseErrorMessage(err))
|
183
|
-
}
|
184
|
-
} finally {
|
185
|
-
setLoading(false)
|
186
|
-
}
|
187
|
-
},
|
188
|
-
[secondFactor, onSubmit],
|
189
|
-
)
|
190
|
-
|
191
|
-
return (
|
192
|
-
<FormCard
|
193
|
-
onSubmit={doSubmit}
|
194
|
-
error={errorMessage}
|
195
|
-
cancel={
|
196
|
-
onCancel && (
|
197
|
-
<Button aria-label={cancelAria} onClick={onCancel}>
|
198
|
-
{cancelLabel}
|
199
|
-
</Button>
|
200
|
-
)
|
201
|
-
}
|
202
|
-
actions={
|
203
|
-
<Button
|
204
|
-
color="brand"
|
205
|
-
type="submit"
|
206
|
-
aria-label={submitAria}
|
207
|
-
loading={loading}
|
208
|
-
>
|
209
|
-
{submitLabel}
|
210
|
-
</Button>
|
211
|
-
}
|
212
|
-
{...props}
|
213
|
-
>
|
214
|
-
<Fieldset title={accountSection} disabled={loading}>
|
215
|
-
<InputText
|
216
|
-
icon={<AtSymbolIcon className="w-5" />}
|
217
|
-
name="username"
|
218
|
-
type="text"
|
219
|
-
onChange={resetState}
|
220
|
-
placeholder={usernamePlaceholder}
|
221
|
-
aria-label={usernameAria}
|
222
|
-
autoCapitalize="none"
|
223
|
-
autoCorrect="off"
|
224
|
-
autoComplete="username"
|
225
|
-
spellCheck="false"
|
226
|
-
dir="auto"
|
227
|
-
enterKeyHint="next"
|
228
|
-
required
|
229
|
-
defaultValue={usernameDefault}
|
230
|
-
readOnly={usernameReadonly}
|
231
|
-
disabled={usernameReadonly}
|
232
|
-
pattern={usernamePattern}
|
233
|
-
title={usernameFormat}
|
234
|
-
/>
|
235
|
-
|
236
|
-
<InputText
|
237
|
-
icon={<LockIcon className="w-5" />}
|
238
|
-
name="password"
|
239
|
-
type="password"
|
240
|
-
onChange={resetState}
|
241
|
-
onFocus={() => setFocused(true)}
|
242
|
-
onBlur={() => setTimeout(setFocused, 100, false)}
|
243
|
-
placeholder={passwordPlaceholder}
|
244
|
-
aria-label={passwordAria}
|
245
|
-
autoCapitalize="none"
|
246
|
-
autoCorrect="off"
|
247
|
-
autoComplete="current-password"
|
248
|
-
dir="auto"
|
249
|
-
enterKeyHint="done"
|
250
|
-
spellCheck="false"
|
251
|
-
required
|
252
|
-
readOnly={passwordReadonly}
|
253
|
-
disabled={passwordReadonly}
|
254
|
-
pattern={passwordPattern}
|
255
|
-
title={passwordFormat}
|
256
|
-
/>
|
257
|
-
|
258
|
-
{passwordWarning && (
|
259
|
-
<div
|
260
|
-
className={clsx(
|
261
|
-
'transition-all delay-300 duration-300 overflow-hidden',
|
262
|
-
focused ? 'max-h-80' : 'max-h-0 -z-10 !mt-0',
|
263
|
-
)}
|
264
|
-
>
|
265
|
-
<InfoCard role="status">{passwordWarning}</InfoCard>
|
266
|
-
</div>
|
267
|
-
)}
|
268
|
-
</Fieldset>
|
269
|
-
|
270
|
-
{rememberVisible && (
|
271
|
-
<Fieldset key="remember" title={sessionSection} disabled={loading}>
|
272
|
-
<InputCheckbox
|
273
|
-
name="remember"
|
274
|
-
defaultChecked={rememberDefault}
|
275
|
-
aria-label={rememberAria}
|
276
|
-
>
|
277
|
-
{rememberLabel}
|
278
|
-
</InputCheckbox>
|
279
|
-
</Fieldset>
|
280
|
-
)}
|
281
|
-
|
282
|
-
{secondFactor && (
|
283
|
-
<Fieldset key="2fa" title={secondFactorSection} disabled={loading}>
|
284
|
-
<div>
|
285
|
-
<InputText
|
286
|
-
icon={<TokenIcon className="w-5" />}
|
287
|
-
name="secondFactor"
|
288
|
-
type="text"
|
289
|
-
placeholder={secondFactorPlaceholder}
|
290
|
-
aria-label={secondFactorAria}
|
291
|
-
autoCapitalize="none"
|
292
|
-
autoCorrect="off"
|
293
|
-
autoComplete="off"
|
294
|
-
spellCheck="false"
|
295
|
-
dir="auto"
|
296
|
-
enterKeyHint="done"
|
297
|
-
required
|
298
|
-
pattern={secondFactorPattern}
|
299
|
-
title={secondFactorFormat}
|
300
|
-
autoFocus={true}
|
301
|
-
/>
|
302
|
-
<p className="text-slate-600 dark:text-slate-400 text-sm">
|
303
|
-
{secondFactorHint.replaceAll('$1', secondFactor.hint)}
|
304
|
-
</p>
|
305
|
-
</div>
|
306
|
-
</Fieldset>
|
307
|
-
)}
|
308
|
-
</FormCard>
|
309
|
-
)
|
310
|
-
}
|
311
|
-
|
312
|
-
function parseErrorMessage(err: unknown): string {
|
313
|
-
if (err instanceof InvalidCredentialsError) {
|
314
|
-
return 'Invalid username or password'
|
315
|
-
}
|
316
|
-
|
317
|
-
return 'An unknown error occurred'
|
318
|
-
}
|
319
|
-
|
320
|
-
export function checkAndFormatEmailOtpCode(code: string): string | false {
|
321
|
-
const EMAIL_CODE_REGEX = /^[A-Z2-7]{5}-[A-Z2-7]{5}$/
|
322
|
-
|
323
|
-
// Trim the reset code
|
324
|
-
let fixed = code.trim().toUpperCase()
|
325
|
-
|
326
|
-
// Add a dash if needed
|
327
|
-
if (fixed.length === 10) {
|
328
|
-
fixed = `${fixed.slice(0, 5)}-${fixed.slice(5, 10)}`
|
329
|
-
}
|
330
|
-
|
331
|
-
// Check that it is a valid format
|
332
|
-
if (!EMAIL_CODE_REGEX.test(fixed)) {
|
333
|
-
return false
|
334
|
-
}
|
335
|
-
|
336
|
-
return fixed
|
337
|
-
}
|
@@ -1,194 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
FormHTMLAttributes,
|
3
|
-
ReactNode,
|
4
|
-
SyntheticEvent,
|
5
|
-
useCallback,
|
6
|
-
useState,
|
7
|
-
} from 'react'
|
8
|
-
|
9
|
-
import { Button } from './button'
|
10
|
-
import { FormCard, FormCardProps } from './form-card'
|
11
|
-
import { Override } from '../lib/util'
|
12
|
-
import { Fieldset } from './fieldset'
|
13
|
-
|
14
|
-
export type SignUpAccountFormOutput = {
|
15
|
-
username: string
|
16
|
-
password: string
|
17
|
-
}
|
18
|
-
|
19
|
-
export type SignUpAccountFormProps = Override<
|
20
|
-
FormCardProps,
|
21
|
-
{
|
22
|
-
onSubmit: (credentials: SignUpAccountFormOutput) => void | PromiseLike<void>
|
23
|
-
submitLabel?: ReactNode
|
24
|
-
submitAria?: string
|
25
|
-
|
26
|
-
onCancel?: () => void
|
27
|
-
cancelLabel?: ReactNode
|
28
|
-
cancelAria?: string
|
29
|
-
|
30
|
-
username?: string
|
31
|
-
usernamePlaceholder?: string
|
32
|
-
usernameLabel?: string
|
33
|
-
usernameAria?: string
|
34
|
-
usernamePattern?: string
|
35
|
-
usernameTitle?: string
|
36
|
-
|
37
|
-
passwordPlaceholder?: string
|
38
|
-
passwordLabel?: string
|
39
|
-
passwordAria?: string
|
40
|
-
passwordPattern?: string
|
41
|
-
passwordTitle?: string
|
42
|
-
}
|
43
|
-
>
|
44
|
-
|
45
|
-
export function SignUpAccountForm({
|
46
|
-
onSubmit,
|
47
|
-
submitAria = 'Next',
|
48
|
-
submitLabel = submitAria,
|
49
|
-
|
50
|
-
onCancel = undefined,
|
51
|
-
cancelAria = 'Cancel',
|
52
|
-
cancelLabel = cancelAria,
|
53
|
-
|
54
|
-
username: defaultUsername = '',
|
55
|
-
usernameLabel = 'Username',
|
56
|
-
usernameAria = usernameLabel,
|
57
|
-
usernamePlaceholder = usernameLabel,
|
58
|
-
usernamePattern,
|
59
|
-
usernameTitle,
|
60
|
-
|
61
|
-
passwordLabel = 'Password',
|
62
|
-
passwordAria = passwordLabel,
|
63
|
-
passwordPlaceholder = passwordLabel,
|
64
|
-
passwordPattern,
|
65
|
-
passwordTitle,
|
66
|
-
|
67
|
-
children,
|
68
|
-
...props
|
69
|
-
}: SignUpAccountFormProps &
|
70
|
-
Omit<FormHTMLAttributes<HTMLFormElement>, keyof SignUpAccountFormProps>) {
|
71
|
-
const [loading, setLoading] = useState(false)
|
72
|
-
const [errorMessage, setErrorMessage] = useState<string | null>(null)
|
73
|
-
|
74
|
-
const doSubmit = useCallback(
|
75
|
-
async (
|
76
|
-
event: SyntheticEvent<
|
77
|
-
HTMLFormElement & {
|
78
|
-
username: HTMLInputElement
|
79
|
-
password: HTMLInputElement
|
80
|
-
},
|
81
|
-
SubmitEvent
|
82
|
-
>,
|
83
|
-
) => {
|
84
|
-
event.preventDefault()
|
85
|
-
|
86
|
-
const credentials = {
|
87
|
-
username: event.currentTarget.username.value,
|
88
|
-
password: event.currentTarget.password.value,
|
89
|
-
}
|
90
|
-
|
91
|
-
setLoading(true)
|
92
|
-
setErrorMessage(null)
|
93
|
-
try {
|
94
|
-
await onSubmit(credentials)
|
95
|
-
} catch (err) {
|
96
|
-
setErrorMessage(parseErrorMessage(err))
|
97
|
-
} finally {
|
98
|
-
setLoading(false)
|
99
|
-
}
|
100
|
-
},
|
101
|
-
[onSubmit, setErrorMessage, setLoading],
|
102
|
-
)
|
103
|
-
|
104
|
-
return (
|
105
|
-
<FormCard
|
106
|
-
append={children}
|
107
|
-
error={errorMessage}
|
108
|
-
onSubmit={doSubmit}
|
109
|
-
cancel={
|
110
|
-
onCancel && (
|
111
|
-
<Button aria-label={cancelAria} onClick={onCancel}>
|
112
|
-
{cancelLabel}
|
113
|
-
</Button>
|
114
|
-
)
|
115
|
-
}
|
116
|
-
actions={
|
117
|
-
<Button
|
118
|
-
color="brand"
|
119
|
-
type="submit"
|
120
|
-
aria-label={submitAria}
|
121
|
-
disabled={loading}
|
122
|
-
>
|
123
|
-
{submitLabel}
|
124
|
-
</Button>
|
125
|
-
}
|
126
|
-
{...props}
|
127
|
-
>
|
128
|
-
<Fieldset disabled={loading}>
|
129
|
-
<label className="text-sm font-medium block">
|
130
|
-
<p>{usernameLabel}</p>
|
131
|
-
|
132
|
-
<div className="relative flex flex-wrap items-center justify-stretch rounded-md border border-solid border-slate-200 dark:border-slate-700 text-neutral-700 dark:text-neutral-100">
|
133
|
-
<span className="w-6 ml-1 text-center text-base">@</span>
|
134
|
-
<input
|
135
|
-
name="username"
|
136
|
-
type="text"
|
137
|
-
onChange={() => setErrorMessage(null)}
|
138
|
-
className="relative m-1 block w-[1px] min-w-0 flex-auto leading-[1.6] bg-transparent bg-clip-padding text-base text-inherit outline-none dark:placeholder:text-neutral-100 disabled:text-gray-500"
|
139
|
-
placeholder={usernamePlaceholder}
|
140
|
-
aria-label={usernameAria}
|
141
|
-
autoCapitalize="none"
|
142
|
-
autoCorrect="off"
|
143
|
-
autoComplete="username"
|
144
|
-
spellCheck="false"
|
145
|
-
dir="auto"
|
146
|
-
enterKeyHint="next"
|
147
|
-
required
|
148
|
-
defaultValue={defaultUsername}
|
149
|
-
pattern={usernamePattern}
|
150
|
-
title={usernameTitle}
|
151
|
-
/>
|
152
|
-
</div>
|
153
|
-
</label>
|
154
|
-
|
155
|
-
<label className="text-sm font-medium block">
|
156
|
-
<p>{passwordLabel}</p>
|
157
|
-
|
158
|
-
<div className="relative flex flex-wrap items-center justify-stretch rounded-md border border-solid border-slate-200 dark:border-slate-700 text-neutral-700 dark:text-neutral-100">
|
159
|
-
<span className="w-6 ml-1 text-center text-2xl font-light -mb-2">
|
160
|
-
*
|
161
|
-
</span>
|
162
|
-
<input
|
163
|
-
name="password"
|
164
|
-
type="password"
|
165
|
-
onChange={() => setErrorMessage(null)}
|
166
|
-
className="relative m-1 block w-[1px] min-w-0 flex-auto leading-[1.6] bg-transparent bg-clip-padding text-base text-inherit outline-none dark:placeholder:text-neutral-100"
|
167
|
-
placeholder={passwordPlaceholder}
|
168
|
-
aria-label={passwordAria}
|
169
|
-
autoCapitalize="none"
|
170
|
-
autoCorrect="off"
|
171
|
-
autoComplete="new-password"
|
172
|
-
dir="auto"
|
173
|
-
enterKeyHint="done"
|
174
|
-
spellCheck="false"
|
175
|
-
required
|
176
|
-
pattern={passwordPattern}
|
177
|
-
title={passwordTitle}
|
178
|
-
/>
|
179
|
-
</div>
|
180
|
-
</label>
|
181
|
-
</Fieldset>
|
182
|
-
</FormCard>
|
183
|
-
)
|
184
|
-
}
|
185
|
-
|
186
|
-
function parseErrorMessage(err: unknown): string {
|
187
|
-
switch ((err as any)?.message) {
|
188
|
-
case 'Invalid credentials':
|
189
|
-
return 'Invalid username or password'
|
190
|
-
default:
|
191
|
-
console.error(err)
|
192
|
-
return 'An unknown error occurred'
|
193
|
-
}
|
194
|
-
}
|
@@ -1,44 +0,0 @@
|
|
1
|
-
import { HTMLAttributes } from 'react'
|
2
|
-
import { LinkDefinition } from '../backend-data'
|
3
|
-
import { clsx } from '../lib/clsx'
|
4
|
-
|
5
|
-
export type SignUpDisclaimerProps = {
|
6
|
-
links?: readonly LinkDefinition[]
|
7
|
-
}
|
8
|
-
|
9
|
-
export function SignUpDisclaimer({
|
10
|
-
links,
|
11
|
-
|
12
|
-
className,
|
13
|
-
...attrs
|
14
|
-
}: SignUpDisclaimerProps &
|
15
|
-
Omit<
|
16
|
-
HTMLAttributes<HTMLParagraphElement>,
|
17
|
-
keyof SignUpDisclaimerProps | 'children'
|
18
|
-
>) {
|
19
|
-
const relevantLinks = links?.filter(
|
20
|
-
(l) => l.rel === 'privacy-policy' || l.rel === 'terms-of-service',
|
21
|
-
)
|
22
|
-
|
23
|
-
return (
|
24
|
-
<p className={clsx('text-sm text-slate-500', className)} {...attrs}>
|
25
|
-
By creating an account you agree to the{' '}
|
26
|
-
{relevantLinks && relevantLinks.length
|
27
|
-
? relevantLinks.map((l, i, a) => (
|
28
|
-
<span key={i}>
|
29
|
-
{i > 0 && (i < a.length - 1 ? ', ' : ' and ')}
|
30
|
-
<a
|
31
|
-
href={l.href}
|
32
|
-
rel={l.rel}
|
33
|
-
target="_blank"
|
34
|
-
className="text-brand underline"
|
35
|
-
>
|
36
|
-
{l.title}
|
37
|
-
</a>
|
38
|
-
</span>
|
39
|
-
))
|
40
|
-
: 'Terms of Service and Privacy Policy'}
|
41
|
-
.
|
42
|
-
</p>
|
43
|
-
)
|
44
|
-
}
|
@@ -1,55 +0,0 @@
|
|
1
|
-
import { OAuthClientMetadata } from '@atproto/oauth-types'
|
2
|
-
|
3
|
-
import { Account, ScopeDetail } from '../backend-data'
|
4
|
-
import { AcceptForm } from '../components/accept-form'
|
5
|
-
import { LayoutTitlePage } from '../components/layout-title-page'
|
6
|
-
|
7
|
-
export type AcceptViewProps = {
|
8
|
-
clientId: string
|
9
|
-
clientMetadata: OAuthClientMetadata
|
10
|
-
clientTrusted: boolean
|
11
|
-
|
12
|
-
account: Account
|
13
|
-
scopeDetails?: ScopeDetail[]
|
14
|
-
|
15
|
-
onAccept: () => void
|
16
|
-
onReject: () => void
|
17
|
-
onBack?: () => void
|
18
|
-
}
|
19
|
-
|
20
|
-
export function AcceptView({
|
21
|
-
clientId,
|
22
|
-
clientMetadata,
|
23
|
-
clientTrusted,
|
24
|
-
account,
|
25
|
-
scopeDetails,
|
26
|
-
onAccept,
|
27
|
-
onReject,
|
28
|
-
onBack,
|
29
|
-
}: AcceptViewProps) {
|
30
|
-
return (
|
31
|
-
<LayoutTitlePage
|
32
|
-
title="Authorize"
|
33
|
-
subtitle={
|
34
|
-
<>
|
35
|
-
Grant access to your{' '}
|
36
|
-
<b className="text-black dark:text-white">
|
37
|
-
{account.preferred_username || account.email || account.sub}
|
38
|
-
</b>{' '}
|
39
|
-
account
|
40
|
-
</>
|
41
|
-
}
|
42
|
-
>
|
43
|
-
<AcceptForm
|
44
|
-
clientId={clientId}
|
45
|
-
clientMetadata={clientMetadata}
|
46
|
-
clientTrusted={clientTrusted}
|
47
|
-
account={account}
|
48
|
-
scopeDetails={scopeDetails}
|
49
|
-
onBack={onBack}
|
50
|
-
onAccept={onAccept}
|
51
|
-
onReject={onReject}
|
52
|
-
/>
|
53
|
-
</LayoutTitlePage>
|
54
|
-
)
|
55
|
-
}
|