Skip to content

Commit

Permalink
Merge branch 'main' into feat/sbb-autocomplete-grid
Browse files Browse the repository at this point in the history
# Conflicts:
#	src/components/autocomplete/autocomplete.ts
  • Loading branch information
DavideMininni-Fincons committed Apr 24, 2024
2 parents d6d9d0e + cf97ecd commit 2d56057
Show file tree
Hide file tree
Showing 36 changed files with 485 additions and 210 deletions.
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -118,7 +118,7 @@
"sass": "1.75.0",
"sinon": "17.0.1",
"storybook": "8.0.9",
"stylelint": "16.3.1",
"stylelint": "16.4.0",
"stylelint-config-prettier-scss": "1.0.0",
"stylelint-config-standard-scss": "13.1.0",
"stylelint-scss": "6.2.1",
Expand Down
24 changes: 12 additions & 12 deletions src/components/accordion/accordion.e2e.ts
Original file line number Diff line number Diff line change
Expand Up @@ -82,14 +82,14 @@ describe(`sbb-accordion ${fixture.name}`, () => {
const panels = Array.from(element.querySelectorAll('sbb-expansion-panel'));
expect(panels.length).to.be.equal(3);
expect(
panels[0].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H4');
panels[0].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h4');
expect(
panels[1].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H4');
panels[1].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h4');
expect(
panels[2].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H4');
panels[2].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h4');
});

it('should dynamically update titleLevel prop', async () => {
Expand All @@ -98,14 +98,14 @@ describe(`sbb-accordion ${fixture.name}`, () => {
const panels = Array.from(element.querySelectorAll('sbb-expansion-panel'));
expect(panels.length).to.be.equal(3);
expect(
panels[0].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H6');
panels[0].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h6');
expect(
panels[1].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H6');
panels[1].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h6');
expect(
panels[2].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.tagName,
).to.be.equal('H6');
panels[2].shadowRoot!.querySelector('.sbb-expansion-panel')!.firstElementChild!.localName,
).to.be.equal('h6');
});

it('should close others when expanding and multi = false', async () => {
Expand Down
2 changes: 1 addition & 1 deletion src/components/accordion/accordion.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ export class SbbAccordionElement extends SbbHydrationMixin(LitElement) {
private _abort = new SbbConnectedAbortController(this);

private _closePanels(e: CustomEvent): void {
if ((e.target as HTMLElement)?.tagName !== 'SBB-EXPANSION-PANEL' || this.multi) {
if ((e.target as HTMLElement)?.localName !== 'sbb-expansion-panel' || this.multi) {
return;
}

Expand Down
2 changes: 1 addition & 1 deletion src/components/alert/alert-group/alert-group.e2e.ts
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ describe(`sbb-alert-group with ${fixture.name}`, () => {
expect(element.querySelectorAll('sbb-alert').length).to.be.equal(2);
const alertGroupTitle = element.shadowRoot!.querySelector('.sbb-alert-group__title')!;
expect(alertGroupTitle.textContent!.trim()).to.be.equal(accessibilityTitle);
expect(alertGroupTitle.tagName).to.be.equal(`H${accessibilityTitleLevel}`);
expect(alertGroupTitle.localName).to.be.equal(`h${accessibilityTitleLevel}`);

// When clicking on close button of the first alert
const closeButton = element
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -154,14 +154,14 @@ describe(`sbb-breadcrumb-group with ${fixture.name}`, () => {
(document.activeElement as HTMLElement).blur();

// Then the body should be focused
expect(document.activeElement!.tagName).to.be.equal('BODY');
expect(document.activeElement!.localName).to.be.equal('body');

// When triggering a slotChange by removing a breadcrumb
element.querySelector('#breadcrumb-6')!.remove();
await waitForLitRender(element);

// Then the body should still be focused
expect(document.activeElement!.tagName).to.be.equal('BODY');
expect(document.activeElement!.localName).to.be.equal('body');
});

it('should remove expand button when too less breadcrumbs available', async () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export class SbbBreadcrumbGroupElement extends SbbNamedSlotListMixin<
typeof LitElement
>(LitElement) {
public static override styles: CSSResultGroup = style;
protected override readonly listChildTagNames = ['SBB-BREADCRUMB'];
protected override readonly listChildLocalNames = ['sbb-breadcrumb'];

/* The state of the breadcrumb group. */
@state()
Expand Down
2 changes: 1 addition & 1 deletion src/components/calendar/calendar.ts
Original file line number Diff line number Diff line change
Expand Up @@ -588,7 +588,7 @@ export class SbbCalendarElement<T = Date> extends LitElement {
}

private _handleTableBlur(eventTarget: HTMLElement): void {
if (eventTarget?.tagName !== 'BUTTON') {
if (eventTarget?.localName !== 'button') {
this._setTabIndex();
}
}
Expand Down
4 changes: 2 additions & 2 deletions src/components/card/common/card-action-common.ts
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,8 @@ export const SbbCardActionCommonElementMixin = <
Array.from(this._card?.querySelectorAll?.(IS_FOCUSABLE_QUERY) ?? [])
.filter(
(el) =>
el.tagName !== 'SBB-CARD-LINK' &&
el.tagName !== 'SBB-CARD-BUTTON' &&
el.localName !== 'sbb-card-link' &&
el.localName !== 'sbb-card-button' &&
!el.hasAttribute(cardFocusableAttributeName),
)
.forEach((el: Element) => el.setAttribute(cardFocusableAttributeName, ''));
Expand Down
9 changes: 8 additions & 1 deletion src/components/container/container/container.scss
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,14 @@
}

.sbb-container {
background-color: var(--sbb-container-background-color, transparent);
background-color: var(--sbb-container-background-color);

// In order to support nested sbb-containers (e.g. if used in an overlay), we need to explicitly set background color to transparent.
// We cannot use the --sbb-container-background-color variable because using it would
// destroy sbb-sticky-bar behavior when the container and the sticky bar have transparent color.
:host([color='transparent']) & {
background-color: transparent;
}

// Placing content before and after the container stops the margin of inner elements from overflowing
&::after,
Expand Down
23 changes: 21 additions & 2 deletions src/components/container/container/container.stories.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,13 +47,25 @@ const defaultArgs: Args = {
color: color.options![0],
};

const DefaultTemplate = ({ color, ...args }: Args): TemplateResult => html`
<sbb-container ${sbbSpread(args)} color=${color}>
const DefaultTemplate = (args: Args): TemplateResult => html`
<sbb-container ${sbbSpread(args)}>
${containerContent('Example title')} ${containerContent('Another one')}
${containerContent('And another one', true)}
</sbb-container>
`;

// Only for visual regression
const NestedContainerTemplate = (): TemplateResult => html`
<sbb-container color="white">
${containerContent('Example title')}
<div style="background-color: var(--sbb-color-milk);">
<sbb-container color="transparent">
${containerContent('And another one', true)}
</sbb-container>
</div>
</sbb-container>
`;

export const Default: StoryObj = {
render: DefaultTemplate,
argTypes: defaultArgTypes,
Expand All @@ -78,7 +90,14 @@ export const Expanded: StoryObj = {
args: { ...defaultArgs, expanded: true },
};

export const NestedContainer: StoryObj = {
render: NestedContainerTemplate,
argTypes: { defaultArgTypes },
args: { ...defaultArgs, expanded: true },
};

const meta: Meta = {
excludeStories: /^(NestedContainer)$/,
parameters: {
docs: {
extractComponentDescription: () => readme,
Expand Down
2 changes: 1 addition & 1 deletion src/components/core/base-elements/link-base-element.ts
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ export abstract class SbbLinkBaseElement extends SbbActionBaseElement {
// event origin, which means the inner anchor element has not actually been activated/clicked.
if (
!this.href ||
!target.tagName.startsWith('SBB-') ||
!target.localName.startsWith('sbb-') ||
target !== composedTarget ||
(await isEventPrevented(event))
) {
Expand Down
6 changes: 3 additions & 3 deletions src/components/core/mixins/named-slot-list-mixin.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ export type WithListChildren<
export declare abstract class SbbNamedSlotListMixinType<
C extends HTMLElement,
> extends SbbHydrationMixinType {
protected abstract readonly listChildTagNames: string[];
protected abstract readonly listChildLocalNames: string[];
@state() protected listChildren: C[];
protected renderList(attributes?: {
class?: string;
Expand Down Expand Up @@ -58,7 +58,7 @@ export const SbbNamedSlotListMixin = <
implements Partial<SbbNamedSlotListMixinType<C>>
{
/** A list of upper-cased tag names to match against. (e.g. SBB-LINK) */
protected abstract readonly listChildTagNames: string[];
protected abstract readonly listChildLocalNames: string[];

/**
* A list of children with the defined tag names.
Expand All @@ -79,7 +79,7 @@ export const SbbNamedSlotListMixin = <

private _handleSlotchange = (): void => {
const listChildren = Array.from(this.children ?? []).filter((e): e is C =>
this.listChildTagNames.includes(e.tagName),
this.listChildLocalNames.includes(e.localName),
);
// If the slotted child instances have not changed, we can skip syncing and updating
// the link reference list.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,10 +137,10 @@ export class SbbExpansionPanelElement extends SbbHydrationMixin(LitElement) {
private _handleSlotchange(): void {
const children = Array.from(this.children ?? []);
const header = children.find(
(e): e is SbbExpansionPanelHeaderElement => e.tagName === 'SBB-EXPANSION-PANEL-HEADER',
(e): e is SbbExpansionPanelHeaderElement => e.localName === 'sbb-expansion-panel-header',
);
const content = children.find(
(e): e is SbbExpansionPanelContentElement => e.tagName === 'SBB-EXPANSION-PANEL-CONTENT',
(e): e is SbbExpansionPanelContentElement => e.localName === 'sbb-expansion-panel-content',
);
if (this._headerRef === header && this._contentRef === content) {
return;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ export class SbbFormFieldClearElement extends SbbNegativeMixin(SbbButtonBaseElem

private async _handleClick(): Promise<void> {
const input = this._formField?.inputElement;
if (!input || input.tagName !== 'INPUT') {
if (!input || input.localName !== 'input') {
return;
}
this._formField?.clear();
Expand Down
2 changes: 1 addition & 1 deletion src/components/form-field/form-field/form-field.ts
Original file line number Diff line number Diff line change
Expand Up @@ -215,7 +215,7 @@ export class SbbFormFieldElement extends SbbNegativeMixin(LitElement) {
this._readInputState();
this._registerInputListener();

if (this._input.tagName === 'TEXTAREA') {
if (this._input.localName === 'textarea') {
this._input.setAttribute('rows', this._input.getAttribute('rows') || '3');
}

Expand Down
8 changes: 4 additions & 4 deletions src/components/link-list/link-list.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,10 @@ export class SbbLinkListElement extends SbbNegativeMixin(
>(LitElement),
) {
public static override styles: CSSResultGroup = style;
protected override readonly listChildTagNames = [
'SBB-BLOCK-LINK',
'SBB-BLOCK-LINK-BUTTON',
'SBB-BLOCK-LINK-STATIC',
protected override readonly listChildLocalNames = [
'sbb-block-link',
'sbb-block-link-button',
'sbb-block-link-static',
];

/** The title text we want to show before the list. */
Expand Down
10 changes: 5 additions & 5 deletions src/components/menu/menu/menu.ts
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ export class SbbMenuElement extends SbbNamedSlotListMixin<
willClose: 'willClose',
didClose: 'didClose',
} as const;
protected override readonly listChildTagNames = ['SBB-MENU-BUTTON', 'SBB-MENU-LINK'];
protected override readonly listChildLocalNames = ['sbb-menu-button', 'sbb-menu-link'];

/**
* The element that will trigger the menu overlay.
Expand Down Expand Up @@ -163,7 +163,7 @@ export class SbbMenuElement extends SbbNamedSlotListMixin<
*/
private _onClick(event: Event): void {
const target = event.target as HTMLElement | undefined;
if (target?.tagName === 'SBB-MENU-BUTTON' || target?.tagName === 'SBB-MENU-LINK') {
if (target?.localName === 'sbb-menu-button' || target?.localName === 'sbb-menu-link') {
this.close();
}
}
Expand Down Expand Up @@ -244,7 +244,7 @@ export class SbbMenuElement extends SbbNamedSlotListMixin<
if (
this.children?.length &&
Array.from(this.children ?? []).every(
(c) => c.tagName === 'SBB-MENU-BUTTON' || c.tagName === 'SBB-MENU-LINK',
(c) => c.localName === 'sbb-menu-button' || c.localName === 'sbb-menu-link',
)
) {
return;
Expand Down Expand Up @@ -344,8 +344,8 @@ export class SbbMenuElement extends SbbNamedSlotListMixin<
this._triggerElement?.focus({
// When inside the sbb-header, we prevent the scroll to avoid the snapping to the top of the page
preventScroll:
this._triggerElement.tagName === 'SBB-HEADER-BUTTON' ||
this._triggerElement.tagName === 'SBB-HEADER-LINK',
this._triggerElement.localName === 'sbb-header-button' ||
this._triggerElement.localName === 'sbb-header-link',
});
this._didClose.emit();
this._windowEventsController?.abort();
Expand Down
5 changes: 4 additions & 1 deletion src/components/navigation/navigation-list/navigation-list.ts
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,10 @@ export class SbbNavigationListElement extends SbbNamedSlotListMixin<
typeof LitElement
>(LitElement) {
public static override styles: CSSResultGroup = style;
protected override readonly listChildTagNames = ['SBB-NAVIGATION-BUTTON', 'SBB-NAVIGATION-LINK'];
protected override readonly listChildLocalNames = [
'sbb-navigation-button',
'sbb-navigation-link',
];

/**
* The label to be shown before the action list.
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,10 @@ export class SbbNavigationMarkerElement extends SbbNamedSlotListMixin<
typeof LitElement
>(LitElement) {
public static override styles: CSSResultGroup = style;
protected override readonly listChildTagNames = ['SBB-NAVIGATION-BUTTON', 'SBB-NAVIGATION-LINK'];
protected override readonly listChildLocalNames = [
'sbb-navigation-button',
'sbb-navigation-link',
];

/**
* Marker size variant.
Expand Down
Loading

0 comments on commit 2d56057

Please sign in to comment.