Dashboard sipadu mbip
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

useMediaQuery.js 1.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. "use strict";
  2. exports.__esModule = true;
  3. exports.default = useMediaQuery;
  4. var _useIsomorphicEffect = _interopRequireDefault(require("./useIsomorphicEffect"));
  5. var _react = require("react");
  6. function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
  7. var isBool = function isBool(a) {
  8. return typeof a === 'boolean';
  9. };
  10. var matchers = new Map();
  11. var getMatcher = function getMatcher(query) {
  12. if (!query || typeof window == 'undefined') return undefined;
  13. var mql = matchers.get(query);
  14. if (!mql) {
  15. mql = window.matchMedia(query);
  16. mql.refCount = 0;
  17. matchers.set(mql.media, mql);
  18. }
  19. return mql;
  20. };
  21. /**
  22. * Match a media query and get updates as the match changes. The media string is
  23. * passed directly to `window.matchMedia` and run as a Layout Effect, so initial
  24. * matches are returned before the browser has a chance to paint.
  25. *
  26. * ```tsx
  27. * function Page() {
  28. * const isWide = useMediaQuery('min-width: 1000px')
  29. *
  30. * return isWide ? "very wide" : 'not so wide'
  31. * }
  32. * ```
  33. *
  34. * Media query lists are also reused globally, hook calls for the same query
  35. * will only create a matcher once under the hood.
  36. *
  37. * @param query A media query
  38. */
  39. function useMediaQuery(query) {
  40. var mql = getMatcher(query);
  41. var _useState = (0, _react.useState)(function () {
  42. return mql ? mql.matches : false;
  43. }),
  44. matches = _useState[0],
  45. setMatches = _useState[1];
  46. (0, _useIsomorphicEffect.default)(function () {
  47. var mql = getMatcher(query);
  48. if (!mql) {
  49. return setMatches(false);
  50. }
  51. var handleChange = function handleChange() {
  52. setMatches(mql.matches);
  53. };
  54. mql.refCount++;
  55. mql.addListener(handleChange);
  56. handleChange();
  57. return function () {
  58. mql.removeListener(handleChange);
  59. mql.refCount--;
  60. if (mql.refCount <= 0) {
  61. matchers.delete(mql.media);
  62. }
  63. mql = undefined;
  64. };
  65. }, [query]);
  66. return matches;
  67. }