UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

126 lines (125 loc) 4.35 kB
"use client"; import _defineProperty from "@babel/runtime/helpers/esm/defineProperty"; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } import "core-js/modules/web.dom-collections.iterator.js"; import React, { useContext, useEffect, useMemo, useRef, useState } from 'react'; import Context from './Context'; import { makeMediaQueryList, createMediaQueryListener, isMatchMediaSupported } from './MediaQueryUtils'; import { toPascalCase } from './component-helper'; const makeLayoutEffect = () => { return typeof window === 'undefined' ? useEffect : window['__SSR_TEST__'] ? () => null : React.useLayoutEffect; }; export const defaultQueries = { small: { min: 0, max: 'small' }, medium: { min: 'small', max: 'medium' }, large: { min: 'medium' } }; export default function useMedia() { let props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; const { initialValue = null, disabled, correctRange = true, breakpoints, queries = defaultQueries, log } = props; const context = useContext(Context); const refs = useRef({}); const defaults = useRef({}); const isMounted = useRef(false); const isDisabled = useRef(disabled); const [result, updateRerender] = useState(makeResult); const useLayoutEffect = useMemo(makeLayoutEffect, []); useLayoutEffect(() => { if (!isMounted.current) { isMounted.current = true; updateRerender(makeResult()); } return removeListeners; }, []); useLayoutEffect(() => { if (isDisabled.current && !disabled) { updateRerender(makeResult()); } isDisabled.current = disabled; }, [disabled]); return result; function removeListeners() { Object.entries(refs.current).forEach(_ref => { var _item$event; let [key, item] = _ref; item === null || item === void 0 ? void 0 : (_item$event = item.event) === null || _item$event === void 0 ? void 0 : _item$event.call(item); delete refs.current[key]; }); } function makeResult() { return Object.entries(queries).reduce((acc, _ref2) => { var _item$mediaQueryList; let [k, when] = _ref2; const key = k; const name = `is${toPascalCase(key)}`; if (disabled) { acc[name] = false; return acc; } defaults.current[name] = false; const item = runQuery({ when, name, key }); const hasMatch = !isMounted.current ? typeof (initialValue === null || initialValue === void 0 ? void 0 : initialValue[name]) !== 'undefined' ? initialValue[name] : false : (item === null || item === void 0 ? void 0 : (_item$mediaQueryList = item.mediaQueryList) === null || _item$mediaQueryList === void 0 ? void 0 : _item$mediaQueryList.matches) || false; acc[name] = hasMatch; if (hasMatch) { acc.key = key; } refs.current[key] = item; return acc; }, { isSSR: !isMatchMediaSupported(), key: null }); } function runQuery(_ref3) { let { when, name, key } = _ref3; if (!isMatchMediaSupported()) { return; } const mediaQueryList = makeMediaQueryList({ when }, breakpoints || context.breakpoints, { disabled, correctRange, log }); const event = createMediaQueryListener(mediaQueryList, match => { if (!isDisabled.current && match) { const state = _objectSpread(_objectSpread({}, defaults.current), {}, { key, isSSR: result.isSSR }); state[name] = match; updateRerender(state); } }); return { event, mediaQueryList }; } } //# sourceMappingURL=useMedia.js.map