Skip to content

Commit

Permalink
Fix: apply destroyInactiveTabPane from the TabPane (#675)
Browse files Browse the repository at this point in the history
* apply destroyInactiveTabPane from the TabPane

* added TabPane `destroyInactiveTabPane` to readme

* fixing syntax error

* added unit test
  • Loading branch information
ChuckJonas authored Oct 16, 2023
1 parent 415ff34 commit 72ca369
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 14 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,7 @@ React.render(

| name | type | default | description |
| --- | --- | --- | --- |
| destroyInactiveTabPane | boolean | false | whether destroy inactive TabPane when change tab |
| key | string | - | corresponding to activeKey, should be unique |
| forceRender | boolean | false | forced render of content in tabs, not lazy render after clicking on tabs |
| tab | ReactNode | - | current tab's title corresponding to current tabPane |
Expand Down
4 changes: 2 additions & 2 deletions src/TabPanelList/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,15 @@ export default function TabPanelList({
})}
>
{tabs.map(
({ key, forceRender, style: paneStyle, className: paneClassName, ...restTabProps }) => {
({ key, forceRender, style: paneStyle, className: paneClassName, destroyInactiveTabPane: itemDestroyInactiveTabPane, ...restTabProps }) => {
const active = key === activeKey;

return (
<CSSMotion
key={key}
visible={active}
forceRender={forceRender}
removeOnLeave={!!destroyInactiveTabPane}
removeOnLeave={!!(destroyInactiveTabPane || itemDestroyInactiveTabPane)}
leavedClassName={`${tabPanePrefixCls}-hidden`}
{...animated.tabPaneMotion}
>
Expand Down
69 changes: 57 additions & 12 deletions tests/index.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -372,6 +372,42 @@ describe('Tabs.Basic', () => {
matchText('Bamboo');
});

it('destroyInactiveTabPane from TabPane', () => {
const props = {
activeKey: 'light',

items: [
{
key: 'light',
children: 'Light',
destroyInactiveTabPane: true,
},
{
key: 'bamboo',
children: 'Bamboo',
destroyInactiveTabPane: true,
},
] as any,
};

const { container, rerender } = render(getTabs(props));

function matchText(text: string) {
expect(container.querySelectorAll('.rc-tabs-tabpane')).toHaveLength(1);
expect(container.querySelector('.rc-tabs-tabpane-active').textContent).toEqual(text);
}

matchText('Light');

rerender(
getTabs({
...props,
activeKey: 'bamboo',
}),
);
matchText('Bamboo');
});

describe('editable', () => {
it('no and', () => {
const onEdit = jest.fn();
Expand Down Expand Up @@ -493,12 +529,21 @@ describe('Tabs.Basic', () => {

const removes = container.querySelectorAll('.rc-tabs-tab-remove');
expect(removes.length).toBe(2);
expect(container.querySelector('[data-node-key="light1"]').querySelector('.rc-tabs-tab-remove')).toBeFalsy();
expect(container.querySelector('[data-node-key="light2"]').querySelector('.rc-tabs-tab-remove')).toBeFalsy();
expect(container.querySelector('[data-node-key="light3"]').querySelector('.rc-tabs-tab-remove')).toBeTruthy();
expect(container.querySelector('[data-node-key="light4"]').querySelector('.rc-tabs-tab-remove')).toBeTruthy();
expect(container.querySelector('[data-node-key="light5"]').querySelector('.rc-tabs-tab-remove')).toBeFalsy();

expect(
container.querySelector('[data-node-key="light1"]').querySelector('.rc-tabs-tab-remove'),
).toBeFalsy();
expect(
container.querySelector('[data-node-key="light2"]').querySelector('.rc-tabs-tab-remove'),
).toBeFalsy();
expect(
container.querySelector('[data-node-key="light3"]').querySelector('.rc-tabs-tab-remove'),
).toBeTruthy();
expect(
container.querySelector('[data-node-key="light4"]').querySelector('.rc-tabs-tab-remove'),
).toBeTruthy();
expect(
container.querySelector('[data-node-key="light5"]').querySelector('.rc-tabs-tab-remove'),
).toBeFalsy();
});
});

Expand Down Expand Up @@ -577,20 +622,20 @@ describe('Tabs.Basic', () => {
});

it('key contains double quote should not crash', () => {
render(<Tabs items={[{key: '"key"', label: 'test'}]} />)
render(<Tabs items={[{ key: '"key"', label: 'test' }]} />);
});

it('key could be number', () => {
render(<Tabs items={[{key: 1 as any, label: 'test'}]} />)
})
render(<Tabs items={[{ key: 1 as any, label: 'test' }]} />);
});

it('support indicatorSize', async () => {
it('support indicatorSize', async () => {
const { container, rerender } = render(getTabs({ indicatorSize: 10 }));
await waitFakeTimer();
expect(container.querySelector('.rc-tabs-ink-bar')).toHaveStyle({ width: '10px' });

rerender(getTabs({ indicatorSize: (origin) => origin - 2 }));
rerender(getTabs({ indicatorSize: origin => origin - 2 }));
await waitFakeTimer();
expect(container.querySelector('.rc-tabs-ink-bar')).toHaveStyle({ width: '18px' });
})
});
});

1 comment on commit 72ca369

@vercel
Copy link

@vercel vercel bot commented on 72ca369 Oct 16, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Successfully deployed to the following URLs:

tabs – ./

tabs-react-component.vercel.app
tabs-git-master-react-component.vercel.app

Please sign in to comment.