@monstermann/signals-modal 0.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.
Files changed (125) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +9 -0
  3. package/dist/anchor/getAnchorElement.d.ts +4 -0
  4. package/dist/anchor/getAnchorElement.js +9 -0
  5. package/dist/anchor/getAnchorMeasurement.d.ts +6 -0
  6. package/dist/anchor/getAnchorMeasurement.js +10 -0
  7. package/dist/anchor/internals.js +19 -0
  8. package/dist/anchor/setAnchorElement.d.ts +4 -0
  9. package/dist/anchor/setAnchorElement.js +9 -0
  10. package/dist/anchor/withAnchorElement.d.ts +6 -0
  11. package/dist/anchor/withAnchorElement.js +32 -0
  12. package/dist/anchor/withAnchorMeasurement.d.ts +12 -0
  13. package/dist/anchor/withAnchorMeasurement.js +56 -0
  14. package/dist/anchor/withMouseAnchor.d.ts +11 -0
  15. package/dist/anchor/withMouseAnchor.js +57 -0
  16. package/dist/createModal.d.ts +14 -0
  17. package/dist/createModal.js +47 -0
  18. package/dist/floating/getFloatingElement.d.ts +4 -0
  19. package/dist/floating/getFloatingElement.js +9 -0
  20. package/dist/floating/getFloatingMeasurement.d.ts +6 -0
  21. package/dist/floating/getFloatingMeasurement.js +10 -0
  22. package/dist/floating/internals.js +19 -0
  23. package/dist/floating/setFloatingElement.d.ts +4 -0
  24. package/dist/floating/setFloatingElement.js +9 -0
  25. package/dist/floating/withFloatingElement.d.ts +6 -0
  26. package/dist/floating/withFloatingElement.js +32 -0
  27. package/dist/floating/withFloatingMeasurement.d.ts +12 -0
  28. package/dist/floating/withFloatingMeasurement.js +67 -0
  29. package/dist/groups/getDialogs.d.ts +4 -0
  30. package/dist/groups/getDialogs.js +10 -0
  31. package/dist/groups/getGroupsForModal.d.ts +4 -0
  32. package/dist/groups/getGroupsForModal.js +10 -0
  33. package/dist/groups/getModalsForGroup.d.ts +4 -0
  34. package/dist/groups/getModalsForGroup.js +10 -0
  35. package/dist/groups/getPopovers.d.ts +4 -0
  36. package/dist/groups/getPopovers.js +10 -0
  37. package/dist/groups/getTooltips.d.ts +4 -0
  38. package/dist/groups/getTooltips.js +10 -0
  39. package/dist/groups/internals.js +26 -0
  40. package/dist/groups/isDialog.d.ts +4 -0
  41. package/dist/groups/isDialog.js +10 -0
  42. package/dist/groups/isModalInGroup.d.ts +4 -0
  43. package/dist/groups/isModalInGroup.js +9 -0
  44. package/dist/groups/isPopover.d.ts +4 -0
  45. package/dist/groups/isPopover.js +10 -0
  46. package/dist/groups/isTooltip.d.ts +4 -0
  47. package/dist/groups/isTooltip.js +10 -0
  48. package/dist/groups/modalGroups.d.ts +8 -0
  49. package/dist/groups/modalGroups.js +9 -0
  50. package/dist/groups/withModalGroups.d.ts +6 -0
  51. package/dist/groups/withModalGroups.js +29 -0
  52. package/dist/index.d.ts +57 -0
  53. package/dist/index.js +57 -0
  54. package/dist/internals/findParentElement.js +9 -0
  55. package/dist/internals/observeDimensions.js +23 -0
  56. package/dist/internals/observePosition.js +44 -0
  57. package/dist/internals/roundByDPR.js +8 -0
  58. package/dist/position/getModalPosition.d.ts +6 -0
  59. package/dist/position/getModalPosition.js +9 -0
  60. package/dist/position/internals.js +32 -0
  61. package/dist/position/withBoundary.d.ts +11 -0
  62. package/dist/position/withBoundary.js +45 -0
  63. package/dist/position/withPlacement.d.ts +14 -0
  64. package/dist/position/withPlacement.js +75 -0
  65. package/dist/position/withPosition.d.ts +22 -0
  66. package/dist/position/withPosition.js +207 -0
  67. package/dist/status/closeAllModals.d.ts +4 -0
  68. package/dist/status/closeAllModals.js +16 -0
  69. package/dist/status/closeModal.d.ts +4 -0
  70. package/dist/status/closeModal.js +16 -0
  71. package/dist/status/getClosedModals.d.ts +4 -0
  72. package/dist/status/getClosedModals.js +12 -0
  73. package/dist/status/getClosingModals.d.ts +4 -0
  74. package/dist/status/getClosingModals.js +12 -0
  75. package/dist/status/getModalStatus.d.ts +6 -0
  76. package/dist/status/getModalStatus.js +9 -0
  77. package/dist/status/getOpenedModals.d.ts +4 -0
  78. package/dist/status/getOpenedModals.js +12 -0
  79. package/dist/status/getOpeningModals.d.ts +4 -0
  80. package/dist/status/getOpeningModals.js +12 -0
  81. package/dist/status/getVisibleModals.d.ts +4 -0
  82. package/dist/status/getVisibleModals.js +12 -0
  83. package/dist/status/internals.js +30 -0
  84. package/dist/status/isAnyModalClosed.d.ts +4 -0
  85. package/dist/status/isAnyModalClosed.js +9 -0
  86. package/dist/status/isAnyModalClosing.d.ts +4 -0
  87. package/dist/status/isAnyModalClosing.js +9 -0
  88. package/dist/status/isAnyModalOpened.d.ts +4 -0
  89. package/dist/status/isAnyModalOpened.js +9 -0
  90. package/dist/status/isAnyModalOpening.d.ts +4 -0
  91. package/dist/status/isAnyModalOpening.js +9 -0
  92. package/dist/status/isAnyModalVisible.d.ts +4 -0
  93. package/dist/status/isAnyModalVisible.js +9 -0
  94. package/dist/status/isModalClosed.d.ts +4 -0
  95. package/dist/status/isModalClosed.js +10 -0
  96. package/dist/status/isModalClosing.d.ts +4 -0
  97. package/dist/status/isModalClosing.js +9 -0
  98. package/dist/status/isModalOpened.d.ts +4 -0
  99. package/dist/status/isModalOpened.js +9 -0
  100. package/dist/status/isModalOpening.d.ts +4 -0
  101. package/dist/status/isModalOpening.js +9 -0
  102. package/dist/status/isModalVisible.d.ts +4 -0
  103. package/dist/status/isModalVisible.js +9 -0
  104. package/dist/status/onModalClosed.d.ts +6 -0
  105. package/dist/status/onModalClosed.js +12 -0
  106. package/dist/status/onModalClosing.d.ts +6 -0
  107. package/dist/status/onModalClosing.js +12 -0
  108. package/dist/status/onModalOpened.d.ts +6 -0
  109. package/dist/status/onModalOpened.js +12 -0
  110. package/dist/status/onModalOpening.d.ts +6 -0
  111. package/dist/status/onModalOpening.js +12 -0
  112. package/dist/status/openModal.d.ts +4 -0
  113. package/dist/status/openModal.js +16 -0
  114. package/dist/status/setModalStatus.d.ts +6 -0
  115. package/dist/status/setModalStatus.js +9 -0
  116. package/dist/status/types.d.ts +4 -0
  117. package/dist/status/withModalStatus.d.ts +7 -0
  118. package/dist/status/withModalStatus.js +38 -0
  119. package/dist/utils/closeLastModalOnClickOutside.d.ts +4 -0
  120. package/dist/utils/closeLastModalOnClickOutside.js +19 -0
  121. package/dist/utils/closeLastModalOnEsc.d.ts +4 -0
  122. package/dist/utils/closeLastModalOnEsc.js +17 -0
  123. package/dist/utils/syncModalGroupsToBody.d.ts +4 -0
  124. package/dist/utils/syncModalGroupsToBody.js +24 -0
  125. package/package.json +43 -0
@@ -0,0 +1,4 @@
1
+ //#region src/status/openModal.d.ts
2
+ declare function openModal(key: string): void;
3
+ //#endregion
4
+ export { openModal };
@@ -0,0 +1,16 @@
1
+ import { $keysToStatus } from "./internals.js";
2
+ import { untrack } from "@monstermann/signals";
3
+
4
+ //#region src/status/openModal.ts
5
+ function openModal(key) {
6
+ untrack(() => {
7
+ const $status = $keysToStatus().get(key);
8
+ if (!$status) return;
9
+ if ($status() === "opening") return;
10
+ if ($status() === "opened") return;
11
+ $status("opening");
12
+ });
13
+ }
14
+
15
+ //#endregion
16
+ export { openModal };
@@ -0,0 +1,6 @@
1
+ import { ModalStatus } from "./types.js";
2
+
3
+ //#region src/status/setModalStatus.d.ts
4
+ declare function setModalStatus(key: string, status: ModalStatus): void;
5
+ //#endregion
6
+ export { setModalStatus };
@@ -0,0 +1,9 @@
1
+ import { $keysToStatus } from "./internals.js";
2
+
3
+ //#region src/status/setModalStatus.ts
4
+ function setModalStatus(key, status) {
5
+ $keysToStatus().get(key)?.(status);
6
+ }
7
+
8
+ //#endregion
9
+ export { setModalStatus };
@@ -0,0 +1,4 @@
1
+ //#region src/status/types.d.ts
2
+ type ModalStatus = "closed" | "opening" | "opened" | "closing";
3
+ //#endregion
4
+ export { ModalStatus };
@@ -0,0 +1,7 @@
1
+ import { ModalStatus } from "./types.js";
2
+ import { Signal } from "@monstermann/signals";
3
+
4
+ //#region src/status/withModalStatus.d.ts
5
+ declare function withModalStatus(status?: ModalStatus): Signal<ModalStatus>;
6
+ //#endregion
7
+ export { withModalStatus };
@@ -0,0 +1,38 @@
1
+ import { set } from "../node_modules/@monstermann/map/dist/Map/set.js";
2
+ import { remove } from "../node_modules/@monstermann/map/dist/Map/remove.js";
3
+ import { onModalClosed } from "./onModalClosed.js";
4
+ import { onModalOpened } from "./onModalOpened.js";
5
+ import { onModalOpening } from "./onModalOpening.js";
6
+ import { $keysToStatus } from "./internals.js";
7
+ import { currentModal } from "../createModal.js";
8
+ import { onModalClosing } from "./onModalClosing.js";
9
+ import { INTERNAL, signal, watch } from "@monstermann/signals";
10
+
11
+ //#region src/status/withModalStatus.ts
12
+ const path = "@signals-modal/status/withModalStatus.ts";
13
+ const meta = {
14
+ path,
15
+ line: 15,
16
+ name: "withModalStatus.$status"
17
+ };
18
+ const meta1 = {
19
+ path,
20
+ line: 20,
21
+ name: "withModalStatus"
22
+ };
23
+ function withModalStatus(status = "closed") {
24
+ const modal = currentModal();
25
+ const $status = signal(status, INTERNAL, meta);
26
+ $keysToStatus((keys) => set(keys, modal.key, $status));
27
+ modal.onDispose(() => $keysToStatus((keys) => remove(keys, modal.key)));
28
+ modal.onDispose(watch($status, (status$1) => {
29
+ if (status$1 === "closed") onModalClosed(modal.key);
30
+ else if (status$1 === "closing") onModalClosing(modal.key);
31
+ else if (status$1 === "opening") onModalOpening(modal.key);
32
+ else if (status$1 === "opened") onModalOpened(modal.key);
33
+ }, INTERNAL, meta1));
34
+ return $status;
35
+ }
36
+
37
+ //#endregion
38
+ export { withModalStatus };
@@ -0,0 +1,4 @@
1
+ //#region src/utils/closeLastModalOnClickOutside.d.ts
2
+ declare function closeLastModalOnClickOutside(): void;
3
+ //#endregion
4
+ export { closeLastModalOnClickOutside };
@@ -0,0 +1,19 @@
1
+ import { $openedModals } from "../status/internals.js";
2
+ import { closeModal } from "../status/closeModal.js";
3
+ import { getFloatingElement } from "../floating/getFloatingElement.js";
4
+ import { findParentElement } from "../internals/findParentElement.js";
5
+
6
+ //#region src/utils/closeLastModalOnClickOutside.ts
7
+ function closeLastModalOnClickOutside() {
8
+ document.addEventListener("mousedown", (evt) => {
9
+ const key = Array.from($openedModals()).at(-1);
10
+ if (!key) return;
11
+ const target = evt.target;
12
+ const floating = getFloatingElement(key);
13
+ if (!floating) return;
14
+ if (!findParentElement(target, (el) => el === floating)) closeModal(key);
15
+ });
16
+ }
17
+
18
+ //#endregion
19
+ export { closeLastModalOnClickOutside };
@@ -0,0 +1,4 @@
1
+ //#region src/utils/closeLastModalOnEsc.d.ts
2
+ declare function closeLastModalOnEsc(): void;
3
+ //#endregion
4
+ export { closeLastModalOnEsc };
@@ -0,0 +1,17 @@
1
+ import { $openedModals } from "../status/internals.js";
2
+ import { closeModal } from "../status/closeModal.js";
3
+ import { findParentElement } from "../internals/findParentElement.js";
4
+
5
+ //#region src/utils/closeLastModalOnEsc.ts
6
+ function closeLastModalOnEsc() {
7
+ document.addEventListener("keydown", (evt) => {
8
+ if (evt.key !== "Escape") return;
9
+ const key = Array.from($openedModals()).at(-1);
10
+ if (!key) return;
11
+ const target = evt.target;
12
+ if (!(target.nodeName === "INPUT" || target.nodeName === "TEXTAREA" || findParentElement(target, (el) => el.getAttribute("contenteditable") === "true"))) closeModal(key);
13
+ });
14
+ }
15
+
16
+ //#endregion
17
+ export { closeLastModalOnEsc };
@@ -0,0 +1,4 @@
1
+ //#region src/utils/syncModalGroupsToBody.d.ts
2
+ declare function syncModalGroupsToBody(): void;
3
+ //#endregion
4
+ export { syncModalGroupsToBody };
@@ -0,0 +1,24 @@
1
+ import { getGroupsForModal } from "../groups/getGroupsForModal.js";
2
+ import { getVisibleModals } from "../status/getVisibleModals.js";
3
+ import { INTERNAL, effect } from "@monstermann/signals";
4
+
5
+ //#region src/utils/syncModalGroupsToBody.ts
6
+ const meta = {
7
+ path: "@signals-modal/utils/syncModalGroupsToBody.ts",
8
+ line: 6,
9
+ name: "syncModalGroupsToBody"
10
+ };
11
+ function syncModalGroupsToBody() {
12
+ effect(() => {
13
+ const modals = getVisibleModals();
14
+ const clx = /* @__PURE__ */ new Set();
15
+ for (const modal of modals) for (const group of getGroupsForModal(modal)) clx.add(`has-${group}`);
16
+ document.body.classList.add(...clx);
17
+ return () => {
18
+ document.body.classList.remove(...clx);
19
+ };
20
+ }, INTERNAL, meta);
21
+ }
22
+
23
+ //#endregion
24
+ export { syncModalGroupsToBody };
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "@monstermann/signals-modal",
3
+ "type": "module",
4
+ "version": "0.0.0",
5
+ "description": "Composable modal management.",
6
+ "author": "Michael Ostermann <michaelostermann@me.com>",
7
+ "license": "MIT",
8
+ "homepage": "https://MichaelOstermann.github.io/signals-modal",
9
+ "repository": {
10
+ "type": "git",
11
+ "url": "git+https://github.com/MichaelOstermann/signals-modal.git"
12
+ },
13
+ "bugs": {
14
+ "url": "https://github.com/MichaelOstermann/signals-modal/issues"
15
+ },
16
+ "keywords": [],
17
+ "sideEffects": false,
18
+ "exports": {
19
+ ".": {
20
+ "types": "./dist/index.d.ts",
21
+ "import": "./dist/index.js"
22
+ }
23
+ },
24
+ "main": "./dist/index.js",
25
+ "module": "./dist/index.js",
26
+ "types": "./dist/index.d.ts",
27
+ "files": [
28
+ "dist"
29
+ ],
30
+ "scripts": {
31
+ "bundle": "tsdown",
32
+ "release": "bun publish --access public"
33
+ },
34
+ "dependencies": {
35
+ "@monstermann/fn": "^0.2.0",
36
+ "@monstermann/signals": "^0.0.0",
37
+ "@monstermann/signals-web": "^0.0.0"
38
+ },
39
+ "devDependencies": {
40
+ "@monstermann/unplugin-fn": "^0.2.0",
41
+ "@monstermann/unplugin-signals": "^0.0.0"
42
+ }
43
+ }