Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove custom Accordion close button element #229

Merged
merged 4 commits into from
Jul 15, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

- USWDS is upgraded to the latest version, from v2.9.0 to v2.11.2.
- The bordered and large styles of checkboxes and radio buttons have updated guidance to improve compatibility with the [USWDS tile style](https://designsystem.digital.gov/components/radio-buttons/). The classes `usa-radio-bordered`, `usa-radio-large`, `usa-checkbox-bordered`, and `usa-checkbox-large` have been removed. Instead, add `usa-radio__input--bordered`, `usa-radio__input--tile`, `usa-checkbox__input-bordered`, `usa-checkbox__input--tile` respectively as modifiers to the element with the class `usa-radio__input` or `usa-checkbox__input`.
- The Accordion component no longer includes a "Close" button. Remove any instances of `<button class="usa-accordion__close-button">` in your project, or references to the `accordionCloseButton` exported member of the JavaScript package.

## 5.1.0

Expand Down
3 changes: 0 additions & 3 deletions docs/_components/accordions.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,6 @@ Before using an accordion, consider if their use would hinder usability. If ther
<div class="usa-accordion__content usa-prose">
<p>Follow this example! Mark the <code>.usa-accordion__button</code> with <code>aria-expanded="true"</code> to indicate that the content referenced with the ID listed in <code>aria-controls</code> is expanded by default, and omit the <code>hidden</code> attribute on the related <code>.usa-accordion__content</code>.</p>
</div>
<button class="usa-accordion__close-button">Close</button>
</div>

<h2 class="usa-accordion__heading">
Expand All @@ -32,7 +31,6 @@ Before using an accordion, consider if their use would hinder usability. If ther
<div class="usa-accordion__content usa-prose">
<p>Do not mark any attributes, other than linking a header and content body by <code>aria-controls="unique-id"</code> and <code>id="unique-id"</code>. This ensures the content is accessible should JavaScript fail to load.</p>
</div>
<button class="usa-accordion__close-button">Close</button>
</div>

<h2 class="usa-accordion__heading">
Expand All @@ -44,7 +42,6 @@ Before using an accordion, consider if their use would hinder usability. If ther
<div class="usa-accordion__content usa-prose">
<p>On the wrapping <code>.usa-accordion</code>, add the <code>aria-multiselectable="true"</code> attribute.</p>
</div>
<button class="usa-accordion__close-button">Close</button>
</div>
</div>
{% endcapture %}
Expand Down
5 changes: 0 additions & 5 deletions docs/_components/form-fields.md
Original file line number Diff line number Diff line change
Expand Up @@ -314,7 +314,6 @@ Follow the same pattern of applying `.usa-input--error` to the effected input an
{% endcapture %}
{% include helpers/code-example.html code=example %}
</div>
<button class="usa-accordion__close-button">Close</button>
</div>

<h3 class="usa-accordion__heading">
Expand Down Expand Up @@ -347,7 +346,6 @@ Follow the same pattern of applying `.usa-input--error` to the effected input an
{% endcapture %}
{% include helpers/code-example.html code=example %}
</div>
<button class="usa-accordion__close-button">Close</button>
</div>

<h3 class="usa-accordion__heading">
Expand All @@ -369,7 +367,6 @@ Follow the same pattern of applying `.usa-input--error` to the effected input an
{% endcapture %}
{% include helpers/code-example.html code=example %}
</div>
<button class="usa-accordion__close-button">Close</button>
</div>
</div>

Expand Down Expand Up @@ -407,7 +404,6 @@ For radio buttons and checkboxes, simply add an error message directly after the
{% endcapture %}
{% include helpers/code-example.html code=example %}
</div>
<button class="usa-accordion__close-button">Close</button>
</div>

<h3 class="usa-accordion__heading">
Expand Down Expand Up @@ -439,6 +435,5 @@ For radio buttons and checkboxes, simply add an error message directly after the
{% endcapture %}
{% include helpers/code-example.html code=example %}
</div>
<button class="usa-accordion__close-button">Close</button>
</div>
</div>
14 changes: 0 additions & 14 deletions src/js/components/accordionCloseButton.js

This file was deleted.

2 changes: 0 additions & 2 deletions src/js/components/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ import timePicker from 'uswds/src/js/components/time-picker';
import table from 'uswds/src/js/components/table';
import tooltip from 'uswds/src/js/components/tooltip';
import validator from 'uswds/src/js/components/validator';
import accordionCloseButton from './accordionCloseButton';

export {
accordion,
Expand All @@ -37,5 +36,4 @@ export {
table,
tooltip,
validator,
accordionCloseButton,
};
69 changes: 3 additions & 66 deletions src/scss/components/_accordions.scss
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
$border-width: 1px;
$icon-size: 1.5;

.usa-accordion__button {
@include u-border($border-width, 'primary-light');
@include u-border($theme-accordion-border-width, $theme-accordion-border-color);
@include u-radius('lg');
@include u-text('normal');
@include add-background-svg('minus');
Expand All @@ -26,72 +23,12 @@ $icon-size: 1.5;
}
}

.usa-accordion__close-button {
@extend .usa-accordion__button;
@include typeset($theme-accordion-font-family, $theme-body-font-size, 1);
background-image: none;
background-color: color('primary-lightest');
color: color('primary');
text-align: center;
padding: units(2) units(2.5);

&:hover {
background-color: color('primary-lighter');
color: color('primary');
}

&:active {
background-color: color('primary-light');
color: color('primary-dark');
}

&:before {
@include add-background-svg('angle-arrow-up');
background-position: center;
background-size: units($icon-size);
overflow: visible;
width: units($icon-size);
height: font-size($theme-accordion-font-family, $theme-body-font-size);
display: inline-block;
position: absolute;
margin-left: - units($icon-size) - units(1);
content: '';
}
}

.usa-accordion--bordered {
.usa-accordion__heading {
margin-block-end: 0;
}

.usa-accordion__button {
@include u-radius('lg');
background-color: transparent;
}

.usa-accordion__button[aria-expanded='true'] {
border-bottom-left-radius: 0;
border-bottom-right-radius: 0;
}

.usa-accordion__container {
@include u-border($border-width, 'primary-light');
@include u-radius('lg');
border-top-width: 0;
border-top-left-radius: 0;
border-top-right-radius: 0;
@include u-radius-bottom(0);
}

.usa-accordion__content {
border-width: 0;
}

.usa-accordion__close-button {
@include u-radius('lg');
background-color: color('primary-lightest');
font-weight: 400;
border-top-left-radius: 0;
border-top-right-radius: 0;
border-width: $border-width 0 0 0;
@include u-radius-bottom('lg');
}
}
2 changes: 2 additions & 0 deletions src/scss/uswds-theme/_components.scss
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ https://v2.designsystem.digital.gov/style-tokens
*/

// Accordion
$theme-accordion-border-width: '1px';
$theme-accordion-border-color: 'primary-light';
$theme-accordion-font-family: 'body';

// Alert
Expand Down
8 changes: 0 additions & 8 deletions test/components/accordions.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,11 +47,3 @@ test('clicking an open accordion title closes the accordion item', async () => {

await expectAccordionItem('unique-id-1', { hidden: true });
});

test('clicking an accordion close button closes the accordion item', async () => {
await expectAccordionItem('unique-id-1', { hidden: false });

await page.click('#unique-id-1 .usa-accordion__close-button');

await expectAccordionItem('unique-id-1', { hidden: true });
});