mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-16 16:04:34 +00:00

* 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();
|
||
}
|
||
};
|