mirror of
https://github.com/datahub-project/datahub.git
synced 2025-10-27 17:02:03 +00:00
83 lines
2.6 KiB
TypeScript
83 lines
2.6 KiB
TypeScript
import { FromToProps } from '@remirror/core-types';
|
|
import { getMarkRange } from '@remirror/core-utils';
|
|
import { useAttrs, useCommands, useEditorState, useHelpers } from '@remirror/react';
|
|
import { Form, Input, Modal, Typography } from 'antd';
|
|
import React, { useEffect, useState } from 'react';
|
|
|
|
type LinkModalProps = {
|
|
visible: boolean;
|
|
handleClose: () => void;
|
|
};
|
|
|
|
export const LinkModal = (props: LinkModalProps) => {
|
|
const { visible, handleClose } = props;
|
|
|
|
const [trPos, setTrPos] = useState<FromToProps>({ from: 0, to: 0 });
|
|
const [form] = Form.useForm();
|
|
|
|
const commands = useCommands();
|
|
const helpers = useHelpers();
|
|
const editorState = useEditorState();
|
|
|
|
const href = (useAttrs().link()?.href as string) ?? '';
|
|
|
|
useEffect(() => {
|
|
if (visible) {
|
|
const { from, to } = editorState.selection;
|
|
const pos = getMarkRange(editorState.doc.resolve(from), 'link') || { from, to };
|
|
|
|
form.setFieldsValue({
|
|
href,
|
|
text: helpers.getTextBetween(pos.from, pos.to, editorState.doc) || '',
|
|
});
|
|
|
|
setTrPos(pos);
|
|
}
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, [visible]);
|
|
|
|
const handleOk = async () => {
|
|
try {
|
|
const values = await form.validateFields();
|
|
const displayText = values.text || values.href;
|
|
|
|
commands.replaceText({
|
|
content: displayText,
|
|
selection: trPos,
|
|
type: 'link',
|
|
attrs: {
|
|
href: values.href,
|
|
},
|
|
});
|
|
|
|
form.resetFields();
|
|
handleClose();
|
|
} catch (e) {
|
|
console.log('Validate Failed:', e);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<Modal title="Add Link" okText="Save" onCancel={handleClose} zIndex={1200} onOk={handleOk} open={visible}>
|
|
<Form
|
|
form={form}
|
|
layout="vertical"
|
|
colon={false}
|
|
requiredMark={false}
|
|
onKeyPress={(e) => e.key === 'Enter' && form.submit()}
|
|
>
|
|
<Form.Item
|
|
name="href"
|
|
label={<Typography.Text strong>Link URL</Typography.Text>}
|
|
rules={[{ required: true }]}
|
|
>
|
|
<Input placeholder="https://www.google.com" autoFocus />
|
|
</Form.Item>
|
|
<Form.Item name="text" label={<Typography.Text strong>Text</Typography.Text>}>
|
|
<Input />
|
|
</Form.Item>
|
|
</Form>
|
|
</Modal>
|
|
);
|
|
};
|