@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,27 +0,0 @@
|
|
1
|
-
declare const colorNames: readonly ["brand", "error", "warning"];
|
2
|
-
type ColorName = (typeof colorNames)[number];
|
3
|
-
export type Customization = {
|
4
|
-
name?: string;
|
5
|
-
logo?: string;
|
6
|
-
colors?: {
|
7
|
-
[_ in ColorName]?: string;
|
8
|
-
};
|
9
|
-
links?: Array<{
|
10
|
-
href: string;
|
11
|
-
title: string;
|
12
|
-
rel?: string;
|
13
|
-
}>;
|
14
|
-
};
|
15
|
-
export declare function buildCustomizationData({ name, logo, links, }?: Customization): {
|
16
|
-
name: string | undefined;
|
17
|
-
logo: string | undefined;
|
18
|
-
links: {
|
19
|
-
href: string;
|
20
|
-
title: string;
|
21
|
-
rel?: string;
|
22
|
-
}[] | undefined;
|
23
|
-
};
|
24
|
-
export declare function buildCustomizationCss(customization?: Customization): string;
|
25
|
-
export declare function buildCustomizationVars(customization?: Customization): Generator<string, void, unknown>;
|
26
|
-
export {};
|
27
|
-
//# sourceMappingURL=customization.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"customization.d.ts","sourceRoot":"","sources":["../../src/output/customization.ts"],"names":[],"mappings":"AACA,QAAA,MAAM,UAAU,wCAAyC,CAAA;AACzD,KAAK,SAAS,GAAG,CAAC,OAAO,UAAU,CAAC,CAAC,MAAM,CAAC,CAAA;AAI5C,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE;SAAG,CAAC,IAAI,SAAS,CAAC,CAAC,EAAE,MAAM;KAAE,CAAA;IACtC,KAAK,CAAC,EAAE,KAAK,CAAC;QACZ,IAAI,EAAE,MAAM,CAAA;QACZ,KAAK,EAAE,MAAM,CAAA;QACb,GAAG,CAAC,EAAE,MAAM,CAAA;KACb,CAAC,CAAA;CACH,CAAA;AAED,wBAAgB,sBAAsB,CAAC,EACrC,IAAI,EACJ,IAAI,EACJ,KAAK,GACN,GAAE,aAAkB;;;;cAVX,MAAM;eACL,MAAM;cACP,MAAM;;EAcf;AAED,wBAAgB,qBAAqB,CAAC,aAAa,CAAC,EAAE,aAAa,UAKlE;AAED,wBAAiB,sBAAsB,CAAC,aAAa,CAAC,EAAE,aAAa,oCAkBpE"}
|
@@ -1,88 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.buildCustomizationData = buildCustomizationData;
|
4
|
-
exports.buildCustomizationCss = buildCustomizationCss;
|
5
|
-
exports.buildCustomizationVars = buildCustomizationVars;
|
6
|
-
// Matches colors defined in tailwind.config.js
|
7
|
-
const colorNames = ['brand', 'error', 'warning'];
|
8
|
-
const isColorName = (name) => colorNames.includes(name);
|
9
|
-
function buildCustomizationData({ name, logo, links, } = {}) {
|
10
|
-
return {
|
11
|
-
name,
|
12
|
-
logo,
|
13
|
-
links,
|
14
|
-
};
|
15
|
-
}
|
16
|
-
function buildCustomizationCss(customization) {
|
17
|
-
const vars = Array.from(buildCustomizationVars(customization));
|
18
|
-
if (vars.length)
|
19
|
-
return `:root { ${vars.join(' ')} }`;
|
20
|
-
return '';
|
21
|
-
}
|
22
|
-
function* buildCustomizationVars(customization) {
|
23
|
-
if (customization?.colors) {
|
24
|
-
for (const [name, value] of Object.entries(customization.colors)) {
|
25
|
-
if (!isColorName(name)) {
|
26
|
-
throw new TypeError(`Invalid color name: ${name}`);
|
27
|
-
}
|
28
|
-
// Skip undefined values
|
29
|
-
if (value === undefined)
|
30
|
-
continue;
|
31
|
-
const { r, g, b, a } = parseColor(value);
|
32
|
-
// Tailwind does not apply alpha values to base colors
|
33
|
-
if (a !== undefined)
|
34
|
-
throw new TypeError('Alpha not supported');
|
35
|
-
yield `--color-${name}: ${r} ${g} ${b};`;
|
36
|
-
}
|
37
|
-
}
|
38
|
-
}
|
39
|
-
function parseColor(color) {
|
40
|
-
if (typeof color !== 'string') {
|
41
|
-
throw new TypeError(`Invalid color value: ${typeof color}`);
|
42
|
-
}
|
43
|
-
if (color.startsWith('#')) {
|
44
|
-
if (color.length === 4 || color.length === 5) {
|
45
|
-
const r = parseUi8Hex(color.slice(1, 2));
|
46
|
-
const g = parseUi8Hex(color.slice(2, 3));
|
47
|
-
const b = parseUi8Hex(color.slice(3, 4));
|
48
|
-
const a = color.length > 4 ? parseUi8Hex(color.slice(4, 5)) : undefined;
|
49
|
-
return { r, g, b, a };
|
50
|
-
}
|
51
|
-
if (color.length === 7 || color.length === 9) {
|
52
|
-
const r = parseUi8Hex(color.slice(1, 3));
|
53
|
-
const g = parseUi8Hex(color.slice(3, 5));
|
54
|
-
const b = parseUi8Hex(color.slice(5, 7));
|
55
|
-
const a = color.length > 8 ? parseUi8Hex(color.slice(7, 9)) : undefined;
|
56
|
-
return { r, g, b, a };
|
57
|
-
}
|
58
|
-
throw new TypeError(`Invalid hex color: ${color}`);
|
59
|
-
}
|
60
|
-
const rgbMatch = color.match(/^\s*rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)\s*$/);
|
61
|
-
if (rgbMatch) {
|
62
|
-
const r = parseUi8Dec(rgbMatch[1]);
|
63
|
-
const g = parseUi8Dec(rgbMatch[2]);
|
64
|
-
const b = parseUi8Dec(rgbMatch[3]);
|
65
|
-
return { r, g, b };
|
66
|
-
}
|
67
|
-
const rgbaMatch = color.match(/^\s*rgba\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)\s*$/);
|
68
|
-
if (rgbaMatch) {
|
69
|
-
const r = parseUi8Dec(rgbaMatch[1]);
|
70
|
-
const g = parseUi8Dec(rgbaMatch[2]);
|
71
|
-
const b = parseUi8Dec(rgbaMatch[3]);
|
72
|
-
const a = parseUi8Dec(rgbaMatch[4]);
|
73
|
-
return { r, g, b, a };
|
74
|
-
}
|
75
|
-
throw new TypeError(`Unsupported color format: ${color}`);
|
76
|
-
}
|
77
|
-
function parseUi8Hex(v) {
|
78
|
-
return asUi8(parseInt(v, 16));
|
79
|
-
}
|
80
|
-
function parseUi8Dec(v) {
|
81
|
-
return asUi8(parseInt(v, 10));
|
82
|
-
}
|
83
|
-
function asUi8(v) {
|
84
|
-
if (v >= 0 && v <= 255 && v === (v | 0))
|
85
|
-
return v;
|
86
|
-
throw new TypeError(`Invalid color component: ${v}`);
|
87
|
-
}
|
88
|
-
//# sourceMappingURL=customization.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"customization.js","sourceRoot":"","sources":["../../src/output/customization.ts"],"names":[],"mappings":"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"}
|
@@ -1,137 +0,0 @@
|
|
1
|
-
import { OAuthClientMetadata } from '@atproto/oauth-types'
|
2
|
-
import { FormEvent } from 'react'
|
3
|
-
|
4
|
-
import { Account, ScopeDetail } from '../backend-data'
|
5
|
-
import { Override } from '../lib/util'
|
6
|
-
import { AccountIdentifier } from './account-identifier'
|
7
|
-
import { Button } from './button'
|
8
|
-
import { ClientName } from './client-name'
|
9
|
-
import { FormCard, FormCardProps } from './form-card'
|
10
|
-
|
11
|
-
export type AcceptFormProps = Override<
|
12
|
-
FormCardProps,
|
13
|
-
{
|
14
|
-
clientId: string
|
15
|
-
clientMetadata: OAuthClientMetadata
|
16
|
-
clientTrusted: boolean
|
17
|
-
|
18
|
-
account: Account
|
19
|
-
scopeDetails?: ScopeDetail[]
|
20
|
-
|
21
|
-
onAccept: () => void
|
22
|
-
acceptLabel?: string
|
23
|
-
|
24
|
-
onReject: () => void
|
25
|
-
rejectLabel?: string
|
26
|
-
|
27
|
-
onBack?: () => void
|
28
|
-
backLabel?: string
|
29
|
-
}
|
30
|
-
>
|
31
|
-
|
32
|
-
export function AcceptForm({
|
33
|
-
clientId,
|
34
|
-
clientMetadata,
|
35
|
-
clientTrusted,
|
36
|
-
|
37
|
-
account,
|
38
|
-
scopeDetails,
|
39
|
-
|
40
|
-
onAccept,
|
41
|
-
acceptLabel = 'Accept',
|
42
|
-
onReject,
|
43
|
-
rejectLabel = 'Deny access',
|
44
|
-
onBack,
|
45
|
-
backLabel = 'Back',
|
46
|
-
|
47
|
-
...props
|
48
|
-
}: AcceptFormProps) {
|
49
|
-
const doSubmit = (e: FormEvent) => {
|
50
|
-
e.preventDefault()
|
51
|
-
onAccept()
|
52
|
-
}
|
53
|
-
|
54
|
-
return (
|
55
|
-
<FormCard
|
56
|
-
onSubmit={doSubmit}
|
57
|
-
cancel={onBack && <Button onClick={onBack}>{backLabel}</Button>}
|
58
|
-
actions={
|
59
|
-
<>
|
60
|
-
<Button type="submit" color="brand">
|
61
|
-
{acceptLabel}
|
62
|
-
</Button>
|
63
|
-
|
64
|
-
<Button onClick={onReject}>{rejectLabel}</Button>
|
65
|
-
</>
|
66
|
-
}
|
67
|
-
{...props}
|
68
|
-
>
|
69
|
-
{clientTrusted && clientMetadata.logo_uri && (
|
70
|
-
<div key="logo" className="flex items-center justify-center">
|
71
|
-
<img
|
72
|
-
crossOrigin="anonymous"
|
73
|
-
src={clientMetadata.logo_uri}
|
74
|
-
alt={clientMetadata.client_name}
|
75
|
-
className="w-16 h-16 rounded-full"
|
76
|
-
/>
|
77
|
-
</div>
|
78
|
-
)}
|
79
|
-
<p>
|
80
|
-
<ClientName
|
81
|
-
clientId={clientId}
|
82
|
-
clientMetadata={clientMetadata}
|
83
|
-
clientTrusted={clientTrusted}
|
84
|
-
/>{' '}
|
85
|
-
is asking for permission to access your account (
|
86
|
-
<AccountIdentifier account={account} />
|
87
|
-
).
|
88
|
-
</p>
|
89
|
-
|
90
|
-
<p>
|
91
|
-
By clicking <b>{acceptLabel}</b>, you allow this application to perform
|
92
|
-
the following actions in accordance to their{' '}
|
93
|
-
<a
|
94
|
-
href={clientMetadata.tos_uri}
|
95
|
-
rel="nofollow noopener"
|
96
|
-
target="_blank"
|
97
|
-
className="text-brand underline"
|
98
|
-
>
|
99
|
-
terms of service
|
100
|
-
</a>
|
101
|
-
{' and '}
|
102
|
-
<a
|
103
|
-
href={clientMetadata.policy_uri}
|
104
|
-
rel="nofollow noopener"
|
105
|
-
target="_blank"
|
106
|
-
className="text-brand underline"
|
107
|
-
>
|
108
|
-
privacy policy
|
109
|
-
</a>
|
110
|
-
:
|
111
|
-
</p>
|
112
|
-
|
113
|
-
{scopeDetails?.length ? (
|
114
|
-
<ul className="list-disc list-inside">
|
115
|
-
{scopeDetails.map(
|
116
|
-
({ scope, description = getScopeDescription(scope) }) => (
|
117
|
-
<li key={scope}>{description}</li>
|
118
|
-
),
|
119
|
-
)}
|
120
|
-
</ul>
|
121
|
-
) : null}
|
122
|
-
</FormCard>
|
123
|
-
)
|
124
|
-
}
|
125
|
-
|
126
|
-
function getScopeDescription(scope: string): string {
|
127
|
-
switch (scope) {
|
128
|
-
case 'atproto':
|
129
|
-
return 'Uniquely identify you'
|
130
|
-
case 'transition:generic':
|
131
|
-
return 'Access your account data (except chat messages)'
|
132
|
-
case 'transition:chat.bsky':
|
133
|
-
return 'Access your chat messages'
|
134
|
-
default:
|
135
|
-
return scope
|
136
|
-
}
|
137
|
-
}
|
@@ -1,18 +0,0 @@
|
|
1
|
-
import { HTMLAttributes } from 'react'
|
2
|
-
|
3
|
-
import { Account } from '../backend-data'
|
4
|
-
|
5
|
-
export type AccountIdentifierProps = {
|
6
|
-
account: Account
|
7
|
-
}
|
8
|
-
|
9
|
-
export function AccountIdentifier({
|
10
|
-
account,
|
11
|
-
...attrs
|
12
|
-
}: AccountIdentifierProps & HTMLAttributes<Element>) {
|
13
|
-
return (
|
14
|
-
<b {...attrs}>
|
15
|
-
{account.preferred_username || account.email || account.sub}
|
16
|
-
</b>
|
17
|
-
)
|
18
|
-
}
|
@@ -1,127 +0,0 @@
|
|
1
|
-
import type { ReactNode } from 'react'
|
2
|
-
import { Account } from '../backend-data'
|
3
|
-
import { Override } from '../lib/util'
|
4
|
-
import { Button } from './button'
|
5
|
-
import { FormCard, FormCardProps } from './form-card'
|
6
|
-
import { AtSymbolIcon } from './icons/at-symbol-icon'
|
7
|
-
import { CaretRightIcon } from './icons/caret-right-icon'
|
8
|
-
import { InputContainer } from './input-container'
|
9
|
-
import { Fieldset } from './fieldset'
|
10
|
-
|
11
|
-
export type AccountPickerProps = Override<
|
12
|
-
FormCardProps,
|
13
|
-
{
|
14
|
-
accounts: readonly Account[]
|
15
|
-
|
16
|
-
onAccount: (account: Account) => void
|
17
|
-
accountAria?: (account: Account) => string
|
18
|
-
|
19
|
-
onOther?: () => void
|
20
|
-
otherLabel?: ReactNode
|
21
|
-
otherAria?: string
|
22
|
-
|
23
|
-
onBack?: () => void
|
24
|
-
backLabel?: ReactNode
|
25
|
-
backAria?: string
|
26
|
-
}
|
27
|
-
>
|
28
|
-
|
29
|
-
export function AccountPicker({
|
30
|
-
accounts,
|
31
|
-
|
32
|
-
onAccount,
|
33
|
-
accountAria = (a) => `Sign in as ${a.name}`,
|
34
|
-
|
35
|
-
onOther = undefined,
|
36
|
-
otherLabel = 'Another account',
|
37
|
-
otherAria = 'Login to account that is not listed',
|
38
|
-
|
39
|
-
onBack,
|
40
|
-
backAria,
|
41
|
-
backLabel = backAria,
|
42
|
-
|
43
|
-
...props
|
44
|
-
}: AccountPickerProps) {
|
45
|
-
return (
|
46
|
-
<FormCard
|
47
|
-
{...props}
|
48
|
-
cancel={
|
49
|
-
onBack && (
|
50
|
-
<Button onClick={onBack} aria-label={backAria}>
|
51
|
-
{backLabel}
|
52
|
-
</Button>
|
53
|
-
)
|
54
|
-
}
|
55
|
-
>
|
56
|
-
<Fieldset title="Sign in as...">
|
57
|
-
{accounts.map((account) => {
|
58
|
-
const [name, identifier] = [
|
59
|
-
account.name,
|
60
|
-
account.preferred_username,
|
61
|
-
account.email,
|
62
|
-
account.sub,
|
63
|
-
].filter(Boolean) as [string, string?]
|
64
|
-
|
65
|
-
return (
|
66
|
-
<InputContainer
|
67
|
-
key={account.sub}
|
68
|
-
onClick={() => onAccount(account)}
|
69
|
-
role="button"
|
70
|
-
aria-label={accountAria(account)}
|
71
|
-
icon={
|
72
|
-
account.picture ? (
|
73
|
-
<img
|
74
|
-
crossOrigin="anonymous"
|
75
|
-
src={account.picture}
|
76
|
-
alt={name}
|
77
|
-
className="-ml-1 w-6 h-6 rounded-full"
|
78
|
-
/>
|
79
|
-
) : (
|
80
|
-
<svg
|
81
|
-
className="-ml-1 w-6 h-6"
|
82
|
-
viewBox="0 0 24 24"
|
83
|
-
fill="none"
|
84
|
-
stroke="none"
|
85
|
-
>
|
86
|
-
<circle cx="12" cy="12" r="12" fill="#0070ff"></circle>
|
87
|
-
<circle cx="12" cy="9.5" r="3.5" fill="#fff"></circle>
|
88
|
-
<path
|
89
|
-
strokeLinecap="round"
|
90
|
-
strokeLinejoin="round"
|
91
|
-
fill="#fff"
|
92
|
-
d="M 12.058 22.784 C 9.422 22.784 7.007 21.836 5.137 20.262 C 5.667 17.988 8.534 16.25 11.99 16.25 C 15.494 16.25 18.391 18.036 18.864 20.357 C 17.01 21.874 14.64 22.784 12.058 22.784 Z"
|
93
|
-
></path>
|
94
|
-
</svg>
|
95
|
-
)
|
96
|
-
}
|
97
|
-
append={<CaretRightIcon className="h-4" />}
|
98
|
-
>
|
99
|
-
<span className="flex flex-wrap items-center">
|
100
|
-
<span className="font-medium truncate mr-2">{name}</span>
|
101
|
-
{identifier && (
|
102
|
-
<span className="text-sm text-neutral-500 dark:text-neutral-400 truncate">
|
103
|
-
{identifier}
|
104
|
-
</span>
|
105
|
-
)}
|
106
|
-
</span>
|
107
|
-
</InputContainer>
|
108
|
-
)
|
109
|
-
})}
|
110
|
-
|
111
|
-
{onOther && (
|
112
|
-
<InputContainer
|
113
|
-
onClick={onOther}
|
114
|
-
aria-label={otherAria}
|
115
|
-
role="button"
|
116
|
-
append={<CaretRightIcon className="h-4" />}
|
117
|
-
icon={<AtSymbolIcon className="h-4" />}
|
118
|
-
>
|
119
|
-
<span className="truncate text-gray-700 dark:text-gray-400">
|
120
|
-
{otherLabel}
|
121
|
-
</span>
|
122
|
-
</InputContainer>
|
123
|
-
)}
|
124
|
-
</Fieldset>
|
125
|
-
</FormCard>
|
126
|
-
)
|
127
|
-
}
|
@@ -1,34 +0,0 @@
|
|
1
|
-
import { ButtonHTMLAttributes } from 'react'
|
2
|
-
import { clsx } from '../lib/clsx'
|
3
|
-
|
4
|
-
export function Button({
|
5
|
-
children,
|
6
|
-
className,
|
7
|
-
type = 'button',
|
8
|
-
role = 'Button',
|
9
|
-
color = 'grey',
|
10
|
-
disabled = false,
|
11
|
-
loading = undefined,
|
12
|
-
...props
|
13
|
-
}: {
|
14
|
-
color?: 'brand' | 'grey'
|
15
|
-
loading?: boolean
|
16
|
-
} & ButtonHTMLAttributes<HTMLButtonElement>) {
|
17
|
-
return (
|
18
|
-
<button
|
19
|
-
role={role}
|
20
|
-
type={type}
|
21
|
-
disabled={disabled || loading === true}
|
22
|
-
{...props}
|
23
|
-
className={clsx(
|
24
|
-
'py-2 px-6 rounded-lg truncate cursor-pointer touch-manipulation tracking-wide overflow-hidden',
|
25
|
-
color === 'brand'
|
26
|
-
? 'bg-brand text-white'
|
27
|
-
: 'bg-slate-100 hover:bg-slate-200 text-slate-600 dark:bg-slate-800 dark:hover:bg-slate-700 dark:text-slate-300',
|
28
|
-
className,
|
29
|
-
)}
|
30
|
-
>
|
31
|
-
{children}
|
32
|
-
</button>
|
33
|
-
)
|
34
|
-
}
|
@@ -1,37 +0,0 @@
|
|
1
|
-
import {
|
2
|
-
isOAuthClientIdDiscoverable,
|
3
|
-
isOAuthClientIdLoopback,
|
4
|
-
OAuthClientMetadata,
|
5
|
-
} from '@atproto/oauth-types'
|
6
|
-
import { HTMLAttributes } from 'react'
|
7
|
-
|
8
|
-
import { UrlViewer } from './url-viewer'
|
9
|
-
|
10
|
-
export type ClientNameProps = {
|
11
|
-
clientId: string
|
12
|
-
clientMetadata: OAuthClientMetadata
|
13
|
-
clientTrusted: boolean
|
14
|
-
loopbackClientName?: string
|
15
|
-
} & HTMLAttributes<Element>
|
16
|
-
|
17
|
-
export function ClientName({
|
18
|
-
clientId,
|
19
|
-
clientMetadata,
|
20
|
-
clientTrusted,
|
21
|
-
loopbackClientName = 'An application on your device',
|
22
|
-
...attrs
|
23
|
-
}: ClientNameProps) {
|
24
|
-
if (clientTrusted && clientMetadata.client_name) {
|
25
|
-
return <span {...attrs}>{clientMetadata.client_name}</span>
|
26
|
-
}
|
27
|
-
|
28
|
-
if (isOAuthClientIdLoopback(clientId)) {
|
29
|
-
return <span {...attrs}>{loopbackClientName}</span>
|
30
|
-
}
|
31
|
-
|
32
|
-
if (isOAuthClientIdDiscoverable(clientId)) {
|
33
|
-
return <UrlViewer {...attrs} url={clientId} path />
|
34
|
-
}
|
35
|
-
|
36
|
-
return <span {...attrs}>{clientId}</span>
|
37
|
-
}
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import { FieldsetHTMLAttributes, forwardRef, ReactNode } from 'react'
|
2
|
-
import { Override } from '../lib/util'
|
3
|
-
|
4
|
-
export type FieldsetCardProps = Override<
|
5
|
-
FieldsetHTMLAttributes<HTMLFieldSetElement>,
|
6
|
-
{
|
7
|
-
title?: ReactNode
|
8
|
-
}
|
9
|
-
>
|
10
|
-
|
11
|
-
export const Fieldset = forwardRef<HTMLFieldSetElement, FieldsetCardProps>(
|
12
|
-
({ title, children, ...props }, ref) => (
|
13
|
-
<fieldset ref={ref} {...props}>
|
14
|
-
{title && (
|
15
|
-
<p
|
16
|
-
key="title"
|
17
|
-
className="mb-1 text-slate-600 dark:text-slate-400 text-sm font-medium"
|
18
|
-
>
|
19
|
-
{title}
|
20
|
-
</p>
|
21
|
-
)}
|
22
|
-
|
23
|
-
<div className="flex flex-col space-y-4">{children}</div>
|
24
|
-
</fieldset>
|
25
|
-
),
|
26
|
-
)
|
@@ -1,47 +0,0 @@
|
|
1
|
-
import { FormHTMLAttributes, forwardRef, ReactNode } from 'react'
|
2
|
-
import { InfoCard } from './info-card'
|
3
|
-
import { clsx } from '../lib/clsx'
|
4
|
-
import { Override } from '../lib/util'
|
5
|
-
|
6
|
-
export type FormCardProps = Override<
|
7
|
-
FormHTMLAttributes<HTMLFormElement>,
|
8
|
-
{
|
9
|
-
append?: ReactNode
|
10
|
-
error?: ReactNode
|
11
|
-
cancel?: ReactNode
|
12
|
-
actions?: ReactNode
|
13
|
-
}
|
14
|
-
>
|
15
|
-
|
16
|
-
export const FormCard = forwardRef<HTMLFormElement, FormCardProps>(
|
17
|
-
({ actions, cancel, append, className, children, error, ...props }, ref) => {
|
18
|
-
return (
|
19
|
-
<form
|
20
|
-
ref={ref}
|
21
|
-
className={clsx('flex flex-col py-4 space-y-4', className)}
|
22
|
-
{...props}
|
23
|
-
>
|
24
|
-
<div className="space-y-4">{children}</div>
|
25
|
-
|
26
|
-
{append && <div key="append">{append}</div>}
|
27
|
-
|
28
|
-
{error && (
|
29
|
-
<InfoCard key="error" role="alert">
|
30
|
-
{error}
|
31
|
-
</InfoCard>
|
32
|
-
)}
|
33
|
-
|
34
|
-
{(actions || cancel) && (
|
35
|
-
<div
|
36
|
-
key="buttons"
|
37
|
-
className="flex flex-wrap flex-row-reverse items-center justify-end space-x-reverse space-x-2"
|
38
|
-
>
|
39
|
-
{actions}
|
40
|
-
<div className="flex-auto" />
|
41
|
-
{cancel}
|
42
|
-
</div>
|
43
|
-
)}
|
44
|
-
</form>
|
45
|
-
)
|
46
|
-
},
|
47
|
-
)
|
@@ -1,42 +0,0 @@
|
|
1
|
-
import { HTMLAttributes } from 'react'
|
2
|
-
import { LinkDefinition } from '../backend-data'
|
3
|
-
import { clsx } from '../lib/clsx'
|
4
|
-
|
5
|
-
export type HelpCardProps = {
|
6
|
-
links?: readonly LinkDefinition[]
|
7
|
-
}
|
8
|
-
|
9
|
-
export function HelpCard({
|
10
|
-
links,
|
11
|
-
|
12
|
-
className,
|
13
|
-
...attrs
|
14
|
-
}: HelpCardProps &
|
15
|
-
Omit<
|
16
|
-
HTMLAttributes<HTMLParagraphElement>,
|
17
|
-
keyof HelpCardProps | 'children'
|
18
|
-
>) {
|
19
|
-
const helpLink = links?.find((l) => l.rel === 'help')
|
20
|
-
|
21
|
-
if (!helpLink) return null
|
22
|
-
|
23
|
-
return (
|
24
|
-
<p
|
25
|
-
className={clsx(
|
26
|
-
'text-sm rounded-md bg-slate-100 text-slate-800 dark:bg-slate-800 dark:text-slate-400 p-3',
|
27
|
-
className,
|
28
|
-
)}
|
29
|
-
{...attrs}
|
30
|
-
>
|
31
|
-
Having trouble?{' '}
|
32
|
-
<a
|
33
|
-
href={helpLink.href}
|
34
|
-
rel={helpLink.rel}
|
35
|
-
target="_blank"
|
36
|
-
className="text-brand"
|
37
|
-
>
|
38
|
-
Contact {helpLink.title}
|
39
|
-
</a>
|
40
|
-
</p>
|
41
|
-
)
|
42
|
-
}
|
@@ -1,5 +0,0 @@
|
|
1
|
-
import { makeSvgComponent } from './util'
|
2
|
-
|
3
|
-
export const AlertIcon = makeSvgComponent(
|
4
|
-
'M11.14 4.494a.995.995 0 0 1 1.72 0l7.001 12.008a.996.996 0 0 1-.86 1.498H4.999a.996.996 0 0 1-.86-1.498L11.14 4.494Zm3.447-1.007c-1.155-1.983-4.019-1.983-5.174 0L2.41 15.494C1.247 17.491 2.686 20 4.998 20h14.004c2.312 0 3.751-2.509 2.587-4.506L14.587 3.487ZM13 9.019a1 1 0 1 0-2 0v2.994a1 1 0 1 0 2 0V9.02Zm-1 4.731a1.25 1.25 0 1 0 0 2.5 1.25 1.25 0 0 0 0-2.5Z',
|
5
|
-
)
|
@@ -1,5 +0,0 @@
|
|
1
|
-
import { makeSvgComponent } from './util'
|
2
|
-
|
3
|
-
export const AtSymbolIcon = makeSvgComponent(
|
4
|
-
'M12 4a8 8 0 1 0 4.21 14.804 1 1 0 0 1 1.054 1.7A9.958 9.958 0 0 1 12 22C6.477 22 2 17.523 2 12S6.477 2 12 2s10 4.477 10 10c0 1.104-.27 2.31-.949 3.243-.716.984-1.849 1.6-3.331 1.465a4.207 4.207 0 0 1-2.93-1.585c-.94 1.21-2.388 1.94-3.985 1.715-2.53-.356-4.04-2.91-3.682-5.458.358-2.547 2.514-4.586 5.044-4.23.905.127 1.68.536 2.286 1.126a1 1 0 0 1 1.964.368l-.515 3.545v.002a2.222 2.222 0 0 0 1.999 2.526c.75.068 1.212-.21 1.533-.65.358-.493.566-1.245.566-2.067a8 8 0 0 0-8-8Zm-.112 5.13c-1.195-.168-2.544.819-2.784 2.529-.24 1.71.784 3.03 1.98 3.198 1.195.168 2.543-.819 2.784-2.529.24-1.71-.784-3.03-1.98-3.198Z',
|
5
|
-
)
|
@@ -1,5 +0,0 @@
|
|
1
|
-
import { makeSvgComponent } from './util'
|
2
|
-
|
3
|
-
export const LockIcon = makeSvgComponent(
|
4
|
-
'M7 7a5 5 0 0 1 10 0v2h1a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H6a2 2 0 0 1-2-2v-9a2 2 0 0 1 2-2h1V7Zm-1 4v9h12v-9H6Zm9-2H9V7a3 3 0 1 1 6 0v2Zm-3 4a1 1 0 0 1 1 1v3a1 1 0 1 1-2 0v-3a1 1 0 0 1 1-1Z',
|
5
|
-
)
|
@@ -1,5 +0,0 @@
|
|
1
|
-
import { makeSvgComponent } from './util'
|
2
|
-
|
3
|
-
export const TokenIcon = makeSvgComponent(
|
4
|
-
'M4 5.5a.5.5 0 0 0-.5.5v2.535a.5.5 0 0 0 .25.433A3.498 3.498 0 0 1 5.5 12a3.498 3.498 0 0 1-1.75 3.032.5.5 0 0 0-.25.433V18a.5.5 0 0 0 .5.5h16a.5.5 0 0 0 .5-.5v-2.535a.5.5 0 0 0-.25-.433A3.498 3.498 0 0 1 18.5 12a3.5 3.5 0 0 1 1.75-3.032.5.5 0 0 0 .25-.433V6a.5.5 0 0 0-.5-.5H4ZM2.5 6A1.5 1.5 0 0 1 4 4.5h16A1.5 1.5 0 0 1 21.5 6v3.17a.5.5 0 0 1-.333.472 2.501 2.501 0 0 0 0 4.716.5.5 0 0 1 .333.471V18a1.5 1.5 0 0 1-1.5 1.5H4A1.5 1.5 0 0 1 2.5 18v-3.17a.5.5 0 0 1 .333-.472 2.501 2.501 0 0 0 0-4.716.5.5 0 0 1-.333-.471V6Zm12 2a.5.5 0 1 1 1 0 .5.5 0 0 1-1 0Zm0 4a.5.5 0 1 1 1 0 .5.5 0 0 1-1 0Zm0 4a.5.5 0 1 1 1 0 .5.5 0 0 1-1 0Z',
|
5
|
-
)
|
@@ -1,17 +0,0 @@
|
|
1
|
-
import type { SVGProps } from 'react'
|
2
|
-
|
3
|
-
export const makeSvgComponent = (path: string) =>
|
4
|
-
function (
|
5
|
-
props: Omit<SVGProps<SVGSVGElement>, 'viewBox' | 'children' | 'xmlns'>,
|
6
|
-
) {
|
7
|
-
return (
|
8
|
-
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" {...props}>
|
9
|
-
<path
|
10
|
-
fill="currentColor"
|
11
|
-
fillRule="evenodd"
|
12
|
-
clipRule="evenodd"
|
13
|
-
d={path}
|
14
|
-
></path>
|
15
|
-
</svg>
|
16
|
-
)
|
17
|
-
}
|