@cleartrip/ct-design-outside-click-handler 4.0.0 → 5.0.0

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/README.md ADDED
@@ -0,0 +1,63 @@
1
+ # OutsideClickHandler
2
+
3
+ A utility component that detects clicks outside of its boundaries.
4
+
5
+ ---
6
+
7
+ ## Installation
8
+
9
+ ```bash
10
+ npm install @cleartrip/ct-design-outside-click-handler
11
+ # or
12
+ pnpm add @cleartrip/ct-design-outside-click-handler
13
+ ```
14
+
15
+ ### Peer dependencies
16
+
17
+ ```bash
18
+ # Required for all targets
19
+ npm install react
20
+
21
+ # Web only
22
+ npm install react-dom
23
+
24
+ # React Native only
25
+ npm install react-native
26
+ ```
27
+
28
+ ---
29
+
30
+ ## Usage
31
+
32
+ ### Basic
33
+
34
+ ```tsx
35
+ import { OutsideClickHandler } from '@cleartrip/ct-design-outside-click-handler';
36
+
37
+ function Example() {
38
+ return (
39
+ <OutsideClickHandler>
40
+ {/* Basic usage */}
41
+ </OutsideClickHandler>
42
+ );
43
+ }
44
+ ```
45
+
46
+ ---
47
+
48
+ ## Accessibility
49
+
50
+ - The component follows accessibility best practices
51
+ - Ensure proper ARIA attributes are provided where needed
52
+ - Test with screen readers to ensure usability
53
+
54
+ ---
55
+
56
+ ## Migration
57
+
58
+ If migrating from a previous version:
59
+
60
+ ```diff
61
+ - import { OutsideClickHandler } from 'yagami/core/components';
62
+ + import { OutsideClickHandler } from '@cleartrip/ct-design-outside-click-handler';
63
+ ```
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
2
  import { OutsideClickHandlerProps } from './type';
3
- declare const OutsideClickHandler: React.ForwardRefExoticComponent<OutsideClickHandlerProps & React.RefAttributes<any>>;
3
+ declare const OutsideClickHandler: React.ForwardRefExoticComponent<OutsideClickHandlerProps & React.RefAttributes<HTMLDivElement>>;
4
4
  export default OutsideClickHandler;
5
5
  //# sourceMappingURL=OutsideClickHandler.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"OutsideClickHandler.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,EAA0D,wBAAwB,EAAE,MAAM,QAAQ,CAAC;AAY1G,QAAA,MAAM,mBAAmB,sFAuExB,CAAC;AAQF,eAAe,mBAAmB,CAAC"}
1
+ {"version":3,"file":"OutsideClickHandler.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,EAA0D,wBAAwB,EAAE,MAAM,QAAQ,CAAC;AAmB1G,QAAA,MAAM,mBAAmB,iGAuExB,CAAC;AAKF,eAAe,mBAAmB,CAAC"}
@@ -1,2 +1,2 @@
1
- "use strict";var e=require("tslib"),n=require("react"),t=require("@cleartrip/ct-design-use-event-callback"),r=require("react/jsx-runtime");function u(e){return e&&e.__esModule?e:{default:e}}var c=u(n),i=u(t);function o(e){return e.substring(2).toLowerCase()}var d=c.default.forwardRef((function(t){var r=t.onOutsideClick,u=t.children,d=t.disabled,s=void 0!==d&&d,a=t.mouseEvent,f=void 0===a?"onClick":a,l=t.touchEvent,v=void 0===l?"onTouchEnd":l,m=t.wrapperProps,E=n.useRef(),k=n.useRef(!1),L=c.default.useRef(!1);c.default.useEffect((function(){return setTimeout((function(){L.current=!0}),0),function(){L.current=!1}}),[]);var h=e.__assign({ref:E},m),p=i.default((function(e){if(k.current)k.current=!1;else{var n;if(e.composedPath)n=e.composedPath().indexOf(E.current)>-1;else{var t=e.target;n=!document.documentElement.contains(t)||E.current.contains(t)}!n&&L.current&&r(e)}}));return c.default.useEffect((function(){var e=o(v),n=function(){k.current=!0};return s||(document.addEventListener(e,p),document.addEventListener("touchmove",n)),function(){document.removeEventListener(e,p),document.removeEventListener("touchmove",n)}}),[p,v,s]),n.useEffect((function(){var e=o(f);return s||document.addEventListener(e,p,!1),function(){document.removeEventListener(e,p,!1)}}),[p,f,s]),c.default.createElement("div",h,u)}));d.defaultProps={onOutsideClick:function(){},disabled:!1};var s=function(t){var u=t.onOutsideClick,c=t.children,i=t.disabled,o=t.className,d=e.__rest(t,["onOutsideClick","children","disabled","className"]),s=n.useRef(),a=function(e){s.current.contains(e.target)||u(e)};return n.useEffect((function(){return i||(document.addEventListener("mousedown",a,!1),document.addEventListener("keydown",a,!1)),function(){document.removeEventListener("mousedown",a,!1),document.removeEventListener("keydown",a,!1)}}),[]),r.jsx("div",e.__assign({className:o},d,{ref:s},{children:c}))};s.defaultProps={onOutsideClick:function(){},disabled:!1,className:""},exports.OldOutsideClickHandler=s,exports.OutsideClickHandler=d;
1
+ "use strict";var e=require("react"),t=require("@cleartrip/ct-design-use-event-callback");function n(e){return e&&e.__esModule?e:{default:e}}var r=n(e),u=n(t);function c(e){return e.substring(2).toLowerCase()}const o=r.default.forwardRef(({onOutsideClick:t,children:n,disabled:o=!1,mouseEvent:s="onClick",touchEvent:d="onTouchEnd",wrapperProps:i})=>{const a=e.useRef(null),l=e.useRef(!1),f=r.default.useRef(!1);r.default.useEffect(()=>(setTimeout(()=>{f.current=!0},0),()=>{f.current=!1}),[]);const m=Object.assign({ref:a},i),v=u.default(e=>{if(l.current)return void(l.current=!1);let n;if(e.composedPath)n=a.current&&e.composedPath().indexOf(a.current)>-1;else{const t=e.target;n=!document.documentElement.contains(t)||a.current&&a.current.contains(t)}!n&&f.current&&t(e)});return r.default.useEffect(()=>{const e=c(d),t=()=>{l.current=!0};return o||(document.addEventListener(e,v),document.addEventListener("touchmove",t)),()=>{document.removeEventListener(e,v),document.removeEventListener("touchmove",t)}},[v,d,o]),e.useEffect(()=>{const e=c(s);return o||document.addEventListener(e,v,!1),()=>{document.removeEventListener(e,v,!1)}},[v,s,o]),r.default.createElement("div",m,n)});o.displayName="OutsideClickHandler",exports.OutsideClickHandler=o;
2
2
  //# sourceMappingURL=ct-design-outside-click-handler.browser.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-design-outside-click-handler.browser.cjs.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx","../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"sourcesContent":[null,null],"names":["mapEventPropToEvent","eventProp","substring","toLowerCase","OutsideClickHandler","React","default","forwardRef","_a","onOutsideClick","children","_b","disabled","_c","mouseEvent","_d","touchEvent","wrapperProps","node","useRef","pressedRef","activatedRef","useEffect","setTimeout","current","childrenProps","ref","handleClick","useEventCallback","event","insideDOM","composedPath","indexOf","target","document","documentElement","contains","mappedTouchEvent","handleTouchMove","addEventListener","removeEventListener","mappedMouseEvent","createElement","defaultProps","className","otherProps","__rest","e","_jsx","__assign"],"mappings":"gNAOA,SAASA,EACPC,GAEA,OAAOA,EAAUC,UAAU,GAAGC,aAChC,CAEA,IAAMC,EAAsBC,EAAKC,QAACC,YAChC,SAACC,OAAEC,EAAcD,EAAAC,eAAEC,EAAQF,EAAAE,SAAEC,EAAgBH,EAAAI,SAAhBA,OAAQ,IAAAD,GAAQA,EAAEE,EAAAL,EAAAM,WAAAA,OAAa,IAAAD,EAAA,UAASA,EAAEE,EAAyBP,EAAAQ,WAAzBA,OAAU,IAAAD,EAAG,aAAYA,EAAEE,EAAYT,EAAAS,aAEtGC,EAAOC,EAAAA,SAEPC,EAAaD,UAAO,GAEpBE,EAAehB,EAAAA,QAAMc,QAAO,GAElCd,EAAKC,QAACgB,WAAU,WAMd,OAHAC,YAAW,WACTF,EAAaG,SAAU,CACxB,GAAE,GACI,WACLH,EAAaG,SAAU,CACzB,CACD,GAAE,IAEH,IAAIC,cAAkBC,IAAKR,GAASD,GAE9BU,EAAcC,WAAiB,SAACC,GAEpC,GAAIT,EAAWI,QACbJ,EAAWI,SAAU,MADvB,CAIA,IAAIM,EAEJ,GAAID,EAAME,aACRD,EAAYD,EAAME,eAAeC,QAAQd,EAAKM,UAAY,MACrD,CACL,IAAMS,EAASJ,EAAMI,OACrBH,GAAaI,SAASC,gBAAgBC,SAASH,IAAWf,EAAKM,QAAQY,SAASH,EACjF,EACIH,GAAaT,EAAaG,SAC7Bf,EAAeoB,EAVhB,CAYH,IA8BA,OA3BAxB,EAAKC,QAACgB,WAAU,WACd,IAAMe,EAAmBrC,EAAoBgB,GACvCsB,EAAkB,WACtBlB,EAAWI,SAAU,CACvB,EAMA,OALKZ,IACHsB,SAASK,iBAAiBF,EAAkBV,GAC5CO,SAASK,iBAAiB,YAAaD,IAGlC,WACLJ,SAASM,oBAAoBH,EAAkBV,GAC/CO,SAASM,oBAAoB,YAAaF,EAC5C,CACD,GAAE,CAACX,EAAaX,EAAYJ,IAE7BU,EAAAA,WAAU,WACR,IAAMmB,EAAmBzC,EAAoBc,GAK7C,OAJKF,GACHsB,SAASK,iBAAiBE,EAAkBd,GAAa,GAGpD,WACLO,SAASM,oBAAoBC,EAAkBd,GAAa,EAC9D,CACD,GAAE,CAACA,EAAab,EAAYF,IAEtBP,EAAKC,QAACoC,cAAc,MAAOjB,EAAef,EACnD,IAIFN,EAAoBuC,aAAe,CACjClC,eAAgB,WAAQ,EACxBG,UAAU,GCtFN,IAAAR,EAA6D,SAACI,GAClE,IAAAC,EAAcD,EAAAC,eACdC,aACAE,EAAQJ,EAAAI,SACRgC,EAASpC,EAAAoC,UACNC,EAAUC,EAAAA,OAAAtC,EALqD,sDAO5DU,EAAOC,EAAAA,SAGPQ,EAAc,SAACoB,GACf7B,EAAKM,QAAQY,SAASW,EAAEd,SAG1BxB,EAAesC,EAEnB,EAcA,OAZAzB,EAAAA,WAAU,WAMR,OALKV,IACHsB,SAASK,iBAAiB,YAAaZ,GAAa,GACpDO,SAASK,iBAAiB,UAAWZ,GAAa,IAG7C,WACLO,SAASM,oBAAoB,YAAab,GAAa,GACvDO,SAASM,oBAAoB,UAAWb,GAAa,EACvD,CACD,GAAE,IAGDqB,EAAAA,IAAA,MAAAC,EAAAA,SAAA,CAAKL,UAAWA,GAAeC,EAAY,CAAAnB,IAAKR,GAAI,CAAAR,SACjDA,IAGP,EAEAN,EAAoBuC,aAAe,CACjClC,eAAgB,WAAQ,EACxBG,UAAU,EACVgC,UAAW"}
1
+ {"version":3,"file":"ct-design-outside-click-handler.browser.cjs.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"sourcesContent":[null],"names":["mapEventPropToEvent","eventProp","substring","toLowerCase","OutsideClickHandler","React","forwardRef","onOutsideClick","children","disabled","mouseEvent","touchEvent","wrapperProps","node","useRef","pressedRef","activatedRef","default","useEffect","setTimeout","current","childrenProps","ref","handleClick","useEventCallback","event","insideDOM","composedPath","indexOf","target","document","documentElement","contains","mappedTouchEvent","handleTouchMove","addEventListener","removeEventListener","mappedMouseEvent","createElement","displayName"],"mappings":"8JAOA,SAASA,EACPC,GAEA,OAAOA,EAAUC,UAAU,GAAGC,aAQhC,CAEM,MAAAC,EAAsBC,EAAAA,QAAMC,WAChC,EAAGC,iBAAgBC,WAAUC,YAAW,EAAOC,aAAa,UAAWC,aAAa,aAAcC,mBAEhG,MAAMC,EAAOC,SAAuB,MAE9BC,EAAaD,UAAO,GAEpBE,EAAeX,EAAAA,QAAMS,QAAO,GAElCT,EAAKY,QAACC,UAAU,KAGdC,WAAW,KACTH,EAAaI,SAAU,GACtB,GACI,KACLJ,EAAaI,SAAU,IAExB,IAEH,MAAMC,iBAAkBC,IAAKT,GAASD,GAEhCW,EAAcC,UAAkBC,IAEpC,GAAIV,EAAWK,QAEb,YADAL,EAAWK,SAAU,GAGvB,IAAIM,EAEJ,GAAID,EAAME,aACRD,EAAYb,EAAKO,SAAWK,EAAME,eAAeC,QAAQf,EAAKO,UAAY,MACrE,CACL,MAAMS,EAASJ,EAAMI,OACrBH,GAAaI,SAASC,gBAAgBC,SAASH,IAAYhB,EAAKO,SAAWP,EAAKO,QAAQY,SAASH,EAClG,EACIH,GAAaV,EAAaI,SAC7Bb,EAAekB,KAgCnB,OA3BApB,EAAKY,QAACC,UAAU,KACd,MAAMe,EAAmBjC,EAAoBW,GACvCuB,EAAkB,KACtBnB,EAAWK,SAAU,GAOvB,OALKX,IACHqB,SAASK,iBAAiBF,EAAkBV,GAC5CO,SAASK,iBAAiB,YAAaD,IAGlC,KACLJ,SAASM,oBAAoBH,EAAkBV,GAC/CO,SAASM,oBAAoB,YAAaF,KAE3C,CAACX,EAAaZ,EAAYF,IAE7BS,EAAAA,UAAU,KACR,MAAMmB,EAAmBrC,EAAoBU,GAK7C,OAJKD,GACHqB,SAASK,iBAAiBE,EAAkBd,GAAa,GAGpD,KACLO,SAASM,oBAAoBC,EAAkBd,GAAa,KAE7D,CAACA,EAAab,EAAYD,IAEtBJ,EAAKY,QAACqB,cAAc,MAAOjB,EAAeb,KAKrDJ,EAAoBmC,YAAc"}
@@ -1,2 +1,2 @@
1
- import{__assign as e,__rest as n}from"tslib";import t,{useRef as r,useEffect as o}from"react";import c from"@cleartrip/ct-design-use-event-callback";import{jsx as i}from"react/jsx-runtime";function u(e){return e.substring(2).toLowerCase()}var d=t.forwardRef((function(n){var i=n.onOutsideClick,d=n.children,s=n.disabled,a=void 0!==s&&s,m=n.mouseEvent,f=void 0===m?"onClick":m,l=n.touchEvent,v=void 0===l?"onTouchEnd":l,E=n.wrapperProps,p=r(),k=r(!1),L=t.useRef(!1);t.useEffect((function(){return setTimeout((function(){L.current=!0}),0),function(){L.current=!1}}),[]);var h=e({ref:p},E),C=c((function(e){if(k.current)k.current=!1;else{var n;if(e.composedPath)n=e.composedPath().indexOf(p.current)>-1;else{var t=e.target;n=!document.documentElement.contains(t)||p.current.contains(t)}!n&&L.current&&i(e)}}));return t.useEffect((function(){var e=u(v),n=function(){k.current=!0};return a||(document.addEventListener(e,C),document.addEventListener("touchmove",n)),function(){document.removeEventListener(e,C),document.removeEventListener("touchmove",n)}}),[C,v,a]),o((function(){var e=u(f);return a||document.addEventListener(e,C,!1),function(){document.removeEventListener(e,C,!1)}}),[C,f,a]),t.createElement("div",h,d)}));d.defaultProps={onOutsideClick:function(){},disabled:!1};var s=function(t){var c=t.onOutsideClick,u=t.children,d=t.disabled,s=t.className,a=n(t,["onOutsideClick","children","disabled","className"]),m=r(),f=function(e){m.current.contains(e.target)||c(e)};return o((function(){return d||(document.addEventListener("mousedown",f,!1),document.addEventListener("keydown",f,!1)),function(){document.removeEventListener("mousedown",f,!1),document.removeEventListener("keydown",f,!1)}}),[]),i("div",e({className:s},a,{ref:m},{children:u}))};s.defaultProps={onOutsideClick:function(){},disabled:!1,className:""};export{s as OldOutsideClickHandler,d as OutsideClickHandler};
1
+ import e,{useRef as t,useEffect as n}from"react";import r from"@cleartrip/ct-design-use-event-callback";function c(e){return e.substring(2).toLowerCase()}const o=e.forwardRef(({onOutsideClick:o,children:u,disabled:s=!1,mouseEvent:d="onClick",touchEvent:i="onTouchEnd",wrapperProps:m})=>{const a=t(null),l=t(!1),v=e.useRef(!1);e.useEffect(()=>(setTimeout(()=>{v.current=!0},0),()=>{v.current=!1}),[]);const f=Object.assign({ref:a},m),E=r(e=>{if(l.current)return void(l.current=!1);let t;if(e.composedPath)t=a.current&&e.composedPath().indexOf(a.current)>-1;else{const n=e.target;t=!document.documentElement.contains(n)||a.current&&a.current.contains(n)}!t&&v.current&&o(e)});return e.useEffect(()=>{const e=c(i),t=()=>{l.current=!0};return s||(document.addEventListener(e,E),document.addEventListener("touchmove",t)),()=>{document.removeEventListener(e,E),document.removeEventListener("touchmove",t)}},[E,i,s]),n(()=>{const e=c(d);return s||document.addEventListener(e,E,!1),()=>{document.removeEventListener(e,E,!1)}},[E,d,s]),e.createElement("div",f,u)});o.displayName="OutsideClickHandler";export{o as OutsideClickHandler};
2
2
  //# sourceMappingURL=ct-design-outside-click-handler.browser.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-design-outside-click-handler.browser.esm.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx","../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"sourcesContent":[null,null],"names":["mapEventPropToEvent","eventProp","substring","toLowerCase","OutsideClickHandler","React","forwardRef","_a","onOutsideClick","children","_b","disabled","_c","mouseEvent","_d","touchEvent","wrapperProps","node","useRef","pressedRef","activatedRef","useEffect","setTimeout","current","childrenProps","ref","handleClick","useEventCallback","event","insideDOM","composedPath","indexOf","target","document","documentElement","contains","mappedTouchEvent","handleTouchMove","addEventListener","removeEventListener","mappedMouseEvent","createElement","defaultProps","className","otherProps","__rest","e","_jsx","__assign"],"mappings":"6LAOA,SAASA,EACPC,GAEA,OAAOA,EAAUC,UAAU,GAAGC,aAChC,CAEA,IAAMC,EAAsBC,EAAMC,YAChC,SAACC,OAAEC,EAAcD,EAAAC,eAAEC,EAAQF,EAAAE,SAAEC,EAAgBH,EAAAI,SAAhBA,OAAQ,IAAAD,GAAQA,EAAEE,EAAAL,EAAAM,WAAAA,OAAa,IAAAD,EAAA,UAASA,EAAEE,EAAyBP,EAAAQ,WAAzBA,OAAU,IAAAD,EAAG,aAAYA,EAAEE,EAAYT,EAAAS,aAEtGC,EAAOC,IAEPC,EAAaD,GAAO,GAEpBE,EAAef,EAAMa,QAAO,GAElCb,EAAMgB,WAAU,WAMd,OAHAC,YAAW,WACTF,EAAaG,SAAU,CACxB,GAAE,GACI,WACLH,EAAaG,SAAU,CACzB,CACD,GAAE,IAEH,IAAIC,KAAkBC,IAAKR,GAASD,GAE9BU,EAAcC,GAAiB,SAACC,GAEpC,GAAIT,EAAWI,QACbJ,EAAWI,SAAU,MADvB,CAIA,IAAIM,EAEJ,GAAID,EAAME,aACRD,EAAYD,EAAME,eAAeC,QAAQd,EAAKM,UAAY,MACrD,CACL,IAAMS,EAASJ,EAAMI,OACrBH,GAAaI,SAASC,gBAAgBC,SAASH,IAAWf,EAAKM,QAAQY,SAASH,EACjF,EACIH,GAAaT,EAAaG,SAC7Bf,EAAeoB,EAVhB,CAYH,IA8BA,OA3BAvB,EAAMgB,WAAU,WACd,IAAMe,EAAmBpC,EAAoBe,GACvCsB,EAAkB,WACtBlB,EAAWI,SAAU,CACvB,EAMA,OALKZ,IACHsB,SAASK,iBAAiBF,EAAkBV,GAC5CO,SAASK,iBAAiB,YAAaD,IAGlC,WACLJ,SAASM,oBAAoBH,EAAkBV,GAC/CO,SAASM,oBAAoB,YAAaF,EAC5C,CACD,GAAE,CAACX,EAAaX,EAAYJ,IAE7BU,GAAU,WACR,IAAMmB,EAAmBxC,EAAoBa,GAK7C,OAJKF,GACHsB,SAASK,iBAAiBE,EAAkBd,GAAa,GAGpD,WACLO,SAASM,oBAAoBC,EAAkBd,GAAa,EAC9D,CACD,GAAE,CAACA,EAAab,EAAYF,IAEtBN,EAAMoC,cAAc,MAAOjB,EAAef,EACnD,IAIFL,EAAoBsC,aAAe,CACjClC,eAAgB,WAAQ,EACxBG,UAAU,GCtFN,IAAAP,EAA6D,SAACG,GAClE,IAAAC,EAAcD,EAAAC,eACdC,aACAE,EAAQJ,EAAAI,SACRgC,EAASpC,EAAAoC,UACNC,EAAUC,EAAAtC,EALqD,sDAO5DU,EAAOC,IAGPQ,EAAc,SAACoB,GACf7B,EAAKM,QAAQY,SAASW,EAAEd,SAG1BxB,EAAesC,EAEnB,EAcA,OAZAzB,GAAU,WAMR,OALKV,IACHsB,SAASK,iBAAiB,YAAaZ,GAAa,GACpDO,SAASK,iBAAiB,UAAWZ,GAAa,IAG7C,WACLO,SAASM,oBAAoB,YAAab,GAAa,GACvDO,SAASM,oBAAoB,UAAWb,GAAa,EACvD,CACD,GAAE,IAGDqB,EAAA,MAAAC,EAAA,CAAKL,UAAWA,GAAeC,EAAY,CAAAnB,IAAKR,GAAI,CAAAR,SACjDA,IAGP,EAEAL,EAAoBsC,aAAe,CACjClC,eAAgB,WAAQ,EACxBG,UAAU,EACVgC,UAAW"}
1
+ {"version":3,"file":"ct-design-outside-click-handler.browser.esm.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"sourcesContent":[null],"names":["mapEventPropToEvent","eventProp","substring","toLowerCase","OutsideClickHandler","React","forwardRef","onOutsideClick","children","disabled","mouseEvent","touchEvent","wrapperProps","node","useRef","pressedRef","activatedRef","useEffect","setTimeout","current","childrenProps","ref","handleClick","useEventCallback","event","insideDOM","composedPath","indexOf","target","document","documentElement","contains","mappedTouchEvent","handleTouchMove","addEventListener","removeEventListener","mappedMouseEvent","createElement","displayName"],"mappings":"wGAOA,SAASA,EACPC,GAEA,OAAOA,EAAUC,UAAU,GAAGC,aAQhC,CAEM,MAAAC,EAAsBC,EAAMC,WAChC,EAAGC,iBAAgBC,WAAUC,YAAW,EAAOC,aAAa,UAAWC,aAAa,aAAcC,mBAEhG,MAAMC,EAAOC,EAAuB,MAE9BC,EAAaD,GAAO,GAEpBE,EAAeX,EAAMS,QAAO,GAElCT,EAAMY,UAAU,KAGdC,WAAW,KACTF,EAAaG,SAAU,GACtB,GACI,KACLH,EAAaG,SAAU,IAExB,IAEH,MAAMC,iBAAkBC,IAAKR,GAASD,GAEhCU,EAAcC,EAAkBC,IAEpC,GAAIT,EAAWI,QAEb,YADAJ,EAAWI,SAAU,GAGvB,IAAIM,EAEJ,GAAID,EAAME,aACRD,EAAYZ,EAAKM,SAAWK,EAAME,eAAeC,QAAQd,EAAKM,UAAY,MACrE,CACL,MAAMS,EAASJ,EAAMI,OACrBH,GAAaI,SAASC,gBAAgBC,SAASH,IAAYf,EAAKM,SAAWN,EAAKM,QAAQY,SAASH,EAClG,EACIH,GAAaT,EAAaG,SAC7BZ,EAAeiB,KAgCnB,OA3BAnB,EAAMY,UAAU,KACd,MAAMe,EAAmBhC,EAAoBW,GACvCsB,EAAkB,KACtBlB,EAAWI,SAAU,GAOvB,OALKV,IACHoB,SAASK,iBAAiBF,EAAkBV,GAC5CO,SAASK,iBAAiB,YAAaD,IAGlC,KACLJ,SAASM,oBAAoBH,EAAkBV,GAC/CO,SAASM,oBAAoB,YAAaF,KAE3C,CAACX,EAAaX,EAAYF,IAE7BQ,EAAU,KACR,MAAMmB,EAAmBpC,EAAoBU,GAK7C,OAJKD,GACHoB,SAASK,iBAAiBE,EAAkBd,GAAa,GAGpD,KACLO,SAASM,oBAAoBC,EAAkBd,GAAa,KAE7D,CAACA,EAAaZ,EAAYD,IAEtBJ,EAAMgC,cAAc,MAAOjB,EAAeZ,KAKrDJ,EAAoBkC,YAAc"}
@@ -1,9 +1,7 @@
1
1
  'use strict';
2
2
 
3
- var tslib = require('tslib');
4
3
  var React = require('react');
5
4
  var useEventCallback = require('@cleartrip/ct-design-use-event-callback');
6
- var jsxRuntime = require('react/jsx-runtime');
7
5
 
8
6
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
7
 
@@ -13,96 +11,62 @@ var useEventCallback__default = /*#__PURE__*/_interopDefault(useEventCallback);
13
11
  function mapEventPropToEvent(eventProp) {
14
12
  return eventProp.substring(2).toLowerCase();
15
13
  }
16
- var OutsideClickHandler$1 = React__default.default.forwardRef(function (_a) {
17
- var onOutsideClick = _a.onOutsideClick, children = _a.children, _b = _a.disabled, disabled = _b === void 0 ? false : _b, _c = _a.mouseEvent, mouseEvent = _c === void 0 ? 'onClick' : _c, _d = _a.touchEvent, touchEvent = _d === void 0 ? 'onTouchEnd' : _d, wrapperProps = _a.wrapperProps;
18
- var node = React.useRef();
19
- var pressedRef = React.useRef(false);
20
- var activatedRef = React__default.default.useRef(false);
21
- React__default.default.useEffect(function () {
22
- setTimeout(function () {
14
+ const OutsideClickHandler = React__default.default.forwardRef(({ onOutsideClick, children, disabled = false, mouseEvent = 'onClick', touchEvent = 'onTouchEnd', wrapperProps }) => {
15
+ const node = React.useRef(null);
16
+ const pressedRef = React.useRef(false);
17
+ const activatedRef = React__default.default.useRef(false);
18
+ React__default.default.useEffect(() => {
19
+ setTimeout(() => {
23
20
  activatedRef.current = true;
24
21
  }, 0);
25
- return function () {
22
+ return () => {
26
23
  activatedRef.current = false;
27
24
  };
28
25
  }, []);
29
- var childrenProps = tslib.__assign({ ref: node }, wrapperProps);
30
- var handleClick = useEventCallback__default.default(function (event) {
26
+ const childrenProps = Object.assign({ ref: node }, wrapperProps);
27
+ const handleClick = useEventCallback__default.default((event) => {
31
28
  if (pressedRef.current) {
32
29
  pressedRef.current = false;
33
30
  return;
34
31
  }
35
- var insideDOM;
32
+ let insideDOM;
36
33
  if (event.composedPath) {
37
- insideDOM = event.composedPath().indexOf(node.current) > -1;
34
+ insideDOM = node.current && event.composedPath().indexOf(node.current) > -1;
38
35
  }
39
36
  else {
40
- var target = event.target;
41
- insideDOM = !document.documentElement.contains(target) || node.current.contains(target);
37
+ const target = event.target;
38
+ insideDOM = !document.documentElement.contains(target) || (node.current && node.current.contains(target));
42
39
  }
43
40
  if (!insideDOM && activatedRef.current) {
44
41
  onOutsideClick(event);
45
42
  }
46
43
  });
47
- React__default.default.useEffect(function () {
48
- var mappedTouchEvent = mapEventPropToEvent(touchEvent);
49
- var handleTouchMove = function () {
44
+ React__default.default.useEffect(() => {
45
+ const mappedTouchEvent = mapEventPropToEvent(touchEvent);
46
+ const handleTouchMove = () => {
50
47
  pressedRef.current = true;
51
48
  };
52
49
  if (!disabled) {
53
50
  document.addEventListener(mappedTouchEvent, handleClick);
54
51
  document.addEventListener('touchmove', handleTouchMove);
55
52
  }
56
- return function () {
53
+ return () => {
57
54
  document.removeEventListener(mappedTouchEvent, handleClick);
58
55
  document.removeEventListener('touchmove', handleTouchMove);
59
56
  };
60
57
  }, [handleClick, touchEvent, disabled]);
61
- React.useEffect(function () {
62
- var mappedMouseEvent = mapEventPropToEvent(mouseEvent);
58
+ React.useEffect(() => {
59
+ const mappedMouseEvent = mapEventPropToEvent(mouseEvent);
63
60
  if (!disabled) {
64
61
  document.addEventListener(mappedMouseEvent, handleClick, false);
65
62
  }
66
- return function () {
63
+ return () => {
67
64
  document.removeEventListener(mappedMouseEvent, handleClick, false);
68
65
  };
69
66
  }, [handleClick, mouseEvent, disabled]);
70
67
  return React__default.default.createElement('div', childrenProps, children);
71
68
  });
72
- OutsideClickHandler$1.defaultProps = {
73
- onOutsideClick: function () { },
74
- disabled: false,
75
- };
69
+ OutsideClickHandler.displayName = 'OutsideClickHandler';
76
70
 
77
- var OutsideClickHandler = function (_a) {
78
- var onOutsideClick = _a.onOutsideClick, children = _a.children, disabled = _a.disabled, className = _a.className, otherProps = tslib.__rest(_a, ["onOutsideClick", "children", "disabled", "className"]);
79
- var node = React.useRef();
80
- var handleClick = function (e) {
81
- if (node.current.contains(e.target)) {
82
- return;
83
- }
84
- else {
85
- onOutsideClick(e);
86
- }
87
- };
88
- React.useEffect(function () {
89
- if (!disabled) {
90
- document.addEventListener('mousedown', handleClick, false);
91
- document.addEventListener('keydown', handleClick, false);
92
- }
93
- return function () {
94
- document.removeEventListener('mousedown', handleClick, false);
95
- document.removeEventListener('keydown', handleClick, false);
96
- };
97
- }, []);
98
- return (jsxRuntime.jsx("div", tslib.__assign({ className: className }, otherProps, { ref: node }, { children: children })));
99
- };
100
- OutsideClickHandler.defaultProps = {
101
- onOutsideClick: function () { },
102
- disabled: false,
103
- className: '',
104
- };
105
-
106
- exports.OldOutsideClickHandler = OutsideClickHandler;
107
- exports.OutsideClickHandler = OutsideClickHandler$1;
71
+ exports.OutsideClickHandler = OutsideClickHandler;
108
72
  //# sourceMappingURL=ct-design-outside-click-handler.cjs.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-design-outside-click-handler.cjs.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx","../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"sourcesContent":[null,null],"names":["OutsideClickHandler","React","useRef","useEventCallback","useEffect","__rest","_jsx","__assign"],"mappings":";;;;;;;;;;;;AAOA,SAAS,mBAAmB,CAC1B,SAAkE,EAAA;IAElE,OAAO,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAAS,CAAC;AACrD,CAAC;AAED,IAAMA,qBAAmB,GAAGC,sBAAK,CAAC,UAAU,CAC1C,UAAC,EAA+G,EAAA;QAA7G,cAAc,GAAA,EAAA,CAAA,cAAA,EAAE,QAAQ,GAAA,EAAA,CAAA,QAAA,EAAE,EAAgB,GAAA,EAAA,CAAA,QAAA,EAAhB,QAAQ,GAAA,EAAA,KAAA,KAAA,CAAA,GAAG,KAAK,GAAA,EAAA,EAAE,EAAA,GAAA,EAAA,CAAA,UAAsB,EAAtB,UAAU,GAAG,EAAA,KAAA,KAAA,CAAA,GAAA,SAAS,GAAA,EAAA,EAAE,EAAyB,GAAA,EAAA,CAAA,UAAA,EAAzB,UAAU,GAAA,EAAA,KAAA,KAAA,CAAA,GAAG,YAAY,GAAA,EAAA,EAAE,YAAY,GAAA,EAAA,CAAA,YAAA,CAAA;AAE5G,IAAA,IAAM,IAAI,GAAGC,YAAM,EAA4C,CAAC;AAEhE,IAAA,IAAM,UAAU,GAAGA,YAAM,CAAC,KAAK,CAAC,CAAC;IAEjC,IAAM,YAAY,GAAGD,sBAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAEzCA,sBAAK,CAAC,SAAS,CAAC,YAAA;AAGd,QAAA,UAAU,CAAC,YAAA;AACT,YAAA,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC;SAC7B,EAAE,CAAC,CAAC,CAAC;QACN,OAAO,YAAA;AACL,YAAA,YAAY,CAAC,OAAO,GAAG,KAAK,CAAC;AAC/B,SAAC,CAAC;KACH,EAAE,EAAE,CAAC,CAAC;IAEP,IAAI,aAAa,oBAAK,GAAG,EAAE,IAAI,EAAK,EAAA,YAAY,CAAE,CAAC;AAEnD,IAAA,IAAM,WAAW,GAAGE,iCAAgB,CAAC,UAAC,KAA8B,EAAA;QAElE,IAAI,UAAU,CAAC,OAAO,EAAE;AACtB,YAAA,UAAU,CAAC,OAAO,GAAG,KAAK,CAAC;YAC3B,OAAO;AACR,SAAA;AACD,QAAA,IAAI,SAAS,CAAC;QAEd,IAAI,KAAK,CAAC,YAAY,EAAE;AACtB,YAAA,SAAS,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;AAC7D,SAAA;AAAM,aAAA;AACL,YAAA,IAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;AAC3C,YAAA,SAAS,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AACzF,SAAA;AACD,QAAA,IAAI,CAAC,SAAS,IAAI,YAAY,CAAC,OAAO,EAAE;YACtC,cAAc,CAAC,KAAK,CAAC,CAAC;AACvB,SAAA;AACH,KAAC,CAAC,CAAC;IAGHF,sBAAK,CAAC,SAAS,CAAC,YAAA;AACd,QAAA,IAAM,gBAAgB,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;AACzD,QAAA,IAAM,eAAe,GAAG,YAAA;AACtB,YAAA,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC;AAC5B,SAAC,CAAC;QACF,IAAI,CAAC,QAAQ,EAAE;AACb,YAAA,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;AACzD,YAAA,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;AACzD,SAAA;QAED,OAAO,YAAA;AACL,YAAA,QAAQ,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;AAC5D,YAAA,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;AAC7D,SAAC,CAAC;KACH,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;AAExC,IAAAG,eAAS,CAAC,YAAA;AACR,QAAA,IAAM,gBAAgB,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;AACjE,SAAA;QAED,OAAO,YAAA;YACL,QAAQ,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;AACrE,SAAC,CAAC;KACH,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExC,OAAOH,sBAAK,CAAC,aAAa,CAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;AAC7D,CAAC,EACD;AAGFD,qBAAmB,CAAC,YAAY,GAAG;IACjC,cAAc,EAAE,eAAQ;AACxB,IAAA,QAAQ,EAAE,KAAK;CAChB;;ACvFK,IAAA,mBAAmB,GAA0C,UAAC,EAMnE,EAAA;AALC,IAAA,IAAA,cAAc,GAAA,EAAA,CAAA,cAAA,EACd,QAAQ,cAAA,EACR,QAAQ,GAAA,EAAA,CAAA,QAAA,EACR,SAAS,GAAA,EAAA,CAAA,SAAA,EACN,UAAU,GAAAK,YAAA,CAAA,EAAA,EALqD,uDAMnE,CADc,CAAA;AAEb,IAAA,IAAM,IAAI,GAAGH,YAAM,EAA4C,CAAC;IAGhE,IAAM,WAAW,GAAG,UAAC,CAAM,EAAA;QACzB,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;YACnC,OAAO;AACR,SAAA;AAAM,aAAA;YACL,cAAc,CAAC,CAAC,CAAC,CAAC;AACnB,SAAA;AACH,KAAC,CAAC;AAEF,IAAAE,eAAS,CAAC,YAAA;QACR,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;YAC3D,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;AAC1D,SAAA;QAED,OAAO,YAAA;YACL,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;YAC9D,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;AAC9D,SAAC,CAAC;KACH,EAAE,EAAE,CAAC,CAAC;AAEP,IAAA,QACEE,cAAA,CAAA,KAAA,EAAAC,cAAA,CAAA,EAAK,SAAS,EAAE,SAAS,EAAM,EAAA,UAAU,EAAE,EAAA,GAAG,EAAE,IAAI,EAAA,EAAA,EAAA,QAAA,EACjD,QAAQ,EAAA,CAAA,CACL,EACN;AACJ,EAAE;AAEF,mBAAmB,CAAC,YAAY,GAAG;IACjC,cAAc,EAAE,eAAQ;AACxB,IAAA,QAAQ,EAAE,KAAK;AACf,IAAA,SAAS,EAAE,EAAE;CACd;;;;;"}
1
+ {"version":3,"file":"ct-design-outside-click-handler.cjs.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"sourcesContent":[null],"names":["React","useRef","useEventCallback","useEffect"],"mappings":"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"}
@@ -1,100 +1,65 @@
1
- import { __assign, __rest } from 'tslib';
2
1
  import React, { useRef, useEffect } from 'react';
3
2
  import useEventCallback from '@cleartrip/ct-design-use-event-callback';
4
- import { jsx } from 'react/jsx-runtime';
5
3
 
6
4
  function mapEventPropToEvent(eventProp) {
7
5
  return eventProp.substring(2).toLowerCase();
8
6
  }
9
- var OutsideClickHandler$1 = React.forwardRef(function (_a) {
10
- var onOutsideClick = _a.onOutsideClick, children = _a.children, _b = _a.disabled, disabled = _b === void 0 ? false : _b, _c = _a.mouseEvent, mouseEvent = _c === void 0 ? 'onClick' : _c, _d = _a.touchEvent, touchEvent = _d === void 0 ? 'onTouchEnd' : _d, wrapperProps = _a.wrapperProps;
11
- var node = useRef();
12
- var pressedRef = useRef(false);
13
- var activatedRef = React.useRef(false);
14
- React.useEffect(function () {
15
- setTimeout(function () {
7
+ const OutsideClickHandler = React.forwardRef(({ onOutsideClick, children, disabled = false, mouseEvent = 'onClick', touchEvent = 'onTouchEnd', wrapperProps }) => {
8
+ const node = useRef(null);
9
+ const pressedRef = useRef(false);
10
+ const activatedRef = React.useRef(false);
11
+ React.useEffect(() => {
12
+ setTimeout(() => {
16
13
  activatedRef.current = true;
17
14
  }, 0);
18
- return function () {
15
+ return () => {
19
16
  activatedRef.current = false;
20
17
  };
21
18
  }, []);
22
- var childrenProps = __assign({ ref: node }, wrapperProps);
23
- var handleClick = useEventCallback(function (event) {
19
+ const childrenProps = Object.assign({ ref: node }, wrapperProps);
20
+ const handleClick = useEventCallback((event) => {
24
21
  if (pressedRef.current) {
25
22
  pressedRef.current = false;
26
23
  return;
27
24
  }
28
- var insideDOM;
25
+ let insideDOM;
29
26
  if (event.composedPath) {
30
- insideDOM = event.composedPath().indexOf(node.current) > -1;
27
+ insideDOM = node.current && event.composedPath().indexOf(node.current) > -1;
31
28
  }
32
29
  else {
33
- var target = event.target;
34
- insideDOM = !document.documentElement.contains(target) || node.current.contains(target);
30
+ const target = event.target;
31
+ insideDOM = !document.documentElement.contains(target) || (node.current && node.current.contains(target));
35
32
  }
36
33
  if (!insideDOM && activatedRef.current) {
37
34
  onOutsideClick(event);
38
35
  }
39
36
  });
40
- React.useEffect(function () {
41
- var mappedTouchEvent = mapEventPropToEvent(touchEvent);
42
- var handleTouchMove = function () {
37
+ React.useEffect(() => {
38
+ const mappedTouchEvent = mapEventPropToEvent(touchEvent);
39
+ const handleTouchMove = () => {
43
40
  pressedRef.current = true;
44
41
  };
45
42
  if (!disabled) {
46
43
  document.addEventListener(mappedTouchEvent, handleClick);
47
44
  document.addEventListener('touchmove', handleTouchMove);
48
45
  }
49
- return function () {
46
+ return () => {
50
47
  document.removeEventListener(mappedTouchEvent, handleClick);
51
48
  document.removeEventListener('touchmove', handleTouchMove);
52
49
  };
53
50
  }, [handleClick, touchEvent, disabled]);
54
- useEffect(function () {
55
- var mappedMouseEvent = mapEventPropToEvent(mouseEvent);
51
+ useEffect(() => {
52
+ const mappedMouseEvent = mapEventPropToEvent(mouseEvent);
56
53
  if (!disabled) {
57
54
  document.addEventListener(mappedMouseEvent, handleClick, false);
58
55
  }
59
- return function () {
56
+ return () => {
60
57
  document.removeEventListener(mappedMouseEvent, handleClick, false);
61
58
  };
62
59
  }, [handleClick, mouseEvent, disabled]);
63
60
  return React.createElement('div', childrenProps, children);
64
61
  });
65
- OutsideClickHandler$1.defaultProps = {
66
- onOutsideClick: function () { },
67
- disabled: false,
68
- };
62
+ OutsideClickHandler.displayName = 'OutsideClickHandler';
69
63
 
70
- var OutsideClickHandler = function (_a) {
71
- var onOutsideClick = _a.onOutsideClick, children = _a.children, disabled = _a.disabled, className = _a.className, otherProps = __rest(_a, ["onOutsideClick", "children", "disabled", "className"]);
72
- var node = useRef();
73
- var handleClick = function (e) {
74
- if (node.current.contains(e.target)) {
75
- return;
76
- }
77
- else {
78
- onOutsideClick(e);
79
- }
80
- };
81
- useEffect(function () {
82
- if (!disabled) {
83
- document.addEventListener('mousedown', handleClick, false);
84
- document.addEventListener('keydown', handleClick, false);
85
- }
86
- return function () {
87
- document.removeEventListener('mousedown', handleClick, false);
88
- document.removeEventListener('keydown', handleClick, false);
89
- };
90
- }, []);
91
- return (jsx("div", __assign({ className: className }, otherProps, { ref: node }, { children: children })));
92
- };
93
- OutsideClickHandler.defaultProps = {
94
- onOutsideClick: function () { },
95
- disabled: false,
96
- className: '',
97
- };
98
-
99
- export { OutsideClickHandler as OldOutsideClickHandler, OutsideClickHandler$1 as OutsideClickHandler };
64
+ export { OutsideClickHandler };
100
65
  //# sourceMappingURL=ct-design-outside-click-handler.esm.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-design-outside-click-handler.esm.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx","../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"sourcesContent":[null,null],"names":["OutsideClickHandler","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"ct-design-outside-click-handler.esm.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"sourcesContent":[null],"names":[],"mappings":";;;AAOA,SAAS,mBAAmB,CAC1B,SAAkE,EAAA;IAElE,OAAO,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,WAAW,EAO1B,CAAC;AAClB,CAAC;AAEK,MAAA,mBAAmB,GAAG,KAAK,CAAC,UAAU,CAC1C,CAAC,EAAE,cAAc,EAAE,QAAQ,EAAE,QAAQ,GAAG,KAAK,EAAE,UAAU,GAAG,SAAS,EAAE,UAAU,GAAG,YAAY,EAAE,YAAY,EAAE,KAAI;AAElH,IAAA,MAAM,IAAI,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;AAE1C,IAAA,MAAM,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAEjC,MAAM,YAAY,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAEzC,IAAA,KAAK,CAAC,SAAS,CAAC,MAAK;QAGnB,UAAU,CAAC,MAAK;AACd,YAAA,YAAY,CAAC,OAAO,GAAG,IAAI,CAAC;SAC7B,EAAE,CAAC,CAAC,CAAC;AACN,QAAA,OAAO,MAAK;AACV,YAAA,YAAY,CAAC,OAAO,GAAG,KAAK,CAAC;AAC/B,SAAC,CAAC;KACH,EAAE,EAAE,CAAC,CAAC;IAEP,MAAM,aAAa,mBAAK,GAAG,EAAE,IAAI,EAAK,EAAA,YAAY,CAAE,CAAC;AAErD,IAAA,MAAM,WAAW,GAAG,gBAAgB,CAAC,CAAC,KAA8B,KAAI;AAEtE,QAAA,IAAI,UAAU,CAAC,OAAO,EAAE;AACtB,YAAA,UAAU,CAAC,OAAO,GAAG,KAAK,CAAC;YAC3B,OAAO;SACR;AACD,QAAA,IAAI,SAAS,CAAC;AAEd,QAAA,IAAI,KAAK,CAAC,YAAY,EAAE;AACtB,YAAA,SAAS,GAAG,IAAI,CAAC,OAAO,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;SAC7E;aAAM;AACL,YAAA,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;YAC3C,SAAS,GAAG,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;SAC3G;AACD,QAAA,IAAI,CAAC,SAAS,IAAI,YAAY,CAAC,OAAO,EAAE;YACtC,cAAc,CAAC,KAAK,CAAC,CAAC;SACvB;AACH,KAAC,CAAC,CAAC;AAGH,IAAA,KAAK,CAAC,SAAS,CAAC,MAAK;AACnB,QAAA,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACzD,MAAM,eAAe,GAAG,MAAK;AAC3B,YAAA,UAAU,CAAC,OAAO,GAAG,IAAI,CAAC;AAC5B,SAAC,CAAC;QACF,IAAI,CAAC,QAAQ,EAAE;AACb,YAAA,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;AACzD,YAAA,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;SACzD;AAED,QAAA,OAAO,MAAK;AACV,YAAA,QAAQ,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;AAC5D,YAAA,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;AAC7D,SAAC,CAAC;KACH,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExC,SAAS,CAAC,MAAK;AACb,QAAA,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,UAAU,CAAC,CAAC;QACzD,IAAI,CAAC,QAAQ,EAAE;YACb,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;SACjE;AAED,QAAA,OAAO,MAAK;YACV,QAAQ,CAAC,mBAAmB,CAAC,gBAAgB,EAAE,WAAW,EAAE,KAAK,CAAC,CAAC;AACrE,SAAC,CAAC;KACH,EAAE,CAAC,WAAW,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC;IAExC,OAAO,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;AAC7D,CAAC,EACD;AAGF,mBAAmB,CAAC,WAAW,GAAG,qBAAqB;;;;"}
@@ -1,148 +1,75 @@
1
1
  (function (global, factory) {
2
- typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react'), require('@cleartrip/ct-design-use-event-callback'), require('react/jsx-runtime')) :
3
- typeof define === 'function' && define.amd ? define(['exports', 'react', '@cleartrip/ct-design-use-event-callback', 'react/jsx-runtime'], factory) :
4
- (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.CTDesignSystemOutsideClickHandler = {}, global.React, global.useEventCallback, global.jsxRuntime));
5
- })(this, (function (exports, React, useEventCallback, jsxRuntime) { 'use strict';
2
+ typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react'), require('@cleartrip/ct-design-use-event-callback')) :
3
+ typeof define === 'function' && define.amd ? define(['exports', 'react', '@cleartrip/ct-design-use-event-callback'], factory) :
4
+ (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.CTDesignSystemOutsideClickHandler = {}, global.React, global.useEventCallback));
5
+ })(this, (function (exports, React, useEventCallback) { 'use strict';
6
6
 
7
7
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
8
8
 
9
9
  var React__default = /*#__PURE__*/_interopDefault(React);
10
10
  var useEventCallback__default = /*#__PURE__*/_interopDefault(useEventCallback);
11
11
 
12
- /******************************************************************************
13
- Copyright (c) Microsoft Corporation.
14
-
15
- Permission to use, copy, modify, and/or distribute this software for any
16
- purpose with or without fee is hereby granted.
17
-
18
- THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
19
- REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
20
- AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
21
- INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
22
- LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
23
- OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
24
- PERFORMANCE OF THIS SOFTWARE.
25
- ***************************************************************************** */
26
- /* global Reflect, Promise, SuppressedError, Symbol */
27
-
28
- var __assign = function () {
29
- __assign = Object.assign || function __assign(t) {
30
- for (var s, i = 1, n = arguments.length; i < n; i++) {
31
- s = arguments[i];
32
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
33
- }
34
- return t;
35
- };
36
- return __assign.apply(this, arguments);
37
- };
38
- function __rest(s, e) {
39
- var t = {};
40
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
41
- if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
42
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
43
- }
44
- return t;
45
- }
46
- typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
47
- var e = new Error(message);
48
- return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
49
- };
50
-
51
12
  function mapEventPropToEvent(eventProp) {
52
13
  return eventProp.substring(2).toLowerCase();
53
14
  }
54
- var OutsideClickHandler$1 = React__default.default.forwardRef(function (_a) {
55
- var onOutsideClick = _a.onOutsideClick, children = _a.children, _b = _a.disabled, disabled = _b === void 0 ? false : _b, _c = _a.mouseEvent, mouseEvent = _c === void 0 ? 'onClick' : _c, _d = _a.touchEvent, touchEvent = _d === void 0 ? 'onTouchEnd' : _d, wrapperProps = _a.wrapperProps;
56
- var node = React.useRef();
57
- var pressedRef = React.useRef(false);
58
- var activatedRef = React__default.default.useRef(false);
59
- React__default.default.useEffect(function () {
60
- setTimeout(function () {
15
+ const OutsideClickHandler = React__default.default.forwardRef(({ onOutsideClick, children, disabled = false, mouseEvent = 'onClick', touchEvent = 'onTouchEnd', wrapperProps }) => {
16
+ const node = React.useRef(null);
17
+ const pressedRef = React.useRef(false);
18
+ const activatedRef = React__default.default.useRef(false);
19
+ React__default.default.useEffect(() => {
20
+ setTimeout(() => {
61
21
  activatedRef.current = true;
62
22
  }, 0);
63
- return function () {
23
+ return () => {
64
24
  activatedRef.current = false;
65
25
  };
66
26
  }, []);
67
- var childrenProps = __assign({ ref: node }, wrapperProps);
68
- var handleClick = useEventCallback__default.default(function (event) {
27
+ const childrenProps = Object.assign({ ref: node }, wrapperProps);
28
+ const handleClick = useEventCallback__default.default((event) => {
69
29
  if (pressedRef.current) {
70
30
  pressedRef.current = false;
71
31
  return;
72
32
  }
73
- var insideDOM;
33
+ let insideDOM;
74
34
  if (event.composedPath) {
75
- insideDOM = event.composedPath().indexOf(node.current) > -1;
35
+ insideDOM = node.current && event.composedPath().indexOf(node.current) > -1;
76
36
  }
77
37
  else {
78
- var target = event.target;
79
- insideDOM = !document.documentElement.contains(target) || node.current.contains(target);
38
+ const target = event.target;
39
+ insideDOM = !document.documentElement.contains(target) || (node.current && node.current.contains(target));
80
40
  }
81
41
  if (!insideDOM && activatedRef.current) {
82
42
  onOutsideClick(event);
83
43
  }
84
44
  });
85
- React__default.default.useEffect(function () {
86
- var mappedTouchEvent = mapEventPropToEvent(touchEvent);
87
- var handleTouchMove = function () {
45
+ React__default.default.useEffect(() => {
46
+ const mappedTouchEvent = mapEventPropToEvent(touchEvent);
47
+ const handleTouchMove = () => {
88
48
  pressedRef.current = true;
89
49
  };
90
50
  if (!disabled) {
91
51
  document.addEventListener(mappedTouchEvent, handleClick);
92
52
  document.addEventListener('touchmove', handleTouchMove);
93
53
  }
94
- return function () {
54
+ return () => {
95
55
  document.removeEventListener(mappedTouchEvent, handleClick);
96
56
  document.removeEventListener('touchmove', handleTouchMove);
97
57
  };
98
58
  }, [handleClick, touchEvent, disabled]);
99
- React.useEffect(function () {
100
- var mappedMouseEvent = mapEventPropToEvent(mouseEvent);
59
+ React.useEffect(() => {
60
+ const mappedMouseEvent = mapEventPropToEvent(mouseEvent);
101
61
  if (!disabled) {
102
62
  document.addEventListener(mappedMouseEvent, handleClick, false);
103
63
  }
104
- return function () {
64
+ return () => {
105
65
  document.removeEventListener(mappedMouseEvent, handleClick, false);
106
66
  };
107
67
  }, [handleClick, mouseEvent, disabled]);
108
68
  return React__default.default.createElement('div', childrenProps, children);
109
69
  });
110
- OutsideClickHandler$1.defaultProps = {
111
- onOutsideClick: function () { },
112
- disabled: false,
113
- };
114
-
115
- var OutsideClickHandler = function (_a) {
116
- var onOutsideClick = _a.onOutsideClick, children = _a.children, disabled = _a.disabled, className = _a.className, otherProps = __rest(_a, ["onOutsideClick", "children", "disabled", "className"]);
117
- var node = React.useRef();
118
- var handleClick = function (e) {
119
- if (node.current.contains(e.target)) {
120
- return;
121
- }
122
- else {
123
- onOutsideClick(e);
124
- }
125
- };
126
- React.useEffect(function () {
127
- if (!disabled) {
128
- document.addEventListener('mousedown', handleClick, false);
129
- document.addEventListener('keydown', handleClick, false);
130
- }
131
- return function () {
132
- document.removeEventListener('mousedown', handleClick, false);
133
- document.removeEventListener('keydown', handleClick, false);
134
- };
135
- }, []);
136
- return (jsxRuntime.jsx("div", __assign({ className: className }, otherProps, { ref: node }, { children: children })));
137
- };
138
- OutsideClickHandler.defaultProps = {
139
- onOutsideClick: function () { },
140
- disabled: false,
141
- className: '',
142
- };
70
+ OutsideClickHandler.displayName = 'OutsideClickHandler';
143
71
 
144
- exports.OldOutsideClickHandler = OutsideClickHandler;
145
- exports.OutsideClickHandler = OutsideClickHandler$1;
72
+ exports.OutsideClickHandler = OutsideClickHandler;
146
73
 
147
74
  }));
148
75
  //# sourceMappingURL=ct-design-outside-click-handler.umd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-design-outside-click-handler.umd.js","sources":["../../../../node_modules/.pnpm/@rollup+plugin-typescript@9.0.2_rollup@3.29.4_tslib@2.6.3_typescript@4.9.5/node_modules/tslib/tslib.es6.js","../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx","../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"sourcesContent":["/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n function next() {\r\n while (env.stack.length) {\r\n var rec = env.stack.pop();\r\n try {\r\n var result = rec.dispose && rec.dispose.call(rec.value);\r\n if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n};\r\n",null,null],"names":["__assign","Object","assign","t","s","i","n","arguments","length","p","prototype","hasOwnProperty","call","apply","__rest","e","indexOf","getOwnPropertySymbols","propertyIsEnumerable","SuppressedError","error","suppressed","message","Error","name","OutsideClickHandler","React","useRef","useEventCallback","useEffect","_jsx"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"ct-design-outside-click-handler.umd.js","sources":["../packages/components/OutsideClickHandler/src/OutsideClickHandler.tsx"],"sourcesContent":[null],"names":["React","useRef","useEventCallback","useEffect"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,4 +1,3 @@
1
1
  export { default as OutsideClickHandler } from './OutsideClickHandler';
2
- export { default as OldOutsideClickHandler } from './OldOutsideClickHandler';
3
- export * from './type';
2
+ export type * from './type';
4
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AACvE,OAAO,EAAE,OAAO,IAAI,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAC7E,cAAc,QAAQ,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AACvE,mBAAmB,QAAQ,CAAC"}
package/dist/type.d.ts CHANGED
@@ -8,7 +8,7 @@ export interface OutsideClickHandlerProps {
8
8
  mouseEvent?: ClickAwayMouseEventHandler;
9
9
  touchEvent?: ClickAwayTouchEventHandler;
10
10
  children: ReactNode;
11
- wrapperProps?: HtmlCompositeAttributes<{}, 'Div'>;
11
+ wrapperProps?: HtmlCompositeAttributes<object, 'Div'>;
12
12
  }
13
13
  export interface OldOutsideClickHandlerProps extends OutsideClickHandlerProps {
14
14
  className?: string;
@@ -1 +1 @@
1
- {"version":3,"file":"type.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,MAAM,MAAM,0BAA0B,GAAG,SAAS,GAAG,aAAa,GAAG,WAAW,GAAG,eAAe,GAAG,aAAa,CAAC;AACnH,MAAM,MAAM,0BAA0B,GAAG,cAAc,GAAG,YAAY,CAAC;AAEvE,MAAM,WAAW,wBAAwB;IAIvC,cAAc,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,KAAK,IAAI,CAAC;IAKzD,QAAQ,CAAC,EAAE,OAAO,CAAC;IAKnB,UAAU,CAAC,EAAE,0BAA0B,CAAC;IAKxC,UAAU,CAAC,EAAE,0BAA0B,CAAC;IAIxC,QAAQ,EAAE,SAAS,CAAC;IAEpB,YAAY,CAAC,EAAE,uBAAuB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;CACnD;AAED,MAAM,WAAW,2BAA4B,SAAQ,wBAAwB;IAC3E,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB"}
1
+ {"version":3,"file":"type.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,MAAM,MAAM,0BAA0B,GAAG,SAAS,GAAG,aAAa,GAAG,WAAW,GAAG,eAAe,GAAG,aAAa,CAAC;AACnH,MAAM,MAAM,0BAA0B,GAAG,cAAc,GAAG,YAAY,CAAC;AAEvE,MAAM,WAAW,wBAAwB;IAIvC,cAAc,EAAE,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU,KAAK,IAAI,CAAC;IAKzD,QAAQ,CAAC,EAAE,OAAO,CAAC;IAKnB,UAAU,CAAC,EAAE,0BAA0B,CAAC;IAKxC,UAAU,CAAC,EAAE,0BAA0B,CAAC;IAIxC,QAAQ,EAAE,SAAS,CAAC;IAEpB,YAAY,CAAC,EAAE,uBAAuB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;CACvD;AAED,MAAM,WAAW,2BAA4B,SAAQ,wBAAwB;IAC3E,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB"}
package/package.json CHANGED
@@ -1,29 +1,37 @@
1
1
  {
2
2
  "name": "@cleartrip/ct-design-outside-click-handler",
3
- "version": "4.0.0",
3
+ "version": "5.0.0",
4
4
  "description": "OutsideClickHandler Component",
5
5
  "types": "dist/index.d.ts",
6
- "main": "dist/ct-design-outside-click-handler.cjs.js",
6
+ "main": "./dist/ct-design-outside-click-handler.cjs.js",
7
7
  "jsnext:main": "dist/ct-design-outside-click-handler.esm.js",
8
8
  "module": "dist/ct-design-outside-click-handler.esm.js",
9
9
  "sideEffects": false,
10
+ "exports": {
11
+ ".": {
12
+ "types": "./dist/index.d.ts",
13
+ "import": "./dist/ct-design-outside-click-handler.esm.js",
14
+ "default": "./dist/ct-design-outside-click-handler.cjs.js"
15
+ }
16
+ },
10
17
  "browser": {
11
18
  "./dist/ct-design-outside-click-handler.esm.js": "./dist/ct-design-outside-click-handler.browser.esm.js",
12
19
  "./dist/ct-design-outside-click-handler.cjs.js": "./dist/ct-design-outside-click-handler.browser.cjs.js"
13
20
  },
14
21
  "files": [
15
- "dist"
22
+ "dist",
23
+ "src"
16
24
  ],
17
25
  "dependencies": {
18
- "@cleartrip/ct-design-use-event-callback": "4.0.0"
26
+ "@cleartrip/ct-design-theme": "5.0.0",
27
+ "@cleartrip/ct-design-use-event-callback": "5.0.0"
19
28
  },
20
29
  "devDependencies": {
21
- "@cleartrip/ct-design-types": "4.0.0"
30
+ "@cleartrip/ct-design-types": "5.0.0"
22
31
  },
23
32
  "peerDependencies": {
24
33
  "react": ">=16.8.0",
25
- "react-dom": ">=16.8.0",
26
- "styled-components": "^5.3.6"
34
+ "react-dom": ">=16.8.0"
27
35
  },
28
36
  "publishConfig": {
29
37
  "access": "public"
@@ -34,6 +42,8 @@
34
42
  "test": "echo \"Error: no test specified\" && exit 1",
35
43
  "watch-package": "rollup -c -w",
36
44
  "build-package": "rollup -c",
37
- "build-package:clean": "rm -rf dist && rollup -c"
45
+ "build-package:clean": "rm -rf dist && rollup -c",
46
+ "publish-package:local": "yalc publish --no-scripts",
47
+ "publish-package:local:registry": "pnpm publish --registry http://localhost:4873 --no-git-checks --access public"
38
48
  }
39
49
  }
@@ -0,0 +1,97 @@
1
+ import React, { useRef, useEffect } from 'react';
2
+ import { ClickAwayMouseEventHandler, ClickAwayTouchEventHandler, OutsideClickHandlerProps } from './type';
3
+ import useEventCallback from '@cleartrip/ct-design-use-event-callback';
4
+
5
+ /**
6
+ * maps onClick -> click
7
+ */
8
+ function mapEventPropToEvent(
9
+ eventProp: ClickAwayMouseEventHandler | ClickAwayTouchEventHandler,
10
+ ): 'click' | 'mousedown' | 'mouseup' | 'touchstart' | 'touchend' | 'pointerdown' | 'pointerup' {
11
+ return eventProp.substring(2).toLowerCase() as
12
+ | 'click'
13
+ | 'mousedown'
14
+ | 'mouseup'
15
+ | 'touchstart'
16
+ | 'touchend'
17
+ | 'pointerdown'
18
+ | 'pointerup';
19
+ }
20
+
21
+ const OutsideClickHandler = React.forwardRef<HTMLDivElement, OutsideClickHandlerProps>(
22
+ ({ onOutsideClick, children, disabled = false, mouseEvent = 'onClick', touchEvent = 'onTouchEnd', wrapperProps }) => {
23
+ // node ref to track element events
24
+ const node = useRef<HTMLDivElement>(null);
25
+ // press event ref like in mobile
26
+ const pressedRef = useRef(false);
27
+ // check if event tracking is activated
28
+ const activatedRef = React.useRef(false);
29
+
30
+ React.useEffect(() => {
31
+ // Ensure that this component is not "activated" synchronously.
32
+ // https://github.com/facebook/react/issues/20074
33
+ setTimeout(() => {
34
+ activatedRef.current = true;
35
+ }, 0);
36
+ return () => {
37
+ activatedRef.current = false;
38
+ };
39
+ }, []);
40
+
41
+ const childrenProps = { ref: node, ...wrapperProps };
42
+
43
+ const handleClick = useEventCallback((event: MouseEvent | TouchEvent) => {
44
+ // Do not act if user performed touchmove
45
+ if (pressedRef.current) {
46
+ pressedRef.current = false;
47
+ return;
48
+ }
49
+ let insideDOM;
50
+
51
+ if (event.composedPath) {
52
+ insideDOM = node.current && event.composedPath().indexOf(node.current) > -1;
53
+ } else {
54
+ const target = event.target as Node | null;
55
+ insideDOM = !document.documentElement.contains(target) || (node.current && node.current.contains(target));
56
+ }
57
+ if (!insideDOM && activatedRef.current) {
58
+ onOutsideClick(event);
59
+ }
60
+ });
61
+
62
+ // use effect for touch event
63
+ React.useEffect(() => {
64
+ const mappedTouchEvent = mapEventPropToEvent(touchEvent);
65
+ const handleTouchMove = () => {
66
+ pressedRef.current = true;
67
+ };
68
+ if (!disabled) {
69
+ document.addEventListener(mappedTouchEvent, handleClick);
70
+ document.addEventListener('touchmove', handleTouchMove);
71
+ }
72
+
73
+ return () => {
74
+ document.removeEventListener(mappedTouchEvent, handleClick);
75
+ document.removeEventListener('touchmove', handleTouchMove);
76
+ };
77
+ }, [handleClick, touchEvent, disabled]);
78
+ // use effect for mouse event
79
+ useEffect(() => {
80
+ const mappedMouseEvent = mapEventPropToEvent(mouseEvent);
81
+ if (!disabled) {
82
+ document.addEventListener(mappedMouseEvent, handleClick, false);
83
+ }
84
+
85
+ return () => {
86
+ document.removeEventListener(mappedMouseEvent, handleClick, false);
87
+ };
88
+ }, [handleClick, mouseEvent, disabled]);
89
+
90
+ return React.createElement('div', childrenProps, children);
91
+ },
92
+ );
93
+
94
+ // TODO add documentation
95
+ OutsideClickHandler.displayName = 'OutsideClickHandler';
96
+
97
+ export default OutsideClickHandler;
package/src/index.ts ADDED
@@ -0,0 +1,2 @@
1
+ export { default as OutsideClickHandler } from './OutsideClickHandler';
2
+ export type * from './type';
package/src/type.ts ADDED
@@ -0,0 +1,37 @@
1
+ import { HtmlCompositeAttributes } from '@cleartrip/ct-design-types';
2
+ import { ReactNode } from 'react';
3
+
4
+ export type ClickAwayMouseEventHandler = 'onClick' | 'onMouseDown' | 'onMouseUp' | 'onPointerDown' | 'onPointerUp';
5
+ export type ClickAwayTouchEventHandler = 'onTouchStart' | 'onTouchEnd';
6
+
7
+ export interface OutsideClickHandlerProps {
8
+ /**
9
+ * click handler for outside event
10
+ */
11
+ onOutsideClick: (event: MouseEvent | TouchEvent) => void;
12
+ /**
13
+ * check if outside click event is disabled
14
+ * @default false
15
+ */
16
+ disabled?: boolean;
17
+ /**
18
+ * the mouse event it should listen to
19
+ * @default 'onCLick'
20
+ */
21
+ mouseEvent?: ClickAwayMouseEventHandler;
22
+ /**
23
+ * touch event it should listen
24
+ * @default 'onTouchEnd'
25
+ */
26
+ touchEvent?: ClickAwayTouchEventHandler;
27
+ /**
28
+ * children
29
+ */
30
+ children: ReactNode;
31
+
32
+ wrapperProps?: HtmlCompositeAttributes<object, 'Div'>;
33
+ }
34
+
35
+ export interface OldOutsideClickHandlerProps extends OutsideClickHandlerProps {
36
+ className?: string;
37
+ }
@@ -1,5 +0,0 @@
1
- import React from 'react';
2
- import { OldOutsideClickHandlerProps } from './type';
3
- declare const OutsideClickHandler: React.FC<OldOutsideClickHandlerProps>;
4
- export default OutsideClickHandler;
5
- //# sourceMappingURL=OldOutsideClickHandler.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"OldOutsideClickHandler.d.ts","sourceRoot":"","sources":["../packages/components/OutsideClickHandler/src/OldOutsideClickHandler.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,EAAE,2BAA2B,EAAE,MAAM,QAAQ,CAAC;AAErD,QAAA,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,2BAA2B,CAmC9D,CAAC;AAQF,eAAe,mBAAmB,CAAC"}