mirror of
https://github.com/labring/FastGPT.git
synced 2026-04-23 01:01:19 +08:00
3a5d725efd
* add dynamic inputRender (#5127) * dynamic input component * fix * fix * fix * perf: dynamic render input * update doc * perf: error catch * num input ui * fix form render (#5177) * perf: i18n check * add log * doc * Sync dataset (#5181) * perf: api dataset create (#5047) * Sync dataset (#5120) * add * wait * restructure dataset sync, update types and APIs, add sync hints, and remove legacy logic * feat: add function to retrieve real file ID from third-party doc library and rename team permission check function for clarity * fix come console * refactor: rename team dataset limit check functions for clarity, update API dataset sync limit usage, and rename root directory to "ROOT_FOLDER" * frat: update sync dataset login * fix delete.ts * feat: update pnpm-lock.yaml to include bullmq, fix comments in api.d.ts and type.d.ts, rename API file ID field, optimize dataset sync logic, and add website sync feature with related APIs * feat: update CollectionCard to support site dataset sync, add API root ID constant and init sync API * feat: add RootCollectionId constant to replace hardcoded root ID --------- Co-authored-by: dreamer6680 <146868355@qq.com> * perf: code * feat: update success message for dataset sync, revise related i18n texts, and optimize file selection logic (#5166) Co-authored-by: dreamer6680 <146868355@qq.com> * perf: select file * Sync dataset (#5180) * feat: update success message for dataset sync, revise related i18n texts, and optimize file selection logic * fix: make listfile function return rawid string --------- Co-authored-by: dreamer6680 <146868355@qq.com> * init sh * fix: ts --------- Co-authored-by: dreamer6680 <1468683855@qq.com> Co-authored-by: dreamer6680 <146868355@qq.com> * update doc * i18n --------- Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: dreamer6680 <1468683855@qq.com> Co-authored-by: dreamer6680 <146868355@qq.com>
107 lines
3.0 KiB
TypeScript
107 lines
3.0 KiB
TypeScript
import dayjs from 'dayjs';
|
|
import cronParser from 'cron-parser';
|
|
import utc from 'dayjs/plugin/utc';
|
|
import timezone from 'dayjs/plugin/timezone';
|
|
import { i18nT } from '../../../web/i18n/utils';
|
|
|
|
dayjs.extend(utc);
|
|
dayjs.extend(timezone);
|
|
|
|
export const formatTime2YMDHMW = (time?: Date | number) =>
|
|
dayjs(time).format('YYYY-MM-DD HH:mm:ss dddd');
|
|
export const formatTime2YMDHMS = (time?: Date | number) =>
|
|
time ? dayjs(time).format('YYYY-MM-DD HH:mm:ss') : '';
|
|
export const formatTime2YMDHM = (time?: Date | number) =>
|
|
time ? dayjs(time).format('YYYY-MM-DD HH:mm') : '';
|
|
export const formatTime2YMD = (time?: Date | number) =>
|
|
time ? dayjs(time).format('YYYY-MM-DD') : '';
|
|
export const formatTime2HM = (time: Date = new Date()) => dayjs(time).format('HH:mm');
|
|
|
|
/**
|
|
* 格式化时间成聊天格式
|
|
*/
|
|
export const formatTimeToChatTime = (time: Date) => {
|
|
const now = dayjs();
|
|
const target = dayjs(time);
|
|
|
|
// 如果传入时间小于60秒,返回刚刚
|
|
if (now.diff(target, 'second') < 60) {
|
|
return i18nT('common:just_now');
|
|
}
|
|
|
|
// 如果时间是今天,展示几时:几分
|
|
//用#占位,i18n生效后replace成:
|
|
if (now.isSame(target, 'day')) {
|
|
return target.format('HH#mm');
|
|
}
|
|
|
|
// 如果是昨天,展示昨天
|
|
if (now.subtract(1, 'day').isSame(target, 'day')) {
|
|
return i18nT('common:yesterday');
|
|
}
|
|
|
|
// 如果是今年,展示某月某日
|
|
if (now.isSame(target, 'year')) {
|
|
return target.format('MM-DD');
|
|
}
|
|
|
|
// 如果是更久之前,展示某年某月某日
|
|
return target.format('YYYY-M-D');
|
|
};
|
|
|
|
export const formatTimeToChatItemTime = (time: Date) => {
|
|
const now = dayjs();
|
|
const target = dayjs(time);
|
|
const detailTime = target.format('HH#mm');
|
|
|
|
// 如果时间是今天,展示几时:几分
|
|
if (now.isSame(target, 'day')) {
|
|
return detailTime;
|
|
}
|
|
|
|
// 如果是昨天,展示昨天+几时:几分
|
|
if (now.subtract(1, 'day').isSame(target, 'day')) {
|
|
return i18nT('common:yesterday_detail_time');
|
|
}
|
|
|
|
// 如果是今年,展示某月某日+几时:几分
|
|
if (now.isSame(target, 'year')) {
|
|
return target.format('MM-DD') + ' ' + detailTime;
|
|
}
|
|
|
|
// 如果是更久之前,展示某年某月某日+几时:几分
|
|
return target.format('YYYY-M-D') + ' ' + detailTime;
|
|
};
|
|
|
|
/* cron time parse */
|
|
export const cronParser2Fields = (cronString: string) => {
|
|
try {
|
|
const cronField = cronParser.parseExpression(cronString).fields;
|
|
return cronField;
|
|
} catch (error) {
|
|
return null;
|
|
}
|
|
};
|
|
// 根据cron表达式和时区获取下一个时间
|
|
export const getNextTimeByCronStringAndTimezone = ({
|
|
cronString,
|
|
timezone
|
|
}: {
|
|
cronString: string;
|
|
timezone: string;
|
|
}) => {
|
|
try {
|
|
const options = {
|
|
currentDate: dayjs().tz(timezone).format(),
|
|
tz: timezone
|
|
};
|
|
const interval = cronParser.parseExpression(cronString, options);
|
|
const date = interval.next().toString();
|
|
|
|
return new Date(date);
|
|
} catch (error) {
|
|
console.log('getNextTimeByCronStringAndTimezone error', error);
|
|
return new Date();
|
|
}
|
|
};
|