// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import type { ReactNode } from 'react'; import React, { useState } from 'react'; import classNames from 'classnames'; import type { LocalizerType } from '../types/Util'; import * as expirationTimer from '../util/expirationTimer'; import { DurationInSeconds } from '../util/durations'; import { DisappearingTimeDialog } from './DisappearingTimeDialog'; import { Select } from './Select'; const CSS_MODULE = 'module-disappearing-timer-select'; export type Props = { i18n: LocalizerType; value?: DurationInSeconds; onChange(value: DurationInSeconds): void; }; export function DisappearingTimerSelect(props: Props): JSX.Element { const { i18n, value = DurationInSeconds.ZERO, onChange } = props; const [isModalOpen, setIsModalOpen] = useState(false); let expirationTimerOptions: ReadonlyArray<{ readonly value: DurationInSeconds; readonly text: string; }> = expirationTimer.DEFAULT_DURATIONS_IN_SECONDS.map(seconds => { const text = expirationTimer.format(i18n, seconds, { capitalizeOff: true, }); return { value: seconds, text, }; }); const isCustomTimeSelected = !expirationTimer.DEFAULT_DURATIONS_SET.has(value); const onSelectChange = (newValue: string) => { const intValue = DurationInSeconds.fromSeconds(parseInt(newValue, 10)); if (intValue === -1) { setIsModalOpen(true); } else { onChange(intValue); } }; // Custom time... expirationTimerOptions = [ ...expirationTimerOptions, { value: DurationInSeconds.fromSeconds(-1), text: i18n( isCustomTimeSelected ? 'selectedCustomDisappearingTimeOption' : 'customDisappearingTimeOption' ), }, ]; let modalNode: ReactNode = null; if (isModalOpen) { modalNode = ( { setIsModalOpen(false); onChange(newValue); }} onClose={() => setIsModalOpen(false)} /> ); } let info: ReactNode; if (isCustomTimeSelected) { info = (
{expirationTimer.format(i18n, value)}
); } return (