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

[Button.js] Update API for HTML standard, simplify attribute naming, & migrate to named slots #217

Merged
merged 56 commits into from
Aug 29, 2024
Merged
Show file tree
Hide file tree
Changes from 52 commits
Commits
Show all changes
56 commits
Select commit Hold shift + click to select a range
41bd315
Removed some data- from attributes
sreidthomas May 20, 2024
e64d7f3
Removed data- from id and aria-label
sreidthomas May 21, 2024
0df3143
Updated several custom attributes removing data-
sreidthomas May 21, 2024
c2a9e20
Updated data-disable to disabled
sreidthomas May 21, 2024
8e5ec8b
Updated attributes in stories.js file
sreidthomas May 21, 2024
04f101e
Changed attributes for cod-icon back to the original
sreidthomas Jul 12, 2024
5d38f3a
Updated attributes in Basic example
sreidthomas Jul 15, 2024
b4d4094
Updated attributes in variations example
sreidthomas Jul 15, 2024
b27ceb8
Updated attributes in Split example
sreidthomas Jul 15, 2024
67fb47f
Updated extra-classes attribute in Basic, Variations and Split examples
sreidthomas Jul 15, 2024
daa5871
Updated attributes in DarkMode example
sreidthomas Jul 15, 2024
8dbc376
Updated attributes in Basic example
sreidthomas Jul 15, 2024
b913c18
Updated attributes in Brand example
sreidthomas Jul 15, 2024
b1fe835
Updated attributes in Offcanvas example
sreidthomas Jul 15, 2024
b039fa6
Updated attributes in OffcanvasResponsive example
sreidthomas Jul 15, 2024
4972f93
Updated attributes in OffcanvasColor example
sreidthomas Jul 15, 2024
b30fd0a
Updated attributes in cod-button for Form Template
sreidthomas Jul 15, 2024
75a844f
Updated attributes in Basic example
sreidthomas Jul 15, 2024
8fc99b4
Updated attributes in TabsDropdown example
sreidthomas Jul 15, 2024
b893a81
Updated attributes in PillsDropdowns example
sreidthomas Jul 15, 2024
6b10e19
Updated attributes for Basic examples
sreidthomas Jul 15, 2024
b02eb59
Updated attributes in Mixed example
sreidthomas Jul 15, 2024
89c004a
Updated attributes in Outline example
sreidthomas Jul 15, 2024
7c1ab80
Updated attributes in CheckboxButtonGroup
sreidthomas Jul 15, 2024
87af4cb
Updated attributes in ButtonToolbar
sreidthomas Jul 15, 2024
042b530
Updated attributes in Vertical example
sreidthomas Jul 15, 2024
51c401c
Updated boolean variables in file
sreidthomas Jul 19, 2024
e35699f
Updated boolean attributes in file
sreidthomas Jul 19, 2024
6a78578
Updated boolean attributes in file
sreidthomas Jul 19, 2024
a112f31
Updated boolean attributes in file
sreidthomas Jul 19, 2024
54688fe
Updated boolean attributes in file
sreidthomas Jul 19, 2024
dbec14b
Updated boolean attributes in file
sreidthomas Jul 19, 2024
d2fb64f
Removed empty and undefined attributes from file
sreidthomas Jul 19, 2024
7bb000b
Removed empty and undefined attributes from file
sreidthomas Jul 19, 2024
e7462ca
Removed empty and undefined attributes from file
sreidthomas Jul 19, 2024
d1075cb
Removed empty and undefined attributes from file
sreidthomas Jul 19, 2024
ff1a06b
Removed empty and undefined attributes in file
sreidthomas Jul 19, 2024
fb5978e
Removed empty and undefined attributes in file
sreidthomas Jul 19, 2024
e721dc4
Fixed prettier issues in 1 file
sreidthomas Jul 19, 2024
48adb8d
Changed close, primary and disableStatus to hasAttribute
sreidthomas Aug 2, 2024
8aecc85
Updated primary logic to not include true/false
sreidthomas Aug 2, 2024
7db74a7
Updated close logic and removed ternary
sreidthomas Aug 2, 2024
a390d1f
Fixed attribute in card.stories.js
sreidthomas Aug 26, 2024
2bb7ad3
Fixed attribute in buttongroup.stories.js file
sreidthomas Aug 26, 2024
8cf9dad
Updated attributes in Alert.js file
sreidthomas Aug 26, 2024
8cbbad8
Updated attributes in ModalFooter.js
sreidthomas Aug 26, 2024
8883951
Updated attributes in Map.js file
sreidthomas Aug 26, 2024
a133e0f
Updated attributes in OffcanvasHeader.js
sreidthomas Aug 26, 2024
e967a55
Updated attributes in ModalHeader.js
sreidthomas Aug 26, 2024
9ab6e2e
Changed attributes in Alert.js back to normal
sreidthomas Aug 27, 2024
0184e92
Fixed attributes in buttongroup.stories.js file
sreidthomas Aug 27, 2024
6914ffe
Fixed attributes in ModalFooter.js file
sreidthomas Aug 27, 2024
a29334e
Added data back to bs-dimsmis
sreidthomas Aug 27, 2024
412bf1c
fixed extra classes attribute in ModalHeader.js file
sreidthomas Aug 27, 2024
f7fc672
Added data back to bs-dismiss attribute
sreidthomas Aug 27, 2024
aa52347
Fixed data-extra-classes attribute in OffcanvasHeader.js file
sreidthomas Aug 27, 2024
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
42 changes: 22 additions & 20 deletions src/components/atoms/Button/Button.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,23 +12,23 @@ export default class Button extends HTMLElement {

connectedCallback() {
// Button attributes
const close = this.getAttribute('data-close');
const link = this.getAttribute('data-link');
const btnID = this.getAttribute('data-id');
const ariaLabel = this.getAttribute('data-aria-label');
const primary = this.getAttribute('data-primary');
const backgroundColor = this.getAttribute('data-background-color');
const shape = this.getAttribute('data-shape');
const icon = this.getAttribute('data-icon');
const iconSize = this.getAttribute('data-icon-size');
const iconOrder = this.getAttribute('data-icon-order');
const hiddenLabel = this.getAttribute('data-hidden-label');
const imgSrc = this.getAttribute('data-img');
const imgAlt = this.getAttribute('data-img-alt');
const size = this.getAttribute('data-size');
const extraClasses = this.getAttribute('data-extra-classes');
const label = this.getAttribute('data-label');
const disableStatus = this.getAttribute('data-disable');
const close = this.hasAttribute('close');
const link = this.getAttribute('link');
const btnID = this.getAttribute('id');
const ariaLabel = this.getAttribute('aria-label');
const primary = this.hasAttribute('primary');
const backgroundColor = this.getAttribute('background-color');
const shape = this.getAttribute('shape');
const icon = this.getAttribute('icon');
const iconSize = this.getAttribute('icon-size');
const iconOrder = this.getAttribute('icon-order');
const hiddenLabel = this.getAttribute('hidden-label');
const imgSrc = this.getAttribute('img');
const imgAlt = this.getAttribute('img-alt');
const size = this.getAttribute('size');
const extraClasses = this.getAttribute('extra-classes');
const label = this.getAttribute('label');
const disableStatus = this.hasAttribute('disabled');
// Building Button component
const btn = document.createElement('button');
const btnClasses = ['btn'];
Expand All @@ -38,9 +38,9 @@ export default class Button extends HTMLElement {
}
disableStatus === 'true' ? (btn.disabled = true) : (btn.disabled = false);
btn.setAttribute('aria-label', `${ariaLabel || ''}`);
if (primary === 'true') {
if (primary) {
btnClasses.push(`btn-${backgroundColor}`);
} else if (primary === 'false') {
} else {
btnClasses.push(`btn-outline-${backgroundColor}`);
}
shape === 'square'
Expand All @@ -51,7 +51,9 @@ export default class Button extends HTMLElement {
imgAlt
? btnClasses.push('cod-button--img')
: btnClasses.push('cod-button--not-img');
close === 'true' ? btnClasses.push('btn-close') : 0;
if (close) {
btnClasses.push('btn-close');
}
btn.className = btnClasses.join(' ');

if (icon) {
Expand Down
6 changes: 3 additions & 3 deletions src/components/atoms/ModalFooter/ModalFooter.js
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,9 @@ export default class ModalFooter extends HTMLElement {
const extraClasses = this.getAttribute('data-extra-classes');

const modalFooterClasses = ['modal-footer'];
this.closeBtn.setAttribute('data-img-alt', '');
this.closeBtn.setAttribute('data-icon', '');
this.closeBtn.setAttribute('data-label', 'Close');
this.closeBtn.setAttribute('img-alt', '');
this.closeBtn.setAttribute('icon', '');
this.closeBtn.setAttribute('label', 'Close');
this.closeBtn.setAttribute('data-bs-dismiss', 'modal');

// TODO: Fix old ESLint errors - see issue #1099
Expand Down
12 changes: 6 additions & 6 deletions src/components/atoms/ModalHeader/ModalHeader.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,15 +47,15 @@ export default class ModalHeader extends HTMLElement {

const btnDark = this.getAttribute('data-button-dark');

const extraClasses = this.getAttribute('data-extra-classes');
const extraClasses = this.getAttribute('extra-classes');
sreidthomas marked this conversation as resolved.
Show resolved Hide resolved

const modalHeaderClasses = ['modal-header'];
this.modalTitle.className = 'modal-title';
this.modalTitle.id = `${parentID}-label`;
this.closeBtn.setAttribute('data-img-alt', '');
this.closeBtn.setAttribute('data-icon', '');
this.closeBtn.setAttribute('data-close', 'true');
this.closeBtn.setAttribute('data-bs-dismiss', 'modal');
this.closeBtn.setAttribute('img-alt', '');
this.closeBtn.setAttribute('icon', '');
this.closeBtn.setAttribute('close', 'true');
this.closeBtn.setAttribute('bs-dismiss', 'modal');

// TODO: Fix old ESLint errors - see issue #1099
// eslint-disable-next-line eqeqeq
Expand All @@ -66,7 +66,7 @@ export default class ModalHeader extends HTMLElement {
// TODO: Fix old ESLint errors - see issue #1099
// eslint-disable-next-line eqeqeq
btnDark == 'true'
? this.closeBtn.setAttribute('data-extra-classes', 'btn-close-white')
? this.closeBtn.setAttribute('extra-classes', 'btn-close-white')
: 0;
this.modalHeader.className = modalHeaderClasses.join(' ');
this.closeBtn.addEventListener('click', this._onClick);
Expand Down
10 changes: 5 additions & 5 deletions src/components/atoms/OffcanvasHeader/OffcanvasHeader.js
Original file line number Diff line number Diff line change
Expand Up @@ -47,13 +47,13 @@ export default class OffcanvasHeader extends HTMLElement {
const offcanvasHeaderClasses = ['offcanvas-header'];
this.offcanvasTitle.className = 'offcanvas-title';
this.offcanvasTitle.id = `${parentID}-label`;
this.closeBtn.setAttribute('data-img-alt', '');
this.closeBtn.setAttribute('data-icon', '');
this.closeBtn.setAttribute('data-close', 'true');
this.closeBtn.setAttribute('data-bs-dismiss', parentID);
this.closeBtn.setAttribute('img-alt', '');
this.closeBtn.setAttribute('icon', '');
this.closeBtn.setAttribute('close', 'true');
this.closeBtn.setAttribute('bs-dismiss', parentID);
sreidthomas marked this conversation as resolved.
Show resolved Hide resolved
extraClasses ? offcanvasHeaderClasses.push(extraClasses) : 0;
btnDark === 'true'
? this.closeBtn.setAttribute('data-extra-classes', 'btn-close-white')
? this.closeBtn.setAttribute('extra-classes', 'btn-close-white')
: 0;
const expand = this.getAttribute('data-expand');
if (expand) {
Expand Down
18 changes: 9 additions & 9 deletions src/components/organisms/Map/Map.js
Original file line number Diff line number Diff line change
Expand Up @@ -214,16 +214,16 @@ export default class Map extends HTMLElement {
closeMapBtn.addEventListener('click', () => {
app[0] ? app[0].setAttribute('data-app-state', 'results') : 0;
});
closeMapBtn.setAttribute('data-primary', true);
closeMapBtn.setAttribute('data-label', 'x');
closeMapBtn.setAttribute('data-size', 'large');
closeMapBtn.setAttribute('primary', true);
closeMapBtn.setAttribute('label', 'x');
closeMapBtn.setAttribute('size', 'large');
closeMapBtn.setAttribute('data-hover', false);
sreidthomas marked this conversation as resolved.
Show resolved Hide resolved
closeMapBtn.setAttribute('data-background-color', 'warning');
closeMapBtn.setAttribute('data-img', '');
closeMapBtn.setAttribute('data-img-alt', '');
closeMapBtn.setAttribute('data-icon', '');
closeMapBtn.setAttribute('data-shape', 'square');
closeMapBtn.setAttribute('data-extra-classes', 'fw-bold');
closeMapBtn.setAttribute('background-color', 'warning');
closeMapBtn.setAttribute('img', '');
closeMapBtn.setAttribute('img-alt', '');
closeMapBtn.setAttribute('icon', '');
closeMapBtn.setAttribute('shape', 'square');
closeMapBtn.setAttribute('extra-classes', 'fw-bold');
this.mapWrapper.appendChild(closeMapBtn);
app[0] ? app[0].setAttribute('data-map-state', 'init') : 0;
break;
Expand Down
38 changes: 19 additions & 19 deletions src/stories/button.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ export default {
primary: {
control: { type: 'boolean' },
},
disable: COMMON_STORY_ARGS.disabled,
disabled: COMMON_STORY_ARGS.disabled,
// TODO: Make this attr name and accepted
// values consistent with other action button, progress bar,
// etc. Issue #202.
Expand All @@ -35,36 +35,36 @@ const Template = (args) => {
btn.addEventListener('click', (e) => {
args.onclick(e);
});
btn.setAttribute('data-primary', args.primary);
btn.setAttribute('data-disable', args.disable);
btn.setAttribute('data-label', args.label);
btn.setAttribute('data-img', args.img ? args.img : '');
btn.setAttribute('data-img-alt', args.imgAlt ? args.imgAlt : '');
btn.setAttribute('data-icon', args.icon ? args.icon : '');
btn.setAttribute('data-icon-order', args.iconOrder ? args.iconOrder : '');
btn.setAttribute('data-icon-size', args.iconSize ? args.iconSize : '');
btn.setAttribute('data-shape', args.shape);
btn.setAttribute('data-aria-label', args.ariaLabel ? args.ariaLabel : '');
btn.setAttribute('primary', args.primary);
btn.setAttribute('disabled', args.disabled);
btn.setAttribute('label', args.label);
btn.setAttribute('img', args.img ? args.img : '');
btn.setAttribute('img-alt', args.imgAlt ? args.imgAlt : '');
btn.setAttribute('icon', args.icon ? args.icon : '');
btn.setAttribute('icon-order', args.iconOrder ? args.iconOrder : '');
btn.setAttribute('icon-size', args.iconSize ? args.iconSize : '');
btn.setAttribute('shape', args.shape);
btn.setAttribute('aria-label', args.ariaLabel ? args.ariaLabel : '');
args.backgroundColor
? btn.setAttribute('data-background-color', args.backgroundColor)
: btn.setAttribute('data-background-color', 'primary');
? btn.setAttribute('background-color', args.backgroundColor)
: btn.setAttribute('background-color', 'primary');
if (args.close) {
btn.setAttribute('data-close', args.close);
btn.setAttribute('close', args.close);
}
if (args.hLabel) {
btn.setAttribute('data-hidden-label', args.hLabel);
btn.setAttribute('hidden-label', args.hLabel);
}
if (args.size) {
btn.setAttribute('data-size', args.size);
btn.setAttribute('size', args.size);
}
if (args.id) {
btn.setAttribute('data-id', args.id);
btn.setAttribute('id', args.id);
}
if (args.link) {
btn.setAttribute('data-link', args.link);
btn.setAttribute('link', args.link);
}
if (args.extraClasses) {
btn.setAttribute('data-extra-classes', args.extraClasses);
btn.setAttribute('extra-classes', args.extraClasses);
}
return btn;
};
Expand Down
136 changes: 17 additions & 119 deletions src/stories/buttongroup.stories.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,79 +14,25 @@ export const Basic = () => html`
<button type="button" class="btn btn-primary">Middle</button>
<button type="button" class="btn btn-primary">Right</button>
</div>
<cod-button
data-label="Left"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Middle"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Right"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button label="Left" background-color="primary" primary></cod-button>
<cod-button label="Middle" background-color="primary" primary></cod-button>
<cod-button label="Right" background-color="primary" primary></cod-button>
</cod-button-group>
`;

export const Mixed = () => html`
<cod-button-group data-type="group" data-label="basic example">
<cod-button
data-label="Left"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Middle"
data-background-color="warning"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Right"
data-background-color="danger"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button label="Left" background-color="primary" primary></cod-button>
<cod-button label="Middle" background-color="warning" primary></cod-button>
<cod-button label="Right" background-color="danger" primary></cod-button>
</cod-button-group>
`;

export const Outlined = () => html`
<cod-button-group data-type="group" data-label="basic example">
<cod-button
data-label="Left"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Middle"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Right"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button label="Left" background-color="primary" primary></cod-button>
<cod-button label="Middle" background-color="primary" primary></cod-button>
<cod-button label="Right" background-color="primary" primary></cod-button>
</cod-button-group>
`;

Expand Down Expand Up @@ -191,27 +137,9 @@ export const ButtonToolbar = () => html`
data-label="group 1"
data-extra-classes="me-2"
>
<cod-button
data-label="1"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="2"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="3"
data-background-color="primary"
data-primary="false"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button label="1" background-color="primary" primary></cod-button>
<cod-button label="2" background-color="primary" primary></cod-button>
<cod-button label="3" background-color="primary" primary></cod-button>
</cod-button-group>
<cod-form-control
data-tag="input"
Expand All @@ -234,40 +162,10 @@ export const Vertical = () => html`
data-label="Vertical button group"
data-vertical="true"
>
<cod-button
data-label="Button"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Button"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Button"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Button"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button
data-label="Button"
data-background-color="primary"
data-primary="true"
data-img-alt=""
data-icon=""
></cod-button>
<cod-button label="Button" background-color="primary" primary></cod-button>
<cod-button label="Button" background-color="primary" primary></cod-button>
<cod-button label="Button" background-color="primary" primary></cod-button>
<cod-button label="Button" background-color="primary" primary></cod-button>
<cod-button label="Button" background-color="primary" primary></cod-button>
</cod-button-group>
`;
Loading
Loading