The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/apps/meteor/client/hooks/usePruneWarningMessage.ts

105 lines
3.2 KiB

import type { IRoom } from '@rocket.chat/core-typings';
import { useSafely } from '@rocket.chat/fuselage-hooks';
import type { TranslationKey } from '@rocket.chat/ui-contexts';
import { useSetting, useTranslation, useLanguage } from '@rocket.chat/ui-contexts';
import { sendAt } from 'cron';
import { intlFormat } from 'date-fns';
import { useEffect, useState } from 'react';
import { useFormattedRelativeTime } from './useFormattedRelativeTime';
import { getCronAdvancedTimerFromPrecisionSetting } from '../../lib/getCronAdvancedTimerFromPrecisionSetting';
import { useRetentionPolicy } from '../views/room/hooks/useRetentionPolicy';
const getMessage = ({ filesOnly, excludePinned }: { filesOnly: boolean; excludePinned: boolean }): TranslationKey => {
if (filesOnly) {
return excludePinned
? 'RetentionPolicy_RoomWarning_UnpinnedFilesOnly_NextRunDate'
: 'RetentionPolicy_RoomWarning_FilesOnly_NextRunDate';
}
return excludePinned ? 'RetentionPolicy_RoomWarning_Unpinned_NextRunDate' : 'RetentionPolicy_RoomWarning_NextRunDate';
};
type CronPrecisionSetting = '0' | '1' | '2' | '3';
const getNextRunDate = ({
enableAdvancedCronTimer,
cronPrecision,
advancedCronTimer,
}: {
enableAdvancedCronTimer: boolean;
cronPrecision: CronPrecisionSetting;
advancedCronTimer: string;
}) => {
if (enableAdvancedCronTimer) {
return sendAt(advancedCronTimer);
}
return sendAt(getCronAdvancedTimerFromPrecisionSetting(cronPrecision));
};
const useNextRunDate = ({
enableAdvancedCronTimer,
advancedCronTimer,
cronPrecision,
}: {
enableAdvancedCronTimer: boolean;
cronPrecision: CronPrecisionSetting;
advancedCronTimer: string;
}) => {
const [nextRunDate, setNextRunDate] = useSafely(useState(getNextRunDate({ enableAdvancedCronTimer, advancedCronTimer, cronPrecision })));
const lang = useLanguage();
useEffect(() => {
const timeoutBetweenRunAndNow = nextRunDate.valueOf() - Date.now();
const timeout = setTimeout(
() => setNextRunDate(getNextRunDate({ enableAdvancedCronTimer, advancedCronTimer, cronPrecision })),
timeoutBetweenRunAndNow,
);
return () => clearTimeout(timeout);
}, [advancedCronTimer, cronPrecision, enableAdvancedCronTimer, nextRunDate, setNextRunDate]);
return intlFormat(
new Date(nextRunDate.valueOf()),
{
localeMatcher: 'best fit',
year: 'numeric',
month: 'long',
day: 'numeric',
hour: 'numeric',
minute: 'numeric',
},
{
locale: lang,
},
);
};
export const usePruneWarningMessage = (room: IRoom) => {
const retention = useRetentionPolicy(room);
if (!retention) {
throw new Error('usePruneWarningMessage - No room provided');
}
const { maxAge, filesOnly, excludePinned } = retention;
const cronPrecision = useSetting<CronPrecisionSetting>('RetentionPolicy_Precision', '0');
const t = useTranslation();
const enableAdvancedCronTimer = useSetting('RetentionPolicy_Advanced_Precision', false);
const advancedCronTimer = useSetting('RetentionPolicy_Advanced_Precision_Cron', '*/30 * * * *');
const message = getMessage({ filesOnly, excludePinned });
const nextRunDate = useNextRunDate({
enableAdvancedCronTimer,
advancedCronTimer,
cronPrecision,
});
const maxAgeFormatted = useFormattedRelativeTime(maxAge);
return t(message, { maxAge: maxAgeFormatted, nextRunDate });
};