-
Notifications
You must be signed in to change notification settings - Fork 353
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(Page): updated logic to allow section grouping (#10650)
* feat(Page): updated logic to allow section grouping * Updated and added unit tests * Added snapshot test * Removed PageNavigation component * PR feedback * Rebased, updated yarn lock * Updated snapshots * Renamed test file * Updated logic to always render PageBody for page nav * Updated tests
- Loading branch information
1 parent
38f193a
commit b9181ae
Showing
21 changed files
with
1,247 additions
and
12,616 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
import * as React from 'react'; | ||
import styles from '@patternfly/react-styles/css/components/Page/page'; | ||
import { css } from '@patternfly/react-styles'; | ||
|
||
export interface PageBodyProps extends React.HTMLProps<HTMLDivElement> { | ||
/** Content rendered inside the section */ | ||
children?: React.ReactNode; | ||
/** Additional classes added to the section */ | ||
className?: string; | ||
} | ||
|
||
export const PageBody: React.FunctionComponent<PageBodyProps> = ({ className, children, ...props }: PageBodyProps) => ( | ||
<div {...props} className={css(styles.pageMainBody, className)}> | ||
{children} | ||
</div> | ||
); | ||
|
||
PageBody.displayName = 'PageBody'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
72 changes: 0 additions & 72 deletions
72
packages/react-core/src/components/Page/PageNavigation.tsx
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
34 changes: 34 additions & 0 deletions
34
packages/react-core/src/components/Page/__tests__/PageBody.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import * as React from 'react'; | ||
import { render, screen } from '@testing-library/react'; | ||
import { PageBody } from '../PageBody'; | ||
import styles from '@patternfly/react-styles/css/components/Page/page'; | ||
|
||
test('Renders without children', () => { | ||
render(<PageBody data-testid="page-main-body" />); | ||
|
||
expect(screen.getByTestId('page-main-body')).toBeVisible(); | ||
}); | ||
test('Renders children', () => { | ||
render(<PageBody>Test</PageBody>); | ||
|
||
expect(screen.getByText('Test')).toBeVisible(); | ||
}); | ||
test(`Renders with class ${styles.pageMainBody} by default`, () => { | ||
render(<PageBody>Test</PageBody>); | ||
|
||
expect(screen.getByText('Test')).toHaveClass(styles.pageMainBody); | ||
}); | ||
test(`Renders with custom classes when className is passed`, () => { | ||
render(<PageBody className="custom-class">Test</PageBody>); | ||
|
||
expect(screen.getByText('Test')).toHaveClass('custom-class'); | ||
}); | ||
test(`Renders with spread props`, () => { | ||
render(<PageBody id="custom-id">Test</PageBody>); | ||
|
||
expect(screen.getByText('Test')).toHaveAttribute('id', 'custom-id'); | ||
}); | ||
test('Matches snapshot', () => { | ||
const { asFragment } = render(<PageBody>Test</PageBody>); | ||
expect(asFragment()).toMatchSnapshot(); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.