@simplybusiness/mobius 10.4.2 → 10.4.3

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.
Files changed (73) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/dist/cjs/components/Popover/Arrow.js +43 -0
  3. package/dist/cjs/components/Popover/Arrow.js.map +7 -0
  4. package/dist/cjs/components/Popover/Popover.js +258 -83
  5. package/dist/cjs/components/Popover/Popover.js.map +4 -4
  6. package/dist/cjs/components/Popover/index.js +258 -83
  7. package/dist/cjs/components/Popover/index.js.map +4 -4
  8. package/dist/cjs/components/Popover/useAutoUpdate.js +53 -0
  9. package/dist/cjs/components/Popover/useAutoUpdate.js.map +7 -0
  10. package/dist/cjs/components/Popover/useFloatingPosition.js +128 -0
  11. package/dist/cjs/components/Popover/useFloatingPosition.js.map +7 -0
  12. package/dist/cjs/components/Popover/useOutsidePress.js +46 -0
  13. package/dist/cjs/components/Popover/useOutsidePress.js.map +7 -0
  14. package/dist/cjs/components/index.js +422 -245
  15. package/dist/cjs/components/index.js.map +4 -4
  16. package/dist/cjs/index.js +422 -245
  17. package/dist/cjs/index.js.map +4 -4
  18. package/dist/cjs/meta.json +316 -32
  19. package/dist/esm/chunk-26KZYRE6.js +108 -0
  20. package/dist/esm/chunk-26KZYRE6.js.map +7 -0
  21. package/dist/esm/chunk-CAL44W47.js +23 -0
  22. package/dist/esm/chunk-CAL44W47.js.map +7 -0
  23. package/dist/esm/{chunk-PEEQNAIN.js → chunk-DMYDWKKA.js} +4 -4
  24. package/dist/esm/chunk-K3ECDAUR.js +33 -0
  25. package/dist/esm/chunk-K3ECDAUR.js.map +7 -0
  26. package/dist/esm/{chunk-GJBH37DH.js → chunk-KFHPI67N.js} +4 -4
  27. package/dist/esm/{chunk-F5ELD54X.js → chunk-LGZWQZLS.js} +2 -2
  28. package/dist/esm/{chunk-OAG5T7NC.js → chunk-NEFRXIFY.js} +4 -4
  29. package/dist/esm/chunk-VZ3IWSK6.js +158 -0
  30. package/dist/esm/chunk-VZ3IWSK6.js.map +7 -0
  31. package/dist/esm/chunk-WYJP7HVL.js +26 -0
  32. package/dist/esm/chunk-WYJP7HVL.js.map +7 -0
  33. package/dist/esm/components/AddressLookup/AddressLookup.js +4 -4
  34. package/dist/esm/components/AddressLookup/index.js +6 -6
  35. package/dist/esm/components/Breadcrumbs/index.js +3 -3
  36. package/dist/esm/components/Checkbox/index.js +1 -1
  37. package/dist/esm/components/Combobox/Combobox.js +3 -3
  38. package/dist/esm/components/Combobox/index.js +3 -3
  39. package/dist/esm/components/Drawer/index.js +3 -3
  40. package/dist/esm/components/Modal/index.js +3 -3
  41. package/dist/esm/components/Popover/Arrow.js +8 -0
  42. package/dist/esm/components/Popover/Arrow.js.map +7 -0
  43. package/dist/esm/components/Popover/Popover.js +5 -1
  44. package/dist/esm/components/Popover/index.js +5 -1
  45. package/dist/esm/components/Popover/useAutoUpdate.js +8 -0
  46. package/dist/esm/components/Popover/useAutoUpdate.js.map +7 -0
  47. package/dist/esm/components/Popover/useFloatingPosition.js +8 -0
  48. package/dist/esm/components/Popover/useFloatingPosition.js.map +7 -0
  49. package/dist/esm/components/Popover/useOutsidePress.js +8 -0
  50. package/dist/esm/components/Popover/useOutsidePress.js.map +7 -0
  51. package/dist/esm/components/index.js +77 -73
  52. package/dist/esm/index.js +77 -73
  53. package/dist/esm/meta.json +3737 -3401
  54. package/dist/tsconfig.build.tsbuildinfo +1 -1
  55. package/dist/types/components/Popover/Arrow.d.ts +9 -0
  56. package/dist/types/components/Popover/useAutoUpdate.d.ts +9 -0
  57. package/dist/types/components/Popover/useFloatingPosition.d.ts +17 -0
  58. package/dist/types/components/Popover/useOutsidePress.d.ts +9 -0
  59. package/package.json +1 -2
  60. package/src/components/Popover/Arrow.tsx +25 -0
  61. package/src/components/Popover/Popover.characterization.test.tsx +269 -0
  62. package/src/components/Popover/Popover.stories.tsx +40 -3
  63. package/src/components/Popover/Popover.test.tsx +6 -2
  64. package/src/components/Popover/Popover.tsx +87 -81
  65. package/src/components/Popover/useAutoUpdate.ts +43 -0
  66. package/src/components/Popover/useFloatingPosition.ts +177 -0
  67. package/src/components/Popover/useOutsidePress.ts +31 -0
  68. package/dist/esm/chunk-O5YEU5TG.js +0 -155
  69. package/dist/esm/chunk-O5YEU5TG.js.map +0 -7
  70. /package/dist/esm/{chunk-PEEQNAIN.js.map → chunk-DMYDWKKA.js.map} +0 -0
  71. /package/dist/esm/{chunk-GJBH37DH.js.map → chunk-KFHPI67N.js.map} +0 -0
  72. /package/dist/esm/{chunk-F5ELD54X.js.map → chunk-LGZWQZLS.js.map} +0 -0
  73. /package/dist/esm/{chunk-OAG5T7NC.js.map → chunk-NEFRXIFY.js.map} +0 -0
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/components/Popover/useFloatingPosition.ts
21
+ var useFloatingPosition_exports = {};
22
+ __export(useFloatingPosition_exports, {
23
+ useFloatingPosition: () => useFloatingPosition
24
+ });
25
+ module.exports = __toCommonJS(useFloatingPosition_exports);
26
+ var import_react = require("react");
27
+ var ABSOLUTE_FLOATING_STYLES = {
28
+ position: "absolute",
29
+ top: 0,
30
+ left: 0,
31
+ width: "max-content"
32
+ };
33
+ var FIXED_FLOATING_STYLES = {
34
+ position: "fixed",
35
+ top: 0,
36
+ left: 0,
37
+ width: "max-content"
38
+ };
39
+ var INITIAL_ARROW_STYLES = {
40
+ position: "absolute"
41
+ };
42
+ var VIEWPORT_PADDING = 0;
43
+ var createsFixedContainingBlock = (el) => {
44
+ const style = window.getComputedStyle(el);
45
+ return style.transform !== "none" || style.filter !== "none" || style.backdropFilter !== "none" || style.perspective !== "none" || /\b(transform|filter|perspective)\b/.test(style.willChange);
46
+ };
47
+ var useFloatingPosition = ({
48
+ referenceRef,
49
+ floatingRef,
50
+ arrowRef,
51
+ isOpen,
52
+ offsetPx,
53
+ arrowWidth,
54
+ useFixedStrategy
55
+ }) => {
56
+ const update = (0, import_react.useCallback)(() => {
57
+ const reference = referenceRef.current;
58
+ const floating = floatingRef.current;
59
+ if (!reference || !floating) return;
60
+ const refRect = reference.getBoundingClientRect();
61
+ const floatingWidth = floating.offsetWidth;
62
+ const floatingHeight = floating.offsetHeight;
63
+ const scrollX = useFixedStrategy ? 0 : window.scrollX;
64
+ const scrollY = useFixedStrategy ? 0 : window.scrollY;
65
+ const parent = floating.parentElement;
66
+ const parentIsCb = useFixedStrategy && !!parent && createsFixedContainingBlock(parent);
67
+ const boundsRect = parentIsCb ? parent.getBoundingClientRect() : {
68
+ left: 0,
69
+ top: 0,
70
+ right: window.innerWidth,
71
+ bottom: window.innerHeight
72
+ };
73
+ const bottomTopViewport = refRect.bottom + offsetPx;
74
+ const topTopViewport = refRect.top - floatingHeight - offsetPx;
75
+ const overflowsBottom = bottomTopViewport + floatingHeight > boundsRect.bottom;
76
+ const fitsTop = topTopViewport >= boundsRect.top;
77
+ const nextPlacement = overflowsBottom && fitsTop ? "top" : "bottom";
78
+ const topViewport = nextPlacement === "bottom" ? bottomTopViewport : topTopViewport;
79
+ const rawLeftViewport = refRect.left + refRect.width / 2 - floatingWidth / 2;
80
+ const minLeftViewport = boundsRect.left + VIEWPORT_PADDING;
81
+ const maxLeftViewport = Math.max(
82
+ minLeftViewport,
83
+ boundsRect.right - floatingWidth - VIEWPORT_PADDING
84
+ );
85
+ const leftViewport = Math.min(
86
+ Math.max(minLeftViewport, rawLeftViewport),
87
+ maxLeftViewport
88
+ );
89
+ const cbOffsetLeft = parentIsCb ? boundsRect.left : 0;
90
+ const cbOffsetTop = parentIsCb ? boundsRect.top : 0;
91
+ floating.style.top = `${topViewport + scrollY - cbOffsetTop}px`;
92
+ floating.style.left = `${leftViewport + scrollX - cbOffsetLeft}px`;
93
+ const arrow = arrowRef.current;
94
+ if (!arrow) return;
95
+ const arrowHalf = arrowWidth / 2;
96
+ const refCenterX = refRect.left + refRect.width / 2;
97
+ const rawArrowLeft = refCenterX - leftViewport - arrowHalf;
98
+ const maxArrowLeft = Math.max(0, floatingWidth - arrowWidth);
99
+ const arrowLeft = Math.min(Math.max(0, rawArrowLeft), maxArrowLeft);
100
+ arrow.style.left = `${arrowLeft}px`;
101
+ if (nextPlacement === "bottom") {
102
+ arrow.style.bottom = "100%";
103
+ arrow.style.top = "";
104
+ arrow.style.transform = "rotate(180deg)";
105
+ } else {
106
+ arrow.style.top = "100%";
107
+ arrow.style.bottom = "";
108
+ arrow.style.transform = "";
109
+ }
110
+ }, [
111
+ referenceRef,
112
+ floatingRef,
113
+ arrowRef,
114
+ offsetPx,
115
+ arrowWidth,
116
+ useFixedStrategy
117
+ ]);
118
+ (0, import_react.useLayoutEffect)(() => {
119
+ if (!isOpen) return;
120
+ update();
121
+ }, [isOpen, update]);
122
+ return {
123
+ initialFloatingStyles: useFixedStrategy ? FIXED_FLOATING_STYLES : ABSOLUTE_FLOATING_STYLES,
124
+ initialArrowStyles: INITIAL_ARROW_STYLES,
125
+ update
126
+ };
127
+ };
128
+ //# sourceMappingURL=useFloatingPosition.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Popover/useFloatingPosition.ts"],
4
+ "sourcesContent": ["import type { CSSProperties, RefObject } from \"react\";\nimport { useCallback, useLayoutEffect } from \"react\";\n\ntype Placement = \"bottom\" | \"top\";\n\ninterface UseFloatingPositionArgs {\n referenceRef: RefObject<HTMLElement | null>;\n floatingRef: RefObject<HTMLDivElement | null>;\n arrowRef: RefObject<SVGSVGElement | null>;\n isOpen: boolean;\n offsetPx: number;\n arrowWidth: number;\n useFixedStrategy: boolean;\n}\n\ninterface UseFloatingPositionResult {\n initialFloatingStyles: CSSProperties;\n initialArrowStyles: CSSProperties;\n update: () => void;\n}\n\n// Two positioning strategies:\n// - `absolute` + document-relative coords (viewport rect + window.scrollY/X)\n// when portalled to document.body. The initial containing block is the\n// document, so absolute coords pin to the trigger and scroll natively.\n// - `fixed` + viewport coords when portalled inside a <dialog> (top-layer).\n// The dialog's own box would otherwise become the containing block for an\n// `absolute` child, throwing off coordinates and triggering `overflow: hidden`\n// clipping. `fixed` keeps the containing block as the viewport.\nconst ABSOLUTE_FLOATING_STYLES: CSSProperties = {\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"max-content\",\n};\n\nconst FIXED_FLOATING_STYLES: CSSProperties = {\n position: \"fixed\",\n top: 0,\n left: 0,\n width: \"max-content\",\n};\n\nconst INITIAL_ARROW_STYLES: CSSProperties = {\n position: \"absolute\",\n};\n\nconst VIEWPORT_PADDING = 0;\n\n// Properties that make an ancestor the containing block for a `position: fixed`\n// descendant, overriding the initial viewport containing block. When the portal\n// target (dialog) has any of these, `position: fixed` coords are interpreted\n// relative to the dialog's box, not the viewport \u2014 we compensate by subtracting\n// the dialog's viewport offset.\nconst createsFixedContainingBlock = (el: HTMLElement): boolean => {\n const style = window.getComputedStyle(el);\n return (\n style.transform !== \"none\" ||\n style.filter !== \"none\" ||\n style.backdropFilter !== \"none\" ||\n style.perspective !== \"none\" ||\n /\\b(transform|filter|perspective)\\b/.test(style.willChange)\n );\n};\n\nexport const useFloatingPosition = ({\n referenceRef,\n floatingRef,\n arrowRef,\n isOpen,\n offsetPx,\n arrowWidth,\n useFixedStrategy,\n}: UseFloatingPositionArgs): UseFloatingPositionResult => {\n // Writes styles directly to the DOM (bypassing React state) so scroll/resize\n // handlers can update position in the same event-frame the browser uses to\n // paint the scroll, eliminating the re-render lag that shows up as a\n // trigger-vs-popover parallax on fast scroll.\n const update = useCallback(() => {\n const reference = referenceRef.current;\n const floating = floatingRef.current;\n if (!reference || !floating) return;\n\n const refRect = reference.getBoundingClientRect();\n const floatingWidth = floating.offsetWidth;\n const floatingHeight = floating.offsetHeight;\n const scrollX = useFixedStrategy ? 0 : window.scrollX;\n const scrollY = useFixedStrategy ? 0 : window.scrollY;\n\n // Clamp to the portal target's bounds when the dialog is a containing\n // block (its own `overflow: hidden` would clip the popover). Otherwise\n // clamp to the viewport.\n const parent = floating.parentElement;\n const parentIsCb =\n useFixedStrategy && !!parent && createsFixedContainingBlock(parent);\n const boundsRect = parentIsCb\n ? parent.getBoundingClientRect()\n : {\n left: 0,\n top: 0,\n right: window.innerWidth,\n bottom: window.innerHeight,\n };\n\n const bottomTopViewport = refRect.bottom + offsetPx;\n const topTopViewport = refRect.top - floatingHeight - offsetPx;\n const overflowsBottom =\n bottomTopViewport + floatingHeight > boundsRect.bottom;\n const fitsTop = topTopViewport >= boundsRect.top;\n const nextPlacement: Placement =\n overflowsBottom && fitsTop ? \"top\" : \"bottom\";\n\n const topViewport =\n nextPlacement === \"bottom\" ? bottomTopViewport : topTopViewport;\n\n const rawLeftViewport =\n refRect.left + refRect.width / 2 - floatingWidth / 2;\n const minLeftViewport = boundsRect.left + VIEWPORT_PADDING;\n const maxLeftViewport = Math.max(\n minLeftViewport,\n boundsRect.right - floatingWidth - VIEWPORT_PADDING,\n );\n const leftViewport = Math.min(\n Math.max(minLeftViewport, rawLeftViewport),\n maxLeftViewport,\n );\n\n // Subtract containing-block offset when the dialog is the CB, so\n // `position: fixed` coords land at the intended viewport position.\n const cbOffsetLeft = parentIsCb ? boundsRect.left : 0;\n const cbOffsetTop = parentIsCb ? boundsRect.top : 0;\n\n floating.style.top = `${topViewport + scrollY - cbOffsetTop}px`;\n floating.style.left = `${leftViewport + scrollX - cbOffsetLeft}px`;\n\n const arrow = arrowRef.current;\n if (!arrow) return;\n\n // Arrow coords are relative to the floating element, so scroll cancels out.\n const arrowHalf = arrowWidth / 2;\n const refCenterX = refRect.left + refRect.width / 2;\n const rawArrowLeft = refCenterX - leftViewport - arrowHalf;\n const maxArrowLeft = Math.max(0, floatingWidth - arrowWidth);\n const arrowLeft = Math.min(Math.max(0, rawArrowLeft), maxArrowLeft);\n\n arrow.style.left = `${arrowLeft}px`;\n if (nextPlacement === \"bottom\") {\n arrow.style.bottom = \"100%\";\n arrow.style.top = \"\";\n arrow.style.transform = \"rotate(180deg)\";\n } else {\n arrow.style.top = \"100%\";\n arrow.style.bottom = \"\";\n arrow.style.transform = \"\";\n }\n }, [\n referenceRef,\n floatingRef,\n arrowRef,\n offsetPx,\n arrowWidth,\n useFixedStrategy,\n ]);\n\n useLayoutEffect(() => {\n if (!isOpen) return;\n update();\n }, [isOpen, update]);\n\n return {\n initialFloatingStyles: useFixedStrategy\n ? FIXED_FLOATING_STYLES\n : ABSOLUTE_FLOATING_STYLES,\n initialArrowStyles: INITIAL_ARROW_STYLES,\n update,\n };\n};\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/components/Popover/useOutsidePress.ts
21
+ var useOutsidePress_exports = {};
22
+ __export(useOutsidePress_exports, {
23
+ useOutsidePress: () => useOutsidePress
24
+ });
25
+ module.exports = __toCommonJS(useOutsidePress_exports);
26
+ var import_react = require("react");
27
+ var useOutsidePress = ({
28
+ referenceRef,
29
+ floatingRef,
30
+ enabled,
31
+ onOutsidePress
32
+ }) => {
33
+ (0, import_react.useEffect)(() => {
34
+ if (!enabled) return;
35
+ const handler = (event) => {
36
+ const target = event.target;
37
+ if (!target) return;
38
+ if (referenceRef.current?.contains(target)) return;
39
+ if (floatingRef.current?.contains(target)) return;
40
+ onOutsidePress(event);
41
+ };
42
+ document.addEventListener("pointerdown", handler);
43
+ return () => document.removeEventListener("pointerdown", handler);
44
+ }, [enabled, onOutsidePress, referenceRef, floatingRef]);
45
+ };
46
+ //# sourceMappingURL=useOutsidePress.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Popover/useOutsidePress.ts"],
4
+ "sourcesContent": ["import type { RefObject } from \"react\";\nimport { useEffect } from \"react\";\n\ninterface UseOutsidePressArgs {\n referenceRef: RefObject<HTMLElement | null>;\n floatingRef: RefObject<HTMLDivElement | null>;\n enabled: boolean;\n onOutsidePress: (event: PointerEvent) => void;\n}\n\nexport const useOutsidePress = ({\n referenceRef,\n floatingRef,\n enabled,\n onOutsidePress,\n}: UseOutsidePressArgs): void => {\n useEffect(() => {\n if (!enabled) return;\n\n const handler = (event: PointerEvent) => {\n const target = event.target as Node | null;\n if (!target) return;\n if (referenceRef.current?.contains(target)) return;\n if (floatingRef.current?.contains(target)) return;\n onOutsidePress(event);\n };\n\n document.addEventListener(\"pointerdown\", handler);\n return () => document.removeEventListener(\"pointerdown\", handler);\n }, [enabled, onOutsidePress, referenceRef, floatingRef]);\n};\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AACA,mBAA0B;AASnB,IAAM,kBAAkB,CAAC;AAAA,EAC9B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MAAiC;AAC/B,8BAAU,MAAM;AACd,QAAI,CAAC,QAAS;AAEd,UAAM,UAAU,CAAC,UAAwB;AACvC,YAAM,SAAS,MAAM;AACrB,UAAI,CAAC,OAAQ;AACb,UAAI,aAAa,SAAS,SAAS,MAAM,EAAG;AAC5C,UAAI,YAAY,SAAS,SAAS,MAAM,EAAG;AAC3C,qBAAe,KAAK;AAAA,IACtB;AAEA,aAAS,iBAAiB,eAAe,OAAO;AAChD,WAAO,MAAM,SAAS,oBAAoB,eAAe,OAAO;AAAA,EAClE,GAAG,CAAC,SAAS,gBAAgB,cAAc,WAAW,CAAC;AACzD;",
6
+ "names": []
7
+ }