From 6db035bfdfa7fbf30e3c06b8fe9f659e0fa5e23e Mon Sep 17 00:00:00 2001 From: Yann Braga Date: Fri, 22 Jan 2021 18:31:20 +0100 Subject: [PATCH] feat(addon-backgrounds): reduced motion disables transition - addon backgrounds should respect the user's configuration - so it disables transition transition animation when requested --- addons/backgrounds/src/decorators/withBackground.ts | 10 ++++++++-- addons/backgrounds/src/helpers/index.ts | 7 ++++++- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/addons/backgrounds/src/decorators/withBackground.ts b/addons/backgrounds/src/decorators/withBackground.ts index defad6f99c71..26ce596afc29 100644 --- a/addons/backgrounds/src/decorators/withBackground.ts +++ b/addons/backgrounds/src/decorators/withBackground.ts @@ -1,7 +1,12 @@ import { StoryFn as StoryFunction, StoryContext, useMemo, useEffect } from '@storybook/addons'; import { PARAM_KEY as BACKGROUNDS_PARAM_KEY } from '../constants'; -import { clearStyles, addBackgroundStyle, getBackgroundColorByName } from '../helpers'; +import { + clearStyles, + addBackgroundStyle, + getBackgroundColorByName, + isReduceMotionEnabled, +} from '../helpers'; export const withBackground = (StoryFn: StoryFunction, context: StoryContext) => { const { globals, parameters } = context; @@ -29,10 +34,11 @@ export const withBackground = (StoryFn: StoryFunction, context: StoryContext) => context.viewMode === 'docs' ? `#anchor--${context.id} .docs-story` : '.sb-show-main'; const backgroundStyles = useMemo(() => { + const transitionStyle = 'transition: background-color 0.3s;'; return ` ${selector} { background: ${selectedBackgroundColor} !important; - transition: background-color 0.3s; + ${isReduceMotionEnabled() ? '' : transitionStyle} } `; }, [selectedBackgroundColor, selector]); diff --git a/addons/backgrounds/src/helpers/index.ts b/addons/backgrounds/src/helpers/index.ts index 3b1d00f237f5..9b35c8acea87 100644 --- a/addons/backgrounds/src/helpers/index.ts +++ b/addons/backgrounds/src/helpers/index.ts @@ -5,7 +5,12 @@ import { logger } from '@storybook/client-logger'; import { Background } from '../types'; -const { document } = global; +const { document, window } = global; + +export const isReduceMotionEnabled = () => { + const prefersReduceMotion = window.matchMedia('(prefers-reduced-motion: reduce)'); + return prefersReduceMotion.matches; +}; export const getBackgroundColorByName = ( currentSelectedValue: string,