mirror of
https://github.com/labring/FastGPT.git
synced 2025-08-01 20:27:45 +00:00

* Dataset collection forbid (#1885) * perf: tool call support same id * feat: collection forbid * feat: collection forbid * Inheritance Permission for apps (#1897) * feat: app schema define chore: references of authapp * feat: authApp method inheritance * feat: create and update api * feat: update * feat: inheritance Permission controller for app. * feat: abstract version of inheritPermission * feat: ancestorId for apps * chore: update app * fix: inheritPermission abstract version * feat: update folder defaultPermission * feat: app update api * chore: inheritance frontend * chore: app list api * feat: update defaultPermission in app deatil * feat: backend api finished * feat: app inheritance permission fe * fix: app update defaultpermission causes collaborator miss * fix: ts error * chore: adjust the codes * chore: i18n chore: i18n * chore: fe adjust and i18n * chore: adjust the code * feat: resume api; chore: rewrite update api and inheritPermission methods * chore: something * chore: fe code adjusting * feat: frontend adjusting * chore: fe code adjusting * chore: adjusting the code * perf: fe loading * format * Inheritance fix (#1908) * fix: SlideCard * fix: authapp did not return parent app for inheritance app * fix: fe adjusting * feat: fe adjusing * perf: inherit per ux * doc * fix: ts errors (#1916) * perf: inherit permission * fix: permission inherit * Workflow type (#1938) * perf: workflow type tmp workflow perf: workflow type feat: custom field config * perf: dynamic input * perf: node classify * perf: node classify * perf: node classify * perf: node classify * fix: workflow custom input * feat: text editor and customFeedback move to basic nodes * feat: community system plugin * fix: ts * feat: exprEval plugin * perf: workflow type * perf: plugin important * fix: default templates * perf: markdown hr css * lock * perf: fetch url * perf: new plugin version * fix: chat histories update * fix: collection paths invalid * perf: app card ui --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
127 lines
3.2 KiB
TypeScript
127 lines
3.2 KiB
TypeScript
import React, { useCallback, useRef } from 'react';
|
|
import { ModalFooter, ModalBody, Input, useDisclosure, Button, Box } from '@chakra-ui/react';
|
|
import MyModal from '@fastgpt/web/components/common/MyModal';
|
|
import { useToast } from '@fastgpt/web/hooks/useToast';
|
|
import { useTranslation } from 'next-i18next';
|
|
import { useRequest2 } from '@fastgpt/web/hooks/useRequest';
|
|
|
|
export const useEditTitle = ({
|
|
title,
|
|
tip,
|
|
placeholder = '',
|
|
canEmpty = true,
|
|
valueRule
|
|
}: {
|
|
title: string;
|
|
tip?: string;
|
|
placeholder?: string;
|
|
canEmpty?: boolean;
|
|
valueRule?: (val: string) => string | void;
|
|
}) => {
|
|
const { t } = useTranslation();
|
|
const { isOpen, onOpen, onClose } = useDisclosure();
|
|
|
|
const inputRef = useRef<HTMLInputElement | null>(null);
|
|
const onSuccessCb = useRef<(content: string) => void | Promise<void>>();
|
|
const onErrorCb = useRef<(err: any) => void>();
|
|
const { toast } = useToast();
|
|
const defaultValue = useRef('');
|
|
|
|
const onOpenModal = useCallback(
|
|
({
|
|
defaultVal,
|
|
onSuccess,
|
|
onError
|
|
}: {
|
|
defaultVal: string;
|
|
onSuccess: (content: string) => any;
|
|
onError?: (err: any) => void;
|
|
}) => {
|
|
onOpen();
|
|
onSuccessCb.current = onSuccess;
|
|
onErrorCb.current = onError;
|
|
defaultValue.current = defaultVal;
|
|
},
|
|
[onOpen]
|
|
);
|
|
|
|
const onclickConfirm = useCallback(async () => {
|
|
if (!inputRef.current || !onSuccessCb.current) return;
|
|
const val = inputRef.current.value;
|
|
|
|
if (!canEmpty && !val) {
|
|
inputRef.current.focus();
|
|
return;
|
|
}
|
|
|
|
if (valueRule) {
|
|
const result = valueRule(val);
|
|
if (result) {
|
|
return toast({
|
|
status: 'warning',
|
|
title: result
|
|
});
|
|
}
|
|
}
|
|
|
|
try {
|
|
await onSuccessCb.current(val);
|
|
|
|
onClose();
|
|
} catch (err) {
|
|
onErrorCb.current?.(err);
|
|
}
|
|
}, [canEmpty, onClose, toast, valueRule]);
|
|
|
|
// eslint-disable-next-line react/display-name
|
|
const EditModal = useCallback(
|
|
({
|
|
maxLength = 30,
|
|
iconSrc = 'modal/edit',
|
|
closeBtnText = t('common.Close')
|
|
}: {
|
|
maxLength?: number;
|
|
iconSrc?: string;
|
|
closeBtnText?: string;
|
|
}) => {
|
|
const { runAsync, loading } = useRequest2(onclickConfirm);
|
|
|
|
return (
|
|
<MyModal isOpen={isOpen} onClose={onClose} iconSrc={iconSrc} title={title} maxW={'500px'}>
|
|
<ModalBody>
|
|
{!!tip && (
|
|
<Box mb={2} color={'myGray.500'} fontSize={'sm'}>
|
|
{tip}
|
|
</Box>
|
|
)}
|
|
|
|
<Input
|
|
ref={inputRef}
|
|
defaultValue={defaultValue.current}
|
|
placeholder={placeholder}
|
|
autoFocus
|
|
maxLength={maxLength}
|
|
/>
|
|
</ModalBody>
|
|
<ModalFooter>
|
|
{!!closeBtnText && (
|
|
<Button mr={3} variant={'whiteBase'} onClick={onClose}>
|
|
{closeBtnText}
|
|
</Button>
|
|
)}
|
|
<Button onClick={runAsync} isLoading={loading}>
|
|
{t('common.Confirm')}
|
|
</Button>
|
|
</ModalFooter>
|
|
</MyModal>
|
|
);
|
|
},
|
|
[isOpen, onClose, onclickConfirm, placeholder, t, tip, title]
|
|
);
|
|
|
|
return {
|
|
onOpenModal,
|
|
EditModal
|
|
};
|
|
};
|