@helpwave/hightide 0.1.27 → 0.1.28

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 (134) hide show
  1. package/dist/coloring/index.d.mts +2 -0
  2. package/dist/coloring/index.d.ts +2 -0
  3. package/dist/coloring/index.js +85 -0
  4. package/dist/coloring/index.js.map +1 -0
  5. package/dist/coloring/index.mjs +48 -0
  6. package/dist/coloring/index.mjs.map +1 -0
  7. package/dist/components/branding/index.d.mts +3 -0
  8. package/dist/components/branding/index.d.ts +3 -0
  9. package/dist/components/branding/index.js +140 -0
  10. package/dist/components/branding/index.js.map +1 -0
  11. package/dist/components/branding/index.mjs +104 -0
  12. package/dist/components/branding/index.mjs.map +1 -0
  13. package/dist/components/date/index.d.mts +10 -0
  14. package/dist/components/date/index.d.ts +10 -0
  15. package/dist/components/date/index.js +1168 -0
  16. package/dist/components/date/index.js.map +1 -0
  17. package/dist/components/date/index.mjs +1124 -0
  18. package/dist/components/date/index.mjs.map +1 -0
  19. package/dist/components/dialog/index.js.map +1 -1
  20. package/dist/components/form/index.d.mts +5 -0
  21. package/dist/components/form/index.d.ts +5 -0
  22. package/dist/components/form/index.js +100 -0
  23. package/dist/components/form/index.js.map +1 -0
  24. package/dist/components/form/index.mjs +64 -0
  25. package/dist/components/form/index.mjs.map +1 -0
  26. package/dist/components/icons-and-geometry/index.d.mts +7 -0
  27. package/dist/components/icons-and-geometry/index.d.ts +7 -0
  28. package/dist/components/icons-and-geometry/index.js +3955 -0
  29. package/dist/components/icons-and-geometry/index.js.map +1 -0
  30. package/dist/components/icons-and-geometry/index.mjs +3939 -0
  31. package/dist/components/icons-and-geometry/index.mjs.map +1 -0
  32. package/dist/components/index.d.mts +83 -0
  33. package/dist/components/index.d.ts +83 -0
  34. package/dist/components/index.js +15471 -0
  35. package/dist/components/index.js.map +1 -0
  36. package/dist/components/index.mjs +15377 -0
  37. package/dist/components/index.mjs.map +1 -0
  38. package/dist/components/layout/index.d.mts +18 -0
  39. package/dist/components/layout/index.d.ts +18 -0
  40. package/dist/components/layout/index.js +3111 -0
  41. package/dist/components/layout/index.js.map +1 -0
  42. package/dist/components/layout/index.mjs +3064 -0
  43. package/dist/components/layout/index.mjs.map +1 -0
  44. package/dist/components/loading-states/index.d.mts +12 -0
  45. package/dist/components/loading-states/index.d.ts +12 -0
  46. package/dist/components/loading-states/index.js +614 -0
  47. package/dist/components/loading-states/index.js.map +1 -0
  48. package/dist/components/loading-states/index.mjs +573 -0
  49. package/dist/components/loading-states/index.mjs.map +1 -0
  50. package/dist/components/navigation/index.d.mts +9 -0
  51. package/dist/components/navigation/index.d.ts +9 -0
  52. package/dist/components/navigation/index.js +4660 -0
  53. package/dist/components/navigation/index.js.map +1 -0
  54. package/dist/components/navigation/index.mjs +4648 -0
  55. package/dist/components/navigation/index.mjs.map +1 -0
  56. package/dist/components/properties/index.d.mts +12 -0
  57. package/dist/components/properties/index.d.ts +12 -0
  58. package/dist/components/properties/index.js +2983 -0
  59. package/dist/components/properties/index.js.map +1 -0
  60. package/dist/components/properties/index.mjs +2951 -0
  61. package/dist/components/properties/index.mjs.map +1 -0
  62. package/dist/components/table/index.d.mts +10 -0
  63. package/dist/components/table/index.d.ts +10 -0
  64. package/dist/components/table/index.js +2329 -0
  65. package/dist/components/table/index.js.map +1 -0
  66. package/dist/components/table/index.mjs +2293 -0
  67. package/dist/components/table/index.mjs.map +1 -0
  68. package/dist/components/user-action/index.d.mts +30 -0
  69. package/dist/components/user-action/index.d.ts +30 -0
  70. package/dist/components/user-action/index.js +4257 -0
  71. package/dist/components/user-action/index.js.map +1 -0
  72. package/dist/components/user-action/index.mjs +4195 -0
  73. package/dist/components/user-action/index.mjs.map +1 -0
  74. package/dist/components/user-action/input/index.d.mts +6 -0
  75. package/dist/components/user-action/input/index.d.ts +6 -0
  76. package/dist/components/user-action/input/index.js +398 -0
  77. package/dist/components/user-action/input/index.js.map +1 -0
  78. package/dist/components/user-action/input/index.mjs +357 -0
  79. package/dist/components/user-action/input/index.mjs.map +1 -0
  80. package/dist/components/user-action/select/index.d.mts +4 -0
  81. package/dist/components/user-action/select/index.d.ts +4 -0
  82. package/dist/components/user-action/select/index.js +1369 -0
  83. package/dist/components/user-action/select/index.js.map +1 -0
  84. package/dist/components/user-action/select/index.mjs +1333 -0
  85. package/dist/components/user-action/select/index.mjs.map +1 -0
  86. package/dist/components/utils/index.d.mts +4 -0
  87. package/dist/components/utils/index.d.ts +4 -0
  88. package/dist/components/utils/index.js +302 -0
  89. package/dist/components/utils/index.js.map +1 -0
  90. package/dist/components/utils/index.mjs +275 -0
  91. package/dist/components/utils/index.mjs.map +1 -0
  92. package/dist/hooks/focus/index.d.mts +6 -0
  93. package/dist/hooks/focus/index.d.ts +6 -0
  94. package/dist/hooks/focus/index.js +379 -0
  95. package/dist/hooks/focus/index.js.map +1 -0
  96. package/dist/hooks/focus/index.mjs +339 -0
  97. package/dist/hooks/focus/index.mjs.map +1 -0
  98. package/dist/hooks/index.d.mts +16 -0
  99. package/dist/hooks/index.d.ts +16 -0
  100. package/dist/hooks/index.js +844 -0
  101. package/dist/hooks/index.js.map +1 -0
  102. package/dist/hooks/index.mjs +794 -0
  103. package/dist/hooks/index.mjs.map +1 -0
  104. package/dist/index.d.mts +110 -0
  105. package/dist/index.d.ts +110 -0
  106. package/dist/index.js +16101 -0
  107. package/dist/index.js.map +1 -0
  108. package/dist/index.mjs +15941 -0
  109. package/dist/index.mjs.map +1 -0
  110. package/dist/localization/defaults/index.d.mts +4 -0
  111. package/dist/localization/defaults/index.d.ts +4 -0
  112. package/dist/localization/defaults/index.js +223 -0
  113. package/dist/localization/defaults/index.js.map +1 -0
  114. package/dist/localization/defaults/index.mjs +195 -0
  115. package/dist/localization/defaults/index.mjs.map +1 -0
  116. package/dist/localization/index.d.mts +7 -0
  117. package/dist/localization/index.d.ts +7 -0
  118. package/dist/localization/index.js +415 -0
  119. package/dist/localization/index.js.map +1 -0
  120. package/dist/localization/index.mjs +380 -0
  121. package/dist/localization/index.mjs.map +1 -0
  122. package/dist/theming/index.d.mts +5 -0
  123. package/dist/theming/index.d.ts +5 -0
  124. package/dist/theming/index.js +174 -0
  125. package/dist/theming/index.js.map +1 -0
  126. package/dist/theming/index.mjs +145 -0
  127. package/dist/theming/index.mjs.map +1 -0
  128. package/dist/utils/index.d.mts +15 -0
  129. package/dist/utils/index.d.ts +15 -0
  130. package/dist/utils/index.js +553 -0
  131. package/dist/utils/index.js.map +1 -0
  132. package/dist/utils/index.mjs +493 -0
  133. package/dist/utils/index.mjs.map +1 -0
  134. package/package.json +25 -24
@@ -0,0 +1,339 @@
1
+ // src/hooks/focus/useFocusGuards.ts
2
+ import { useEffect } from "react";
3
+ var selectorName = "data-hw-focus-guard";
4
+ function FocusGuard() {
5
+ const element = document.createElement("div");
6
+ element.setAttribute(selectorName, "");
7
+ element.tabIndex = 0;
8
+ element.style.border = "none";
9
+ element.style.outline = "none";
10
+ element.style.boxShadow = "none";
11
+ element.style.opacity = "0";
12
+ element.style.position = "fixed";
13
+ element.style.pointerEvents = "none";
14
+ return element;
15
+ }
16
+ var FocusGuardsService = class _FocusGuardsService {
17
+ constructor() {
18
+ this.count = 0;
19
+ }
20
+ static getInstance() {
21
+ if (!_FocusGuardsService.instance) {
22
+ _FocusGuardsService.instance = new _FocusGuardsService();
23
+ }
24
+ return _FocusGuardsService.instance;
25
+ }
26
+ add() {
27
+ const edgeGuards = document.querySelectorAll(`[${selectorName}]`);
28
+ document.body.insertAdjacentElement("afterbegin", edgeGuards[0] ?? FocusGuard());
29
+ document.body.insertAdjacentElement("beforeend", edgeGuards[1] ?? FocusGuard());
30
+ this.count++;
31
+ }
32
+ remove() {
33
+ if (this.count === 1) {
34
+ document.querySelectorAll(`[${selectorName}]`).forEach((node) => node.remove());
35
+ }
36
+ this.count--;
37
+ }
38
+ };
39
+ var useFocusGuards = () => {
40
+ useEffect(() => {
41
+ FocusGuardsService.getInstance().add();
42
+ return () => {
43
+ FocusGuardsService.getInstance().remove();
44
+ };
45
+ }, []);
46
+ };
47
+
48
+ // src/hooks/focus/useFocusManagement.ts
49
+ import { useCallback } from "react";
50
+ function useFocusManagement() {
51
+ const getFocusableElements = useCallback(() => {
52
+ return Array.from(
53
+ document.querySelectorAll(
54
+ 'input, button, select, textarea, a[href], [tabindex]:not([tabindex="-1"])'
55
+ )
56
+ ).filter(
57
+ (el) => el instanceof HTMLElement && !el.hasAttribute("disabled") && !el.hasAttribute("hidden") && el.tabIndex !== -1
58
+ );
59
+ }, []);
60
+ const getNextFocusElement = useCallback(() => {
61
+ const elements = getFocusableElements();
62
+ if (elements.length === 0) {
63
+ return void 0;
64
+ }
65
+ let nextElement = elements[0];
66
+ if (document.activeElement instanceof HTMLElement) {
67
+ const currentIndex = elements.indexOf(document.activeElement);
68
+ nextElement = elements[(currentIndex + 1) % elements.length];
69
+ }
70
+ return nextElement;
71
+ }, [getFocusableElements]);
72
+ const focusNext = useCallback(() => {
73
+ const nextElement = getNextFocusElement();
74
+ nextElement?.focus();
75
+ }, [getNextFocusElement]);
76
+ const getPreviousFocusElement = useCallback(() => {
77
+ const elements = getFocusableElements();
78
+ if (elements.length === 0) {
79
+ return void 0;
80
+ }
81
+ let previousElement = elements[0];
82
+ if (document.activeElement instanceof HTMLElement) {
83
+ const currentIndex = elements.indexOf(document.activeElement);
84
+ if (currentIndex === 0) {
85
+ previousElement = elements[elements.length - 1];
86
+ } else {
87
+ previousElement = elements[currentIndex - 1];
88
+ }
89
+ }
90
+ return previousElement;
91
+ }, [getFocusableElements]);
92
+ const focusPrevious = useCallback(() => {
93
+ const previousElement = getPreviousFocusElement();
94
+ if (previousElement) previousElement.focus();
95
+ }, [getPreviousFocusElement]);
96
+ return {
97
+ getFocusableElements,
98
+ getNextFocusElement,
99
+ getPreviousFocusElement,
100
+ focusNext,
101
+ focusPrevious
102
+ };
103
+ }
104
+
105
+ // src/hooks/focus/useFocusOnceVisible.ts
106
+ import React, { useEffect as useEffect2 } from "react";
107
+ var useFocusOnceVisible = (ref, disable = false) => {
108
+ const [hasUsedFocus, setHasUsedFocus] = React.useState(false);
109
+ useEffect2(() => {
110
+ if (disable || hasUsedFocus) {
111
+ return;
112
+ }
113
+ const observer = new IntersectionObserver(([entry]) => {
114
+ if (entry.isIntersecting && !hasUsedFocus) {
115
+ ref.current?.focus();
116
+ setHasUsedFocus(hasUsedFocus);
117
+ }
118
+ }, {
119
+ threshold: 0.1
120
+ });
121
+ if (ref.current) {
122
+ observer.observe(ref.current);
123
+ }
124
+ return () => observer.disconnect();
125
+ }, [disable, hasUsedFocus, ref]);
126
+ };
127
+
128
+ // src/hooks/focus/useFocusTrap.ts
129
+ import { useCallback as useCallback2, useEffect as useEffect4, useId, useRef, useState as useState2 } from "react";
130
+
131
+ // src/hooks/focus/useIsMounted.ts
132
+ import { useEffect as useEffect3, useLayoutEffect, useState } from "react";
133
+ var isClient = typeof window !== "undefined" && typeof document !== "undefined";
134
+ var useIsomorphicEffect = isClient ? useLayoutEffect : useEffect3;
135
+ var useIsMounted = () => {
136
+ const [isMounted, setIsMounted] = useState(false);
137
+ useIsomorphicEffect(() => {
138
+ setIsMounted(true);
139
+ return () => {
140
+ setIsMounted(false);
141
+ };
142
+ }, []);
143
+ return isMounted;
144
+ };
145
+
146
+ // src/hooks/focus/useFocusTrap.ts
147
+ var createFocusGuard = () => {
148
+ const div = document.createElement("div");
149
+ Object.assign(div.style, {
150
+ opacity: "0",
151
+ outline: "none",
152
+ boxShadow: "none",
153
+ position: "fixed",
154
+ pointerEvents: "none",
155
+ touchAction: "none"
156
+ });
157
+ div.tabIndex = 0;
158
+ div.setAttribute("data-hw-focus-guard", "");
159
+ document.body.appendChild(div);
160
+ return div;
161
+ };
162
+ function getContainedFocusableElements(element) {
163
+ return element?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
164
+ }
165
+ var FocusTrapService = class {
166
+ constructor() {
167
+ // The last entry is always the active one
168
+ this.listeners = [];
169
+ this.onFocusIn = (event) => {
170
+ const active = this.getActive();
171
+ if (!active || !active.container.current) return;
172
+ const { container } = active;
173
+ if (!container.current.contains(event.target)) {
174
+ this.focusElement();
175
+ }
176
+ };
177
+ }
178
+ getActive() {
179
+ if (this.listeners.length === 0) return void 0;
180
+ return this.listeners[this.listeners.length - 1];
181
+ }
182
+ focusElement() {
183
+ const active = this.getActive();
184
+ if (!active) return;
185
+ const { container, initialFocusElement } = active;
186
+ const containerElement = container.current;
187
+ if (initialFocusElement?.current) {
188
+ initialFocusElement.current.focus();
189
+ } else {
190
+ const elements = getContainedFocusableElements(containerElement);
191
+ if (elements && elements.length > 0) {
192
+ const first = elements.item(0);
193
+ first.focus();
194
+ } else {
195
+ containerElement.focus();
196
+ }
197
+ }
198
+ }
199
+ removeGuards() {
200
+ document.querySelectorAll("[data-hw-focus-guard]").forEach((node) => node.remove());
201
+ }
202
+ addGuards() {
203
+ document.body.insertAdjacentElement("afterbegin", createFocusGuard());
204
+ document.body.insertAdjacentElement("beforeend", createFocusGuard());
205
+ }
206
+ activate() {
207
+ document.addEventListener("focusin", this.onFocusIn);
208
+ this.addGuards();
209
+ }
210
+ deactivate() {
211
+ document.removeEventListener("focusin", this.onFocusIn);
212
+ this.removeGuards();
213
+ }
214
+ register(listener) {
215
+ this.listeners.push(listener);
216
+ if (this.listeners.length === 1) {
217
+ this.activate();
218
+ }
219
+ const active = listener;
220
+ this.listeners.forEach((listener2) => {
221
+ const { focus, pause } = listener2;
222
+ if (listener2 === active) {
223
+ focus();
224
+ } else {
225
+ pause();
226
+ }
227
+ });
228
+ }
229
+ unregister(id) {
230
+ const index = this.listeners.findIndex((trap) => trap.id === id);
231
+ if (index !== -1) {
232
+ const isActive = index === this.listeners.length - 1;
233
+ const listener = this.listeners[index];
234
+ this.listeners = this.listeners.filter((listener2) => listener2.id !== id);
235
+ if (isActive) {
236
+ this.deactivate();
237
+ listener.focusLast();
238
+ const active = this.getActive();
239
+ this.listeners.forEach((listener2) => {
240
+ const { pause, unpause } = listener2;
241
+ if (listener2 === active) {
242
+ unpause();
243
+ } else {
244
+ pause();
245
+ }
246
+ });
247
+ if (this.listeners.length > 0) {
248
+ this.activate();
249
+ }
250
+ }
251
+ } else {
252
+ console.warn(`Unable to unregister id ${id}: not found`);
253
+ }
254
+ }
255
+ };
256
+ var service = new FocusTrapService();
257
+ var useFocusTrap = ({
258
+ container,
259
+ active = true,
260
+ initialFocus,
261
+ focusFirst = true
262
+ }) => {
263
+ const lastFocusRef = useRef(null);
264
+ const [paused, setPaused] = useState2(false);
265
+ const isMounted = useIsMounted();
266
+ const id = useId();
267
+ const focusElement = useCallback2(() => {
268
+ const containerElement = container.current;
269
+ if (initialFocus?.current) {
270
+ initialFocus.current.focus();
271
+ } else {
272
+ const elements = getContainedFocusableElements(containerElement);
273
+ if (elements && elements.length > 0) {
274
+ const first = elements.item(0);
275
+ first.focus();
276
+ } else {
277
+ containerElement.focus();
278
+ }
279
+ }
280
+ }, [container, initialFocus]);
281
+ useEffect4(() => {
282
+ if (active && isMounted) {
283
+ let pause = function() {
284
+ setPaused(true);
285
+ }, unpause = function() {
286
+ setPaused(false);
287
+ if (!container.current.contains(document.activeElement)) {
288
+ focusElement();
289
+ }
290
+ }, focus = function() {
291
+ focusElement();
292
+ setPaused(false);
293
+ }, focusLast = function() {
294
+ lastFocusRef.current?.focus();
295
+ };
296
+ if (!lastFocusRef.current) {
297
+ lastFocusRef.current = document.activeElement;
298
+ }
299
+ service.register({ id, pause, focus, focusLast, unpause, container, initialFocusElement: initialFocus });
300
+ return () => {
301
+ service.unregister(id);
302
+ lastFocusRef.current = void 0;
303
+ };
304
+ }
305
+ }, [active, container, focusElement, id, initialFocus, isMounted]);
306
+ useEffect4(() => {
307
+ if (active && !paused && isMounted) {
308
+ let onKeyDown = function(event) {
309
+ const key = event.key;
310
+ const elements = getContainedFocusableElements(containerElement);
311
+ const active2 = document.activeElement;
312
+ const index = [...elements].findIndex((value) => value === active2);
313
+ if (index === -1 || event.altKey || event.ctrlKey || event.metaKey) {
314
+ return;
315
+ }
316
+ if (key === "Tab") {
317
+ const next = event.shiftKey ? -1 : 1;
318
+ const nextIndex = (index + next + elements.length) % elements.length;
319
+ const nextElement = elements[nextIndex];
320
+ nextElement.focus();
321
+ event.preventDefault();
322
+ }
323
+ };
324
+ const containerElement = container.current;
325
+ containerElement.addEventListener("keydown", onKeyDown);
326
+ return () => {
327
+ containerElement.removeEventListener("keydown", onKeyDown);
328
+ };
329
+ }
330
+ }, [active, paused, isMounted, container, initialFocus, focusFirst, focusElement]);
331
+ };
332
+ export {
333
+ useFocusGuards,
334
+ useFocusManagement,
335
+ useFocusOnceVisible,
336
+ useFocusTrap,
337
+ useIsMounted
338
+ };
339
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/hooks/focus/useFocusGuards.ts","../../../src/hooks/focus/useFocusManagement.ts","../../../src/hooks/focus/useFocusOnceVisible.ts","../../../src/hooks/focus/useFocusTrap.ts","../../../src/hooks/focus/useIsMounted.ts"],"sourcesContent":["import { useEffect } from 'react'\n\nconst selectorName = 'data-hw-focus-guard'\n\nfunction FocusGuard() {\n const element = document.createElement('div')\n element.setAttribute(selectorName, '')\n element.tabIndex = 0\n element.style.border = 'none'\n element.style.outline = 'none'\n element.style.boxShadow = 'none'\n element.style.opacity = '0'\n element.style.position = 'fixed'\n element.style.pointerEvents = 'none'\n return element\n}\n\nclass FocusGuardsService {\n private count: number = 0\n\n private static instance: FocusGuardsService\n\n private constructor() {}\n\n static getInstance(): FocusGuardsService {\n if (!FocusGuardsService.instance) {\n FocusGuardsService.instance = new FocusGuardsService()\n }\n return FocusGuardsService.instance\n }\n\n add() {\n const edgeGuards = document.querySelectorAll(`[${selectorName}]`)\n document.body.insertAdjacentElement('afterbegin', edgeGuards[0] ?? FocusGuard())\n document.body.insertAdjacentElement('beforeend', edgeGuards[1] ?? FocusGuard())\n this.count++\n }\n\n remove() {\n if (this.count === 1) {\n document.querySelectorAll(`[${selectorName}]`)\n .forEach((node) => node.remove())\n }\n this.count--\n }\n}\n\nexport const useFocusGuards = () => {\n useEffect(() => {\n FocusGuardsService.getInstance().add()\n return () => {\n FocusGuardsService.getInstance().remove()\n }\n }, [])\n}","import { useCallback } from 'react'\n\nexport function useFocusManagement() {\n const getFocusableElements = useCallback((): HTMLElement[] => {\n return Array.from(\n document.querySelectorAll(\n 'input, button, select, textarea, a[href], [tabindex]:not([tabindex=\"-1\"])'\n )\n ).filter(\n (el): el is HTMLElement =>\n el instanceof HTMLElement &&\n !el.hasAttribute('disabled') &&\n !el.hasAttribute('hidden') &&\n el.tabIndex !== -1\n )\n }, [])\n\n const getNextFocusElement = useCallback((): HTMLElement | undefined => {\n const elements = getFocusableElements()\n if(elements.length === 0) {\n return undefined\n }\n let nextElement = elements[0]\n if(document.activeElement instanceof HTMLElement) {\n const currentIndex = elements.indexOf(document.activeElement)\n nextElement = elements[(currentIndex + 1) % elements.length]\n }\n return nextElement\n }, [getFocusableElements])\n\n const focusNext = useCallback(() => {\n const nextElement = getNextFocusElement()\n nextElement?.focus()\n }, [getNextFocusElement])\n\n const getPreviousFocusElement = useCallback((): HTMLElement | undefined => {\n const elements = getFocusableElements()\n if(elements.length === 0) {\n return undefined\n }\n let previousElement = elements[0]\n if(document.activeElement instanceof HTMLElement) {\n const currentIndex = elements.indexOf(document.activeElement)\n if(currentIndex === 0) {\n previousElement = elements[elements.length - 1]\n } else {\n previousElement = elements[currentIndex - 1]\n }\n }\n return previousElement\n }, [getFocusableElements])\n\n const focusPrevious = useCallback(() => {\n const previousElement = getPreviousFocusElement()\n if (previousElement) previousElement.focus()\n }, [getPreviousFocusElement])\n\n return {\n getFocusableElements,\n getNextFocusElement,\n getPreviousFocusElement,\n focusNext,\n focusPrevious,\n }\n}","import type { MutableRefObject } from 'react'\nimport React, { useEffect } from 'react'\n\nexport const useFocusOnceVisible = (\n ref: MutableRefObject<HTMLElement>,\n disable: boolean = false\n) => {\n const [hasUsedFocus, setHasUsedFocus] = React.useState(false)\n\n useEffect(() => {\n if (disable || hasUsedFocus) {\n return\n }\n const observer = new IntersectionObserver(([entry]) => {\n if (entry.isIntersecting && !hasUsedFocus) {\n ref.current?.focus()\n setHasUsedFocus(hasUsedFocus)\n }\n }, {\n threshold: 0.1,\n })\n\n if (ref.current) {\n observer.observe(ref.current)\n }\n\n return () => observer.disconnect()\n }, [disable, hasUsedFocus, ref])\n}","'use client'\n\nimport type { MutableRefObject } from 'react'\nimport { useCallback, useEffect, useId, useRef, useState } from 'react'\nimport { useIsMounted } from '@/src/hooks/focus/useIsMounted'\n\nconst createFocusGuard = () => {\n const div = document.createElement('div')\n Object.assign(div.style, {\n opacity: '0',\n outline: 'none',\n boxShadow: 'none',\n position: 'fixed',\n pointerEvents: 'none',\n touchAction: 'none',\n })\n div.tabIndex = 0\n div.setAttribute('data-hw-focus-guard', '')\n document.body.appendChild(div)\n return div\n}\n\nfunction getContainedFocusableElements(element: HTMLElement) {\n return element?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])')\n}\n\ntype ListenerType = {\n id: string,\n pause: () => void,\n unpause: () => void,\n focus: () => void,\n focusLast: () => void,\n container: MutableRefObject<HTMLElement>,\n initialFocusElement: MutableRefObject<HTMLElement>,\n}\n\nclass FocusTrapService {\n // The last entry is always the active one\n private listeners: ListenerType[] = []\n\n public getActive(): ListenerType | undefined {\n if (this.listeners.length === 0) return undefined\n return this.listeners[this.listeners.length - 1]\n }\n\n private focusElement() {\n const active = this.getActive()\n if(!active) return\n const { container, initialFocusElement } = active\n const containerElement = container.current\n // Try in the following order\n // 1. Focus the initial element\n // 2. Focus the first focusable element in the container\n // 3. Focus the container\n if (initialFocusElement?.current) {\n initialFocusElement.current.focus()\n } else {\n const elements = getContainedFocusableElements(containerElement)\n if (elements && elements.length > 0) {\n const first = elements.item(0) as HTMLElement\n first.focus()\n } else {\n containerElement.focus()\n }\n }\n }\n\n private onFocusIn = (event: FocusEvent) => {\n const active = this.getActive()\n if(!active || !active.container.current) return\n const { container } = active\n if (!container.current.contains(event.target as HTMLElement)) {\n this.focusElement()\n }\n }\n\n private removeGuards() {\n document.querySelectorAll('[data-hw-focus-guard]').forEach((node) => node.remove())\n }\n\n private addGuards() {\n document.body.insertAdjacentElement('afterbegin', createFocusGuard())\n document.body.insertAdjacentElement('beforeend', createFocusGuard())\n }\n\n private activate() {\n document.addEventListener('focusin', this.onFocusIn)\n this.addGuards()\n }\n\n private deactivate() {\n document.removeEventListener('focusin', this.onFocusIn)\n this.removeGuards()\n }\n\n register(listener: ListenerType) {\n this.listeners.push(listener)\n if (this.listeners.length === 1) {\n this.activate()\n }\n const active = listener\n this.listeners.forEach((listener) => {\n const { focus, pause } = listener\n if (listener === active) {\n focus()\n } else {\n pause()\n }\n })\n }\n\n unregister(id: string) {\n const index = this.listeners.findIndex(trap => trap.id === id)\n if (index !== -1) {\n const isActive = index === this.listeners.length - 1\n const listener = this.listeners[index]\n this.listeners = this.listeners.filter(listener => listener.id !== id)\n if (isActive) {\n // Deactivate all focus traps\n this.deactivate()\n // Focus last element in previous focus context\n listener.focusLast()\n // Activate and pause remaining focus traps\n const active = this.getActive()\n this.listeners.forEach((listener) => {\n const { pause, unpause } = listener\n if (listener === active) {\n unpause()\n } else {\n pause()\n }\n })\n // Reactivate\n if (this.listeners.length > 0) {\n this.activate()\n }\n }\n } else {\n console.warn(`Unable to unregister id ${id}: not found`)\n }\n }\n}\n\nconst service = new FocusTrapService()\n\nexport type UseFocusTrapProps = {\n container: MutableRefObject<HTMLElement>,\n active?: boolean,\n initialFocus?: MutableRefObject<HTMLElement>,\n /**\n * Whether to focus the first element when the initialFocus isn't provided\n *\n * Focuses the container instead\n */\n focusFirst?: boolean,\n}\n\nexport const useFocusTrap = ({\n container,\n active = true,\n initialFocus,\n focusFirst = true,\n }: UseFocusTrapProps) => {\n const lastFocusRef = useRef<HTMLElement | null>(null)\n const [paused, setPaused] = useState(false)\n const isMounted = useIsMounted()\n const id = useId()\n\n const focusElement = useCallback(() => {\n const containerElement = container.current\n // Try in the following order\n // 1. Focus the initial element\n // 2. Focus the first focusable element in the container\n // 3. Focus the container\n if (initialFocus?.current) {\n initialFocus.current.focus()\n } else {\n const elements = getContainedFocusableElements(containerElement)\n if (elements && elements.length > 0) {\n const first = elements.item(0) as HTMLElement\n first.focus()\n } else {\n containerElement.focus()\n }\n }\n }, [container, initialFocus])\n\n useEffect(() => {\n if (active && isMounted) {\n if (!lastFocusRef.current) {\n lastFocusRef.current = document.activeElement as HTMLElement\n }\n\n function pause() {\n setPaused(true)\n }\n\n function unpause() {\n setPaused(false)\n if (!container.current.contains(document.activeElement as HTMLElement)) {\n focusElement()\n }\n }\n\n function focus() {\n focusElement()\n setPaused(false)\n }\n\n function focusLast() {\n lastFocusRef.current?.focus()\n }\n\n service.register({ id, pause, focus, focusLast, unpause, container, initialFocusElement: initialFocus })\n return () => {\n service.unregister(id)\n lastFocusRef.current = undefined\n }\n }\n }, [active, container, focusElement, id, initialFocus, isMounted])\n\n useEffect(() => {\n if (active && !paused && isMounted) {\n const containerElement = container.current\n\n function onKeyDown(event: KeyboardEvent) {\n const key = event.key\n const elements = getContainedFocusableElements(containerElement)\n const active = document.activeElement as HTMLElement\n const index = [...elements].findIndex(value => value === active)\n if (index === -1 || event.altKey || event.ctrlKey || event.metaKey) {\n return\n }\n if (key === 'Tab') {\n const next = event.shiftKey ? -1 : 1\n const nextIndex = (index + next + elements.length) % elements.length\n const nextElement = elements[nextIndex] as HTMLElement\n nextElement.focus()\n event.preventDefault()\n }\n }\n\n // Register and unregister the listeners\n containerElement.addEventListener('keydown', onKeyDown)\n return () => {\n containerElement.removeEventListener('keydown', onKeyDown)\n }\n }\n }, [active, paused, isMounted, container, initialFocus, focusFirst, focusElement])\n}","'use client'\n\nimport { useEffect, useLayoutEffect, useState } from 'react'\n\nconst isClient = typeof window !== 'undefined' && typeof document !== 'undefined'\nconst useIsomorphicEffect = isClient ? useLayoutEffect : useEffect\n\nexport const useIsMounted = () => {\n const [isMounted, setIsMounted] = useState(false)\n\n useIsomorphicEffect(() => {\n setIsMounted(true)\n return () => {\n setIsMounted(false)\n }\n }, [])\n return isMounted\n}"],"mappings":"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","names":["useEffect","useCallback","useEffect","useState","useEffect","listener","useState","useCallback","useEffect","active"]}
@@ -0,0 +1,16 @@
1
+ export { useFocusGuards } from './focus/useFocusGuards.mjs';
2
+ export { useFocusManagement } from './focus/useFocusManagement.mjs';
3
+ export { useFocusOnceVisible } from './focus/useFocusOnceVisible.mjs';
4
+ export { UseFocusTrapProps, useFocusTrap } from './focus/useFocusTrap.mjs';
5
+ export { useIsMounted } from './focus/useIsMounted.mjs';
6
+ export { UseDelayOptions, UseDelayOptionsResolved, useDelay } from './useDelay.mjs';
7
+ export { FloatingElementAlignment, UseFloatingElementOptions, UseFloatingElementProps, useFloatingElement } from './useFloatingElement.mjs';
8
+ export { useHoverState } from './useHoverState.mjs';
9
+ export { useLocalStorage } from './useLocalStorage.mjs';
10
+ export { useLogOnce } from './useLogOnce.mjs';
11
+ export { useOutsideClick } from './useOutsideClick.mjs';
12
+ export { PopoverHorizontalAlignment, PopoverVerticalAlignment, usePopoverPosition } from './usePopoverPosition.mjs';
13
+ export { useRerender } from './useRerender.mjs';
14
+ export { useResizeCallbackWrapper } from './useResizeCallbackWrapper.mjs';
15
+ export { UseSearchProps, useSearch } from './useSearch.mjs';
16
+ import 'react';
@@ -0,0 +1,16 @@
1
+ export { useFocusGuards } from './focus/useFocusGuards.js';
2
+ export { useFocusManagement } from './focus/useFocusManagement.js';
3
+ export { useFocusOnceVisible } from './focus/useFocusOnceVisible.js';
4
+ export { UseFocusTrapProps, useFocusTrap } from './focus/useFocusTrap.js';
5
+ export { useIsMounted } from './focus/useIsMounted.js';
6
+ export { UseDelayOptions, UseDelayOptionsResolved, useDelay } from './useDelay.js';
7
+ export { FloatingElementAlignment, UseFloatingElementOptions, UseFloatingElementProps, useFloatingElement } from './useFloatingElement.js';
8
+ export { useHoverState } from './useHoverState.js';
9
+ export { useLocalStorage } from './useLocalStorage.js';
10
+ export { useLogOnce } from './useLogOnce.js';
11
+ export { useOutsideClick } from './useOutsideClick.js';
12
+ export { PopoverHorizontalAlignment, PopoverVerticalAlignment, usePopoverPosition } from './usePopoverPosition.js';
13
+ export { useRerender } from './useRerender.js';
14
+ export { useResizeCallbackWrapper } from './useResizeCallbackWrapper.js';
15
+ export { UseSearchProps, useSearch } from './useSearch.js';
16
+ import 'react';