Skip to content

Commit

Permalink
feat: add size s
Browse files Browse the repository at this point in the history
  • Loading branch information
DavideMininni-Fincons committed Apr 23, 2024
1 parent 8b91eb8 commit e057e42
Show file tree
Hide file tree
Showing 8 changed files with 113 additions and 8 deletions.
30 changes: 30 additions & 0 deletions src/components/accordion/accordion.stories.ts
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,16 @@ const titleLevel: InputType = {
},
};

const size: InputType = {
control: {
type: 'inline-radio',
},
options: ['l', 's'],
table: {
category: 'Accordion',
},
};

const color: InputType = {
control: {
type: 'inline-radio',
Expand Down Expand Up @@ -111,6 +121,7 @@ const defaultArgTypes: ArgTypes = {
numberOfPanels,
multi,
'title-level': titleLevel,
size,
color,
expanded,
borderless,
Expand All @@ -124,6 +135,7 @@ const defaultArgs: Args = {
numberOfPanels: 3,
multi: false,
'title-level': titleLevel.options![2],
size: size.options![0],
color: color.options![0],
expanded: false,
borderless: false,
Expand Down Expand Up @@ -215,6 +227,24 @@ export const Multi: StoryObj = {
args: { ...defaultArgs, multi: true },
};

export const NoAnimation: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, 'disable-animation': true },
};

export const SizeS: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, size: size.options![1] },
};

export const SizeSWithIcon: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, size: size.options![1], iconName: 'swisspass-medium' },
};

const meta: Meta = {
decorators: [withActions as Decorator],
parameters: {
Expand Down
12 changes: 11 additions & 1 deletion src/components/accordion/accordion.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { CSSResultGroup, TemplateResult } from 'lit';
import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
import { html, LitElement } from 'lit';
import { customElement, property } from 'lit/decorators.js';

Expand Down Expand Up @@ -44,6 +44,9 @@ export class SbbAccordionElement extends SbbHydrationMixin(LitElement) {
}
private _multi: boolean = false;

/** Size variant, either l or s; overrides the size on any projected `sbb-expansion-panel`. `*/
@property({ reflect: true }) public size: 's' | 'l' = 'l';

private _abort = new SbbConnectedAbortController(this);

private _closePanels(e: CustomEvent): void {
Expand Down Expand Up @@ -87,10 +90,17 @@ export class SbbAccordionElement extends SbbHydrationMixin(LitElement) {
);
}

protected override willUpdate(changedProperties: PropertyValues<this>): void {
if (changedProperties.has('size')) {
this._expansionPanels.forEach((panel: SbbExpansionPanelElement) => (panel.size = this.size));
}
}

private _handleSlotchange(): void {
this._expansionPanels.forEach(
(panel: SbbExpansionPanelElement, index: number, array: SbbExpansionPanelElement[]) => {
panel.titleLevel = this.titleLevel;
panel.size = this.size;
panel.toggleAttribute('data-accordion-first', index === 0);
panel.toggleAttribute('data-accordion-last', index === array.length - 1);
},
Expand Down
16 changes: 12 additions & 4 deletions src/components/accordion/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,13 @@ The `multi` property, if set, allows having more than one `sbb-expansion-panel`

## Style

The component has two different sizes, `l` (default) and `s`, which can be changed using the `size` property.
The property overrides the `size` value of any inner `sbb-expansion-panel`.

```html
<sbb-accordion size="s"> ... </sbb-accordion>
```

The component has a `titleLevel` property, which is proxied to each inner `sbb-expansion-panel-header`, and can be used
to wrap the header of each `sbb-expansion-panel` in a heading tag; if the property is unset, a `div` is used.

Expand All @@ -43,10 +50,11 @@ In the following example, all the `sbb-expansion-panel-header` would be wrapped

## Properties

| Name | Attribute | Privacy | Type | Default | Description |
| ------------ | ------------- | ------- | ----------------------- | ------- | --------------------------------------------------------------------------- |
| `titleLevel` | `title-level` | public | `SbbTitleLevel \| null` | `null` | The heading level for the sbb-expansion-panel-headers within the component. |
| `multi` | `multi` | public | `boolean` | `false` | Whether more than one sbb-expansion-panel can be open at the same time. |
| Name | Attribute | Privacy | Type | Default | Description |
| ------------ | ------------- | ------- | ----------------------- | ------- | ----------------------------------------------------------------------------------------- |
| `titleLevel` | `title-level` | public | `SbbTitleLevel \| null` | `null` | The heading level for the sbb-expansion-panel-headers within the component. |
| `multi` | `multi` | public | `boolean` | `false` | Whether more than one sbb-expansion-panel can be open at the same time. |
| `size` | `size` | public | `'s' \| 'l'` | `'l'` | Size variant, either l or s; overrides the size on any projected `sbb-expansion-panel`. ` |

## Slots

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,10 @@
display: block;
}

:host([data-size='s']) {
--sbb-expansion-panel-content-padding-inline: var(--sbb-spacing-fixed-5x);
}

:host([data-icon-space]) {
@include sbb.mq($from: micro) {
// The space taken by the icon in the sbb-expansion-panel-header must be considered here to correctly calculate the padding value;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,12 @@
display: block;
}

:host([data-size='s']) {
--sbb-expansion-panel-header-gap: var(--sbb-spacing-fixed-2x);
--sbb-expansion-panel-header-padding-block: var(--sbb-spacing-fixed-3x);
--sbb-expansion-panel-header-padding-inline: var(--sbb-spacing-fixed-5x);
}

:host([disabled]) {
--sbb-expansion-panel-header-cursor: default;
--sbb-expansion-panel-header-text-color: var(--sbb-color-granite);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -85,6 +85,13 @@ const disabled: InputType = {
},
};

const size: InputType = {
control: {
type: 'inline-radio',
},
options: ['l', 's'],
};

const defaultArgTypes: ArgTypes = {
headerText,
iconName,
Expand All @@ -94,6 +101,7 @@ const defaultArgTypes: ArgTypes = {
color,
borderless,
disabled,
size,
};

const defaultArgs: Args = {
Expand All @@ -105,6 +113,7 @@ const defaultArgs: Args = {
color: color.options![0],
borderless: false,
disabled: false,
size: size.options![0],
};

const Template = ({ headerText, iconName, contentText, ...args }: Args): TemplateResult => html`
Expand Down Expand Up @@ -191,6 +200,24 @@ export const LongText: StoryObj = {
args: { ...defaultArgs, headerText: longText, contentText: longText },
};

export const NoAnimation: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, 'disable-animation': true },
};

export const SizeS: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, size: size.options![1] },
};

export const SizeSWithIcon: StoryObj = {
render: Template,
argTypes: defaultArgTypes,
args: { ...defaultArgs, size: size.options![1], iconName: 'swisspass-medium' },
};

const meta: Meta = {
decorators: [withActions as Decorator],
parameters: {
Expand Down
18 changes: 15 additions & 3 deletions src/components/expansion-panel/expansion-panel/expansion-panel.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { CSSResultGroup, TemplateResult } from 'lit';
import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
import { LitElement } from 'lit';
import { customElement, property } from 'lit/decorators.js';
import { html, unsafeStatic } from 'lit/static-html.js';
Expand Down Expand Up @@ -65,6 +65,9 @@ export class SbbExpansionPanelElement extends SbbHydrationMixin(LitElement) {
/** Whether the panel has no border. */
@property({ reflect: true, type: Boolean }) public borderless = false;

/** Size variant, either l or s. */
@property({ reflect: true }) public size: 's' | 'l' = 'l';

/** Emits whenever the `sbb-expansion-panel` starts the opening transition. */
private _willOpen: EventEmitter<void> = new EventEmitter(
this,
Expand Down Expand Up @@ -124,8 +127,14 @@ export class SbbExpansionPanelElement extends SbbHydrationMixin(LitElement) {
super.connectedCallback();
const signal = this._abort.signal;
this.addEventListener('toggleExpanded', () => this._toggleExpanded(), { signal });
const accordion = this.closest?.('sbb-accordion');
this.toggleAttribute('data-accordion', !!accordion);
this.toggleAttribute('data-accordion', !!this.closest?.('sbb-accordion'));
}

protected override willUpdate(changedProperties: PropertyValues<this>): void {
if (changedProperties.has('size')) {
this._headerRef?.setAttribute('data-size', String(this.size));
this._contentRef?.setAttribute('data-size', String(this.size));
}
}

public override disconnectedCallback(): void {
Expand All @@ -149,10 +158,12 @@ export class SbbExpansionPanelElement extends SbbHydrationMixin(LitElement) {
header.id ||= `sbb-expansion-panel-header${this._progressiveId}`;
header.setAttribute('aria-expanded', String(this.expanded));
header.toggleAttribute('disabled', this.disabled);
header.setAttribute('data-size', String(this.size));
}
if (content && this._contentRef !== content) {
content.id ||= `sbb-expansion-panel-content${this._progressiveId}`;
content.setAttribute('aria-hidden', String(!this.expanded));
content.setAttribute('data-size', String(this.size));
}

this._headerRef = header;
Expand Down Expand Up @@ -206,6 +217,7 @@ export class SbbExpansionPanelElement extends SbbHydrationMixin(LitElement) {
</div>
</div>
`;
/* eslint-enable lit/binding-positions */
}
}

Expand Down
8 changes: 8 additions & 0 deletions src/components/expansion-panel/expansion-panel/readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,13 @@ The component has two background options (`milk` and `white`, which is the defau
<sbb-expansion-panel color="milk"> ... </sbb-expansion-panel>
```

The component has two different sizes, `l` (default) and `s`, which can be changed using the `size` property.
The property is overridden when the component is used within a `sbb-accordion`.

```html
<sbb-expansion-panel size="s"> ... </sbb-expansion-panel>
```

It's also possible to display the `sbb-expansion-panel` without border by setting the `borderless` variable.

```html
Expand Down Expand Up @@ -78,6 +85,7 @@ and the `aria-hidden` attribute on the content.
| `expanded` | `expanded` | public | `boolean` | `false` | Whether the panel is expanded. |
| `disabled` | `disabled` | public | `boolean` | `false` | Whether the panel is disabled, so its expanded state can't be changed. |
| `borderless` | `borderless` | public | `boolean` | `false` | Whether the panel has no border. |
| `size` | `size` | public | `'s' \| 'l'` | `'l'` | Size variant, either l or s. |

## Events

Expand Down

0 comments on commit e057e42

Please sign in to comment.