From 5834e5328b75d3e5355d0ac3a8b6b7cc511bd6d3 Mon Sep 17 00:00:00 2001 From: LuckyFBB <976060700@qq.com> Date: Wed, 12 Oct 2022 12:01:38 +0800 Subject: [PATCH 1/3] feat: add empty component --- src/components/empty/__tests__/empty.test.tsx | 37 ++++++++++++ src/components/empty/index.tsx | 20 +++++++ src/components/empty/style.scss | 9 +++ src/components/index.tsx | 1 + src/stories/empty.stories.tsx | 58 +++++++++++++++++++ src/styles/index.scss | 1 + 6 files changed, 126 insertions(+) create mode 100644 src/components/empty/__tests__/empty.test.tsx create mode 100644 src/components/empty/index.tsx create mode 100644 src/components/empty/style.scss create mode 100644 src/stories/empty.stories.tsx diff --git a/src/components/empty/__tests__/empty.test.tsx b/src/components/empty/__tests__/empty.test.tsx new file mode 100644 index 000000000..5597cee03 --- /dev/null +++ b/src/components/empty/__tests__/empty.test.tsx @@ -0,0 +1,37 @@ +import * as React from 'react'; +import { render } from '@testing-library/react'; +import '@testing-library/jest-dom/extend-expect'; + +import Empty, { DEFAULT_BASE64, GREY_BASE64 } from '../index'; + +describe('Empty', () => { + it('image size should change', () => { + const { container } = render(); + expect( + container.querySelector('.ant-empty-image')?.style.height + ).toBe('20px'); + }); + + it('description can be false', () => { + const { container } = render(); + expect(container.querySelector('.ant-empty-description')).toBeFalsy(); + }); + + it('render correct img for default type', () => { + const { container } = render(); + const srcValue = container.querySelector('img').getAttribute('src'); + expect(srcValue).toEqual(DEFAULT_BASE64); + }) + + it('render correct img for grey type', () => { + const { container } = render(); + const srcValue = container.querySelector('img').getAttribute('src'); + expect(srcValue).toEqual(GREY_BASE64); + }) + + it('render correct img when have image props', () => { + const { container } = render(); + const srcValue = container.querySelector('img').getAttribute('src'); + expect(srcValue).toEqual('public/iamges/drag-drawer-icon.png'); + }) +}); diff --git a/src/components/empty/index.tsx b/src/components/empty/index.tsx new file mode 100644 index 000000000..684c6762b --- /dev/null +++ b/src/components/empty/index.tsx @@ -0,0 +1,20 @@ +import React from 'react'; +import { Empty as AntdEmpty, EmptyProps } from 'antd'; + +interface IProps { + type?: 'default' | 'grey'; +} + +export const DEFAULT_BASE64 = + ''; +export const GREY_BASE64 = + ''; + +const Empty = (props: EmptyProps & IProps) => { + const { type = 'default', image, ...rest } = props; + let newImage: React.ReactNode = type === 'default' ? DEFAULT_BASE64 : GREY_BASE64; + if (image) newImage = image as React.ReactNode; + return ; +}; + +export default Empty; diff --git a/src/components/empty/style.scss b/src/components/empty/style.scss new file mode 100644 index 000000000..d8041450b --- /dev/null +++ b/src/components/empty/style.scss @@ -0,0 +1,9 @@ +.ant-empty { + .ant-empty-description { + color: #8b8fa8; + line-height: 20px; + font-size: 14px; + font-family: PingFangSC-Regular, 'PingFang SC'; + font-weight: 400; + } +} diff --git a/src/components/index.tsx b/src/components/index.tsx index 7e77a65a0..347ac9209 100644 --- a/src/components/index.tsx +++ b/src/components/index.tsx @@ -35,4 +35,5 @@ export { default as TableCell } from './tableCell'; export { default as TextMark } from './textMark'; export { default as ToolModal } from './toolModal'; export { default as ProgressLine } from './progressLine' +export { default as Empty } from './empty' diff --git a/src/stories/empty.stories.tsx b/src/stories/empty.stories.tsx new file mode 100644 index 000000000..e57fdd2e2 --- /dev/null +++ b/src/stories/empty.stories.tsx @@ -0,0 +1,58 @@ +import React from 'react' +import { storiesOf } from '@storybook/react'; +import { withKnobs } from '@storybook/addon-knobs'; +import { PropsTable } from './components/propsTable'; +import Empty from '../components/empty'; + +const stories = storiesOf('Empty 空状态', module); +stories.addDecorator(withKnobs) + +const propDefinitions = [{ + property: 'type', + propType: 'string', + required: false, + description: '默认展示图片的类型', + defaultValue: 'default' +}, { + property: 'image', + propType: 'React.Node', + required: false, + description: '自定义图片(设置该参数时,默认的图片不生效)', + defaultValue: '' +}, { + property: '其他参数', + propType: '', + required: false, + description: 继承antd4.x的Empty, + defaultValue: '' +}] + +stories.add('Empty 空状态', () => ( +
+

何时使用

+

{`当目前没有数据时,用于显式的用户提示。初始化场景时的引导创建流程`}

+

1、使用默认空状态

+ +

2、使用灰色空状态

+ +

3、使用自定义图片

+ +
+), { + info: { + text: ` + 代码示例: + ~~~js +

1、使用默认空状态

+ + +

2、使用灰色空状态

+ + +

3、使用自定义图片

+ + ~~~ + `, + TableComponent: () => PropsTable({ propDefinitions }) + } +}); diff --git a/src/styles/index.scss b/src/styles/index.scss index b3a45df9c..dbf526269 100644 --- a/src/styles/index.scss +++ b/src/styles/index.scss @@ -18,6 +18,7 @@ @import "../components/spreadSheet/style.scss"; @import "../components/toolModal/style.scss"; @import "../components/mxGraph/style.scss"; +@import "../components/empty/style.scss"; .sb-show-main{ #root>div:nth-child(3) { From 90370b796519599115e950ed8f2ce4595a3c3374 Mon Sep 17 00:00:00 2001 From: LuckyFBB <976060700@qq.com> Date: Wed, 12 Oct 2022 16:58:41 +0800 Subject: [PATCH 2/3] feat: update review comment --- .../__snapshots__/empty.test.tsx.snap | 98 +++++++++++++++++++ src/components/empty/__tests__/empty.test.tsx | 14 ++- src/components/empty/index.tsx | 4 +- src/components/empty/style.scss | 16 +-- src/stories/empty.stories.tsx | 32 +++++- 5 files changed, 148 insertions(+), 16 deletions(-) create mode 100644 src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap diff --git a/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap b/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap new file mode 100644 index 000000000..43fbd07ad --- /dev/null +++ b/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap @@ -0,0 +1,98 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Empty success render 1`] = ` +Object { + "asFragment": [Function], + "baseElement": +
+
+
+ No Data +
+
+ No Data +
+
+
+ , + "container":
+
+
+ No Data +
+
+ No Data +
+
+
, + "debug": [Function], + "findAllByAltText": [Function], + "findAllByDisplayValue": [Function], + "findAllByLabelText": [Function], + "findAllByPlaceholderText": [Function], + "findAllByRole": [Function], + "findAllByTestId": [Function], + "findAllByText": [Function], + "findAllByTitle": [Function], + "findByAltText": [Function], + "findByDisplayValue": [Function], + "findByLabelText": [Function], + "findByPlaceholderText": [Function], + "findByRole": [Function], + "findByTestId": [Function], + "findByText": [Function], + "findByTitle": [Function], + "getAllByAltText": [Function], + "getAllByDisplayValue": [Function], + "getAllByLabelText": [Function], + "getAllByPlaceholderText": [Function], + "getAllByRole": [Function], + "getAllByTestId": [Function], + "getAllByText": [Function], + "getAllByTitle": [Function], + "getByAltText": [Function], + "getByDisplayValue": [Function], + "getByLabelText": [Function], + "getByPlaceholderText": [Function], + "getByRole": [Function], + "getByTestId": [Function], + "getByText": [Function], + "getByTitle": [Function], + "queryAllByAltText": [Function], + "queryAllByDisplayValue": [Function], + "queryAllByLabelText": [Function], + "queryAllByPlaceholderText": [Function], + "queryAllByRole": [Function], + "queryAllByTestId": [Function], + "queryAllByText": [Function], + "queryAllByTitle": [Function], + "queryByAltText": [Function], + "queryByDisplayValue": [Function], + "queryByLabelText": [Function], + "queryByPlaceholderText": [Function], + "queryByRole": [Function], + "queryByTestId": [Function], + "queryByText": [Function], + "queryByTitle": [Function], + "rerender": [Function], + "unmount": [Function], +} +`; diff --git a/src/components/empty/__tests__/empty.test.tsx b/src/components/empty/__tests__/empty.test.tsx index 5597cee03..32589fc2a 100644 --- a/src/components/empty/__tests__/empty.test.tsx +++ b/src/components/empty/__tests__/empty.test.tsx @@ -5,31 +5,35 @@ import '@testing-library/jest-dom/extend-expect'; import Empty, { DEFAULT_BASE64, GREY_BASE64 } from '../index'; describe('Empty', () => { - it('image size should change', () => { + test('should support empty success render', () => { + const wrapper = render() + expect(wrapper).toMatchSnapshot(); + }) + it('should support empty image size should change', () => { const { container } = render(); expect( container.querySelector('.ant-empty-image')?.style.height ).toBe('20px'); }); - it('description can be false', () => { + it('should support empty description can be false', () => { const { container } = render(); expect(container.querySelector('.ant-empty-description')).toBeFalsy(); }); - it('render correct img for default type', () => { + it('should support empty render correct img for default type', () => { const { container } = render(); const srcValue = container.querySelector('img').getAttribute('src'); expect(srcValue).toEqual(DEFAULT_BASE64); }) - it('render correct img for grey type', () => { + it('should support empty render correct img for grey type', () => { const { container } = render(); const srcValue = container.querySelector('img').getAttribute('src'); expect(srcValue).toEqual(GREY_BASE64); }) - it('render correct img when have image props', () => { + it('should support empty render correct img when have image props', () => { const { container } = render(); const srcValue = container.querySelector('img').getAttribute('src'); expect(srcValue).toEqual('public/iamges/drag-drawer-icon.png'); diff --git a/src/components/empty/index.tsx b/src/components/empty/index.tsx index 684c6762b..9e992aa1d 100644 --- a/src/components/empty/index.tsx +++ b/src/components/empty/index.tsx @@ -14,7 +14,9 @@ const Empty = (props: EmptyProps & IProps) => { const { type = 'default', image, ...rest } = props; let newImage: React.ReactNode = type === 'default' ? DEFAULT_BASE64 : GREY_BASE64; if (image) newImage = image as React.ReactNode; - return ; + return
+ +
}; export default Empty; diff --git a/src/components/empty/style.scss b/src/components/empty/style.scss index d8041450b..df729b23b 100644 --- a/src/components/empty/style.scss +++ b/src/components/empty/style.scss @@ -1,9 +1,11 @@ -.ant-empty { - .ant-empty-description { - color: #8b8fa8; - line-height: 20px; - font-size: 14px; - font-family: PingFangSC-Regular, 'PingFang SC'; - font-weight: 400; +.dtc-empty{ + .ant-empty { + .ant-empty-description { + color: #8b8fa8; + line-height: 20px; + font-size: 14px; + font-family: PingFangSC-Regular, 'PingFang SC'; + font-weight: 400; + } } } diff --git a/src/stories/empty.stories.tsx b/src/stories/empty.stories.tsx index e57fdd2e2..348a1f3e6 100644 --- a/src/stories/empty.stories.tsx +++ b/src/stories/empty.stories.tsx @@ -2,6 +2,7 @@ import React from 'react' import { storiesOf } from '@storybook/react'; import { withKnobs } from '@storybook/addon-knobs'; import { PropsTable } from './components/propsTable'; +import ExampleContainer from './components/exampleCode'; import Empty from '../components/empty'; const stories = storiesOf('Empty 空状态', module); @@ -27,16 +28,38 @@ const propDefinitions = [{ defaultValue: '' }] +const otherDependencies = `import { Empty } from 'dt-react-component';` + +const basicFunctionCode = `` + +const basicEmpty = `` + +const basicGreyEmpty = `` + +const customizeImage = `` + +const moreSettingImage = `` + stories.add('Empty 空状态', () => (

何时使用

{`当目前没有数据时,用于显式的用户提示。初始化场景时的引导创建流程`}

1、使用默认空状态

- + + +

2、使用灰色空状态

- + + +

3、使用自定义图片

- + + + +

4、更多配置

+ + +
), { info: { @@ -51,6 +74,9 @@ stories.add('Empty 空状态', () => (

3、使用自定义图片

+ +

4、更多配置

+ ~~~ `, TableComponent: () => PropsTable({ propDefinitions }) From db3ce219066685dc44f7518212b385b8f59a1996 Mon Sep 17 00:00:00 2001 From: LuckyFBB <976060700@qq.com> Date: Wed, 12 Oct 2022 20:38:45 +0800 Subject: [PATCH 3/3] feat: update empty __snapshots__ --- .../__snapshots__/empty.test.tsx.snap | 48 +++++++++++-------- 1 file changed, 28 insertions(+), 20 deletions(-) diff --git a/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap b/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap index 43fbd07ad..6b1905439 100644 --- a/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap +++ b/src/components/empty/__tests__/__snapshots__/empty.test.tsx.snap @@ -1,10 +1,37 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Empty success render 1`] = ` +exports[`Empty should support empty success render 1`] = ` Object { "asFragment": [Function], "baseElement":
+
+
+
+ No Data +
+
+ No Data +
+
+
+
+ , + "container":
+
@@ -23,25 +50,6 @@ Object {
- , - "container":
-
-
- No Data -
-
- No Data -
-
, "debug": [Function], "findAllByAltText": [Function],