@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.
- package/LICENSE +21 -0
- package/README.md +9 -0
- package/dist/anchor/getAnchorElement.d.ts +4 -0
- package/dist/anchor/getAnchorElement.js +9 -0
- package/dist/anchor/getAnchorMeasurement.d.ts +6 -0
- package/dist/anchor/getAnchorMeasurement.js +10 -0
- package/dist/anchor/internals.js +19 -0
- package/dist/anchor/setAnchorElement.d.ts +4 -0
- package/dist/anchor/setAnchorElement.js +9 -0
- package/dist/anchor/withAnchorElement.d.ts +6 -0
- package/dist/anchor/withAnchorElement.js +32 -0
- package/dist/anchor/withAnchorMeasurement.d.ts +12 -0
- package/dist/anchor/withAnchorMeasurement.js +56 -0
- package/dist/anchor/withMouseAnchor.d.ts +11 -0
- package/dist/anchor/withMouseAnchor.js +57 -0
- package/dist/createModal.d.ts +14 -0
- package/dist/createModal.js +47 -0
- package/dist/floating/getFloatingElement.d.ts +4 -0
- package/dist/floating/getFloatingElement.js +9 -0
- package/dist/floating/getFloatingMeasurement.d.ts +6 -0
- package/dist/floating/getFloatingMeasurement.js +10 -0
- package/dist/floating/internals.js +19 -0
- package/dist/floating/setFloatingElement.d.ts +4 -0
- package/dist/floating/setFloatingElement.js +9 -0
- package/dist/floating/withFloatingElement.d.ts +6 -0
- package/dist/floating/withFloatingElement.js +32 -0
- package/dist/floating/withFloatingMeasurement.d.ts +12 -0
- package/dist/floating/withFloatingMeasurement.js +67 -0
- package/dist/groups/getDialogs.d.ts +4 -0
- package/dist/groups/getDialogs.js +10 -0
- package/dist/groups/getGroupsForModal.d.ts +4 -0
- package/dist/groups/getGroupsForModal.js +10 -0
- package/dist/groups/getModalsForGroup.d.ts +4 -0
- package/dist/groups/getModalsForGroup.js +10 -0
- package/dist/groups/getPopovers.d.ts +4 -0
- package/dist/groups/getPopovers.js +10 -0
- package/dist/groups/getTooltips.d.ts +4 -0
- package/dist/groups/getTooltips.js +10 -0
- package/dist/groups/internals.js +26 -0
- package/dist/groups/isDialog.d.ts +4 -0
- package/dist/groups/isDialog.js +10 -0
- package/dist/groups/isModalInGroup.d.ts +4 -0
- package/dist/groups/isModalInGroup.js +9 -0
- package/dist/groups/isPopover.d.ts +4 -0
- package/dist/groups/isPopover.js +10 -0
- package/dist/groups/isTooltip.d.ts +4 -0
- package/dist/groups/isTooltip.js +10 -0
- package/dist/groups/modalGroups.d.ts +8 -0
- package/dist/groups/modalGroups.js +9 -0
- package/dist/groups/withModalGroups.d.ts +6 -0
- package/dist/groups/withModalGroups.js +29 -0
- package/dist/index.d.ts +57 -0
- package/dist/index.js +57 -0
- package/dist/internals/findParentElement.js +9 -0
- package/dist/internals/observeDimensions.js +23 -0
- package/dist/internals/observePosition.js +44 -0
- package/dist/internals/roundByDPR.js +8 -0
- package/dist/position/getModalPosition.d.ts +6 -0
- package/dist/position/getModalPosition.js +9 -0
- package/dist/position/internals.js +32 -0
- package/dist/position/withBoundary.d.ts +11 -0
- package/dist/position/withBoundary.js +45 -0
- package/dist/position/withPlacement.d.ts +14 -0
- package/dist/position/withPlacement.js +75 -0
- package/dist/position/withPosition.d.ts +22 -0
- package/dist/position/withPosition.js +207 -0
- package/dist/status/closeAllModals.d.ts +4 -0
- package/dist/status/closeAllModals.js +16 -0
- package/dist/status/closeModal.d.ts +4 -0
- package/dist/status/closeModal.js +16 -0
- package/dist/status/getClosedModals.d.ts +4 -0
- package/dist/status/getClosedModals.js +12 -0
- package/dist/status/getClosingModals.d.ts +4 -0
- package/dist/status/getClosingModals.js +12 -0
- package/dist/status/getModalStatus.d.ts +6 -0
- package/dist/status/getModalStatus.js +9 -0
- package/dist/status/getOpenedModals.d.ts +4 -0
- package/dist/status/getOpenedModals.js +12 -0
- package/dist/status/getOpeningModals.d.ts +4 -0
- package/dist/status/getOpeningModals.js +12 -0
- package/dist/status/getVisibleModals.d.ts +4 -0
- package/dist/status/getVisibleModals.js +12 -0
- package/dist/status/internals.js +30 -0
- package/dist/status/isAnyModalClosed.d.ts +4 -0
- package/dist/status/isAnyModalClosed.js +9 -0
- package/dist/status/isAnyModalClosing.d.ts +4 -0
- package/dist/status/isAnyModalClosing.js +9 -0
- package/dist/status/isAnyModalOpened.d.ts +4 -0
- package/dist/status/isAnyModalOpened.js +9 -0
- package/dist/status/isAnyModalOpening.d.ts +4 -0
- package/dist/status/isAnyModalOpening.js +9 -0
- package/dist/status/isAnyModalVisible.d.ts +4 -0
- package/dist/status/isAnyModalVisible.js +9 -0
- package/dist/status/isModalClosed.d.ts +4 -0
- package/dist/status/isModalClosed.js +10 -0
- package/dist/status/isModalClosing.d.ts +4 -0
- package/dist/status/isModalClosing.js +9 -0
- package/dist/status/isModalOpened.d.ts +4 -0
- package/dist/status/isModalOpened.js +9 -0
- package/dist/status/isModalOpening.d.ts +4 -0
- package/dist/status/isModalOpening.js +9 -0
- package/dist/status/isModalVisible.d.ts +4 -0
- package/dist/status/isModalVisible.js +9 -0
- package/dist/status/onModalClosed.d.ts +6 -0
- package/dist/status/onModalClosed.js +12 -0
- package/dist/status/onModalClosing.d.ts +6 -0
- package/dist/status/onModalClosing.js +12 -0
- package/dist/status/onModalOpened.d.ts +6 -0
- package/dist/status/onModalOpened.js +12 -0
- package/dist/status/onModalOpening.d.ts +6 -0
- package/dist/status/onModalOpening.js +12 -0
- package/dist/status/openModal.d.ts +4 -0
- package/dist/status/openModal.js +16 -0
- package/dist/status/setModalStatus.d.ts +6 -0
- package/dist/status/setModalStatus.js +9 -0
- package/dist/status/types.d.ts +4 -0
- package/dist/status/withModalStatus.d.ts +7 -0
- package/dist/status/withModalStatus.js +38 -0
- package/dist/utils/closeLastModalOnClickOutside.d.ts +4 -0
- package/dist/utils/closeLastModalOnClickOutside.js +19 -0
- package/dist/utils/closeLastModalOnEsc.d.ts +4 -0
- package/dist/utils/closeLastModalOnEsc.js +17 -0
- package/dist/utils/syncModalGroupsToBody.d.ts +4 -0
- package/dist/utils/syncModalGroupsToBody.js +24 -0
- package/package.json +43 -0
|
@@ -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,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,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,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,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
|
+
}
|