Skip to content

Commit 1c86c43

Browse files
authored
fix(drawer): use percent width (#539)
1 parent 758d56f commit 1c86c43

File tree

3 files changed

+21
-15
lines changed

3 files changed

+21
-15
lines changed

src/drawer/__tests/__snapshots__/index.test.tsx.snap

+1-1
Original file line numberDiff line numberDiff line change
@@ -18,7 +18,7 @@ exports[`test Drawer snapshot match 1`] = `
1818
/>
1919
<div
2020
class="dtc-drawer-content-wrapper"
21-
style="width: 1000px;"
21+
style="width: 69.44444444444444%;"
2222
>
2323
<div
2424
aria-modal="true"

src/drawer/__tests/index.test.tsx

+1-1
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ describe('test Drawer ', () => {
6262
</Drawer>
6363
);
6464
expect(document.querySelector('.dtc-drawer-content-wrapper')).toHaveStyle({
65-
width: '1256px',
65+
width: `${(1256 / 1440) * 100}%`,
6666
});
6767
});
6868
test('should render className/style correct', () => {

src/drawer/index.tsx

+19-13
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,12 @@ export enum DrawerType {
2222
Normal = 'normal',
2323
}
2424

25+
enum DrawerSize {
26+
Small = 720,
27+
Default = 1000,
28+
Large = 1256,
29+
}
30+
2531
interface BaseDrawerProps extends Omit<AntdDrawerProps, 'placement' | 'children'> {
2632
size?: 'small' | 'default' | 'large';
2733
loading?: boolean;
@@ -56,9 +62,9 @@ function isControlled<T extends readOnlyTab>(props: DrawerProps<T>): props is Dr
5662
}
5763

5864
const getWidthFromSize = (size: DrawerProps['size']) => {
59-
if (size === 'small') return 720;
60-
if (size === 'large') return 1256;
61-
return 1000;
65+
if (size === 'small') return `${(DrawerSize.Small / 1440) * 100}%`;
66+
if (size === 'large') return `${(DrawerSize.Large / 1440) * 100}%`;
67+
return `${(DrawerSize.Default / 1440) * 100}%`;
6268
};
6369

6470
const isValidBanner = (banner: DrawerProps['banner']): banner is AlertProps['message'] => {
@@ -67,7 +73,7 @@ const isValidBanner = (banner: DrawerProps['banner']): banner is AlertProps['mes
6773
};
6874

6975
const Drawer = <T extends readOnlyTab>(props: DrawerProps<T>) => {
70-
const slidePrefixCls = 'dtc-drawer';
76+
const drawerPrefixCls = 'dtc-drawer';
7177

7278
const {
7379
open,
@@ -89,7 +95,7 @@ const Drawer = <T extends readOnlyTab>(props: DrawerProps<T>) => {
8995
const finalWidth = width ?? getWidthFromSize(size);
9096
const isFormType = type === DrawerType.Form;
9197

92-
const [internalTabKey, setInternalTabKey] = useState('');
98+
const [internalTabKey, setInternalTabKey] = useState<TabKey<T>>('');
9399

94100
useEffect(() => {
95101
open &&
@@ -102,7 +108,7 @@ const Drawer = <T extends readOnlyTab>(props: DrawerProps<T>) => {
102108
const renderButton = () => {
103109
return (
104110
<img
105-
className={`${slidePrefixCls}-icon`}
111+
className={`${drawerPrefixCls}-icon`}
106112
onClick={onClose}
107113
src=""
108114
alt="closeBtn"
@@ -122,19 +128,19 @@ const Drawer = <T extends readOnlyTab>(props: DrawerProps<T>) => {
122128
mask={isFormType ? true : mask}
123129
maskClosable={isFormType ? false : maskClosable}
124130
width={finalWidth}
125-
prefixCls={slidePrefixCls}
131+
prefixCls={drawerPrefixCls}
126132
onClose={onClose}
127133
{...rest}
128134
{...motionProps}
129135
>
130136
{!isFormType && renderButton()}
131-
<Spin wrapperClassName={`${slidePrefixCls}-nested-loading`} spinning={loading}>
137+
<Spin wrapperClassName={`${drawerPrefixCls}-nested-loading`} spinning={loading}>
132138
{title && (
133-
<div className={`${slidePrefixCls}-header`}>
139+
<div className={`${drawerPrefixCls}-header`}>
134140
{title}
135141
{isFormType && (
136142
<CloseOutlined
137-
className={`${slidePrefixCls}-header--icon`}
143+
className={`${drawerPrefixCls}-header--icon`}
138144
onClick={onClose}
139145
/>
140146
)}
@@ -152,23 +158,23 @@ const Drawer = <T extends readOnlyTab>(props: DrawerProps<T>) => {
152158
destroyInactiveTabPane
153159
activeKey={currentKey}
154160
onChange={handleChangeKey}
155-
className={`${slidePrefixCls}-tabs`}
161+
className={`${drawerPrefixCls}-tabs`}
156162
>
157163
{props.tabs?.map((tab: { key: string; title: React.ReactNode }) => (
158164
<Tabs.TabPane tab={tab.title} key={tab.key} />
159165
))}
160166
</Tabs>
161167
)}
162168
<div
163-
className={classNames(`${slidePrefixCls}-body`, bodyClassName)}
169+
className={classNames(`${drawerPrefixCls}-body`, bodyClassName)}
164170
style={bodyStyle}
165171
>
166172
{isFunction(props)
167173
? props.children?.(currentKey ?? '')
168174
: (props.children as React.ReactNode)}
169175
</div>
170176
{footer ? (
171-
<div className={classNames(`${slidePrefixCls}-footer`)}>{footer}</div>
177+
<div className={classNames(`${drawerPrefixCls}-footer`)}>{footer}</div>
172178
) : null}
173179
</Spin>
174180
</RcDrawer>

0 commit comments

Comments
 (0)