Skip to content

Commit

Permalink
Remove support for for Breadcrumb, SubNav, TabNav, UnderlineNav (#3319)
Browse files Browse the repository at this point in the history
* Remove support for for Breadcrumb, SubNav, TabNav, UnderlineNav

* update snapshots after removing activeClassName test

* update docs to remove activeClassName instructions
  • Loading branch information
broccolinisoup authored Jun 5, 2023
1 parent d848aa5 commit 5d31e62
Show file tree
Hide file tree
Showing 15 changed files with 5 additions and 195 deletions.
5 changes: 5 additions & 0 deletions .changeset/popular-rivers-warn.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
'@primer/react': major
---

Remove support for `activeClassName` for Breadcrumb, SubNav, TabNav, UnderlineNav
5 changes: 0 additions & 5 deletions docs/content/Breadcrumbs.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -18,11 +18,6 @@ Breadcrumbs are used to show taxonomical context on pages that are many levels d
- Do not have a section-level navigation
- May need the ability to quickly go back to the previous (parent) page

To use Breadcrumbs with [react-router](https://github.com/ReactTraining/react-router) or
[react-router-dom](https://www.npmjs.com/package/react-router-dom), pass
`as={NavLink}` and omit the `selected` prop.
This ensures that the NavLink gets `activeClassName='selected'`

## Examples

```jsx live
Expand Down
7 changes: 0 additions & 7 deletions docs/content/SubNav.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,6 @@ status: Alpha

import data from '../../src/SubNav/SubNav.docs.json'

Use the SubNav component for navigation on a dashboard-type interface with another set of navigation components above it. This helps distinguish navigation hierarchy.

To use SubNav with [react-router](https://github.com/ReactTraining/react-router) or
[react-router-dom](https://www.npmjs.com/package/react-router-dom), pass
`as={NavLink}` and omit the `selected` prop.
This ensures that the NavLink gets `activeClassName='selected'`

**Attention:** Make sure to properly label your `SubNav` with an `aria-label` to provide context about the type of navigation contained in `SubNav`.

## Examples
Expand Down
5 changes: 0 additions & 5 deletions docs/content/TabNav.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,6 @@ status: Alpha

import data from '../../src/TabNav/TabNav.docs.json'

To use TabNav with [react-router](https://github.com/ReactTraining/react-router) or
[react-router-dom](https://www.npmjs.com/package/react-router-dom), pass
`as={NavLink}` and omit the `selected` prop.
This ensures that the NavLink gets `activeClassName='selected'`

**Attention:** Make sure to properly label your `TabNav` with an `aria-label` to provide context about the type of navigation contained in `TabNav`.

## Examples
Expand Down
5 changes: 0 additions & 5 deletions docs/content/UnderlineNav.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -12,11 +12,6 @@ Use the UnderlineNav component to style navigation with a minimal underlined sel

UnderlineNav is deprecated and will be replaced by the draft `UnderlineNav` in the next major release. See [the draft UnderlineNav's docs](/drafts/UnderlineNav2) for more details.

To use UnderlineNav with [react-router](https://github.com/ReactTraining/react-router) or
[react-router-dom](https://www.npmjs.com/package/react-router-dom), pass
`as={NavLink}` and omit the `selected` prop.
This ensures that the NavLink gets `activeClassName='selected'`

**Attention:** Make sure to properly label your `UnderlineNav` with an `aria-label` to provide context about the type of navigation contained in `UnderlineNav`.

## Examples
Expand Down
1 change: 0 additions & 1 deletion src/Breadcrumbs/Breadcrumbs.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,6 @@ type StyledBreadcrumbsItemProps = {
} & SxProp

const BreadcrumbsItem = styled.a.attrs<StyledBreadcrumbsItemProps>(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : undefined,
className: classnames(props.selected && SELECTED_CLASS, props.className),
'aria-current': props.selected ? 'page' : null,
}))<StyledBreadcrumbsItemProps>`
Expand Down
5 changes: 0 additions & 5 deletions src/Breadcrumbs/__tests__/BreadcrumbsItem.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,9 +20,4 @@ describe('Breadcrumbs.Item', () => {
it('respects the "selected" prop', () => {
expect(render(<Breadcrumbs.Item selected />)).toMatchSnapshot()
})

it('adds activeClassName={SELECTED_CLASS} when it gets a "to" prop', () => {
const Link = ({theme: _ignoredTheme, ...props}: Record<string, unknown>) => <div {...props} />
expect(render(<Breadcrumbs.Item as={Link} to="#" />)).toMatchSnapshot()
})
})
Original file line number Diff line number Diff line change
@@ -1,32 +1,5 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`Breadcrumbs.Item adds activeClassName={SELECTED_CLASS} when it gets a "to" prop 1`] = `
.c0 {
color: #0969da;
display: inline-block;
font-size: 14px;
-webkit-text-decoration: none;
text-decoration: none;
}
.c0:hover {
-webkit-text-decoration: underline;
text-decoration: underline;
}
.c0.selected {
color: #1F2328;
pointer-events: none;
}
<div
activeClassName="selected"
aria-current={null}
className="c0"
to="#"
/>
`;

exports[`Breadcrumbs.Item renders consistently 1`] = `
.c0 {
color: #0969da;
Expand Down
1 change: 0 additions & 1 deletion src/SubNav/SubNav.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -63,7 +63,6 @@ type StyledSubNavLinkProps = {
} & SxProp

const SubNavLink = styled.a.attrs<StyledSubNavLinkProps>(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : undefined,
className: classnames(ITEM_CLASS, props.selected && SELECTED_CLASS, props.className),
}))<StyledSubNavLinkProps>`
padding-left: ${get('space.3')};
Expand Down
1 change: 0 additions & 1 deletion src/TabNav/TabNav.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,6 @@ export type TabNavLinkProps = React.DetailedHTMLProps<React.HTMLAttributes<HTMLA
} & SxProp

const TabNavLink = styled.a.attrs<TabNavLinkProps>(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : undefined,
className: classnames(ITEM_CLASS, props.selected && SELECTED_CLASS, props.className),
role: 'tab',
'aria-selected': !!props.selected,
Expand Down
1 change: 0 additions & 1 deletion src/UnderlineNav/UnderlineNav.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,6 @@ type StyledUnderlineNavLinkProps = {
} & SxProp

const UnderlineNavLink = styled.a.attrs<StyledUnderlineNavLinkProps>(props => ({
activeClassName: typeof props.to === 'string' ? 'selected' : undefined,
className: classnames(ITEM_CLASS, props.selected && SELECTED_CLASS, props.className),
}))<StyledUnderlineNavLinkProps>`
padding: ${get('space.3')} ${get('space.2')};
Expand Down
5 changes: 0 additions & 5 deletions src/__tests__/SubNavLink.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,4 @@ describe('SubNav.Link', () => {
it('respects the "selected" prop', () => {
expect(render(<SubNav.Link selected />)).toMatchSnapshot()
})

it('adds activeClassName={SELECTED_CLASS} when it gets a "to" prop', () => {
const Link = ({theme: _ignoredTheme, ...props}: Record<string, unknown>) => <div {...props} />
expect(render(<SubNav.Link as={Link} to="#" />)).toMatchSnapshot()
})
})
5 changes: 0 additions & 5 deletions src/__tests__/UnderlineNavLink.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -22,9 +22,4 @@ describe('UnderlineNav.Link', () => {
it('respects the "selected" prop', () => {
expect(render(<UnderlineNav.Link selected />)).toMatchSnapshot()
})

it('adds activeClassName={SELECTED_CLASS} when it gets a "to" prop', () => {
const Link = ({theme: _ignoredTheme, ...props}: Record<string, unknown>) => <div {...props} />
expect(render(<UnderlineNav.Link as={Link} to="#" />)).toMatchSnapshot()
})
})
67 changes: 0 additions & 67 deletions src/__tests__/__snapshots__/SubNavLink.test.tsx.snap
Original file line number Diff line number Diff line change
@@ -1,72 +1,5 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`SubNav.Link adds activeClassName={SELECTED_CLASS} when it gets a "to" prop 1`] = `
.c0 {
padding-left: 16px;
padding-right: 16px;
font-weight: 500;
font-size: 14px;
line-height: 20px;
min-height: 34px;
color: #1F2328;
text-align: center;
-webkit-text-decoration: none;
text-decoration: none;
border-top: 1px solid #d0d7de;
border-bottom: 1px solid #d0d7de;
border-right: 1px solid #d0d7de;
display: -webkit-box;
display: -webkit-flex;
display: -ms-flexbox;
display: flex;
-webkit-align-items: center;
-webkit-box-align: center;
-ms-flex-align: center;
align-items: center;
}
.c0:first-of-type {
border-top-left-radius: 6px;
border-bottom-left-radius: 6px;
border-left: 1px solid #d0d7de;
}
.c0:last-of-type {
border-top-right-radius: 6px;
border-bottom-right-radius: 6px;
}
.c0:hover,
.c0:focus {
-webkit-text-decoration: none;
text-decoration: none;
background-color: #f6f8fa;
-webkit-transition: background-color 0.2s ease;
transition: background-color 0.2s ease;
}
.c0:hover .SubNav-octicon,
.c0:focus .SubNav-octicon {
color: #656d76;
}
.c0.selected {
color: #ffffff;
background-color: #0969da;
border-color: #0969da;
}
.c0.selected .SubNav-octicon {
color: #ffffff;
}
<div
activeClassName="selected"
className="c0 SubNav-item"
to="#"
/>
`;

exports[`SubNav.Link renders consistently 1`] = `
.c0 {
padding-left: 16px;
Expand Down
60 changes: 0 additions & 60 deletions src/__tests__/__snapshots__/UnderlineNavLink.test.tsx.snap
Original file line number Diff line number Diff line change
@@ -1,65 +1,5 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP

exports[`UnderlineNav.Link adds activeClassName={SELECTED_CLASS} when it gets a "to" prop 1`] = `
.c0 {
padding: 16px 8px;
margin-right: 16px;
font-size: 14px;
line-height: 1.5;
color: #1F2328;
text-align: center;
border-bottom: 2px solid transparent;
-webkit-text-decoration: none;
text-decoration: none;
}
.c0:hover,
.c0:focus {
color: #1F2328;
-webkit-text-decoration: none;
text-decoration: none;
border-bottom-color: rgba(175,184,193,0.2);
-webkit-transition: border-bottom-color 0.2s ease;
transition: border-bottom-color 0.2s ease;
}
.c0:hover .PRC-UnderlineNav-octicon,
.c0:focus .PRC-UnderlineNav-octicon {
color: #656d76;
}
.c0.PRC-selected {
color: #1F2328;
border-bottom-color: #fd8c73;
}
.c0.PRC-selected .PRC-UnderlineNav-octicon {
color: #1F2328;
}
.c0:focus:not(:disabled) {
box-shadow: none;
outline: 2px solid #0969da;
outline-offset: -8px;
}
.c0:focus:not(:disabled):not(:focus-visible) {
outline: solid 1px transparent;
}
.c0:focus-visible:not(:disabled) {
box-shadow: none;
outline: 2px solid #0969da;
outline-offset: -8px;
}
<div
activeClassName="selected"
className="c0 PRC-UnderlineNav-item"
to="#"
/>
`;

exports[`UnderlineNav.Link renders consistently 1`] = `
.c0 {
padding: 16px 8px;
Expand Down

0 comments on commit 5d31e62

Please sign in to comment.