// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useMemo, useState } from 'react'; import type { LocalizerType } from '../../../types/Util'; import { getMuteOptions } from '../../../util/getMuteOptions'; import { parseIntOrThrow } from '../../../util/parseIntOrThrow'; import { Checkbox } from '../../Checkbox'; import { Modal } from '../../Modal'; import { Button, ButtonVariant } from '../../Button'; type PropsType = { i18n: LocalizerType; id: string; muteExpiresAt: undefined | number; onClose: () => unknown; setMuteExpiration: ( conversationId: string, muteExpiresAt: undefined | number ) => unknown; }; export function ConversationNotificationsModal({ i18n, id, muteExpiresAt, onClose, setMuteExpiration, }: PropsType): JSX.Element { const muteOptions = useMemo( () => getMuteOptions(muteExpiresAt, i18n).map(({ disabled, name, value }) => ({ disabled, text: name, value, })), [i18n, muteExpiresAt] ); const [muteExpirationValue, setMuteExpirationValue] = useState(muteExpiresAt); const onMuteChange = () => { const ms = parseIntOrThrow( muteExpirationValue, 'NotificationSettings: mute ms was not an integer' ); setMuteExpiration(id, ms); onClose(); }; return ( } > {muteOptions .filter(x => x.value > 0) .map(option => ( value && setMuteExpirationValue(option.value)} /> ))} ); }