mirror of
https://github.com/docmost/docmost
synced 2025-03-28 21:13:28 +00:00

* stripe init git submodules for enterprise modules * * Cloud billing UI - WIP * Proxy websockets in dev mode * Separate workspace login and creation for cloud * Other fixes * feat: billing (cloud) * * add domain service * prepare links from workspace hostname * WIP * Add exchange token generation * Validate JWT token type during verification * domain service * add SkipTransform decorator * * updates (server) * add new packages * new sso migration file * WIP * Fix hostname generation * WIP * WIP * Reduce input error font-size * set max password length * jwt package * license page - WIP * * License management UI * Move license key store to db * add reflector * SSO enforcement * * Add default plan * Add usePlan hook * * Fix auth container margin in mobile * Redirect login and home to select page in cloud * update .gitignore * Default to yearly * * Trial messaging * Handle ended trials * Don't set to readonly on collab disconnect (Cloud) * Refine trial (UI) * Fix bug caused by using jotai optics atom in AppHeader component * configurable database maximum pool * Close SSO form on save * wip * sync * Only show sign-in in cloud * exclude base api part from workspaceId check * close db connection beforeApplicationShutdown * Add health/live endpoint * clear cookie on hostname change * reset currentUser atom * Change text * return 401 if workspace does not match * feat: show user workspace list in cloud login page * sync * Add home path * Prefetch to speed up queries * * Add robots.txt * Disallow login and forgot password routes * wildcard user-agent * Fix space query cache * fix * fix * use space uuid for recent pages * prefetch billing plans * enhance license page * sync
89 lines
2.4 KiB
TypeScript
89 lines
2.4 KiB
TypeScript
import { useAtom } from "jotai";
|
|
import * as z from "zod";
|
|
import { useForm, zodResolver } from "@mantine/form";
|
|
import { workspaceAtom } from "@/features/user/atoms/current-user-atom.ts";
|
|
import React, { useState } from "react";
|
|
import { Button, Text, TagsInput } from "@mantine/core";
|
|
import { notifications } from "@mantine/notifications";
|
|
import { useTranslation } from "react-i18next";
|
|
import { updateWorkspace } from "@/features/workspace/services/workspace-service.ts";
|
|
import { IWorkspace } from "@/features/workspace/types/workspace.types.ts";
|
|
|
|
const formSchema = z.object({
|
|
emailDomains: z.array(z.string()),
|
|
});
|
|
|
|
type FormValues = z.infer<typeof formSchema>;
|
|
export default function AllowedDomains() {
|
|
const { t } = useTranslation();
|
|
const [isLoading, setIsLoading] = useState(false);
|
|
const [workspace, setWorkspace] = useAtom(workspaceAtom);
|
|
const [, setDomains] = useState<string[]>([]);
|
|
|
|
const form = useForm<FormValues>({
|
|
validate: zodResolver(formSchema),
|
|
initialValues: {
|
|
emailDomains: workspace?.emailDomains || [],
|
|
},
|
|
});
|
|
|
|
async function handleSubmit(data: Partial<IWorkspace>) {
|
|
setIsLoading(true);
|
|
try {
|
|
const updatedWorkspace = await updateWorkspace({
|
|
emailDomains: data.emailDomains,
|
|
});
|
|
setWorkspace(updatedWorkspace);
|
|
|
|
notifications.show({
|
|
message: t("Updated successfully"),
|
|
});
|
|
} catch (err) {
|
|
console.log(err);
|
|
notifications.show({
|
|
message: err.response.data.message,
|
|
color: "red",
|
|
});
|
|
}
|
|
|
|
form.resetDirty();
|
|
|
|
setIsLoading(false);
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<div>
|
|
<Text size="md">Allowed email domains</Text>
|
|
<Text size="sm" c="dimmed">
|
|
Only users with email addresses from these domains can signup via SSO.
|
|
</Text>
|
|
</div>
|
|
<form onSubmit={form.onSubmit(handleSubmit)}>
|
|
<TagsInput
|
|
mt="sm"
|
|
description={t(
|
|
"Enter valid domain names separated by comma or space",
|
|
)}
|
|
placeholder={t("e.g acme.com")}
|
|
variant="filled"
|
|
splitChars={[",", " "]}
|
|
maxDropdownHeight={0}
|
|
maxTags={20}
|
|
onChange={setDomains}
|
|
{...form.getInputProps("emailDomains")}
|
|
/>
|
|
|
|
<Button
|
|
type="submit"
|
|
mt="sm"
|
|
disabled={!form.isDirty()}
|
|
loading={isLoading}
|
|
>
|
|
{t("Save")}
|
|
</Button>
|
|
</form>
|
|
</>
|
|
);
|
|
}
|