Files
tools/vue/toolkit/src/composables/browser/usePreferredReducedTransparency/index.ts
T
robonen ab6d8f6ce0
Publish to NPM / Check version changes and publish (push) Failing after 10m34s
build: bump new versions
2026-06-18 02:57:03 +07:00

31 lines
1.1 KiB
TypeScript

import { computed } from 'vue';
import type { ComputedRef } from 'vue';
import type { ConfigurableWindow } from '@/types';
import { useMediaQuery } from '@/composables/browser/useMediaQuery';
export type ReducedTransparencyType
= 'reduce' | 'no-preference';
/**
* @name usePreferredReducedTransparency
* @category Browser
* @description Reactive `prefers-reduced-transparency` media query, resolving to
* `'reduce'` or `'no-preference'`. SSR-safe (defaults to `'no-preference'`).
*
* @param {ConfigurableWindow} [options={}] Options (custom `window`)
* @returns {ComputedRef<ReducedTransparencyType>} Readonly ref of the user's transparency preference
*
* @example
* const transparency = usePreferredReducedTransparency();
* // transparency.value === 'reduce' | 'no-preference'
*
* @since 0.0.14
*/
export function usePreferredReducedTransparency(
options: ConfigurableWindow = {},
): ComputedRef<ReducedTransparencyType> {
const isReduced = useMediaQuery('(prefers-reduced-transparency: reduce)', options);
return computed<ReducedTransparencyType>(() => isReduced.value ? 'reduce' : 'no-preference');
}