signal-desktop/ts/components/conversation/conversation-details/GroupLinkManagement.tsx

195 lines
5.8 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2020 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import React, { useState } from 'react';
import type { ConversationType } from '../../../state/ducks/conversations';
import type { LocalizerType } from '../../../types/Util';
import { ConfirmationDialog } from '../../ConfirmationDialog';
import { ConversationDetailsIcon, IconType } from './ConversationDetailsIcon';
import { PanelRow } from './PanelRow';
import { PanelSection } from './PanelSection';
import { Select } from '../../Select';
import { SignalService as Proto } from '../../../protobuf';
import { copyGroupLink } from '../../../util/copyGroupLink';
import { useDelayedRestoreFocus } from '../../../hooks/useRestoreFocus';
import { useUniqueId } from '../../../hooks/useUniqueId';
2021-07-09 19:36:10 +00:00
const AccessControlEnum = Proto.AccessControl.AccessRequired;
export type PropsDataType = {
conversation?: ConversationType;
i18n: LocalizerType;
2021-03-02 16:27:11 +00:00
isAdmin: boolean;
};
export type PropsType = PropsDataType & {
changeHasGroupLink: (conversationId: string, value: boolean) => unknown;
generateNewGroupLink: (conversationId: string) => unknown;
setAccessControlAddFromInviteLinkSetting: (
conversationId: string,
value: boolean
) => unknown;
};
2022-11-18 00:45:19 +00:00
export function GroupLinkManagement({
changeHasGroupLink,
conversation,
generateNewGroupLink,
i18n,
2021-03-02 16:27:11 +00:00
isAdmin,
setAccessControlAddFromInviteLinkSetting,
2022-11-18 00:45:19 +00:00
}: PropsType): JSX.Element {
const groupLinkSelectId = useUniqueId();
const approveSelectId = useUniqueId();
if (conversation === undefined) {
throw new Error('GroupLinkManagement rendered without a conversation');
}
const [focusRef] = useDelayedRestoreFocus();
const createEventHandler = (
handleEvent: (id: string, x: boolean) => unknown
) => {
return (value: string) => {
handleEvent(conversation.id, value === 'true');
};
};
const membersNeedAdminApproval =
2021-07-09 19:36:10 +00:00
conversation.accessControlAddFromInviteLink ===
AccessControlEnum.ADMINISTRATOR;
const hasGroupLink =
conversation.groupLink &&
2021-07-09 19:36:10 +00:00
conversation.accessControlAddFromInviteLink !==
AccessControlEnum.UNSATISFIABLE;
const groupLinkInfo = hasGroupLink ? conversation.groupLink : '';
const [hasGenerateNewLinkDialog, setHasGenerateNewLinkDialog] =
useState(false);
return (
<>
{hasGenerateNewLinkDialog && (
<ConfirmationDialog
2022-09-27 20:24:21 +00:00
dialogName="GroupLinkManagement.resetLink"
actions={[
{
action: () => {
generateNewGroupLink(conversation.id);
},
style: 'negative',
2023-03-30 00:03:25 +00:00
text: i18n('icu:GroupLinkManagement--reset'),
},
]}
i18n={i18n}
onClose={() => {
setHasGenerateNewLinkDialog(false);
}}
2023-03-30 00:03:25 +00:00
title={i18n('icu:GroupLinkManagement--confirm-reset')}
/>
)}
<PanelSection>
<PanelRow
info={groupLinkInfo}
label={
<label htmlFor={groupLinkSelectId}>
2023-03-30 00:03:25 +00:00
{i18n('icu:ConversationDetails--group-link')}
</label>
}
right={
2021-03-02 16:27:11 +00:00
isAdmin ? (
<Select
id={groupLinkSelectId}
onChange={createEventHandler(changeHasGroupLink)}
options={[
{
2023-03-30 00:03:25 +00:00
text: i18n('icu:on'),
value: 'true',
},
{
2023-03-30 00:03:25 +00:00
text: i18n('icu:off'),
value: 'false',
},
]}
ref={focusRef}
value={String(Boolean(hasGroupLink))}
/>
2021-03-02 16:27:11 +00:00
) : null
}
/>
</PanelSection>
{hasGroupLink ? (
<>
<PanelSection>
<PanelRow
icon={
<ConversationDetailsIcon
2023-03-30 00:03:25 +00:00
ariaLabel={i18n('icu:GroupLinkManagement--share')}
icon={IconType.share}
/>
}
2023-03-30 00:03:25 +00:00
label={i18n('icu:GroupLinkManagement--share')}
ref={!isAdmin ? focusRef : undefined}
onClick={() => {
if (conversation.groupLink) {
void copyGroupLink(conversation.groupLink);
}
}}
/>
2021-03-02 16:27:11 +00:00
{isAdmin ? (
<PanelRow
icon={
<ConversationDetailsIcon
2023-03-30 00:03:25 +00:00
ariaLabel={i18n('icu:GroupLinkManagement--reset')}
icon={IconType.reset}
2021-03-02 16:27:11 +00:00
/>
}
2023-03-30 00:03:25 +00:00
label={i18n('icu:GroupLinkManagement--reset')}
onClick={() => setHasGenerateNewLinkDialog(true)}
2021-03-02 16:27:11 +00:00
/>
) : null}
</PanelSection>
2021-03-02 16:27:11 +00:00
{isAdmin ? (
<PanelSection>
<PanelRow
2023-03-30 00:03:25 +00:00
info={i18n('icu:GroupLinkManagement--approve-info')}
label={
<label htmlFor={approveSelectId}>
2023-03-30 00:03:25 +00:00
{i18n('icu:GroupLinkManagement--approve-label')}
</label>
}
2021-03-02 16:27:11 +00:00
right={
<Select
id={approveSelectId}
onChange={createEventHandler(
setAccessControlAddFromInviteLinkSetting
)}
options={[
{
2023-03-30 00:03:25 +00:00
text: i18n('icu:on'),
value: 'true',
},
{
2023-03-30 00:03:25 +00:00
text: i18n('icu:off'),
value: 'false',
},
]}
value={String(membersNeedAdminApproval)}
/>
2021-03-02 16:27:11 +00:00
}
/>
</PanelSection>
) : null}
</>
) : null}
</>
);
2022-11-18 00:45:19 +00:00
}