@i-novus/n2o-components 7.27.37 → 7.27.39
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/lib/Typography/FormattedText.d.ts +10 -0
- package/lib/Typography/FormattedText.js +19 -0
- package/lib/Typography/FormattedText.js.map +1 -0
- package/lib/Typography/Text.d.ts +8 -0
- package/lib/Typography/Text.js +16 -0
- package/lib/Typography/Text.js.map +1 -0
- package/lib/Typography/Title.d.ts +267 -0
- package/lib/Typography/Title.js +14 -0
- package/lib/Typography/Title.js.map +1 -0
- package/lib/Typography/utils.d.ts +3 -0
- package/lib/Typography/utils.js +28 -0
- package/lib/Typography/utils.js.map +1 -0
- package/lib/display/Block.d.ts +2 -2
- package/lib/display/Tooltip/Tooltip.d.ts +13 -0
- package/lib/display/Tooltip/Tooltip.js +24 -0
- package/lib/display/Tooltip/Tooltip.js.map +1 -0
- package/lib/display/Tooltip/TooltipComponent.d.ts +15 -0
- package/lib/display/Tooltip/TooltipComponent.js +21 -0
- package/lib/display/Tooltip/TooltipComponent.js.map +1 -0
- package/lib/display/Tooltip/useTooltipFloating.d.ts +808 -0
- package/lib/display/Tooltip/useTooltipFloating.js +74 -0
- package/lib/display/Tooltip/useTooltipFloating.js.map +1 -0
- package/lib/display/Tooltip/useTooltipTrigger.d.ts +24 -0
- package/lib/display/Tooltip/useTooltipTrigger.js +52 -0
- package/lib/display/Tooltip/useTooltipTrigger.js.map +1 -0
- package/lib/utils/parseFormatter.d.ts +1 -1
- package/lib/utils/parseFormatter.js +1 -1
- package/lib/utils/parseFormatter.js.map +1 -1
- package/lib/utils/useClickOutside.d.ts +11 -0
- package/lib/utils/useClickOutside.js +23 -0
- package/lib/utils/useClickOutside.js.map +1 -0
- package/package.json +2 -1
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { useCallback, useEffect, useRef, useState } from 'react';
|
|
2
|
+
import { autoUpdate, flip, offset, shift, useFloating } from '@floating-ui/react';
|
|
3
|
+
import { useClickOutside } from '../../utils/useClickOutside';
|
|
4
|
+
export var Container;
|
|
5
|
+
(function (Container) {
|
|
6
|
+
Container["BODY"] = "body";
|
|
7
|
+
Container["TARGET"] = "target";
|
|
8
|
+
})(Container || (Container = {}));
|
|
9
|
+
/**
|
|
10
|
+
* Хук для управления состоянием тултипа
|
|
11
|
+
*/
|
|
12
|
+
export function useTooltipFloating({ delay, placement, container, closeOnClickOutside }) {
|
|
13
|
+
const [open, onOpenChange] = useState(false);
|
|
14
|
+
const timeoutRef = useRef();
|
|
15
|
+
const isMountedRef = useRef(false);
|
|
16
|
+
useEffect(() => {
|
|
17
|
+
isMountedRef.current = true;
|
|
18
|
+
return () => {
|
|
19
|
+
isMountedRef.current = false;
|
|
20
|
+
clearTimeout(timeoutRef.current);
|
|
21
|
+
};
|
|
22
|
+
}, []);
|
|
23
|
+
const handleOpen = useCallback(() => {
|
|
24
|
+
if (!isMountedRef.current) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
clearTimeout(timeoutRef.current);
|
|
28
|
+
timeoutRef.current = window.setTimeout(() => onOpenChange(true), delay);
|
|
29
|
+
}, [delay]);
|
|
30
|
+
const handleClose = useCallback(() => {
|
|
31
|
+
if (!isMountedRef.current) {
|
|
32
|
+
return;
|
|
33
|
+
}
|
|
34
|
+
clearTimeout(timeoutRef.current);
|
|
35
|
+
onOpenChange(false);
|
|
36
|
+
}, []);
|
|
37
|
+
const toggle = useCallback(() => {
|
|
38
|
+
if (!isMountedRef.current) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
clearTimeout(timeoutRef.current);
|
|
42
|
+
onOpenChange(prev => !prev);
|
|
43
|
+
}, []);
|
|
44
|
+
/** Хук возвращающий позиционирование */
|
|
45
|
+
const { refs, floatingStyles } = useFloating({
|
|
46
|
+
open,
|
|
47
|
+
onOpenChange,
|
|
48
|
+
placement,
|
|
49
|
+
strategy: container === Container.TARGET ? 'absolute' : 'fixed',
|
|
50
|
+
middleware: [offset(6), flip(), shift()],
|
|
51
|
+
whileElementsMounted: autoUpdate,
|
|
52
|
+
});
|
|
53
|
+
useClickOutside({
|
|
54
|
+
isActive: open && closeOnClickOutside,
|
|
55
|
+
onClickOutside: handleClose,
|
|
56
|
+
excludeRefs: [
|
|
57
|
+
refs.reference,
|
|
58
|
+
refs.floating,
|
|
59
|
+
],
|
|
60
|
+
});
|
|
61
|
+
const style = Object.assign({ zIndex: 9999 }, (container === Container.TARGET ? { width: 'max-content' } : {}));
|
|
62
|
+
return {
|
|
63
|
+
open,
|
|
64
|
+
onOpenChange,
|
|
65
|
+
handleOpen,
|
|
66
|
+
handleClose,
|
|
67
|
+
toggle,
|
|
68
|
+
refs,
|
|
69
|
+
floatingRef: refs.setFloating,
|
|
70
|
+
floatingStyles: Object.assign(Object.assign({}, floatingStyles), style),
|
|
71
|
+
portal: container === Container.BODY,
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=useTooltipFloating.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTooltipFloating.js","sourceRoot":"","sources":["../../../src/display/Tooltip/useTooltipFloating.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { ReactElement, Ref, MutableRefObject } from 'react';
|
|
2
|
+
import { ReferenceType } from '@floating-ui/react';
|
|
3
|
+
export declare enum Trigger {
|
|
4
|
+
HOVER = "hover",
|
|
5
|
+
CLICK = "click"
|
|
6
|
+
}
|
|
7
|
+
export interface TooltipTrigger {
|
|
8
|
+
children: ReactElement & {
|
|
9
|
+
ref?: Ref<unknown>;
|
|
10
|
+
};
|
|
11
|
+
refs: {
|
|
12
|
+
setReference(node: ReferenceType | null): void;
|
|
13
|
+
reference: MutableRefObject<ReferenceType | null>;
|
|
14
|
+
};
|
|
15
|
+
trigger: Trigger;
|
|
16
|
+
handleOpen(): void;
|
|
17
|
+
handleClose(): void;
|
|
18
|
+
toggle(): void;
|
|
19
|
+
}
|
|
20
|
+
/** Хук для работы с системой позиционирования
|
|
21
|
+
* Устанавливает слушателей эвентов
|
|
22
|
+
* Объединяет существующие ref с ссылками, необходимыми для позиционирования
|
|
23
|
+
*/
|
|
24
|
+
export declare function useTooltipTrigger({ children, refs, trigger, handleOpen, handleClose, toggle, }: TooltipTrigger): ReactElement<any, string | import("react").JSXElementConstructor<any>> | null;
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { cloneElement, useEffect, } from 'react';
|
|
2
|
+
export var Trigger;
|
|
3
|
+
(function (Trigger) {
|
|
4
|
+
Trigger["HOVER"] = "hover";
|
|
5
|
+
Trigger["CLICK"] = "click";
|
|
6
|
+
})(Trigger || (Trigger = {}));
|
|
7
|
+
/** Хук для работы с системой позиционирования
|
|
8
|
+
* Устанавливает слушателей эвентов
|
|
9
|
+
* Объединяет существующие ref с ссылками, необходимыми для позиционирования
|
|
10
|
+
*/
|
|
11
|
+
export function useTooltipTrigger({ children, refs, trigger, handleOpen, handleClose, toggle, }) {
|
|
12
|
+
useEffect(() => {
|
|
13
|
+
const element = refs.reference.current;
|
|
14
|
+
if (!element) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const eventHandlers = [];
|
|
18
|
+
if (trigger === Trigger.HOVER) {
|
|
19
|
+
eventHandlers.push(['mouseenter', handleOpen], ['mouseleave', handleClose], ['focus', handleOpen], ['blur', handleClose]);
|
|
20
|
+
}
|
|
21
|
+
if (trigger === Trigger.CLICK) {
|
|
22
|
+
eventHandlers.push(['click', toggle]);
|
|
23
|
+
}
|
|
24
|
+
eventHandlers.forEach(([event, handler]) => {
|
|
25
|
+
element.addEventListener(event, handler);
|
|
26
|
+
});
|
|
27
|
+
// eslint-disable-next-line consistent-return
|
|
28
|
+
return () => {
|
|
29
|
+
eventHandlers.forEach(([event, handler]) => {
|
|
30
|
+
element.removeEventListener(event, handler);
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
}, [trigger, handleOpen, handleClose, toggle, refs.reference]);
|
|
34
|
+
if (!children) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return cloneElement(children, {
|
|
38
|
+
ref: (node) => {
|
|
39
|
+
refs.setReference(node);
|
|
40
|
+
if (node) {
|
|
41
|
+
// Проброс оригинального ref
|
|
42
|
+
if (typeof children.ref === 'function') {
|
|
43
|
+
children.ref(node);
|
|
44
|
+
}
|
|
45
|
+
else if (children.ref) {
|
|
46
|
+
children.ref.current = node;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=useTooltipTrigger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useTooltipTrigger.js","sourceRoot":"","sources":["../../../src/display/Tooltip/useTooltipTrigger.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,YAAY,EACZ,SAAS,GAIZ,MAAM,OAAO,CAAA;AAGd,MAAM,CAAN,IAAY,OAGX;AAHD,WAAY,OAAO;IACf,0BAAe,CAAA;IACf,0BAAe,CAAA;AACnB,CAAC,EAHW,OAAO,KAAP,OAAO,QAGlB;AAcD;;;GAGG;AACH,MAAM,UAAU,iBAAiB,CAAC,EACI,QAAQ,EACR,IAAI,EACJ,OAAO,EACP,UAAU,EACV,WAAW,EACX,MAAM,GACO;IAC/C,SAAS,CAAC,GAAG,EAAE;QACX,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,OAA6B,CAAA;QAE5D,IAAI,CAAC,OAAO,EAAE;YAAE,OAAM;SAAE;QAExB,MAAM,aAAa,GAAgC,EAAE,CAAA;QAErD,IAAI,OAAO,KAAK,OAAO,CAAC,KAAK,EAAE;YAC3B,aAAa,CAAC,IAAI,CACd,CAAC,YAAY,EAAE,UAAU,CAAC,EAC1B,CAAC,YAAY,EAAE,WAAW,CAAC,EAC3B,CAAC,OAAO,EAAE,UAAU,CAAC,EACrB,CAAC,MAAM,EAAE,WAAW,CAAC,CACxB,CAAA;SACJ;QAED,IAAI,OAAO,KAAK,OAAO,CAAC,KAAK,EAAE;YAC3B,aAAa,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAA;SACxC;QAED,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE;YACvC,OAAO,CAAC,gBAAgB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAA;QAC5C,CAAC,CAAC,CAAA;QAEF,6CAA6C;QAC7C,OAAO,GAAG,EAAE;YACR,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,EAAE,EAAE;gBACvC,OAAO,CAAC,mBAAmB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAA;YAC/C,CAAC,CAAC,CAAA;QACN,CAAC,CAAA;IACL,CAAC,EAAE,CAAC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;IAE9D,IAAI,CAAC,QAAQ,EAAE;QAAE,OAAO,IAAI,CAAA;KAAE;IAE9B,OAAO,YAAY,CAAC,QAAQ,EAAE;QAC1B,GAAG,EAAE,CAAC,IAAwB,EAAE,EAAE;YAC9B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;YACvB,IAAI,IAAI,EAAE;gBACN,4BAA4B;gBAC5B,IAAI,OAAO,QAAQ,CAAC,GAAG,KAAK,UAAU,EAAE;oBACpC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;iBACrB;qBAAM,IAAI,QAAQ,CAAC,GAAG,EAAE;oBACpB,QAAQ,CAAC,GAA4C,CAAC,OAAO,GAAG,IAAI,CAAA;iBACxE;aACJ;QACL,CAAC;KACJ,CAAC,CAAA;AACN,CAAC"}
|
|
@@ -45,7 +45,7 @@ function snils(value, formatString = '000-000-000 00') {
|
|
|
45
45
|
* @param typeAndformat - строка с типом данных и форматом
|
|
46
46
|
* @returns {*}
|
|
47
47
|
*/
|
|
48
|
-
export function parseFormatter(data, typeAndformat =
|
|
48
|
+
export function parseFormatter(data, typeAndformat = '') {
|
|
49
49
|
if (numeral.formats.phone === undefined) {
|
|
50
50
|
numeral.register('format', 'phone', {
|
|
51
51
|
regexps: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parseFormatter.js","sourceRoot":"","sources":["../../src/utils/parseFormatter.js"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,eAAe,CAAA;AAClC,OAAO,OAAO,MAAM,SAAS,CAAA;AAC7B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,IAAI,MAAM,aAAa,CAAA;AAC9B,OAAO,IAAI,MAAM,aAAa,CAAA;AAC9B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,GAAG,MAAM,YAAY,CAAA;AAC5B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,QAAQ,MAAM,iBAAiB,CAAA;AACtC,OAAO,QAAQ,MAAM,iBAAiB,CAAA;AAEtC,MAAM,cAAc,GAAG;IACnB,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;IACvD,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;IACtD,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE;QACzB,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAEnD,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACzC,CAAC;IACD,WAAW,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IACpD,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;IACnE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;CACnC,CAAA;AAED,SAAS,KAAK,CAAC,KAAK,EAAE,YAAY,GAAG,gBAAgB;IACjD,MAAM,GAAG,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,KAAI,EAAE,CAAA;IAE7C,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,EAAE;QAAE,OAAO,GAAG,CAAA;KAAE;IAErC,IAAI,QAAQ,GAAG,EAAE,CAAA;IAEjB,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE;QAC7B,QAAQ,IAAI,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;KAChD;IAED,OAAO,QAAQ,CAAA;AACnB,CAAC;AAED;;;;;;;;;;;;;;GAcG;AACH,MAAM,UAAU,cAAc,CAAC,IAAI,EAAE,aAAa,GAAG,
|
|
1
|
+
{"version":3,"file":"parseFormatter.js","sourceRoot":"","sources":["../../src/utils/parseFormatter.js"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,eAAe,CAAA;AAClC,OAAO,OAAO,MAAM,SAAS,CAAA;AAC7B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,IAAI,MAAM,aAAa,CAAA;AAC9B,OAAO,IAAI,MAAM,aAAa,CAAA;AAC9B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,GAAG,MAAM,YAAY,CAAA;AAC5B,OAAO,KAAK,MAAM,cAAc,CAAA;AAChC,OAAO,QAAQ,MAAM,iBAAiB,CAAA;AACtC,OAAO,QAAQ,MAAM,iBAAiB,CAAA;AAEtC,MAAM,cAAc,GAAG;IACnB,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;IACvD,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;IACtD,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE;QACzB,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAEnD,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IACzC,CAAC;IACD,WAAW,EAAE,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IACpD,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;IACnE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;CACnC,CAAA;AAED,SAAS,KAAK,CAAC,KAAK,EAAE,YAAY,GAAG,gBAAgB;IACjD,MAAM,GAAG,GAAG,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,GAAG,KAAK,CAAC,EAAE,CAAC,KAAI,EAAE,CAAA;IAE7C,IAAI,GAAG,CAAC,MAAM,KAAK,EAAE,EAAE;QAAE,OAAO,GAAG,CAAA;KAAE;IAErC,IAAI,QAAQ,GAAG,EAAE,CAAA;IAEjB,KAAK,MAAM,IAAI,IAAI,YAAY,EAAE;QAC7B,QAAQ,IAAI,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;KAChD;IAED,OAAO,QAAQ,CAAA;AACnB,CAAC;AAED;;;;;;;;;;;;;;GAcG;AACH,MAAM,UAAU,cAAc,CAAC,IAAI,EAAE,aAAa,GAAG,EAAE;IACnD,IAAI,OAAO,CAAC,OAAO,CAAC,KAAK,KAAK,SAAS,EAAE;QACrC,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,EAAE;YAChC,OAAO,EAAE;gBACL,MAAM,EAAE,+CAA+C;aAC1D;YACD,MAAM,CAAC,KAAK,EAAE,YAAY;gBACtB,IAAI,CAAC,KAAK,IAAI,CAAC,YAAY,EAAE;oBACzB,OAAO,EAAE,CAAA;iBACZ;gBAED,SAAS,SAAS,CAAC,WAAW;oBAC1B,OAAO,WAAW,CAAC,QAAQ,EAAE,CAAC,OAAO,CACjC,iEAAiE,EACjE,UAAU,CACb,CAAA;gBACL,CAAC;gBAED,SAAS,MAAM,CAAC,WAAW,EAAE,YAAY;oBACrC,WAAW,GAAG,SAAS,CAAC,WAAW,CAAC,CAAA;oBACpC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;wBAChD,YAAY,GAAG,YAAY,CAAC,OAAO,CAAC,GAAG,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAA;qBAC3D;oBAED,OAAO,YAAY,CAAA;gBACvB,CAAC;gBAED,OAAO,MAAM,CAAC,KAAK,EAAE,YAAY,CAAC,CAAA;YACtC,CAAC;SACJ,CAAC,CAAA;KACL;IAED,IAAI,OAAO,CAAC,OAAO,CAAC,KAAK,KAAK,SAAS,EAAE;QACrC,OAAO,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,EAAE;YAChC,OAAO,EAAE;gBACL,MAAM,EAAE,qBAAqB;aAChC;YACD,MAAM,EAAE,KAAK;SAChB,CAAC,CAAA;KACL;IAED,MAAM,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAA;IAC1B,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,GAAG,CAAC,CAAA;IAErD,MAAM,IAAI,GAAG,aAAa,CAAC,CAAC,CAAC,CAAA;IAE7B,IACI,KAAK,CAAC,IAAI,CAAC;QACX,CAAC,aAAa;QACd,CAAC,GAAG,KAAK,EAAE,IAAI,aAAa,CAAC,CAAC,CAAC,KAAK,aAAa,CAAC,EACpD;QAAE,OAAO,IAAI,CAAA;KAAE;IAEjB,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE;QAAE,OAAO,IAAI,CAAA;KAAE;IAE1C,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;IAEjD,OAAO,cAAc,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC,CAAA;AACtD,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { RefObject } from 'react';
|
|
2
|
+
declare type RefType = RefObject<HTMLElement | null> | {
|
|
3
|
+
current: HTMLElement | null;
|
|
4
|
+
};
|
|
5
|
+
interface UseClickOutsideProps {
|
|
6
|
+
isActive: boolean;
|
|
7
|
+
onClickOutside(): void;
|
|
8
|
+
excludeRefs: RefType[];
|
|
9
|
+
}
|
|
10
|
+
export declare function useClickOutside({ isActive, onClickOutside, excludeRefs, }: UseClickOutsideProps): void;
|
|
11
|
+
export {};
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { useEffect } from 'react';
|
|
2
|
+
export function useClickOutside({ isActive, onClickOutside, excludeRefs, }) {
|
|
3
|
+
useEffect(() => {
|
|
4
|
+
if (!isActive) {
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
const handleClickOutside = (e) => {
|
|
8
|
+
const target = e.target;
|
|
9
|
+
const isInside = excludeRefs.some((ref) => {
|
|
10
|
+
const element = ref.current;
|
|
11
|
+
return element instanceof HTMLElement && element.contains(target);
|
|
12
|
+
});
|
|
13
|
+
if (isInside) {
|
|
14
|
+
return;
|
|
15
|
+
}
|
|
16
|
+
onClickOutside();
|
|
17
|
+
};
|
|
18
|
+
document.addEventListener('pointerdown', handleClickOutside);
|
|
19
|
+
// eslint-disable-next-line consistent-return
|
|
20
|
+
return () => document.removeEventListener('pointerdown', handleClickOutside);
|
|
21
|
+
}, [isActive, onClickOutside, excludeRefs]);
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=useClickOutside.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useClickOutside.js","sourceRoot":"","sources":["../../src/utils/useClickOutside.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAa,SAAS,EAAE,MAAM,OAAO,CAAA;AAU5C,MAAM,UAAU,eAAe,CAAC,EAC5B,QAAQ,EACR,cAAc,EACd,WAAW,GACQ;IACnB,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,CAAC,QAAQ,EAAE;YAAE,OAAM;SAAE;QAEzB,MAAM,kBAAkB,GAAG,CAAC,CAAa,EAAE,EAAE;YACzC,MAAM,MAAM,GAAG,CAAC,CAAC,MAAc,CAAA;YAE/B,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE;gBACtC,MAAM,OAAO,GAAG,GAAG,CAAC,OAAO,CAAA;gBAE3B,OAAO,OAAO,YAAY,WAAW,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;YACrE,CAAC,CAAC,CAAA;YAEF,IAAI,QAAQ,EAAE;gBAAE,OAAM;aAAE;YAExB,cAAc,EAAE,CAAA;QACpB,CAAC,CAAA;QAED,QAAQ,CAAC,gBAAgB,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAA;QAE5D,6CAA6C;QAC7C,OAAO,GAAG,EAAE,CAAC,QAAQ,CAAC,mBAAmB,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAA;IAChF,CAAC,EAAE,CAAC,QAAQ,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC,CAAA;AAC/C,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@i-novus/n2o-components",
|
|
3
|
-
"version": "7.27.
|
|
3
|
+
"version": "7.27.39",
|
|
4
4
|
"description": "UI components for N2O framework",
|
|
5
5
|
"author": "I-Novus LLC<n2o@i-novus.ru>",
|
|
6
6
|
"license": "Apache-2.0",
|
|
@@ -38,6 +38,7 @@
|
|
|
38
38
|
"lint": "yarn eslint && yarn stylelint"
|
|
39
39
|
},
|
|
40
40
|
"dependencies": {
|
|
41
|
+
"@floating-ui/react": "^0.27.13",
|
|
41
42
|
"@fontsource/exo-2": "^4.3.0",
|
|
42
43
|
"@fortawesome/fontawesome-free": "^6.4.2",
|
|
43
44
|
"@fortawesome/fontawesome-svg-core": "^6.4.2",
|