Skip to content

Commit

Permalink
Merge branch 'main' into dsw-000-dividersize
Browse files Browse the repository at this point in the history
  • Loading branch information
ashleynolan authored Jan 8, 2025
2 parents 18d30d8 + 109dd8e commit ffa1925
Show file tree
Hide file tree
Showing 23 changed files with 779 additions and 224 deletions.
9 changes: 9 additions & 0 deletions .changeset/tiny-eels-play.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
---
"@justeattakeaway/pie-toast-provider": minor
"@justeattakeaway/pie-toast": minor
"@justeattakeaway/pie-webc": minor
"pie-storybook": minor
"pie-monorepo": minor
---

[Added] - priority order for the toast provider
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
],
[
"4",
"Positive - actionable"
"Success - actionable"
],
[
"5",
Expand All @@ -34,7 +34,7 @@
],
[
"8",
"Positive"
"Success"
],
[
"9",
Expand Down
111 changes: 103 additions & 8 deletions apps/pie-storybook/stories/pie-toast-provider.stories.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,39 @@
import { html } from 'lit';
import { type Meta } from '@storybook/web-components';
import { action } from '@storybook/addon-actions';

import '@justeattakeaway/pie-toast-provider';
import { type ToastProviderProps } from '@justeattakeaway/pie-toast-provider';
import { toaster } from '@justeattakeaway/pie-toast-provider';
import { type ToastProviderProps, defaultProps } from '@justeattakeaway/pie-toast-provider';
import '@justeattakeaway/pie-button';
import '@justeattakeaway/pie-tag';

import { createStory } from '../utilities';

type ToastProviderStoryMeta = Meta<ToastProviderProps>;

const defaultArgs: ToastProviderProps = {};
const defaultArgs: ToastProviderProps = {
...defaultProps,
options: {
duration: 3000,
isDismissible: true,
onPieToastOpen: action('onPieToastOpen'),
onPieToastClose: action('onPieToastClose'),
onPieToastLeadingActionClick: action('onPieToastLeadingActionClick'),
},
};

const toastProviderStoryMeta: ToastProviderStoryMeta = {
title: 'Toast Provider',
component: 'pie-toast-provider',
argTypes: {},
argTypes: {
options: {
description: 'Default options for all toasts; accepts all toast props.',
control: 'object',
defaultValue: {
summary: defaultProps.options,
},
},
},
args: defaultArgs,
parameters: {
design: {
Expand All @@ -25,10 +45,85 @@ const toastProviderStoryMeta: ToastProviderStoryMeta = {

export default toastProviderStoryMeta;

// TODO: remove the eslint-disable rule when props are added
// eslint-disable-next-line no-empty-pattern
const Template = ({}: ToastProviderProps) => html`
<pie-toast-provider></pie-toast-provider>
const Template = ({ options }: ToastProviderProps) => {
const onQueueUpdate = (event: CustomEvent) => {
const queueLength = document.querySelector('#queue-length-tag') as HTMLElement;
if (queueLength) {
queueLength.textContent = `Toast Queue Length: ${event.detail.length}`;
}
};

return html`
<pie-toast-provider
.options=${options}
@pie-toast-provider-queue-update=${onQueueUpdate}>
</pie-toast-provider>
<pie-tag id="queue-length-tag" variant="information" style="margin-top: 16px;">
Toast Queue Length: 0
</pie-tag>
<div style="margin-top: 16px; display: flex; gap: 16px; flex-wrap: wrap;">
<pie-button
@click=${() => {
toaster.create({
message: 'Low Priority Info',
variant: 'info',
});
}}>
Trigger Info Toast (Low Priority)
</pie-button>
<pie-button
@click=${() => {
toaster.create({
message: 'Medium Priority Warning Toast',
variant: 'warning',
});
}}>
Trigger Warning Toast (Medium Priority)
</pie-button>
<pie-button
@click=${() => {
toaster.create({
message: 'High Priority Error Toast',
variant: 'error',
});
}}>
Trigger Error Toast (High Priority)
</pie-button>
<pie-button
@click=${() => {
toaster.create({
message: 'Actionable Info Toast',
variant: 'info',
leadingAction: { text: 'Retry' },
});
}}>
Trigger Actionable Info Toast
</pie-button>
<pie-button
@click=${() => {
toaster.create({
message: 'Persistent Toast',
duration: null,
});
}}>
Trigger Persistent Toast
</pie-button>
<pie-button
variant="secondary"
@click=${() => {
toaster.clearAll();
}}>
Clear All Toasts
</pie-button>
</div>
`;
};

export const Default = createStory<ToastProviderProps>(Template, defaultArgs)();
9 changes: 6 additions & 3 deletions apps/pie-storybook/stories/testing/pie-chip.test.stories.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { html, nothing } from 'lit';
import { ifDefined } from 'lit/directives/if-defined.js';
import { action } from '@storybook/addon-actions';
import { type Meta } from '@storybook/web-components';

import '@justeattakeaway/pie-chip';
Expand Down Expand Up @@ -87,8 +86,12 @@ const chipStoryMeta: ChipStoryMeta = {

export default chipStoryMeta;

const clickAction = action('clicked');
const closeAction = action('pie-chip-close');
const clickAction = () => {
console.log('pie-chip clicked');
};
const closeAction = () => {
console.log('pie-chip-close clicked');
};

const Template: TemplateFunction<ChipProps> = ({
aria,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
import { html } from 'lit';
import { type Meta } from '@storybook/web-components';

import '@justeattakeaway/pie-toast-provider';
import { type ToastProviderProps, defaultProps } from '@justeattakeaway/pie-toast-provider';

import { createStory } from '../../utilities';

type ToastProviderStoryMeta = Meta<ToastProviderProps>;

const defaultArgs: ToastProviderProps = {
...defaultProps,
};

const toastProviderStoryMeta: ToastProviderStoryMeta = {
title: 'Toast Provider',
component: 'pie-toast-provider',
argTypes: {
options: {
description: 'Default options for all toasts; accepts all toast props.',
control: 'object',
defaultValue: {
summary: defaultProps.options,
},
},
},
args: defaultArgs,
};

export default toastProviderStoryMeta;

const onQueueUpdate = (queue: CustomEvent) => {
console.log('toast provider queue:', queue.detail);
};

const Template = ({ options }: ToastProviderProps) => html`
<pie-toast-provider
.options="${options}"
@pie-toast-provider-queue-update="${onQueueUpdate}">
</pie-toast-provider>
`;

export const Default = createStory<ToastProviderProps>(Template, defaultArgs)();
6 changes: 3 additions & 3 deletions packages/components/pie-chip/playwright-lit.config.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { defineConfig } from '@sand4rt/experimental-ct-web';
import { getPlaywrightConfig } from '@justeattakeaway/pie-components-config';
import { defineConfig } from '@playwright/test';
import { getPlaywrightNativeConfig } from '@justeattakeaway/pie-components-config';

export default defineConfig(getPlaywrightConfig());
export default defineConfig(getPlaywrightNativeConfig());
17 changes: 5 additions & 12 deletions packages/components/pie-chip/test/accessibility/pie-chip.spec.ts
Original file line number Diff line number Diff line change
@@ -1,17 +1,10 @@
import { test, expect } from '@justeattakeaway/pie-webc-testing/src/playwright/webc-fixtures.ts';
import { PieChip, type ChipProps } from '../../src/index.ts';
import { test, expect } from '@justeattakeaway/pie-webc-testing/src/playwright/playwright-fixtures.ts';
import { BasePage } from '@justeattakeaway/pie-webc-testing/src/helpers/page-object/base-page.ts';

test.describe('PieChip - Accessibility tests', () => {
test('a11y - should test the PieChip component WCAG compliance', async ({ makeAxeBuilder, mount }) => {
await mount(
PieChip,
{
props: {} as ChipProps,
slots: {
default: 'Label',
},
},
);
test('a11y - should test the PieChip component WCAG compliance', async ({ makeAxeBuilder, page }) => {
const pieChipPage = new BasePage(page, 'chip--default');
await pieChipPage.load();

const results = await makeAxeBuilder().analyze();

Expand Down
Loading

0 comments on commit ffa1925

Please sign in to comment.