@os-design/use-click-outside 1.0.21 → 1.0.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/cjs/index.js CHANGED
@@ -7,7 +7,7 @@ exports["default"] = void 0;
7
7
  var _useEvent = _interopRequireDefault(require("@os-design/use-event"));
8
8
  var _react = require("react");
9
9
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
10
- function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
10
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
11
11
  var useClickOutside = function useClickOutside(target, listener) {
12
12
  var listenerRef = (0, _react.useRef)();
13
13
  (0, _react.useEffect)(function () {
@@ -23,6 +23,5 @@ var useClickOutside = function useClickOutside(target, listener) {
23
23
  (0, _useEvent["default"])(document, 'mousedown', clickListener);
24
24
  (0, _useEvent["default"])(document, 'touchstart', clickListener);
25
25
  };
26
- var _default = useClickOutside;
27
- exports["default"] = _default;
26
+ var _default = exports["default"] = useClickOutside;
28
27
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["_useEvent","_interopRequireDefault","require","_react","obj","__esModule","_typeof","Symbol","iterator","constructor","prototype","useClickOutside","target","listener","listenerRef","useRef","useEffect","current","clickListener","useCallback","event","element","Element","contains","useEvent","document","_default","exports"],"sources":["../../src/index.ts"],"sourcesContent":["import useEvent from '@os-design/use-event';\nimport { RefObject, useCallback, useEffect, useRef } from 'react';\n\nconst useClickOutside = (\n target: Element | RefObject<Element>,\n listener: EventListener\n): void => {\n const listenerRef = useRef<EventListener>();\n\n useEffect(() => {\n listenerRef.current = listener;\n }, [listener]);\n\n const clickListener = useCallback(\n (event) => {\n if (typeof target !== 'object' || target === null) return;\n const element = target instanceof Element ? target : target.current;\n if (element === null || !element.contains) return;\n if (!listenerRef.current || element.contains(event.target)) return;\n listenerRef.current(event);\n },\n [target]\n );\n\n useEvent(document, 'mousedown', clickListener);\n useEvent(document, 'touchstart', clickListener);\n};\n\nexport default useClickOutside;\n"],"mappings":";;;;;;AAAA,IAAAA,SAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAAkE,SAAAD,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,gBAAAA,GAAA;AAAA,SAAAE,QAAAF,GAAA,sCAAAE,OAAA,wBAAAC,MAAA,uBAAAA,MAAA,CAAAC,QAAA,aAAAJ,GAAA,kBAAAA,GAAA,gBAAAA,GAAA,WAAAA,GAAA,yBAAAG,MAAA,IAAAH,GAAA,CAAAK,WAAA,KAAAF,MAAA,IAAAH,GAAA,KAAAG,MAAA,CAAAG,SAAA,qBAAAN,GAAA,KAAAE,OAAA,CAAAF,GAAA;AAElE,IAAMO,eAAe,GAAG,SAAlBA,eAAeA,CACnBC,MAAoC,EACpCC,QAAuB,EACd;EACT,IAAMC,WAAW,GAAG,IAAAC,aAAM,EAAgB,CAAC;EAE3C,IAAAC,gBAAS,EAAC,YAAM;IACdF,WAAW,CAACG,OAAO,GAAGJ,QAAQ;EAChC,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,IAAMK,aAAa,GAAG,IAAAC,kBAAW,EAC/B,UAACC,KAAK,EAAK;IACT,IAAId,OAAA,CAAOM,MAAM,MAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;IACnD,IAAMS,OAAO,GAAGT,MAAM,YAAYU,OAAO,GAAGV,MAAM,GAAGA,MAAM,CAACK,OAAO;IACnE,IAAII,OAAO,KAAK,IAAI,IAAI,CAACA,OAAO,CAACE,QAAQ,EAAE;IAC3C,IAAI,CAACT,WAAW,CAACG,OAAO,IAAII,OAAO,CAACE,QAAQ,CAACH,KAAK,CAACR,MAAM,CAAC,EAAE;IAC5DE,WAAW,CAACG,OAAO,CAACG,KAAK,CAAC;EAC5B,CAAC,EACD,CAACR,MAAM,CACT,CAAC;EAED,IAAAY,oBAAQ,EAACC,QAAQ,EAAE,WAAW,EAAEP,aAAa,CAAC;EAC9C,IAAAM,oBAAQ,EAACC,QAAQ,EAAE,YAAY,EAAEP,aAAa,CAAC;AACjD,CAAC;AAAC,IAAAQ,QAAA,GAEaf,eAAe;AAAAgB,OAAA,cAAAD,QAAA"}
1
+ {"version":3,"file":"index.js","names":["_useEvent","_interopRequireDefault","require","_react","obj","__esModule","_typeof","o","Symbol","iterator","constructor","prototype","useClickOutside","target","listener","listenerRef","useRef","useEffect","current","clickListener","useCallback","event","element","Element","contains","useEvent","document","_default","exports"],"sources":["../../src/index.ts"],"sourcesContent":["import useEvent from '@os-design/use-event';\nimport { RefObject, useCallback, useEffect, useRef } from 'react';\n\nconst useClickOutside = (\n target: Element | RefObject<Element>,\n listener: EventListener\n): void => {\n const listenerRef = useRef<EventListener>();\n\n useEffect(() => {\n listenerRef.current = listener;\n }, [listener]);\n\n const clickListener = useCallback(\n (event) => {\n if (typeof target !== 'object' || target === null) return;\n const element = target instanceof Element ? target : target.current;\n if (element === null || !element.contains) return;\n if (!listenerRef.current || element.contains(event.target)) return;\n listenerRef.current(event);\n },\n [target]\n );\n\n useEvent(document, 'mousedown', clickListener);\n useEvent(document, 'touchstart', clickListener);\n};\n\nexport default useClickOutside;\n"],"mappings":";;;;;;AAAA,IAAAA,SAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAD,OAAA;AAAkE,SAAAD,uBAAAG,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,gBAAAA,GAAA;AAAA,SAAAE,QAAAC,CAAA,sCAAAD,OAAA,wBAAAE,MAAA,uBAAAA,MAAA,CAAAC,QAAA,aAAAF,CAAA,kBAAAA,CAAA,gBAAAA,CAAA,WAAAA,CAAA,yBAAAC,MAAA,IAAAD,CAAA,CAAAG,WAAA,KAAAF,MAAA,IAAAD,CAAA,KAAAC,MAAA,CAAAG,SAAA,qBAAAJ,CAAA,KAAAD,OAAA,CAAAC,CAAA;AAElE,IAAMK,eAAe,GAAG,SAAlBA,eAAeA,CACnBC,MAAoC,EACpCC,QAAuB,EACd;EACT,IAAMC,WAAW,GAAG,IAAAC,aAAM,EAAgB,CAAC;EAE3C,IAAAC,gBAAS,EAAC,YAAM;IACdF,WAAW,CAACG,OAAO,GAAGJ,QAAQ;EAChC,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,IAAMK,aAAa,GAAG,IAAAC,kBAAW,EAC/B,UAACC,KAAK,EAAK;IACT,IAAIf,OAAA,CAAOO,MAAM,MAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;IACnD,IAAMS,OAAO,GAAGT,MAAM,YAAYU,OAAO,GAAGV,MAAM,GAAGA,MAAM,CAACK,OAAO;IACnE,IAAII,OAAO,KAAK,IAAI,IAAI,CAACA,OAAO,CAACE,QAAQ,EAAE;IAC3C,IAAI,CAACT,WAAW,CAACG,OAAO,IAAII,OAAO,CAACE,QAAQ,CAACH,KAAK,CAACR,MAAM,CAAC,EAAE;IAC5DE,WAAW,CAACG,OAAO,CAACG,KAAK,CAAC;EAC5B,CAAC,EACD,CAACR,MAAM,CACT,CAAC;EAED,IAAAY,oBAAQ,EAACC,QAAQ,EAAE,WAAW,EAAEP,aAAa,CAAC;EAC9C,IAAAM,oBAAQ,EAACC,QAAQ,EAAE,YAAY,EAAEP,aAAa,CAAC;AACjD,CAAC;AAAC,IAAAQ,QAAA,GAAAC,OAAA,cAEahB,eAAe","ignoreList":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["useEvent","useCallback","useEffect","useRef","useClickOutside","target","listener","listenerRef","current","clickListener","event","element","Element","contains","document"],"sources":["../../src/index.ts"],"sourcesContent":["import useEvent from '@os-design/use-event';\nimport { RefObject, useCallback, useEffect, useRef } from 'react';\n\nconst useClickOutside = (\n target: Element | RefObject<Element>,\n listener: EventListener\n): void => {\n const listenerRef = useRef<EventListener>();\n\n useEffect(() => {\n listenerRef.current = listener;\n }, [listener]);\n\n const clickListener = useCallback(\n (event) => {\n if (typeof target !== 'object' || target === null) return;\n const element = target instanceof Element ? target : target.current;\n if (element === null || !element.contains) return;\n if (!listenerRef.current || element.contains(event.target)) return;\n listenerRef.current(event);\n },\n [target]\n );\n\n useEvent(document, 'mousedown', clickListener);\n useEvent(document, 'touchstart', clickListener);\n};\n\nexport default useClickOutside;\n"],"mappings":"AAAA,OAAOA,QAAQ,MAAM,sBAAsB;AAC3C,SAAoBC,WAAW,EAAEC,SAAS,EAAEC,MAAM,QAAQ,OAAO;AAEjE,MAAMC,eAAe,GAAGA,CACtBC,MAAoC,EACpCC,QAAuB,KACd;EACT,MAAMC,WAAW,GAAGJ,MAAM,CAAgB,CAAC;EAE3CD,SAAS,CAAC,MAAM;IACdK,WAAW,CAACC,OAAO,GAAGF,QAAQ;EAChC,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,MAAMG,aAAa,GAAGR,WAAW,CAC9BS,KAAK,IAAK;IACT,IAAI,OAAOL,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;IACnD,MAAMM,OAAO,GAAGN,MAAM,YAAYO,OAAO,GAAGP,MAAM,GAAGA,MAAM,CAACG,OAAO;IACnE,IAAIG,OAAO,KAAK,IAAI,IAAI,CAACA,OAAO,CAACE,QAAQ,EAAE;IAC3C,IAAI,CAACN,WAAW,CAACC,OAAO,IAAIG,OAAO,CAACE,QAAQ,CAACH,KAAK,CAACL,MAAM,CAAC,EAAE;IAC5DE,WAAW,CAACC,OAAO,CAACE,KAAK,CAAC;EAC5B,CAAC,EACD,CAACL,MAAM,CACT,CAAC;EAEDL,QAAQ,CAACc,QAAQ,EAAE,WAAW,EAAEL,aAAa,CAAC;EAC9CT,QAAQ,CAACc,QAAQ,EAAE,YAAY,EAAEL,aAAa,CAAC;AACjD,CAAC;AAED,eAAeL,eAAe"}
1
+ {"version":3,"file":"index.js","names":["useEvent","useCallback","useEffect","useRef","useClickOutside","target","listener","listenerRef","current","clickListener","event","element","Element","contains","document"],"sources":["../../src/index.ts"],"sourcesContent":["import useEvent from '@os-design/use-event';\nimport { RefObject, useCallback, useEffect, useRef } from 'react';\n\nconst useClickOutside = (\n target: Element | RefObject<Element>,\n listener: EventListener\n): void => {\n const listenerRef = useRef<EventListener>();\n\n useEffect(() => {\n listenerRef.current = listener;\n }, [listener]);\n\n const clickListener = useCallback(\n (event) => {\n if (typeof target !== 'object' || target === null) return;\n const element = target instanceof Element ? target : target.current;\n if (element === null || !element.contains) return;\n if (!listenerRef.current || element.contains(event.target)) return;\n listenerRef.current(event);\n },\n [target]\n );\n\n useEvent(document, 'mousedown', clickListener);\n useEvent(document, 'touchstart', clickListener);\n};\n\nexport default useClickOutside;\n"],"mappings":"AAAA,OAAOA,QAAQ,MAAM,sBAAsB;AAC3C,SAAoBC,WAAW,EAAEC,SAAS,EAAEC,MAAM,QAAQ,OAAO;AAEjE,MAAMC,eAAe,GAAGA,CACtBC,MAAoC,EACpCC,QAAuB,KACd;EACT,MAAMC,WAAW,GAAGJ,MAAM,CAAgB,CAAC;EAE3CD,SAAS,CAAC,MAAM;IACdK,WAAW,CAACC,OAAO,GAAGF,QAAQ;EAChC,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,MAAMG,aAAa,GAAGR,WAAW,CAC9BS,KAAK,IAAK;IACT,IAAI,OAAOL,MAAM,KAAK,QAAQ,IAAIA,MAAM,KAAK,IAAI,EAAE;IACnD,MAAMM,OAAO,GAAGN,MAAM,YAAYO,OAAO,GAAGP,MAAM,GAAGA,MAAM,CAACG,OAAO;IACnE,IAAIG,OAAO,KAAK,IAAI,IAAI,CAACA,OAAO,CAACE,QAAQ,EAAE;IAC3C,IAAI,CAACN,WAAW,CAACC,OAAO,IAAIG,OAAO,CAACE,QAAQ,CAACH,KAAK,CAACL,MAAM,CAAC,EAAE;IAC5DE,WAAW,CAACC,OAAO,CAACE,KAAK,CAAC;EAC5B,CAAC,EACD,CAACL,MAAM,CACT,CAAC;EAEDL,QAAQ,CAACc,QAAQ,EAAE,WAAW,EAAEL,aAAa,CAAC;EAC9CT,QAAQ,CAACc,QAAQ,EAAE,YAAY,EAAEL,aAAa,CAAC;AACjD,CAAC;AAED,eAAeL,eAAe","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@os-design/use-click-outside",
3
- "version": "1.0.21",
3
+ "version": "1.0.23",
4
4
  "license": "UNLICENSED",
5
5
  "repository": "git@gitlab.com:os-team/libs/os-design.git",
6
6
  "main": "dist/cjs/index.js",
@@ -30,10 +30,10 @@
30
30
  "access": "public"
31
31
  },
32
32
  "dependencies": {
33
- "@os-design/use-event": "^1.0.19"
33
+ "@os-design/use-event": "^1.0.21"
34
34
  },
35
35
  "peerDependencies": {
36
36
  "react": ">=18"
37
37
  },
38
- "gitHead": "2605fbf8f46c78800cd4ba6dcb0dd895a893bf96"
38
+ "gitHead": "6c92e27c799cae9ae9930e734868d8da35c61cb6"
39
39
  }
package/src/index.mdx ADDED
@@ -0,0 +1,46 @@
1
+ import { Meta } from '@storybook/blocks';
2
+ import UseClickOutsideExample from './index.example';
3
+
4
+ <Meta title='Utils/useClickOutside' />
5
+
6
+ # useClickOutside
7
+
8
+ Sets the listener that will be called when the click event occurs outside the target element.
9
+
10
+ ## Example of usage
11
+
12
+ ```tsx
13
+ import React, { useCallback, useRef, useState } from 'react';
14
+ import styled from '@emotion/styled';
15
+ import { useClickOutside } from '@os-design/utils';
16
+
17
+ const Container = styled.div`
18
+ background-color: hsl(0, 50%, 50%);
19
+ width: 10em;
20
+ height: 10em;
21
+ `;
22
+
23
+ const UseClickOutsideExample: React.FC = () => {
24
+ const containerRef = useRef<HTMLDivElement>();
25
+ const [numberOfEvents, setNumberOfEvents] = useState(0);
26
+
27
+ const incrementNumberOfEvents = useCallback(() => {
28
+ setNumberOfEvents(numberOfEvents + 1);
29
+ }, [numberOfEvents]);
30
+
31
+ useClickOutside(containerRef.current, incrementNumberOfEvents);
32
+
33
+ return (
34
+ <>
35
+ <Container ref={containerRef} />
36
+ <p>Number of click events: {numberOfEvents}</p>
37
+ </>
38
+ );
39
+ };
40
+
41
+ export default UseClickOutsideExample;
42
+ ```
43
+
44
+ <UseClickOutsideExample />
45
+
46
+ Try clicking inside the red rectangle and outside it.