Skip to content

Commit

Permalink
feat(radio-button): slug
Browse files Browse the repository at this point in the history
  • Loading branch information
ariellalgilmore committed Dec 7, 2023
1 parent 6344a55 commit f032b33
Show file tree
Hide file tree
Showing 4 changed files with 166 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,30 @@ class CDSRadioButtonGroup extends FormMixin(HostListenerMixin(LitElement)) {
}
}

/**
* Handles `slotchange` event.
*/
protected _handleSlotChange({ target }: Event) {
const hasContent = (target as HTMLSlotElement)
.assignedNodes()
.filter((elem) =>
(elem as HTMLElement).matches !== undefined
? (elem as HTMLElement).matches(
(this.constructor as typeof CDSRadioButtonGroup).slugItem
)
: false
);

this._hasSlug = Boolean(hasContent);
(hasContent[0] as HTMLElement).setAttribute('size', 'mini');
this.requestUpdate();
}

/**
* `true` if there is a slug.
*/
protected _hasSlug = false;

/**
* The `value` attribute for the `<input>` for selection.
*/
Expand Down Expand Up @@ -189,6 +213,8 @@ class CDSRadioButtonGroup extends FormMixin(HostListenerMixin(LitElement)) {
orientation,
legendText,
helperText,
_hasSlug: hasSlug,
_handleSlotChange: handleSlotChange
} = this;

const showWarning = !readOnly && !invalid && warn;
Expand All @@ -211,14 +237,15 @@ class CDSRadioButtonGroup extends FormMixin(HostListenerMixin(LitElement)) {
[`${prefix}--radio-button-group--readonly`]: readOnly,
[`${prefix}--radio-button-group--${orientation}`]:
orientation === 'vertical',
[`${prefix}--radio-button-group--slug`]: hasSlug,
});

return html` <fieldset
class="${fieldsetClasses}"
?disabled="${disabled}"
aria-readonly="${readOnly}">
${legendText
? html` <legend class="${prefix}--label">${legendText}</legend>`
? html` <legend class="${prefix}--label">${legendText} <slot name="slug" @slotchange="${handleSlotChange}"></slot></legend>`
: ``}
<slot></slot>
</fieldset>
Expand All @@ -244,6 +271,13 @@ class CDSRadioButtonGroup extends FormMixin(HostListenerMixin(LitElement)) {
return `${prefix}-radio-button`;
}

/**
* A selector that will return the slug item.
*/
static get slugItem() {
return `${prefix}-slug`;
}

/**
* The name of the custom event fired after this radio button group changes its selected item.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ $css--plex: true !default;
@use '@carbon/styles/scss/theme' as *;
@use '@carbon/styles/scss/spacing' as *;
@use '@carbon/styles/scss/utilities' as *;
@use '@carbon/styles/scss/utilities/convert' as *;
@use '@carbon/styles/scss/components/form';
@use '@carbon/styles/scss/components/radio-button/radio-button' as *;

Expand Down Expand Up @@ -58,6 +59,11 @@ $css--plex: true !default;
}
}

:host(#{$prefix}-radio-button[orientation='vertical']) {
margin-block-end: to-rem(6px);
margin-inline-end: 0;
}

:host(#{$prefix}-radio-button[invalid]) .#{$prefix}--radio-button__appearance {
border-color: $support-error;
}
Expand Down Expand Up @@ -102,3 +108,23 @@ $css--plex: true !default;
margin-left: $spacing-03;
}
}

:host(#{$prefix}-radio-button[slug]){
.#{$prefix}--radio-button__label-text {
display: flex;
}
}

:host(#{$prefix}-radio-button-group) .#{$prefix}--radio-button-group--slug,
:host(#{$prefix}-radio-button[slug]){
::slotted(#{$prefix}-slug){
margin-inline-start: $spacing-03;
}
}

:host(#{$prefix}-radio-button[slug]){
::slotted(#{$prefix}-slug[inline]){
line-height: inherit;
margin-block-start: to-rem(-1px);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,31 @@ class CDSRadioButton extends HostListenerMixin(FocusMixin(LitElement)) {
}
};

/**
* Handles `slotchange` event.
*/
protected _handleSlotChange({ target }: Event) {
const hasContent = (target as HTMLSlotElement)
.assignedNodes()
.filter((elem) =>
(elem as HTMLElement).matches !== undefined
? (elem as HTMLElement).matches(
(this.constructor as typeof CDSRadioButton).slugItem
)
: false
);

this._hasSlug = Boolean(hasContent);
const type = (hasContent[0] as HTMLElement).getAttribute('kind');
(hasContent[0] as HTMLElement).setAttribute('size', type === 'inline' ? 'md' : 'mini');
this.requestUpdate();
}

/**
* `true` if there is a slug.
*/
protected _hasSlug = false;

/**
* `true` if this radio button should be checked.
*/
Expand Down Expand Up @@ -261,10 +286,12 @@ class CDSRadioButton extends HostListenerMixin(FocusMixin(LitElement)) {

updated(changedProperties) {
const {
_hasSlug: hasSlug,
_inputNode: inputNode,
_radioButtonDelegate: radioButtonDelegate,
name,
} = this;

if (changedProperties.has('checked') || changedProperties.has('name')) {
if (this.readOnly) {
this.checked = false;
Expand All @@ -288,6 +315,7 @@ class CDSRadioButton extends HostListenerMixin(FocusMixin(LitElement)) {
: '0'
);
}
hasSlug ? this.setAttribute('slug', '') : this.removeAttribute('slug');
}

render() {
Expand All @@ -301,6 +329,7 @@ class CDSRadioButton extends HostListenerMixin(FocusMixin(LitElement)) {
disabledItem,
} = this;
const innerLabelClasses = classMap({
[`${prefix}--radio-button__label-text`]: true,
[`${prefix}--visually-hidden`]: hideLabel,
});
return html`
Expand All @@ -314,11 +343,20 @@ class CDSRadioButton extends HostListenerMixin(FocusMixin(LitElement)) {
value=${ifDefined(value)} />
<label for="input" class="${prefix}--radio-button__label">
<span class="${prefix}--radio-button__appearance"></span>
<span class="${innerLabelClasses}"><slot>${labelText}</slot></span>
<span class="${innerLabelClasses}">${labelText}
<slot name="slug" @slotchange="${this._handleSlotChange}"></slot></span>
</label>
`;
}

/**
* A selector that will return the slug item.
*/
static get slugItem() {
return `${prefix}-slug`;
}

/**
* The name of the custom event fired after this radio button changes its checked state.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -191,6 +191,72 @@ export const _NumberItem = () => {
`;
};

export const _RadioButton = () => {
return html`
<div class="slug-check-radio-container">
<cds-radio-button-group
legend-text="Group label"
name="radio-group"
value="radio-1"
orientation="vertical">
<cds-slug alignment="bottom-left"> ${content}${actions} </cds-slug>
<cds-radio-button
label-text="Radio button label"
value="radio-1"></cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-2"></cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-3"></cds-radio-button>
</cds-radio-button-group>
<cds-radio-button-group
legend-text="Group label"
name="radio-group-2"
value="radio-4"
orientation="vertical">
<cds-radio-button
label-text="Radio button label"
value="radio-4">
<cds-slug alignment="bottom-left"> ${content}${actions} </cds-slug>
</cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-5">
<cds-slug alignment="bottom-left"> ${content}${actions} </cds-slug>
</cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-6"></cds-radio-button>
</cds-radio-button-group>
<cds-radio-button-group
legend-text="Group label"
name="radio-group-2"
value="radio-4"
orientation="vertical">
<cds-radio-button
label-text="Radio button label"
value="radio-4">
<cds-slug alignment="bottom-left" kind="inline"> ${content}${actions} </cds-slug>
</cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-5">
<cds-slug alignment="bottom-left" kind="inline"> ${content}${actions} </cds-slug>
</cds-radio-button>
<cds-radio-button
label-text="Radio button label"
value="radio-6"></cds-radio-button>
</cds-radio-button-group>
</div>
`;
};
export const _Select = () => {
return html`
<div style="width: 400px">
Expand Down

0 comments on commit f032b33

Please sign in to comment.