Home / Function/ CreateAuth0IntegrationDialog() — supabase Function Reference

CreateAuth0IntegrationDialog() — supabase Function Reference

Architecture documentation for the CreateAuth0IntegrationDialog() function in CreateAuth0Dialog.tsx from the supabase codebase.

Entity Profile

Relationship Graph

Source Code

apps/studio/components/interfaces/Auth/ThirdPartyAuthForm/CreateAuth0Dialog.tsx lines 44–182

export const CreateAuth0IntegrationDialog = ({
  visible,
  onClose,
  onDelete,
}: CreateAuth0IntegrationProps) => {
  // TODO: Remove this if this Dialog is only used for creating.
  const isCreating = true

  const { ref: projectRef } = useParams()
  const { mutate: createAuthIntegration, isPending } = useCreateThirdPartyAuthIntegrationMutation({
    onSuccess: () => {
      toast.success(`Successfully created a new Auth0 Auth integration.`)
      onClose()
    },
  })

  const form = useForm<z.infer<typeof FormSchema>>({
    resolver: zodResolver(FormSchema),
    defaultValues: {
      enabled: true,
      auth0DomainName: '',
    },
  })

  useEffect(() => {
    if (visible) {
      form.reset({
        enabled: true,
        auth0DomainName: '',
      })

      // the form input doesn't exist when the form is reset
      setTimeout(() => {
        form.setFocus('auth0DomainName')
      }, 25)
    }
  }, [visible])

  const onSubmit: SubmitHandler<z.infer<typeof FormSchema>> = async (values) => {
    createAuthIntegration({
      projectRef: projectRef!,
      oidcIssuerUrl: `https://${values.auth0DomainName}.auth0.com`,
    })
  }

  return (
    <Dialog open={visible} onOpenChange={() => onClose()}>
      <DialogContent>
        <DialogHeader>
          <DialogTitle className="truncate">
            {isCreating ? `Add new Auth0 connection` : `Update existing Auth0 connection`}
          </DialogTitle>
        </DialogHeader>
        <Separator />
        <DialogSection>
          <Form_Shadcn_ {...form}>
            <form id={FORM_ID} onSubmit={form.handleSubmit(onSubmit)} className="space-y-4">
              {/* Enabled flag can't be changed for now because there's no update API call for integrations */}
              {/* <FormField_Shadcn_
              key="enabled"
              control={form.control}
              name="enabled"
              render={({ field }) => (
                <FormItemLayout
                  className="px-8"
                  label={`Enable Auth0 Auth Connection`}
                  layout="flex"
                >
                  <FormControl_Shadcn_>
                    <Switch
                      checked={field.value}
                      onCheckedChange={field.onChange}
                      disabled={field.disabled}
                    />
                  </FormControl_Shadcn_>
                </FormItemLayout>
              )}
            />
            <Separator /> */}
              <p className="text-sm text-foreground-light">
                This will enable a JWT token from your Auth0 project to access data from this
                Supabase project.
              </p>
              <FormField_Shadcn_
                key="auth0DomainName"
                control={form.control}
                name="auth0DomainName"
                render={({ field }) => (
                  <FormItemLayout label="Auth0 domain name">
                    <div className="flex flex-row">
                      <Button
                        type="default"
                        size="small"
                        className="px-2 text-foreground-light rounded-r-none"
                        onClick={() => form.setFocus('auth0DomainName')}
                      >
                        https://
                      </Button>
                      <FormControl_Shadcn_>
                        <Input_Shadcn_
                          className="border-l-0 rounded-none border-r-0 z-50"
                          {...field}
                        />
                      </FormControl_Shadcn_>
                      <Button
                        type="default"
                        size="small"
                        className="px-2 text-foreground-light rounded-l-none"
                        onClick={() => form.setFocus('auth0DomainName')}
                      >
                        .auth0.com
                      </Button>
                    </div>
                  </FormItemLayout>
                )}
              />
            </form>
          </Form_Shadcn_>
        </DialogSection>
        <DialogFooter>
          {!isCreating && (
            <div className="flex-1">
              <Button type="danger" onClick={() => onDelete()} icon={<Trash />}>
                Remove connection
              </Button>
            </div>
          )}

          <Button disabled={isPending} type="default" onClick={() => onClose()}>
            Cancel
          </Button>
          <Button form={FORM_ID} htmlType="submit" disabled={isPending} loading={isPending}>
            {isCreating ? 'Create connection' : 'Update connection'}
          </Button>
        </DialogFooter>
      </DialogContent>
    </Dialog>
  )
}

Subdomains

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free