mirror of
https://github.com/docmost/docmost.git
synced 2026-05-18 15:34:05 +08:00
670ee64179
* feat: support i18n * feat: wip support i18n * feat: complete space translation * feat: complete page translation * feat: update space translation * feat: update workspace translation * feat: update group translation * feat: update workspace translation * feat: update page translation * feat: update user translation * chore: update pnpm-lock * feat: add query translation * refactor: merge to single file * chore: remove necessary code * feat: save language to BE * fix: only load current language * feat: save language to locale column * fix: cleanups * add language menu to preferences page * new translations * translate editor * Translate editor placeholders * translate space selection component --------- Co-authored-by: Philip Okugbe <phil@docmost.com> Co-authored-by: Philip Okugbe <16838612+Philipinho@users.noreply.github.com>
75 lines
2.3 KiB
TypeScript
75 lines
2.3 KiB
TypeScript
import { Button, Divider, Group, Modal, Stack } from "@mantine/core";
|
|
import { useDisclosure } from "@mantine/hooks";
|
|
import React, { useState } from "react";
|
|
import { useAddSpaceMemberMutation } from "@/features/space/queries/space-query.ts";
|
|
import { MultiMemberSelect } from "@/features/space/components/multi-member-select.tsx";
|
|
import { SpaceMemberRole } from "@/features/space/components/space-member-role.tsx";
|
|
import { SpaceRole } from "@/lib/types.ts";
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
interface AddSpaceMemberModalProps {
|
|
spaceId: string;
|
|
}
|
|
export default function AddSpaceMembersModal({
|
|
spaceId,
|
|
}: AddSpaceMemberModalProps) {
|
|
const { t } = useTranslation();
|
|
const [opened, { open, close }] = useDisclosure(false);
|
|
const [memberIds, setMemberIds] = useState<string[]>([]);
|
|
const [role, setRole] = useState<string>(SpaceRole.WRITER);
|
|
const addSpaceMemberMutation = useAddSpaceMemberMutation();
|
|
|
|
const handleMultiSelectChange = (value: string[]) => {
|
|
setMemberIds(value);
|
|
};
|
|
|
|
const handleRoleSelection = (role: string) => {
|
|
setRole(role);
|
|
};
|
|
|
|
const handleSubmit = async () => {
|
|
// member can be a users or groups
|
|
const userIds = memberIds
|
|
.map((id) => (id.startsWith("user-") ? id.split("user-")[1] : null))
|
|
.filter((id) => id !== null);
|
|
|
|
const groupIds = memberIds
|
|
.map((id) => (id.startsWith("group-") ? id.split("group-")[1] : null))
|
|
.filter((id) => id !== null);
|
|
|
|
const addSpaceMember = {
|
|
spaceId: spaceId,
|
|
userIds: userIds,
|
|
groupIds: groupIds,
|
|
role: role,
|
|
};
|
|
|
|
await addSpaceMemberMutation.mutateAsync(addSpaceMember);
|
|
close();
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<Button onClick={open}>{t("Add space members")}</Button>
|
|
<Modal opened={opened} onClose={close} title={t("Add space members")}>
|
|
<Divider size="xs" mb="xs" />
|
|
|
|
<Stack>
|
|
<MultiMemberSelect onChange={handleMultiSelectChange} />
|
|
<SpaceMemberRole
|
|
onSelect={handleRoleSelection}
|
|
defaultRole={role}
|
|
label={t("Select role")}
|
|
/>
|
|
</Stack>
|
|
|
|
<Group justify="flex-end" mt="md">
|
|
<Button onClick={handleSubmit} type="submit">
|
|
{t("Add")}
|
|
</Button>
|
|
</Group>
|
|
</Modal>
|
|
</>
|
|
);
|
|
}
|