mirror of
https://github.com/labring/FastGPT.git
synced 2026-05-07 01:02:55 +08:00
470eeca060
* feat: wecom integration (#6234) * wip: wecom * feat: template filter by user tag * feat: wecom pay * fix: some bug * fix: zod error * feat: bill * fix: bill toast * feat: forbidden downgrade plan button * chore(fe): wecom zone * chore: use queue to delete team instead of a session * chore: adjust * feat: wecom bill logic refactor * perf: plan * perf: plan * fix: i18n * chore: adjust * feat: adjust * feat: add wecom config * perf: wecom app template recommendation & system tool preinstall * perf: some variable and tip * update create bill api schema * update create bill api schema * update create bill api schema * feat: wecom * chore: adjust * fix: ts * perf: condition order * perf: condition order --------- Co-authored-by: archer <545436317@qq.com> * feat: system tool config tags (#6257) * fix: system secret (#6259) * fix: system secret * chore: update docs * chore: merge main (#6264) * feat: wecom integration (#6234) * wip: wecom * feat: template filter by user tag * feat: wecom pay * fix: some bug * fix: zod error * feat: bill * fix: bill toast * feat: forbidden downgrade plan button * chore(fe): wecom zone * chore: use queue to delete team instead of a session * chore: adjust * feat: wecom bill logic refactor * perf: plan * perf: plan * fix: i18n * chore: adjust * feat: adjust * feat: add wecom config * perf: wecom app template recommendation & system tool preinstall * perf: some variable and tip * update create bill api schema * update create bill api schema * update create bill api schema * feat: wecom * chore: adjust * fix: ts * perf: condition order * perf: condition order --------- Co-authored-by: archer <545436317@qq.com> * feat: system tool config tags (#6257) * fix: system secret (#6259) * fix: system secret * chore: update docs --------- Co-authored-by: archer <545436317@qq.com> * chore: update version number (#6266) * fix: price status (#6279) * fix: back button (#6281) * team plan max file size & count (#6258) * team plan max file size & count * fix * fix * fix * perf: presign url * remove empty check * remove empty check * fix: ts * fix: doc * fix presign file * perf: code * perf: i18n * fix: remove maxSize attribute --------- Co-authored-by: archer <545436317@qq.com> Co-authored-by: Finley Ge <finleyge@fastgpt.io> * feat: marketplace batch update (#6299) * feat: wecom integration (#6234) * wip: wecom * feat: template filter by user tag * feat: wecom pay * fix: some bug * fix: zod error * feat: bill * fix: bill toast * feat: forbidden downgrade plan button * chore(fe): wecom zone * chore: use queue to delete team instead of a session * chore: adjust * feat: wecom bill logic refactor * perf: plan * perf: plan * fix: i18n * chore: adjust * feat: adjust * feat: add wecom config * perf: wecom app template recommendation & system tool preinstall * perf: some variable and tip * update create bill api schema * update create bill api schema * update create bill api schema * feat: wecom * chore: adjust * fix: ts * perf: condition order * perf: condition order --------- Co-authored-by: archer <545436317@qq.com> * feat: system tool config tags (#6257) * fix: system secret (#6259) * fix: system secret * chore: update docs * chore: merge main (#6264) * feat: wecom integration (#6234) * wip: wecom * feat: template filter by user tag * feat: wecom pay * fix: some bug * fix: zod error * feat: bill * fix: bill toast * feat: forbidden downgrade plan button * chore(fe): wecom zone * chore: use queue to delete team instead of a session * chore: adjust * feat: wecom bill logic refactor * perf: plan * perf: plan * fix: i18n * chore: adjust * feat: adjust * feat: add wecom config * perf: wecom app template recommendation & system tool preinstall * perf: some variable and tip * update create bill api schema * update create bill api schema * update create bill api schema * feat: wecom * chore: adjust * fix: ts * perf: condition order * perf: condition order --------- Co-authored-by: archer <545436317@qq.com> * feat: system tool config tags (#6257) * fix: system secret (#6259) * fix: system secret * chore: update docs --------- Co-authored-by: archer <545436317@qq.com> * fix: custom domain limitation (#6265) * chore: update version number (#6266) * fix: price status (#6279) * fix: back button (#6281) * chore/rebase main (#6295) * chore(deps): bump undici from 7.16.0 to 7.18.2 (#6272) Bumps [undici](https://github.com/nodejs/undici) from 7.16.0 to 7.18.2. - [Release notes](https://github.com/nodejs/undici/releases) - [Commits](https://github.com/nodejs/undici/compare/v7.16.0...v7.18.2) --- updated-dependencies: - dependency-name: undici dependency-version: 7.18.2 dependency-type: direct:production ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * chore(deps): bump undici in /plugins/webcrawler/SPIDER (#6273) Bumps [undici](https://github.com/nodejs/undici) from 6.21.3 to 6.23.0. - [Release notes](https://github.com/nodejs/undici/releases) - [Commits](https://github.com/nodejs/undici/compare/v6.21.3...v6.23.0) --- updated-dependencies: - dependency-name: undici dependency-version: 6.23.0 dependency-type: indirect ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * chore(deps): bump tar from 7.4.3 to 7.5.3 in /document (#6282) Bumps [tar](https://github.com/isaacs/node-tar) from 7.4.3 to 7.5.3. - [Release notes](https://github.com/isaacs/node-tar/releases) - [Changelog](https://github.com/isaacs/node-tar/blob/main/CHANGELOG.md) - [Commits](https://github.com/isaacs/node-tar/compare/v7.4.3...v7.5.3) --- updated-dependencies: - dependency-name: tar dependency-version: 7.5.3 dependency-type: indirect ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> * perf: remove request invalid field (#6283) * V4.14.5.1 dev (#6290) * chore: cherry pick some commits from v4.14.6-dev (#6287) * fix: custom domain limitation (#6265) * fix: system secret (#6259) * fix: system secret * chore: update docs * chore: docs * fix password variable & datetime picker (#6276) * fix password variable & datetime picker * doc * chore: cherry pick some commits from v4.14.6-dev (#6287) * fix: custom domain limitation (#6265) * fix: system secret (#6259) * fix: system secret * chore: update docs * chore: docs * doc * chore: docs --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com> Co-authored-by: Finley Ge <finleyge@fastgpt.io> * perf: extname computed (#6285) * perf: extname computed * chore: handle hash or query flags --------- Co-authored-by: Finley Ge <finleyge@fastgpt.io> * chore: docs (#6291) --------- Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: Archer <545436317@qq.com> * chore: deploy scripts (#6293) * docs: 41451 upgrade doc (#6294) * feat: wecom integration (#6234) * wip: wecom * feat: template filter by user tag * feat: wecom pay * fix: some bug * fix: zod error * feat: bill * fix: bill toast * feat: forbidden downgrade plan button * chore(fe): wecom zone * chore: use queue to delete team instead of a session * chore: adjust * feat: wecom bill logic refactor * perf: plan * perf: plan * fix: i18n * chore: adjust * feat: adjust * feat: add wecom config * perf: wecom app template recommendation & system tool preinstall * perf: some variable and tip * update create bill api schema * update create bill api schema * update create bill api schema * feat: wecom * chore: adjust * fix: ts * perf: condition order * perf: condition order --------- Co-authored-by: archer <545436317@qq.com> * feat: system tool config tags (#6257) * fix: price status (#6279) * fix: back button (#6281) --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Archer <545436317@qq.com> Co-authored-by: heheer <heheer@sealos.io> * feat: marketplace batch update * chore: components reuse * fix: test case --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: archer <545436317@qq.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: heheer <heheer@sealos.io> * fix: upload file size limit && batch update plugin ui (#6308) * fix: batch update drawer ui && custom plan logic * fix: max upload file size * chore: remove comment * fix: plan-status (#6311) * fix: price page (#6313) * fix: plan ui * fix: custom standard plan (#6317) * fix: system tool route & batch update drawer ui (#6318) * fix: system tool route * chore: upgrade docs * chore: batch update ui * fix: marketplace tool detail readme height (#6324) * fix: marketplace tool detail readme height * chore: use useRequest2 * chore: adapt new plugin sdk (#6334) * chore: adapt new plugin sdk * chore: bump @fastgpt-sdk/plugin to 0.3.6; fix type error --------- Co-authored-by: Finley Ge <finleyge@fastgpt.io> Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com> * fix: marketplace batch update drawer button background (#6340) * chore: useRequest2 -> useRequest * #6193 feat(SeekDB): 集成支持 SeekDB 向量数据库 (#6338) * #6193 feat(SeekDB): 集成支持 SeekDB 向量数据库 - 添加 SEEKDB_ADDRESS 环境变量支持 - 在 vectorDB 控制器中优先返回 SeekVectorCtrl 实例 - 新增 SeekDB 向量库控制器,复用 OceanBase 控制器实现 - 更新部署文档,新增 SeekDB 相关描述和配置说明 - 新增 SeekDB 的 Docker Compose 配置,支持国内和全球镜像 - 在开发文档中添加 SeekDB 的环境要求及特性介绍 - 修改部署脚本支持 SeekDB 版本快速部署 * fix(vectorDB): add type annotation to getVectorObj to resolve TypeScript compilation error - Add return type annotation (: VectorControllerType) to getVectorObj function - Fixes Docker build failure: Property 'insertIds' does not exist on type 'unknown' - The Vector object now has correct type inference for retryFn Related: Docker build fails at TypeScript type checking stage * #6193 refactor(vectorDB): 调整 SeekDB 控制器导入方式 - 将 ObClient 和 ObVectorCtrl 分开导入,提升代码清晰度 - 将导出语句拆分为两行,便于后续维护 - 保持 OceanBase 控制器复用逻辑不变 - 优化代码格式,增强可读性 * doc --------- Co-authored-by: archer <545436317@qq.com> * fix date time picker disabled status (#6352) * fix date time picker disabled status * fix build * fix: copilot review * perf: claude review * fix: ts * chore: docs, type (#6350) * fix: mock (#6354) --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: archer <545436317@qq.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: roy <whoeverimf5@gmail.com> Co-authored-by: flying~dragon <58673960+flying-dragon-ai@users.noreply.github.com>
165 lines
4.8 KiB
TypeScript
165 lines
4.8 KiB
TypeScript
import React, { useState, useMemo, useRef, useEffect } from 'react';
|
|
import type { BoxProps } from '@chakra-ui/react';
|
|
import { Box, Card, Flex, Portal, useOutsideClick } from '@chakra-ui/react';
|
|
import { format } from 'date-fns';
|
|
import type { Matcher } from 'react-day-picker';
|
|
import { DayPicker } from 'react-day-picker';
|
|
import 'react-day-picker/dist/style.css';
|
|
import zhCN from 'date-fns/locale/zh-CN';
|
|
import MyIcon from '../Icon';
|
|
|
|
const DateTimePicker = ({
|
|
onChange,
|
|
popPosition = 'bottom',
|
|
defaultDate,
|
|
selectedDateTime,
|
|
disabled,
|
|
isDisabled,
|
|
...props
|
|
}: {
|
|
onChange?: (dateTime: Date | undefined) => void;
|
|
popPosition?: 'bottom' | 'top';
|
|
defaultDate?: Date;
|
|
selectedDateTime?: Date;
|
|
disabled?: Matcher[];
|
|
isDisabled?: boolean;
|
|
} & Omit<BoxProps, 'onChange'>) => {
|
|
const containerRef = useRef<HTMLDivElement>(null);
|
|
const popoverRef = useRef<HTMLDivElement>(null);
|
|
const [selectedDate, setSelectedDate] = useState<Date | undefined>(
|
|
selectedDateTime || defaultDate
|
|
);
|
|
const [showSelected, setShowSelected] = useState(false);
|
|
const [position, setPosition] = useState({ top: 0, left: 0 });
|
|
|
|
useEffect(() => {
|
|
setSelectedDate(selectedDateTime);
|
|
}, [selectedDateTime]);
|
|
|
|
useEffect(() => {
|
|
if (!showSelected) return;
|
|
const updatePosition = () => {
|
|
const rect = containerRef.current?.getBoundingClientRect();
|
|
const popoverRect = popoverRef.current?.getBoundingClientRect();
|
|
if (!rect || !popoverRect) return;
|
|
|
|
const padding = 8;
|
|
const topBottom = rect.bottom + 4;
|
|
const topTop = rect.top - 4 - popoverRect.height;
|
|
const maxTop = window.innerHeight - popoverRect.height - padding;
|
|
const maxLeft = window.innerWidth - popoverRect.width - padding;
|
|
|
|
let top = popPosition === 'top' ? topTop : topBottom;
|
|
if (
|
|
popPosition === 'bottom' &&
|
|
topBottom + popoverRect.height > window.innerHeight - padding &&
|
|
topTop >= padding
|
|
) {
|
|
top = topTop;
|
|
}
|
|
if (
|
|
popPosition === 'top' &&
|
|
topTop < padding &&
|
|
topBottom + popoverRect.height <= window.innerHeight - padding
|
|
) {
|
|
top = topBottom;
|
|
}
|
|
top = Math.min(Math.max(top, padding), Math.max(padding, maxTop));
|
|
|
|
let left = rect.left;
|
|
left = Math.min(Math.max(left, padding), Math.max(padding, maxLeft));
|
|
|
|
setPosition({ top, left });
|
|
};
|
|
|
|
const raf = requestAnimationFrame(updatePosition);
|
|
window.addEventListener('resize', updatePosition);
|
|
window.addEventListener('scroll', updatePosition, true);
|
|
return () => {
|
|
cancelAnimationFrame(raf);
|
|
window.removeEventListener('resize', updatePosition);
|
|
window.removeEventListener('scroll', updatePosition, true);
|
|
};
|
|
}, [showSelected, popPosition]);
|
|
|
|
// 点击外部关闭
|
|
useEffect(() => {
|
|
if (!showSelected) return;
|
|
const handleClick = (e: MouseEvent) => {
|
|
if (
|
|
containerRef.current?.contains(e.target as Node) ||
|
|
popoverRef.current?.contains(e.target as Node)
|
|
) {
|
|
return;
|
|
}
|
|
setShowSelected(false);
|
|
};
|
|
document.addEventListener('mousedown', handleClick);
|
|
return () => document.removeEventListener('mousedown', handleClick);
|
|
}, [showSelected]);
|
|
|
|
const formatSelected = useMemo(() => {
|
|
if (selectedDate) {
|
|
return format(selectedDate, 'y/MM/dd');
|
|
}
|
|
return '';
|
|
}, [selectedDate]);
|
|
|
|
return (
|
|
<Box position={'relative'} ref={containerRef}>
|
|
<Flex
|
|
border={'base'}
|
|
px={3}
|
|
pr={3}
|
|
py={1}
|
|
borderRadius={'sm'}
|
|
fontSize={'sm'}
|
|
alignItems={'center'}
|
|
{...(isDisabled
|
|
? { cursor: 'not-allowed', bg: 'myGray.100', opacity: 0.6 }
|
|
: {
|
|
cursor: 'pointer',
|
|
bg: 'myGray.50',
|
|
onClick: () => setShowSelected((state) => !state)
|
|
})}
|
|
{...props}
|
|
>
|
|
<Box color={'myGray.600'} fontWeight={'400'} flex={1}>
|
|
{formatSelected}
|
|
</Box>
|
|
<MyIcon ml={2} name={'date'} w={'16px'} color={'myGray.600'} />
|
|
</Flex>
|
|
{showSelected && (
|
|
<Portal>
|
|
<Card
|
|
ref={popoverRef}
|
|
position={'fixed'}
|
|
top={`${position.top}px`}
|
|
left={`${position.left}px`}
|
|
zIndex={1500}
|
|
css={{
|
|
'--rdp-background-color': '#d6e8ff',
|
|
'--rdp-accent-color': '#0000ff'
|
|
}}
|
|
>
|
|
<DayPicker
|
|
locale={zhCN}
|
|
mode="single"
|
|
defaultMonth={selectedDate}
|
|
selected={selectedDate}
|
|
disabled={disabled}
|
|
onSelect={(date) => {
|
|
setSelectedDate(date);
|
|
onChange?.(date);
|
|
setShowSelected(false);
|
|
}}
|
|
/>
|
|
</Card>
|
|
</Portal>
|
|
)}
|
|
</Box>
|
|
);
|
|
};
|
|
|
|
export default DateTimePicker;
|