diff --git a/packages/components/snackbar/src/snackbar.ts b/packages/components/snackbar/src/snackbar.ts index caef015a..46e51e64 100644 --- a/packages/components/snackbar/src/snackbar.ts +++ b/packages/components/snackbar/src/snackbar.ts @@ -2,7 +2,7 @@ import { buildProps } from '@puik/utils' import type { ExtractPropTypes, PropType } from 'vue' import type Snackbar from './snackbar.vue' -export const snackbarVariants = ['default', 'danger'] as const +export const snackbarVariants = ['default', 'danger', 'success'] as const export type PuikSnackbarVariant = (typeof snackbarVariants)[number] export interface SnackbarAction { diff --git a/packages/components/snackbar/stories/snackbar.stories.ts b/packages/components/snackbar/stories/snackbar.stories.ts index b46ccf49..ad7967cf 100644 --- a/packages/components/snackbar/stories/snackbar.stories.ts +++ b/packages/components/snackbar/stories/snackbar.stories.ts @@ -119,12 +119,18 @@ const WithoutActionTemplate: StoryFn = () => ({ text: 'Unable to update settings.', variant: 'danger', }) - return { displaySnackbar, displayErrorSnackbar } + const displaySuccessSnackbar = () => + PuikSnackbar({ + text: 'Settings updated successfully.', + variant: 'success', + }) + return { displaySnackbar, displayErrorSnackbar, displaySuccessSnackbar } }, template: `
Display Snackbar Display Error Snackbar + Display Success Snackbar
`, }) @@ -139,6 +145,7 @@ export const WithoutAction: StoryObj = { @@ -179,6 +191,13 @@ const displayErrorSnackbar = () => close + +
+ Settings updated successfully. + +
`, language: 'html', }, @@ -208,12 +227,22 @@ const WithActionTemplate: StoryFn = () => ({ callback: action('Error snackbar action callback function'), }, }) - return { displaySnackbar, displayErrorSnackbar } + const displaySuccessSnackbar = () => + PuikSnackbar({ + text: 'Settings updated successfully.', + variant: 'success', + action: { + label: 'Cancel', + callback: action('Success snackbar action callback function'), + }, + }) + return { displaySnackbar, displayErrorSnackbar, displaySuccessSnackbar } }, template: `
Display Snackbar Display Error Snackbar + Display Success Snackbar
`, }) @@ -228,6 +257,7 @@ export const WithAction: StoryObj = { @@ -278,6 +317,14 @@ export const WithAction: StoryObj = { close + +
+ Settings updated successfully. + + +
`, language: 'html', }, diff --git a/packages/components/snackbar/test/snackbar.spec.ts b/packages/components/snackbar/test/snackbar.spec.ts index e851b600..afa5abf5 100644 --- a/packages/components/snackbar/test/snackbar.spec.ts +++ b/packages/components/snackbar/test/snackbar.spec.ts @@ -66,6 +66,14 @@ describe('Snackbar tests', () => { expect(findAction().exists()).toBeFalsy() }) + it('should be a success snackbar without action', () => { + const text = faker.lorem.sentence() + factory({ text, variant: 'success' }) + expect(findText().text()).toEqual(text) + expect(findSnackbar().classes()).toContain('puik-snackbar--success') + expect(findAction().exists()).toBeFalsy() + }) + it('should be a dangerous snackbar with action', async () => { const text = faker.lorem.sentence() const label = faker.lorem.word() @@ -86,6 +94,26 @@ describe('Snackbar tests', () => { expect(callback).toBeCalled() }) + it('should be a success snackbar with action', async () => { + const text = faker.lorem.sentence() + const label = faker.lorem.word() + const callback = vi.fn() + factory({ + text, + action: { + label, + callback, + }, + variant: 'success', + }) + expect(findAction().exists()).toBeTruthy() + expect(findText().text()).toEqual(text) + expect(findSnackbar().classes()).toContain('puik-snackbar--success') + expect(findAction().text()).toEqual(label) + await findAction().trigger('click') + expect(callback).toBeCalled() + }) + it('should close the snackbar when clicking on the close button', async () => { const text = faker.lorem.sentence() await factory({ text }) diff --git a/packages/theme/src/snackbar.scss b/packages/theme/src/snackbar.scss index 6d4010ba..6fcccda0 100644 --- a/packages/theme/src/snackbar.scss +++ b/packages/theme/src/snackbar.scss @@ -9,6 +9,10 @@ @apply bg-red-500; } + &--success { + @apply bg-green-500; + } + &__text { @apply font-primary flex-grow; }