@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,45 +0,0 @@
|
|
1
|
-
import { clsx } from '../lib/clsx'
|
2
|
-
import { Override } from '../lib/util'
|
3
|
-
import { AlertIcon } from './icons/alert-icon'
|
4
|
-
import { InputLayout, InputLayoutProps } from './input-layout'
|
5
|
-
|
6
|
-
export type InfoCardProps = Override<
|
7
|
-
InputLayoutProps,
|
8
|
-
{
|
9
|
-
role: 'alert' | 'status'
|
10
|
-
}
|
11
|
-
>
|
12
|
-
|
13
|
-
export function InfoCard({
|
14
|
-
children,
|
15
|
-
className,
|
16
|
-
role = 'alert',
|
17
|
-
...props
|
18
|
-
}: InfoCardProps) {
|
19
|
-
return (
|
20
|
-
<InputLayout
|
21
|
-
className={clsx(
|
22
|
-
role === 'alert' ? 'bg-error' : 'bg-gray-100 dark:bg-slate-800',
|
23
|
-
className,
|
24
|
-
)}
|
25
|
-
icon={
|
26
|
-
<AlertIcon
|
27
|
-
className={clsx(
|
28
|
-
'fill-current h-4 w-4',
|
29
|
-
role === 'alert' ? 'text-white' : 'text-brand',
|
30
|
-
)}
|
31
|
-
/>
|
32
|
-
}
|
33
|
-
{...props}
|
34
|
-
>
|
35
|
-
<div
|
36
|
-
className={clsx(
|
37
|
-
'py-2 overflow-hidden',
|
38
|
-
role === 'alert' ? 'text-white' : undefined,
|
39
|
-
)}
|
40
|
-
>
|
41
|
-
{children}
|
42
|
-
</div>
|
43
|
-
</InputLayout>
|
44
|
-
)
|
45
|
-
}
|
@@ -1,47 +0,0 @@
|
|
1
|
-
import { InputHTMLAttributes, useRef, useState } from 'react'
|
2
|
-
import { InputContainer } from './input-container'
|
3
|
-
|
4
|
-
const generateUniqueId = () => Math.random().toString(36).slice(2)
|
5
|
-
|
6
|
-
export type InputCheckboxProps = Omit<
|
7
|
-
InputHTMLAttributes<HTMLInputElement>,
|
8
|
-
'type'
|
9
|
-
>
|
10
|
-
|
11
|
-
export function InputCheckbox({
|
12
|
-
id,
|
13
|
-
children,
|
14
|
-
className,
|
15
|
-
...props
|
16
|
-
}: InputCheckboxProps) {
|
17
|
-
const [htmlFor] = useState(generateUniqueId)
|
18
|
-
const ref = useRef<HTMLDivElement>(null)
|
19
|
-
const inputRef = useRef<HTMLInputElement>(null)
|
20
|
-
|
21
|
-
return (
|
22
|
-
<InputContainer
|
23
|
-
id={id}
|
24
|
-
ref={ref}
|
25
|
-
icon={
|
26
|
-
<input
|
27
|
-
{...props}
|
28
|
-
ref={inputRef}
|
29
|
-
id={htmlFor}
|
30
|
-
className="text-brand outline-none"
|
31
|
-
type="checkbox"
|
32
|
-
/>
|
33
|
-
}
|
34
|
-
className={className}
|
35
|
-
onClick={(event) => {
|
36
|
-
if (event.target === ref.current && !event.defaultPrevented) {
|
37
|
-
inputRef.current?.click()
|
38
|
-
inputRef.current?.focus()
|
39
|
-
}
|
40
|
-
}}
|
41
|
-
>
|
42
|
-
<label htmlFor={htmlFor} className="block w-full leading-[1.6]">
|
43
|
-
{children}
|
44
|
-
</label>
|
45
|
-
</InputContainer>
|
46
|
-
)
|
47
|
-
}
|
@@ -1,37 +0,0 @@
|
|
1
|
-
import { forwardRef, useState } from 'react'
|
2
|
-
import { clsx } from '../lib/clsx'
|
3
|
-
import { InputLayout, InputLayoutProps } from './input-layout'
|
4
|
-
|
5
|
-
export type InputContainerProps = InputLayoutProps
|
6
|
-
|
7
|
-
export const InputContainer = forwardRef<HTMLDivElement, InputContainerProps>(
|
8
|
-
({ className, onFocus, icon, onBlur, ...props }, ref) => {
|
9
|
-
const [focused, setFocused] = useState(false)
|
10
|
-
|
11
|
-
return (
|
12
|
-
<InputLayout
|
13
|
-
ref={ref}
|
14
|
-
className={clsx(
|
15
|
-
// Background
|
16
|
-
'bg-gray-100 has-[:focus]:bg-slate-200',
|
17
|
-
'dark:bg-slate-800 dark:has-[:focus]:bg-slate-700',
|
18
|
-
// Border
|
19
|
-
'outline-none',
|
20
|
-
'border-solid border-2 border-transparent hover:border-gray-400 has-[:focus]:border-brand hover:has-[:focus]:border-brand',
|
21
|
-
'dark:hover:border-gray-500',
|
22
|
-
className,
|
23
|
-
)}
|
24
|
-
onFocus={(event) => {
|
25
|
-
onFocus?.(event)
|
26
|
-
if (!event.defaultPrevented) setFocused(true)
|
27
|
-
}}
|
28
|
-
onBlur={(event) => {
|
29
|
-
onBlur?.(event)
|
30
|
-
if (!event.defaultPrevented) setFocused(false)
|
31
|
-
}}
|
32
|
-
icon={<div className={focused ? 'text-brand' : undefined}>{icon}</div>}
|
33
|
-
{...props}
|
34
|
-
/>
|
35
|
-
)
|
36
|
-
},
|
37
|
-
)
|
@@ -1,47 +0,0 @@
|
|
1
|
-
import { forwardRef, HTMLAttributes, ReactNode } from 'react'
|
2
|
-
import { clsx } from '../lib/clsx'
|
3
|
-
import { Override } from '../lib/util'
|
4
|
-
|
5
|
-
export type InputLayoutProps = Override<
|
6
|
-
HTMLAttributes<HTMLDivElement>,
|
7
|
-
{
|
8
|
-
icon?: ReactNode
|
9
|
-
append?: ReactNode
|
10
|
-
}
|
11
|
-
>
|
12
|
-
|
13
|
-
export const InputLayout = forwardRef<HTMLDivElement, InputLayoutProps>(
|
14
|
-
({ className, icon, append, children, ...props }, ref) => {
|
15
|
-
return (
|
16
|
-
<div
|
17
|
-
ref={ref}
|
18
|
-
className={clsx(
|
19
|
-
// Layout
|
20
|
-
'pl-1 pr-2', // Less padding on the left because icon will provide some
|
21
|
-
'min-h-12',
|
22
|
-
'flex items-center justify-stretch',
|
23
|
-
// Border
|
24
|
-
'rounded-lg',
|
25
|
-
// Font
|
26
|
-
'text-gray-700',
|
27
|
-
'dark:text-gray-100',
|
28
|
-
className,
|
29
|
-
)}
|
30
|
-
{...props}
|
31
|
-
>
|
32
|
-
<div
|
33
|
-
className={clsx(
|
34
|
-
'self-start shrink-0 grow-0',
|
35
|
-
'w-8 h-12',
|
36
|
-
'flex items-center justify-center',
|
37
|
-
'text-gray-500',
|
38
|
-
)}
|
39
|
-
>
|
40
|
-
{icon}
|
41
|
-
</div>
|
42
|
-
<div className="flex-auto relative">{children}</div>
|
43
|
-
{append && <div className="grow-0 shrink-0">{append}</div>}
|
44
|
-
</div>
|
45
|
-
)
|
46
|
-
},
|
47
|
-
)
|
@@ -1,69 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
forwardRef,
|
3
|
-
InputHTMLAttributes,
|
4
|
-
MouseEventHandler,
|
5
|
-
ReactNode,
|
6
|
-
useCallback,
|
7
|
-
useImperativeHandle,
|
8
|
-
useRef,
|
9
|
-
useState,
|
10
|
-
} from 'react'
|
11
|
-
import { InputContainer } from './input-container'
|
12
|
-
|
13
|
-
export const InputText = forwardRef<
|
14
|
-
HTMLInputElement,
|
15
|
-
{
|
16
|
-
icon?: ReactNode
|
17
|
-
} & InputHTMLAttributes<HTMLInputElement>
|
18
|
-
>(({ className, icon, children, onFocus, onBlur, ...props }, ref) => {
|
19
|
-
const [focused, setFocused] = useState(false)
|
20
|
-
const inputRef = useRef<HTMLInputElement>(null)
|
21
|
-
|
22
|
-
useImperativeHandle(ref, () => inputRef.current!, [])
|
23
|
-
|
24
|
-
const handleClick = useCallback<MouseEventHandler<HTMLDivElement>>(
|
25
|
-
(event) => {
|
26
|
-
if (inputRef.current !== event.target) {
|
27
|
-
event.preventDefault()
|
28
|
-
event.stopPropagation()
|
29
|
-
inputRef.current?.focus()
|
30
|
-
}
|
31
|
-
},
|
32
|
-
[],
|
33
|
-
)
|
34
|
-
|
35
|
-
const handleMouseDown = useCallback<MouseEventHandler<HTMLDivElement>>(
|
36
|
-
(event) => {
|
37
|
-
if (focused && event.target !== inputRef.current) {
|
38
|
-
// Prevent "blur" event from firing when clicking outside the input
|
39
|
-
event.preventDefault()
|
40
|
-
event.stopPropagation()
|
41
|
-
}
|
42
|
-
},
|
43
|
-
[focused],
|
44
|
-
)
|
45
|
-
|
46
|
-
return (
|
47
|
-
<InputContainer
|
48
|
-
icon={icon}
|
49
|
-
className={className}
|
50
|
-
onClick={handleClick}
|
51
|
-
onMouseDown={handleMouseDown}
|
52
|
-
>
|
53
|
-
<input
|
54
|
-
ref={inputRef}
|
55
|
-
className="w-full bg-transparent bg-clip-padding text-base text-inherit outline-none dark:placeholder-gray-500"
|
56
|
-
onFocus={(event) => {
|
57
|
-
setFocused(true)
|
58
|
-
onFocus?.(event)
|
59
|
-
}}
|
60
|
-
onBlur={(event) => {
|
61
|
-
setFocused(false)
|
62
|
-
onBlur?.(event)
|
63
|
-
}}
|
64
|
-
{...props}
|
65
|
-
/>
|
66
|
-
{children}
|
67
|
-
</InputContainer>
|
68
|
-
)
|
69
|
-
})
|
@@ -1,60 +0,0 @@
|
|
1
|
-
import { HTMLAttributes, ReactNode } from 'react'
|
2
|
-
import { clsx } from '../lib/clsx'
|
3
|
-
import { Override } from '../lib/util'
|
4
|
-
|
5
|
-
export type LayoutTitlePageProps = Override<
|
6
|
-
HTMLAttributes<HTMLDivElement>,
|
7
|
-
{
|
8
|
-
title?: ReactNode
|
9
|
-
subtitle?: ReactNode
|
10
|
-
}
|
11
|
-
>
|
12
|
-
|
13
|
-
export function LayoutTitlePage({
|
14
|
-
children,
|
15
|
-
title,
|
16
|
-
subtitle,
|
17
|
-
className,
|
18
|
-
...props
|
19
|
-
}: LayoutTitlePageProps) {
|
20
|
-
return (
|
21
|
-
<div
|
22
|
-
{...props}
|
23
|
-
className={clsx(
|
24
|
-
className,
|
25
|
-
'flex flex-col items-center',
|
26
|
-
'md:flex md:flex-row md:justify-stretch md:items-center',
|
27
|
-
'min-h-screen min-w-screen',
|
28
|
-
'bg-white text-slate-900',
|
29
|
-
'dark:bg-slate-900 dark:text-slate-100',
|
30
|
-
)}
|
31
|
-
>
|
32
|
-
<div
|
33
|
-
className={clsx(
|
34
|
-
'px-6 pt-4',
|
35
|
-
'md:max-w-lg',
|
36
|
-
'md:grid md:content-center md:justify-items-end',
|
37
|
-
'md:self-stretch',
|
38
|
-
'md:w-1/2 md:max-w-fix md:p-4',
|
39
|
-
'md:text-right',
|
40
|
-
'md:dark:border-r md:dark:border-slate-700',
|
41
|
-
'md:bg-slate-100 md:dark:bg-slate-800',
|
42
|
-
)}
|
43
|
-
>
|
44
|
-
{title && (
|
45
|
-
<h1 className="text-xl md:text-2xl lg:text-5xl md:mt-4 mb-4 font-semibold text-brand">
|
46
|
-
{title}
|
47
|
-
</h1>
|
48
|
-
)}
|
49
|
-
|
50
|
-
{subtitle && (
|
51
|
-
<p className="hidden md:block max-w-xs text-slate-500 dark:text-slate-500">
|
52
|
-
{subtitle}
|
53
|
-
</p>
|
54
|
-
)}
|
55
|
-
</div>
|
56
|
-
|
57
|
-
<div className="w-full px-6 md:max-w-3xl md:px-12">{children}</div>
|
58
|
-
</div>
|
59
|
-
)
|
60
|
-
}
|
@@ -1,74 +0,0 @@
|
|
1
|
-
import { HTMLAttributes } from 'react'
|
2
|
-
import { Override } from '../lib/util'
|
3
|
-
import { clsx } from '../lib/clsx'
|
4
|
-
|
5
|
-
export type LayoutWelcomeProps = Override<
|
6
|
-
HTMLAttributes<HTMLDivElement>,
|
7
|
-
{
|
8
|
-
name?: string
|
9
|
-
logo?: string
|
10
|
-
links?: Array<{
|
11
|
-
title: string
|
12
|
-
href: string
|
13
|
-
rel?: string
|
14
|
-
}>
|
15
|
-
logoAlt?: string
|
16
|
-
}
|
17
|
-
>
|
18
|
-
|
19
|
-
export function LayoutWelcome({
|
20
|
-
name,
|
21
|
-
logo,
|
22
|
-
logoAlt = name || 'Logo',
|
23
|
-
links,
|
24
|
-
children,
|
25
|
-
className,
|
26
|
-
...props
|
27
|
-
}: LayoutWelcomeProps) {
|
28
|
-
return (
|
29
|
-
<div
|
30
|
-
className={clsx(
|
31
|
-
'min-h-screen w-full',
|
32
|
-
'flex items-center justify-center flex-col',
|
33
|
-
'bg-white text-slate-900',
|
34
|
-
'dark:bg-slate-900 dark:text-slate-100',
|
35
|
-
className,
|
36
|
-
)}
|
37
|
-
{...props}
|
38
|
-
>
|
39
|
-
<div className="w-full max-w-screen-sm overflow-hidden flex-grow flex flex-col items-center justify-center">
|
40
|
-
{logo && (
|
41
|
-
<img
|
42
|
-
src={logo}
|
43
|
-
alt={logoAlt}
|
44
|
-
className="w-16 h-16 md:w-24 md:h-24 mb-8"
|
45
|
-
/>
|
46
|
-
)}
|
47
|
-
|
48
|
-
{name && (
|
49
|
-
<h1 className="text-2xl md:text-4xl mb-8 mx-4 text-center font-bold">
|
50
|
-
{name}
|
51
|
-
</h1>
|
52
|
-
)}
|
53
|
-
|
54
|
-
{children}
|
55
|
-
</div>
|
56
|
-
|
57
|
-
{links != null && links.length > 0 && (
|
58
|
-
<nav className="w-full max-w-screen-sm overflow-hidden mt-4 border-t border-t-slate-200 dark:border-t-slate-700 flex flex-wrap justify-center">
|
59
|
-
{links.map((link) => (
|
60
|
-
<a
|
61
|
-
key={link.href}
|
62
|
-
href={link.href}
|
63
|
-
rel={link.rel}
|
64
|
-
target="_blank"
|
65
|
-
className="m-2 md:m-4 text-xs md:text-sm text-brand hover:underline"
|
66
|
-
>
|
67
|
-
{link.title}
|
68
|
-
</a>
|
69
|
-
))}
|
70
|
-
</nav>
|
71
|
-
)}
|
72
|
-
</div>
|
73
|
-
)
|
74
|
-
}
|