Loading...
Loading...
Modal imperative API guide. Use when creating modal dialogs using createModal from @lobehub/ui. Triggers on modal component implementation or dialog creation tasks.
npx skill4agent add lobehub/lobe-chat modalcreateModal@lobehub/ui| Mode | Characteristics | Recommended |
|---|---|---|
| Declarative | Need | ❌ |
| Imperative | Call function directly, no state | ✅ |
features/
└── MyFeatureModal/
├── index.tsx # Export createXxxModal
└── MyFeatureContent.tsx # Modal contentMyFeatureContent.tsx'use client';
import { useModalContext } from '@lobehub/ui';
import { useTranslation } from 'react-i18next';
export const MyFeatureContent = () => {
const { t } = useTranslation('namespace');
const { close } = useModalContext(); // Optional: get close method
return <div>{/* Modal content */}</div>;
};index.tsx'use client';
import { createModal } from '@lobehub/ui';
import { t } from 'i18next'; // Note: use i18next, not react-i18next
import { MyFeatureContent } from './MyFeatureContent';
export const createMyFeatureModal = () =>
createModal({
allowFullscreen: true,
children: <MyFeatureContent />,
destroyOnHidden: false,
footer: null,
styles: { body: { overflow: 'hidden', padding: 0 } },
title: t('myFeature.title', { ns: 'setting' }),
width: 'min(80%, 800px)',
});import { createMyFeatureModal } from '@/features/MyFeatureModal';
const handleOpen = useCallback(() => {
createMyFeatureModal();
}, []);
return <Button onClick={handleOpen}>Open</Button>;useTranslationimport { t } from 'i18next'const { close, setCanDismissByClickOutside } = useModalContext();| Property | Type | Description |
|---|---|---|
| | Allow fullscreen mode |
| | Destroy content on close |
| | Footer content |
| | Modal width |
src/features/SkillStore/index.tsxsrc/features/LibraryModal/CreateNew/index.tsx