diff --git a/CHANGELOG.md b/CHANGELOG.md index bc60bb4..b3b9ccd 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,15 +2,23 @@ ### v9.0.0 -#### Beta9 +- Convert project to typescript +- Upgrade to Webpack 5 +- Fix a memory leak with useMediaQuery hook +- Add support for React 18 +- Add docs webpage + +### v9.0.0-beta + +#### Beta 9 - Fix typescript output -#### Beta8 +#### Beta 8 - Fix webpack bundle issue (self is not defined) -#### Beta7 +#### Beta 7 - Improve typescript typings - Add typing support for React 18 @@ -18,7 +26,7 @@ - Upgrade to Webpack 5 - Fix a bug with React 18 not re-rendering -#### Beta6 +#### Beta 6 - Convert project to typescript - Remove UMD build from project diff --git a/dist/react-responsive.min.js.map b/dist/react-responsive.min.js.map index 2781b55..1c01690 100644 --- a/dist/react-responsive.min.js.map +++ b/dist/react-responsive.min.js.map @@ -1 +1 @@ -{"version":3,"file":"react-responsive.min.js","mappings":"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","sources":["webpack://MediaQuery/webpack/universalModuleDefinition","webpack://MediaQuery/./node_modules/css-mediaquery/index.js","webpack://MediaQuery/./node_modules/hyphenate-style-name/index.js","webpack://MediaQuery/./node_modules/matchmediaquery/index.js","webpack://MediaQuery/./node_modules/prop-types/factoryWithThrowingShims.js","webpack://MediaQuery/./node_modules/prop-types/index.js","webpack://MediaQuery/./node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack://MediaQuery/./node_modules/shallow-equal/dist/index.esm.js","webpack://MediaQuery/./src/Component.ts","webpack://MediaQuery/./src/Context.ts","webpack://MediaQuery/./src/index.ts","webpack://MediaQuery/./src/mediaQuery.ts","webpack://MediaQuery/./src/toQuery.ts","webpack://MediaQuery/./src/useMediaQuery.ts","webpack://MediaQuery/external umd {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}","webpack://MediaQuery/webpack/bootstrap","webpack://MediaQuery/webpack/runtime/define property getters","webpack://MediaQuery/webpack/runtime/hasOwnProperty shorthand","webpack://MediaQuery/webpack/runtime/make namespace object","webpack://MediaQuery/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MediaQuery\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"MediaQuery\"] = factory(root[\"React\"]);\n})(this, (__WEBPACK_EXTERNAL_MODULE__359__) => {\nreturn ","/*\nCopyright (c) 2014, Yahoo! Inc. All rights reserved.\nCopyrights licensed under the New BSD License.\nSee the accompanying LICENSE file for terms.\n*/\n\n'use strict';\n\nexports.match = matchQuery;\nexports.parse = parseQuery;\n\n// -----------------------------------------------------------------------------\n\nvar RE_MEDIA_QUERY = /(?:(only|not)?\\s*([^\\s\\(\\)]+)(?:\\s*and)?\\s*)?(.+)?/i,\n RE_MQ_EXPRESSION = /\\(\\s*([^\\s\\:\\)]+)\\s*(?:\\:\\s*([^\\s\\)]+))?\\s*\\)/,\n RE_MQ_FEATURE = /^(?:(min|max)-)?(.+)/,\n RE_LENGTH_UNIT = /(em|rem|px|cm|mm|in|pt|pc)?$/,\n RE_RESOLUTION_UNIT = /(dpi|dpcm|dppx)?$/;\n\nfunction matchQuery(mediaQuery, values) {\n return parseQuery(mediaQuery).some(function (query) {\n var inverse = query.inverse;\n\n // Either the parsed or specified `type` is \"all\", or the types must be\n // equal for a match.\n var typeMatch = query.type === 'all' || values.type === query.type;\n\n // Quit early when `type` doesn't match, but take \"not\" into account.\n if ((typeMatch && inverse) || !(typeMatch || inverse)) {\n return false;\n }\n\n var expressionsMatch = query.expressions.every(function (expression) {\n var feature = expression.feature,\n modifier = expression.modifier,\n expValue = expression.value,\n value = values[feature];\n\n // Missing or falsy values don't match.\n if (!value) { return false; }\n\n switch (feature) {\n case 'orientation':\n case 'scan':\n return value.toLowerCase() === expValue.toLowerCase();\n\n case 'width':\n case 'height':\n case 'device-width':\n case 'device-height':\n expValue = toPx(expValue);\n value = toPx(value);\n break;\n\n case 'resolution':\n expValue = toDpi(expValue);\n value = toDpi(value);\n break;\n\n case 'aspect-ratio':\n case 'device-aspect-ratio':\n case /* Deprecated */ 'device-pixel-ratio':\n expValue = toDecimal(expValue);\n value = toDecimal(value);\n break;\n\n case 'grid':\n case 'color':\n case 'color-index':\n case 'monochrome':\n expValue = parseInt(expValue, 10) || 1;\n value = parseInt(value, 10) || 0;\n break;\n }\n\n switch (modifier) {\n case 'min': return value >= expValue;\n case 'max': return value <= expValue;\n default : return value === expValue;\n }\n });\n\n return (expressionsMatch && !inverse) || (!expressionsMatch && inverse);\n });\n}\n\nfunction parseQuery(mediaQuery) {\n return mediaQuery.split(',').map(function (query) {\n query = query.trim();\n\n var captures = query.match(RE_MEDIA_QUERY),\n modifier = captures[1],\n type = captures[2],\n expressions = captures[3] || '',\n parsed = {};\n\n parsed.inverse = !!modifier && modifier.toLowerCase() === 'not';\n parsed.type = type ? type.toLowerCase() : 'all';\n\n // Split expressions into a list.\n expressions = expressions.match(/\\([^\\)]+\\)/g) || [];\n\n parsed.expressions = expressions.map(function (expression) {\n var captures = expression.match(RE_MQ_EXPRESSION),\n feature = captures[1].toLowerCase().match(RE_MQ_FEATURE);\n\n return {\n modifier: feature[1],\n feature : feature[2],\n value : captures[2]\n };\n });\n\n return parsed;\n });\n}\n\n// -- Utilities ----------------------------------------------------------------\n\nfunction toDecimal(ratio) {\n var decimal = Number(ratio),\n numbers;\n\n if (!decimal) {\n numbers = ratio.match(/^(\\d+)\\s*\\/\\s*(\\d+)$/);\n decimal = numbers[1] / numbers[2];\n }\n\n return decimal;\n}\n\nfunction toDpi(resolution) {\n var value = parseFloat(resolution),\n units = String(resolution).match(RE_RESOLUTION_UNIT)[1];\n\n switch (units) {\n case 'dpcm': return value / 2.54;\n case 'dppx': return value * 96;\n default : return value;\n }\n}\n\nfunction toPx(length) {\n var value = parseFloat(length),\n units = String(length).match(RE_LENGTH_UNIT)[1];\n\n switch (units) {\n case 'em' : return value * 16;\n case 'rem': return value * 16;\n case 'cm' : return value * 96 / 2.54;\n case 'mm' : return value * 96 / 2.54 / 10;\n case 'in' : return value * 96;\n case 'pt' : return value * 72;\n case 'pc' : return value * 72 / 12;\n default : return value;\n }\n}\n","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","'use strict';\n\nvar staticMatch = require('css-mediaquery').match;\nvar dynamicMatch = typeof window !== 'undefined' ? window.matchMedia : null;\n\n// our fake MediaQueryList\nfunction Mql(query, values, forceStatic){\n var self = this;\n if(dynamicMatch && !forceStatic){\n var mql = dynamicMatch.call(window, query);\n this.matches = mql.matches;\n this.media = mql.media;\n // TODO: is there a time it makes sense to remove this listener?\n mql.addListener(update);\n } else {\n this.matches = staticMatch(query, values);\n this.media = query;\n }\n\n this.addListener = addListener;\n this.removeListener = removeListener;\n this.dispose = dispose;\n\n function addListener(listener){\n if(mql){\n mql.addListener(listener);\n }\n }\n\n function removeListener(listener){\n if(mql){\n mql.removeListener(listener);\n }\n }\n\n // update ourselves!\n function update(evt){\n self.matches = evt.matches;\n self.media = evt.media;\n }\n\n function dispose(){\n if(mql){\n mql.removeListener(update);\n }\n }\n}\n\nfunction matchMedia(query, values, forceStatic){\n return new Mql(query, values, forceStatic);\n}\n\nmodule.exports = matchMedia;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","function shallowEqualObjects(objA, objB) {\n if (objA === objB) {\n return true;\n }\n\n if (!objA || !objB) {\n return false;\n }\n\n var aKeys = Object.keys(objA);\n var bKeys = Object.keys(objB);\n var len = aKeys.length;\n\n if (bKeys.length !== len) {\n return false;\n }\n\n for (var i = 0; i < len; i++) {\n var key = aKeys[i];\n\n if (objA[key] !== objB[key] || !Object.prototype.hasOwnProperty.call(objB, key)) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction shallowEqualArrays(arrA, arrB) {\n if (arrA === arrB) {\n return true;\n }\n\n if (!arrA || !arrB) {\n return false;\n }\n\n var len = arrA.length;\n\n if (arrB.length !== len) {\n return false;\n }\n\n for (var i = 0; i < len; i++) {\n if (arrA[i] !== arrB[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nexport { shallowEqualArrays, shallowEqualObjects };\n","import useMediaQuery from './useMediaQuery';\nimport { ReactNode, FC, CSSProperties } from 'react';\nimport { MediaQueryAllQueryable, MediaQueryMatchers } from './types';\n\ninterface MediaQueryProps extends MediaQueryAllQueryable {\n component?: ReactNode\n // eslint-disable-next-line @typescript-eslint/ban-types\n children?: ReactNode | Function;\n query?: string;\n style?: CSSProperties;\n className?: string;\n device?: MediaQueryMatchers;\n values?: Partial;\n onBeforeChange?: (_matches: boolean) => void;\n onChange?: (_matches: boolean) => void;\n}\n\nconst MediaQuery: FC = ({\n children,\n device,\n onChange,\n ...settings\n}) => {\n const matches = useMediaQuery(settings, device, onChange);\n\n if (typeof children === 'function') {\n return children(matches);\n }\n return matches ? children : null;\n};\n\nexport default MediaQuery;\n","import { createContext } from 'react'\nimport { MediaQueryAllQueryable } from './types'\n\nconst Context = createContext | undefined>(undefined)\n\nexport default Context\n","import useMediaQuery from './useMediaQuery'\nimport MediaQuery from './Component'\nimport toQuery from './toQuery'\nimport Context from './Context'\n\nexport {\n MediaQuery as default,\n useMediaQuery,\n toQuery,\n Context\n}\n\nexport type {\n MediaQueryTypes,\n MediaQueryType,\n MediaQueryFeatures,\n MediaQueryAllQueryable\n} from './types'\n","import PropTypes from 'prop-types'\n\nconst stringOrNumber = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number\n])\n\n// media types\nconst types = {\n all: PropTypes.bool,\n grid: PropTypes.bool,\n aural: PropTypes.bool,\n braille: PropTypes.bool,\n handheld: PropTypes.bool,\n print: PropTypes.bool,\n projection: PropTypes.bool,\n screen: PropTypes.bool,\n tty: PropTypes.bool,\n tv: PropTypes.bool,\n embossed: PropTypes.bool\n}\n\n// properties that match media queries\nconst matchers = {\n orientation: PropTypes.oneOf([\n 'portrait',\n 'landscape'\n ]),\n\n scan: PropTypes.oneOf([\n 'progressive',\n 'interlace'\n ]),\n\n aspectRatio: PropTypes.string,\n deviceAspectRatio: PropTypes.string,\n\n height: stringOrNumber,\n deviceHeight: stringOrNumber,\n\n width: stringOrNumber,\n deviceWidth: stringOrNumber,\n\n color: PropTypes.bool,\n\n colorIndex: PropTypes.bool,\n\n monochrome: PropTypes.bool,\n resolution: stringOrNumber,\n type: Object.keys(types)\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst { type, ...featureMatchers } = matchers\n\n// media features\nconst features = {\n minAspectRatio: PropTypes.string,\n maxAspectRatio: PropTypes.string,\n minDeviceAspectRatio: PropTypes.string,\n maxDeviceAspectRatio: PropTypes.string,\n\n minHeight: stringOrNumber,\n maxHeight: stringOrNumber,\n minDeviceHeight: stringOrNumber,\n maxDeviceHeight: stringOrNumber,\n\n minWidth: stringOrNumber,\n maxWidth: stringOrNumber,\n minDeviceWidth: stringOrNumber,\n maxDeviceWidth: stringOrNumber,\n\n minColor: PropTypes.number,\n maxColor: PropTypes.number,\n\n minColorIndex: PropTypes.number,\n maxColorIndex: PropTypes.number,\n\n minMonochrome: PropTypes.number,\n maxMonochrome: PropTypes.number,\n\n minResolution: stringOrNumber,\n maxResolution: stringOrNumber,\n\n ...featureMatchers\n}\n\nconst all = { ...types, ...features }\n\nexport default {\n all: all,\n types: types,\n matchers: matchers,\n features: features\n}\n","import hyphenate from 'hyphenate-style-name'\nimport mq from './mediaQuery'\nimport { MediaQueryAllQueryable } from './types'\n\nconst negate = (cond: string) => `not ${cond}`\n\nconst keyVal = (k: string, v: unknown): string => {\n const realKey = hyphenate(k)\n\n // px shorthand\n if (typeof v === 'number') {\n v = `${v}px`\n }\n if (v === true) {\n return realKey\n }\n if (v === false) {\n return negate(realKey)\n }\n return `(${realKey}: ${v})`\n}\n\nconst join = (conds: string[]): string => conds.join(' and ')\n\nconst toQuery = (obj: Partial): string => {\n const rules: string[] = []\n Object.keys(mq.all).forEach((k) => {\n const v = obj[k as keyof MediaQueryAllQueryable]\n if (v != null) {\n rules.push(keyVal(k, v))\n }\n })\n return join(rules)\n}\n\nexport default toQuery\n","import { useRef, useEffect, useContext, useState } from 'react'\nimport matchMedia from 'matchmediaquery'\nimport hyphenate from 'hyphenate-style-name'\nimport { shallowEqualObjects } from 'shallow-equal'\nimport toQuery from './toQuery'\nimport Context from './Context'\nimport { MediaQueryAllQueryable, MediaQueryMatchers } from './types'\n\ntype MediaQuerySettings = Partial\ntype HyphenateKeyTypes = MediaQueryMatchers | MediaQueryAllQueryable;\n\nconst makeQuery = (settings: MediaQuerySettings) => settings.query || toQuery(settings)\n\nconst hyphenateKeys = (obj?: HyphenateKeyTypes) => {\n type K = keyof HyphenateKeyTypes;\n\n if (!obj) return undefined\n const keys = Object.keys(obj) as K[]\n\n return keys.reduce((result, key) => {\n result[hyphenate(key)] = obj[key]\n return result\n }, {} as Record)\n}\n\nconst useIsUpdate = () => {\n const ref = useRef(false)\n\n useEffect(() => {\n ref.current = true\n }, [])\n\n return ref.current\n}\n\nconst useDevice = (deviceFromProps?: MediaQueryMatchers): Partial | undefined => {\n const deviceFromContext = useContext(Context)\n const getDevice = () =>\n hyphenateKeys(deviceFromProps) || hyphenateKeys(deviceFromContext)\n const [ device, setDevice ] = useState(getDevice)\n\n useEffect(() => {\n const newDevice = getDevice()\n if (!shallowEqualObjects(device, newDevice)) {\n setDevice(newDevice)\n }\n }, [ deviceFromProps, deviceFromContext ])\n\n return device\n}\n\nconst useQuery = (settings: MediaQuerySettings) => {\n const getQuery = () => makeQuery(settings)\n const [ query, setQuery ] = useState(getQuery)\n\n useEffect(() => {\n const newQuery = getQuery()\n if (query !== newQuery) {\n setQuery(newQuery)\n }\n }, [ settings ])\n\n return query\n}\n\nconst useMatchMedia = (query: string, device?: MediaQueryMatchers) => {\n const getMatchMedia = () => matchMedia(query, device || {}, !!device)\n const [ mq, setMq ] = useState(getMatchMedia)\n const isUpdate = useIsUpdate()\n\n useEffect(() => {\n if (isUpdate) {\n // skip on mounting, it has already been set\n const newMq = getMatchMedia()\n setMq(newMq)\n\n return () => {\n if (newMq) {\n newMq.dispose()\n }\n }\n }\n }, [ query, device ])\n\n return mq\n}\n\nconst useMatches = (mediaQuery: MediaQueryList): boolean => {\n const [ matches, setMatches ] = useState(mediaQuery.matches)\n\n useEffect(() => {\n const updateMatches = (ev: MediaQueryListEvent) => {\n setMatches(ev.matches)\n }\n mediaQuery.addListener(updateMatches)\n setMatches(mediaQuery.matches)\n\n return () => {\n mediaQuery.removeListener(updateMatches)\n }\n }, [ mediaQuery ])\n\n return matches\n}\n\nconst useMediaQuery = (settings: MediaQuerySettings, device?: MediaQueryMatchers, onChange?: (_: boolean) => void) => {\n const deviceSettings = useDevice(device)\n const query = useQuery(settings)\n if (!query) throw new Error('Invalid or missing MediaQuery!')\n const mq = useMatchMedia(query, deviceSettings)\n const matches = useMatches(mq as unknown as MediaQueryList)\n const isUpdate = useIsUpdate()\n\n useEffect(() => {\n if (isUpdate && onChange) {\n onChange(matches)\n }\n }, [ matches ])\n\n useEffect(() => () => {\n if (mq) {\n mq.dispose()\n }\n }, [])\n\n return matches\n}\n\nexport default useMediaQuery\n","module.exports = __WEBPACK_EXTERNAL_MODULE__359__;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(607);\n"],"names":["root","factory","exports","module","require","define","amd","this","__WEBPACK_EXTERNAL_MODULE__359__","mediaQuery","values","split","map","query","captures","trim","match","RE_MEDIA_QUERY","modifier","type","expressions","parsed","inverse","toLowerCase","expression","RE_MQ_EXPRESSION","feature","RE_MQ_FEATURE","value","parseQuery","some","typeMatch","expressionsMatch","every","expValue","toPx","toDpi","toDecimal","parseInt","RE_LENGTH_UNIT","RE_RESOLUTION_UNIT","ratio","numbers","decimal","Number","resolution","parseFloat","String","length","uppercasePattern","msPattern","cache","toHyphenLower","name","hasOwnProperty","hName","replace","test","staticMatch","dynamicMatch","window","matchMedia","Mql","forceStatic","self","mql","call","matches","media","addListener","update","evt","listener","removeListener","dispose","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","props","propName","componentName","location","propFullName","secret","err","Error","getShim","isRequired","ReactPropTypes","array","bigint","bool","func","number","object","string","symbol","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","shallowEqualObjects","objA","objB","aKeys","Object","keys","bKeys","len","i","key","prototype","shallowEqualArrays","arrA","arrB","children","device","onChange","settings","Context","createContext","undefined","useMediaQuery","toQuery","stringOrNumber","types","all","grid","aural","braille","handheld","print","projection","screen","tty","tv","embossed","matchers","orientation","scan","aspectRatio","deviceAspectRatio","height","deviceHeight","width","deviceWidth","color","colorIndex","monochrome","featureMatchers","features","minAspectRatio","maxAspectRatio","minDeviceAspectRatio","maxDeviceAspectRatio","minHeight","maxHeight","minDeviceHeight","maxDeviceHeight","minWidth","maxWidth","minDeviceWidth","maxDeviceWidth","minColor","maxColor","minColorIndex","maxColorIndex","minMonochrome","maxMonochrome","minResolution","maxResolution","obj","rules","forEach","k","v","push","realKey","keyVal","join","hyphenateKeys","reduce","result","useIsUpdate","ref","useRef","useEffect","current","deviceSettings","deviceFromProps","deviceFromContext","useContext","getDevice","useState","setDevice","newDevice","useDevice","getQuery","makeQuery","setQuery","newQuery","useQuery","mq","getMatchMedia","setMq","isUpdate","useMatchMedia","setMatches","updateMatches","ev","useMatches","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","d","definition","o","defineProperty","enumerable","get","prop","r","Symbol","toStringTag"],"sourceRoot":""} \ No newline at end of file +{"version":3,"file":"react-responsive.min.js","mappings":"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","sources":["webpack://MediaQuery/webpack/universalModuleDefinition","webpack://MediaQuery/./node_modules/css-mediaquery/index.js","webpack://MediaQuery/./node_modules/hyphenate-style-name/index.js","webpack://MediaQuery/./node_modules/matchmediaquery/index.js","webpack://MediaQuery/./node_modules/prop-types/factoryWithThrowingShims.js","webpack://MediaQuery/./node_modules/prop-types/index.js","webpack://MediaQuery/./node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack://MediaQuery/./node_modules/shallow-equal/dist/index.esm.js","webpack://MediaQuery/./src/Component.ts","webpack://MediaQuery/./src/Context.ts","webpack://MediaQuery/./src/index.ts","webpack://MediaQuery/./src/mediaQuery.ts","webpack://MediaQuery/./src/toQuery.ts","webpack://MediaQuery/./src/useMediaQuery.ts","webpack://MediaQuery/external umd {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}","webpack://MediaQuery/webpack/bootstrap","webpack://MediaQuery/webpack/runtime/define property getters","webpack://MediaQuery/webpack/runtime/hasOwnProperty shorthand","webpack://MediaQuery/webpack/runtime/make namespace object","webpack://MediaQuery/webpack/startup"],"sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"MediaQuery\"] = factory(require(\"react\"));\n\telse\n\t\troot[\"MediaQuery\"] = factory(root[\"React\"]);\n})(this, (__WEBPACK_EXTERNAL_MODULE__359__) => {\nreturn ","/*\nCopyright (c) 2014, Yahoo! Inc. All rights reserved.\nCopyrights licensed under the New BSD License.\nSee the accompanying LICENSE file for terms.\n*/\n\n'use strict';\n\nexports.match = matchQuery;\nexports.parse = parseQuery;\n\n// -----------------------------------------------------------------------------\n\nvar RE_MEDIA_QUERY = /(?:(only|not)?\\s*([^\\s\\(\\)]+)(?:\\s*and)?\\s*)?(.+)?/i,\n RE_MQ_EXPRESSION = /\\(\\s*([^\\s\\:\\)]+)\\s*(?:\\:\\s*([^\\s\\)]+))?\\s*\\)/,\n RE_MQ_FEATURE = /^(?:(min|max)-)?(.+)/,\n RE_LENGTH_UNIT = /(em|rem|px|cm|mm|in|pt|pc)?$/,\n RE_RESOLUTION_UNIT = /(dpi|dpcm|dppx)?$/;\n\nfunction matchQuery(mediaQuery, values) {\n return parseQuery(mediaQuery).some(function (query) {\n var inverse = query.inverse;\n\n // Either the parsed or specified `type` is \"all\", or the types must be\n // equal for a match.\n var typeMatch = query.type === 'all' || values.type === query.type;\n\n // Quit early when `type` doesn't match, but take \"not\" into account.\n if ((typeMatch && inverse) || !(typeMatch || inverse)) {\n return false;\n }\n\n var expressionsMatch = query.expressions.every(function (expression) {\n var feature = expression.feature,\n modifier = expression.modifier,\n expValue = expression.value,\n value = values[feature];\n\n // Missing or falsy values don't match.\n if (!value) { return false; }\n\n switch (feature) {\n case 'orientation':\n case 'scan':\n return value.toLowerCase() === expValue.toLowerCase();\n\n case 'width':\n case 'height':\n case 'device-width':\n case 'device-height':\n expValue = toPx(expValue);\n value = toPx(value);\n break;\n\n case 'resolution':\n expValue = toDpi(expValue);\n value = toDpi(value);\n break;\n\n case 'aspect-ratio':\n case 'device-aspect-ratio':\n case /* Deprecated */ 'device-pixel-ratio':\n expValue = toDecimal(expValue);\n value = toDecimal(value);\n break;\n\n case 'grid':\n case 'color':\n case 'color-index':\n case 'monochrome':\n expValue = parseInt(expValue, 10) || 1;\n value = parseInt(value, 10) || 0;\n break;\n }\n\n switch (modifier) {\n case 'min': return value >= expValue;\n case 'max': return value <= expValue;\n default : return value === expValue;\n }\n });\n\n return (expressionsMatch && !inverse) || (!expressionsMatch && inverse);\n });\n}\n\nfunction parseQuery(mediaQuery) {\n return mediaQuery.split(',').map(function (query) {\n query = query.trim();\n\n var captures = query.match(RE_MEDIA_QUERY),\n modifier = captures[1],\n type = captures[2],\n expressions = captures[3] || '',\n parsed = {};\n\n parsed.inverse = !!modifier && modifier.toLowerCase() === 'not';\n parsed.type = type ? type.toLowerCase() : 'all';\n\n // Split expressions into a list.\n expressions = expressions.match(/\\([^\\)]+\\)/g) || [];\n\n parsed.expressions = expressions.map(function (expression) {\n var captures = expression.match(RE_MQ_EXPRESSION),\n feature = captures[1].toLowerCase().match(RE_MQ_FEATURE);\n\n return {\n modifier: feature[1],\n feature : feature[2],\n value : captures[2]\n };\n });\n\n return parsed;\n });\n}\n\n// -- Utilities ----------------------------------------------------------------\n\nfunction toDecimal(ratio) {\n var decimal = Number(ratio),\n numbers;\n\n if (!decimal) {\n numbers = ratio.match(/^(\\d+)\\s*\\/\\s*(\\d+)$/);\n decimal = numbers[1] / numbers[2];\n }\n\n return decimal;\n}\n\nfunction toDpi(resolution) {\n var value = parseFloat(resolution),\n units = String(resolution).match(RE_RESOLUTION_UNIT)[1];\n\n switch (units) {\n case 'dpcm': return value / 2.54;\n case 'dppx': return value * 96;\n default : return value;\n }\n}\n\nfunction toPx(length) {\n var value = parseFloat(length),\n units = String(length).match(RE_LENGTH_UNIT)[1];\n\n switch (units) {\n case 'em' : return value * 16;\n case 'rem': return value * 16;\n case 'cm' : return value * 96 / 2.54;\n case 'mm' : return value * 96 / 2.54 / 10;\n case 'in' : return value * 96;\n case 'pt' : return value * 72;\n case 'pc' : return value * 72 / 12;\n default : return value;\n }\n}\n","/* eslint-disable no-var, prefer-template */\nvar uppercasePattern = /[A-Z]/g\nvar msPattern = /^ms-/\nvar cache = {}\n\nfunction toHyphenLower(match) {\n return '-' + match.toLowerCase()\n}\n\nfunction hyphenateStyleName(name) {\n if (cache.hasOwnProperty(name)) {\n return cache[name]\n }\n\n var hName = name.replace(uppercasePattern, toHyphenLower)\n return (cache[name] = msPattern.test(hName) ? '-' + hName : hName)\n}\n\nexport default hyphenateStyleName\n","'use strict';\n\nvar staticMatch = require('css-mediaquery').match;\nvar dynamicMatch = typeof window !== 'undefined' ? window.matchMedia : null;\n\n// our fake MediaQueryList\nfunction Mql(query, values, forceStatic){\n var self = this;\n if(dynamicMatch && !forceStatic){\n var mql = dynamicMatch.call(window, query);\n this.matches = mql.matches;\n this.media = mql.media;\n // TODO: is there a time it makes sense to remove this listener?\n mql.addListener(update);\n } else {\n this.matches = staticMatch(query, values);\n this.media = query;\n }\n\n this.addListener = addListener;\n this.removeListener = removeListener;\n this.dispose = dispose;\n\n function addListener(listener){\n if(mql){\n mql.addListener(listener);\n }\n }\n\n function removeListener(listener){\n if(mql){\n mql.removeListener(listener);\n }\n }\n\n // update ourselves!\n function update(evt){\n self.matches = evt.matches;\n self.media = evt.media;\n }\n\n function dispose(){\n if(mql){\n mql.removeListener(update);\n }\n }\n}\n\nfunction matchMedia(query, values, forceStatic){\n return new Mql(query, values, forceStatic);\n}\n\nmodule.exports = matchMedia;\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bigint: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","function shallowEqualObjects(objA, objB) {\n if (objA === objB) {\n return true;\n }\n\n if (!objA || !objB) {\n return false;\n }\n\n var aKeys = Object.keys(objA);\n var bKeys = Object.keys(objB);\n var len = aKeys.length;\n\n if (bKeys.length !== len) {\n return false;\n }\n\n for (var i = 0; i < len; i++) {\n var key = aKeys[i];\n\n if (objA[key] !== objB[key] || !Object.prototype.hasOwnProperty.call(objB, key)) {\n return false;\n }\n }\n\n return true;\n}\n\nfunction shallowEqualArrays(arrA, arrB) {\n if (arrA === arrB) {\n return true;\n }\n\n if (!arrA || !arrB) {\n return false;\n }\n\n var len = arrA.length;\n\n if (arrB.length !== len) {\n return false;\n }\n\n for (var i = 0; i < len; i++) {\n if (arrA[i] !== arrB[i]) {\n return false;\n }\n }\n\n return true;\n}\n\nexport { shallowEqualArrays, shallowEqualObjects };\n","import useMediaQuery from './useMediaQuery';\nimport { ReactNode, FC, CSSProperties } from 'react';\nimport { MediaQueryAllQueryable, MediaQueryMatchers } from './types';\n\ninterface MediaQueryProps extends MediaQueryAllQueryable {\n component?: ReactNode\n // eslint-disable-next-line @typescript-eslint/ban-types\n children?: ReactNode | Function;\n query?: string;\n style?: CSSProperties;\n className?: string;\n device?: MediaQueryMatchers;\n values?: Partial;\n onBeforeChange?: (_matches: boolean) => void;\n onChange?: (_matches: boolean) => void;\n}\n\nconst MediaQuery: FC = ({\n children,\n device,\n onChange,\n ...settings\n}) => {\n const matches = useMediaQuery(settings, device, onChange);\n\n if (typeof children === 'function') {\n return children(matches);\n }\n return matches ? children : null;\n};\n\nexport default MediaQuery;\n","import { createContext } from 'react'\nimport { MediaQueryAllQueryable } from './types'\n\nconst Context = createContext | undefined>(undefined)\n\nexport default Context\n","import useMediaQuery from './useMediaQuery'\nimport MediaQuery from './Component'\nimport toQuery from './toQuery'\nimport Context from './Context'\n\nexport {\n MediaQuery as default,\n useMediaQuery,\n toQuery,\n Context\n}\n\nexport type {\n MediaQueryTypes,\n MediaQueryType,\n MediaQueryFeatures,\n MediaQueryAllQueryable\n} from './types'\n","import PropTypes from 'prop-types'\n\nconst stringOrNumber = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.number\n])\n\n// media types\nconst types = {\n all: PropTypes.bool,\n grid: PropTypes.bool,\n aural: PropTypes.bool,\n braille: PropTypes.bool,\n handheld: PropTypes.bool,\n print: PropTypes.bool,\n projection: PropTypes.bool,\n screen: PropTypes.bool,\n tty: PropTypes.bool,\n tv: PropTypes.bool,\n embossed: PropTypes.bool\n}\n\n// properties that match media queries\nconst matchers = {\n orientation: PropTypes.oneOf([\n 'portrait',\n 'landscape'\n ]),\n\n scan: PropTypes.oneOf([\n 'progressive',\n 'interlace'\n ]),\n\n aspectRatio: PropTypes.string,\n deviceAspectRatio: PropTypes.string,\n\n height: stringOrNumber,\n deviceHeight: stringOrNumber,\n\n width: stringOrNumber,\n deviceWidth: stringOrNumber,\n\n color: PropTypes.bool,\n\n colorIndex: PropTypes.bool,\n\n monochrome: PropTypes.bool,\n resolution: stringOrNumber,\n type: Object.keys(types)\n}\n\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nconst { type, ...featureMatchers } = matchers\n\n// media features\nconst features = {\n minAspectRatio: PropTypes.string,\n maxAspectRatio: PropTypes.string,\n minDeviceAspectRatio: PropTypes.string,\n maxDeviceAspectRatio: PropTypes.string,\n\n minHeight: stringOrNumber,\n maxHeight: stringOrNumber,\n minDeviceHeight: stringOrNumber,\n maxDeviceHeight: stringOrNumber,\n\n minWidth: stringOrNumber,\n maxWidth: stringOrNumber,\n minDeviceWidth: stringOrNumber,\n maxDeviceWidth: stringOrNumber,\n\n minColor: PropTypes.number,\n maxColor: PropTypes.number,\n\n minColorIndex: PropTypes.number,\n maxColorIndex: PropTypes.number,\n\n minMonochrome: PropTypes.number,\n maxMonochrome: PropTypes.number,\n\n minResolution: stringOrNumber,\n maxResolution: stringOrNumber,\n\n ...featureMatchers\n}\n\nconst all = { ...types, ...features }\n\nexport default {\n all: all,\n types: types,\n matchers: matchers,\n features: features\n}\n","import hyphenate from 'hyphenate-style-name'\nimport mq from './mediaQuery'\nimport { MediaQueryAllQueryable } from './types'\n\nconst negate = (cond: string) => `not ${cond}`\n\nconst keyVal = (k: string, v: unknown): string => {\n const realKey = hyphenate(k)\n\n // px shorthand\n if (typeof v === 'number') {\n v = `${v}px`\n }\n if (v === true) {\n return realKey\n }\n if (v === false) {\n return negate(realKey)\n }\n return `(${realKey}: ${v})`\n}\n\nconst join = (conds: string[]): string => conds.join(' and ')\n\nconst toQuery = (obj: Partial): string => {\n const rules: string[] = []\n Object.keys(mq.all).forEach((k) => {\n const v = obj[k as keyof MediaQueryAllQueryable]\n if (v != null) {\n rules.push(keyVal(k, v))\n }\n })\n return join(rules)\n}\n\nexport default toQuery\n","import { useRef, useEffect, useContext, useState } from 'react'\nimport matchMedia from 'matchmediaquery'\nimport hyphenate from 'hyphenate-style-name'\nimport { shallowEqualObjects } from 'shallow-equal'\nimport toQuery from './toQuery'\nimport Context from './Context'\nimport { MediaQueryAllQueryable, MediaQueryMatchers } from './types'\n\ntype MediaQuerySettings = Partial\ntype HyphenateKeyTypes = MediaQueryMatchers | MediaQueryAllQueryable;\n\nconst makeQuery = (settings: MediaQuerySettings) => settings.query || toQuery(settings)\n\nconst hyphenateKeys = (obj?: HyphenateKeyTypes) => {\n type K = keyof HyphenateKeyTypes;\n\n if (!obj) return undefined\n const keys = Object.keys(obj) as K[]\n\n return keys.reduce((result, key) => {\n result[hyphenate(key)] = obj[key]\n return result\n }, {} as Record)\n}\n\nconst useIsUpdate = () => {\n const ref = useRef(false)\n\n useEffect(() => {\n ref.current = true\n }, [])\n\n return ref.current\n}\n\nconst useDevice = (deviceFromProps?: MediaQueryMatchers): Partial | undefined => {\n const deviceFromContext = useContext(Context)\n const getDevice = () =>\n hyphenateKeys(deviceFromProps) || hyphenateKeys(deviceFromContext)\n const [ device, setDevice ] = useState(getDevice)\n\n useEffect(() => {\n const newDevice = getDevice()\n if (!shallowEqualObjects(device, newDevice)) {\n setDevice(newDevice)\n }\n }, [ deviceFromProps, deviceFromContext ])\n\n return device\n}\n\nconst useQuery = (settings: MediaQuerySettings) => {\n const getQuery = () => makeQuery(settings)\n const [ query, setQuery ] = useState(getQuery)\n\n useEffect(() => {\n const newQuery = getQuery()\n if (query !== newQuery) {\n setQuery(newQuery)\n }\n }, [ settings ])\n\n return query\n}\n\nconst useMatchMedia = (query: string, device?: MediaQueryMatchers) => {\n const getMatchMedia = () => matchMedia(query, device || {}, !!device)\n const [ mq, setMq ] = useState(getMatchMedia)\n const isUpdate = useIsUpdate()\n\n useEffect(() => {\n if (isUpdate) {\n // skip on mounting, it has already been set\n const newMq = getMatchMedia()\n setMq(newMq)\n\n return () => {\n if (newMq) {\n newMq.dispose()\n }\n }\n }\n }, [ query, device ])\n\n return mq\n}\n\nconst useMatches = (mediaQuery: MediaQueryList): boolean => {\n const [ matches, setMatches ] = useState(mediaQuery.matches)\n\n useEffect(() => {\n const updateMatches = (ev: MediaQueryListEvent) => {\n setMatches(ev.matches)\n }\n mediaQuery.addListener(updateMatches)\n setMatches(mediaQuery.matches)\n\n return () => {\n mediaQuery.removeListener(updateMatches)\n }\n }, [ mediaQuery ])\n\n return matches\n}\n\nconst useMediaQuery = (settings: MediaQuerySettings, device?: MediaQueryMatchers, onChange?: (_: boolean) => void) => {\n const deviceSettings = useDevice(device)\n const query = useQuery(settings)\n if (!query) throw new Error('Invalid or missing MediaQuery!')\n const mq = useMatchMedia(query, deviceSettings)\n const matches = useMatches(mq as unknown as MediaQueryList)\n const isUpdate = useIsUpdate()\n\n useEffect(() => {\n if (isUpdate && onChange) {\n onChange(matches)\n }\n }, [ matches ])\n\n useEffect(() => () => {\n if (mq) {\n mq.dispose()\n }\n }, [])\n\n return matches\n}\n\nexport default useMediaQuery\n","module.exports = __WEBPACK_EXTERNAL_MODULE__359__;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(607);\n"],"names":["root","factory","exports","module","require","define","amd","this","__WEBPACK_EXTERNAL_MODULE__359__","mediaQuery","values","split","map","query","captures","trim","match","RE_MEDIA_QUERY","modifier","type","expressions","parsed","inverse","toLowerCase","expression","RE_MQ_EXPRESSION","feature","RE_MQ_FEATURE","value","parseQuery","some","typeMatch","expressionsMatch","every","expValue","toPx","toDpi","toDecimal","parseInt","RE_LENGTH_UNIT","RE_RESOLUTION_UNIT","ratio","numbers","decimal","Number","resolution","parseFloat","String","length","uppercasePattern","msPattern","cache","toHyphenLower","name","hasOwnProperty","hName","replace","test","staticMatch","dynamicMatch","window","matchMedia","Mql","forceStatic","self","mql","call","matches","media","addListener","update","evt","listener","removeListener","dispose","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","props","propName","componentName","location","propFullName","secret","err","Error","getShim","isRequired","ReactPropTypes","array","bigint","bool","func","number","object","string","symbol","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","shallowEqualObjects","objA","objB","aKeys","Object","keys","bKeys","len","i","key","prototype","shallowEqualArrays","arrA","arrB","children","device","onChange","settings","Context","createContext","undefined","useMediaQuery","toQuery","stringOrNumber","types","all","grid","aural","braille","handheld","print","projection","screen","tty","tv","embossed","matchers","orientation","scan","aspectRatio","deviceAspectRatio","height","deviceHeight","width","deviceWidth","color","colorIndex","monochrome","featureMatchers","features","minAspectRatio","maxAspectRatio","minDeviceAspectRatio","maxDeviceAspectRatio","minHeight","maxHeight","minDeviceHeight","maxDeviceHeight","minWidth","maxWidth","minDeviceWidth","maxDeviceWidth","minColor","maxColor","minColorIndex","maxColorIndex","minMonochrome","maxMonochrome","minResolution","maxResolution","obj","rules","forEach","k","v","push","realKey","keyVal","join","hyphenateKeys","reduce","result","useIsUpdate","ref","useRef","useEffect","current","deviceSettings","deviceFromProps","deviceFromContext","useContext","getDevice","useState","setDevice","newDevice","useDevice","getQuery","makeQuery","setQuery","newQuery","useQuery","mq","getMatchMedia","setMq","isUpdate","useMatchMedia","setMatches","updateMatches","ev","useMatches","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","d","definition","o","defineProperty","enumerable","get","prop","r","Symbol","toStringTag"],"sourceRoot":""} \ No newline at end of file diff --git a/package.json b/package.json index f7a02ec..778d03a 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "react-responsive", "description": "Media queries in react for responsive design", - "version": "9.0.0-beta.10", + "version": "9.0.0", "homepage": "http://github.com/contra/react-responsive", "repository": { "type": "git", @@ -42,7 +42,7 @@ "devDependencies": { "@types/chai": "^4.3.1", "@types/hyphenate-style-name": "^1.0.0", - "@types/jsdom": "^16.2.6", + "@types/jsdom": "^20.0.0", "@types/match-media-mock": "^0.1.5", "@types/matchmediaquery": "^0.3.0", "@types/mocha": "^9.0.0", @@ -56,7 +56,7 @@ "eslint": "^8.13.0", "eslint-plugin-compat": "^4.0.2", "gh-pages": "^4.0.0", - "jsdom": "^19.0.0", + "jsdom": "^20.0.0", "match-media-mock": "^0.1.1", "mocha": "^10.0.0", "react": "^18.0.0", @@ -65,8 +65,8 @@ "sinon": "^14.0.0", "ts-loader": "^9.2.8", "ts-node": "^10.0.0", - "typedoc": "^0.22.15", - "typescript": "^4.6.3", + "typedoc": "^0.23.14", + "typescript": "^4.8.3", "webpack": "^5.72.0", "webpack-cli": "^4.9.2" }, diff --git a/types/mediaQuery.d.ts b/types/mediaQuery.d.ts index a454d5f..03ffd0a 100644 --- a/types/mediaQuery.d.ts +++ b/types/mediaQuery.d.ts @@ -5,34 +5,34 @@ declare const _default: { scan: PropTypes.Requireable; aspectRatio: PropTypes.Requireable; deviceAspectRatio: PropTypes.Requireable; - height: PropTypes.Requireable; - deviceHeight: PropTypes.Requireable; - width: PropTypes.Requireable; - deviceWidth: PropTypes.Requireable; + height: PropTypes.Requireable>; + deviceHeight: PropTypes.Requireable>; + width: PropTypes.Requireable>; + deviceWidth: PropTypes.Requireable>; color: PropTypes.Requireable; colorIndex: PropTypes.Requireable; monochrome: PropTypes.Requireable; - resolution: PropTypes.Requireable; + resolution: PropTypes.Requireable>; minAspectRatio: PropTypes.Requireable; maxAspectRatio: PropTypes.Requireable; minDeviceAspectRatio: PropTypes.Requireable; maxDeviceAspectRatio: PropTypes.Requireable; - minHeight: PropTypes.Requireable; - maxHeight: PropTypes.Requireable; - minDeviceHeight: PropTypes.Requireable; - maxDeviceHeight: PropTypes.Requireable; - minWidth: PropTypes.Requireable; - maxWidth: PropTypes.Requireable; - minDeviceWidth: PropTypes.Requireable; - maxDeviceWidth: PropTypes.Requireable; + minHeight: PropTypes.Requireable>; + maxHeight: PropTypes.Requireable>; + minDeviceHeight: PropTypes.Requireable>; + maxDeviceHeight: PropTypes.Requireable>; + minWidth: PropTypes.Requireable>; + maxWidth: PropTypes.Requireable>; + minDeviceWidth: PropTypes.Requireable>; + maxDeviceWidth: PropTypes.Requireable>; minColor: PropTypes.Requireable; maxColor: PropTypes.Requireable; minColorIndex: PropTypes.Requireable; maxColorIndex: PropTypes.Requireable; minMonochrome: PropTypes.Requireable; maxMonochrome: PropTypes.Requireable; - minResolution: PropTypes.Requireable; - maxResolution: PropTypes.Requireable; + minResolution: PropTypes.Requireable>; + maxResolution: PropTypes.Requireable>; all: PropTypes.Requireable; grid: PropTypes.Requireable; aural: PropTypes.Requireable; @@ -63,14 +63,14 @@ declare const _default: { scan: PropTypes.Requireable; aspectRatio: PropTypes.Requireable; deviceAspectRatio: PropTypes.Requireable; - height: PropTypes.Requireable; - deviceHeight: PropTypes.Requireable; - width: PropTypes.Requireable; - deviceWidth: PropTypes.Requireable; + height: PropTypes.Requireable>; + deviceHeight: PropTypes.Requireable>; + width: PropTypes.Requireable>; + deviceWidth: PropTypes.Requireable>; color: PropTypes.Requireable; colorIndex: PropTypes.Requireable; monochrome: PropTypes.Requireable; - resolution: PropTypes.Requireable; + resolution: PropTypes.Requireable>; type: string[]; }; features: { @@ -78,34 +78,34 @@ declare const _default: { scan: PropTypes.Requireable; aspectRatio: PropTypes.Requireable; deviceAspectRatio: PropTypes.Requireable; - height: PropTypes.Requireable; - deviceHeight: PropTypes.Requireable; - width: PropTypes.Requireable; - deviceWidth: PropTypes.Requireable; + height: PropTypes.Requireable>; + deviceHeight: PropTypes.Requireable>; + width: PropTypes.Requireable>; + deviceWidth: PropTypes.Requireable>; color: PropTypes.Requireable; colorIndex: PropTypes.Requireable; monochrome: PropTypes.Requireable; - resolution: PropTypes.Requireable; + resolution: PropTypes.Requireable>; minAspectRatio: PropTypes.Requireable; maxAspectRatio: PropTypes.Requireable; minDeviceAspectRatio: PropTypes.Requireable; maxDeviceAspectRatio: PropTypes.Requireable; - minHeight: PropTypes.Requireable; - maxHeight: PropTypes.Requireable; - minDeviceHeight: PropTypes.Requireable; - maxDeviceHeight: PropTypes.Requireable; - minWidth: PropTypes.Requireable; - maxWidth: PropTypes.Requireable; - minDeviceWidth: PropTypes.Requireable; - maxDeviceWidth: PropTypes.Requireable; + minHeight: PropTypes.Requireable>; + maxHeight: PropTypes.Requireable>; + minDeviceHeight: PropTypes.Requireable>; + maxDeviceHeight: PropTypes.Requireable>; + minWidth: PropTypes.Requireable>; + maxWidth: PropTypes.Requireable>; + minDeviceWidth: PropTypes.Requireable>; + maxDeviceWidth: PropTypes.Requireable>; minColor: PropTypes.Requireable; maxColor: PropTypes.Requireable; minColorIndex: PropTypes.Requireable; maxColorIndex: PropTypes.Requireable; minMonochrome: PropTypes.Requireable; maxMonochrome: PropTypes.Requireable; - minResolution: PropTypes.Requireable; - maxResolution: PropTypes.Requireable; + minResolution: PropTypes.Requireable>; + maxResolution: PropTypes.Requireable>; }; }; export default _default;