sd-webui-lobe-theme/src/components/PromptEditor/Prompt.tsx

80 lines
2.3 KiB
TypeScript
Raw Blame History

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

import { consola } from 'consola';
import { memo, useCallback, useState } from 'react';
import { useTranslation } from 'react-i18next';
import { Flexbox } from 'react-layout-kit';
import TagList, { PromptType, TagItem } from './TagList';
import { useStyles } from './style';
import { formatPrompt } from './utils';
interface PromptProps {
type: PromptType;
}
const Prompt = memo<PromptProps>(({ type }) => {
const [tags, setTags] = useState<TagItem[]>([]);
const { styles } = useStyles();
const { t } = useTranslation();
const id =
type === 'positive' ? "[id$='2img_prompt'] textarea" : "[id$='2img_neg_prompt'] textarea";
const getValue = useCallback(() => {
try {
const textarea = get_uiCurrentTabContent().querySelector(id) as HTMLTextAreaElement;
if (textarea) setTags(formatPrompt(textarea.value));
} catch (error) {
consola.error('🤯 [prompt]', error);
}
}, []);
const setValue = useCallback(() => {
try {
const newValue = tags.map((t) => t.text).join(', ');
const textarea = get_uiCurrentTabContent().querySelector(id) as HTMLTextAreaElement;
if (textarea) textarea.value = newValue;
updateInput(textarea);
} catch (error) {
consola.error('🤯 [prompt]', error);
}
}, [tags, type]);
const setCurrentValue = useCallback((currentTags: TagItem[]) => {
try {
const textarea = get_uiCurrentTabContent().querySelector(id) as HTMLTextAreaElement;
if (textarea) textarea.value = currentTags.map((t) => t.text).join(', ');
updateInput(textarea);
} catch (error) {
consola.error('🤯 [prompt]', error);
}
}, []);
return (
<div className={styles.promptView}>
<TagList setTags={setTags} setValue={setCurrentValue} tags={tags} type={type} />
<Flexbox gap={8} horizontal>
<button
className="secondary gradio-button"
onClick={getValue}
style={{ flex: 1, height: 36 }}
title={t('prompt.load')}
type="button"
>
🔄
</button>
<button
className="secondary gradio-button"
onClick={setValue}
style={{ flex: 1, height: 36 }}
title={t('prompt.set')}
type="button"
>
</button>
</Flexbox>
</div>
);
});
export default Prompt;