{"version":3,"file":"HomeGroupAddExistingMembers-3e90dc23.js","sources":["../../src/components/HomeGroups/HomeGroupAddExistingMembers.tsx"],"sourcesContent":["import { Fragment, useState } from \"react\"\nimport { useParams } from \"react-router-dom\"\nimport styled from \"styled-components\"\n\nimport { Pager } from \"src/components/Pager/Pager\"\nimport { useUrlPager } from \"src/components/Pager/useUrlPager\"\nimport {\n useDeleteHomeGroupMember,\n useFetchHomeGroupMembers,\n usePostHomeGroupMember,\n} from \"src/data/homeGroups/queries/homeGroupMemberQueries\"\nimport { IHomeGroupMember } from \"src/data/homeGroups/types/homeGroupTypes\"\nimport { useOrganization } from \"src/data/organizations/hooks/useOrganization\"\nimport { useFetchMembers } from \"src/data/organizations/queries/memberQueries\"\nimport { IOrganizationMember } from \"src/data/organizations/types/organizationMemberTypes\"\nimport { useTranslate } from \"src/i18n/useTranslate\"\nimport { Routes } from \"src/router/routes\"\nimport { useRouter } from \"src/router/useRouter\"\nimport { MButton } from \"src/ui/Button/MButton\"\nimport { GridTable } from \"src/ui/GridTable/GridTable\"\nimport { MBanner } from \"src/ui/MBanner/MBanner\"\nimport { FullscreenView } from \"src/ui/Modals/FullscreenView\"\nimport { Heading2Mixin, MText } from \"src/ui/MText\"\nimport { spacing } from \"src/ui/spacing\"\nimport { debug } from \"src/utils/logger\"\n\nconst MEMBER_PAGE_SIZE = 10\n\nexport function HomeGroupAddExistingMembers({\n homeGroupId,\n}: {\n homeGroupId: string\n}) {\n const { t, langKeys } = useTranslate()\n const { navigate } = useRouter()\n\n const { limit, setOffset, offset } = useUrlPager({\n initialLimit: MEMBER_PAGE_SIZE,\n })\n const { org } = useOrganization()\n const [busyMemberId, setBusyMemberId] = useState(\"\")\n const deleteHomeGroupMember = useDeleteHomeGroupMember()\n const postHomeGroupMember = usePostHomeGroupMember()\n\n const fetchHomegroupMembers = useFetchHomeGroupMembers({\n orgId: org.id,\n homeGroupId: homeGroupId,\n })\n const homeGroupMembers = fetchHomegroupMembers.data?.members || []\n\n const fetchMembers = useFetchMembers({\n orgId: org.id,\n filter: { offset, limit },\n })\n const orgMembers = fetchMembers.data?.members || []\n\n function handleAddMemberClick(id: string) {\n setBusyMemberId(id)\n postHomeGroupMember.mutate(\n { homeGroupId, homeGroupMemberId: id, orgId: org.id },\n { onSettled: () => setBusyMemberId(\"\") }\n )\n }\n\n function handleRemoveMemberClick(homeGroupMemberId: string) {\n setBusyMemberId(homeGroupMemberId)\n deleteHomeGroupMember.mutate(\n { orgId: org.id, homeGroupId, homeGroupMemberId },\n {\n onSettled() {\n setBusyMemberId(\"\")\n },\n }\n )\n }\n\n const rows: JSX.Element[] = orgMembers.map((member) => (\n