payload-auth 1.2.0 → 1.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/better-auth/plugin/constants.d.ts +2 -0
- package/dist/better-auth/plugin/constants.d.ts.map +1 -1
- package/dist/better-auth/plugin/constants.js +30 -1
- package/dist/better-auth/plugin/index.d.ts +5 -5
- package/dist/better-auth/plugin/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/index.js +14 -10
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +17 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts +10 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.d.ts.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/require-admin-invite-for-sign-up-middleware.js +43 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +6 -1
- package/dist/better-auth/plugin/lib/set-login-methods.d.ts +5 -0
- package/dist/better-auth/plugin/lib/set-login-methods.d.ts.map +1 -0
- package/dist/better-auth/plugin/lib/set-login-methods.js +16 -0
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts +2 -2
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/components/admin-buttons/index.js +2 -3
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts +2 -2
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.js +2 -3
- package/dist/better-auth/plugin/payload/components/admin-invite-button/index.scss +5 -3
- package/dist/better-auth/plugin/payload/components/logout-button.d.ts +1 -2
- package/dist/better-auth/plugin/payload/components/logout-button.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/components/logout-button.js +2 -3
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts +14 -0
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js +142 -0
- package/dist/better-auth/plugin/payload/components/{admin-social-provider-buttons → social-provider-buttons}/index.scss +1 -1
- package/dist/better-auth/plugin/payload/exports/client.d.ts +4 -4
- package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/client.js +5 -5
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +2 -3
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/client.js +37 -54
- package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/index.js +3 -4
- package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +3 -4
- package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-signup/client.js +51 -85
- package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts +0 -1
- package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-signup/index.js +44 -87
- package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/forgot-password/client.js +5 -7
- package/dist/better-auth/plugin/types.d.ts +23 -14
- package/dist/better-auth/plugin/types.d.ts.map +1 -1
- package/dist/better-auth/plugin/types.js +1 -1
- package/dist/shared/form/ui/index.d.ts +2 -2
- package/dist/shared/form/ui/index.d.ts.map +1 -1
- package/dist/shared/form/ui/index.js +4 -7
- package/dist/shared/form/ui/index.scss +15 -0
- package/dist/shared/form/validation.d.ts +103 -0
- package/dist/shared/form/validation.d.ts.map +1 -0
- package/dist/shared/form/validation.js +108 -0
- package/package.json +1 -1
- package/dist/better-auth/plugin/payload/components/admin-social-provider-buttons/index.d.ts +0 -14
- package/dist/better-auth/plugin/payload/components/admin-social-provider-buttons/index.d.ts.map +0 -1
- package/dist/better-auth/plugin/payload/components/admin-social-provider-buttons/index.js +0 -109
- package/dist/better-auth/plugin/payload/views/admin-signup/index.scss +0 -29
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAClE,OAAO,KAAK,EACV,iBAAiB,IAAI,qBAAqB,EAC1C,gBAAgB,IAAI,oBAAoB,EACxC,QAAQ,EACR,gBAAgB,EACjB,MAAM,mBAAmB,CAAA;AAC1B,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,SAAS,CAAA;AACvG,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/better-auth/plugin/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export { };
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/types.ts"],"sourcesContent":["import type { UnionToIntersection, betterAuth } from 'better-auth'\nimport type {\n  BetterAuthOptions as BetterAuthOptionsType,\n  BetterAuthPlugin as BetterAuthPluginType,\n  InferAPI,\n  InferPluginTypes\n} from 'better-auth/types'\nimport type { BasePayload, CollectionConfig, Config, Endpoint, Payload, PayloadRequest } from 'payload'\nimport { adminRoutes } from './constants'\n\n/**\n * BetterAuth options with the following caveats:\n * - The `database` option is removed as it is configured internally\n * - The `user` `modelName` and `fields` is removed as it is configured internally\n * - The `account` `modelName` and `fields` is removed as it is configured internally\n * - The `session` `modelName` and `fields` is removed as it is configured internally\n * - The `verification` `modelName` and `fields` is removed as it is configured internally\n *\n * @see https://www.better-auth.com/docs/reference/options\n */\nexport interface BetterAuthOptions\n  extends Omit<BetterAuthOptionsType, 'database' | 'user' | 'account' | 'verification' | 'session' | 'advanced'> {\n  user?: Omit<NonNullable<BetterAuthOptionsType['user']>, 'modelName' | 'fields'> | undefined\n  account?: Omit<NonNullable<BetterAuthOptionsType['account']>, 'modelName' | 'fields'> | undefined\n  session?: Omit<NonNullable<BetterAuthOptionsType['session']>, 'modelName' | 'fields'> | undefined\n  verification?: Omit<NonNullable<BetterAuthOptionsType['verification']>, 'modelName' | 'fields'> | undefined\n  advanced?: Omit<NonNullable<BetterAuthOptionsType['advanced']>, 'generateId'> | undefined\n}\n\nexport interface SanitizedBetterAuthOptions extends Omit<BetterAuthOptionsType, 'database'> {}\n\nexport type SocialProvider = keyof NonNullable<BetterAuthOptionsType['socialProviders']>\n\nexport type SocialProviders = {\n  [key in SocialProvider]?: {\n    enabled?: boolean\n    disableSignUp?: boolean\n  }\n}\n\nexport interface BetterAuthPluginOptions {\n  /**\n   * Disable the plugin\n   * @default false\n   */\n  disabled?: boolean\n  /**\n   * Disable the default payload auth\n   *\n   * This will ensure that better-auth handles both admin and frontend auth\n   *\n   * Admin will make use of custom admin routes for auth and give you more control\n   *\n   * Note: This will override the option passed in the users collection config\n   *\n   * Read about this more in the docs\n   * @see https://www.payloadauth.com/docs/better-auth#disable-default-payload-auth\n   *\n   * @default false\n   */\n  disableDefaultPayloadAuth?: boolean\n  /**\n   * Custom admin components when disableDefaultPayloadAuth is true\n   *\n   * These components will be used to render the login, create first admin, and other auth-related views\n   */\n  adminComponents?: {\n    /**\n     * Custom social providers\n     *\n     * This will add social providers to the login view\n     *\n     * Make sure to include the provider in the betterAuthOptions.socialProviders array\n     */\n    socialProviders?: SocialProviders\n  }\n  /**\n   * Debug options\n   */\n  debug?: {\n    /**\n     * Enable debug logs\n     * @default false\n     */\n    enableDebugLogs?: boolean\n    /**\n     * Log the tables that are needed for better-auth on init\n     * @default false\n     */\n    logTables?: boolean\n  }\n  /**\n   * Hide the better-authplugin collections from the payload admin UI\n   * @default false\n   */\n  hidePluginCollections?: boolean\n  /**\n   * Defines the admin group for collections.\n   * @default \"Auth\"\n   */\n  collectionAdminGroup?: string\n  /**\n   * Configure the Users collections:\n   */\n  users?: {\n    /**\n     * Will set the `modelName` for the `user` table in better-auth\n     *\n     * and the `slug` for the `users` collection in payload\n     *\n     * @default 'users'\n     */\n    slug?: string | undefined\n    /**\n     * The default role for users\n     *\n     * This will be used as the default role for the role field in the users collection\n     *\n     * If you define this you must also have this role in the roles array\n     *\n     * This will also be used as the defaultRole option in the better-auth admin plugin if present\n     * @see https://www.better-auth.com/docs/plugins/admin#default-role\n     * @default \"user\"\n     */\n    defaultRole?: string\n    /**\n     * The default role for admins\n     *\n     * This will be used as the default role for when admins sign up in the create first admin view or when inviting new admins\n     *\n     *\n     * @default \"admin\"\n     */\n    defaultAdminRole?: string\n    /**\n     * All roles for the users collection\n     *\n     * These will be used to define all the options in the user collection role field\n     *\n     * Will be merged with the adminRoles array, no need to worry about redefining in adminRoles or duplicates\n     *\n     * This should match the roles in the better-auth admin plugin if you are using it\n     * @see https://www.better-auth.com/docs/plugins/admin#access-control\n     *\n     * @default [\"user\"]\n     */\n    roles?: string[]\n    /**\n     * Define admin roles for the users collection\n     *\n     * These roles will be given admin access to all auth collections created by this plugin\n     *\n     * Note: Will be merged with the roles array, no need to worry about redefining in roles or duplicates\n     *\n     * Will be also used as the adminRoles option in the better-auth admin plugin if present\n     *\n     * @see https://www.better-auth.com/docs/plugins/admin#admin-roles\n     *\n     * @default [\"admin\"]\n     */\n    adminRoles?: string[]\n    /**\n     * Hide the `users` collection from the payload admin UI\n     *\n     * This will be overwritten if you change the value in the collection overrides option\n     */\n    hidden?: boolean | undefined\n    /**\n     * Define which fields users can update themselves\n     *\n     * Password field is automatically included and doesn't need to be specified here\n     *\n     * @example ['name', 'dateOfBirth', 'phoneNumber']\n     * @default ['name']\n     */\n    allowedFields?: string[] | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     * Example use cases include adding saveToJwt to specific fields or\n     * modifying field descriptions\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n    /**\n     * This will block the first on sign up verification email from better-auth.\n     * If you are using Payload's userCollection.verify option, you will want to set this to true.\n     * Function that will be blocked: options.emailVerificationsendVerificationEmail\n     * @default false\n     */\n    blockFirstBetterAuthVerificationEmail?: boolean\n  }\n  /**\n   * Configure the Accounts collections:\n   */\n  accounts?: {\n    /**\n     * Will set the `modelName` for the `account` table in better-auth\n     *\n     * and the `slug` for the `accounts` collection in payload\n     *\n     * @default 'accounts'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `accounts` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Sessions collections:\n   */\n  sessions?: {\n    /**\n     * Will set the `modelName` for the `session` table in better-auth\n     *\n     * and the `slug` for the `sessions` collection in payload\n     *\n     * @default 'sessions'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `sessions` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Verifications collections:\n   */\n  verifications?: {\n    /**\n     * Will set the `modelName` for the `verification` table in better-auth\n     *\n     * and the `slug` for the `verifications` collection in payload\n     *\n     * @default 'verifications'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `verifications` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Admin Invitations collections:\n   */\n  adminInvitations?: {\n    /**\n     * Will set the `slug` for the `admin-invitations` collection in payload\n     *\n     * @default 'admin-invitations'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `admin-invitations` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * This will be used to generate the admin invite url\n     *\n     * @param options Object containing payload and the token\n     * @returns The admin invite url\n     */\n    generateInviteUrl?: GenerateAdminInviteUrlFn\n    /**\n     * This will be used to send the admin invite email\n     *\n     * @param options Object containing payload, email and the url\n     * @returns The admin invite url\n     */\n    sendInviteEmail?: SendAdminInviteEmailFn\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * BetterAuth options with the following caveats:\n   * - The `database` option is removed as it is configured internally\n   * - The `user` `modelName` and `fields` is removed as it is configured internally\n   * - The `account` `modelName` and `fields` is removed as it is configured internally\n   * - The `session` `modelName` and `fields` is removed as it is configured internally\n   * - The `verification` `modelName` and `fields` is removed as it is configured internally\n   *\n   * @see https://www.better-auth.com/docs/reference/options\n   */\n  betterAuthOptions?: BetterAuthOptions\n}\n\nexport type SendAdminInviteEmailFn = (options: { payload: Payload; email: string; url: string }) => Promise<\n  | { success: true; message?: string }\n  | { success: false; message: string }\n>\n\nexport type GenerateAdminInviteUrlFn = (options: { payload: Payload; token: string }) => string\n\nexport type ConfigAdminCustom = {\n  betterAuth: {\n    adminRoutes: {\n      [key in keyof typeof adminRoutes]: string\n    }\n  }\n}\n\nexport interface BetterAuthPlugin {\n  (config: Config): Config\n  pluginOptions: BetterAuthPluginOptions\n}\n\nexport interface PayloadRequestWithBetterAuth<TPlugins extends BetterAuthPluginType[] = []> extends PayloadRequest {\n  payload: BasePayload & {\n    betterAuth: BetterAuthReturn<TPlugins>\n  }\n}\n\nexport type CollectionHookWithBetterAuth<T extends (args: any) => any> = T extends (args: infer A) => infer R\n  ? (args: Omit<A, 'req'> & { req: PayloadRequestWithBetterAuth }) => R\n  : never\n\nexport type EndpointWithBetterAuth = Omit<Endpoint, 'handler'> & {\n  handler: (req: PayloadRequestWithBetterAuth) => Promise<Response> | Response\n}\n\nexport type ExtractEndpoints<T> = T extends BetterAuthPlugin ? (T extends { endpoints?: infer E } ? E : {}) : {}\n\nexport type TPlugins<TPlugins extends BetterAuthPluginType[] = BetterAuthPluginType[]> = TPlugins\n\nexport type PluginInferTypes<T extends TPlugins> = {\n  [K in keyof InferPluginTypes<{ plugins: T }>]: InferPluginTypes<{\n    plugins: T\n  }>[K]\n}\n\nexport type BetterAuthReturn<T extends TPlugins> = Omit<ReturnType<typeof betterAuth>, '$Infer'> & {\n  api: T extends (infer P)[] ? InferAPI<UnionToIntersection<ExtractEndpoints<P>>> : {}\n  $Infer: ReturnType<typeof betterAuth>['$Infer'] & PluginInferTypes<T>\n}\n\nexport type BetterAuthFunctionOptions<P extends TPlugins> = Omit<BetterAuthOptions, 'database' | 'plugins'> & {\n  enableDebugLogs?: boolean\n  plugins: P\n}\n"],"names":[],"mappings":"AAqXA,WAGC"}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/better-auth/plugin/types.ts"],"sourcesContent":["import type { UnionToIntersection, betterAuth } from 'better-auth'\nimport type {\n  BetterAuthOptions as BetterAuthOptionsType,\n  BetterAuthPlugin as BetterAuthPluginType,\n  InferAPI,\n  InferPluginTypes\n} from 'better-auth/types'\nimport type { BasePayload, CollectionConfig, Config, Endpoint, Payload, PayloadRequest } from 'payload'\nimport { adminRoutes, loginMethods, socialProviders } from './constants'\n\n/**\n * BetterAuth options with the following caveats:\n * - The `database` option is removed as it is configured internally\n * - The `user` `modelName` and `fields` is removed as it is configured internally\n * - The `account` `modelName` and `fields` is removed as it is configured internally\n * - The `session` `modelName` and `fields` is removed as it is configured internally\n * - The `verification` `modelName` and `fields` is removed as it is configured internally\n *\n * @see https://www.better-auth.com/docs/reference/options\n */\nexport interface BetterAuthOptions\n  extends Omit<BetterAuthOptionsType, 'database' | 'user' | 'account' | 'verification' | 'session' | 'advanced'> {\n  user?: Omit<NonNullable<BetterAuthOptionsType['user']>, 'modelName' | 'fields'> | undefined\n  account?: Omit<NonNullable<BetterAuthOptionsType['account']>, 'modelName' | 'fields'> | undefined\n  session?: Omit<NonNullable<BetterAuthOptionsType['session']>, 'modelName' | 'fields'> | undefined\n  verification?: Omit<NonNullable<BetterAuthOptionsType['verification']>, 'modelName' | 'fields'> | undefined\n  advanced?: Omit<NonNullable<BetterAuthOptionsType['advanced']>, 'generateId'> | undefined\n}\n\nexport interface SanitizedBetterAuthOptions extends Omit<BetterAuthOptionsType, 'database'> {}\n\nexport type SocialProvider = (typeof socialProviders)[number]\n\nexport type LoginMethod = (typeof loginMethods)[number]\n\nexport interface BetterAuthPluginOptions {\n  /**\n   * Disable the plugin\n   * @default false\n   */\n  disabled?: boolean\n  /**\n   * Disable the default payload auth\n   *\n   * This will ensure that better-auth handles both admin and frontend auth\n   *\n   * Admin will make use of custom admin routes for auth and give you more control\n   *\n   * Note: This will override the option passed in the users collection config\n   *\n   * Read about this more in the docs\n   * @see https://www.payloadauth.com/docs/better-auth#disable-default-payload-auth\n   *\n   * @default false\n   */\n  disableDefaultPayloadAuth?: boolean\n  /**\n   * Custom admin components when disableDefaultPayloadAuth is true\n   *\n   * These components will be used to render the login, create first admin, and other auth-related views\n   */\n  admin?: {\n    /**\n     * Override which social buttons are shown in the Payload Login / Sign Up view.\n     *\n     * Provide an array of LoginMethod keys.\n     */\n    loginMethods?: LoginMethod[]\n  }\n  /**\n   * Debug options\n   */\n  debug?: {\n    /**\n     * Enable debug logs\n     * @default false\n     */\n    enableDebugLogs?: boolean\n    /**\n     * Log the tables that are needed for better-auth on init\n     * @default false\n     */\n    logTables?: boolean\n  }\n  /**\n   * Hide the better-authplugin collections from the payload admin UI\n   * @default false\n   */\n  hidePluginCollections?: boolean\n  /**\n   * Defines the admin group for collections.\n   * @default \"Auth\"\n   */\n  collectionAdminGroup?: string\n  /**\n   * Require a valid admin invitation for any *public* sign‑up.\n   *\n   * – Applies to both email/password and social‑provider flows.  \n   * – Existing users can still sign in; admins can still create users via\n   *   the Payload UI or server‑side calls.  \n   * – Ignores provider‑level `disableImplicitSignUp` and `disableSignUp`:\n   *   with a valid invite the sign‑up proceeds, without one it's blocked.\n   * – Also sets `disableImplicitSignUp` for all providers, requiring `requestSignUp` to be true for all `authClient.signIn.social` calls when creating a new account with a provider.\n   *\n   * Enable when you want OAuth for internal/admin use only and no public\n   * registrations at all.\n   *\n   * @default false\n   */\n  requireAdminInviteForSignUp?: boolean\n  /**\n   * Configure the Users collections:\n   */\n  users?: {\n    /**\n     * Will set the `modelName` for the `user` table in better-auth\n     *\n     * and the `slug` for the `users` collection in payload\n     *\n     * @default 'users'\n     */\n    slug?: string | undefined\n    /**\n     * The default role for users\n     *\n     * This will be used as the default role for the role field in the users collection\n     *\n     * If you define this you must also have this role in the roles array\n     *\n     * This will also be used as the defaultRole option in the better-auth admin plugin if present\n     * @see https://www.better-auth.com/docs/plugins/admin#default-role\n     * @default \"user\"\n     */\n    defaultRole?: string\n    /**\n     * The default role for admins\n     *\n     * This will be used as the default role for when admins sign up in the create first admin view or when inviting new admins\n     *\n     *\n     * @default \"admin\"\n     */\n    defaultAdminRole?: string\n    /**\n     * All roles for the users collection\n     *\n     * These will be used to define all the options in the user collection role field\n     *\n     * Will be merged with the adminRoles array, no need to worry about redefining in adminRoles or duplicates\n     *\n     * This should match the roles in the better-auth admin plugin if you are using it\n     * @see https://www.better-auth.com/docs/plugins/admin#access-control\n     *\n     * @default [\"user\"]\n     */\n    roles?: string[]\n    /**\n     * Define admin roles for the users collection\n     *\n     * These roles will be given admin access to all auth collections created by this plugin\n     *\n     * Note: Will be merged with the roles array, no need to worry about redefining in roles or duplicates\n     *\n     * Will be also used as the adminRoles option in the better-auth admin plugin if present\n     *\n     * @see https://www.better-auth.com/docs/plugins/admin#admin-roles\n     *\n     * @default [\"admin\"]\n     */\n    adminRoles?: string[]\n    /**\n     * Hide the `users` collection from the payload admin UI\n     *\n     * This will be overwritten if you change the value in the collection overrides option\n     */\n    hidden?: boolean | undefined\n    /**\n     * Define which fields users can update themselves\n     *\n     * Password field is automatically included and doesn't need to be specified here\n     *\n     * @example ['name', 'dateOfBirth', 'phoneNumber']\n     * @default ['name']\n     */\n    allowedFields?: string[] | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     * Example use cases include adding saveToJwt to specific fields or\n     * modifying field descriptions\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n    /**\n     * This will block the first on sign up verification email from better-auth.\n     * If you are using Payload's userCollection.verify option, you will want to set this to true.\n     * Function that will be blocked: options.emailVerificationsendVerificationEmail\n     * @default false\n     */\n    blockFirstBetterAuthVerificationEmail?: boolean\n  }\n  /**\n   * Configure the Accounts collections:\n   */\n  accounts?: {\n    /**\n     * Will set the `modelName` for the `account` table in better-auth\n     *\n     * and the `slug` for the `accounts` collection in payload\n     *\n     * @default 'accounts'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `accounts` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Sessions collections:\n   */\n  sessions?: {\n    /**\n     * Will set the `modelName` for the `session` table in better-auth\n     *\n     * and the `slug` for the `sessions` collection in payload\n     *\n     * @default 'sessions'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `sessions` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Verifications collections:\n   */\n  verifications?: {\n    /**\n     * Will set the `modelName` for the `verification` table in better-auth\n     *\n     * and the `slug` for the `verifications` collection in payload\n     *\n     * @default 'verifications'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `verifications` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * Configure the Admin Invitations collections:\n   */\n  adminInvitations?: {\n    /**\n     * Will set the `slug` for the `admin-invitations` collection in payload\n     *\n     * @default 'admin-invitations'\n     */\n    slug?: string | undefined\n    /**\n     * Hide the `admin-invitations` collection from the payload admin UI\n     */\n    hidden?: boolean | undefined\n    /**\n     * This will be used to generate the admin invite url\n     *\n     * @param options Object containing payload and the token\n     * @returns The admin invite url\n     */\n    generateInviteUrl?: GenerateAdminInviteUrlFn\n    /**\n     * This will be used to send the admin invite email\n     *\n     * @param options Object containing payload, email and the url\n     * @returns The admin invite url\n     */\n    sendInviteEmail?: SendAdminInviteEmailFn\n    /**\n     * Function to override the collection configuration\n     *\n     * This allows modifying the collection config after it has been built\n     *\n     * @param options Object containing the collection config and potentially additional parameters\n     * @returns Modified collection config\n     */\n    collectionOverrides?: (options: { collection: CollectionConfig }) => CollectionConfig\n  }\n  /**\n   * BetterAuth options with the following caveats:\n   * - The `database` option is removed as it is configured internally\n   * - The `user` `modelName` and `fields` is removed as it is configured internally\n   * - The `account` `modelName` and `fields` is removed as it is configured internally\n   * - The `session` `modelName` and `fields` is removed as it is configured internally\n   * - The `verification` `modelName` and `fields` is removed as it is configured internally\n   *\n   * @see https://www.better-auth.com/docs/reference/options\n   */\n  betterAuthOptions?: BetterAuthOptions\n}\n\nexport type SendAdminInviteEmailFn = (options: { payload: Payload; email: string; url: string }) => Promise<\n  | { success: true; message?: string }\n  | { success: false; message: string }\n>\n\nexport type GenerateAdminInviteUrlFn = (options: { payload: Payload; token: string }) => string\n\nexport type ConfigAdminCustom = {\n  betterAuth: {\n    adminRoutes: {\n      [key in keyof typeof adminRoutes]: string\n    }\n  }\n}\n\nexport interface BetterAuthPlugin {\n  (config: Config): Config\n  pluginOptions: BetterAuthPluginOptions\n}\n\nexport interface PayloadRequestWithBetterAuth<TPlugins extends BetterAuthPluginType[] = []> extends PayloadRequest {\n  payload: BasePayload & {\n    betterAuth: BetterAuthReturn<TPlugins>\n  }\n}\n\nexport type CollectionHookWithBetterAuth<T extends (args: any) => any> = T extends (args: infer A) => infer R\n  ? (args: Omit<A, 'req'> & { req: PayloadRequestWithBetterAuth }) => R\n  : never\n\nexport type EndpointWithBetterAuth = Omit<Endpoint, 'handler'> & {\n  handler: (req: PayloadRequestWithBetterAuth) => Promise<Response> | Response\n}\n\nexport type ExtractEndpoints<T> = T extends BetterAuthPlugin ? (T extends { endpoints?: infer E } ? E : {}) : {}\n\nexport type TPlugins<TPlugins extends BetterAuthPluginType[] = BetterAuthPluginType[]> = TPlugins\n\nexport type PluginInferTypes<T extends TPlugins> = {\n  [K in keyof InferPluginTypes<{ plugins: T }>]: InferPluginTypes<{\n    plugins: T\n  }>[K]\n}\n\nexport type BetterAuthReturn<T extends TPlugins> = Omit<ReturnType<typeof betterAuth>, '$Infer'> & {\n  api: T extends (infer P)[] ? InferAPI<UnionToIntersection<ExtractEndpoints<P>>> : {}\n  $Infer: ReturnType<typeof betterAuth>['$Infer'] & PluginInferTypes<T>\n}\n\nexport type BetterAuthFunctionOptions<P extends TPlugins> = Omit<BetterAuthOptions, 'database' | 'plugins'> & {\n  enableDebugLogs?: boolean\n  plugins: P\n}\n"],"names":[],"mappings":"AA8XA,WAGC"}
|
|
@@ -19,7 +19,7 @@ type FormErrorProps = {
|
|
|
19
19
|
errors?: string[];
|
|
20
20
|
className?: string;
|
|
21
21
|
};
|
|
22
|
-
declare const
|
|
22
|
+
declare const FormError: React.FC<FormErrorProps>;
|
|
23
23
|
type FormProps = ComponentPropsWithoutRef<'form'>;
|
|
24
24
|
declare const Form: React.FC<FormProps>;
|
|
25
25
|
type FormInputWrapProps = ComponentPropsWithoutRef<'div'>;
|
|
@@ -27,5 +27,5 @@ declare const FormInputWrap: React.FC<FormInputWrapProps>;
|
|
|
27
27
|
type FieldInputWrapProps = ComponentPropsWithoutRef<'div'>;
|
|
28
28
|
declare const FieldInputWrap: React.FC<FieldInputWrapProps>;
|
|
29
29
|
export type { FormFieldProps, FormLabelProps, FormErrorProps, FormProps, FormInputWrapProps };
|
|
30
|
-
export { FormField, FormLabel,
|
|
30
|
+
export { FormField, FormLabel, FormError, Form, FormInputWrap, FieldInputWrap };
|
|
31
31
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/form/ui/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,wBAAwB,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAE5E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAGxD,OAAO,cAAc,CAAA;AAErB,KAAK,cAAc,GAAG,wBAAwB,CAAC,KAAK,CAAC,GAAG;IACtD,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAIvC,CAAA;AAED,KAAK,cAAc,GAAG,wBAAwB,CAAC,OAAO,CAAC,GAAG;IACxD,KAAK,EAAE,SAAS,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAKvC,CAAA;AAED,KAAK,gBAAgB,GAAG;IACtB,IAAI,EAAE,YAAY,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,WAAW,GAAI,qBAAqB,gBAAgB,6BAShE,CAAA;AAED,KAAK,cAAc,GAAG;IACpB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/shared/form/ui/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,KAAK,wBAAwB,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAA;AAE5E,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAGxD,OAAO,cAAc,CAAA;AAErB,KAAK,cAAc,GAAG,wBAAwB,CAAC,KAAK,CAAC,GAAG;IACtD,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAIvC,CAAA;AAED,KAAK,cAAc,GAAG,wBAAwB,CAAC,OAAO,CAAC,GAAG;IACxD,KAAK,EAAE,SAAS,CAAA;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAKvC,CAAA;AAED,KAAK,gBAAgB,GAAG;IACtB,IAAI,EAAE,YAAY,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,WAAW,GAAI,qBAAqB,gBAAgB,6BAShE,CAAA;AAED,KAAK,cAAc,GAAG;IACpB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAA;IACjB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CAK9B,CAAA;AAEV,KAAK,SAAS,GAAG,wBAAwB,CAAC,MAAM,CAAC,CAAA;AAEjD,QAAA,MAAM,IAAI,EAAE,KAAK,CAAC,EAAE,CAAC,SAAS,CAI7B,CAAA;AAED,KAAK,kBAAkB,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAA;AAEzD,QAAA,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAI/C,CAAA;AAED,KAAK,mBAAmB,GAAG,wBAAwB,CAAC,KAAK,CAAC,CAAA;AAE1D,QAAA,MAAM,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC,mBAAmB,CAIjD,CAAA;AAED,YAAY,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,SAAS,EAAE,kBAAkB,EAAE,CAAA;AAC7F,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,aAAa,EAAE,cAAc,EAAE,CAAA"}
|
|
@@ -33,11 +33,8 @@ export const FieldErrors = ({ meta, className })=>{
|
|
|
33
33
|
children: error
|
|
34
34
|
});
|
|
35
35
|
};
|
|
36
|
-
const
|
|
37
|
-
|
|
38
|
-
className: clsx('field-error', className),
|
|
39
|
-
delay: 0,
|
|
40
|
-
staticPositioning: true,
|
|
36
|
+
const FormError = ({ errors, className })=>errors ? /*#__PURE__*/ _jsx("div", {
|
|
37
|
+
className: clsx('form-error', className),
|
|
41
38
|
children: errors.join(', ')
|
|
42
39
|
}) : null;
|
|
43
40
|
const Form = ({ children, className, ...rest })=>/*#__PURE__*/ _jsx("form", {
|
|
@@ -55,6 +52,6 @@ const FieldInputWrap = ({ children, className, ...rest })=>/*#__PURE__*/ _jsx("d
|
|
|
55
52
|
...rest,
|
|
56
53
|
children: children
|
|
57
54
|
});
|
|
58
|
-
export { FormField, FormLabel,
|
|
55
|
+
export { FormField, FormLabel, FormError, Form, FormInputWrap, FieldInputWrap };
|
|
59
56
|
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zaGFyZWQvZm9ybS91aS9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHR5cGUgQ29tcG9uZW50UHJvcHNXaXRob3V0UmVmLCB0eXBlIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IGNsc3ggZnJvbSAnY2xzeCdcbmltcG9ydCB0eXBlIHsgQW55RmllbGRNZXRhIH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LWZvcm0nXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnQHBheWxvYWRjbXMvdWkvZWxlbWVudHMvVG9vbHRpcCdcblxuaW1wb3J0ICcuL2luZGV4LnNjc3MnXG5cbnR5cGUgRm9ybUZpZWxkUHJvcHMgPSBDb21wb25lbnRQcm9wc1dpdGhvdXRSZWY8J2Rpdic+ICYge1xuICBoYXNFcnJvcj86IGJvb2xlYW5cbn1cblxuY29uc3QgRm9ybUZpZWxkOiBSZWFjdC5GQzxGb3JtRmllbGRQcm9wcz4gPSAoeyBjaGlsZHJlbiwgaGFzRXJyb3IsIGNsYXNzTmFtZSwgLi4ucmVzdCB9KSA9PiAoXG4gIDxkaXYgY2xhc3NOYW1lPXtjbHN4KCdmaWVsZC10eXBlJywgY2xhc3NOYW1lLCB7IGVycm9yOiBoYXNFcnJvciB9KX0gey4uLnJlc3R9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbnR5cGUgRm9ybUxhYmVsUHJvcHMgPSBDb21wb25lbnRQcm9wc1dpdGhvdXRSZWY8J2xhYmVsJz4gJiB7XG4gIGxhYmVsOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59XG5cbmNvbnN0IEZvcm1MYWJlbDogUmVhY3QuRkM8Rm9ybUxhYmVsUHJvcHM+ID0gKHsgbGFiZWwsIHJlcXVpcmVkID0gZmFsc2UsIGNsYXNzTmFtZSwgLi4ucmVzdCB9KSA9PiAoXG4gIDxsYWJlbCBjbGFzc05hbWU9e2Nsc3goJ2ZpZWxkLWxhYmVsJywgY2xhc3NOYW1lKX0gey4uLnJlc3R9PlxuICAgIHtsYWJlbH1cbiAgICB7cmVxdWlyZWQgJiYgPHNwYW4gY2xhc3NOYW1lPVwicmVxdWlyZWRcIj4qPC9zcGFuPn1cbiAgPC9sYWJlbD5cbilcblxudHlwZSBGaWVsZEVycm9yc1Byb3BzID0ge1xuICBtZXRhOiBBbnlGaWVsZE1ldGFcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEVycm9ycyA9ICh7IG1ldGEsIGNsYXNzTmFtZSB9OiBGaWVsZEVycm9yc1Byb3BzKSA9PiB7XG4gIGlmICghbWV0YS5pc1RvdWNoZWQpIHJldHVybiBudWxsXG4gIGNvbnN0IGVycm9yID0gbWV0YS5lcnJvcnMuYXQoMCk/Lm1lc3NhZ2UgfHwgbnVsbFxuXG4gIHJldHVybiAoXG4gICAgPFRvb2x0aXAgYWxpZ25DYXJldD1cInJpZ2h0XCIgY2xhc3NOYW1lPXtjbHN4KCdmaWVsZC1lcnJvcicsIGNsYXNzTmFtZSl9IHNob3c9eyEhZXJyb3J9IGRlbGF5PXswfSBzdGF0aWNQb3NpdGlvbmluZz5cbiAgICAgIHtlcnJvcn1cbiAgICA8L1Rvb2x0aXA+
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zaGFyZWQvZm9ybS91aS9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHR5cGUgQ29tcG9uZW50UHJvcHNXaXRob3V0UmVmLCB0eXBlIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IGNsc3ggZnJvbSAnY2xzeCdcbmltcG9ydCB0eXBlIHsgQW55RmllbGRNZXRhIH0gZnJvbSAnQHRhbnN0YWNrL3JlYWN0LWZvcm0nXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnQHBheWxvYWRjbXMvdWkvZWxlbWVudHMvVG9vbHRpcCdcblxuaW1wb3J0ICcuL2luZGV4LnNjc3MnXG5cbnR5cGUgRm9ybUZpZWxkUHJvcHMgPSBDb21wb25lbnRQcm9wc1dpdGhvdXRSZWY8J2Rpdic+ICYge1xuICBoYXNFcnJvcj86IGJvb2xlYW5cbn1cblxuY29uc3QgRm9ybUZpZWxkOiBSZWFjdC5GQzxGb3JtRmllbGRQcm9wcz4gPSAoeyBjaGlsZHJlbiwgaGFzRXJyb3IsIGNsYXNzTmFtZSwgLi4ucmVzdCB9KSA9PiAoXG4gIDxkaXYgY2xhc3NOYW1lPXtjbHN4KCdmaWVsZC10eXBlJywgY2xhc3NOYW1lLCB7IGVycm9yOiBoYXNFcnJvciB9KX0gey4uLnJlc3R9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9kaXY+XG4pXG5cbnR5cGUgRm9ybUxhYmVsUHJvcHMgPSBDb21wb25lbnRQcm9wc1dpdGhvdXRSZWY8J2xhYmVsJz4gJiB7XG4gIGxhYmVsOiBSZWFjdE5vZGVcbiAgcmVxdWlyZWQ/OiBib29sZWFuXG59XG5cbmNvbnN0IEZvcm1MYWJlbDogUmVhY3QuRkM8Rm9ybUxhYmVsUHJvcHM+ID0gKHsgbGFiZWwsIHJlcXVpcmVkID0gZmFsc2UsIGNsYXNzTmFtZSwgLi4ucmVzdCB9KSA9PiAoXG4gIDxsYWJlbCBjbGFzc05hbWU9e2Nsc3goJ2ZpZWxkLWxhYmVsJywgY2xhc3NOYW1lKX0gey4uLnJlc3R9PlxuICAgIHtsYWJlbH1cbiAgICB7cmVxdWlyZWQgJiYgPHNwYW4gY2xhc3NOYW1lPVwicmVxdWlyZWRcIj4qPC9zcGFuPn1cbiAgPC9sYWJlbD5cbilcblxudHlwZSBGaWVsZEVycm9yc1Byb3BzID0ge1xuICBtZXRhOiBBbnlGaWVsZE1ldGFcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG59XG5cbmV4cG9ydCBjb25zdCBGaWVsZEVycm9ycyA9ICh7IG1ldGEsIGNsYXNzTmFtZSB9OiBGaWVsZEVycm9yc1Byb3BzKSA9PiB7XG4gIGlmICghbWV0YS5pc1RvdWNoZWQpIHJldHVybiBudWxsXG4gIGNvbnN0IGVycm9yID0gbWV0YS5lcnJvcnMuYXQoMCk/Lm1lc3NhZ2UgfHwgbnVsbFxuXG4gIHJldHVybiAoXG4gICAgPFRvb2x0aXAgYWxpZ25DYXJldD1cInJpZ2h0XCIgY2xhc3NOYW1lPXtjbHN4KCdmaWVsZC1lcnJvcicsIGNsYXNzTmFtZSl9IHNob3c9eyEhZXJyb3J9IGRlbGF5PXswfSBzdGF0aWNQb3NpdGlvbmluZz5cbiAgICAgIHtlcnJvcn1cbiAgICA8L1Rvb2x0aXA+XG4gIClcbn1cblxudHlwZSBGb3JtRXJyb3JQcm9wcyA9IHtcbiAgZXJyb3JzPzogc3RyaW5nW11cbiAgY2xhc3NOYW1lPzogc3RyaW5nXG59XG5cbmNvbnN0IEZvcm1FcnJvcjogUmVhY3QuRkM8Rm9ybUVycm9yUHJvcHM+ID0gKHsgZXJyb3JzLCBjbGFzc05hbWUgfSkgPT5cbiAgZXJyb3JzID8gKFxuICAgIDxkaXYgY2xhc3NOYW1lPXtjbHN4KCdmb3JtLWVycm9yJywgY2xhc3NOYW1lKX0+XG4gICAgICB7ZXJyb3JzLmpvaW4oJywgJyl9XG4gICAgPC9kaXY+XG4gICkgOiBudWxsXG5cbnR5cGUgRm9ybVByb3BzID0gQ29tcG9uZW50UHJvcHNXaXRob3V0UmVmPCdmb3JtJz5cblxuY29uc3QgRm9ybTogUmVhY3QuRkM8Rm9ybVByb3BzPiA9ICh7IGNoaWxkcmVuLCBjbGFzc05hbWUsIC4uLnJlc3QgfSkgPT4gKFxuICA8Zm9ybSBjbGFzc05hbWU9e2Nsc3goJ2Zvcm0nLCBjbGFzc05hbWUpfSB7Li4ucmVzdH0+XG4gICAge2NoaWxkcmVufVxuICA8L2Zvcm0+XG4pXG5cbnR5cGUgRm9ybUlucHV0V3JhcFByb3BzID0gQ29tcG9uZW50UHJvcHNXaXRob3V0UmVmPCdkaXYnPlxuXG5jb25zdCBGb3JtSW5wdXRXcmFwOiBSZWFjdC5GQzxGb3JtSW5wdXRXcmFwUHJvcHM+ID0gKHsgY2hpbGRyZW4sIGNsYXNzTmFtZSwgLi4ucmVzdCB9KSA9PiAoXG4gIDxkaXYgY2xhc3NOYW1lPXtgJHtjbGFzc05hbWV9X19pbnB1dFdyYXBgfSB7Li4ucmVzdH0+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxudHlwZSBGaWVsZElucHV0V3JhcFByb3BzID0gQ29tcG9uZW50UHJvcHNXaXRob3V0UmVmPCdkaXYnPlxuXG5jb25zdCBGaWVsZElucHV0V3JhcDogUmVhY3QuRkM8RmllbGRJbnB1dFdyYXBQcm9wcz4gPSAoeyBjaGlsZHJlbiwgY2xhc3NOYW1lLCAuLi5yZXN0IH0pID0+IChcbiAgPGRpdiBjbGFzc05hbWU9e2Nsc3goJ2ZpZWxkLXR5cGVfX3dyYXAnLCBjbGFzc05hbWUpfSB7Li4ucmVzdH0+XG4gICAge2NoaWxkcmVufVxuICA8L2Rpdj5cbilcblxuZXhwb3J0IHR5cGUgeyBGb3JtRmllbGRQcm9wcywgRm9ybUxhYmVsUHJvcHMsIEZvcm1FcnJvclByb3BzLCBGb3JtUHJvcHMsIEZvcm1JbnB1dFdyYXBQcm9wcyB9XG5leHBvcnQgeyBGb3JtRmllbGQsIEZvcm1MYWJlbCwgRm9ybUVycm9yLCBGb3JtLCBGb3JtSW5wdXRXcmFwLCBGaWVsZElucHV0V3JhcCB9XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJjbHN4IiwiVG9vbHRpcCIsIkZvcm1GaWVsZCIsImNoaWxkcmVuIiwiaGFzRXJyb3IiLCJjbGFzc05hbWUiLCJyZXN0IiwiZGl2IiwiZXJyb3IiLCJGb3JtTGFiZWwiLCJsYWJlbCIsInJlcXVpcmVkIiwic3BhbiIsIkZpZWxkRXJyb3JzIiwibWV0YSIsImlzVG91Y2hlZCIsImVycm9ycyIsImF0IiwibWVzc2FnZSIsImFsaWduQ2FyZXQiLCJzaG93IiwiZGVsYXkiLCJzdGF0aWNQb3NpdGlvbmluZyIsIkZvcm1FcnJvciIsImpvaW4iLCJGb3JtIiwiZm9ybSIsIkZvcm1JbnB1dFdyYXAiLCJGaWVsZElucHV0V3JhcCJdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU9BLFdBQThELFFBQU87QUFDNUUsT0FBT0MsVUFBVSxPQUFNO0FBRXZCLFNBQVNDLE9BQU8sUUFBUSxrQ0FBaUM7QUFFekQsT0FBTyxlQUFjO0FBTXJCLE1BQU1DLFlBQXNDLENBQUMsRUFBRUMsUUFBUSxFQUFFQyxRQUFRLEVBQUVDLFNBQVMsRUFBRSxHQUFHQyxNQUFNLGlCQUNyRixLQUFDQztRQUFJRixXQUFXTCxLQUFLLGNBQWNLLFdBQVc7WUFBRUcsT0FBT0o7UUFBUztRQUFLLEdBQUdFLElBQUk7a0JBQ3pFSDs7QUFTTCxNQUFNTSxZQUFzQyxDQUFDLEVBQUVDLEtBQUssRUFBRUMsV0FBVyxLQUFLLEVBQUVOLFNBQVMsRUFBRSxHQUFHQyxNQUFNLGlCQUMxRixNQUFDSTtRQUFNTCxXQUFXTCxLQUFLLGVBQWVLO1FBQWEsR0FBR0MsSUFBSTs7WUFDdkRJO1lBQ0FDLDBCQUFZLEtBQUNDO2dCQUFLUCxXQUFVOzBCQUFXOzs7O0FBUzVDLE9BQU8sTUFBTVEsY0FBYyxDQUFDLEVBQUVDLElBQUksRUFBRVQsU0FBUyxFQUFvQjtJQUMvRCxJQUFJLENBQUNTLEtBQUtDLFNBQVMsRUFBRSxPQUFPO0lBQzVCLE1BQU1QLFFBQVFNLEtBQUtFLE1BQU0sQ0FBQ0MsRUFBRSxDQUFDLElBQUlDLFdBQVc7SUFFNUMscUJBQ0UsS0FBQ2pCO1FBQVFrQixZQUFXO1FBQVFkLFdBQVdMLEtBQUssZUFBZUs7UUFBWWUsTUFBTSxDQUFDLENBQUNaO1FBQU9hLE9BQU87UUFBR0MsaUJBQWlCO2tCQUM5R2Q7O0FBR1AsRUFBQztBQU9ELE1BQU1lLFlBQXNDLENBQUMsRUFBRVAsTUFBTSxFQUFFWCxTQUFTLEVBQUUsR0FDaEVXLHVCQUNFLEtBQUNUO1FBQUlGLFdBQVdMLEtBQUssY0FBY0s7a0JBQ2hDVyxPQUFPUSxJQUFJLENBQUM7U0FFYjtBQUlOLE1BQU1DLE9BQTRCLENBQUMsRUFBRXRCLFFBQVEsRUFBRUUsU0FBUyxFQUFFLEdBQUdDLE1BQU0saUJBQ2pFLEtBQUNvQjtRQUFLckIsV0FBV0wsS0FBSyxRQUFRSztRQUFhLEdBQUdDLElBQUk7a0JBQy9DSDs7QUFNTCxNQUFNd0IsZ0JBQThDLENBQUMsRUFBRXhCLFFBQVEsRUFBRUUsU0FBUyxFQUFFLEdBQUdDLE1BQU0saUJBQ25GLEtBQUNDO1FBQUlGLFdBQVcsR0FBR0EsVUFBVSxXQUFXLENBQUM7UUFBRyxHQUFHQyxJQUFJO2tCQUNoREg7O0FBTUwsTUFBTXlCLGlCQUFnRCxDQUFDLEVBQUV6QixRQUFRLEVBQUVFLFNBQVMsRUFBRSxHQUFHQyxNQUFNLGlCQUNyRixLQUFDQztRQUFJRixXQUFXTCxLQUFLLG9CQUFvQks7UUFBYSxHQUFHQyxJQUFJO2tCQUMxREg7O0FBS0wsU0FBU0QsU0FBUyxFQUFFTyxTQUFTLEVBQUVjLFNBQVMsRUFBRUUsSUFBSSxFQUFFRSxhQUFhLEVBQUVDLGNBQWMsR0FBRSJ9
|
|
@@ -10,3 +10,18 @@
|
|
|
10
10
|
padding: 4px 8px;
|
|
11
11
|
line-height: 15px;
|
|
12
12
|
}
|
|
13
|
+
|
|
14
|
+
html[data-theme="light"] .form-error {
|
|
15
|
+
background-color: var(--theme-error-200);
|
|
16
|
+
color: black;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.form-error {
|
|
20
|
+
display: block;
|
|
21
|
+
color: var(--theme-error-950);
|
|
22
|
+
background-color: var(--theme-error-300);
|
|
23
|
+
color: white;
|
|
24
|
+
border-radius: var(--style-radius-s);
|
|
25
|
+
padding: 10px 15px;
|
|
26
|
+
margin-bottom: 1.2rem;
|
|
27
|
+
}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
/**
|
|
3
|
+
* Minimal translation function type extracted from `i18next`.
|
|
4
|
+
* Accepts a key and returns the translated string.
|
|
5
|
+
*/
|
|
6
|
+
export type Translate = (...args: any[]) => string;
|
|
7
|
+
export declare const emailField: ({ t, required }: {
|
|
8
|
+
t: Translate;
|
|
9
|
+
required?: boolean;
|
|
10
|
+
}) => z.ZodEffects<z.ZodString, string, string>;
|
|
11
|
+
export declare const usernameField: ({ t, required, minLength, maxLength }: {
|
|
12
|
+
t: Translate;
|
|
13
|
+
required?: boolean;
|
|
14
|
+
minLength?: number;
|
|
15
|
+
maxLength?: number;
|
|
16
|
+
}) => z.ZodEffects<z.ZodString, string, string>;
|
|
17
|
+
export declare const passwordField: ({ t, required, minLength }: {
|
|
18
|
+
t: Translate;
|
|
19
|
+
required?: boolean;
|
|
20
|
+
minLength?: number;
|
|
21
|
+
}) => z.ZodString;
|
|
22
|
+
export declare const confirmPasswordField: ({ t, required }: {
|
|
23
|
+
t: Translate;
|
|
24
|
+
required?: boolean;
|
|
25
|
+
}) => z.ZodString;
|
|
26
|
+
/**
|
|
27
|
+
* Returns a Zod object schema with `password` and `confirmPassword` fields
|
|
28
|
+
* and a refinement that ensures they match.
|
|
29
|
+
*/
|
|
30
|
+
export declare const passwordWithConfirmation: ({ t, minLength }: {
|
|
31
|
+
t: Translate;
|
|
32
|
+
minLength?: number;
|
|
33
|
+
}) => z.ZodEffects<z.ZodObject<{
|
|
34
|
+
password: z.ZodString;
|
|
35
|
+
confirmPassword: z.ZodString;
|
|
36
|
+
}, "strip", z.ZodTypeAny, {
|
|
37
|
+
password: string;
|
|
38
|
+
confirmPassword: string;
|
|
39
|
+
}, {
|
|
40
|
+
password: string;
|
|
41
|
+
confirmPassword: string;
|
|
42
|
+
}>, {
|
|
43
|
+
password: string;
|
|
44
|
+
confirmPassword: string;
|
|
45
|
+
}, {
|
|
46
|
+
password: string;
|
|
47
|
+
confirmPassword: string;
|
|
48
|
+
}>;
|
|
49
|
+
export declare const isValidEmail: (val: string) => boolean;
|
|
50
|
+
export declare const isValidUsername: (val: string, { minLength, maxLength }?: {
|
|
51
|
+
minLength?: number;
|
|
52
|
+
maxLength?: number;
|
|
53
|
+
}) => boolean;
|
|
54
|
+
type UsernameSettings = {
|
|
55
|
+
minLength: number;
|
|
56
|
+
maxLength: number;
|
|
57
|
+
};
|
|
58
|
+
export declare const createLoginSchema: ({ t, loginType, canLoginWithUsername, usernameSettings }: {
|
|
59
|
+
t: Translate;
|
|
60
|
+
loginType: "email" | "username" | "emailOrUsername";
|
|
61
|
+
canLoginWithUsername?: boolean;
|
|
62
|
+
usernameSettings?: UsernameSettings;
|
|
63
|
+
}) => z.ZodObject<{
|
|
64
|
+
login: z.ZodEffects<z.ZodString, string, string>;
|
|
65
|
+
password: z.ZodString;
|
|
66
|
+
}, "strip", z.ZodTypeAny, {
|
|
67
|
+
password: string;
|
|
68
|
+
login: string;
|
|
69
|
+
}, {
|
|
70
|
+
password: string;
|
|
71
|
+
login: string;
|
|
72
|
+
}>;
|
|
73
|
+
export declare const createSignupSchema: ({ t, requireUsername }: {
|
|
74
|
+
t: Translate;
|
|
75
|
+
requireUsername?: boolean;
|
|
76
|
+
}) => z.ZodEffects<z.ZodObject<{
|
|
77
|
+
email: z.ZodEffects<z.ZodString, string, string>;
|
|
78
|
+
username: z.ZodOptional<z.ZodEffects<z.ZodString, string, string>>;
|
|
79
|
+
password: z.ZodString;
|
|
80
|
+
confirmPassword: z.ZodString;
|
|
81
|
+
}, "strip", z.ZodTypeAny, {
|
|
82
|
+
email: string;
|
|
83
|
+
password: string;
|
|
84
|
+
confirmPassword: string;
|
|
85
|
+
username?: string | undefined;
|
|
86
|
+
}, {
|
|
87
|
+
email: string;
|
|
88
|
+
password: string;
|
|
89
|
+
confirmPassword: string;
|
|
90
|
+
username?: string | undefined;
|
|
91
|
+
}>, {
|
|
92
|
+
email: string;
|
|
93
|
+
password: string;
|
|
94
|
+
confirmPassword: string;
|
|
95
|
+
username?: string | undefined;
|
|
96
|
+
}, {
|
|
97
|
+
email: string;
|
|
98
|
+
password: string;
|
|
99
|
+
confirmPassword: string;
|
|
100
|
+
username?: string | undefined;
|
|
101
|
+
}>;
|
|
102
|
+
export {};
|
|
103
|
+
//# sourceMappingURL=validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../src/shared/form/validation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAA;AAQvB;;;GAGG;AACH,MAAM,MAAM,SAAS,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,MAAM,CAAA;AAMlD,eAAO,MAAM,UAAU,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,8CAMtF,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,uCAK3B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,8CAMA,CAAA;AAED,eAAO,MAAM,aAAa,GAAI,4BAAuC;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE,gBAI5H,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,iBAAwB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,gBAIhG,CAAA;AAMD;;;GAGG;AACH,eAAO,MAAM,wBAAwB,GAAI,kBAAsB;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAE;;;;;;;;;;;;;;;EAS7F,CAAA;AAMN,eAAO,MAAM,YAAY,GAAI,KAAK,MAAM,YAAyB,CAAA;AACjE,eAAO,MAAM,eAAe,GAAI,KAAK,MAAM,EAAE,2BAAoC;IAAE,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAO,YACjD,CAAA;AAM/E,KAAK,gBAAgB,GAAG;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,CAAA;AAEhE,eAAO,MAAM,iBAAiB,GAAI,0DAK/B;IACD,CAAC,EAAE,SAAS,CAAA;IACZ,SAAS,EAAE,OAAO,GAAG,UAAU,GAAG,iBAAiB,CAAA;IACnD,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC;;;;;;;;;EA8BG,CAAA;AAEJ,eAAO,MAAM,kBAAkB,GAAI,wBAAgC;IAAE,CAAC,EAAE,SAAS,CAAC;IAAC,eAAe,CAAC,EAAE,OAAO,CAAA;CAAE;;;;;;;;;;;;;;;;;;;;;;;;;EAWxG,CAAA"}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { emailRegex, usernameRegex } from "../utils/regex";
|
|
3
|
+
// ---------------------------------------------------------------------------
|
|
4
|
+
// Field builders
|
|
5
|
+
// ---------------------------------------------------------------------------
|
|
6
|
+
export const emailField = ({ t, required = true })=>{
|
|
7
|
+
let schema = z.string();
|
|
8
|
+
if (required) schema = schema.min(1, t('validation:required'));
|
|
9
|
+
return schema.refine((val)=>emailRegex.test(val), {
|
|
10
|
+
message: t('authentication:emailNotValid') || 'Email is not valid'
|
|
11
|
+
});
|
|
12
|
+
};
|
|
13
|
+
export const usernameField = ({ t, required = true, minLength = 5, maxLength = 128 })=>{
|
|
14
|
+
let schema = z.string();
|
|
15
|
+
if (required) schema = schema.min(1, t('validation:required'));
|
|
16
|
+
return schema.refine((val)=>usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength, {
|
|
17
|
+
message: t('authentication:usernameNotValid') || 'Username is not valid'
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
export const passwordField = ({ t, required = true, minLength = 1 })=>{
|
|
21
|
+
let schema = z.string();
|
|
22
|
+
if (required) schema = schema.min(minLength, t('validation:required') || 'Password is required');
|
|
23
|
+
return schema;
|
|
24
|
+
};
|
|
25
|
+
export const confirmPasswordField = ({ t, required = true })=>{
|
|
26
|
+
let schema = z.string();
|
|
27
|
+
if (required) schema = schema.min(1, t('validation:required') || 'Confirm password is required');
|
|
28
|
+
return schema;
|
|
29
|
+
};
|
|
30
|
+
// ---------------------------------------------------------------------------
|
|
31
|
+
// Composables
|
|
32
|
+
// ---------------------------------------------------------------------------
|
|
33
|
+
/**
|
|
34
|
+
* Returns a Zod object schema with `password` and `confirmPassword` fields
|
|
35
|
+
* and a refinement that ensures they match.
|
|
36
|
+
*/ export const passwordWithConfirmation = ({ t, minLength = 1 })=>z.object({
|
|
37
|
+
password: passwordField({
|
|
38
|
+
t,
|
|
39
|
+
minLength
|
|
40
|
+
}),
|
|
41
|
+
confirmPassword: confirmPasswordField({
|
|
42
|
+
t
|
|
43
|
+
})
|
|
44
|
+
}).refine((data)=>data.password === data.confirmPassword, {
|
|
45
|
+
path: [
|
|
46
|
+
'confirmPassword'
|
|
47
|
+
],
|
|
48
|
+
message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'
|
|
49
|
+
});
|
|
50
|
+
// ---------------------------------------------------------------------------
|
|
51
|
+
// Utility validators (non‑Zod) — handy for dynamic login field checks
|
|
52
|
+
// ---------------------------------------------------------------------------
|
|
53
|
+
export const isValidEmail = (val)=>emailRegex.test(val);
|
|
54
|
+
export const isValidUsername = (val, { minLength = 5, maxLength = 128 } = {})=>usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength;
|
|
55
|
+
export const createLoginSchema = ({ t, loginType, canLoginWithUsername = false, usernameSettings = {
|
|
56
|
+
minLength: 5,
|
|
57
|
+
maxLength: 128
|
|
58
|
+
} })=>z.object({
|
|
59
|
+
login: z.string().refine((val)=>{
|
|
60
|
+
if (!val) return false;
|
|
61
|
+
if (loginType === 'email') return isValidEmail(val);
|
|
62
|
+
if (loginType === 'username') return isValidUsername(val, usernameSettings);
|
|
63
|
+
return isValidEmail(val) || isValidUsername(val, usernameSettings);
|
|
64
|
+
}, (val)=>{
|
|
65
|
+
if (!val) return {
|
|
66
|
+
message: t('validation:required')
|
|
67
|
+
};
|
|
68
|
+
const isProbablyEmail = val.includes('@') || !canLoginWithUsername;
|
|
69
|
+
if (loginType === 'email') {
|
|
70
|
+
return {
|
|
71
|
+
message: t('authentication:emailNotValid') || 'Email is not valid'
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
if (loginType === 'username') {
|
|
75
|
+
return {
|
|
76
|
+
message: t('authentication:usernameNotValid') || 'Username is not valid'
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
return {
|
|
80
|
+
message: isProbablyEmail ? t('authentication:emailNotValid') || 'Email is not valid' : t('authentication:usernameNotValid') || 'Username is not valid'
|
|
81
|
+
};
|
|
82
|
+
}),
|
|
83
|
+
password: passwordField({
|
|
84
|
+
t
|
|
85
|
+
})
|
|
86
|
+
});
|
|
87
|
+
export const createSignupSchema = ({ t, requireUsername = false })=>z.object({
|
|
88
|
+
email: emailField({
|
|
89
|
+
t
|
|
90
|
+
}),
|
|
91
|
+
username: usernameField({
|
|
92
|
+
t,
|
|
93
|
+
required: requireUsername
|
|
94
|
+
}).optional(),
|
|
95
|
+
password: passwordField({
|
|
96
|
+
t
|
|
97
|
+
}),
|
|
98
|
+
confirmPassword: confirmPasswordField({
|
|
99
|
+
t
|
|
100
|
+
})
|
|
101
|
+
}).refine((data)=>data.password === data.confirmPassword, {
|
|
102
|
+
path: [
|
|
103
|
+
'confirmPassword'
|
|
104
|
+
],
|
|
105
|
+
message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'
|
|
106
|
+
});
|
|
107
|
+
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/shared/form/validation.ts"],"sourcesContent":["import { z } from 'zod'\n\nimport { emailRegex, usernameRegex } from '@/shared/utils/regex'\n\n// ---------------------------------------------------------------------------\n// Types\n// ---------------------------------------------------------------------------\n\n/**\n * Minimal translation function type extracted from `i18next`.\n * Accepts a key and returns the translated string.\n */\nexport type Translate = (...args: any[]) => string\n\n// ---------------------------------------------------------------------------\n// Field builders\n// ---------------------------------------------------------------------------\n\nexport const emailField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => emailRegex.test(val), {\n    message: t('authentication:emailNotValid') || 'Email is not valid'\n  })\n}\n\nexport const usernameField = ({\n  t,\n  required = true,\n  minLength = 5,\n  maxLength = 128\n}: {\n  t: Translate\n  required?: boolean\n  minLength?: number\n  maxLength?: number\n}) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required'))\n  return schema.refine((val) => usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength, {\n    message: t('authentication:usernameNotValid') || 'Username is not valid'\n  })\n}\n\nexport const passwordField = ({ t, required = true, minLength = 1 }: { t: Translate; required?: boolean; minLength?: number }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(minLength, t('validation:required') || 'Password is required')\n  return schema\n}\n\nexport const confirmPasswordField = ({ t, required = true }: { t: Translate; required?: boolean }) => {\n  let schema = z.string()\n  if (required) schema = schema.min(1, t('validation:required') || 'Confirm password is required')\n  return schema\n}\n\n// ---------------------------------------------------------------------------\n// Composables\n// ---------------------------------------------------------------------------\n\n/**\n * Returns a Zod object schema with `password` and `confirmPassword` fields\n * and a refinement that ensures they match.\n */\nexport const passwordWithConfirmation = ({ t, minLength = 1 }: { t: Translate; minLength?: number }) =>\n  z\n    .object({\n      password: passwordField({ t, minLength }),\n      confirmPassword: confirmPasswordField({ t })\n    })\n    .refine((data) => data.password === data.confirmPassword, {\n      path: ['confirmPassword'],\n      message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n    })\n\n// ---------------------------------------------------------------------------\n// Utility validators (non‑Zod) — handy for dynamic login field checks\n// ---------------------------------------------------------------------------\n\nexport const isValidEmail = (val: string) => emailRegex.test(val)\nexport const isValidUsername = (val: string, { minLength = 5, maxLength = 128 }: { minLength?: number; maxLength?: number } = {}) =>\n  usernameRegex.test(val) && val.length >= minLength && val.length <= maxLength\n\n// ---------------------------------------------------------------------------\n// Schema builders\n// ---------------------------------------------------------------------------\n\ntype UsernameSettings = { minLength: number; maxLength: number }\n\nexport const createLoginSchema = ({\n  t,\n  loginType,\n  canLoginWithUsername = false,\n  usernameSettings = { minLength: 5, maxLength: 128 }\n}: {\n  t: Translate\n  loginType: 'email' | 'username' | 'emailOrUsername'\n  canLoginWithUsername?: boolean\n  usernameSettings?: UsernameSettings\n}) =>\n  z.object({\n    login: z.string().refine(\n      (val) => {\n        if (!val) return false\n        if (loginType === 'email') return isValidEmail(val)\n        if (loginType === 'username') return isValidUsername(val, usernameSettings)\n        return isValidEmail(val) || isValidUsername(val, usernameSettings)\n      },\n      (val) => {\n        if (!val) return { message: t('validation:required') }\n\n        const isProbablyEmail = val.includes('@') || !canLoginWithUsername\n\n        if (loginType === 'email') {\n          return { message: t('authentication:emailNotValid') || 'Email is not valid' }\n        }\n\n        if (loginType === 'username') {\n          return { message: t('authentication:usernameNotValid') || 'Username is not valid' }\n        }\n\n        return {\n          message: isProbablyEmail\n            ? t('authentication:emailNotValid') || 'Email is not valid'\n            : t('authentication:usernameNotValid') || 'Username is not valid'\n        }\n      }\n    ),\n    password: passwordField({ t })\n  })\n\nexport const createSignupSchema = ({ t, requireUsername = false }: { t: Translate; requireUsername?: boolean }) =>\n  z\n    .object({\n      email: emailField({ t }),\n      username: usernameField({ t, required: requireUsername }).optional(),\n      password: passwordField({ t }),\n      confirmPassword: confirmPasswordField({ t })\n    })\n    .refine((data) => data.password === data.confirmPassword, {\n      path: ['confirmPassword'],\n      message: t('fields:passwordsDoNotMatch') || 'Passwords do not match'\n    })\n"],"names":["z","emailRegex","usernameRegex","emailField","t","required","schema","string","min","refine","val","test","message","usernameField","minLength","maxLength","length","passwordField","confirmPasswordField","passwordWithConfirmation","object","password","confirmPassword","data","path","isValidEmail","isValidUsername","createLoginSchema","loginType","canLoginWithUsername","usernameSettings","login","isProbablyEmail","includes","createSignupSchema","requireUsername","email","username","optional"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
|
-
import type { SocialProviders } from '@/better-auth/plugin/types';
|
|
3
|
-
import './index.scss';
|
|
4
|
-
type AdminSocialProviderButtonsProps = {
|
|
5
|
-
allowSignup: boolean;
|
|
6
|
-
socialProviders: SocialProviders;
|
|
7
|
-
setLoading: (loading: boolean) => void;
|
|
8
|
-
hasPasskeySupport?: boolean;
|
|
9
|
-
redirectUrl?: string;
|
|
10
|
-
newUserCallbackURL?: string;
|
|
11
|
-
};
|
|
12
|
-
declare const AdminSocialProviderButtons: React.FC<AdminSocialProviderButtonsProps>;
|
|
13
|
-
export default AdminSocialProviderButtons;
|
|
14
|
-
//# sourceMappingURL=index.d.ts.map
|
package/dist/better-auth/plugin/payload/components/admin-social-provider-buttons/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/admin-social-provider-buttons/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAkB,MAAM,OAAO,CAAA;AAMtC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAA;AAGjE,OAAO,cAAc,CAAA;AAErB,KAAK,+BAA+B,GAAG;IACrC,WAAW,EAAE,OAAO,CAAA;IACpB,eAAe,EAAE,eAAe,CAAA;IAChC,UAAU,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,IAAI,CAAA;IACtC,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,kBAAkB,CAAC,EAAE,MAAM,CAAA;CAC5B,CAAA;AAID,QAAA,MAAM,0BAA0B,EAAE,KAAK,CAAC,EAAE,CAAC,+BAA+B,CA8FzE,CAAA;AAED,eAAe,0BAA0B,CAAA"}
|
|
@@ -1,109 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
-
import React, { useMemo } from "react";
|
|
4
|
-
import { Icons } from "../../../../../shared/components/icons";
|
|
5
|
-
import { Key } from "lucide-react";
|
|
6
|
-
import { useRouter } from "next/navigation";
|
|
7
|
-
import { Button, toast } from "@payloadcms/ui";
|
|
8
|
-
import { createAuthClient } from "better-auth/react";
|
|
9
|
-
import { passkeyClient } from "better-auth/client/plugins";
|
|
10
|
-
import "./index.scss";
|
|
11
|
-
const baseClass = 'admin-social-provider-buttons';
|
|
12
|
-
const AdminSocialProviderButtons = ({ allowSignup, socialProviders, setLoading, hasPasskeySupport, redirectUrl, newUserCallbackURL })=>{
|
|
13
|
-
const router = useRouter();
|
|
14
|
-
const authClient = useMemo(()=>createAuthClient({
|
|
15
|
-
plugins: [
|
|
16
|
-
passkeyClient()
|
|
17
|
-
]
|
|
18
|
-
}), []);
|
|
19
|
-
const providers = Object.keys(socialProviders ?? {});
|
|
20
|
-
const providerCount = providers.length;
|
|
21
|
-
const renderProviderButton = (provider, showIconOnly)=>{
|
|
22
|
-
const providerConfig = socialProviders?.[provider];
|
|
23
|
-
const Icon = Icons[provider];
|
|
24
|
-
const providerName = provider.charAt(0).toUpperCase() + provider.slice(1);
|
|
25
|
-
return /*#__PURE__*/ _jsx(Button, {
|
|
26
|
-
type: "button",
|
|
27
|
-
size: "large",
|
|
28
|
-
className: `${baseClass}__button provider--${provider}`,
|
|
29
|
-
onClick: async ()=>{
|
|
30
|
-
setLoading(true);
|
|
31
|
-
try {
|
|
32
|
-
await authClient.signIn.social({
|
|
33
|
-
provider: provider,
|
|
34
|
-
requestSignUp: allowSignup ? true : !providerConfig?.disableSignUp,
|
|
35
|
-
callbackURL: redirectUrl,
|
|
36
|
-
newUserCallbackURL: newUserCallbackURL
|
|
37
|
-
});
|
|
38
|
-
} catch (error) {
|
|
39
|
-
toast.error(`Failed to sign in with ${providerName}`);
|
|
40
|
-
} finally{
|
|
41
|
-
setLoading(false);
|
|
42
|
-
}
|
|
43
|
-
},
|
|
44
|
-
icon: showIconOnly ? /*#__PURE__*/ _jsx(Icon, {
|
|
45
|
-
className: `${baseClass}__icon`
|
|
46
|
-
}) : undefined,
|
|
47
|
-
tooltip: showIconOnly ? `Sign in with ${providerName}` : undefined,
|
|
48
|
-
children: !showIconOnly && /*#__PURE__*/ _jsxs(_Fragment, {
|
|
49
|
-
children: [
|
|
50
|
-
/*#__PURE__*/ _jsx(Icon, {
|
|
51
|
-
className: `${baseClass}__icon`
|
|
52
|
-
}),
|
|
53
|
-
" ",
|
|
54
|
-
/*#__PURE__*/ _jsx("span", {
|
|
55
|
-
children: providerName
|
|
56
|
-
})
|
|
57
|
-
]
|
|
58
|
-
})
|
|
59
|
-
}, provider);
|
|
60
|
-
};
|
|
61
|
-
if (providerCount === 0 && !hasPasskeySupport) {
|
|
62
|
-
return null;
|
|
63
|
-
}
|
|
64
|
-
const showIconOnly = providerCount >= 3;
|
|
65
|
-
return /*#__PURE__*/ _jsxs("div", {
|
|
66
|
-
className: `${baseClass} ${baseClass}--count-${showIconOnly ? 'many' : providerCount}`,
|
|
67
|
-
children: [
|
|
68
|
-
providers.map((provider)=>renderProviderButton(provider, showIconOnly)),
|
|
69
|
-
hasPasskeySupport && !allowSignup && /*#__PURE__*/ _jsxs(Button, {
|
|
70
|
-
type: "button",
|
|
71
|
-
size: "large",
|
|
72
|
-
className: `${baseClass}__button provider--passkey`,
|
|
73
|
-
onClick: async ()=>{
|
|
74
|
-
setLoading(true);
|
|
75
|
-
try {
|
|
76
|
-
await authClient.signIn.passkey({
|
|
77
|
-
fetchOptions: {
|
|
78
|
-
onSuccess () {
|
|
79
|
-
if (router && redirectUrl) {
|
|
80
|
-
router.push(redirectUrl);
|
|
81
|
-
}
|
|
82
|
-
},
|
|
83
|
-
onError (context) {
|
|
84
|
-
toast.error(context.error.message || 'Failed to sign in with passkey');
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
} catch (error) {
|
|
89
|
-
toast.error(error?.message || 'Failed to sign in with passkey');
|
|
90
|
-
} finally{
|
|
91
|
-
setLoading(false);
|
|
92
|
-
}
|
|
93
|
-
},
|
|
94
|
-
children: [
|
|
95
|
-
/*#__PURE__*/ _jsx(Key, {
|
|
96
|
-
size: 16,
|
|
97
|
-
className: `${baseClass}__icon`
|
|
98
|
-
}),
|
|
99
|
-
/*#__PURE__*/ _jsx("span", {
|
|
100
|
-
children: "Passkey"
|
|
101
|
-
})
|
|
102
|
-
]
|
|
103
|
-
})
|
|
104
|
-
]
|
|
105
|
-
});
|
|
106
|
-
};
|
|
107
|
-
export default AdminSocialProviderButtons;
|
|
108
|
-
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/components/admin-social-provider-buttons/index.tsx"],"sourcesContent":["'use client'\n\nimport React, { useMemo } from 'react'\nimport { Icons } from '@/shared/components/icons'\nimport { Key } from 'lucide-react'\nimport { useRouter } from 'next/navigation'\nimport { Button, toast } from '@payloadcms/ui'\nimport { createAuthClient } from 'better-auth/react'\nimport type { SocialProviders } from '@/better-auth/plugin/types'\nimport { passkeyClient } from 'better-auth/client/plugins'\n\nimport './index.scss'\n\ntype AdminSocialProviderButtonsProps = {\n  allowSignup: boolean\n  socialProviders: SocialProviders\n  setLoading: (loading: boolean) => void\n  hasPasskeySupport?: boolean\n  redirectUrl?: string\n  newUserCallbackURL?: string\n}\n\nconst baseClass = 'admin-social-provider-buttons'\n\nconst AdminSocialProviderButtons: React.FC<AdminSocialProviderButtonsProps> = ({\n  allowSignup,\n  socialProviders,\n  setLoading,\n  hasPasskeySupport,\n  redirectUrl,\n  newUserCallbackURL\n}) => {\n  const router = useRouter()\n  const authClient = useMemo(() => createAuthClient({ plugins: [passkeyClient()] }), [])\n  const providers = Object.keys(socialProviders ?? {}) as Array<keyof SocialProviders>\n  const providerCount = providers.length\n\n  const renderProviderButton = (provider: keyof SocialProviders, showIconOnly: boolean) => {\n    const providerConfig = socialProviders?.[provider]\n    const Icon = Icons[provider as keyof typeof Icons]\n    const providerName = provider.charAt(0).toUpperCase() + provider.slice(1)\n\n    return (\n      <Button\n        key={provider}\n        type=\"button\"\n        size=\"large\"\n        className={`${baseClass}__button provider--${provider}`}\n        onClick={async () => {\n          setLoading(true)\n          try {\n            await authClient.signIn.social({\n              provider: provider,\n              requestSignUp: allowSignup ? true : !providerConfig?.disableSignUp,\n              callbackURL: redirectUrl,\n              newUserCallbackURL: newUserCallbackURL\n            })\n          } catch (error: any) {\n            toast.error(`Failed to sign in with ${providerName}`)\n          } finally {\n            setLoading(false)\n          }\n        }}\n        icon={showIconOnly ? <Icon className={`${baseClass}__icon`} /> : undefined}\n        tooltip={showIconOnly ? `Sign in with ${providerName}` : undefined}\n      >\n        {!showIconOnly && (\n          <>\n            <Icon className={`${baseClass}__icon`} /> <span>{providerName}</span>\n          </>\n        )}\n      </Button>\n    )\n  }\n\n  if (providerCount === 0 && !hasPasskeySupport) {\n    return null\n  }\n\n  const showIconOnly = providerCount >= 3\n\n  return (\n    <div className={`${baseClass} ${baseClass}--count-${showIconOnly ? 'many' : providerCount}`}>\n      {providers.map((provider) => renderProviderButton(provider, showIconOnly))}\n\n      {hasPasskeySupport && !allowSignup && (\n        <Button\n          type=\"button\"\n          size=\"large\"\n          className={`${baseClass}__button provider--passkey`}\n          onClick={async () => {\n            setLoading(true)\n            try {\n              await authClient.signIn.passkey({\n                fetchOptions: {\n                  onSuccess() {\n                    if (router && redirectUrl) {\n                      router.push(redirectUrl)\n                    }\n                  },\n                  onError(context: any) {\n                    toast.error(context.error.message || 'Failed to sign in with passkey')\n                  }\n                }\n              })\n            } catch (error: any) {\n              toast.error(error?.message || 'Failed to sign in with passkey')\n            } finally {\n              setLoading(false)\n            }\n          }}\n        >\n          <Key size={16} className={`${baseClass}__icon`} />\n          <span>Passkey</span>\n        </Button>\n      )}\n    </div>\n  )\n}\n\nexport default AdminSocialProviderButtons\n"],"names":["React","useMemo","Icons","Key","useRouter","Button","toast","createAuthClient","passkeyClient","baseClass","AdminSocialProviderButtons","allowSignup","socialProviders","setLoading","hasPasskeySupport","redirectUrl","newUserCallbackURL","router","authClient","plugins","providers","Object","keys","providerCount","length","renderProviderButton","provider","showIconOnly","providerConfig","Icon","providerName","charAt","toUpperCase","slice","type","size","className","onClick","signIn","social","requestSignUp","disableSignUp","callbackURL","error","icon","undefined","tooltip","span","div","map","passkey","fetchOptions","onSuccess","push","onError","context","message"],"mappings":"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"}
|