From 7e05bbe6dd551daa8153892188a31b80be4bd531 Mon Sep 17 00:00:00 2001 From: wulibaibao <13366578180@163.com> Date: Fri, 29 Apr 2022 17:09:01 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=A1=A8=E6=A0=BCcolumn=E8=B6=85?= =?UTF-8?q?=E5=87=BAtooltip=E6=98=BE=E7=A4=BA=E7=BB=84=E4=BB=B6=E5=BC=80?= =?UTF-8?q?=E5=8F=91=EF=BC=8C=E5=AF=8C=E6=96=87=E6=9C=AC=E6=94=AF=E6=8C=81?= =?UTF-8?q?markdown=E8=AF=AD=E6=B3=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package.json | 3 +- src/components/Public/ButtonModal.tsx | 115 ++++++++++++++++++++++++ src/components/Public/OverflowText.tsx | 49 ++++++++++ src/components/RichTextEditor/index.tsx | 17 ++-- src/pages/Outline/index.tsx | 12 ++- src/pages/Plan/CreatePage.tsx | 1 + src/pages/Plan/hooks.ts | 3 +- 7 files changed, 190 insertions(+), 10 deletions(-) create mode 100644 src/components/Public/ButtonModal.tsx create mode 100644 src/components/Public/OverflowText.tsx diff --git a/package.json b/package.json index f45c57f..6d0e6ba 100644 --- a/package.json +++ b/package.json @@ -62,7 +62,8 @@ "@types/reactcss": "^1.2.6", "@types/styled-components": "^5.1.24", "@umijs/route-utils": "^1.0.36", - "@wangeditor/editor": "^0.15.15", + "@wangeditor/editor": "^5.0.1", + "@wangeditor/plugin-md": "^1.0.0", "ahooks": "^3.1.13", "antd": "^4.19.3", "bizcharts": "^3.5.3-beta.0", diff --git a/src/components/Public/ButtonModal.tsx b/src/components/Public/ButtonModal.tsx new file mode 100644 index 0000000..c27d29d --- /dev/null +++ b/src/components/Public/ButtonModal.tsx @@ -0,0 +1,115 @@ +import React from "react" +import { Button , Modal , Form } from "antd" +import type { ButtonProps , ModalProps , FormProps , FormInstance } from "antd" + +type IProps = { + onOk?: (_: any) => void + +} & ButtonProps & ModalProps & FormProps + +type TModalProps = { + +} & FormProps & ModalProps + +type TModalRefs = { + show: (_: any) => void; + cancel: () => void; + form: FormInstance; +} + +const ModalComponent: React.ForwardRefRenderFunction = (props , ref) => { + const { basicTitle , modalBodyRender , hasForm , layout , onCancel } = props + + const [ source ,setSource ] = React.useState(undefined) + const [ visible ,setVisible ] = React.useState(false) + + const [form] = Form.useForm() + + React.useImperativeHandle(ref , () => ({ + show (_) { + if (_) { + setSource(_) + } + setVisible(true) + }, + form, + cancel: handleCancel + })) + + const handleOk = () => { + onOk && onOk(source , cancel) + } + + const handleCancel = useCallback(() => { + setVisible(false) + setSource(false) + form.resetFields() + onCancel && onCancel() + } , []) + + React.useEffect(() => { + return () => { + handleCancel() + } + } , []) + + return ( + + + + + } + > + { + modalBodyRender && hasForm ? +
+ { modalBodyRender() } +
: + modalBodyRender() + } +
+ ) +} + +const TModal = React.forwardRef(ModalComponent) + +const ButtonModal: React.FC = (props) => { + const { onOk , onCancel } = props + + const ref = React.useRef(null) + + const handleOk = (vals: any) => { + console.log(vals) + ref.current.cancel() + } + + const handleCancel = () => { + onCancel && onCancel() + } + + return ( + <> + + + + ) +} + +export default ButtonModal \ No newline at end of file diff --git a/src/components/Public/OverflowText.tsx b/src/components/Public/OverflowText.tsx new file mode 100644 index 0000000..da378ac --- /dev/null +++ b/src/components/Public/OverflowText.tsx @@ -0,0 +1,49 @@ +import React from "react" +import { Typography , Tooltip } from "antd" + +type IProps = { + title: string; + [k: string]: any; +} + +const OverflowText: React.FC = (props) => { + const { children , style , rows = 1 ,...rest } = props + console.log(style) + + const [showTooltip, setShowTooltip] = React.useState(false) + + React.useEffect(() => { + return () => { + setShowTooltip(false) + } + } , []) + + if (showTooltip ) + return ( + + + {children} + + + ) + + return ( + setShowTooltip(true) + }} + > + {children || "-"} + + ) +} + +export default OverflowText \ No newline at end of file diff --git a/src/components/RichTextEditor/index.tsx b/src/components/RichTextEditor/index.tsx index 7cb1a3b..18a1466 100644 --- a/src/components/RichTextEditor/index.tsx +++ b/src/components/RichTextEditor/index.tsx @@ -1,14 +1,19 @@ +import React from "react" + +import { createEditor, createToolbar, SlateTransforms, IDomEditor, IEditorConfig, Boot } from '@wangeditor/editor' +import markdownModule from '@wangeditor/plugin-md' -import '@wangeditor/editor/dist/css/style.css' -import { createEditor, createToolbar, SlateTransforms, IDomEditor, IEditorConfig } from '@wangeditor/editor' import toolbarConfig from './toolbar.config' -import React from "react" import { message } from "antd" import { useSize } from "ahooks" -import styles from "./index.less" import { uploadOss } from '@/services' +import '@wangeditor/editor/dist/css/style.css' +import styles from "./index.less" + +Boot.registerModule(markdownModule) + type IProps = { onEditorChange?: (vm?: any) => void; defaultValue?: any[]; @@ -31,7 +36,7 @@ const RichTextEditor: React.FC = (props) => { const toolbar = React.useRef(null) const editor = React.useRef(null) as any - + React.useEffect(() => { const riceEditor = createEditor({ selector: editor.current, @@ -51,7 +56,7 @@ const RichTextEditor: React.FC = (props) => { selector: toolbar.current as any, config: toolbarConfig }) - + onEditorChange && onEditorChange(vm) }, onChange(vm) { diff --git a/src/pages/Outline/index.tsx b/src/pages/Outline/index.tsx index ef348e1..c11dd37 100644 --- a/src/pages/Outline/index.tsx +++ b/src/pages/Outline/index.tsx @@ -6,6 +6,7 @@ import AddModal from './components/AddModal'; import DeleteModal from './components/DeleteModal'; import { ColumnProps } from 'antd/lib/table'; import { deleteOutline } from './services'; +import OverflowText from "@/components/Public/OverflowText" const DEFAULT_PAGE_QUERY = { page_size: 20, page_num: 1 }; @@ -37,7 +38,9 @@ const TestDemand: React.FC = () => { const data = await download(row.id); const fileContent = row.name.split('.'); const fileSuffix = fileContent[fileContent.length - 1]; + let fileAppType = 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'; + if (fileSuffix === 'doc') { fileAppType = 'application/msword'; } else if (fileSuffix == 'pdf') { @@ -46,15 +49,19 @@ const TestDemand: React.FC = () => { fileAppType = 'text/plain'; } else { } + const blob = new Blob([data], { type: fileAppType, }); + const objectURL = URL.createObjectURL(blob); const btn = document.createElement('a'); + btn.download = row.name; btn.href = objectURL; btn.click(); URL.revokeObjectURL(objectURL); + message.success('下载成功'); }; @@ -70,8 +77,10 @@ const TestDemand: React.FC = () => { { title: '备注', dataIndex: 'remark', + ellipsis: true, + width: 200, render(_, row) { - return _ || "-" + return } }, { @@ -133,6 +142,7 @@ const TestDemand: React.FC = () => { columns={columns} dataSource={dataSource?.data || []} size="small" + rowkey="id" pagination={{ total: dataSource?.total ?? 1, current: pageQuery.page_num, diff --git a/src/pages/Plan/CreatePage.tsx b/src/pages/Plan/CreatePage.tsx index 602fb86..1ac4924 100644 --- a/src/pages/Plan/CreatePage.tsx +++ b/src/pages/Plan/CreatePage.tsx @@ -9,6 +9,7 @@ import SuiteTable from "@/pages/Plan/components/ContentTable/Suite.table" import TaskTable from "@/pages/Plan/components/ContentTable/Task.table" import { CustomForm } from "@/components/CustomStyled" import { usePlanProvider } from "./hooks" + /** * * 测试方案 diff --git a/src/pages/Plan/hooks.ts b/src/pages/Plan/hooks.ts index e842d11..4b53d1c 100644 --- a/src/pages/Plan/hooks.ts +++ b/src/pages/Plan/hooks.ts @@ -10,6 +10,5 @@ export const Provider = React.createContext( ) export const usePlanProvider = () => { - const provider = React.useContext(Provider) - return provider + return React.useContext(Provider) } \ No newline at end of file -- Gitee