From 2cbc72f6175dbebb1d40e9ff31b7415b41d4ac6d Mon Sep 17 00:00:00 2001 From: tangjinzhou <415800467@qq.com> Date: Sun, 30 Aug 2020 22:23:36 +0800 Subject: [PATCH] chore: remove require --- antdv-demo | 2 +- components/_util/responsiveObserve.js | 97 ++++++----------- .../__tests__/__snapshots__/demo.test.js.snap | 8 +- components/carousel/index.jsx | 21 +--- .../__tests__/__snapshots__/demo.test.js.snap | 100 +++++++++++++++--- .../descriptions/__tests__/index.test.js | 24 ----- components/layout/Sider.jsx | 14 --- .../__tests__/__snapshots__/demo.test.js.snap | 4 +- .../__snapshots__/index.test.js.snap | 2 +- .../__tests__/__snapshots__/demo.test.js.snap | 12 +-- .../__tests__/__snapshots__/demo.test.js.snap | 2 +- .../__tests__/__snapshots__/demo.test.js.snap | 9 +- components/tree/Tree.jsx | 3 +- .../__tests__/__snapshots__/demo.test.js.snap | 20 ++-- components/vc-menu/DOMWrap.jsx | 11 -- components/vc-slick/src/slider.js | 19 ++-- .../vc-tree-select/src/Base/BasePopup.jsx | 2 +- components/vc-tree-select/src/SelectNode.jsx | 3 +- components/vc-tree/index.js | 4 +- components/vc-tree/src/index.js | 6 +- examples/App.vue | 2 +- package.json | 3 +- tests/setup.js | 18 ++-- 23 files changed, 178 insertions(+), 208 deletions(-) diff --git a/antdv-demo b/antdv-demo index 5a00801c50..7c607950a2 160000 --- a/antdv-demo +++ b/antdv-demo @@ -1 +1 @@ -Subproject commit 5a00801c5012248ce32d8ed7a4164da3a5fde90f +Subproject commit 7c607950a297b2635264abf208d1a1ce64e502de diff --git a/components/_util/responsiveObserve.js b/components/_util/responsiveObserve.js index 2d5fccd2ee..9b6fa3c766 100644 --- a/components/_util/responsiveObserve.js +++ b/components/_util/responsiveObserve.js @@ -1,23 +1,3 @@ -// matchMedia polyfill for -// https://github.com/WickyNilliams/enquire.js/issues/82 -let enquire; - -// TODO: Will be removed in antd 4.0 because we will no longer support ie9 -if (typeof window !== 'undefined') { - const matchMediaPolyfill = mediaQuery => { - return { - media: mediaQuery, - matches: false, - addListener() {}, - removeListener() {}, - }; - }; - // ref: https://github.com/ant-design/ant-design/issues/18774 - if (!window.matchMedia) window.matchMedia = matchMediaPolyfill; - // eslint-disable-next-line global-require - enquire = require('enquire.js'); -} - export const responsiveArray = ['xxl', 'xl', 'lg', 'md', 'sm', 'xs']; export const responsiveMap = { @@ -29,65 +9,54 @@ export const responsiveMap = { xxl: '(min-width: 1600px)', }; -let subscribers = []; +const subscribers = new Map(); let subUid = -1; let screens = {}; const responsiveObserve = { + matchHandlers: {}, dispatch(pointMap) { screens = pointMap; - if (subscribers.length < 1) { - return false; - } - - subscribers.forEach(item => { - item.func(screens); - }); - - return true; + subscribers.forEach(func => func(screens)); + return subscribers.size >= 1; }, subscribe(func) { - if (subscribers.length === 0) { - this.register(); - } - const token = (++subUid).toString(); - subscribers.push({ - token, - func, - }); + if (!subscribers.size) this.register(); + subUid += 1; + subscribers.set(subUid, func); func(screens); - return token; + return subUid; }, unsubscribe(token) { - subscribers = subscribers.filter(item => item.token !== token); - if (subscribers.length === 0) { - this.unregister(); - } + subscribers.delete(token); + if (!subscribers.size) this.unregister(); }, unregister() { - Object.keys(responsiveMap).map(screen => enquire.unregister(responsiveMap[screen])); + Object.keys(responsiveMap).forEach(screen => { + const matchMediaQuery = responsiveMap[screen]; + const handler = this.matchHandlers[matchMediaQuery]; + handler?.mql.removeListener(handler?.listener); + }); + subscribers.clear(); }, register() { - Object.keys(responsiveMap).map(screen => - enquire.register(responsiveMap[screen], { - match: () => { - const pointMap = { - ...screens, - [screen]: true, - }; - this.dispatch(pointMap); - }, - unmatch: () => { - const pointMap = { - ...screens, - [screen]: false, - }; - this.dispatch(pointMap); - }, - // Keep a empty destroy to avoid triggering unmatch when unregister - destroy() {}, - }), - ); + Object.keys(responsiveMap).forEach(screen => { + const matchMediaQuery = responsiveMap[screen]; + const listener = ({ matches }) => { + this.dispatch({ + ...screens, + [screen]: matches, + }); + }; + const mql = window.matchMedia(matchMediaQuery); + mql.addListener(listener); + this.matchHandlers[matchMediaQuery] = { + mql, + listener, + }; + + listener(mql); + }); }, }; diff --git a/components/carousel/__tests__/__snapshots__/demo.test.js.snap b/components/carousel/__tests__/__snapshots__/demo.test.js.snap index 8fb95d8a24..d2b9470a9c 100644 --- a/components/carousel/__tests__/__snapshots__/demo.test.js.snap +++ b/components/carousel/__tests__/__snapshots__/demo.test.js.snap @@ -314,28 +314,28 @@ exports[`renders ./antdv-demo/docs/carousel/demo/fade.md correctly 1`] = `