diff --git a/packages/showcases/core/csf/components/overlays/alert.csf.js b/packages/showcases/core/csf/components/overlays/alert.csf.js index 8698bd2c9..578601f76 100644 --- a/packages/showcases/core/csf/components/overlays/alert.csf.js +++ b/packages/showcases/core/csf/components/overlays/alert.csf.js @@ -32,4 +32,13 @@ export const argTypes = { defaultValue: undefined, control: { type: 'text' }, }, + + timeout: { + type: { name: 'number', required: false }, + description: 'Duration of the animation', + defaultValue: 8000, + control: { + type: 'number', + }, + }, }; diff --git a/packages/showcases/core/csf/components/overlays/snackbar.csf.js b/packages/showcases/core/csf/components/overlays/snackbar.csf.js index ddbdb510a..68a18fae6 100644 --- a/packages/showcases/core/csf/components/overlays/snackbar.csf.js +++ b/packages/showcases/core/csf/components/overlays/snackbar.csf.js @@ -9,12 +9,6 @@ export const parameters = { }; export const argTypes = { - content: { - type: { name: 'string', required: true }, - description: 'Text displayed on the snackbar', - defaultValue: 'This is the content of a snackbar', - control: { type: 'text' }, - }, withCloseButton: { type: { name: 'boolean', required: false }, description: 'Show close button', @@ -31,4 +25,12 @@ export const argTypes = { type: 'text', }, }, + timeout: { + type: { name: 'number', required: false }, + description: 'Duration of the animation', + defaultValue: 4500, + control: { + type: 'number', + }, + }, }; diff --git a/packages/showcases/core/csf/components/overlays/toast.csf.js b/packages/showcases/core/csf/components/overlays/toast.csf.js index bc6fc9fba..bbd4d3314 100644 --- a/packages/showcases/core/csf/components/overlays/toast.csf.js +++ b/packages/showcases/core/csf/components/overlays/toast.csf.js @@ -9,12 +9,6 @@ export const parameters = { }; export const argTypes = { - content: { - type: { name: 'string', required: true }, - description: 'Text displayed on the toast', - defaultValue: 'This is the content of a toast', - control: { type: 'text' }, - }, withCloseButton: { type: { name: 'boolean', required: false }, description: 'Show close button', @@ -31,4 +25,12 @@ export const argTypes = { type: 'boolean', }, }, + timeout: { + type: { name: 'number', required: false }, + description: 'Duration of the animation', + defaultValue: 4500, + control: { + type: 'number', + }, + }, }; diff --git a/packages/showcases/react/stories/components/overlays/VtmnAlert/VtmnAlert.stories.tsx b/packages/showcases/react/stories/components/overlays/VtmnAlert/VtmnAlert.stories.tsx index a4374154b..0ba28c52b 100644 --- a/packages/showcases/react/stories/components/overlays/VtmnAlert/VtmnAlert.stories.tsx +++ b/packages/showcases/react/stories/components/overlays/VtmnAlert/VtmnAlert.stories.tsx @@ -7,6 +7,8 @@ import { import { VtmnAlert } from '@vtmn/react'; import { VtmnButton } from '@vtmn/react'; +const CSS_ANIMATION_TIME_MS = 700; + export default { title: 'Components / Overlays / VtmnAlert', component: VtmnAlert, @@ -21,7 +23,7 @@ const OverviewTemplate: Story = (args) => { if (showAlert) { const timeout = setTimeout(() => { setShowAlert(false); - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); return () => clearTimeout(timeout); } }, [showAlert]); diff --git a/packages/showcases/react/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.tsx b/packages/showcases/react/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.tsx index bcc384297..c541c54b7 100644 --- a/packages/showcases/react/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.tsx +++ b/packages/showcases/react/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.tsx @@ -7,10 +7,20 @@ import { import { VtmnSnackbar } from '@vtmn/react'; import { VtmnButton } from '@vtmn/react'; +const CSS_ANIMATION_TIME_MS = 500; + export default { title: 'Components / Overlays / VtmnSnackbar', component: VtmnSnackbar, - argTypes, + argTypes: { + ...argTypes, + content: { + type: { name: 'string', required: true }, + description: 'Text displayed on the toast', + defaultValue: 'This is the content of a toast', + control: { type: 'text' }, + }, + }, parameters, } as Meta; @@ -21,7 +31,7 @@ const OverviewTemplate: Story = (args) => { if (showSnackbar) { const timeout = setTimeout(() => { setshowSnackbar(false); - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); return () => clearTimeout(timeout); } }, [showSnackbar]); diff --git a/packages/showcases/react/stories/components/overlays/VtmnToast/VtmnToast.stories.tsx b/packages/showcases/react/stories/components/overlays/VtmnToast/VtmnToast.stories.tsx index f35320739..deefb2f21 100644 --- a/packages/showcases/react/stories/components/overlays/VtmnToast/VtmnToast.stories.tsx +++ b/packages/showcases/react/stories/components/overlays/VtmnToast/VtmnToast.stories.tsx @@ -7,10 +7,20 @@ import { import { VtmnToast } from '@vtmn/react'; import { VtmnButton } from '@vtmn/react'; +const CSS_ANIMATION_TIME_MS = 500; + export default { title: 'Components / Overlays / VtmnToast', component: VtmnToast, - argTypes, + argTypes: { + ...argTypes, + content: { + type: { name: 'string', required: true }, + description: 'Text displayed on the snackbar', + defaultValue: 'This is the content of a snackbar', + control: { type: 'text' }, + }, + }, parameters, } as Meta; @@ -21,7 +31,7 @@ const OverviewTemplate: Story = (args) => { if (showToast) { const timeout = setTimeout(() => { setshowToast(false); - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); return () => clearTimeout(timeout); } }, [showToast]); diff --git a/packages/showcases/svelte/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.svelte b/packages/showcases/svelte/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.svelte index f93c77976..1578e8802 100644 --- a/packages/showcases/svelte/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.svelte +++ b/packages/showcases/svelte/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.svelte @@ -11,17 +11,7 @@ ({ showAlert.value = true; setTimeout(() => { showAlert.value = false; - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); }, args, }; diff --git a/packages/showcases/vue/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.js b/packages/showcases/vue/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.js index e12ea97ff..8ab7d04f8 100644 --- a/packages/showcases/vue/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.js +++ b/packages/showcases/vue/stories/components/overlays/VtmnSnackbar/VtmnSnackbar.stories.js @@ -1,28 +1,16 @@ import { ref } from 'vue'; import { VtmnSnackbar, VtmnButton } from '@vtmn/vue'; -import { parameters } from '@vtmn/showcase-core/csf/components/overlays/snackbar.csf'; +import { + parameters, + argTypes, +} from '@vtmn/showcase-core/csf/components/overlays/snackbar.csf'; + +const CSS_ANIMATION_TIME_MS = 500; export default { title: 'Components / Overlays / VtmnSnackbar', component: VtmnSnackbar, - argTypes: { - withCloseButton: { - type: { name: 'boolean', required: true }, - description: 'Show close button', - defaultValue: false, - control: { - type: 'boolean', - }, - }, - actionLabel: { - type: { name: 'string', required: false }, - describe: 'Label of the action. If set, it displays action button', - defaultValue: undefined, - control: { - type: 'text', - }, - }, - }, + argTypes, parameters, }; @@ -37,7 +25,7 @@ const Template = (args) => ({ showSnackbar.value = true; setTimeout(() => { showSnackbar.value = false; - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); }, args, }; diff --git a/packages/showcases/vue/stories/components/overlays/VtmnToast/VtmnToast.stories.js b/packages/showcases/vue/stories/components/overlays/VtmnToast/VtmnToast.stories.js index 618608d52..afb15acf7 100644 --- a/packages/showcases/vue/stories/components/overlays/VtmnToast/VtmnToast.stories.js +++ b/packages/showcases/vue/stories/components/overlays/VtmnToast/VtmnToast.stories.js @@ -1,28 +1,16 @@ import { ref } from 'vue'; import { VtmnToast, VtmnButton } from '@vtmn/vue'; -import { parameters } from '@vtmn/showcase-core/csf/components/overlays/toast.csf'; +import { + parameters, + argTypes, +} from '@vtmn/showcase-core/csf/components/overlays/toast.csf'; + +const CSS_ANIMATION_TIME_MS = 500; export default { title: 'Components / Overlays / VtmnToast', component: VtmnToast, - argTypes: { - withCloseButton: { - type: { name: 'boolean', required: false }, - description: 'Show close button', - defaultValue: false, - control: { - type: 'boolean', - }, - }, - withIcon: { - type: { name: 'boolean', required: false }, - description: 'Display left icon', - defaultValue: false, - control: { - type: 'boolean', - }, - }, - }, + argTypes, parameters, }; @@ -37,7 +25,7 @@ const Template = (args) => ({ showToast.value = true; setTimeout(() => { showToast.value = false; - }, 8000); + }, args.timeout + CSS_ANIMATION_TIME_MS); }, args, }; diff --git a/packages/sources/react/src/components/overlays/VtmnAlert/VtmnAlert.tsx b/packages/sources/react/src/components/overlays/VtmnAlert/VtmnAlert.tsx index 2080fb721..2aeb00ec0 100644 --- a/packages/sources/react/src/components/overlays/VtmnAlert/VtmnAlert.tsx +++ b/packages/sources/react/src/components/overlays/VtmnAlert/VtmnAlert.tsx @@ -4,6 +4,8 @@ import { VtmnAlertVariant } from './types'; import clsx from 'clsx'; import { VtmnButton } from '../../actions/VtmnButton'; +const INFINITE_TIMEOUT_MS = 9999000; + export interface VtmnAlertProps extends Omit, 'onClose'> { /** @@ -48,14 +50,20 @@ export const VtmnAlert = ({ timeout = 8000, className, }: VtmnAlertProps) => { + const propertyStyle: Record = { + '--vtmn-animation_alert-duration': `${ + timeout < Infinity ? timeout : INFINITE_TIMEOUT_MS + }ms`, + }; return (
0 && 'show', + timeout > 0 && 'show animate-delay', className, )} > diff --git a/packages/sources/react/src/components/overlays/VtmnSnackbar/VtmnSnackbar.tsx b/packages/sources/react/src/components/overlays/VtmnSnackbar/VtmnSnackbar.tsx index 521e802b2..b7cdb5d69 100644 --- a/packages/sources/react/src/components/overlays/VtmnSnackbar/VtmnSnackbar.tsx +++ b/packages/sources/react/src/components/overlays/VtmnSnackbar/VtmnSnackbar.tsx @@ -3,6 +3,8 @@ import '@vtmn/css-snackbar/dist/index-with-vars.css'; import clsx from 'clsx'; import { VtmnButton } from '../../actions/VtmnButton'; +const INFINITE_TIMEOUT_MS = 9999000; + export interface VtmnSnackbarProps extends Omit, 'onClose'> { /** @@ -20,6 +22,11 @@ export interface VtmnSnackbarProps */ withCloseButton?: boolean; + /** + * Duration of the snackbar in ms + */ + timeout?: number; + /** * The alert callback close function * @type {function} @@ -33,11 +40,22 @@ export const VtmnSnackbar = ({ withCloseButton = false, onClose, className, + timeout = 4500, }: VtmnSnackbarProps) => { + const propertyStyle: Record = { + '--vtmn-animation_overlay-duration': `${ + timeout < Infinity ? timeout : INFINITE_TIMEOUT_MS + }ms`, + }; return (
0 && 'show animate-delay', + className, + )} onClick={onClose} >
{content}
diff --git a/packages/sources/react/src/components/overlays/VtmnToast/VtmnToast.tsx b/packages/sources/react/src/components/overlays/VtmnToast/VtmnToast.tsx index 762422dc5..23df2d81c 100644 --- a/packages/sources/react/src/components/overlays/VtmnToast/VtmnToast.tsx +++ b/packages/sources/react/src/components/overlays/VtmnToast/VtmnToast.tsx @@ -3,6 +3,8 @@ import '@vtmn/css-toast/dist/index-with-vars.css'; import clsx from 'clsx'; import { VtmnButton } from '../../actions/VtmnButton'; +const INFINITE_TIMEOUT_MS = 9999000; + export interface VtmnToastProps extends Omit, 'onClose'> { /** @@ -20,6 +22,11 @@ export interface VtmnToastProps */ withCloseButton?: boolean; + /** + * Duration of the toast in ms + */ + timeout?: number; + /** * The alert callback close function * @type {function} @@ -33,13 +40,20 @@ export const VtmnToast = ({ withCloseButton = false, onClose, className, + timeout = 4500, }: VtmnToastProps) => { + const propertyStyle: Record = { + '--vtmn-animation_overlay-duration': `${ + timeout < Infinity ? timeout : INFINITE_TIMEOUT_MS + }ms`, + }; return (
0 && 'show animate-delay', withIcon && 'vtmn-toast--with-icon-info', className, )} diff --git a/packages/sources/vue/src/components/overlays/VtmnAlert/VtmnAlert.vue b/packages/sources/vue/src/components/overlays/VtmnAlert/VtmnAlert.vue index 96113aaaa..74ff79dda 100644 --- a/packages/sources/vue/src/components/overlays/VtmnAlert/VtmnAlert.vue +++ b/packages/sources/vue/src/components/overlays/VtmnAlert/VtmnAlert.vue @@ -4,6 +4,8 @@ import { computed, defineComponent, PropType, reactive } from 'vue'; import { VtmnAlertVariant } from './types'; import { VtmnButton } from '../../index'; +const INFINITE_TIMEOUT_MS = 9999000; + export default /*#__PURE__*/ defineComponent({ name: 'VtmnAlert', components: { VtmnButton }, @@ -49,9 +51,16 @@ export default /*#__PURE__*/ defineComponent({ return { classes: computed(() => ({ 'vtmn-alert': true, - show: props.timeout > 0, + 'show animate-delay': props.timeout > 0, [`vtmn-alert_variant--${props.variant}`]: props.variant, })), + style: { + '--vtmn-animation_alert-duration': `${ + typeof props.timeout === 'number' && props.timeout < Infinity + ? props.timeout + : INFINITE_TIMEOUT_MS + }ms`, + }, handleClose, }; }, @@ -59,7 +68,13 @@ export default /*#__PURE__*/ defineComponent({